OSDN Git Service

8422ca06275a6eb0a0d8d946363062daba5c369c
[pf3gnuchains/gcc-fork.git] / gcc / ChangeLog
1 2012-10-29  Alexandre Oliva <aoliva@redhat.com>
2
3         PR debug/54551
4         PR debug/54693
5         * valtrack.c (dead_debug_global_find): Accept NULL dtemp.
6         (dead_debug_global_insert): Return new entry.
7         (dead_debug_global_replace_temp): Return early if REG is no
8         longer in place, or if dtemp was already substituted.
9         (dead_debug_promote_uses): Insert for all defs and replace all
10         debug uses at once.
11         (dead_debug_local_finish): Release used after promotion.
12         (dead_debug_insert_temp): Stop if dtemp is NULL.
13
14 2012-10-29  Alexandre Oliva <aoliva@redhat.com>
15
16         PR debug/54693
17         * loop-unroll.c (loop_exit_at_end_p): Skip debug insns.
18
19 2012-10-29  Alexandre Oliva <aoliva@redhat.com>
20
21         PR debug/54693
22         * config/i386/i386.c (add_parameter_dependencies): Stop
23         backward scan at the insn before the incoming head.
24         (ix86_dependencies_evaluation_hook): Skip debug insns.  Stop
25         if first_arg is head.
26
27 2012-10-29  Andrew Pinski  <apinski@cavium.com>
28
29         * config/aarch64/aarch64-protos.h (aarch64_load_tp): New proto.
30         * config/aarch64/aarch64.c (aarch64_load_tp): Export.
31         (aarch64_init_builtins): Don't add __builtin_thread_pointer builtin.
32         * config/aarch64/aarch64.h (aarch64_builtins): Delete
33
34 AARCH64_BUILTIN_THREAD_POINTER.
35         * config/aarch64/aarch64.md (get_thread_pointerdi): New pattern.
36
37 2012-10-29  Marc Glisse  <marc.glisse@inria.fr>
38
39         PR middle-end/55027
40         * tree.c (real_zerop, real_onep, real_twop, real_minus_onep):
41         Handle VECTOR_CST.
42
43 2012-10-29  Vladimir Makarov  <vmakarov@redhat.com>
44
45         * rtlanal.c (strip_address_mutation): Use SUBREG_REG instead of
46         XEXP.
47
48 2012-10-29  Uros Bizjak  <ubizjak@gmail.com>
49
50         * config/i386/i386.c (ix86_decompose_address): Use simplify_gen_subreg
51         for all addresses, zero-extended with AND.
52
53 2012-10-29  Vladimir Makarov  <vmakarov@redhat.com>
54
55         PR middle-end/55116
56         * rtlanal.c (strip_address_mutation): Add SUBREG case.
57
58 2012-10-29  Jan Hubicka  <jh@suse.cz>
59
60         * ipa-inline.c (want_inline_function_called_once_p): Rename to ...
61         (want_inline_function_to_all_callers_p): check also functions with
62         multiple callers.
63         (ipa_inline): Handle inlining for size into multiple callers.
64
65 2012-10-29  Richard Guenther  <rguenther@suse.de>
66
67         PR middle-end/53695
68         * tracer.c (tracer): Fixup loop structure.
69         * cfgloopmanip.c (force_single_succ_latches): Add assert.
70         (fix_loop_structure): Re-compute loop latches and disambiguate
71         loops with multiple latches if required.
72
73 2012-10-29  Uros Bizjak  <ubizjak@gmail.com>
74
75         * config/i386/i386.c (ix86_decompose_address): Use simplify_gen_subreg
76         to check SImode equivalent of address, zero-extended with AND RTX.
77         * config/i386/i386.md (ashift to lea splitter): Split to SImode mult.
78         (simple lea to add/shift peephole2s): Remove peephole2s that operate
79         on subregs of DImode operations.
80
81 2012-10-28  Vladimir Makarov  <vmakarov@redhat.com>
82
83         PR rtl-optimization/55106
84         * lra-constraints.c (skip_usage_debug_insns): New function.
85         (check_secondary_memory_needed_p): Ditto.
86         (inherit_reload_reg): Use the new functions.  Improve debug output.
87
88 2012-10-29  Jonathan Wakely  <jwakely.gcc@gmail.com>
89
90         * doc/cpp.texi (Search Path): Fix outdated C++ path.
91
92 2012-10-28  Jan Hubicka  <jh@suse.cz>
93
94         * ipa-inline-analysis.c (eliminated_by_inlining_prob): Handle
95         &this->field expressions.
96
97 2012-10-28  Vladimir Makarov  <vmakarov@redhat.com>
98
99         * rtl.h (struct rtx_def): Add a comment for member unchanging.
100         * lra-int.h (LRA_TEMP_CLOBBER_P): New macro.
101         (lra_hard_reg_substitution): Rename to lra_final_code_change.
102         * lra-constraints.c (match_reload): Mark temporary clobbers.
103         * lra-spill.c (lra_hard_reg_substitution): Rename to
104         lra_final_code_change.  Remove temporary clobbers.
105         * lra.c (lra): Rename to lra_final_code_change.
106
107 2012-10-28  Jan Hubicka  <jh@suse.cz>
108
109         * ipa-inline.c (edge_badness): Fix overflow.
110         (inline_small_functions): Initialize SCCs correctly.
111         (do_estimate_edge_time, do_estimate_edge_hints): Skip self
112         recursive functions in SCC hints.
113
114 2012-10-28  Steven Bosscher  <steven@gcc.gnu.org>
115
116         PR rtl-optimization/38711
117         * ira.c (ira): Remove DF_LIVE if the problem is in the stack.
118         (do_reload): Add it back at the end for -O2 and higher.
119
120         * function.c (thread_prologue_and_epilogue_insns): Use
121         REG_SET_TO_HARD_REG_SET instead of CLEAR_HARD_REG_SET and
122         reg_set_to_hard_reg_set.
123
124 2012-10-28  Jan Hubicka  <jh@suse.cz>
125
126         * ipa-inline.c (edge_badness): Reduce precision; use scc hints.
127         (inline_small_functions): Fix dumps; update all callees after inlining.
128         * ipa-inline.h (INLINE_HINT_in_scc, INLINE_HINT_same_scc): New
129         constants.
130         (inline summary): Add SCC_NO.
131         * ipa-inline-analysis.c (dump_inline_hints): Dump SCC hints.
132         (reset_inline_summary): Reset scc_no.
133         (estimate_node_size_and_time): Set in_scc hint.
134         (do_estimate_edge_time): Add same_scc hint.
135         (do_estimate_edge_hints): Likewise.
136
137 2012-10-28  Andreas Schwab  <schwab@linux-m68k.org>
138
139         * doc/cppopts.texi: Fix use of @item vs. @itemx inside @table.
140         * doc/extend.texi: Likewise.
141         * doc/generic.texi: Likewise.
142         * doc/invoke.texi: Likewise.
143         * doc/md.texi: Likewise.
144         * doc/sourcebuild.texi: Likewise.
145
146         * doc/tm.texi.in (Misc): Add newline before @end.
147         * doc/tm.texi: Update.
148
149 2012-10-27  Joern Rennecke  <joern.rennecke@embecosm.com>
150
151         * lra-assigns.c (find_hard_regno_for): Fix use of WORDS_BIG_ENDIAN.
152
153 2012-10-27  Georg-Johann Lay  <avr@gjlay.de>
154
155         PR target/55034
156         * config/avr/avr.c (avr_out_lpm): Remove unused regno_dest.
157
158 2012-10-27  Oleg Endo  <olegendo@gcc.gnu.org>
159
160         PR target/55042
161         * config/sh/sh.c (sh1_builtin_p): Comment out unused function.
162
163 2012-10-27  Uros Bizjak  <ubizjak@gmail.com>
164
165         * config/i386/i386.md (*lea<mode>): Remove unneeded temporary.
166
167 2012-10-26  David S. Miller  <davem@davemloft.net>
168
169         * config/sparc/constraints.md: Update unused letter list, move
170         "w" near other memory constraints.  Remove no longer relevant
171         comment.
172         * doc/md.texi: Sync sparc constraint documentation with reality.
173
174 2012-10-26  DJ Delorie  <dj@redhat.com>
175
176         * config/rl78/rl78.c (rl78_as_legitimate_address): Do not allow
177         reg+addend addresses for the _far namespace.
178
179 2012-10-26  Segher Boessenkool  <segher@kernel.crashing.org>
180
181         * config/rs6000/sync.md (ATOMIC): Correct DI condition.
182
183 2012-10-26  Jakub Jelinek  <jakub@redhat.com>
184
185         PR debug/54970
186         * cfgexpand.c (expand_debug_expr): Expand &MEM_REF[&var, n]
187         as DEBUG_IMPLICIT_PTR + n if &var expands to DEBUG_IMPLICIT_PTR.
188         * tree-sra.c (create_access_replacement): Allow also MEM_REFs
189         with ADDR_EXPR first operand in DECL_DEBUG_EXPR expressions.
190         * var-tracking.c (track_expr_p): Handle MEM_REFs in DECL_DEBUG_EXPR
191         expressions.
192         * dwarf2out.c (add_var_loc_to_decl): Likewise.
193
194 2012-10-26  Jeff Law  <law@redhat.com>
195
196         * tree-ssa-threadedge.c (cond_arg_set_in_bb): Use last stmt.
197
198 2012-10-26  Gunther Nikl  <gnikl@users.sourceforge.net>
199
200         * common/config/m68k/m68k-common.c (m68k_handle_option): Set
201         gcc_options fields of opts_set for -m68020-40 and -m68020-60.
202
203 2012-10-26  Teresa Johnson  <tejohnson@google.com>
204
205         * ree.c (add_removable_extension): Remove unnecessary
206         mode check with other extension.
207         * testsuite/gcc.c-torture/execute/20111227-2.c: New test.
208         * testsuite/gcc.c-torture/execute/20111227-3.c: Ditto.
209
210 2012-10-26  Jan Hubicka  <jh@suse.cz>
211
212         * ipa-inline-transform.c (inline_call): Only account size changes
213         for !DECL_EXTERNAL.
214
215 2012-10-26  Martin Jambor  <mjambor@suse.cz>
216
217         PR debug/54971
218         * tree-sra.c (struct access): New flag grp_to_be_debug_replaced.
219         (dump_access): Dump the new flag.
220         (analyze_access_subtree): Set the new flag when appropriate.
221         (create_access_replacement): Handle debug replacements differently.
222         (generate_subtree_copies): Handle the grp_to_be_debug_replaced flag.
223         (init_subtree_with_zero): Likewise.
224         (sra_modify_expr): Likewise.
225         (load_assign_lhs_subreplacements): Likewise.
226         (sra_modify_assign): Likewise.
227
228 2012-10-23  Yuri Rumyantsev  <ysrumyan@gmail.com>
229
230         * config/i386/i386.c (insn_is_function_arg) : Add check on CALL
231         instruction.
232         (ix86_dependencies_evaluation_hook): Insert dependencies in all
233         predecessors of call block for non-trivial region avoiding creation
234         of loop-carried dependency to avoid cross-block motion of HW registers.
235
236 2012-10-26  Richard Biener  <rguenther@suse.de>
237
238         PR middle-end/54824
239         * tree-optimize.c (execute_fixup_cfg): Insert __builtin_unreachable
240         at the end of blocks with no successors.
241
242 2012-10-26  Alexander Ivchenko  <alexander.ivchenko@intel.com>
243             Uros Bizjak  <ubizjak@gmail.com>
244
245         * gcc/common/config/i386/i386-common.c
246         (OPTION_MASK_ISA_FXSR_SET): New.
247         (OPTION_MASK_ISA_XSAVE_SET): Likewise.
248         (OPTION_MASK_ISA_XSAVEOPT_SET): Likewise.
249         (ix86_handle_option): Handle mfxsr, mxsave, mxsaveopt options.
250         * gcc/config.gcc (i[34567]86-*-*): Add fxsrintrin.h,
251         xsaveintrin.h, xsaveoptintrin.h.
252         (x86_64-*-*): Likewise.
253         * config/i386/fxsrintrin.h: New header.
254         * config/i386/xsaveintrin.h: Likewise.
255         * config/i386/xsaveoptintrin.h: Likewise.
256         * gcc/config/i386/driver-i386.c (host_detect_local_cpu): Detect
257         FXSR/XSAVE/XSAVEOPT support.
258         * gcc/config/i386/i386-builtin-types.def
259         (VOID_FTYPE_PVOID_INT64): New function type.
260         * gcc/config/i386/i386-c.c: Define __FXSR__, __XSAVE__
261         and __XSAVEOPT__ if needed.
262         * gcc/config/i386/i386.c (ix86_target_string): Define -mfxsr,
263          -mxsave and -mxsaveopt options.
264         (PTA_FXSR): New.
265         (PTA_XSAVE): Likewise.
266         (PTA_XSAVEOPT): Likewise.
267         (ix86_option_override_internal): Handle new option.
268         (processor_alias_table): Added PTA_FXSR, PTA_XSAVE, PTA_XSAVEOPT.
269         (ix86_valid_target_attribute_inner_p): Add OPT_mfxsr,
270         OPT_mxsave, OPT_mxsaveopt.
271         (ix86_builtins): Add IX86_BUILTIN_FXSAVE, IX86_BUILTIN_FXRSTOR,
272         IX86_BUILTIN_FXSAVE64, IX86_BUILTIN_XSAVE, IX86_BUILTIN_XSAVE64,
273         IX86_BUILTIN_XRSTOR, IX86_BUILTIN_XRSTOR64, IX86_BUILTIN_XSAVEOPT,
274         IX86_BUILTIN_XSAVEOPT64.
275         (ix86_expand_builtin): Handle these built-ins.
276         * gcc/config/i386/i386.h (TARGET_FXSR): New.
277         (TARGET_XSAVE): Likewise.
278         (TARGET_XSAVEOPT): Likewise.
279         * gcc/config/i386/i386.md (ANY_XSAVE): New int iterator.
280         (ANY_XSAVE64): Likewise.
281         (xsave): New int attribute.
282         (fxsave): New instruction.
283         (fxsave64): Likewise.
284         (fxrstor): Likewise.
285         (fxrstor64): Likewise.
286         (<xsave>): Likewise.
287         (<xsave>_rex64): Likewise.
288         (xrstor): Likewise.
289         (xrstor_rex64): Likewise.
290         (xrstor64): Likewise.
291         * gcc/config/i386/i386.opt (mfxsr): New.
292         (mxsave): Likewise.
293         (mxsaveopt): Likewise.
294         * gcc/config/i386/x86intrin.h: Include
295         xsaveintrin.h, fxsrintrin.h, xsaveoptintrin.h.
296
297 2012-10-26  Ralf Corsépius  <ralf.corsepius@rtems.org>
298
299         * config/avr/t-rtems: Revert previous commit.
300
301 2012-10-26  Richard Sandiford  <rdsandiford@googlemail.com>
302
303         PR bootstrap/55049
304         * Makefile.in (rtlanal.o): Add dependency on addresses.h.
305         * rtl.h (address_info): New structure.
306         (strip_address_mutations, decompose_address, decompose_lea_address)
307         (decompose_mem_address, update_address, get_index_scale)
308         (get_index_code): Declare.
309         * rtlanal.c: Include addresses.h.
310         (strip_address_mutations, must_be_base_p, must_be_index_p)
311         (set_address_segment, set_address_base, set_address_index)
312         (set_address_disp, decompose_incdec_address, decompose_automod_address)
313         (extract_plus_operands, baseness, decompose_normal_address)
314         (decompose_address, decompose_lea_address, decompose_mem_address)
315         (update_address, get_index_scale, get_index_code): New functions.
316         * lra-constraints.c (strip_subreg): New function.
317         (address, extract_loc_address_regs, extract_address_regs)
318         (get_index_scale): Delete.
319         (process_addr_reg): Apply strip_subreg to the location.
320         (uses_hard_regs_p): Use decompose_mem_address.
321         (valid_address_p, base_plus_disp_to_reg, can_add_disp_p)
322         (equiv_address_substitution): Take an address_info rather
323         than an address.  Remove other arguments.  Avoid using Pmode.
324         (process_address): Use decompose_mem_address and decompose_lea_address.
325         Update calls to above functions.
326
327 2012-10-26  Richard Sandiford  <rdsandiford@googlemail.com>
328
329         * lra-constraints.c (process_address): Tighten arguments to
330         base_reg_class.  Use simplify_gen_binary to generate PLUS rtxes.
331
332 2012-10-26  Richard Sandiford  <rdsandiford@googlemail.com>
333
334         * lra-constraints.c (get_index_scale, can_add_disp_p): New functions.
335         (equiv_address_substitution): Use them.
336
337 2012-10-26  Richard Sandiford  <rdsandiford@googlemail.com>
338
339         * lra-constraints.c (valid_address_p): New function, split out from...
340         (process_address): ...here.
341
342 2012-10-26  Richard Sandiford  <rdsandiford@googlemail.com>
343
344         * lra-constraints.c (process_address): Describe the kinds of address
345         that we might see.
346
347 2012-10-25  Vladimir Makarov  <vmakarov@redhat.com>
348
349         * lra-int.h (lra_assert): Redefine it gcc_checking_assert.
350         * lra-constraints.c (check_and_process_move): Remove #if
351         ENABLE_ASSERT_CHECKING.
352
353 2012-10-26  Ralf Corsépius  <ralf.corsepius@rtems.org>
354
355         * config/avr/rtems.h (TARGET_OS_CPP_BUILTINS): Remove
356         __USE_INIT_FINI__.
357         * config/avr/t-rtems (LIB1ASMFUNCS): Filter out _exit.
358
359 2012-10-25  David S. Miller  <davem@davemloft.net>
360
361         * config/sparc/constraints.md ("U"): Delete.
362         * config/sparc/sparc.md: Use 'r' constraint instead of 'U'.
363         * config/sparc/sync.md: Likewise.
364
365 2012-10-25  Lawrence Crowl  <crowl@google.com>
366
367         * hash-table.h: Add usage documentation.
368         (template struct typed_free_remove): Clarify documentation.
369         Rename template parameter.
370         (struct typed_noop_remove): Likewise.
371         (descriptor concept): Change typedef T to value_type.
372         Add typedef compare_type.  Use more precise template parameter name,
373         Descriptor instead of Descr.  Update users to match.
374         (struct hash_table): Change 'find' parameters to use compare_type
375         instead of the value type.
376
377 2012-10-25  Jan Hubicka  <jh@suse.cz>
378
379         * ipa-cp.c (ipcp_discover_new_direct_edges): If something was turned
380         to direct call update the summary.
381         * ipa-inline-transform.c (inline_call): Sanity check that summaries
382         match the predicted effect; fix updating of summary after edge
383         redirection.
384         * ipa-inline-analysis.c (inline_node_duplication_hook): Do not try
385         to update the summary and recompute it instead.
386         (estimate_function_body_sizes): Fix self size estimation; double
387         check that it agrees with inline_update_overall_summary.
388         (estimate_edge_size_and_time): Handle devirtualizaiton costs.
389         (estimate_edge_devirt_benefit): Update to be called from
390         estimate_edge_size_and_time.
391         (estimate_calls_size_and_time): Update.
392         (estimate_node_size_and_time): Watch overflows.
393         (inline_merge_summary): Likewise.
394         * ipa-prob.c: Include ipa-inline.h
395         (ipa_make_edge_direct_to_target): After redirection update the summary.
396
397 2012-10-25  Cary Coutant  <ccoutant@google.com>
398
399         PR debug/55063
400         * dwarf2out.c (prune_unused_types_prune): Check whether DIE is
401         already a declaration.
402
403 2012-10-25  Vladimir Makarov  <vmakarov@redhat.com>
404
405         * lra-assigns.c (assign_by_spills): Add non-reload pseudos
406         assigned to hard register to changed_pseudo_bitmap.
407
408 2012-10-25  Ralf Corsépius  <ralf.corsepius@rtems.org>
409
410         * config.gcc (microblaze*-*-rtems*): New target.
411         * config/microblaze/rtems.h: New.
412         * config/microblaze/t-rtems: New.
413
414 2012-10-25  Jan Hubicka  <jh@suse.cz>
415
416         PR tree-optimize/54980
417         * tree-ssa-loop-ivcanon.c (constant_after_peeling): Fix obvious typo.
418         (loop_edge_to_cancel): Be sure that the edge is from an conditional
419         so we can cancel it.
420
421 2012-10-25  Marc Glisse  <marc.glisse@inria.fr>
422
423         PR c++/54427
424         * tree.c (signed_or_unsigned_type_for): Handle vectors.
425
426 2012-10-25  Jan Hubicka  <jh@suse.cz>
427
428         * ipa-inline.c (recursive_inlining): Redirect to master
429         clone before testing profitability.
430
431 2012-10-25  Richard Biener  <rguenther@suse.de>
432
433         PR tree-optimization/54902
434         * tree-ssa-pre.c (fini_eliminate): Return TODO.
435         (do_pre): Adjust.
436         (execute_fre): Likewise.
437         * tree-ssa-tailmerge.c (tail_merge_optimize): Delete unreachable
438         blocks before computing dominators.
439
440 2012-10-25  Richard Sandiford  <rdsandiford@googlemail.com>
441
442         * expr.c (emit_block_move_via_loop): Use simplify_gen_binary
443         rather than gen_rtx_PLUS.
444
445 2012-10-24  Vladimir Makarov  <vmakarov@redhat.com>
446
447         PR bootstrap/55068
448         PR regression/55050
449         * ira.c (setup_reg_renumber): Fix assert.
450         * ira-emit.c (emit_move_list): Update equivalences only for LRA.
451
452 2012-10-24  Vladimir Makarov  <vmakarov@redhat.com>
453
454         PR bootstrap/55067
455         * lra.c: Rename loc to sloc and loc_t to sloc_t.
456
457 2012-10-24  Sharad Singhai  <singhai@google.com>
458
459         * config/rs6000/rs6000.c (rs6000_density_test): Use dump_enabled_p
460           instead of dump_kind_p.
461
462 2012-10-24  Manuel López-Ibáñez  <manu@gcc.gnu.org>
463
464         PR c++/54928
465         * tree-diagnostic.c (maybe_unwind_expanded_macro_loc):
466         Use diagnostic_append_note.
467         * diagnostic.c (diagnostic_build_prefix): Make diagnostic const.
468         (default_diagnostic_finalizer): Do not destroy prefix here.
469         (diagnostic_report_diagnostic): Destroy it here.
470         (diagnostic_append_note): New.
471         * diagnostic.h (diagnostic_append_note): Declare.
472
473 2012-10-24  Vladimir Makarov  <vmakarov@redhat.com>
474
475         PR rtl-optimization/55055
476         * lra-spills.c (alter_subregs): New function.
477         (lra_hard_reg_substitution): Use it.
478
479 2012-10-24  Sharad Singhai  <singhai@google.com>
480
481         * dumpfile.c (dump_enabled_p): Make it inline and move the definition
482         to dumpfile.h.
483         (dump_kind_p): Deleted. Functionality replaced by dump_enabled_p.
484         Make alt_dump_file extern.
485         * dumpfile.h (dump_enabled_p): Move inline definition here.
486         (dump_kind_p): Delete declaration.
487         Add extern declaration of alt_dump_file.
488         * toplev.c: Move dump_file and dump_file_name to dumpfile.c.
489         * tree-vect-loop-manip.c: Replace all uses of dump_kind_p with
490         dump_enabled_p.
491         * tree-vectorizer.c: Likewise.
492         * tree-vect-loop.c: Likewise.
493         * tree-vect-data-refs.c: Likewise.
494         * tree-vect-patterns.c: Likewise.
495         * tree-vect-stmts.c: Likewise.
496         * tree-vect-slp.c: Likewise.
497
498 2012-10-24  Richard Sandiford  <rdsandiford@googlemail.com>
499
500         * expmed.c (lowpart_bit_field_p): Add missing == 0 check.
501
502 2012-10-24  Vladimir Makarov  <vmakarov@redhat.com>
503
504         PR bootstrap/55049
505         * lra-constraints.c (extract_loc_address_regs): Pass top_p for
506         ZERO_EXTEND operand.
507
508 2012-10-24  Vladimir Makarov  <vmakarov@redhat.com>
509
510         PR bootstrap/55048
511         * lra-constraints.c (update_ebb_live_info): Skip
512         non-NOTE_INSN_BASIC_BLOCK notes.
513
514 2012-10-24  Jakub Jelinek  <jakub@redhat.com>
515
516         PR rtl-optimization/55010
517         * cse.c (fold_rtx) <RTX_COMPARE>: Call copy_rtx on folded_arg{0,1}
518         before passing it to simplify_relational_operation.
519
520         PR debug/54828
521         * gimple.h (is_gimple_sizepos): New inline function.
522         * gimplify.c (gimplify_one_sizepos): Use it.  Remove useless
523         final assignment to expr variable.
524         * tree.c (RETURN_TRUE_IF_VAR): Return true also if
525         !TYPE_SIZES_GIMPLIFIED (type) and _t is going to be gimplified
526         into a local temporary.
527
528 2012-10-23  David S. Miller  <davem@davemloft.net>
529
530         * config/sparc/constraints.md ("T", "W"): Change
531         definitions to use define_memory_constraint.  Do not match 'reg'.
532         * config/sparc/sparc.c (memory_ok_for_ldd): Remove all non-MEM
533         handling code, update comment.
534
535 2012-10-23  Ian Lance Taylor  <iant@google.com>
536
537         * doc/extend.texi (Extended Asm): The '+' constraint does not
538         require a register.
539
540 2012-10-23  Jeff Law  <law@redhat.com>
541
542         * tree-ssa-threadedge.c (thread_across_edge): Remove unused
543         parameter in call to cond_arg_set_in_bb.
544
545         * tree-ssa-threadedge.c (cond_arg_set_in_bb): Remove unused
546         debugging argument.
547
548         PR tree-optimization/54985
549         * tree-ssa-threadedge.c (cond_arg_set_in_bb): New function extracted
550         from thread_across_edge.
551         (thread_across_edge): Use it in all cases where we might thread
552         across a back edge.
553
554 2012-10-23  Vladimir Makarov  <vmakarov@redhat.com>
555
556         * lra-constraints.c (update_ebb_live_info): Process empty blocks.
557
558 2012-10-23  Richard Sandiford  <rdsandiford@googlemail.com>
559
560         * expmed.c (store_split_bit_field): Update the calls to
561         extract_fixed_bit_field.  In the big-endian case, always
562         use the mode of OP0 to count the number of significant bits.
563         (extract_bit_field_1): Remove unit, offset, bitpos and
564         byte_offset from the outermost scope.  Express conditions in terms
565         of bitnum rather than offset, bitpos and byte_offset.  Move the
566         computation of MODE1 to the block that needs it.  Use MODE unless
567         the TMODE-based mode_for_size calculation succeeds.  Split the
568         plain move cases into two, one for memory accesses and one for
569         register accesses.  Generalize the memory case, freeing it from
570         the old register-based endian checks.  Move the INT_MODE calculation
571         above the code that needs it.  Use simplify_gen_subreg to handle
572         multiword OP0s.  If the field still spans several words, pass it
573         directly to extract_split_bit_field.  Assume after that point
574         that both targets and register sources fit within a word.
575         Replace x-prefixed variables with non-prefixed forms.
576         Compute the bitpos for ext(z)v register operands directly in the
577         chosen unit size, rather than going through an intermediate
578         BITS_PER_WORD unit size.  Simplify the containment check
579         used when forcing OP0 into a register.  Update the call to
580         extract_fixed_bit_field.
581         (extract_fixed_bit_field): Replace the bitpos and offset parameters
582         with a single bitnum parameter, of the same form as extract_bit_field.
583         Assume that OP0 contains the full field.  Simplify the memory offset
584         calculation and containment check for volatile bitfields.  Make the
585         offset explicit when volatile bitfields force a misaligned access.
586         Remove WARNED and fix long lines.  Assert that the processed OP0
587         has an integral mode.
588         (store_split_bit_field): Update the call to store_fixed_bit_field.
589
590 2012-10-23  Richard Sandiford  <rdsandiford@googlemail.com>
591
592         * expmed.c (lowpart_bit_field_p): New function.
593         (store_bit_field_1): Remove unit, offset, bitpos and byte_offset
594         from the outermost scope.  Express conditions in terms of bitnum
595         rather than offset, bitpos and byte_offset.  Split the plain move
596         cases into two, one for memory accesses and one for register accesses.
597         Allow simplify_gen_subreg to fail rather than calling validate_subreg.
598         Move the handling of multiword OP0s after the code that coerces VALUE
599         to an integer mode.  Use simplify_gen_subreg for this case and assert
600         that it succeeds.  If the field still spans several words, pass it
601         directly to store_split_bit_field.  Assume after that point that
602         both sources and register targets fit within a word.  Replace
603         x-prefixed variables with non-prefixed forms.  Compute the bitpos
604         for insv register operands directly in the chosen unit size, rather
605         than going through an intermediate BITS_PER_WORD unit size.
606         Update the call to store_fixed_bit_field.
607         (store_fixed_bit_field): Replace the bitpos and offset parameters
608         with a single bitnum parameter, of the same form as store_bit_field.
609         Assume that OP0 contains the full field.  Simplify the memory offset
610         calculation.  Assert that the processed OP0 has an integral mode.
611         (store_split_bit_field): Update the call to store_fixed_bit_field.
612
613 2012-10-23  Paul Koning  <ni1d@arrl.net>
614
615         PR debug/54508
616         * dwarf2out.c (prune_unused_types_prune): If pruning a class and
617         not all its children were marked, add DW_AT_declaration flag.
618
619 2012-10-23  Ian Bolton  <ian.bolton@arm.com>
620             James Greenhalgh  <james.greenhalgh@arm.com>
621             Jim MacArthur  <jim.macarthur@arm.com>
622             Marcus Shawcroft  <marcus.shawcroft@arm.com>
623             Nigel Stephens  <nigel.stephens@arm.com>
624             Ramana Radhakrishnan  <ramana.radhakrishnan@arm.com>
625             Richard Earnshaw  <rearnsha@arm.com>
626             Sofiane Naci  <sofiane.naci@arm.com>
627             Stephen Thomas  <stephen.thomas@arm.com>
628             Tejas Belagod  <tejas.belagod@arm.com>
629             Yufeng Zhang  <yufeng.zhang@arm.com>
630
631         * config.gcc: Add AArch64.
632         * configure.ac: Add AArch64 TLS support detection.
633         * configure: Regenerate.
634
635 2012-10-23  Ian Bolton  <ian.bolton@arm.com>
636             James Greenhalgh  <james.greenhalgh@arm.com>
637             Jim MacArthur  <jim.macarthur@arm.com>
638             Chris Schlumberger-Socha <chris.schlumberger-socha@arm.com>
639             Marcus Shawcroft  <marcus.shawcroft@arm.com>
640             Nigel Stephens  <nigel.stephens@arm.com>
641             Ramana Radhakrishnan  <ramana.radhakrishnan@arm.com>
642             Richard Earnshaw  <rearnsha@arm.com>
643             Sofiane Naci  <sofiane.naci@arm.com>
644             Stephen Thomas  <stephen.thomas@arm.com>
645             Tejas Belagod  <tejas.belagod@arm.com>
646             Yufeng Zhang  <yufeng.zhang@arm.com>
647
648         * doc/invoke.texi (AArch64 Options): New.
649         * doc/md.texi (Machine Constraints): Add AArch64.
650
651 2012-10-23  Ian Bolton  <ian.bolton@arm.com>
652             James Greenhalgh  <james.greenhalgh@arm.com>
653             Jim MacArthur  <jim.macarthur@arm.com>
654             Chris Schlumberger-Socha <chris.schlumberger-socha@arm.com>
655             Marcus Shawcroft  <marcus.shawcroft@arm.com>
656             Nigel Stephens  <nigel.stephens@arm.com>
657             Ramana Radhakrishnan  <ramana.radhakrishnan@arm.com>
658             Richard Earnshaw  <rearnsha@arm.com>
659             Sofiane Naci  <sofiane.naci@arm.com>
660             Stephen Thomas  <stephen.thomas@arm.com>
661             Tejas Belagod  <tejas.belagod@arm.com>
662             Yufeng Zhang  <yufeng.zhang@arm.com>
663
664         * common/config/aarch64/aarch64-common.c: New file.
665         * config/aarch64/aarch64-arches.def: New file.
666         * config/aarch64/aarch64-builtins.c: New file.
667         * config/aarch64/aarch64-cores.def: New file.
668         * config/aarch64/aarch64-elf-raw.h: New file.
669         * config/aarch64/aarch64-elf.h: New file.
670         * config/aarch64/aarch64-generic.md: New file.
671         * config/aarch64/aarch64-linux.h: New file.
672         * config/aarch64/aarch64-modes.def: New file.
673         * config/aarch64/aarch64-option-extensions.def: New file.
674         * config/aarch64/aarch64-opts.h: New file.
675         * config/aarch64/aarch64-protos.h: New file.
676         * config/aarch64/aarch64-simd.md: New file.
677         * config/aarch64/aarch64-tune.md: New file.
678         * config/aarch64/aarch64.c: New file.
679         * config/aarch64/aarch64.h: New file.
680         * config/aarch64/aarch64.md: New file.
681         * config/aarch64/aarch64.opt: New file.
682         * config/aarch64/arm_neon.h: New file.
683         * config/aarch64/constraints.md: New file.
684         * config/aarch64/gentune.sh: New file.
685         * config/aarch64/iterators.md: New file.
686         * config/aarch64/large.md: New file.
687         * config/aarch64/predicates.md: New file.
688         * config/aarch64/small.md: New file.
689         * config/aarch64/sync.md: New file.
690         * config/aarch64/t-aarch64-linux: New file.
691         * config/aarch64/t-aarch64: New file.
692
693 2012-10-23  Michael Matz  <matz@suse.de>
694
695         * tree-ssa-operands.h (struct def_optype_d, def_optype_p): Remove.
696         (ssa_operands.free_defs): Remove.
697         (DEF_OP_PTR, DEF_OP): Remove.
698         (struct ssa_operand_iterator_d): Remove 'defs', add 'flags' members,
699         rename 'phi_stmt' to 'stmt', 'phi_i' to 'i' and 'num_phi' to 'numops'.
700         * gimple.h (gimple_statement_with_ops.def_ops): Remove.
701         (gimple_def_ops, gimple_set_def_ops): Remove.
702         (gimple_vdef_op): Don't take const gimple, adjust.
703         (gimple_asm_input_op, gimple_asm_input_op_ptr,
704         gimple_asm_set_input_op, gimple_asm_output_op,
705         gimple_asm_output_op_ptr, gimple_asm_set_output_op): Adjust asserts,
706         and rewrite to move def operands to front.
707         (gimple_asm_clobber_op, gimple_asm_set_clobber_op,
708         gimple_asm_label_op, gimple_asm_set_label_op): Correct asserts.
709         * tree-ssa-operands.c (build_defs): Remove.
710         (init_ssa_operands): Don't initialize it.
711         (fini_ssa_operands): Don't free it.
712         (cleanup_build_arrays): Don't truncate it.
713         (finalize_ssa_stmt_operands): Don't assert on it.
714         (alloc_def, add_def_op, append_def): Remove.
715         (finalize_ssa_defs): Remove building of def_ops list.
716         (finalize_ssa_uses): Don't mark for SSA renaming here, ...
717         (add_stmt_operand): ... but here, don't call append_def.
718         (get_indirect_ref_operands): Remove recurse_on_base argument.
719         (get_expr_operands): Adjust call to get_indirect_ref_operands.
720         (verify_ssa_operands): Don't check def operands.
721         (free_stmt_operands): Don't free def operands.
722         * gimple.c (gimple_copy): Don't clear def operands.
723         * tree-flow-inline.h (op_iter_next_use): Adjust to explicitely
724         handle def operand.
725         (op_iter_next_tree, op_iter_next_def): Ditto.
726         (clear_and_done_ssa_iter): Clear new fields.
727         (op_iter_init): Adjust to setup new iterator structure.
728         (op_iter_init_phiuse): Adjust.
729
730 2012-10-23  Greta Yorsh  <Greta.Yorsh@arm.com>
731
732         * config/arm/arm.c (offset_ok_for_ldrd_strd): Return false for Thumb1.
733
734 2012-10-23  Vladimir Makarov  <vmakarov@redhat.com>
735
736         * dbxout.c (dbxout_symbol_location): Pass new argument to alter_subreg.
737         * dwarf2out.c: Include ira.h and lra.h.
738         (based_loc_descr, compute_frame_pointer_to_fb_displacement): Use
739         lra_eliminate_regs for LRA instead of eliminate_regs.
740         * expr.c (emit_move_insn_1): Pass an additional argument to
741         emit_move_via_integer.  Use emit_move_via_integer for LRA only if
742         the insn is recognized.
743         * emit-rtl.c (gen_rtx_REG): Add lra_in_progress.
744         (validate_subreg): Don't check offset for LRA and floating point modes.
745         * final.c (final_scan_insn, cleanup_subreg_operands): Pass new
746         argument to alter_subreg.
747         (walk_alter_subreg, output_operand): Ditto.
748         (alter_subreg): Add new argument.
749         * gcse.c (calculate_bb_reg_pressure): Add parameter to
750         ira_setup_eliminable_regset call.
751         * ira.c: Include lra.h.
752         (ira_init_once, ira_init, ira_finish_once): Call lra_start_once,
753         lra_init, lra_finish_once in anyway.
754         (ira_setup_eliminable_regset): Add parameter.  Remove need_fp.
755         Call lra_init_elimination and mark HARD_FRAME_POINTER_REGNUM as
756         living forever if frame_pointer_needed.
757         (setup_reg_class_relations): Set up ira_reg_class_subset.
758         (ira_reg_equiv_invariant_p, ira_reg_equiv_const): Remove.
759         (find_reg_equiv_invariant_const): Ditto.
760         (setup_reg_renumber): Use ira_equiv_no_lvalue_p instead of
761         ira_reg_equiv_invariant_p.  Skip caps for LRA.
762         (setup_reg_equiv_init, ira_update_equiv_info_by_shuffle_insn): New
763         functions.
764         (ira_reg_equiv_len, ira_reg_equiv): New externals.
765         (ira_reg_equiv): New.
766         (ira_expand_reg_equiv, init_reg_equiv, finish_reg_equiv): New
767         functions.
768         (no_equiv, update_equiv_regs): Use ira_reg_equiv instead of
769         reg_equiv_init.
770         (setup_reg_equiv): New function.
771         (ira_use_lra_p): New global.
772         (ira): Set up lra_simple_p and ira_conflicts_p.  Set up and
773         restore flag_caller_saves and flag_ira_region.  Move
774         initialization of ira_obstack and ira_bitmap_obstack upper.  Call
775         init_reg_equiv, setup_reg_equiv, and setup_reg_equiv_init instead
776         of initialization of ira_reg_equiv_len, ira_reg_equiv_invariant_p,
777         and ira_reg_equiv_const.  Call ira_setup_eliminable_regset with a
778         new argument.  Don't flatten IRA IRA for LRA.  Don't reassign
779         conflict allocnos for LRA. Call finish_reg_equiv.
780         (do_reload): Prepare code for LRA call.  Call LRA.
781         * ira.h (ira_use_lra_p): New external.
782         (struct target_ira): Add members x_ira_class_subset_p
783         x_ira_reg_class_subset, and x_ira_reg_classes_intersect_p.
784         (ira_class_subset_p, ira_reg_class_subset): New macros.
785         (ira_reg_classes_intersect_p): New macro.
786         (struct ira_reg_equiv): New.
787         (ira_setup_eliminable_regset): Add an argument.
788         (ira_expand_reg_equiv, ira_update_equiv_info_by_shuffle_insn): New
789         prototypes.
790         * ira-color.c (color_pass, move_spill_restore, coalesce_allocnos):
791         Use ira_equiv_no_lvalue_p.
792         (coalesce_spill_slots, ira_sort_regnos_for_alter_reg): Ditto.
793         * ira-emit.c (ira_create_new_reg): Call ira_expand_reg_equiv.
794         (generate_edge_moves, change_loop) Use ira_equiv_no_lvalue_p.
795         (emit_move_list): Simplify code.  Call
796         ira_update_equiv_info_by_shuffle_insn.  Use ira_reg_equiv instead
797         of ira_reg_equiv_invariant_p and ira_reg_equiv_const.  Change assert.
798         * ira-int.h (struct target_ira_int): Remove x_ira_class_subset_p
799         and x_ira_reg_classes_intersect_p.
800         (ira_class_subset_p, ira_reg_classes_intersect_p): Remove.
801         (ira_reg_equiv_len, ira_reg_equiv_invariant_p): Ditto.
802         (ira_reg_equiv_const): Ditto.
803         (ira_equiv_no_lvalue_p): New function.
804         * jump.c (true_regnum): Always use hard_regno for subreg_get_info
805         when lra is in progress.
806         * haifa-sched.c (sched_init): Pass new argument to
807         ira_setup_eliminable_regset.
808         * loop-invariant.c (calculate_loop_reg_pressure): Pass new
809         argument to ira_setup_eliminable_regset.
810         * lra.h: New.
811         * lra-int.h: Ditto.
812         * lra.c: Ditto.
813         * lra-assigns.c: Ditto.
814         * lra-constraints.c: Ditto.
815         * lra-coalesce.c: Ditto.
816         * lra-eliminations.c: Ditto.
817         * lra-lives.c: Ditto.
818         * lra-spills.c: Ditto.
819         * Makefile.in (LRA_INT_H): New.
820         (OBJS): Add lra.o, lra-assigns.o, lra-coalesce.o, lra-constraints.o,
821         lra-eliminations.o, lra-lives.o, and lra-spills.o.
822         (dwarf2out.o): Add dependence on ira.h and lra.h.
823         (ira.o): Add dependence on lra.h.
824         (lra.o, lra-assigns.o, lra-coalesce.o, lra-constraints.o): New entries.
825         (lra-eliminations.o, lra-lives.o, lra-spills.o): Ditto.
826         * output.h (alter_subreg): Add new argument.
827         * rtlanal.c (simplify_subreg_regno): Permit mode changes for LRA.
828         Permit ARG_POINTER_REGNUM and STACK_POINTER_REGNUM for LRA.
829         * recog.c (general_operand, register_operand): Accept paradoxical
830         FLOAT_MODE subregs for LRA.
831         (scratch_operand): Accept pseudos for LRA.
832         * rtl.h (lra_in_progress): New external.
833         (debug_bb_n_slim, debug_bb_slim, print_value_slim): New prototypes.
834         (debug_rtl_slim, debug_insn_slim): Ditto.
835         * sdbout.c (sdbout_symbol): Pass new argument to alter_subreg.
836         * sched-vis.c (print_value_slim): New.
837         * target.def (lra_p): New hook.
838         (register_priority): Ditto.
839         (different_addr_displacement_p): Ditto.
840         (spill_class): Ditto.
841         * target-globals.h (this_target_lra_int): New external.
842         (target_globals): New member lra_int.
843         (restore_target_globals): Restore this_target_lra_int.
844         * target-globals.c: Include lra-int.h.
845         (default_target_globals): Add &default_target_lra_int.
846         * targhooks.c (default_lra_p): New function.
847         (default_register_priority): Ditto.
848         (default_different_addr_displacement_p): Ditto.
849         * targhooks.h (default_lra_p): Declare.
850         (default_register_priority): Ditto.
851         (default_different_addr_displacement_p): Ditto.
852         * timevar.def (TV_LRA, TV_LRA_ELIMINATE, TV_LRA_INHERITANCE): New.
853         (TV_LRA_CREATE_LIVE_RANGES, TV_LRA_ASSIGN, TV_LRA_COALESCE): New.
854         * config/arm/arm.c (load_multiple_sequence): Pass new argument to
855         alter_subreg.
856         (store_multiple_sequence): Ditto.
857         * config/i386/i386.h (enum ix86_tune_indices): Add
858         X86_TUNE_GENERAL_REGS_SSE_SPILL.
859         (TARGET_GENERAL_REGS_SSE_SPILL): New macro.
860         * config/i386/i386.c (initial_ix86_tune_features): Set up
861         X86_TUNE_GENERAL_REGS_SSE_SPILL for m_COREI7 and m_CORE2I7.
862         (ix86_lra_p, ix86_register_priority): New functions.
863         (ix86_secondary_reload): Add NON_Q_REGS, SIREG, DIREG.
864         (inline_secondary_memory_needed): Change assert.
865         (ix86_spill_class): New function.
866         (TARGET_LRA_P, TARGET_REGISTER_BANK, TARGET_SPILL_CLASS): New macros.
867         * config/m68k/m68k.c (emit_move_sequence): Pass new argument to
868         alter_subreg.
869         * config/m32r/m32r.c (gen_split_move_double): Ditto.
870         * config/pa/pa.c (pa_emit_move_sequence): Ditto.
871         * config/sh/sh.md: Ditto.
872         * config/v850/v850.c (v850_reorg): Ditto.
873         * config/xtensa/xtensa.c (fixup_subreg_mem): Ditto.
874         * doc/md.texi: Add new interpretation of hint * for LRA.
875         * doc/passes.texi: Describe LRA pass.
876         * doc/tm.texi.in: Add TARGET_LRA_P, TARGET_REGISTER_PRIORITY,
877         TARGET_DIFFERENT_ADDR_DISPLACEMENT_P, and TARGET_SPILL_CLASS.
878         * doc/tm.texi: Update.
879
880 2012-10-23  Jan Hubicka  <jh@suse.cz>
881
882         * loop-unroll.c (decide_peel_simple): Simple peeling makes sense even
883         with simple loops; bound number of branches only when FDO is not
884         available.
885         (decide_unroll_stupid): Mention that num_loop_branches heuristics
886         is off.
887
888 2012-10-23  Nick Clifton  <nickc@redhat.com>
889
890         PR target/54660
891         * config/iq2000/iq2000.c (iq2000_function_arg_advance): Suppress
892         compile time warning about pointer printing.
893
894 2012-10-23  Joseph Myers  <joseph@codesourcery.com>
895
896         * config.gcc (*-*-linux* | frv-*-*linux* | *-*-kfreebsd*-gnu |
897         *-*-knetbsd*-gnu | *-*-gnu* | *-*-kopensolaris*-gnu): Use
898         glibc-c.o in c_target_objs and cxx_target_objs.  Use t-glibc in
899         tmake_file.  Set target_has_targetcm.
900         (tilegx-*-linux*, tilepro-*-linux*): Append to c_target_objs and
901         cxx_target_objs rather than overriding previous value.
902         * config/glibc-c.c, config/t-glibc: New.
903         * doc/tm.texi.in (TARGET_C_PREINCLUDE): New @hook.
904         * doc/tm.texi: Regenerate.
905         * hooks.c (hook_constcharptr_void_null): New.
906         * hooks.h (hook_constcharptr_void_null): Declare.
907
908 2012-10-23  Eric Botcazou  <ebotcazou@adacore.com>
909
910         * config/mips/linux-common.h (STACK_CHECK_STATIC_BUILTIN): Define.
911         (STACK_CHECK_PROTECT): Likewise.
912         * config/mips/mips.h (MIPS_PROLOGUE_TEMP2_REGNUM): Likewise.
913         (MIPS_PROLOGUE_TEMP2): Likewise.
914         * config/mips/mips-protos.h (mips_output_probe_stack_range): Declare.
915         * config/mips/mips.c: Include common/common-target.h.
916         (mips_emit_probe_stack_range): New function.
917         (mips_output_probe_stack_range): Likewise.
918         (mips_expand_prologue): Invoke mips_emit_probe_stack_range if static
919         builtin stack checking is enabled.
920         * config/mips/mips.md (UNSPEC_PROBE_STACK_RANGE): New constant.
921         (probe_stack_range_<P:mode>): New insn.
922
923 2012-10-23  Marc Glisse  <marc.glisse@inria.fr>
924
925         * tree-ssa-forwprop.c (forward_propagate_into_cond): Handle vectors.
926         * fold-const.c (fold_relational_const): Handle VECTOR_CST.
927         * doc/generic.texi (VEC_COND_EXPR): Document current policy.
928
929 2012-10-23  Jan Hubicka  <jh@suse.cz>
930
931         PR middle-end/54937
932         * tree-ssa-loop-niter.c (record_estimate): Do not try to lower
933         the bound of non-is_exit statements.
934         (maybe_lower_iteration_bound): Do it here.
935         (estimate_numbers_of_iterations_loop): Call it.
936
937 2012-10-23  Jan Hubicka  <jh@suse.cz>
938
939         PR middle-end/54967
940         * cfgloopmanip.c (fix_bb_placements): Add loop_closed_ssa_invalidated;
941         track basic blocks that moved out of their loops.
942         (unloop): Likewise.
943         (remove_path): Update.
944         (fix_loop_placements): Update.
945         * tree-ssa-loop-ivcanon.c (try_unroll_loop_completely): Add
946         loop_closed_ssa_invalidated parameter; pass it around.
947         (canonicalize_loop_induction_variables): Update loop closed
948         SSA form if needed.
949         (tree_unroll_loops_completely): Likewise; do irred update out of
950         the outer loop; verify that SSA form is closed.
951         * cfgloop.h (unrloop): Update.
952
953 2012-10-23  Terry Guo  <terry.guo@arm.com>
954
955         PR target/55019
956         * config/arm/arm.c (thumb1_expand_prologue): Don't push high regs with
957         live argument regs.
958
959 2012-10-23  Hans-Peter Nilsson  <hp@bitrange.com>
960
961         PR middle-end/55030
962         Revert:
963         * stmt.c (expand_nl_goto_receiver): Remove almost-copy of
964         expand_builtin_setjmp_receiver.
965         (expand_label): Adjust, call expand_builtin_setjmp_receiver
966         with NULL for the label parameter.
967         * builtins.c (expand_builtin_setjmp_receiver): Don't clobber
968         the frame-pointer.  Adjust comments.
969         [HAVE_builtin_setjmp_receiver]: Emit builtin_setjmp_receiver
970         only if LABEL is non-NULL.
971
972 2012-10-22  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
973
974         PR tree-optimization/55008
975         * gimple-ssa-strength-reduction.c (find_basis_for_candidate):
976         Don't allow a candidate to be a basis for itself under another
977         interpretation.
978
979 2012-10-22  Sharad Singhai  <singhai@google.com>
980
981         * dumpfile.c (dump_phase_enabled_p): Renamed dump_enabled_p. Update
982         all callers.
983         (dump_enabled_p): A new function to check if any of the dump files
984         is available.
985         (dump_kind_p): Remove check for current_function_decl. Add check for
986         dumpfile and alt_dump_file.
987         * dumpfile.h: Add declaration of dump_enabled_p.
988
989 2012-10-22  Richard Biener  <rguenther@suse.de>
990
991         PR lto/55021
992         * tree-streamer-in.c (unpack_ts_int_cst_value_fields): Remove
993         bogus truncations.
994
995 2012-10-22  Uros Bizjak  <ubizjak@gmail.com>
996
997         * config/i386/i386.c (memory_address_length): Assert that non-null
998         base or index RTXes are registers.  Do not check for REG RTXes.
999         Determine addr32 prefix using SImode_address_operand or
1000         from original base and index RTXes.  Simplify code.
1001
1002 2012-10-22  Richard Biener  <rguenther@suse.de>
1003
1004         PR tree-optimization/55011
1005         * tree-vrp.c (update_value_range): For invalid lattice transitions
1006         drop to VARYING.
1007
1008 2012-10-22  Julian Brown  <julian@codesourcery.com>
1009
1010         * config/arm/arm.h (CANNOT_CHANGE_MODE_CLASS): Avoid subreg'ing
1011         VFP D registers in big-endian mode.
1012
1013 2012-10-22  Georg-Johann Lay  <avr@gjlay.de>
1014
1015         * doc/invoke.texi (AVR Options): Document __AVR_ARCH__.
1016         Note __AVR_<device>__ is not defined for cores.
1017         Don't point to --help=target.
1018
1019 2012-10-22  Sameera Deshpande  <sameera.deshpande@arm.com>
1020             Greta Yorsh  <Greta.Yorsh@arm.com>
1021
1022         * config/arm/arm.c (thumb2_emit_ldrd_pop): New function.
1023         (arm_expand_epilogue): Use the new function.
1024
1025 2012-10-22  Sameera Deshpande  <sameera.deshpande@arm.com>
1026             Greta Yorsh  <Greta.Yorsh@arm.com>
1027
1028         * config/arm/arm.c (thumb2_emit_strd_push): New function.
1029         (arm_expand_prologue): Use the new function.
1030
1031 2012-10-22  Sameera Deshpande  <sameera.deshpande@arm.com>
1032             Greta Yorsh  <Greta.Yorsh@arm.com>
1033
1034         * config/arm/arm-protos.h (offset_ok_for_ldrd_strd): New declaration.
1035         (operands_ok_ldrd_strd): Likewise.
1036         * config/arm/arm.c (offset_ok_for_ldrd_strd): New function.
1037         (operands_ok_ldrd_strd): Likewise.
1038         * config/arm/arm.md (thumb2_ldrd, thumb2_ldrd_base): New patterns.
1039         (thumb2_ldrd_base_neg): Likewise.
1040         (thumb2_strd, thumb2_strd_base, thumb_strd_base_neg): Likewise.
1041         * predicates.md (ldrd_strd_offset_operand): New predicate.
1042         * config/arm/constraints.md (Do): New constraint.
1043
1044 2012-10-22  Hans-Peter Nilsson  <hp@bitrange.com>
1045
1046         * config/mmix/mmix.md ("nonlocal_goto_receiver"): Refer to the
1047         frame-pointer as an operand.
1048         ("*nonlocal_goto_receiver_expanded"): Ditto.  Use
1049         mmix_output_register_setting instead of naked output_asm_insn for
1050         the offset from the frame-pointer to the saved rO.
1051         * config/mmix/mmix.c (mmix_output_register_setting): Emit NEGU for
1052         values -255..0.
1053         * config/mmix/predicates.md ("frame_pointer_operand"): New.
1054         * config/mmix/constraints.md ("Yf"): New.
1055
1056         * stmt.c (expand_nl_goto_receiver): Remove almost-copy of
1057         expand_builtin_setjmp_receiver.
1058         (expand_label): Adjust, call expand_builtin_setjmp_receiver
1059         with NULL for the label parameter.
1060         * builtins.c (expand_builtin_setjmp_receiver): Don't clobber
1061         the frame-pointer.  Adjust comments.
1062         [HAVE_builtin_setjmp_receiver]: Emit builtin_setjmp_receiver
1063         only if LABEL is non-NULL.
1064
1065 2012-10-21  Uros Bizjak  <ubizjak@gmail.com>
1066
1067         * config/i386/i386-protos.h (memory_address_length): Add new bool
1068         argument.  Update all uses.
1069         * config/i386/i386.c (memory_address_length): If not LEA insn, then
1070         add length of addr32 prefix based on mode of base or index register.
1071         (ix86_attr_length_address_default) <TYPE_LEA>: Do not handle SImode
1072         addresses here.  Update call to memory_address_length.
1073         (ix86_print_address_operand): Use SImode_address_operand predicate.
1074         * config/i386/predicates.md (SImode_address_operand): New.
1075         * config/i386/i386.md (lea<mode>): Use SImode_address_operand
1076         to calculate "mode" attribute.  Use SImode_address_operand predicate
1077         instead of open-coding accepted RTX codes.
1078
1079 2012-10-21  Joern Rennecke  <joern.rennecke@embecosm.com>
1080
1081         * rtl.def (ADDR_DIFF_VEC): Fix comment typo.
1082
1083 2012-10-21  Eric Botcazou  <ebotcazou@adacore.com>
1084
1085         PR rtl-optimization/44194
1086         * calls.c (expand_call): Allow sibling calls in the PARALLEL case.
1087
1088 2012-10-21  Tobias Burnus  <burnus@net-b.de>
1089
1090         PR fortran/54725
1091         * Makefile.in (TARGET_SYSTEM_ROOT_DEFINE): New.
1092
1093 2012-10-21  Chung-Lin Tang  <cltang@codesourcery.com>
1094
1095         * config/xtensa/xtensa.c (xtensa_expand_builtin): Remove unused 'arg'
1096         variable.
1097
1098 2012-10-20  Eric Botcazou  <ebotcazou@adacore.com>
1099
1100         PR rtl-optimization/54315
1101         * calls.c (expand_call): Don't deal specifically with BLKmode values
1102         returned in naked registers.
1103         * expr.h (copy_blkmode_from_reg): Adjust prototype.
1104         * expr.c (copy_blkmode_from_reg): Rename first parameter into
1105         TARGET and make it required.  Assert that SRCREG hasn't BLKmode.
1106         Add a couple of short-circuits for common cases and be prepared
1107         for sub-word registers.
1108         (expand_assignment): Call copy_blkmode_from_reg for BLKmode values
1109         returned in naked registers.
1110         (store_expr): Likewise.
1111         (store_field): Likewise.
1112
1113 2012-10-20  Jan Hubicka  <jh@suse.cz>
1114
1115         * loop-unroll.c (decide_unroll_constant_iterations): Don't
1116         perform unrolling for loops with low iterations bounds or estimates.
1117
1118 2012-10-20  Jan Hubicka  <jh@suse.cz>
1119
1120         * loop-iv.c (iv_number_of_iterations): Record the upper bound
1121         only if there are no further conditions on it.
1122
1123 2012-10-20  Manuel López-Ibáñez  <manu@gcc.gnu.org>
1124
1125         PR c/53063
1126         PR c/40989
1127         * opts.c (finish_options): Remove explicit handling from here.
1128
1129 2012-10-20  Joern Rennecke  <joern.rennecke@embecosm.com>
1130             Richard Sandiford  <rdsandiford@googlemail.com>
1131
1132         * emit-rtl.c (copy_delay_slot_insn): New function.
1133         * emit-rtl.h (copy_delay_slot_insn): Declare.
1134         * reorg.c: Include "emit-rtl.h".
1135         (steal_delay_list_from_target): Use copy_delay_slot_insn.
1136         (fill_slots_from_thread, fill_simple_delay_slots): Likewise.
1137
1138         * final.c (shorten_branches): When optimizing, start with small
1139         length and increase from there, and don't decrease lengths.
1140
1141 2012-10-19  Jan Hubicka  <jh@suse.cz>
1142
1143         * builtins.def (BUILT_IN_UNREACHABLE): Make
1144         ATTR_CONST_NORETURN_NOTHROW_LEAF_LIST.
1145         * builtin-attrs.def (ATTR_CONST_NORETURN_NOTHROW_LEAF_LIST): Define.
1146
1147 2012-10-19  Michael Meissner  <meissner@linux.vnet.ibm.com>
1148             Dominique Dhumieres  <dominiq@lps.ens.fr>
1149
1150         * config/rs6000/rs6000-cpus.def (POWERPC_MASKS): Don't assume
1151         OPTION_MASK_STRICT_ALIGN is defined.
1152         (MASK_STRICT_ALIGN): If OPTION_MASK_STRICT_ALIGN is not defined,
1153         define this to 0 for the 3 ports that use it.
1154
1155         * config/rs6000/rs6000.c (OPTION_MASK_STRICT_ALIGN): Don't do
1156         check for ports not having -mstrict-align here, move test to
1157         rs6000-cpus.def.
1158         (MASK_STRICT_ALIGN): Likewise.
1159         (rs6000_debug_reg_global): Print out correct target flag words if
1160         -mdebug=reg.
1161
1162 2012-10-19  Marek Polacek  <polacek@redhat.com>
1163
1164         PR middle-end/54945
1165         * fold-const.c (fold_sign_changed_comparison):  Punt if folding
1166         pointer/non-pointer comparison.
1167
1168 2012-10-19  Greta Yorsh  <Greta.Yorsh@arm.com>
1169
1170         * doc/sourcebuild.texi (Effective-Target Keywords): Document
1171         new effective target keyword arm_prefer_ldrd_strd.
1172
1173 2012-10-19  Richard Guenther  <rguenther@suse.de>
1174
1175         PR tree-optimization/54981
1176         * tree-loop-distribution.c (ssa_name_has_uses_outside_loop_p):
1177         Do not consider debug stmts as uses.
1178
1179 2012-10-19  Richard Biener  <rguenther@suse.de>
1180
1181         PR tree-optimization/54976
1182         * tree-vect-stmts.c (get_vectype_for_scalar_type_and_size):
1183         Robustify against odd inner_mode inputs.
1184
1185 2012-10-19  Zhenqiang Chen <zhenqiang.chen@linaro.org>
1186
1187         PR target/54892
1188         * config/arm/arm.c (arm_expand_compare_and_swap): Use SImode to make
1189         sure the mode is correct when falling through from above cases.
1190
1191 2012-10-19  Bin Cheng  <bin.cheng@arm.com>
1192
1193         * common.opt (flag_ira_hoist_pressure): New.
1194         * doc/invoke.texi (-fira-hoist-pressure): Describe.
1195         * ira-costs.c (ira_set_pseudo_classes): New parameter.
1196         * ira.h: Update copyright dates.
1197         (ira_set_pseudo_classes): Update prototype.
1198         * haifa-sched.c (sched_init): Update call.
1199         * ira.c (ira): Update call.
1200         * regmove.c: Update copyright dates.
1201         (regmove_optimize): Update call.
1202         * loop-invariant.c: Update copyright dates.
1203         (move_loop_invariants): Update call.
1204         * gcse.c: (struct bb_data): New structure.
1205         (BB_DATA): New macro.
1206         (curr_bb, curr_reg_pressure): New static variables.
1207         (should_hoist_expr_to_dom): Rename from hoist_expr_reaches_here_p.
1208         Change parameter expr_index to expr.
1209         New parameters pressure_class, nregs and hoisted_bbs.
1210         Use reg pressure to determine the distance expr can be hoisted.
1211         (hoist_code): Use reg pressure to direct the hoist process.
1212         (get_regno_pressure_class, get_pressure_class_and_nregs)
1213         (change_pressure, calculate_bb_reg_pressure): New.
1214         (one_code_hoisting_pass): Calculate register pressure. Allocate
1215         and free data.
1216
1217 2012-10-19  Bin Cheng  <bin.cheng@arm.com>
1218
1219         * gcse.c: Update copyright dates.
1220         (hoist_expr_reaches_here_p): Change parameter type from char *
1221         to sbitmap.
1222
1223 2012-10-19  Sebastian Huber <sebastian.huber@embedded-brains.de>
1224
1225         * config.gcc
1226         (arm*-*-eabi* | arm*-*-symbianelf* | arm*-*-rtemseabi*): Rename
1227         "arm*-*-rtemseabi*" to "arm*-*-rtems*".
1228
1229 2012-10-19  Alan Modra  <amodra@gmail.com>
1230
1231         * configure.ac (HAVE_LD_NO_DOT_SYMS): Set if using gold.
1232         (HAVE_LD_LARGE_TOC): Likewise.
1233         * configure: Regenerate.
1234
1235 2012-10-19  Alan Modra  <amodra@gmail.com>
1236
1237         * config/rs6000/predicates.md (splat_input_operand): Don't call
1238         input_operand for MEMs.  Instead check for volatile and call
1239         memory_address_addr_space_p with modified mode.
1240
1241 2012-10-18  Uros Bizjak  <ubizjak@gmail.com>
1242
1243         * config/i386/i386.md (rdpmc): Remove expander.
1244         (rdtsc): Ditto.
1245         (rdtscp): Ditto.
1246         (rdpmc): Rename from *rdpmc.
1247         (rdpmc_rex64): Rename from *rdpmc_rex64.
1248         (rdtsc): Rename from *rdtsc.
1249         (rdtsc_rex64): Rename from *rdtsc_rex64.
1250         (rdtscp): Rename from *rdtscp.
1251         (rdtscp_rex64): Rename from *rdtscp_rex64.
1252
1253         * config/i386/i386.c (struct builtin_description bdesc_special_args)
1254         <IX86_BUILTIN_RDTSC>: Use CODE_FOR_NOTHING.
1255         <IX86_BUILTIN_RDTSCP>: Ditto.
1256         (struct builtin_description bdesc__args) <IX86_BUILTIN_RDPMC>: Ditto.
1257         (ix86_expand_builtin) <IX86_BUILTIN_{RDPMC,RDTSC,RDTSCP}>: Handle here.
1258
1259 2012-10-18  Jan-Benedict Glaw  <jbglaw@lug-owl.de>
1260
1261         * config/sh/sh.c: Fix comment to silence warning.
1262
1263 2012-10-18  Matthew Gretton-Dann  <matthew.gretton-dann@arm.com>
1264             Ramana Radhakrishnan  <ramana.radhakrishnan@arm.com>
1265             Sameera Deshpande  <sameera.deshpande@arm.com>
1266
1267         * config/arm/cortex-a15-neon.md: New file.
1268         * config/arm/cortex-a15.md (cortex_a15_call): Adjust reservation.
1269         (cortex_a15_load1): Likewise.
1270         (cortex_a15_load3): Likewise.
1271         (cortex_a15_store1): Likewise.
1272         (cortex_a15_store3): Likewise.
1273         (cortex-a15-neon.md): Include.
1274
1275 2012-10-18  Segher Boessenkool  <segher@kernel.crashing.org>
1276
1277         * config/rs6000/altivec.md (altivec_lvsl, altivec_lvsr): Add mode.
1278         (altivec_vsumsws_nomode): Delete.
1279         (reduc_splus_<mode>, reduc_uplus_<mode>): Call gen_altivec_vsumsws
1280         instead of gen_altivec_vsumsws_nomode.
1281         (altivec_lvlx, altivec_lvlxl, altivec_lvrx, altivec_lvrxl): Add mode.
1282         * config/rs6000/rs6000.md (probe_stack): Rename to...
1283         (probe_stack_<mode>): ... this.  Add mode.  Change pattern to
1284         use std instead of stw when appropriate.
1285         (probe_stack): New expander.
1286         (move_from_CR_ov_bit): Add mode.
1287         (splitter for compare_plus_ne0_<mode>, splitter for
1288         compare_plus_ne0_<mode>_1): Remove constraints.
1289         * config/rs6000/sync.md (loadsync): Rename to...
1290         (loadsync_<mode>): ... this.  Add mode.
1291         (atomic_load<mode>): Adjust.
1292
1293 2012-10-18  Eric Botcazou  <ebotcazou@adacore.com>
1294
1295         * loop-invariant.c: Include target.h.
1296         (check_dependency): Return false for an uninitialized argument register
1297         that is likely to be spilled.
1298         * Makefile.in (loop-invariant.o): Add $(TARGET_H).
1299
1300 2012-10-18  Eric Botcazou  <ebotcazou@adacore.com>
1301
1302         * except.c (sjlj_emit_function_enter): Remove unused variable.
1303
1304 2012-10-18  Matthew Gretton-Dann  <matthew.gretton-dann@arm.com>
1305             Ramana Radhakrishnan  <ramana.radhakrishnan@arm.com>
1306
1307         * config/arm/arm.c (neon_builtin_data): Add vfma and vfms builtins.
1308         * config/arm/neon-docgen.ml (intrinsic_groups): Add
1309         fused-multiply-* groups.
1310         * config/neon-gen.ml (print_feature_test_start): New function.
1311         (print_feature_test_end): Likewise.
1312         (print_variant): Print feature test macros.
1313         * config/arm/neon-testgen.ml (emit_prologue): Allow different
1314         tests to require different effective targets.
1315         (effective_target): New function.
1316         (test_intrinsic): Specify correct effective targets.
1317         * gcc/config/arm/neon.md (fma<VCVTF:mode>4_intrinsic): New pattern.
1318         (fmsub<VCVTF:mode>4_intrinsic): Likewise.
1319         (neon_vfma<VCVFT:mode>): New expand.
1320         (neon_vfms<VCVFT:mode>): Likewise.
1321         * config/neon.ml (opcode): Add Vfma and Vfms.
1322         (features): Add Requires_feature.
1323         (ops): Add VFMA and VFMS intrinsics.
1324         * config/arm/arm_neon.h: Regenerate.
1325         * doc/arm-neon-intrinsics.texi: Likewise.
1326
1327 2012-10-18  Richard Guenther  <rguenther@suse.de>
1328
1329         * lto-streamer.h (enum LTO_tags): Add LTO_integer_cst.
1330         * lto-streamer-in.c (lto_input_tree): Use it.
1331         * lto-streamer-out.c (lto_output_tree): Likewise, for
1332         !TREE_OVERFLOW integer constants only.
1333         * tree-streamer-in.c (unpack_ts_int_cst_value_fields): New function.
1334         (unpack_value_fields): Call it.
1335         (streamer_read_integer_cst): Simplify.
1336         * tree-streamer-out.c (pack_ts_int_cst_value_fields): New function.
1337         (streamer_pack_tree_bitfields): Call it.
1338         (streamer_write_integer_cst): Adjust.
1339
1340 2012-10-18  Matthew Gretton-Dann  <matthew.gretton-dann@arm.com>
1341             Ramana Radhakrishnan  <ramana.radhakrishnan@arm.com>
1342
1343         * config.gcc: Add support for ARMv8 for arm*-*-* targets.
1344         * config/arm/arm-arches.def: Add armv8-a
1345         * config/arm/arm-fpus.def: Add fp-armv8, neon-fp-armv8,
1346         crypto-neon-fp-armv8.  Add crypto field.
1347         * config/arm/arm-tables.opt: Regenerate.
1348         * config/arm/arm.c (FL_FOR_ARCH8A): Likewise.
1349         (arm_arch8): New global variable.
1350         (ARM_FPU): Add crypto parameter.
1351         (arm_option_override): Set arm_arch8, update comments.
1352         * config/arm/arm.h (TARGET_CRYPTO): New macro.
1353         (arm_fpu_desc): Add crypto field.
1354         (base_architecture): Add ARMv8 entry.
1355         (arm_arch8): New variable declaration.
1356         * config/arm/bpabi.h: ARMv8 supports BE8.
1357         * doc/invoke.texi: Document ARMv8 options.
1358
1359 2012-10-17  Aldy Hernandez  <aldyh@redhat.com>
1360
1361         PR middle-end/54893
1362         * trans-mem.c (diagnose_tm_1_op): Allow volatiles inside relaxed
1363         transactions.
1364
1365 2012-10-17  Aldy Hernandez  <aldyh@redhat.com>
1366
1367         PR rtl-optimization/54900
1368         * ifcvt.c (noce_can_store_speculate_p): Call
1369         memory_must_be_modified_in_insn_p.
1370         * alias.c (memory_must_be_modified_in_insn_p): New.
1371         (set_dest_equal_p): New.
1372         * rtl.h (memory_must_be_modified_in_p): Protoize.
1373
1374 2012-10-17  Michael Meissner  <meissner@linux.vnet.ibm.com>
1375
1376         * config/rs6000/rs6000.opt (rs6000_isa_flags): New flag word to
1377         replace target_flags that gives us 63 possible switches.
1378         (x_rs6000_isa_flags): Save area for rs6000_isa_flags.
1379         (x_rs6000_isa_flags_explicit): Save area for rs6000_isa_flags_explicit.
1380         (rs6000_target_flags_explicit): Delete in favor of
1381         x_rs6000_isa_flags_explicit.
1382         (-mpowerpc64): Change all switches that used to be in target_flags
1383         to now be in rs6000_isa_flags.  In using rs6000_isa_flags, the
1384         options machinary will generate names of the form OPITON_<xxx>
1385         instead of TARGET_<xxx> and OPTION_MASK_<xxx> instead of MASK_<xxx>.
1386         (-mpowerpc-gpopt): Likewise.
1387         (-mpowerpc-gfxopt): Likewise.
1388         (-mmfcrf): Likewise.
1389         (-mpopcntb): Likewise.
1390         (-mfprnd): Likewise.
1391         (-mcmpb): Likewise.
1392         (-mmfpgpr): Likewise.
1393         (-maltivec): Likewise.
1394         (-mhard-dfp): Likewise.
1395         (-mmulhw): Likewise.
1396         (-mdlmzb): Likewise.
1397         (-mmultiple): Likewise.
1398         (-mstring): Likewise.
1399         (-msoft-float): Likewise.
1400         (-mhard-float): Likewise.
1401         (-mpopcntd): Likewise.
1402         (-mvsx): Likewise.
1403         (-mno-update): Likewise.
1404         (-mupdate): Likewise.
1405         (-mrecip-precision): Likewise.
1406         (-mminimal-toc): Likewise.
1407         (-misel): Likewise.
1408         * config/rs6000/aix64.opt (-maix64): Likewise.
1409         (-maix32): Likewise.
1410         * config/rs6000/sysv4.opt (-mstrict-align): Likewise.
1411         (-mrelocatable): Likewise.
1412         (-mlittle-endian): Likewise.
1413         (-mlittle): Likewise.
1414         (-mbig-endian): LIkewise.
1415         (-mbig): Likewise.
1416         (-meabi): Likewise.
1417         (-m64): Likewise.
1418         (-m32): Likewise.
1419         * config/rs6000/darwin.opt (-m64): Likewise.
1420         (-m32): Likewise.
1421
1422         * config/rs6000/rs6000-cpus.def (ISA_2_1_MASKS): Move the various
1423         masks used in rs6000.c here, since they are more logically in this
1424         file.  Convert from being enums to just #defines, since the types
1425         of these masks is now HOST_WIDE_INT instead of int.  For
1426         POWERPC_MASKS, add MASK_SOFT_FLOAT, since the only use case or'ed
1427         in the mask.  Change the use in rs6000.c not to do the OR of
1428         MASK_SOFT_FLOAT.
1429         (ISA_2_1_MASKS): Likewise.
1430         (ISA_2_2_MASKS): Likewise.
1431         (ISA_2_4_MASKS): Likewise.
1432         (ISA_2_5_MASKS_EMBEDDED): Likewise.
1433         (ISA_2_5_MASKS_SERVER): Likewise.
1434         (POWERPC_7400_MASK): Likewise.
1435         (POWERPC_MASKS): Likewise.
1436         * config/rs6000/rs6000.c (ISA_2_1_MASKS): Likewise.
1437         (ISA_2_1_MASKS): Likewise.
1438         (ISA_2_2_MASKS): Likewise.
1439         (ISA_2_4_MASKS): Likewise.
1440         (ISA_2_5_MASKS_EMBEDDED): Likewise.
1441         (ISA_2_5_MASKS_SERVER): Likewise.
1442         (POWERPC_7400_MASK): Likewise.
1443         (POWERPC_MASKS): Likewise.
1444         (rs6000_option_override_internal): Likewise.
1445
1446         * config/rs6000/rs6000.c (darwin_rs6000_override_options): Change
1447         all uses of target_flags to rs6000_isa_flags.  Change all uses of
1448         target_flags_explicit to rs6000_isa_flags_explicit.  Change the
1449         use of MASK_<xxx> to OPTION_MASK_<xxx> that options.h defines when
1450         we use a secondary flags word.  Save/restore/print the new flags
1451         word when switching contexts with different target attributes.
1452         (rs6000_option_override_internal): Likewise.
1453         (rs6000_darwin_file_start): Likewise.
1454         (rs6000_opt_masks): Likewise.
1455         (rs6000_inner_target_options): Likewise.
1456         (rs6000_pragma_target_parse): Likewise.
1457         (rs6000_set_current_function): Likewise.
1458         (rs6000_function_specific_save): Likewise.
1459         (rs6000_function_specific_restore): Likewise.
1460         (rs6000_function_specific_print): Likewise.
1461         (rs6000_can_inline_p): Likewise.
1462         * config/rs6000/rs6000-c.c (rs6000_target_modify_macros): Likewise.
1463         (rs6000_cpu_cpp_builtins): Likewise.
1464         * common/config/rs6000/rs6000-driver.c (rs6000_handle_option):
1465         Likewise.
1466
1467         * config/rs6000/rs6000.h (MASK_ALTIVEC): In moving to using
1468         Var(...) for all of the isa switches, the options machinery now
1469         uses OPTION_MASK_<xxx> instead of MASK_<xxx> for the mask name.
1470         Use #define to map the old name into the new name.  For switches
1471         that are defined in aix64.opt, sysv4.opt, and darwin.opt, only do
1472         the definition if those switches were defined.
1473         (MASK_ALTIVEC): Likewise.
1474         (MASK_CMPB): Likewise.
1475         (MASK_DFP): Likewise.
1476         (MASK_DLMZB): Likewise.
1477         (MASK_EABI): Likewise.
1478         (MASK_FPRND): Likewise.
1479         (MASK_HARD_FLOAT): Likewise.
1480         (MASK_ISEL): Likewise.
1481         (MASK_MFCRF): Likewise.
1482         (MASK_MFPGPR): Likewise.
1483         (MASK_MULHW): Likewise.
1484         (MASK_MULTIPLE): Likewise.
1485         (MASK_NO_UPDATE): Likewise.
1486         (MASK_POPCNTB): Likewise.
1487         (MASK_POPCNTD): Likewise.
1488         (MASK_PPC_GFXOPT): Likewise.
1489         (MASK_PPC_GPOPT): Likewise.
1490         (MASK_RECIP_PRECISION): Likewise.
1491         (MASK_SOFT_FLOAT): Likewise.
1492         (MASK_STRICT_ALIGN): Likewise.
1493         (MASK_STRING): Likewise.
1494         (MASK_UPDATE): Likewise.
1495         (MASK_VSX): Likewise.
1496         (MASK_POWERPC64): Likewise.
1497         (MASK_64BIT): Likewise.
1498         (MASK_RELOCATABLE): Likewise.
1499         (MASK_LITTLE_ENDIAN): Likewise.
1500         (MASK_MINIMAL_TOC): Likewise.
1501         (MASK_REGNAMES): Likewise.
1502         (MASK_PROTOTYPE): Likewise.
1503         (rs6000_isa_flags_explicit): Define in terms of the
1504         global_options_set structure.
1505
1506         * gcc/config/rs6000/aix43.h (SUBTARGET_OVERRIDE_OPTIONS):
1507         Change use of target_flags to rs6000_isa_flags, target_flags_explicit
1508         to rs6000_isa_flags_explicit, and MASK_<xxx> to OPTION_MASK_<xxx>.
1509         * gcc/config/rs6000/aix51.h (SUBTARGET_OVERRIDE_OPTIONS): Likewise.
1510         * gcc/config/rs6000/aix52.h (SUBTARGET_OVERRIDE_OPTIONS): Likewise.
1511         * gcc/config/rs6000/aix53.h (SUBTARGET_OVERRIDE_OPTIONS): Likewise.
1512         * gcc/config/rs6000/aix61.h (SUBTARGET_OVERRIDE_OPTIONS): Likewise.
1513         * gcc/config/rs6000/freebsd64.h (RELOCATABLE_NEEDS_FIXUP): Likewise.
1514         (SUBSUBTARGET_OVERRIDE_OPTIONS): Likewise.
1515         * gcc/config/rs6000/freebsd.h (RELOCATABLE_NEEDS_FIXUP): Likewise.
1516         * gcc/config/rs6000/linux64.h (RELOCATABLE_NEEDS_FIXUP): Likewise.
1517         (SUBSUBTARGET_OVERRIDE_OPTIONS): Likewise.
1518         (OPTION_LITTLE_ENDIAN): Likewise.
1519         (OPTION_RELOCATABLE): Likewise.
1520         (OPTION_EABI): Likewise.
1521         (OPTION_PROTOTYPE): Likewise.
1522         * gcc/config/rs6000/linux.h (RELOCATABLE_NEEDS_FIXUP): Likewise.
1523         * gcc/config/rs6000/option-defaults.h (OPTION_MASK_64BIT): Likewise.
1524         (OPT_ARCH32): Likewise.
1525         (OPT_ARCH64): Likewise.
1526         * gcc/config/rs6000/sysv4.h (TARGET_TOC): Likewise.
1527         (SUBTARGET_OVERRIDE_OPTIONS): Likewise.
1528         (SUBSUBTARGET_OVERRIDE_OPTIONS): Likewise.
1529         (TARGET_OS_SYSV_CPP_BUILTINS): Likewise.
1530
1531         * config/rs6000/t-rs6000 (rs6000.o): Add rs6000-cpus.def as a
1532         dependency.
1533
1534 2012-10-17  Jan Hubicka  <jh@suse.cz>
1535
1536         * cfgloopmanip.c (copy_loop_info): New function.
1537         (duplicate_loop): Use it.
1538         (loop_version): Use it.
1539         * loop-unswitch.c (unswitch_loop): Use it.
1540         * cfgloop.h (copy_loop_info): Declare.
1541
1542 2012-10-17  Jan Hubicka  <jh@suse.cz>
1543
1544         * tree-ssa-loop-ivcanon.c (tree_estimate_loop_size): Add edge_to_cancel
1545         parameter and use it to estimate code optimized out in the final
1546         iteration.
1547         (loop_edge_to_cancel): New function.
1548         (try_unroll_loop_completely): New IRRED_IVALIDATED parameter;
1549         handle unrolling loops with bounds given via max_loop_iteratins;
1550         handle unrolling non-inner loops when code size shrinks;
1551         tidy dump output; when the last iteration loop still stays
1552         as loop in the CFG forcongly redirect the latch to
1553         __builtin_unreachable.
1554         (canonicalize_loop_induction_variables): Add irred_invlaidated
1555         parameter; record niter bound derrived; dump
1556         max_loop_iterations bounds; call try_unroll_loop_completely
1557         even if no niter bound is given.
1558         (canonicalize_induction_variables): Handle irred_invalidated.
1559         (tree_unroll_loops_completely): Handle non-innermost loops;
1560         handle irred_invalidated.
1561         * cfgloop.h (unlop): Declare.
1562         * cfgloopmanip.c (unloop): Export.
1563         * tree.c (build_common_builtin_nodes): Build BULTIN_UNREACHABLE.
1564
1565 2012-10-17  Michael Meissner  <meissner@linux.vnet.ibm.com>
1566
1567         * opth-gen.awk (TARGET_* generation): Always generate TARGET_<xxx>
1568         for Mask options, whether they use Var(...) or not.
1569
1570         * config/linux-android.h (ANDROID_TARGET_OS_CPP_BUILTINS): Use
1571         TARGET_<xxx> instead of OPTION_<xxx>.
1572         * config/i386/i386.h (TARGET_64BIT): Likewise.
1573         (TARGET_MMX): Likewise.
1574         (TARGET_3DNOW): Likewise.
1575         (TARGET_3DNOW_A): Likewise.
1576         (TARGET_SSE): Likewise.
1577         (TARGET_SSE2): Likewise.
1578         (TARGET_SSE3): Likewise.
1579         (TARGET_SSSE3): Likewise.
1580         (TARGET_SSE4_1): Likewise.
1581         (TARGET_SSE4_2): Likewise.
1582         (TARGET_AVX): Likewise.
1583         (TARGET_AVX2): Likewise.
1584         (TARGET_FMA): Likewise.
1585         (TARGET_SSE4A): Likewise.
1586         (TARGET_FMA4): Likewise.
1587         (TARGET_XOP): Likewise.
1588         (TARGET_LWP): Likewise.
1589         (TARGET_ROUND): Likewise.
1590         (TARGET_ABM): Likewise.
1591         (TARGET_BMI): Likewise.
1592         (TARGET_BMI2): Likewise.
1593         (TARGET_LZCNT): Likewise.
1594         (TARGET_TBM): Likewise.
1595         (TARGET_POPCNT): Likewise.
1596         (TARGET_SAHF): Likewise.
1597         (TARGET_MOVBE): Likewise.
1598         (TARGET_CRC32): Likewise.
1599         (TARGET_AES): Likewise.
1600         (TARGET_PCLMUL): Likewise.
1601         (TARGET_CMPXCHG16B): Likewise.
1602         (TARGET_FSGSBASE): Likewise.
1603         (TARGET_RDRND): Likewise.
1604         (TARGET_F16C): Likewise.
1605         (TARGET_RTM     ): Likewise.
1606         (TARGET_HLE): Likewise.
1607         (TARGET_RDSEED): Likewise.
1608         (TARGET_PRFCHW): Likewise.
1609         (TARGET_ADX): Likewise.
1610         (TARGET_64BIT): Likewise.
1611         (TARGET_MMX): Likewise.
1612         (TARGET_3DNOW): Likewise.
1613         (TARGET_3DNOW_A): Likewise.
1614         (TARGET_SSE): Likewise.
1615         (TARGET_SSE2): Likewise.
1616         (TARGET_SSE3): Likewise.
1617         (TARGET_SSSE3): Likewise.
1618         (TARGET_SSE4_1): Likewise.
1619         (TARGET_SSE4_2): Likewise.
1620         (TARGET_AVX): Likewise.
1621         (TARGET_AVX2): Likewise.
1622         (TARGET_FMA): Likewise.
1623         (TARGET_SSE4A): Likewise.
1624         (TARGET_FMA4): Likewise.
1625         (TARGET_XOP): Likewise.
1626         (TARGET_LWP): Likewise.
1627         (TARGET_ROUND): Likewise.
1628         (TARGET_ABM): Likewise.
1629         (TARGET_BMI): Likewise.
1630         (TARGET_BMI2): Likewise.
1631         (TARGET_LZCNT): Likewise.
1632         (TARGET_TBM): Likewise.
1633         (TARGET_POPCNT): Likewise.
1634         (TARGET_SAHF): Likewise.
1635         (TARGET_MOVBE): Likewise.
1636         (TARGET_CRC32): Likewise.
1637         (TARGET_AES): Likewise.
1638         (TARGET_PCLMUL): Likewise.
1639         (TARGET_CMPXCHG16B): Likewise.
1640         (TARGET_FSGSBASE): Likewise.
1641         (TARGET_RDRND): Likewise.
1642         (TARGET_F16C): Likewise.
1643         (TARGET_RTM): Likewise.
1644         (TARGET_HLE): Likewise.
1645         (TARGET_RDSEED): Likewise.
1646         (TARGET_PRFCHW): Likewise.
1647         (TARGET_ADX): Likewise.
1648         (TARGET_LP64): Likewise.
1649         (TARGET_X32): Likewise.
1650         (TARGET_ISA_ROUND): Likewise.
1651         * config/i386/darwin.h (TARGET_64BIT): Likewise.
1652
1653         * doc/options.texi (Mask): Update documentation to specify only
1654         TARGET_<xxx> is generated.
1655
1656 2012-10-17  Greta Yorsh  <Greta.Yorsh@arm.com>
1657
1658         * config/arm/arm.md (UNSPEC_PROLOGUE_USE): Rename this...
1659         (UNSPEC_REGISTER_USE): ... to this.
1660         (prologue_use): Rename this...
1661           (force_register_use): ... to this and update output assembly.
1662         (epilogue) Rename gen_prologue_use to gen_force_register_use.
1663         * config/arm/arm.c (arm_expand_prologue): Likewise.
1664         (thumb1_expand_epilogue): Likewise.
1665         (arm_expand_epilogue): Likewise.
1666         (arm_expand_epilogue): Likewise.
1667
1668 2012-10-17  Georg-Johann Lay  <avr@gjlay.de>
1669
1670         * config/avr/avr-arch.h (avr_extra_arch_macro): Remove prototype.
1671         * config/avr/avr.c (avr_extra_arch_macro): Remove variable.
1672         (avr_option_override): Remove setting of avr_extra_arch_macro.
1673         * config/avr/avr-c.c (avr_extra_arch_macro): Replace with
1674         avr_current_device->macro.
1675
1676 2012-10-17  Richard Biener  <rguenther@suse.de>
1677
1678         * tree-streamer-out.c (write_ts_decl_common_tree_pointers):
1679         Do not write TREE_CHAIN of PARM_DECLs.
1680         (write_ts_decl_non_common_tree_pointers): Instead stream
1681         the DECL_ARGUMENTS chain.
1682         * tree-streamer-in.c (lto_input_ts_decl_common_tree_pointers):
1683         Do not read TREE_CHAIN of PARM_DECLs.
1684         (lto_input_ts_decl_non_common_tree_pointes): Instead read
1685         the DECL_ARGUMENTS as chain.
1686
1687 2012-10-17  Steven Bosscher  <steven@gcc.gnu.org>
1688
1689         * config/iq2000/iq2000.h (call_used_regs): Remove definition.
1690
1691 2012-10-16  Eric Botcazou  <ebotcazou@adacore.com>
1692
1693         PR rtl-optimization/54870
1694         * tree.h (TREE_ADDRESSABLE): Document special usage on SSA_NAME.
1695         * cfgexpand.c (update_alias_info_with_stack_vars ): Set it on the
1696         SSA_NAME pointer that points to a partition if there is at least
1697         one variable with it set in the partition.
1698         * dse.c (local_variable_can_escape): New predicate.
1699         (can_escape): Call it.
1700         * gimplify.c (mark_addressable): If this is a partitioned decl, also
1701         mark the SSA_NAME pointer that points to a partition.
1702
1703 2012-10-16  Steven Bosscher  <steven@gcc.gnu.org>
1704
1705         * df-problems.c (df_kill_notes): Split up in two functions.
1706         (df_remove_dead_and_unused_notes): New function, first half of
1707         df_kill notes to remove all REG_DEAD and REG_UNUSED notes.
1708         (df_remove_dead_eq_notes): New function, second half of df_kill_notes
1709         to remove REG_EQUAL and REG_EQUIV notes referring to dead registers.
1710         (df_note_bb_compute): Call df_remove_dead_and_unused_notes instead
1711         of df_kill_notes.  Call df_remove_dead_eq_notes after processing insn.
1712
1713         * web.c (web): Re-add DF_RD_PRUNE_DEAD_DEFS;
1714
1715 2012-10-16  Ian Lance Taylor  <iant@google.com>
1716
1717         * doc/extend.texi (Return Address): Change
1718         __builtin_extract_return_address to
1719         __builtin_extract_return_addr.
1720
1721 2012-10-16  Steven Bosscher  <steven@gcc.gnu.org>
1722
1723         * rtl.h (get_call_rtx_from): New prototype.
1724         * rtlanal.c (get_call_rtx_from): New function.
1725         * calls.c (emit_call_1): Use it.
1726         * dse.c (scan_insn): Likewise
1727         * dwarf2out.c (dwarf2out_var_location): Likewise.
1728         * sched-deps.c (call_may_noreturn_p): Likewise.
1729         * var-tracking.c (prepare_call_arguments): Likewise.
1730         * config/sh/sh.c (sh_adjust_cost): Likewise.
1731
1732 2012-10-16  Tom de Vries  <tom@codesourcery.com>
1733
1734         * expr.c (move_by_pieces, move_by_pieces_ninsns, can_store_by_pieces)
1735         (store_by_pieces_1): Don't enter loop when no more data is left.
1736
1737 2012-10-16  Joern Rennecke  <joern.rennecke@embecosm.com>
1738
1739         * loop-doloop.c (doloop_modify): Pass doloop_end pattern to
1740         gen_doloop_begin.
1741         (doloop_optimize): Pass flag to indicate if loop is entered at top
1742         to gen_doloop_end.
1743         * config/arm/thumb2.md (doloop_end): Accept extra operand.
1744         * config/bfin/bfin.md (doloop_end): Likewise.
1745         * config/c6x/c6x.md (doloop_end): Likewise.
1746         * config/ia64/ia64.md (doloop_end): Likewise.
1747         * config/mep/mep.md (doloop_begin, doloop_end): Likewise.
1748         * config/rs6000/rs6000.md (doloop_end): Likewise.
1749         * config/s390/s390.md (doloop_end): Likewise.
1750         * config/sh/sh.md (doloop_end): Likewise.
1751         * config/spu/spu.md (doloop_end): Likewise.
1752         * config/tilegx/tilegx.md (doloop_end): Likewise.
1753         * config/tilepro/tilepro.md (doloop_end): Likewise.
1754         * doc/md.texi (doloop_end): Document new operand.
1755         * basic-block.h (contains_no_active_insn_p): Declare.
1756         * cfgrtl.c (contains_no_active_insn_p): New function, factored
1757         out of ...
1758         (forwarder_block_p): ... here.
1759
1760 2012-10-16  Manuel López-Ibáñez  <manu@gcc.gnu.org>
1761
1762         PR c/53063
1763         PR c/40989
1764         * doc/options.texi (EnabledBy): Document new form.
1765         * optc-gen.awk: Handle new form of EnabledBy.
1766         * common.opt (Wunused-but-set-parameter): Use EnabledBy.
1767         (Wunused-parameter): Likewise.
1768         * opts.c (finish_options): Do not handle them explicitly.
1769         * opt-functions.awk (search_var_name): New.
1770
1771 2012-10-16  Manuel López-Ibáñez  <manu@gcc.gnu.org>
1772
1773         PR c/53063
1774         PR c/40989
1775         * optc-gen.awk: Handle new form of LangEnabledBy.
1776         * opts.c (set_Wstrict_aliasing): Declare here. Make static.
1777         * common.opt (Wstrict-aliasing=,Wstrict-overflow=): Do not use Init.
1778         * doc/options.texi (LangEnabledBy): Document new form.
1779         * flags.h (set_Wstrict_aliasing): Do not declare.
1780
1781 2012-10-16  Ulrich Weigand  <Ulrich.Weigand@de.ibm.com>
1782
1783         * reload.c (find_reloads_subreg_address): Remove FORCE_REPLACE
1784         parameter.  Always replace normal subreg with memory reference
1785         whenever possible.  Return NULL otherwise.
1786         (find_reloads_toplev): Always call find_reloads_subreg_address
1787         for subregs of registers equivalent to a memory location.
1788         Only recurse further if find_reloads_subreg_address fails.
1789         (find_reloads_address_1): Only call find_reloads_subreg_address
1790         for subregs of registers equivalent to a memory location.
1791         Properly handle failure of find_reloads_subreg_address.
1792
1793 2012-10-16  Jakub Jelinek  <jakub@redhat.com>
1794
1795         PR debug/54796
1796         * rtl.h: Document jump flag on VALUE.
1797         * cselib.h (cselib_set_value_sp_based,
1798         cselib_sp_based_value_p): New prototypes.
1799         * alias.c (find_base_term): For cselib_sp_based_value_p
1800         return static_reg_base_value[STACK_POINTER_REGNUM].
1801         * cselib.c (SP_BASED_VALUE_P): Define.
1802         (cselib_set_value_sp_based, cselib_sp_based_value_p): New functions.
1803         * var-tracking.c (add_stores): Call cselib_set_value_sp_based
1804         for not yet preserved VALUEs of sp on sp assignments if
1805         hard_frame_pointer_adjustment != -1.
1806         (vt_initialize): When setting hard_frame_pointer_adjustment,
1807         disassociate sp from its previous value and call
1808         cselib_set_value_sp_based on a new VALUE created for sp.
1809
1810         PR tree-optimization/54889
1811         * tree-vect-stmts.c (vectorizable_load): Add VIEW_CONVERT_EXPR if
1812         ARRAY_REF newref doesn't have compatible type with vectype element
1813         type, use vectype element type for MEM_REF.
1814
1815 2012-10-16  Steven Bosscher  <steven@gcc.gnu.org>
1816
1817         * combine.c (record_dead_and_set_regs): Iterate over hard register set
1818         with a hard_reg_set_iterator.
1819         * cse.c (invalidate_for_call): Likewise.
1820         * gcse.c (compute_hash_table_work): Likewise.
1821         * loop-iv.c (simplify_using_initial_values): Likewise.
1822         * postreload-gcse.c (record_opr_changes): Likewise.
1823         * regcprop.c (copyprop_hardreg_forward_1): Likewise.
1824         * var-tracking.c (dataflow_set_clear_at_call): Likewise.
1825
1826 2012-10-15   Easwaran Raman  <eraman@google.com>
1827
1828         * optabs.c (emit_cmp_and_jump_insn_1): Add a new parameter to
1829         specificy the probability of taking the jump.
1830         (emit_cmp_and_jump_insns): Likewise.
1831         (expand_compare_and_swap_loop): Make the jump predicted not taken.
1832         * dojump.c (do_compare_rtx_and_jump): Remove the code attaching
1833         REG_BR_PROB note and pass probability to emit_cmp_and_jump_insns.
1834         * cfgbuild.c (compute_outgoing_frequencies): Do not guess outgoing
1835         probabilities for branches with more than two successors.
1836         * expr.c (emit_block_move_via_loop): Predict the loop backedge loop
1837         to be highly taken.
1838         (try_casesi): Pass the probability of jumping to the default label.
1839         (try_tablejump): Likewise.
1840         (do_tablejump): Likewise.
1841         * expr.h (try_tablejump): Add a new parameter.
1842         (try_casesi): Likewise.
1843         (emit_cmp_and_jump_insns): Add probability as default parameter with a
1844         default value of -1.
1845         * except.c (sjlj_emit_function_enter): Pass probability to
1846         emit_cmp_and_jump_insns.
1847         * stmt.c (case_node): Add new fields PROB and SUBTREE_PROB.
1848         (do_jump_if_equal): Pass probability for REG_BR_PROB note.
1849         (add_case_node): Pass estimated probability of jumping to the case
1850         label.
1851         (emit_case_decision_tree): Pass default_prob to emit_case_nodes.
1852         (get_outgoing_edge_probs): New function.
1853         (conditional_probability): Likewise.
1854         (reset_out_edges_aux): Likewise.
1855         (compute_cases_per_edge): Likewise.
1856         (emit_case_dispatch_table): Update probabilities of edges coming out
1857         of the switch statement.
1858         (expand_case): Compute and propagate default edge probability to
1859         emit_case_dispatch_table.
1860         (expand_sjlj_dispatch_table): Update calls to add_case_node and
1861         emit_case_dispatch_table.
1862         (balance_case_nodes): Update subtree_prob values.
1863         (emit_case_nodes): Compute edge probabilities and add pass them to
1864         emit_cmp_and_jump_insns.
1865
1866 2012-10-15  Oleg Endo  <olegendo@gcc.gnu.org>
1867
1868         PR target/51244
1869         * config/sh/sh-protos.h (set_of_reg): New struct.
1870         (sh_find_set_of_reg, sh_is_logical_t_store_expr,
1871         sh_try_omit_signzero_extend):  Declare...
1872         * config/sh/sh.c (sh_find_set_of_reg, sh_is_logical_t_store_expr,
1873         sh_try_omit_signzero_extend): ...these new functions.
1874         * config/sh/sh.md (*logical_op_t): New insn_and_split.
1875         (*zero_extend<mode>si2_compact): Use sh_try_omit_signzero_extend
1876         in splitter.
1877         (*extend<mode>si2_compact_reg): Convert to insn_and_split.
1878         Use sh_try_omit_signzero_extend in splitter.
1879         (*mov<mode>_reg_reg): Disallow t_reg_operand as operand 1.
1880         (*cbranch_t): Rewrite combine part in splitter using new
1881         sh_find_set_of_reg function.
1882
1883 2012-10-15  Oleg Endo  <olegendo@gcc.gnu.org>
1884
1885         PR target/54760
1886         * config/sh/sh.c (sh_find_base_reg_disp): Stop searching insns when
1887         hitting a call insn if GBR is marked as call used.
1888         * config/sh/iterators.md (QIHISIDI): New mode iterator.
1889         * config/sh/predicates.md (gbr_address_mem): New predicate.
1890         * config/sh/sh.md (*movdi_gbr_load, *movdi_gbr_store): New
1891         insn_and_split.  Use QIHISIDI instead of QIHISI in unnamed GBR
1892         addressing splits.
1893
1894 2012-10-15  Oleg Endo  <olegendo@gcc.gnu.org>
1895
1896         * config/sh/sh.c: Update function attribute comments.
1897         * doc/extend.texi (function_vector): Rephrase SH2A specific part.
1898         (nosave_low_regs, renesas, trapa_handler): Document SH specific
1899         attributes.
1900         (sp_switch, trap_exit): Add to index.
1901
1902 2012-10-15  Matthias Klose  <doko@ubuntu.com>
1903
1904         * config.gcc: Match arm*-*-linux-* for ARM Linux/GNU.
1905         * doc/install.texi: Use arm-*-*linux-* instead of arm-*-*linux-gnueabi.
1906
1907 2012-10-15  Uros Bizjak  <ubizjak@gmail.com>
1908
1909         * config/i386/sse.md (UNSPEC_MOVU): Remove.
1910         (UNSPEC_LOADU): New.
1911         (UNSPEC_STOREU): Ditto.
1912         (<sse>_movu<ssemodesuffix><avxsizesuffix>): Split to ...
1913         (<sse>_loadu<ssemodesuffix><avxsizesuffix>): ... this and ...
1914         (<sse>_storeu<ssemodesuffix><avxsizesuffix>) ... this.
1915         (<sse2>_movdqu<avxsizesuffix>): Split to ...
1916         (<sse2>_loaddqu<avxsizesuffix>): ... this and ...
1917         (<sse2>_storedqu<avxsizesuffix>): ... this.
1918         (*sse4_2_pcmpestr_unaligned): Update.
1919         (*sse4_2_pcmpistr_unaligned): Ditto.
1920
1921         * config/i386/i386.c (ix86_avx256_split_vector_move_misalign): Use
1922         gen_avx_load{dqu,ups,upd}256 to load from unaligned memory and
1923         gen_avx_store{dqu,ups,upd}256 to store to unaligned memory.
1924         (ix86_expand_vector_move_misalign): Use gen_sse_loadups or
1925         gen_sse2_load{dqu,upd} to load from unaligned memory and
1926         gen_sse_loadups or gen_sse2_store{dqu,upd}256 to store to
1927         unaligned memory.
1928         (struct builtin_description bdesc_spec) <IX86_BUILTIN_LOADUPS>:
1929         Use CODE_FOR_sse_loadups.
1930         <IX86_BUILTIN_LOADUPD>: Use CODE_FOR_sse2_loadupd.
1931         <IX86_BUILTIN_LOADDQU>: Use CODE_FOR_sse2_loaddqu.
1932         <IX86_BUILTIN_STOREUPS>: Use CODE_FOR_sse_storeups.
1933         <IX86_BUILTIN_STOREUPD>: Use CODE_FOR_sse2_storeupd.
1934         <IX86_BUILTIN_STOREDQU>: Use CODE_FOR_sse2_storedqu.
1935         <IX86_BUILTIN_LOADUPS256>: Use CODE_FOR_avx_loadups256.
1936         <IX86_BUILTIN_LOADUPD256>: Use CODE_FOR_avx_loadupd256.
1937         <IX86_BUILTIN_LOADDQU256>: Use CODE_FOR_avx_loaddqu256.
1938         <IX86_BUILTIN_STOREUPS256>: Use CODE_FOR_avx_storeups256.
1939         <IX86_BUILTIN_STOREUPD256>: Use CODE_FOR_avx_storeupd256.
1940         <IX86_BUILTIN_STOREDQU256>: Use CODE_FOR_avx_storedqu256.
1941
1942 2012-10-15  Dodji Seketeli  <dodji@redhat.com>
1943
1944         * alias.c: Cleanup comments.
1945
1946 2012-10-15  Marc Glisse  <marc.glisse@inria.fr>
1947
1948         PR tree-optimization/54915
1949         * tree-ssa-forwprop.c (simplify_vector_constructor): Check
1950         argument's type.
1951
1952 2012-10-15  Richard Biener  <rguenther@suse.de>
1953
1954         * data-streamer.h (bp_pack_string_with_length): New function.
1955         (bp_pack_string): Likewise.
1956         (bp_unpack_indexed_string): Likewise.
1957         (bp_unpack_string): Likewise.
1958         * data-streamer-out.c (bp_pack_string_with_length): Likewise.
1959         (bp_pack_string): Likewise.
1960         * data-streamer-in.c (bp_unpack_indexed_string): Likewise.
1961         (bp_unpack_string): Likewise.
1962         * tree-streamer-out.c (pack_ts_translation_unit_decl_value_fields):
1963         Pack TRANSLATION_UNIT_LANGUAGE here, not ...
1964         (write_ts_translation_unit_decl_tree_pointers): ... here.  Remove.
1965         (streamer_pack_tree_bitfields): Adjust.
1966         (streamer_write_tree_body): Likewise.
1967         * tree-streamer-in.c (unpack_ts_translation_unit_decl_value_fields):
1968         Unpack TRANSLATION_UNIT_LANGUAGE here, not ...
1969         (lto_input_ts_translation_unit_decl_tree_pointers): ... here.  Remove.
1970         (unpack_value_fields): Adjust.
1971         (streamer_read_tree_body): Likewise.
1972
1973 2012-10-15  J"orn Rennecke  <joern.rennecke@arc.com>
1974
1975         * genoutput.c (process_template): Process '*' in '@' alternatives.
1976         * doc/md.texi (node Output Statement): Provide example for the above.
1977
1978 2012-10-15  Richard Guenther  <rguenther@suse.de>
1979
1980         PR tree-optimization/54920
1981         * tree-ssa-pre.c (create_expression_by_pieces): Properly
1982         allocate temporary storage for all NARY elements.
1983
1984 2012-10-15  Joern Rennecke  <joern.rennecke@embecosm.com>
1985
1986         * web.c (union_match_dups): Properly handle OP_INOUT match_dups.
1987
1988 2012-10-15  Eric Botcazou  <ebotcazou@adacore.com>
1989
1990         * expr.c (expand_expr_real_1) <VIEW_CONVERT_EXPR>: Do not unnecessarily
1991         copy the object in the MEM_P case.
1992
1993 2012-10-15  Richard Guenther  <rguenther@suse.de>
1994
1995         * tree-streamer-out.c (streamer_pack_tree_bitfields): Back
1996         BINFO_BASE_ACCESSES and CONSTRUCTOR lengths here.
1997         (streamer_write_chain): Write TREE_CHAIN as null-terminated list.
1998         (write_ts_exp_tree_pointers): Adjust.
1999         (write_ts_binfo_tree_pointers): Likewise.
2000         (write_ts_constructor_tree_pointers): Likewise.
2001         * tree-streamer-in.c (streamer_read_chain): Read TREE_CHAIN as
2002         null-terminated list.
2003         (unpack_value_fields): Unpack BINFO_BASE_ACCESSES and
2004         CONSTRUCTOR lengths and materialize the arrays.
2005         (lto_input_ts_exp_tree_pointers): Adjust.
2006         (lto_input_ts_binfo_tree_pointers): Likewise.
2007         (lto_input_ts_constructor_tree_pointers): Likewise.
2008
2009 2012-10-14  Hans-Peter Nilsson  <hp@bitrange.com>
2010
2011         * config/mmix/mmix.c (mmix_opposite_regno): Handle the
2012         return-value register too.
2013
2014 2012-10-14  Steven Bosscher  <steven@gcc.gnu.org>
2015
2016         PR rtl-optimization/38711
2017         * df.h (df_get_live_out, df_get_live_in): Make static inline functions.
2018         * df-problems.c (df_get_live_out, df_get_live_in): Moved to df.h.
2019         * ira-lives.c (process_bb_node_lives): Use df_get_live_out instead of
2020         DF_LR_OUT.
2021         * ira-build.c (create_bb_allocnos): Likewise.
2022         (create_loop_allocnos): Likewise, and use df_get_live_in instead of
2023         DF_LR_IN.
2024         * ira-emit.c (generate_edge_moves): Likewise.
2025         (add_ranges_and_copies): Likewise.
2026         * ira-color.c (ira_loop_edge_freq): Use df_get_live_out instead of
2027         DF_LR_OUT, and df_get_live_in instead of DF_LR_IN.
2028         * ira.c (mark_elimination): Update DF_LR and DF_LIVE.
2029         (build_insn_chain): Use df_get_live_out instead of DF_LR_OUT.
2030         (do_reload): Remove the DF_LIVE problem for -O1.
2031
2032 2012-10-14  Steven Bosscher  <steven@gcc.gnu.org>
2033
2034         PR rtl-optimization/54919
2035         * loop-unroll.c (struct var_to_expand): Remove accum_pos field.
2036         (analyze_insn_to_expand_var): Do not record accum_pos.
2037         (expand_var_during_unrolling): Use validate_replace_rtx_group to
2038         perform replacement of all references to SET_DEST (set) with the
2039         new register, including references in REG_EQUAL notes.
2040         (insert_var_expansion_initialization): Insert initializatio insns
2041         at the bottom of the pre-header of the loop.
2042
2043 2012-10-14  Jan Hubicka  <jh@suse.cz>
2044
2045         * tree-ssa-loop-niter.c (estimate_numbers_of_iterations_loop): Do not
2046         predict loops with multiple exits realistically.
2047         * cfgloopanal.c (single_likely_exit): New function.
2048
2049 2012-10-14  Uros Bizjak  <ubizjak@gmail.com>
2050
2051         * config/alpha/alpha.md: Remove empty predicates and/or constraints.
2052         * config/alpha/sync.md: Ditto.
2053
2054 2012-10-13  Uros Bizjak  <ubizjak@gmail.com>
2055
2056         * config/alpha/alpha.md (I24MODE): New mode iterator.
2057         (any_divmod): New code iterator.
2058         (<code>si3): Macroize expander from {div,mod,udiv,umod}si3 using
2059         any_divmod code iterator.
2060         (<code>si3): Macroize expander from {div,mod,udiv,umod}di3 using
2061         any_divmod code iterator.
2062         (extendqi<mode>2): Macroize insn from extendqi{hi,si}2 using
2063         I24MODE mode iterator.
2064         (unaligned_store<mode>): Macroize expander from unaligned_store{qi,hi}
2065         using I12MODE mode iterator.
2066         (mov<mode>): Macroize expander from mov{qi,hi} using
2067         I12MODE mode iterator.
2068
2069 2012-10-13  Eric Botcazou  <ebotcazou@adacore.com>
2070
2071         PR rtl-optimization/54871
2072         * loop-iv.c (simplify_using_initial_values): When scanning previous
2073         basic blocks, prune the recorded conditions if the current insn was
2074         not used to make a replacement.
2075
2076         * loop-unroll.c (decide_unroll_constant_iterations): Clean up message.
2077         (unroll_loop_constant_iterations): Clarify head comment.
2078         (decide_unroll_runtime_iterations): Clean up message.
2079         (unroll_loop_runtime_iterations): Clarify head comment.
2080         (decide_peel_simple): Clean up message.
2081         (peel_loop_simple): Clarify head comment.
2082         (decide_unroll_stupid): Clean up message.
2083         (unroll_loop_stupid): Clarify head comment.
2084
2085 2012-10-13  Andreas Schwab  <schwab@linux-m68k.org>
2086
2087         PR gcov-profile/44728
2088         * gcov.c (create_file_names): When stripping extension only look
2089         at base name.
2090
2091 2012-10-13  Jan Hubicka  <jh@suse.cz>
2092
2093         * loop-iv.c (determine_max_iter): Fix handling of AND.
2094         (iv_number_of_iterations): Record upper bounds as unsigned
2095         values.
2096
2097 2012-10-13  Steven Bosscher  <steven@gcc.gnu.org>
2098
2099         * ira.c (ira): Set current_loops to &ira_loops before recording
2100         loop exits.  Release recorded exits and loops early.
2101
2102 2012-10-13  Chung-Lin Tang  <cltang@codesourcery.com>
2103
2104         * builtins.c (expand_builtin_set_thread_pointer): Use
2105         create_input_operand() instead of create_fixed_operand().
2106
2107 2012-10-13  Uros Bizjak  <ubizjak@gmail.com>
2108
2109         * config/alpha/alpha.md (FMODE): New mode iterator.
2110         (modesuffix): Handle SF and DF modes.
2111         (opmode): New mode attribute.
2112         (abs<mode>2): Macroize insn from abs{sf,df}2 using FMODE mode iterator.
2113         (*nabs<mode>2): Macroize insn from *nabs{sf,df}2 using
2114         FMODE mode iterator.
2115         (neg<mode>2): Macroize insn from neg{sf,df}2 using FMODE mode iterator.
2116         (copysign<mode>3): Macroize insn from copysign{sf,df}3 using
2117         FMODE mode iterator.
2118         (*ncopysign<mode>3): Macroize insn from *ncopysign{sf,df}3 using
2119         FMODE mode iterator.
2120         (*add<mode>3_ieee): Macroize insn from *add{sf,df}_ieee using
2121         FMODE mode iterator.
2122         (add<mode>3): Macroize insn from add{sf,df}3 using FMODE mode iterator.
2123         (*sub<mode>3_ieee): Macroize insn from *sub{sf,df}3_ieee using
2124         FMODE mode iterator.
2125         (sub<mode>3): Macroize insn from sub{sf,df}3 using FMODE mode iterator.
2126         (*mul<mode>3_ieee): Macroize insn from *mul{sf,df}3_ieee using
2127         FMODE mode iterator.
2128         (mul<mode>3): Macroize insn from mul{sf,df}3 using FMODE mode iterator.
2129         (*div<mode>3_ieee): Macroize insn from *div{sf,df}3_ieee using
2130         FMODE mode iterator.
2131         (div<mode>3): Macroize insn from div{sf,df}3 using FMODE mode iterator.
2132         (*sqrt<mode>2_ieee): Macroize insn from *sqrt{sf,df}2_ieee using
2133         FMODE mode iterator.
2134         (sqrt<mode>2): Macroize insn from sqrt{sf,df}2
2135         using FMODE mode iterator.
2136         (*mov<mode>cc_internal): Macroize insn from *mov{sf,df}cc_internal
2137         using FMODE mode iterator.
2138         (mov<mode>cc): Macroize expander from mov{sf,df}cc
2139         using FMODE mode iterator.
2140
2141 2012-10-12  Oleg Endo  <olegendo@gcc.gnu.org>
2142
2143         PR target/54602
2144         * config/sh/sh.md: Correct define_delay for return insns.
2145         (*movsi_pop): Delete.
2146
2147 2012-10-12  Oleg Endo  <olegendo@gcc.gnu.org>
2148
2149         PR target/54680
2150         * config/sh/sh.c (sh_fsca_sf2int, sh_fsca_int2sf): Fix swapped
2151         comments.
2152         * config/sh/predicates.md (fpul_operand): Add comment.
2153         (fpul_fsca_operand, fsca_scale_factor): New predicates.
2154         * config/sh/sh.md (fsca): Move below sincossf3 expander.  Convert to
2155         insn_and_split.  Use fpul_fsca_operand and fsca_scale_factor
2156         predicates.  Simplify fpul operand in splitter.
2157
2158 2012-10-12  Jan Hubicka <jh@suse.cz>
2159
2160         * tree-ssa-threadupdate.c (def_split_header_continue_p): Do not
2161         escape the loop.
2162
2163 2012-10-12  Jan Hubicka <jh@suse.cz>
2164
2165         * web.c (web_main): Do not set DF_RD_PRUNE_DEAD_DEFS flag.
2166
2167 2012-10-12  Aaron Gray <aaronngray.lists@gmail.com>
2168             Diego Novillo <dnovillo@google.com>
2169
2170         * gengtype-lex.l: Support for C++ single line comments.
2171         Support for classes.
2172         (CXX_KEYWORD): New.  Support C++ keywords inline, public,
2173         protected, private, template, operator, friend, &, ~.
2174         (TYPEDEF): New.  Support typedef.
2175         * gengtype-parser.c: updated 'token_names[]'
2176         (direct_declarator): Add support for parsing functions and ctors.
2177
2178 2012-10-12  Diego Novillo  <dnovillo@google.com>
2179
2180         * doc/gty.texi: Document C++ limitations in gengtype.
2181         * gengtype-lex.l (CID): Rename from ID.
2182         (ID): Include scoping '::' as part of the identifier name.
2183         * gengtype-parse.c (token_names): Update.
2184         (token_value_format): Update.
2185         (consume_until_eos): Rename from consume_until_semi.
2186         Remove unused argument IMMEDIATE.  Update all callers.
2187         Also consider '}' as a finalizer.
2188         (consume_until_comma_or_eos): Rename from
2189         consume_until_comma_or_semi.
2190         Remove unused argument IMMEDIATE.  Update all callers.
2191         Also consider '}' as a finalizer.
2192         (direct_declarator): Add documentation on ctor support.
2193         Add argument IN_STRUCT.
2194         If the token following ID is a '(', consider ID a
2195         function and return NULL.
2196         If the token following '(' is not a '*', and IN_STRUCT is true,
2197         conclude that this is a ctor and return NULL.
2198         If the token is IGNORABLE_CXX_KEYWORD, return NULL.
2199         (inner_declarator): Add argument IN_STRUCT.
2200         Update all callers.
2201         (declarator): Add argument IN_STRUCT with default value false.
2202         Update all callers.
2203         (type): Document argument NESTED.
2204         Skip over C++ inheritance specifiers.
2205         If a token TYPEDEF is found, emit an error.
2206         If an enum is found inside a class/structure, emit an error.
2207         (typedefs, structures, param_structs, variables): Initialize.
2208         (new_structure): Do not complain about duplicate
2209         structures if S has a line location set.
2210         * gengtype-state.c (write_state_type): Remove default handler.
2211         Add handler for TYPE_NONE.
2212         (read_state_scalar_char_type):
2213         * gengtype.c: Fix spacing.
2214         * gengtype.h (enum gty_token): Add name.  Add token
2215         IGNORABLE_CXX_KEYWORD.
2216
2217 2012-10-12  Chung-Lin Tang  <cltang@codesourcery.com>
2218
2219         * config/arm/arm.md (get_thread_pointersi): Moved to place with
2220         other TLS related patterns.
2221
2222 2012-10-12  Richard Biener  <rguenther@suse.de>
2223
2224         * tree-streamer-out.c (pack_ts_target_option): Rename from ...
2225         (write_ts_target_option): ... this.
2226         (pack_ts_optimization): Rename from ...
2227         (write_ts_optimization): ... this.
2228         (streamer_pack_tree_bitfields): Pack them in the bitfield section ...
2229         (streamer_write_tree_body): ... not here.
2230         * tree-streamer-in.c (unpack_ts_target_option): Rename from ...
2231         (lto_input_ts_target_option): ... this.
2232         (unpack_ts_optimization): Rename from ...
2233         (lto_input_ts_optimization): ... this.
2234         (unpack_value_fields): Unpack them from the bitfield section ...
2235         (streamer_read_tree_body): ... not from here.
2236
2237 2012-10-12  Uros Bizjak  <ubizjak@gmail.com>
2238
2239         * config/alpha/alpha.md (vecmodesuffix): New mode attribute.
2240         (modesuffix): Handle V8QI and V4HI modes.
2241         (any_maxmin): New code iterator.
2242         (maxmin): New code attribute.
2243         (<code><mode>3): Macroize insn from {smax,smin,umax,umin}{qi,hi}3
2244         using any_maxmin code iterator and I12MODE mode iterator.
2245         (<code><mode>3): Macroize insn from {smax,smin,umax,umin}{v8qi,v4hi}3
2246         using any_maxmin code iterator and VEC12 mode iterator.
2247
2248 2012-10-12  Marc Glisse  <marc.glisse@inria.fr>
2249
2250         * optabs.c (vector_compare_rtx): Change prototype.
2251         (expand_vec_cond_expr): Handle VEC_COND_EXPR whose first operand
2252         is not a comparison.
2253         * gimplify.c (gimplify_expr): Handle VEC_COND_EXPR.
2254
2255 2012-10-12  Richard Biener  <rguenther@suse.de>
2256
2257         PR tree-optimization/54894
2258         * tree-vect-stmts.c (get_vectype_for_scalar_type_and_size):
2259         Handle over-aligned scalar types properly.
2260
2261 2012-10-12  Oleg Endo  <olegendo@gcc.gnu.org>
2262
2263         PR target/54760
2264         * config/sh/sh.c (bdesc): Remove thread pointer built-ins.
2265         * config/sh/sh.md (get_thread_pointer, set_thread_pointer): Append mode
2266         name 'si'.
2267
2268 2012-10-12  Oleg Endo  <olegendo@gcc.gnu.org>
2269
2270         PR target/51244
2271         * config/sh/sh.md (negsi_cond, negdi_cond, stack_protect_test): Remove
2272         get_t_reg_rtx when invoking gen_branch_true or gen_branch_false.
2273         (*zero_extend<mode>si2_compact): Convert to insn_and_split.  Convert
2274         zero extensions of T bit stores to reg moves in splitter.  Remove
2275         obsolete unnamed peephole2 that caught zero extensions after negc T bit
2276         stores.
2277         (*branch_true_eq, *branch_false_ne): Delete.
2278         (branch_true, branch_false): Convert insn to expander.  Move actual
2279         insn logic to...
2280         (*cbranch_t): ...this new insn_and_split.  Try to find preceding
2281         redundant T bit stores and tests and combine them with the conditional
2282         branch if possible in the splitter.
2283         (movrt_xor, *movt_movrt): New insn_and_split.
2284         * config/sh/predicates.md (cbranch_treg_value): New predicate.
2285         * config/sh/sh-protos.h (sh_eval_treg_value): Forward declare...
2286         * config/sh/sh.c (sh_eval_treg_value): ...this new function.
2287         (expand_cbranchsi4, expand_cbranchdi4): Remove get_t_reg_rtx
2288         when invoking gen_branch_true or gen_branch_false.
2289
2290 2012-10-11  Uros Bizjak  <ubizjak@gmail.com>
2291
2292         * config/alpha/alpha.md (IMODE): New mode iterator.
2293         (I124MODE): Ditto.
2294         (I248MODE): Ditto.
2295         (modesuffix): Handle QI and HI modes.
2296         (zero_extendqi<mode>2): Macroize insn from zero_extendqi{hi,si,di}2
2297         using I248MODE mode iterator.
2298         (zero_extendhi<mode>2): Macroize insn from zero_extendhi{si,di}2
2299         using I48MODE mode iterator.
2300         (andnot<mode>3): Macroize insn from andnot{si,di}3 using
2301         I48MODE mode iterator.
2302         (ins<modesuffix>l_const): Macroize insn from ins{b,w,l}l_const
2303         using I248MODE mode iterator.
2304         (ins<modesuffix>l): Macroize insn from ins{b,w,l}l
2305         using I248MODE mode iterator.
2306         (*mov<mode>cc_internal): Macroize insn from
2307         *mov{qi,hi,si,di}cc_internal using IMODE mode iterator.
2308         (*mov<mode>cc_lbc): Macroize insn from
2309         *mov{qi,hi,si,di}cc_lbc using IMODE mode iterator.
2310         (*mov<mode>cc_lbs): Macroize insn from
2311         *mov{qi,hi,si,di}cc_lbs using IMODE mode iterator.
2312         (mov<mode>cc): Macroize expander from mov{si,di}cc
2313         using I48MODE mode iterator.
2314
2315 2012-10-11  Steven Bosscher  <steven@gcc.gnu.org>
2316
2317         * ira-build.c (ira_loop_tree_body_rev_postorder): New function.
2318         (ira_traverse_loop_tree): Traverse a loop's basic blocks in
2319         reverse post-order of the reversed control-flow direction.
2320         * ira-conflicts.c (ira_build_conflicts): Pass add_copies as
2321         the pre-order function to ira_traverse_loop_tree to preserve
2322         the existing semantics.
2323
2324         * ira-lives.c (remove_some_program_points_and_update_live_ranges):
2325         Squeeze out live range chain elements if their program points are
2326         connected.
2327
2328 2012-10-11  Jakub Jelinek  <jakub@redhat.com>
2329
2330         * tree.def (REDUC_PLUS_EXPR): Fix up comment.
2331
2332         * fold-const.c (fold_unary_loc): Handle REDUC_MIN_EXPR,
2333         REDUC_MAX_EXPR and REDUC_PLUS_EXPR.
2334
2335 2012-10-11  James Lemke  <jwlemke@codesourcery.com>
2336
2337         * config/rs6000/predicates.md (zero_fp_constant): Fix comment.
2338         * config/rs6000/rs6000.md (return_pred): Fix null return.
2339         * config/rs6000/rs6000.c (rs6000_emit_set_const): Fix indentation.
2340         (print_operand): Make FALLTHRU obvious.
2341         (output_cbranch): Correct comment.
2342
2343 2012-10-11  Uros Bizjak  <ubizjak@gmail.com>
2344
2345         * config/alpha/alpha.md (DWI): New mode attribute.
2346         (*sadd<modesuffix>): Macroize insn from *saddl and *saddq using
2347         I48MODE mode iterator.
2348         (addv<mode>3): Macroize insn from addvsi3 and addvdi3 using
2349         I48MODE mode iterator.
2350         (neg<mode>2): Macroize insn from negsi2 and negdi2 using
2351         I48MODE mode iterator.
2352         (negv<mode>2): Macroize insn from negvsi2 and negvdi2 using
2353         I48MODE mode iterator.
2354         (sub<mode>3): Macroize insn from subsi3 and subdi3 using
2355         I48MODE mode iterator.
2356         (*ssub<modesuffix>): Macroize insn from *ssubl and *ssubq using
2357         I48MODE mode iterator.
2358         (subv<mode>3): Macroize insn from subvsi3 and subvdi3 using
2359         I48MODE mode iterator.
2360         (mul<mode>3): Macroize insn from mulsi3 and muldi3 using
2361         I48MODE mode iterator.
2362         (mulv<mode>3): Macroize insn from mulvsi3 and mulvdi3 using
2363         I48MODE mode iterator.
2364         (*iornot<mode>3): Macroize insn from *iornotsi3 and *iornotdi3 using
2365         I48MODE mode iterator.
2366         (*xornot<mode>3): Macroize insn from *xornotsi3 and *xornotdi3 using
2367         I48MODE mode iterator.
2368
2369 2012-10-11  Jason Merrill  <jason@redhat.com>
2370
2371         * configure.ac (gcc_cv_as_aix_ref): Fix typo.
2372         * configure: Regenerate.
2373
2374 2012-10-11  Chung-Lin Tang  <cltang@codesourcery.com>
2375
2376         * builtins.c (expand_builtin_thread_pointer): New.
2377         (expand_builtin_set_thread_pointer): New.
2378         (expand_builtin): Add BUILT_IN_THREAD_POINTER,
2379         BUILT_IN_SET_THREAD_POINTER expand cases.
2380         * builtins.def (BUILT_IN_THREAD_POINTER):
2381         New __builtin_thread_pointer builtin.
2382         (BUILT_IN_SET_THREAD_POINTER):
2383         New __builtin_set_thread_pointer builtin.
2384         * optabs.def (get_thread_pointer,set_thread_pointer):
2385         New standard names.
2386         * doc/md.texi (Standard Names): Document get_thread_pointer and
2387         set_thread_pointer patterns.
2388         * config/alpha/alpha.md (get_thread_pointerdi): Rename from load_tp.
2389         (set_thread_pointerdi): Rename from set_tp.
2390         * config/alpha/alpha.c (alpha_legitimize_address_1): Change
2391         gen_load_tp calls to gen_get_thread_pointerdi.
2392         (alpha_builtin): Remove ALPHA_BUILTIN_THREAD_POINTER,
2393         ALPHA_BUILTIN_SET_THREAD_POINTER.
2394         (code_for_builtin): Remove CODE_FOR_load_tp, CODE_FOR_set_tp.
2395         (alpha_init_builtins): Remove __builtin_thread_pointer,
2396         __builtin_set_thread_pointer machine-specific builtins.
2397         (alpha_expand_builtin_thread_pointer): Add hook function for
2398         TARGET_EXPAND_BUILTIN_THREAD_POINTER.
2399         (alpha_expand_builtin_set_thread_pointer): Add hook function for
2400         TARGET_EXPAND_BUILTIN_SET_THREAD_POINTER.
2401         (alpha_fold_builtin): Remove ALPHA_BUILTIN_THREAD_POINTER,
2402         ALPHA_BUILTIN_SET_THREAD_POINTER cases.
2403         * config/arm/arm.md (get_thread_pointersi): New pattern.
2404         * config/arm/arm-protos.h (arm_load_tp): Add extern declaration.
2405         * config/arm/arm.c (arm_load_tp): Remove static.
2406         (arm_builtins): Remove ARM_BUILTIN_THREAD_POINTER.
2407         (arm_init_tls_builtins): Remove function.
2408         (arm_init_builtins): Remove call to arm_init_tls_builtins().
2409         (arm_expand_builtin): Remove ARM_BUILTIN_THREAD_POINTER case.
2410         * config/mips/mips.md (get_thread_pointer<mode>): New pattern.
2411         * config/mips/mips-protos.h (mips_expand_thread_pointer):
2412         Add extern declaration.
2413         * config/mips/mips.c (mips_expand_thread_pointer):
2414         Renamed from mips_get_tp.
2415         (mips_get_tp): New stub calling mips_expand_thread_pointer.
2416         * config/s390/s390.c (s390_builtin,code_for_builtin_64,
2417         code_for_builtin_31,s390_init_builtins,s390_expand_builtin): Remove.
2418         * config/s390/s390.md (get_tp_64,get_tp_31,set_tp_64,set_tp_31):
2419         Remove.
2420         (get_thread_pointer<mode>,set_thread_pointer<mode>):
2421         New, adapted from removed patterns.
2422         * config/xtensa/xtensa.md (get_thread_pointersi):
2423         Renamed from load_tp.
2424         (set_thread_pointersi): Renamed from set_tp.
2425         * config/xtensa/xtensa.c (xtensa_legitimize_tls_address):
2426         Change gen_load_tp calls to gen_get_thread_pointersi.
2427         (xtensa_builtin): Remove XTENSA_BUILTIN_THREAD_POINTER and
2428         XTENSA_BUILTIN_SET_THREAD_POINTER.
2429         (xtensa_init_builtins): Remove __builtin_thread_pointer,
2430         __builtin_set_thread_pointer machine-specific builtins.
2431         (xtensa_fold_builtin): Remove XTENSA_BUILTIN_THREAD_POINTER,
2432         XTENSA_BUILTIN_SET_THREAD_POINTER cases.
2433         (xtensa_expand_builtin): Remove XTENSA_BUILTIN_THREAD_POINTER,
2434         XTENSA_BUILTIN_SET_THREAD_POINTER cases.
2435
2436 2012-10-11  Marc Glisse  <marc.glisse@inria.fr>
2437
2438         * doc/extend.texi (Vector Extensions): C++ improvements.
2439         * doc/generic.texi (LSHIFT_EXPR, RSHIFT_EXPR): Mixed vector-scalar.
2440         (LT_EXPR, LE_EXPR, GT_EXPR, GE_EXPR, EQ_EXPR, NE_EXPR): Specify
2441         the vector case.
2442         (VEC_COND_EXPR): Document it.
2443
2444 2012-10-11  Terry Guo  <terry.guo@arm.com>
2445
2446         * config/arm/arm.c (arm_arch6m): New variable to denote armv6-m
2447         architecture.
2448         * config/arm/arm.h (TARGET_HAVE_DMB): The armv6-m also has DMB
2449         instruction.
2450
2451 2012-10-11  Hans-Peter Nilsson  <hp@bitrange.com>
2452
2453         PR target/54373
2454         * configure.ac (out-of-tree linker .hidden support) Set to "no"
2455         for mmix-knuth-mmixware.
2456         * configure: Regenerate.
2457
2458         * configure.ac (gcc_cv_as_comdat_group_group): Default to no.
2459         * configure: Regenerate.
2460
2461         * acinclude.m4 (_gcc_COMPUTE_GAS_VERSION): Allow a single
2462         character to quote the VERSION= contents.  Sanity-check contents.
2463         * configure.ac ("what linker to use" ld version extraction): Ditto.
2464         * configure: Regenerate.
2465
2466 2012-10-10  Segher Boessenkool  <segher@kernel.crashing.org>
2467
2468         * config/rs6000/rs6000.h (PRINT_OPERAND_PUNCT_VALID_P): Delete '.'.
2469
2470 2012-10-10  Jakub Jelinek  <jakub@redhat.com>
2471
2472         PR tree-optimization/54877
2473         * tree-vect-loop.c (vect_is_simple_reduction_1): For MINUS_EXPR
2474         use make_ssa_name instead of copy_ssa_name.
2475
2476 2012-10-10  Richard Biener  <rguenther@suse.de>
2477
2478         * lto-streamer-in.c (lto_input_location_bitpack): Rename to ...
2479         (lto_input_location): ... this.  Kill original.
2480         (input_eh_region): Adjust.
2481         (input_struct_function_base): Likewise.
2482         (lto_read_tree): Likewise.
2483         * lto-streamer-out.c (lto_output_location_bitpack): Rename to ...
2484         (lto_output_location): ... this.  Kill original.
2485         (lto_write_tree): Adjust.
2486         (output_eh_region): Likewise.
2487         (output_struct_function_base): Likewise.
2488         * lto-streamer.c (lto_streamer_hooks_init): Initialize location hooks.
2489         * lto-streamer.h (lto_input_location): Adjust prototype.
2490         (lto_output_location): Likewise.
2491         * streamer-hooks.h (struct streamer_hooks): Adjust prototype
2492         of input_location and output_location hooks.
2493         (stream_input_location): New define.
2494         (stream_output_location): Likewise.
2495         * tree-streamer-in.c (unpack_ts_block_value_fields): Adjust.
2496         (unpack_value_fields): Likewise.
2497         (streamer_read_tree_bitfields): Likewise.
2498         (lto_input_ts_decl_minimal_tree_pointers): Likewise.
2499         (lto_input_ts_exp_tree_pointers): Likewise.
2500         (lto_input_ts_block_tree_pointers): Likewise.
2501         * tree-streamer-out.c (pack_ts_block_value_fields): Adjust.
2502         (streamer_pack_tree_bitfields): Likewise.
2503         (write_ts_decl_minimal_tree_pointers): Likewise.
2504         (write_ts_exp_tree_pointers): Likewise.
2505         (write_ts_block_tree_pointers): Likewise.
2506         * gimple-streamer-in.c (input_phi): Adjust.
2507         (input_gimple_stmt): Likewise.
2508         * gimple-streamer-out.c (output_phi): Adjust.
2509         (output_gimple_stmt): Likewise.
2510         * tree-streamer.h (streamer_read_tree_bitfields): Adjust prototype.
2511         (streamer_pack_tree_bitfields): Likewise.
2512
2513 2012-10-10  Michael Meissner  <meissner@linux.vnet.ibm.com>
2514
2515         * config/rs6000/rs6000.c (altivec_expand_dst_builtin): Fix signed
2516         vs. unsigned warnings by using enum type for function code.
2517         (paired_expand_builtin): Likewise.
2518         (spe_expand_builtin): Likewise.
2519
2520         * config/rs6000/rs6000-c.c (rs6000_target_modify_macros): Change
2521         builtin mask, target flags masks type to HOST_WIDE_INT in
2522         preparation for growing the number of ISA switches from 31 to 63.
2523
2524         * config/rs6000/rs6000.opt (rs6000_builtin_mask): Make mask type
2525         HOST_WIDE_INT.
2526
2527         * config/rs6000/rs6000.c (struct builtin_description): Make
2528         builtin mask field HOST_WIDE_INT.  Make target flags field
2529         HOST_WIDE_INT in preparation for growing the # of ISA switches.
2530         (struct rs6000_builtin_info_type): Likewise.
2531         (struct rs6000_ptt): Likewise.
2532         (rs6000_builtin_mask_calculate): Likewise.
2533         (rs6000_invalid_builtin): Likewise.
2534         (rs6000_builtin_decl): Likewise.
2535         (rs6000_common_init_builtins): Likewise.
2536         (rs6000_darwin_file_start): Likewise.
2537         (rs6000_final_prescan_insn): Likewise.
2538         (rs6000_inner_target_options): Likewise.
2539         (build_target_option_node): Likewise.
2540         (rs6000_function_specific_print): Likewise.
2541         (DEBUG_FMT_W): New format for printing HOST_WIDE_INT in hex.
2542
2543         * config/rs6000/rs6000-protos.h (rs6000_builtin_mask_calculate):
2544         Make target flags, builtin masks arguments/return values
2545         HOST_WIDE_INT in preparation for growing the number of ISA from 31
2546         to 63.
2547         (rs6000_target_modify_macros): Likewise.
2548         (rs6000_target_modify_macros_ptr): Likewise.
2549
2550         * config/rs6000/rs6000.c (DEBUG_FMT_ID): Move "-32s" to a separate
2551         define and change DEBUG_FMT_<x> to use it.
2552         (DEBUG_FMT_D): Likewise.
2553         (DEBUG_FMT_S): Likewise.
2554         (DEBUG_FMT_X): Delete, no longer used.
2555         (DEBUG_FMT_W): Likewise.
2556         (DEBUG_FMT_WX): New debug format for printing options in a
2557         friendly fashion.
2558         (rs6000_debug_reg_global): If -mdebug=reg, print all of the
2559         options in target_flags and target_flags_explicit.  Print the
2560         default options for -mcpu=<xxx>, -mtune=<xxx>, and the default
2561         options.  Adjust printing out the builtin options.
2562         (rs6000_option_override_internal): Change printing the builtin
2563         options to use rs6000_print_builtin_options.
2564         (rs6000_function_specific_print): Change to use
2565         rs6000_print_isa_options to print ISA flags.
2566         (rs6000_print_options_internal): New function for expanded
2567         -mdebug=reg option printing to print both the ISA options, and the
2568         builtins that are enabled.
2569         (rs6000_print_isa_options): New function to print the ISA options.
2570         (rs6000_print_builtin_options): New function to print the builtin
2571         functions enabled.
2572
2573 2012-10-10  Jakub Jelinek  <jakub@redhat.com>
2574
2575         PR target/51109
2576         * config/i386/bdver1.md (bdver1-mult): Remove.
2577
2578         PR middle-end/54879
2579         * combine.c (count_rtxs): Use RTX_BIN_ARITH resp. RTX_COMM_ARITH
2580         instead of '2' resp. 'c' for GET_RTX_CLASS comparisons.
2581
2582         PR middle-end/54862
2583         * simplify-rtx.c (simplify_truncation): Compare UINTVAL instead of
2584         INTVAL of second argument with precision resp. op_precision.
2585
2586 2012-10-10  Dodji Seketeli  <dodji@redhat.com>
2587
2588         PR middle-end/54860 - Make sure attributes hash table is created
2589         * attribs.c (register_scoped_attributes): Ensure the attribute
2590         hash table is created.
2591
2592 2012-10-10  Ganesh Gopalasubramanian  <Ganesh.Gopalasubramanian@amd.com>
2593
2594         PR target/51109
2595         * config/i386/bdver1.md (bdver1_int): Automaton has been
2596         split to reduce state transitions.
2597
2598 2012-10-10  Richard Biener  <rguenther@suse.de>
2599
2600         PR middle-end/54876
2601         * ipa-prop.c (prune_expression_for_jf_1): New function.
2602         (prune_expression_for_jf): Clear EXPR_LOCATION for all
2603         sub-expressions as well.
2604
2605 2012-10-10  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
2606
2607         * config.gcc: Enable zEC12 for with-arch and with-tune
2608         configure switches.
2609         * common/config/s390/s390-common.c (processor_flags_table): Add
2610         zEC12 entry.
2611         * config/s390/2827.md: New file.
2612         * config/s390/s390-opts.h (enum processor_type): Add
2613         PROCESSOR_2827_ZEC12.
2614         * config/s390/s390.h (enum processor_flags): Add PF_ZEC12.
2615         (TARGET_CPU_ZEC12, TARGET_ZEC12): New macro definitions.
2616         * config/s390/s390.c (zEC12_cost): New definition.
2617         (s390_option_override): Set costs for zEC12.
2618         Set parameter defaults for zEC12.
2619         (legitimate_reload_fp_constant_p): Adjust comment.
2620         (preferred_la_operand_p): Adjust comment.
2621         (s390_expand_insv): Generate insv pattern without CC clobber for zEC12.
2622         (s390_adjust_priority): Add zEC12 check.
2623         (s390_issue_rate): Return 2 for zEC12.
2624         (s390_reorg): Enable code optimizations for zEC12.
2625         (s390_sched_reorder): Reorder insns according to OOO attributes.
2626         (s390_get_sched_attrmask): New function.
2627         (s390_sched_score): New function.
2628         (s390_sched_variable_issue): Update s390_sched_state.
2629         (s390_sched_init): Reset s390_sched_state.
2630         (s390_loop_unroll_adjust): Enable for zEC12.
2631         * config/s390/s390.opt: Add zEC12 processor type value.
2632         * config/s390/s390.md: Enable mnemonic attribute.
2633         (attr cpu, cpu_facility): Add zEC12.
2634         Include 2827.md.
2635         ("*insv<mode>_zEC12", "*insv<mode>_zEC12_noshift")
2636         ("*load_and_trap<mode>"): New insn definition.
2637         ("*cmp_and_trap_unsigned_int<mode>"): Add clt and clgt.
2638
2639 2012-10-09  David S. Miller  <davem@davemloft.net>
2640
2641         * config/sparc/sparc.md (type attribute): Add new types 'visl'
2642         (VIS logical operation), 'vismv' (VIS move), and 'pdistn'.  Rename
2643         'fgm_pdist' to 'pdist'.
2644         (*movsi_insn): Use vismv and visl.
2645         (*movdi_insn_sp64): Likewise.
2646         (*movsf_insn): Likewise.
2647         (*movdf_insn_sp64): Likewise.
2648         (*mov<VM32:mode>_insn): Likewise, use 'fsrc2s' instead of 'fsrc1s'.
2649         (*mov<VM64:mode>_insn_sp64): Likewise, use 'fsrc2s'
2650         instead of 'fsrc1s'.
2651         (*mov<VM64:mode>_insn_sp32): Likewise, use 'fsrc2s'
2652         instead of 'fsrc1s'.
2653         (VIS logical instructions): Mark as visl.
2654         (pdist_vis): Use 'pdist'.
2655         (pditsn<mode>_vis): Use 'pdistn'.
2656         * config/sparc/ultra1_2.md: Adjust for new VIS attribute types.
2657         * config/sparc/ultra3.md: Likewise.
2658         * config/sparc/niagara.md: Likewise.
2659         * config/sparc/niagara2.md: Likewise.
2660         * config/sparc/niagara4.md: Add cpu units "n4_slot2" and
2661         "n4_load_store" for special store scheduling.  Use them in load
2662         and store reservations.  Integer divide and multiply can only
2663         issue in slot-1.  Represent 1-cycle VIS moves and 3-cycle VIS
2664         logic operations.
2665
2666 2012-10-10  Dehao Chen  <dehao@google.com>
2667
2668         * tree-eh.c (lower_try_finally_onedest): Set correct location for
2669         deallocator.
2670         * gimplify.c (gimplify_expr): Set correct location for TRY stmt.
2671
2672 2012-10-10  Oleg Endo  <olegendo@gcc.gnu.org>
2673
2674         PR target/52480
2675         * config/sh/sh.md (extv, extzv): Check that operands[3] is zero,
2676         regardless of the endianness.
2677
2678 2012-10-09  Lawrence Crowl  <crowl@google.com>
2679
2680         * Makefile.in (fold-const.o): Add depencence on hash-table.h.
2681         (dse.o): Likewise.
2682         (cfg.o): Likewise.
2683         * fold-const.c (fold_checksum_tree): Change to new
2684         type-safe hash table.
2685         * (print_fold_checksum): Likewise.
2686         * cfg.c (var bb_original): Likewise.
2687         * (var bb_copy): Likewise.
2688         * (var loop_copy): Likewise.
2689         * hash-table.h (template hash_table): Constify parameters for find...
2690         and remove_elt... member functions.
2691         (hash_table::empty) Correct size expression.
2692         (hash_table::clear_slot) Correct deleted entry assignment.
2693         * dse.c (var rtx_group_table): Change to new type-safe hash table.
2694
2695 2012-10-09  Steven Bosscher  <steven@gcc.gnu.org>
2696
2697         * basic-block. (profile_record): New struct, moved from passes.c.
2698         * cfghooks.h (struct cfg_hooks) <account_profile_record>: New hook.
2699         (account_profile_record): New prototype.
2700         * cfghooks.c (account_profile_record): New function.
2701         * tree-cfg.c (gimple_account_profile_record): New function
2702         (gimple_cfg_hooks): Add it.
2703         * cfgrtl.c (rtl_account_profile_record): New function
2704         (rtl_cfg_hooks, cfg_layout_rtl_cfg_hooks): Add it.
2705         * passes.c (check_profile_consistency): Simplify.  Move IR-dependent
2706         code around using cfghooks machinery.
2707
2708 2012-10-09  Oleg Endo  <olegendo@gcc.gnu.org>
2709
2710         PR target/54760
2711         * doc/extend.texi (Target Builtins): Add SH built-in section.
2712         Document __builtin_thread_pointer and __builtin_set_thread_pointer.
2713
2714 2012-10-09  Venkataramanan Kumar  <venkataramanan.kumar@amd.com>
2715
2716         PR middle-end/53397
2717         * tree-ssa-loop-prefetch.c (gather_memory_references_ref):
2718         Perform non constant step prefetching in inner loop, only
2719         when it is invariant in the entire loop nest.
2720         * tree-ssa-loop-prefetch.c (dump_mem_details): New function to dump
2721         base, step and delta values of memeory reference analysed for
2722         prefetching.
2723         * tree-ssa-loop-prefetch.c (dump_mem_ref): Call dump_mem_details
2724         to print base, step and delta values of memory reference.
2725         * cfgloop.h (loop_outermost): New function that returns outermost
2726         loop for a given loop in a loop nest.
2727
2728 2012-10-09  Richard Guenther  <rguenther@suse.de>
2729
2730         PR middle-end/54837
2731         * cfgexpand.c (expand_debug_source_expr): Move checking
2732         code conditional on a found decl_debug_args vector.
2733
2734 2012-10-09  Richard Guenther  <rguenther@suse.de>
2735
2736         * tree-streamer.c (streamer_tree_cache_get): Move ...
2737         * tree-streamer.h (streamer_tree_cache_get): ... here as inline.
2738
2739 2012-10-09  Jan Hubicka  <jh@suse.cz>
2740
2741         * loop-unroll.c (unroll_loop_constant_iterations): Add
2742         update of loop->nb_iterations_upper_bound I missed in my previous
2743         commit; use TRUNC_DIV_EXPR instead of FLOOR_DIV_EXPR to divide
2744         iteration count.
2745         (decide_unroll_runtime_iterations): Avoid overflow.
2746         (unroll_loop_runtime_iterations): Use TRUNC_DIV_EXPR instead of
2747         FLOOR_DIV_EXPR to update iteration bounds.
2748         (decide_peel_simple): Avoid integer overflow when deciding
2749         on number of peelings.
2750         (decide_unroll_stupid): Likewise.
2751
2752 2012-10-09  Tobias Burnus  <burnus@net-b.de>
2753
2754         * lto-cgraph.c (input_node_opt_summary): Remove unused code.
2755         * lto-opts.c (append_to_collect_gcc_options): Fix condition.
2756         * lto-symtab.c (lto_cgraph_replace_node): Don't xstrdup string
2757         which is passed to fprintf.
2758
2759 2012-10-09  Paolo Carlini  <paolo.carlini@oracle.com>
2760
2761         PR c++/54194
2762         * tree.h: Add EXPR_LOC_OR_LOC.
2763
2764 2012-10-09  Nick Clifton  <nickc@redhat.com>
2765
2766         PR rtl-optimization/54739
2767         * config/mcore/mcore.md: (anddi3, iordi3, xordi3): Delete patterns.
2768
2769         PR target/54661
2770         * config/mcore/mcore.c (mcore_output_movedouble): Fix typo.
2771
2772 2012-10-09  Marc Glisse  <marc.glisse@inria.fr>
2773
2774         PR c++/54427
2775         * fold-const.c (fold_binary_loc): Use build_zero_cst instead of
2776         build_int_cst for a potential vector.
2777
2778 2012-10-08  Uros Bizjak  <ubizjak@gmail.com>
2779
2780         * config/i386/atom.md (atom_sse_4): Merge atom_sse_attr attibutes.
2781         (atom_sse_5): Ditto.
2782
2783 2012-10-08  Marc Glisse  <marc.glisse@inria.fr>
2784
2785         PR target/54400
2786         * config/i386/i386.md (type attribute): Add sseadd1.
2787         (unit attribute): Add support for sseadd1.
2788         (memory attribute): Likewise.
2789         * config/i386/athlon.md: Likewise.
2790         * config/i386/core2.md: Likewise.
2791         * config/i386/atom.md: Likewise.
2792         * config/i386/ppro.md: Likewise.
2793         * config/i386/bdver1.md: Likewise.
2794         * config/i386/sse.md (sse3_h<plusminus_insn>v2df3): Split into...
2795         (sse3_haddv2df3): ... expander.
2796         (*sse3_haddv2df3): ... define_insn. Accept permuted operands.
2797         (sse3_hsubv2df3): ... define_insn.
2798         (*sse3_haddv2df3_low): New define_insn.
2799         (*sse3_hsubv2df3_low): New define_insn.
2800
2801 2012-10-08  Jan Hubicka  <jh@suse.cz>
2802
2803         * loop-unswitch.c (unswitch_single_loop): Use
2804         estimated_loop_iterations_int to prevent unswitching when loop
2805         is known to not roll.
2806         * tree-ssa-loop-niter.c (estimated_loop_iterations): Do not segfault
2807         when SCEV is not initialized.
2808         (max_loop_iterations): Likewise.
2809         * tree-ssa-loop-unswitch.c (tree_ssa_unswitch_loops): Use
2810         estimated_loop_iterations_int to prevent unswithcing when
2811         loop is known to not roll.
2812         * tree-scalar-evolution.c (scev_initialized_p): New function.
2813         * tree-scalar-evolution.h (scev_initialized_p): Likewise.
2814         * loop-unroll.c (decide_peel_once_rolling): Use
2815         max_loop_iterations_int.
2816         (unroll_loop_constant_iterations): Update
2817         nb_iterations_upper_bound and nb_iterations_estimate.
2818         (decide_unroll_runtime_iterations): Use
2819         estimated_loop_iterations or max_loop_iterations;
2820         (unroll_loop_runtime_iterations): fix profile updating.
2821         (decide_peel_simple): Use estimated_loop_iterations
2822         and max_loop_iterations.
2823         (decide_unroll_stupid): Use estimated_loop_iterations
2824         ad max_loop_iterations.
2825         * loop-doloop.c (doloop_modify): Use max_loop_iterations_int.
2826         (doloop_optimize): Likewise.
2827         * loop-iv.c (iv_number_of_iterations): Use record_niter_bound.
2828         (find_simple_exit): Likewise.
2829         * cfgloop.h (struct niter_desc): Remove niter_max.
2830
2831 2012-10-08  Marek Polacek  <polacek@redhat.com>
2832
2833         PR debug/54831
2834         * var-tracking.c (vt_add_function_parameter): Use condition instead
2835         of gcc_assert.
2836
2837 2012-10-08  Dehao Chen  <dehao@google.com>
2838
2839         * predict.c (predict_loops): Predict for short-circuit conditions.
2840         (predict_extra_loop_exits): New Function.
2841
2842 2012-10-08  Steven Bosscher  <steven@gcc.gnu.org>
2843
2844         * bitmap.h (bitmap_and_into): Update prototype.
2845         * bitmap.c (bitmap_and_into): Return true if the target bitmap
2846         changed, false otherwise.
2847
2848         * df.h (df_dump_insn_problem_function): New function type.
2849         (struct df_problem): Add two functions, to dump just before and
2850         just after an insn.
2851         (DF_RD_PRUNE_DEAD_DEFS): New changable flag.
2852         (df_dump_insn_top, df_dump_insn_bottom): New prototypes.
2853         * df-core (df_dump_region): Use dump_bb.
2854         (df_dump_bb_problem_data): New function.
2855         (df_dump_top, df_dump_bottom): Rewrite using df_dump_bb_problem_data.
2856         (df_dump_insn_problem_data): New function.
2857         (df_dump_insn_top, df_dump_insn_bottom): New functions.
2858         * df-scan.c (problem_SCAN): Add NULL fields for new members.
2859         * df-problems.c (df_rd_local_compute): Ignore hard registers if
2860         DF_NO_HARD_REGS is in effect.
2861         (df_rd_transfer_function): If DF_RD_PRUNE_DEAD_DEFS is in effect,
2862         prune reaching defs using the LR problem.
2863         (df_rd_start_dump): Fix dumping of DEFs map.
2864         (df_rd_dump_defs_set): New function.
2865         (df_rd_top_dump, df_rd_bottom_dump): Use it.
2866         (problem_RD): Add NULL fields for new members.
2867         (problem_LR, problem_LIVE): Likewise.
2868         (df_chain_bb_dump): New function.
2869         (df_chain_top_dump): Dump only for artificial DEFs and USEs,
2870         using df_chain_bb_dump.
2871         (df_chain_bottom_dump): Likewise.
2872         (df_chain_insn_top_dump, df_chain_insn_bottom_dump): New functions.
2873         (problem_CHAIN): Add them as new members.
2874         (problem_WORD_LR, problem_NOTE): Add NULL fields for new members.
2875         (problem_MD): Likewise.
2876         * cfgrtl.c (rtl_dump_bb): Use df_dump_insn_top and df_dump_insn_bottom.
2877         (print_rtl_with_bb): Likewise.
2878
2879         * dce.c (init_dce): Use DF_RD_PRUNE_DEAD_DEFS.
2880         * loop-invariant.c (find_defs): Likewise.
2881         * loop-iv.c (iv_analysis_loop_init): Likewise.
2882         * ree.c (find_and_remove_re): Likewise.
2883         * web.c (web_main): Likewise.
2884
2885 2012-10-08  Jason Merrill  <jason@redhat.com>
2886
2887         * config/rs6000/rs6000.c (rs6000_code_end): Protect the use of
2888         ASM_WEAKEN_DECL with #if RS6000_WEAK.
2889
2890 2012-10-08  Richard Guenther  <rguenther@suse.de>
2891
2892         PR tree-optimization/54825
2893         * tree-ssa-sccvn.c (vn_nary_length_from_stmt): Handle BIT_FIELD_REF.
2894         (init_vn_nary_op_from_stmt): Likewise.
2895         * tree-ssa-pre.c (compute_avail): Use vn_nary_op_lookup_stmt.
2896         * tree-ssa-sccvn.h (sizeof_vn_nary_op): Avoid overflow.
2897
2898 2012-10-08  Richard Guenther  <rguenther@suse.de>
2899
2900         * tree-ssa-pre.c (postorder_num): New global.
2901         (compute_antic): Initialize all blocks and adjust for
2902         generic postorder.
2903         (my_rev_post_order_compute): Remove.
2904         (init_pre): Use inverted_post_order_compute.
2905
2906 2012-10-08  Bernd Schmidt  <bernds@codesourcery.com>
2907
2908         * sched-int.h (schedule_block): Adjust declaration.
2909         * sched-rgn.c (bb_state_array, bb_state): New static variables.
2910         (sched_rgn_init): Initialize them.
2911         (sched_rgn_free): Free them.
2912         (schedule_region): Save scheduling state for future blocks, and
2913         pass such state to schedule_block.
2914         * params.def (PARAM_SCHED_STATE_EDGE_PROB_CUTOFF): New.
2915         * doc/invoke.texi (--param): Document it.
2916         * haifa-sched.c (schedule_block): New arg init_state.  Use it to
2917         initialize state if nonnull.  All callers changed.
2918         Call advance_one_cycle after scheduling.
2919
2920 2012-10-08  Georg-Johann Lay  <avr@gjlay.de>
2921
2922         PR target/54854
2923         * doc/invoke.texi (AVR Options): Remove -mshort-calls.
2924         * config/avr/avr.opt (-mshort-calls): Remove option.
2925         * config/avr/avr.h (AVR_HAVE_JMP_CALL): Don't depend on
2926         TARGET_SHORT_CALLS.
2927
2928 2012-10-08  Oleg Endo  <olegendo@gcc.gnu.org>
2929
2930         PR target/54685
2931         * config/sh/sh.md (one_cmplsi2): Make insn_and_split.  Add manual
2932         combine matching for an insn sequence where a ge:SI pattern
2933         can be used.
2934
2935 2012-10-08  Dodji Seketeli  <dodji@redhat.com>
2936
2937         PR c++/53528 C++11 attribute support
2938         * plugin.h (register_scoped_attributes): Declare new function.
2939         * tree.h (enu attribute_flags::ATTR_FLAG_CXX_11): New flag.
2940         (lookup_scoped_attribute_spec, cxx_11_attribute_p)
2941         (get_attribute_name, get_attribute_namespace): Declare new functions.
2942         (struct attribute_spec): Remove const qualifier from the members.
2943         * tree.c (comp_type_attributes, private_lookup_attribute)
2944         (lookup_ident_attribute, remove_attribute, merge_attribute)
2945         (attribute_hash_list, attribute_list_contained): Use
2946         get_attribute_name.
2947         * attribs.c (decl_attributes): Don't crash on error_mark_node.
2948         Forbid c++11 attributes appertaining to type-specifiers.
2949         (attribute_hash): Remove global variable.
2950         (attributes_table): New global variable.
2951         (find_attribute_namespace, register_scoped_attribute): New static
2952         functions.
2953         (register_scoped_attributes, lookup_scoped_attribute_spec)
2954         (cxx11_attribute_p, get_attribute_name, get_attribute_namespace):
2955         New public functions.
2956         (init_attributes): Register all the GNU attributes into the "gnu"
2957         namespace.
2958         (register_attribute): Use register_scoped_attribute to register
2959         the attribute into the "gnu" namespace.
2960         (lookup_attribute_spec): Use lookup_scoped_attribute_spec to
2961         lookup the attribute in the "gnu" namespace.
2962         (decl_attributes): Use new get_attribute_namespace and
2963         lookup_scoped_attribute_spec to consider attribute namespaces when
2964         looking up attributes.  When operating in c++-11 mode, pass flag
2965         ATTR_FLAG_CXX11 to the spec handler.
2966
2967 2012-10-08  Georg-Johann Lay  <avr@gjlay.de>
2968
2969         PR target/54815
2970         * config/avr/avr.md (*add<mode>3, add<mode>3, addpsi3): Make
2971         constraint alternative "r,0,r" slighly more expensive.
2972         (sub<mode>3, andqi3, andhi3, andpsi3, andsi3): Ditto.
2973         (iorqi3, iorhi3, iorpsi3, iorsi3): Ditto.
2974         (xorhi3, xorpsi3, xorsi3): Ditto.
2975
2976 2012-10-08  Oleg Endo  <olegendo@gcc.gnu.org>
2977
2978         PR target/54760
2979         * config/sh/sh.md (*mov<mode>_gbr_load, *mov<mode>_gbr_store): New
2980         insns and accompanying unnamed splits.
2981         * config/sh/predicates.md (general_movsrc_operand,
2982         general_movdst_operand): Reject GBR addresses.
2983         * config/sh/sh-protos.h (sh_find_equiv_gbr_addr): New declaration.
2984         * config/sh/sh.c (sh_address_cost, sh_legitimate_address_p,
2985         sh_secondary_reload): Handle GBR addresses.
2986         (base_reg_disp): New class.
2987         (sh_find_base_reg_disp, sh_find_equiv_gbr_addr): New functions.
2988
2989 2012-10-08  Hans-Peter Nilsson  <hp@bitrange.com>
2990
2991         * config/mmix/mmix.c (mmix_output_octa): Don't assume
2992         HOST_WIDEST_INT_PRINT_HEX starts with "0x".  Instead use
2993         HOST_WIDE_INT_PRINT_HEX_PURE, falling back to
2994         HOST_WIDEST_INT_PRINT_UNSIGNED.
2995
2996 2012-10-07  Richard Sandiford  <rdsandiford@googlemail.com>
2997
2998         * machmode.h (GET_MODE_UNIT_PRECISION): New macro.
2999         * simplify-rtx.c (simplify_truncation): New function,
3000         extracted from simplify_subreg and (in small part) from
3001         simplify_unary_operation_1.
3002         (simplify_unary_operation_1) <TRUNCATE>: Use it.  Remove sign bit
3003         test for !TRULY_NOOP_TRUNCATION_MODES_P.
3004         (simplify_subreg): Use simplify_truncate for lowpart subregs
3005         where both the inner and outer modes are scalar integers.
3006         * config/mips/mips.c (mips_truncated_op_cost): New function.
3007         (mips_rtx_costs): Adjust test for BADDU.
3008         * config/mips/mips.md (*baddu_di<mode>): Push truncates to operands.
3009
3010 2012-10-07  Jan Hubicka  <jh@suse.cz>
3011
3012         * ipa-inline-analysis.c (do_estimate_edge_time): Return actual
3013         time spent by the inlined sequence.
3014         (do_estimate_edge_growth): Rename to ...
3015         (do_estimate_edge_time): ... this one; return size of inlined sequence.
3016         * ipa-inline.h (do_estimate_edge_size): New.
3017         (do_estimate_edge_growth): Remove.
3018         (estimate_edge_size): New function.
3019         (estimate_edge_growth): Use it.
3020
3021 2012-10-07  Jan Hubicka  <jh@suse.cz>
3022
3023         * lto-cgraph.c (lto_symtab_encoder_new): New parameter FOR_INPUT.
3024         (lto_symtab_encoder_delete): Update.
3025         (lto_symtab_encoder_encode): Update.
3026         (compute_ltrans_boundary): Update.
3027         (input_symtab): Update.
3028         * lto-streamer.h (lto_symtab_encoder_new): Update.
3029
3030 2012-10-07  Richard Sandiford  <rdsandiford@googlemail.com>
3031
3032         * config/mips/mips-protos.h (mips_split_type): New enum.
3033         (mips_split_64bit_move_p, mips_split_doubleword_move): Delete.
3034         (mips_split_move_p, mips_split_move, mips_split_move_insn_p)
3035         (mips_split_move_insn): Declare.
3036         * config/mips/mips.c (mips_tuning_info): New variable.
3037         (mips_load_store_insns): Use mips_split_move_insn_p instead of
3038         mips_split_64bit_move_p.
3039         (mips_emit_move_or_split, mips_mult_move_p): New functions.
3040         (mips_split_64bit_move_p): Rename to...
3041         (mips_split_move_p): ...this and take a mips_split_type argument.
3042         Generalize to all moves.  Call mips_mult_move_p.
3043         (mips_split_doubleword_move): Rename to...
3044         (mips_split_move): ...this and take a mips_split_type argument.
3045         Assert that mips_split_move_p holds.
3046         (mips_insn_split_type, mips_split_move_insn_p, mips_split_move_insn):
3047         New functions.
3048         (mips_output_move): Use mips_split_move_p instead of
3049         mips_split_64bit_move_p.  Handle MULT $0, $0 moves.
3050         (mips_save_reg): Use mips_emit_move_or_split.
3051         (mips_sim_reset): Assign to curr_state.  Call targetm.sched.init
3052         and advance_state.
3053         (mips_sim_init): Call targetm.sched.init_dfa_pre_cycle_insn and
3054         targetm.sched.init_dfa_post_cycle_insn, if defined.
3055         (mips_sim_next_cycle): Assign to curr_state.  Use advance_state
3056         instead of state_transition.
3057         (mips_sim_issue_insn): Assign to curr_state.  Use
3058         targetm.sched.variable_issue to see how many more insns can be issued.
3059         (mips_seq_time, mips_mult_zero_zero_cost)
3060         (mips_set_fast_mult_zero_zero_p, mips_set_tuning_info)
3061         (mips_expand_to_rtl_hook): New functions.
3062         (TARGET_EXPAND_TO_RTL_HOOK): Define.
3063         * config/mips/mips.md (move_type): Add imul.
3064         (type): Map imul move_types to imul.
3065         (*movdi_32bit, *movti): Add imul alternatives.
3066         Use mips_split_move_insn_p and mips_split_move_insn instead of
3067         mips_split_64bit_move_p and mips_split_doubleword_move in move
3068         splitters.
3069
3070 2012-10-06  Segher Boessenkool  <segher@kernel.crashing.org>
3071
3072         * config/rs6000/rs6000.c (print_operand) ['A']: Delete.
3073
3074 2012-10-06  Paolo Carlini  <paolo.carlini@oracle.com>
3075
3076         PR c++/52764
3077         * ginclude/stdint-wrap.h: In C++11 if __STDC_HOSTED__ define
3078         __STDC_LIMIT_MACROS and __STDC_CONSTANT_MACROS.
3079         * ginclude/stdint-gcc.h: In C++11 unconditionally define
3080         limit and constant macros.
3081
3082 2012-10-06  Paolo Carlini  <paolo.carlini@oracle.com>
3083
3084         PR c++/54249
3085         * ginclude/stddef.h: In C++11 mode declare nullptr_t in the global
3086         namespace.
3087
3088 2012-10-06  Jan Hubicka  <jh@suse.cz>
3089
3090         PR lto/53831
3091         PR lto/54776
3092         * lto-streamer-out.c (produce_symtab): Cleanup; drop v1 API hack.
3093
3094 2012-10-06  Dehao Chen  <dehao@google.com>
3095
3096         PR debug/54826
3097         * gimple-low.c (lower_stmt): Set the block for call args.
3098
3099 2012-10-06  Jan Hubicka  <jh@suse.cz>
3100
3101         * doc/invoke.texi (-fprofile-report): Document.
3102         * common.opt (-fprofile-report): New option.
3103         * toplev.c (finalize): Call dump_profile_report.
3104         * toplev.h (profile_report): Declare.
3105         * passes.c (profile_record): New static var.
3106         (check_profile_consistency): New function.
3107         (dump_profile_record): New function.
3108         (execute_one_ipa_transform_pass): Call check_profile_consistency.
3109         (execute_one_pass): Likewise.
3110
3111 2012-10-06  Jan Hubicka  <jh@suse.cz>
3112
3113         PR lto/54790
3114         * lto-streamer.h (lto_symtab_register_decl, lto_symtab_get_resolution,
3115         lto_mark_nothrow_fndecl, lto_fixup_nothrow_decls): Remove.
3116         * lto-symtab.c (lto_symtab_register_decl): Remove.
3117
3118 2012-10-06  Andreas Schwab  <schwab@linux-m68k.org>
3119
3120         PR rtl-optimization/54739
3121         * config/m68k/m68k.md (anddi3, iordi3, xordi3, one_cmpldi2): Remove.
3122
3123 2012-10-06  Oleg Endo  <olegendo@gcc.gnu.org>
3124
3125         PR target/54760
3126         * config/sh/sh.md (define_constants): Add UNSPECV_GBR.
3127         (get_thread_pointer, set_thread_pointer): New expanders.
3128         (load_gbr): Rename to store_gbr.  Remove GBR_REG use.
3129         (store_gbr): New insn.
3130         * config/sh/sh.c (prepare_move_operands): Use gen_store_gbr instead of
3131         gen_load_gbr in TLS_MODEL_LOCAL_EXEC case.
3132         (sh1_builtin_p): New function.
3133         (signature_args): Add SH_BLTIN_VP.
3134         (bdesc): Add __builtin_thread_pointer and __builtin_set_thread_pointer.
3135
3136 2012-10-05  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
3137
3138         PR rtl-optimization/54739
3139         * config/pa/pa.md: Remove DImode and, not and, ior and xor patterns
3140         for 32-bit targets.  Adjust expanders.
3141
3142         * config/pa/pa.md: Adjust unamed HImode add insn pattern.
3143
3144 2012-10-05  Oleg Endo  <olegendo@gcc.gnu.org>
3145
3146         * config/sh/sh.c (builtin_description): Add is_enabled member.
3147         (shmedia_builtin_p): New function.
3148         (bdesc): Use shmedia_builtin_p for existing built-ins.
3149         (sh_media_init_builtins, sh_init_builtins): Merge into single function
3150         sh_init_builtins.  Add is_enabled checking.  Move variable declarations
3151         to where they are actually used.
3152         (sh_media_builtin_decl, sh_builtin_decl): Merge into single function
3153         sh_builtin_decl.  Add is_enabled checking.
3154         (sh_expand_builtin): Move variable declarations to where they are
3155         actually used.
3156
3157 2012-10-05  Jakub Jelinek  <jakub@redhat.com>
3158
3159         * tree-inline.c (expand_call_inline): Move VAR_DECLs with
3160         PARM_DECL origins from remapped DECL_INITIAL's BLOCK_VARS
3161         into id->block's BLOCK_VARS.
3162
3163         PR debug/54519
3164         * ipa-split.c (split_function): Add debug args and debug source
3165         and normal stmts for args_to_skip which are gimple regs.
3166         * tree-inline.c (copy_debug_stmt): When inlining, adjust source
3167         debug bind stmts to debug binds of corresponding DEBUG_EXPR_DECL.
3168
3169 2012-10-05  Georg-Johann Lay  <avr@gjlay.de>
3170
3171         * config/avr/avr.md: Fix indentations of insn C snippets.
3172
3173 2012-10-05  Richard Guenther  <rguenther@suse.de>
3174
3175         PR middle-end/54811
3176         * tree-ssa-live.c (clear_unused_block_pointer_1): Look at
3177         DECL_DEBUG_EXPR again.
3178
3179 2012-10-05  Jan Hubicka  <jh@suse.cz>
3180             Jakub Jelinek  <jakub@redhat.com>
3181
3182         PR tree-optimization/33763
3183         * tree-inline.c (expand_call_inline): Silently ignore always_inline
3184         attribute for redefined extern inline functions.
3185
3186 2012-10-04  Jan Hubicka  <jh@suse.cz>
3187
3188         * tree-vectorizer.h (vect_estimate_min_profitable_iters): Remove.
3189         * tree-vect-loop.c (vect_estimate_min_profitable_iters): Declare here.
3190         (vect_analyze_loop_operations): Use loop count estimate to rule out
3191         unprofitable vectorization.
3192         (vect_estimate_min_profitable_iters): Return
3193         ret_min_profitable_estimate.
3194
3195 2012-10-05  Jakub Jelinek  <jakub@redhat.com>
3196
3197         PR tree-optimization/54810
3198         * tree-vrp.c (register_edge_assert_for_2): Handle
3199         NAME = (unsigned) NAME2; if (NAME cmp CST) for
3200         narrowing casts to unsigned integral type like
3201         NAME = NAME2 & CST2; if (NAME cmp CST) where CST2
3202         is the max value of the unsigned integral type.
3203
3204 2012-10-04  Jeff Law  <law@redhat.com>
3205
3206         PR target/50356
3207         * config/h8300/h8300.c (h8300_rtx_costs): Fix typo in CONST_INT case.
3208
3209 2012-10-04  Jason Merrill  <jason@redhat.com>
3210
3211         * config/rs6000/rs6000.c (rs6000_code_end): Protect the use of
3212         ASM_WEAKEN_DECL with #if RS6000_WEAK.
3213
3214 2012-10-04  Basile Starynkevitch  <basile@starynkevitch.net>
3215
3216         * gengtype.c (walk_type): Emit mark_hook when inside a
3217         struct of a union member.
3218
3219 2012-10-04  Georg-Johann Lay  <avr@gjlay.de>
3220
3221         * config/avr/predicates.md (flash_operand): New predicate.
3222         * config/avr/avr.md (reload_in<mode>): Use it in operand 1 instead
3223         of memory_operand.
3224
3225 2012-10-04  Tobias Burnus  <burnus@net-b.de>
3226
3227         * gcc.c (record_temp_file, add_sysrooted_prefix, process_command,
3228         do_self_spec, compare_debug_dump_opt_spec_function): Plug memleaks.
3229         (do_spec_1): Ditto, fix out-of-bound access.
3230         * opts.c (common_handle_option): Plug memleak.
3231
3232 2012-10-04  Jason Merrill  <jason@redhat.com>
3233
3234         * config/darwin.c (darwin_assemble_visibility): Treat
3235         VISIBILITY_INTERNAL as hidden.
3236
3237         * config/darwin-c.c (find_subframework_file): Add missing const.
3238         (framework_construct_pathname): Likewise.
3239
3240 2012-10-04  Florian Weimer  <fweimer@redhat.com>
3241
3242         * doc/cpp.texi (Pragmas): Document #pragma GCC warning, #pragma
3243         GCC error.
3244
3245 2012-10-04  Richard Guenther  <rguenther@suse.de>
3246
3247         PR middle-end/54735
3248         * tree-ssa-pre.c (do_pre): Make sure to update virtual SSA form before
3249         cleaning up the CFG.
3250
3251 2012-10-04  Richard Guenther  <rguenther@suse.de>
3252
3253         PR lto/47799
3254         * tree-streamer-out.c (write_ts_block_tree_pointers): For
3255         inlined functions outer scopes write the ultimate origin
3256         as BLOCK_ABSTRACT_ORIGIN and BLOCK_SOURCE_LOCATION.
3257         Do not stream the fragment chains.
3258         * tree-streamer-in.c (lto_input_ts_block_tree_pointers): Likewise.
3259         * dwarf2out.c (gen_subprogram_die): Handle NULL DECL_INITIAL.
3260         (dwarf2out_decl): Always output DECL_ABSTRACT function decls.
3261
3262 2012-10-04  Arnaud Charlet  <charlet@adacore.com>
3263
3264         * dumpfile.h, dumpfile.c: Remove TDI_ada.
3265
3266 2012-10-04  Yuri Rumyantsev  <ysrumyan@gmail.com>
3267
3268         * config/i386/i386.c (ix86_dep_by_shift_count_body) : Add
3269         check on reload_completed since it can be invoked before
3270         register allocation phase in pre-reload schedule.
3271         (ia32_multipass_dfa_lookahead) : Do not use dfa_lookahead for
3272         pre-reload schedule to save compile time.
3273         (ix86_sched_reorder) : Do not perform ready list reordering for
3274         pre-reload schedule to save compile time.
3275         (insn_is_function_arg) : New function. Returns true if lhs of insn is
3276         HW function argument register.
3277         (add_parameter_dependencies) : New function. Add output dependencies
3278         for chain of function adjacent arguments if only there is a move to
3279         likely spilled HW registers. Return first argument if at least one
3280         dependence was added or NULL otherwise.
3281         (avoid_func_arg_motion) : New function. Add output or anti dependency
3282         from insn to first_arg to restrict code motion.
3283         (add_dependee_for_func_arg) : New function. Avoid cross block motion of
3284         function argument through adding dependency from the first non-jump
3285         insn in bb.
3286         (ix86_dependencies_evaluation_hook) : New function. Hook for
3287         pre-reload schedule: avoid motion of function arguments passed in
3288         likely spilled HW registers.
3289         (ix86_adjust_priority) : New function. Hook for pre-reload schedule:
3290         set priority of moves from likely spilled HW registers to maximum to
3291         schedule them as soon as possible.
3292         (ix86_sched_init_global): Do not perform multipass scheduling for
3293         pre-reload schedule to save compile time.
3294
3295 2012-10-04  Uros Bizjak  <ubizjak@gmail.com>
3296
3297         * configure.ac (noexception_flags): Add -fasynchronous-unwind-tables.
3298         * configure: Regenerate.
3299
3300 2012-10-04  Kaz Kojima  <kkojima@gcc.gnu.org>
3301
3302         * config/sh/sh.c (sh_can_use_simple_return_p): Return false for
3303         SHmedia and SHcompact using call cookie.
3304         * config/sh/sh.md (epilogue): Emit non-inlined return insns for
3305         SHmedia and SHcompact using call cookie.
3306
3307 2012-10-03  Oleg Endo  <olegendo@gcc.gnu.org>
3308
3309         PR target/51244
3310         * config/sh/sh.md (*mov_t_msb_neg): New insn and two accompanying
3311         unnamed split patterns.
3312
3313 2012-10-03  Oleg Endo  <olegendo@gcc.gnu.org>
3314
3315         PR target/50457
3316         * config/sh/sh.c (parse_validate_atomic_model_option): Handle name
3317         strings in sh_atomic_model.
3318         * config/sh/sh.h (TARGET_CPU_CPP_BUILTINS): Move macro implementation
3319         to ...
3320         * config/sh/sh-c.c (sh_cpu_cpp_builtins): ... this new function.
3321         Add __SH1__ and __SH2__ defines.  Add __SH_ATOMIC_MODEL_*__ define.
3322         * config/sh/sh-protos.h (sh_atomic_model): Add name and cdef_name
3323         variables.
3324         (sh_cpu_cpp_builtins): Declare new function.
3325
3326 2012-10-03  Dehao Chen  <dehao@google.com>
3327
3328         PR middle-end/54782
3329         * tree-cfg.c (move_block_to_fn): Update lexical block for phi_args.
3330
3331 2012-10-03  Vladimir Makarov  <vmakarov@redhat.com>
3332
3333         * reginfo.c (max_regno_since_last_resize): New.
3334         (reg_preferred_class, reg_alternate_class): Add assert.
3335         (allocate_reg_info): Initialize allocated reg info.
3336         (resize_reg_info): Make bigger reg_info and initialize new memory.
3337         (reginfo_init): Initialize max_regno_since_last_resize.
3338         (setup_reg_classes): Change assert.
3339
3340 2012-10-03  Andrew W. Nosenko <andrew.w.nosenko@gmail.com>
3341
3342         * config/i386/driver-i386.c (host_detect_local_cpu): Fix logic
3343         in SSE and YMM state support check for -march=native.
3344
3345 2012-10-03  Nick Clifton  <nickc@redhat.com>
3346
3347         * config/rx/rx.c (struct decl_chain): New local structure.
3348         (warned_decls): New local variable.  Contains a stack of decls for
3349         which warnings have been issued.
3350         (add_warned_decl): Adds a decl to the stack.
3351         (already_warned): Returns true if a given decl is on the stack.
3352         (rx_set_current_function): Issue a warning if multiple fast
3353         interrupt handlers are defined.
3354         * config/rx/rx.opt (mwarn-multiple-fast-interrupts): New option.
3355         * doc/invoke.texi: Document the option.
3356
3357 2012-10-03  Mark Kettenis  <kettenis@openbsd.org>
3358
3359         * config.gcc (*-*-openbsd4.[3-9]|*-*-openbsd[5-9]*): Set
3360         default_use_cxa_atexit to yes.
3361
3362 2012-10-03  Jakub Jelinek  <jakub@redhat.com>
3363
3364         PR rtl-optimization/54792
3365         * sched-deps.c (find_modifiable_mems): Scan also TAIL insn.
3366
3367 2012-10-02  H.J. Lu  <hongjiu.lu@intel.com>
3368
3369         PR target/54785
3370         * doc/invoke.texi: Document -mprefer-avx128.
3371
3372 2012-10-02  Andrew Pinski  <apinski@cavium.com>
3373
3374         * simplify-rtx.c (simplify_unary_operation_1 <case TRUNCATE>):
3375         Don't optimize a truncate of a mem if it is a vector mode.
3376
3377 2012-10-02  Alexandre Oliva <aoliva@redhat.com>
3378
3379         PR debug/54551
3380         * Makefile.in (VALTRACK_H): Add hash-table.h.
3381         * valtrack.h: Include hash-table.h.
3382         (struct dead_debug_global_entry): New.
3383         (struct dead_debug_hash_descr): New.
3384         (struct dead_debug_global): New.
3385         (struct dead_debug): Rename to...
3386         (struct dead_debug_local): ... this.  Adjust all uses.
3387         (dead_debug_global_init, dead_debug_global_finish): New.
3388         (dead_debug_init): Rename to...
3389         (dead_debug_local_init): ... this.  Adjust all callers.
3390         (dead_debug_finish): Rename to...
3391         (dead_debug_local_finish): ... this.  Adjust all callers.
3392         * valtrack.c (dead_debug_global_init): New.
3393         (dead_debug_init): Rename to...
3394         (dead_debug_local_init): ... this.  Take global parameter.
3395         Save it and initialize used bitmap from it.
3396         (dead_debug_global_find, dead_debug_global_insert): New.
3397         (dead_debug_global_replace_temp): New.
3398         (dead_debug_promote_uses): New.
3399         (dead_debug_finish): Rename to...
3400         (dead_debug_local_finish): ... this.  Promote remaining uses.
3401         (dead_debug_global_finish): New.
3402         (dead_debug_add): Try to replace global temps first.
3403         (dead_debug_insert_temp): Support global replacements.
3404         * dce.c (word_dce_process_block, dce_process_block): Add
3405         global_debug parameter.  Pass it on.
3406         (fast_dce): Initialize, pass on and finalize global_debug.
3407         * df-problems.c (df_set_unused_notes_for_mw): Adjusted.
3408         (df_create_unused_notes, df_note_bb_compute): Likewise.
3409         (df_note_compute): Justify local-only dead debug analysis.
3410
3411 2012-10-02  Alexandre Oliva <aoliva@redhat.com>
3412
3413         PR debug/53135
3414         * dwarf2out.c (value_format): Use block4 for dw_val_class_loc
3415         when needed.
3416
3417 2012-10-02  Alexandre Oliva <aoliva@redhat.com>
3418
3419         PR debug/54177
3420         * var-tracking.c (vt_add_function_parameter): Bail if
3421         var_lowpart fails.
3422
3423 2012-10-02  H.J. Lu  <hongjiu.lu@intel.com>
3424
3425         PR target/54741
3426         * config/i386/driver-i386.c (XCR_XFEATURE_ENABLED_MASK): New.
3427         (XSTATE_FP): Likewise.
3428         (XSTATE_SSE): Likewise.
3429         (XSTATE_YMM): Likewise.
3430         (host_detect_local_cpu): Disable AVX, AVX2, FMA, FMA4 and XOP if
3431         SSE and YMM states aren't supported.
3432
3433 2012-10-02  Richard Sandiford  <rdsandiford@googlemail.com>
3434
3435         * config/mips/mips.md (*baddu_si_eb, *baddu_si_el): Merge into...
3436         (*baddu_si): ...this new pattern.
3437
3438 2012-10-02  Richard Sandiford  <rdsandiford@googlemail.com>
3439
3440         * ira-int.h (target_ira_int): Add x_ira_useful_class_mode_regs.
3441         (ira_useful_class_mode_regs): New macro.
3442         * ira.c (clarify_prohibited_class_mode_regs): Set up
3443         ira_useful_class_mode_regs.
3444         * ira-color.c (setup_profitable_hard_regs): Use it to initialise
3445         profitable_hard_regs.
3446
3447 2012-10-02  Richard Sandiford  <rdsandiford@googlemail.com>
3448
3449         * ira.h (target_ira): Add x_ira_class_singleton.
3450         (ira_class_singleton): New macro.
3451         * ira.c (setup_prohibited_class_mode_regs): Set up ira_class_singleton.
3452         * ira-build.c (update_conflict_hard_reg_costs): Use
3453         ira_class_singleton to check for classes with a single
3454         allocatable register.
3455         * ira-lives.c (ira_implicitly_set_insn_hard_regs): Likewise.
3456         (single_reg_class): Likewise.  When more than one class is specified,
3457         check whether they have the same singleton register.
3458         (process_single_reg_class_operands): Require single_reg_class
3459         to return NO_REGS or a class with a single allocatable register.
3460         Obtain that register from ira_class_singleton.
3461
3462 2012-10-02  Michael Meissner  <meissner@linux.vnet.ibm.com>
3463
3464         * config/rs6000/rs6000.c (rs6000_option_override_internal): If
3465         -mcpu=<xxx> is not specified and the compiler is not configured
3466         using --with-cpu=<xxx>, use the bits from the TARGET_DEFAULT to
3467         set the initial options.
3468
3469 2012-10-02  Sharad Singhai  <singhai@google.com>
3470
3471         PR testsuite/54772
3472         * tree-vect-stmts.c (vectorizable_operation): Add missing return.
3473
3474 2012-10-02  David Edelsohn  <dje.gcc@gmail.com>
3475
3476         * config/rs6000/rs6000.c (rs6000_option_override_internal): Do not
3477         set TARGET_ALTIVEC_VRSAVE for TARGET_ELF.
3478         (rs6000_stack_info): Only set vrsave_mask if TARGET_ALTIVEC_VRSAVE.
3479
3480 2012-10-02  Jakub Jelinek  <jakub@redhat.com>
3481
3482         PR tree-optimization/54713
3483         * expr.c (categorize_ctor_elements_1): Don't assume purpose is
3484         non-NULL.
3485         * tree-cfg.c (verify_gimple_assign_single): Add verification of
3486         vector CONSTRUCTORs.
3487         * tree-ssa-sccvn.c (vn_reference_lookup_3): For VECTOR_TYPE
3488         CONSTRUCTORs, don't do anything if element type is VECTOR_TYPE,
3489         and don't check index.
3490         * tree-vect-slp.c (vect_get_constant_vectors): VIEW_CONVERT_EXPR ctor
3491         elements first if their type isn't compatible with vector element type.
3492
3493 2012-10-02  Eric Botcazou  <ebotcazou@adacore.com>
3494
3495         * tree.h (DECL_NONLOCAL_FRAME): New macro.
3496         * tree-nested.c (get_frame_type): Set DECL_NONLOCAL_FRAME.
3497         * tree-streamer-in.c (unpack_ts_decl_common_value_fields): Stream in
3498         DECL_NONLOCAL_FRAME flag.
3499         * tree-streamer-out.c (pack_ts_decl_common_value_fields): Stream out
3500         DECL_NONLOCAL_FRAME flag.
3501
3502 2012-10-02  Marc Glisse  <marc.glisse@inria.fr>
3503
3504         * tree-ssa-forwprop.c (forward_propagate_into_cond): Don't use
3505         boolean_type_node for vectors.
3506
3507 2012-10-01  Michael Meissner  <meissner@linux.vnet.ibm.com>
3508
3509         * config/rs6000/rs6000.c (toplevel): Include dumpfile.h.
3510         (rs6000_density_test): Rework to accommodate 09-30 change by
3511         Sharad Singhai.
3512
3513         * config/rs6000/t-rs6000 (rs6000.o): Add dumpfile.h dependency.
3514
3515 2012-10-01  Dehao Chen  <dehao@google.com>
3516
3517         PR middle-end/54759
3518         * tree-vect-loop-manip.c (slpeel_make_loop_iterate_ntimes): Use
3519         LOCATION_LOCUS to compare with UNKNOWN_LOCATION.
3520         (slpeel_tree_peel_loop_to_edge): Likewise.
3521         * tree-vectorizer.c (vectorize_loops): Likewise.
3522
3523 2012-10-01  Andrew MacLeod  <amacleod@redhat.com>
3524
3525         PR target/54087
3526         * optabs.c (expand_atomic_fetch_op_no_fallback): New.  Factored code
3527         from expand_atomic_fetch_op.
3528         (expand_atomic_fetch_op):  Try atomic_{add|sub} operations in terms of
3529         the other one if direct opcode fails.
3530
3531 2012-10-01  Uros Bizjak  <ubizjak@gmail.com>
3532
3533         PR rtl-optimization/54457
3534         * simplify-rtx.c (simplify_subreg):
3535         Simplify (subreg:M (op:N ((x:N) (y:N)), 0)
3536         to (op:M (subreg:M (x:N) 0) (subreg:M (x:N) 0)), where
3537         the outer subreg is effectively a truncation to the original mode M.
3538
3539 2012-10-01  Richard Guenther  <rguenther@suse.de>
3540
3541         * builtins.def (ATTR_MATHFN_FPROUNDING): Do not use no-vops
3542         with -frounding-math.
3543         * builtin-attrs.def (ATTR_PURE_NOTHROW_NOVOPS_LIST): Remove.
3544         (ATTR_PURE_NOTHROW_NOVOPS_LEAF_LIST): Likewise.
3545
3546 2012-10-01  Eric Botcazou  <ebotcazou@adacore.com>
3547
3548         * tree.h (copy_mem_ref_info): Delete.
3549         * tree-ssa-address.c (copy_mem_ref_info): Likewise.
3550         (maybe_fold_tmr): Copy flags manually.
3551         * tree-ssa-loop-im.c (simple_mem_ref_in_stmt): Rewrite.
3552
3553 2012-10-01  Marc Glisse  <marc.glisse@inria.fr>
3554
3555         * simplify-rtx.c (simplify_binary_operation_1) <VEC_SELECT>:
3556         Detect the identity.
3557         <VEC_CONCAT>: Handle VEC_SELECTs from the same vector.
3558
3559 2012-10-01  Oleg Endo  <olegendo@gcc.gnu.org>
3560
3561         PR target/50457
3562         * config/sh/sh.opt (matomic-model): New option.
3563         (msoft-atomic): Mark as deprecated and alias to
3564         matomic-model=soft-gusa.
3565         (mhard-atomic): Delete.
3566         * config/sh/predicates.md (gbr_displacement): New predicate.
3567         * config/sh/sh-protos.h (sh_atomic_model): New struct.
3568         (selected_atomic_model): New declaration.
3569         (TARGET_ATOMIC_ANY, TARGET_ATOMIC_STRICT, TARGET_ATOMIC_SOFT_GUSA,
3570         TARGET_ATOMIC_HARD_LLCS, TARGET_ATOMIC_SOFT_TCB,
3571         TARGET_ATOMIC_SOFT_TCB_GBR_OFFSET_RTX, TARGET_ATOMIC_SOFT_IMASK):
3572         New macros.
3573         * config/sh/linux.h (SUBTARGET_OVERRIDE_OPTIONS): Adapt setting to
3574         default atomic model.
3575         * config/sh/sh.c (selected_atomic_model_): New global variable.
3576         (selected_atomic_model, parse_validate_atomic_model_option): New
3577         functions.
3578         (sh_option_override): Replace atomic selection checks with call to
3579         parse_validate_atomic_model_option.
3580         * config/sh/sh.h (TARGET_ANY_ATOMIC, UNSUPPORTED_ATOMIC_OPTIONS,
3581         UNSUPPORTED_HARD_ATOMIC_CPU): Delete.
3582         (DRIVER_SELF_SPECS): Remove atomic checks.
3583         config/sh/sync.md: Update documentation comments.
3584         (atomic_compare_and_swap<mode>, atomic_exchange<mode>,
3585         atomic_fetch_<fetchop_name><mode>, atomic_fetch_nand<mode>,
3586         atomic_<fetchop_name>_fetch<mode>, atomic_nand_fetch<mode>): Use
3587         TARGET_ATOMIC_ANY as condition.  Add TARGET_ATOMIC_STRICT check for
3588         SH4A case.  Handle new TARGET_ATOMIC_SOFT_TCB and
3589         TARGET_ATOMIC_SOFT_IMASK cases.
3590         (atomic_test_and_set): Handle new TARGET_ATOMIC_SOFT_TCB and
3591         TARGET_ATOMIC_SOFT_IMASK cases.
3592         (atomic_compare_and_swapsi_hard, atomic_exchangesi_hard,
3593         atomic_fetch_<fetchop_name>si_hard, atomic_fetch_nandsi_hard,
3594         atomic_<fetchop_name>_fetchsi_hard, atomic_nand_fetchsi_hard):
3595         Add TARGET_ATOMIC_STRICT check.
3596         (atomic_compare_and_swap<mode>_hard, atomic_exchange<mode>_hard,
3597         atomic_fetch_<fetchop_name><mode>_hard, atomic_fetch_nand<mode>_hard,
3598         atomic_<fetchop_name>_fetch<mode>_hard, atomic_nand_fetch<mode>_hard,
3599         atomic_test_and_set_hard): Use TARGET_ATOMIC_HARD_LLCS condition.
3600         (atomic_compare_and_swap<mode>_soft, atomic_exchange<mode>_soft,
3601         atomic_fetch_<fetchop_name><mode>_soft, atomic_fetch_nand<mode>_soft,
3602         atomic_<fetchop_name>_fetch<mode>_soft, atomic_nand_fetch<mode>_soft,
3603         atomic_test_and_set_soft): Append _gusa to the insn names and use
3604         TARGET_ATOMIC_SOFT_GUSA as condition.
3605         (atomic_compare_and_swap<mode>_soft_tcb,
3606         atomic_exchange<mode>_soft_tcb,
3607         atomic_fetch_<fetchop_name><mode>_soft_tcb,
3608         atomic_fetch_nand<mode>_soft_tcb,
3609         atomic_<fetchop_name>_fetch<mode>_soft_tcb,
3610         atomic_nand_fetch<mode>_soft_tcb, atomic_test_and_set_soft_tcb):
3611         New insns.
3612         (atomic_compare_and_swap<mode>_soft_imask,
3613         atomic_exchange<mode>_soft_imask,
3614         atomic_fetch_<fetchop_name><mode>_soft_imask,
3615         atomic_fetch_nand<mode>_soft_imask,
3616         atomic_<fetchop_name>_fetch<mode>_soft_imask,
3617         atomic_nand_fetch<mode>_soft_imask, atomic_test_and_set_soft_imask):
3618         New insns.
3619         * doc/invoke.texi (SH Options): Document new matomic-model option.
3620         Remove msoft-atomic and mhard-atomic options.
3621
3622 2012-10-01  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
3623
3624         PR target/54746
3625         * config/s390/s390.c (s390_option_override): Add missing break.
3626
3627 2012-09-30  Sharad Singhai  <singhai@google.com>
3628
3629         * dumpfile.c: New file with parts moved from tree-dump.c.
3630         (pflags): New variable.
3631         (alt_flags): Ditto.
3632         (alt_dump_file): Ditto.
3633         (dump_files):  Update to include additional fields.
3634         (struct dump_option_value_info): Add additional entries.
3635         (get_dump_file_name): Use command line filename if available.
3636         (dump_open_alternate_stream): New function.
3637         (dump_loc): Ditto.
3638         (dump_gimple_stmt): Ditto.
3639         (dump_gimple_stmt_loc): Ditto.
3640         (dump_generic_expr): Ditto.
3641         (dump_generic_expr_loc): Ditto.
3642         (dump_printf): Ditto.
3643         (dump_printf_loc): Ditto.
3644         (dump_start): Ditto.
3645         (dump_finish): Ditto.
3646         (dump_begin): Ditto.
3647         (dump_enabled_p): Return true if either of the dump types is enabled.
3648         (dump_initialized_p): Return true if either type of dump is
3649         initialized.
3650         (dump_end): Do not close standard streams.
3651         (dump_enable_all): Handle filenames for regular dumps.
3652         (dump_switch_p_1): Handle command-line dump filenames.
3653         (opt_info_enable_all): New function.
3654         (opt_info_switch_p_1): Ditto.
3655         (opt_info_switch_p): Ditto.
3656         (dump_kind_p): Ditto.
3657         (dump_basic_block): Ditto.
3658         (dump_combine_total_stats): Ditto.
3659         (dump_remap_tree_vectorizer_verbose): Ditto.
3660         * gimple-pretty-print.h: Rename dump_gimple_stmt to
3661         pp_gimple_stmt_1.  All callers updated.
3662
3663 2012-09-30  Sharad Singhai  <singhai@google.com>
3664
3665         * doc/invoke.texi: Add documentation for the new -fopt-info option.
3666         * tree-dump.c: Move general dump file related functionality into
3667         dumpfile.c. Remove unneeded headers.
3668         * tree-dump.h: Move function declarations into dumpfile.h.
3669         * dumpfile.h: Include "line-map.h". Add defines for MSG flags.
3670         (struct dump_file_info): Move here from tree-dump.c.  Rename flags
3671         to pflags, state to pstate, stream to pstream, filename to
3672         pfilename. All callers updated. Add alt_flags, alt_state,
3673         alt_filenmae, alt_stream.
3674         * tree-vectorizer.c: Include "dumpfile.h". Remove vect_dump.
3675         (vect_set_dump_settings): Remove.
3676         (vect_print_dump_info): Ditto.
3677         * tree-vectorizer.h: Remove declaration of vect_dump and
3678         vect_print_dump_info.
3679         * tree-vect-loop.c: Include "dumpfile.h". Use new dump style.
3680         * tree-vect-data-refs.c: Ditto.
3681         * tree-vect-stmts.c: Ditto.
3682         * tree-vect-slp.c: Ditto.
3683         * tree-vect-patterns.c: Ditto.
3684         * tree-vect-loop-manip.c: Ditto.
3685         * opts.c (vect_set_verbosity_level): Remove.
3686         (common_handle_option): Handle -fopt-info flag. Deprecate
3687         -ftree-vectorizer-verbose.
3688         * tree-parloops.c (gather_scalar_reductions): Remove reference to
3689         vect_dump.
3690         * flag-types.h: Remove vect_verbosity_levels.
3691         * common.opt: Add -fopt-info. Deprecate -ftree-vectorizer-verbose.
3692         * opts-global.c (dump_remap_tree_vectorizer_verbose): New function.
3693         (handle_common_deferred_options): Handle -fopt-info and
3694         -ftree-vectorizer-verbose.
3695         * Makefile.in: Add dumpfile.o.
3696         (tree-dump.o): Update dependencies.
3697         (tree-vect-loop.o): Ditto.
3698         (tree-vect-loop-manip.o): Ditto.
3699         (tree-vect-slp.o): Ditto.
3700         (tree-vect-stmts.o): Ditto.
3701         (tree-vectorizer.o): Ditto.
3702         (opts.o): Ditto.
3703         * passes.c (finish_optimization_passes): Instead of using
3704         dump_begin/dump_end, use dump_start/dump_finish. Do not use dump_file.
3705         (pass_init_dump_file): Ditto.
3706
3707 2012-09-30  Joern Rennecke  <joern.rennecke@embecosm.com>
3708
3709         PR rtl-optimization/38449:
3710         * hooks.c (hook_bool_const_rtx_const_rtx_true): New function.
3711         * hooks.h (hook_bool_const_rtx_const_rtx_true): Declare.
3712         * target.def: Merge in definitions and documentation for
3713         TARGET_CAN_FOLLOW_JUMP.
3714         * doc/tm.texi.in: Add documentation locations for the above.
3715         * doc/tm.texi: Regenerate.
3716         * reorg.c (follow_jumps): New parameters jump and crossing.
3717         Changed all callers.
3718
3719 2012-09-30  Eric Botcazou  <ebotcazou@adacore.com>
3720
3721         * reorg.c (relax_delay_slots): Use delay_insn consistently.
3722
3723         * config/sparc/sparc.c (gen_stack_pointer_dec): Delete.
3724         (sparc_expand_epilogue): Use gen_stack_pointer_inc and adjust.
3725         (sparc_flat_expand_epilogue): Likewise.
3726         (emit_and_preserve): Likewise.
3727         (sparc_fold_builtin): Fix thinko in latest change.
3728
3729 2012-09-30  Andreas Schwab  <schwab@linux-m68k.org>
3730
3731         * config/m68k/m68k.md: Add names to bitfield insert and extract
3732         insns.
3733         (*insv_8_16_reg): Remove constraints and conditions that assume
3734         that operand 0 could be a MEM.
3735         (*extzv_8_16_reg, *extv_8_16_reg): Likewise, for operand 1.
3736
3737 2012-09-30  Jan Hubicka  <jh@suse.cz>
3738
3739         * cfgloop.c (scale_loop_profile): Move to...
3740         * cfgloopmanip.c (scale_loop_profile): .. here; use
3741         scale_loop_frequencies.
3742         (loopify): Use RDIV.
3743
3744 2012-09-28  Jan Hubicka  <jh@suse.cz>
3745
3746         * tree-call-cdce.c (shrink_wrap_one_built_in_call): Update profile.
3747
3748 2012-09-28  Jan Hubicka  <jh@suse.cz>
3749
3750         * function.c (dup_block_and_redirect): Update profile.
3751
3752 2012-09-29  Andreas Tobler  <andreast@fgznet.ch>
3753
3754         * config.gcc: Replace 'host' with 'target' when configuring for
3755         powerpc64*-*-freebsd.
3756
3757 2012-09-29  Marc Glisse  <marc.glisse@inria.fr>
3758
3759         * tree.c (truth_type_for): New function.
3760         * tree.h (truth_type_for): Declare.
3761         * gimple-fold.c (and_comparisons_1): Call it.
3762         (or_comparisons_1): Likewise.
3763         * tree-ssa-forwprop.c (forward_propagate_into_cond): Don't use
3764         boolean_type_node for vectors.
3765
3766 2012-09-28  Jan Hubicka  <jh@suse.cz>
3767
3768         * basic-block.h (RDIV): Define.
3769         (EDGE_FREQUENCY): Simplify.
3770         (check_probability, combine_probabilities, apply_probability,
3771         inverse_probability): New.
3772         * cfgloop.c (scale_loop_profile): New function.
3773         * cfgloop.h (scale_loop_profile): Declare.
3774         (slpeel_add_loop_guard): Add probability parameter.
3775         (set_prologue_iterations): Add probability parameter.
3776         (slpeel_tree_peel_loop_to_edge): Add bound1 and bound2 parameters;
3777         update probabilities correctly.
3778         (vect_do_peeling_for_alignment, vect_gen_niters_for_prolog_loop): New.
3779
3780 2012-09-20  Bernd Schmidt  <bernds@codesourcery.com>
3781
3782         PR bootstrap/54688
3783         * sched-deps.c (parse_add_or_inc): Remove MINUS handling.  Take
3784         STACK_GROWS_DOWNWARD into account.
3785
3786 2012-09-28  Jakub Jelinek  <jakub@redhat.com>
3787
3788         PR target/54716
3789         * config/i386/predicates.md (nonimmediate_or_const_vector_operand):
3790         New predicate.
3791         * config/i386/i386.c (ix86_expand_vector_logical_operator): New
3792         function.
3793         * config/i386/i386-protos.h (ix86_expand_vector_logical_operator): New
3794         prototype.
3795         * config/i386/sse.md (<code><mode>3 VI logic): Use it.
3796
3797         PR tree-optimization/54713
3798         * fold-const.c (vec_cst_ctor_to_array): Give up if vector CONSTRUCTOR
3799         has vector elements.
3800         (fold_ternary_loc) <case BIT_FIELD_REF>: Likewise.
3801         * tree-vect-generic.c (vector_element): Don't rely on CONSTRUCTOR elts
3802         indexes.  Use BIT_FIELD_REF if CONSTRUCTOR has vector elements.
3803         (lower_vec_perm): Use NULL_TREE CONSTRUCTOR indexes.
3804
3805 2012-09-28  Georg-Johann Lay  <avr@gjlay.de>
3806
3807         * config/avr/avr.md (adjust_len): Add lpm.
3808         (reload_in<mode>): Use avr_out_lpm for output.  Use "lpm" for
3809         adjust_len.
3810         * config/avr/avr-protos.h (avr_out_lpm): New prototype.
3811         * config/avr/avr.c (avr_out_lpm): Make global.
3812         (adjust_insn_length): Handle ADJUST_LEN_LPM.
3813
3814 2012-09-28  Richard Guenther  <rguenther@suse.de>
3815
3816         PR lto/47799
3817         * lto-streamer-out.c (tree_is_indexable): Make PARM_DECLs global.
3818         (lto_output_tree_ref): Handle references to them.
3819         (output_function): Do not output function arguments again.
3820         * lto-streamer-in.c (input_function): Do not input arguments
3821         again, nor overwrite them.
3822
3823 2012-09-28  Richard Guenther  <rguenther@suse.de>
3824
3825         * cgraph.h (symtab_node_base): Re-order and pack fields.
3826
3827 2012-09-28  Georg-Johann Lay  <avr@gjlay.de>
3828
3829         * config/avr/avr.c (avr_pgm_check_var_decl): Fix non-error diagnostic.
3830
3831 2012-09-28  Georg-Johann Lay  <avr@gjlay.de>
3832
3833         PR rtl-optimization/52543
3834         * config/avr/avr.c (avr_mode_dependent_address_p): Return true for
3835         all non-generic address spaces.
3836         (TARGET_SECONDARY_RELOAD): New hook define to...
3837         (avr_secondary_reload): ...this new static function.
3838         * config/avr/avr.md (reload_in<mode>): New insns.
3839
3840         Undo r185605 (mostly):
3841         * config/avr/avr-protos.h (avr_load_lpm): Remove.
3842         * config/avr/avr.c (avr_load_libgcc_p): Don't restrict to __flash
3843         loads.
3844         (avr_out_lpm): Also handle loads > 1 byte.
3845         (avr_load_lpm): Remove.
3846         (avr_find_unused_d_reg): New static function.
3847         (avr_out_lpm_no_lpmx): New static function.
3848         (adjust_insn_length): Remove ADJUST_LEN_LOAD_LPM.
3849         * config/avr/avr.md (unspec): Remove UNSPEC_LPM.
3850         (load_<mode>_libgcc): Use MEM instead of UNSPEC_LPM.
3851         (load_<mode>, load_<mode>_clobber): Remove.
3852         (mov<mode>): For multi-byte move from non-generic
3853         16-bit address spaces: Expand to *mov<mode> again.
3854         (load<mode>_libgcc): New expander.
3855         (split-lpmx): Remove split.
3856
3857 2012-09-27  Dehao Chen  <dehao@google.com>
3858
3859         * tree.h (tree_constructor): Remove IS_UNKNOWN_LOCATION.
3860         (extern void protected_set_expr_location): Likewise.
3861         (function_args_iter_next): Likewise.
3862         (inlined_function_outer_scope_p): Likewise.
3863         * input.h (IS_UNKNOWN_LOCATION): Likewise.
3864         * fold-const.c (expr_location_or): Likewise.
3865         * lto-cgraph.c (output_node_opt_summary): Likewise.
3866         * dwarf2out.c (add_src_coords_attributes): Likewise.
3867         * tree-eh.c (lower_try_finally_dup_block): Likewise.
3868         * profile.c (branch_prob):
3869         * cfgexpand.c (expand_gimple_cond): Likewise.
3870         (expand_gimple_basic_block): Likewise.
3871         (construct_exit_block): Likewise.
3872         (gimple_expand_cfg): Likewise.
3873         * cfgcleanup.c (try_forward_edges): Likewise.
3874         * tree-ssa-live.c (remove_unused_scope_block_p): Likewise.
3875         (dump_scope_block): Likewise.
3876         * ipa-prop.c (ipa_write_jump_function): Likewise.
3877         * rtl.h (extern void rtl_check_failed_flag): Likewise.
3878         * gimple.h (gimple_set_location): Likewise.
3879         (gimple_has_location): Likewise.
3880         * cfgrtl.c (unique_locus_on_edge_between_p): Likewise.
3881         (force_nonfallthru_and_redirect): Likewise.
3882         (fixup_reorder_chain): Likewise.
3883         (cfg_layout_merge_blocks): Likewise.
3884
3885 2012-09-27  Meador Inge  <meadori@codesourcery.com>
3886
3887         * gcc-ar.c (main): Handle the returning of the sub-process error
3888         code correctly.
3889
3890 2012-09-27  Ulrich Weigand  <ulrich.weigand@linaro.org>
3891
3892         * lower-subreg.c (enum classify_move_insn): Rename
3893         SIMPLE_PSEUDO_REG_MOVE to DECOMPOSABLE_SIMPLE_MOVE.
3894         (find_decomposable_subregs): Update.
3895         (decompose_multiword_subregs): Add DECOMPOSE_COPIES parameter.
3896         Only mark pseudo-to-pseudo copies as DECOMPOSABLE_SIMPLE_MOVE
3897         if that parameter is true.
3898         (rest_of_handle_lower_subreg): Call decompose_multiword_subregs
3899         with DECOMPOSE_COPIES false.
3900         (rest_of_handle_lower_subreg2): Call decompose_multiword_subregs
3901         with DECOMPOSE_COPIES true.
3902
3903 2012-09-27  Marek Polacek  <polacek@redhat.com>
3904
3905         * doc/gcov.texi (Gcov Data Files): Fix a typo.
3906
3907 2012-09-27  Jakub Jelinek  <jakub@redhat.com>
3908
3909         PR target/54703
3910         * simplify-rtx.c (simplify_binary_operation_1): Perform
3911         (x - (x & y)) -> (x & ~y) optimization only for integral modes.
3912
3913 2012-09-27  Marc Glisse  <marc.glisse@inria.fr>
3914
3915         PR c/53024
3916         PR c++/54427
3917         * doc/extend.texi (Vector Extensions): C++ improvements.
3918         Power of 2 size requirement.
3919
3920 2012-09-27  Richard Guenther  <rguenther@suse.de>
3921
3922         PR lto/54709
3923         * lto-symtab.c (resolution_guessed_p): Remove.
3924         (set_resolution_guessed): Likewise.
3925         (lto_symtab_register_decl): Remove assert.
3926         (lto_symtab_resolve_symbols): Do not alter symbol resolutions
3927         and return the prevailing symbol, checking for multiple prevailing
3928         symbols here.
3929         (lto_symtab_merge_decls_1): Use the result from
3930         lto_symtab_resolve_symbols.  Do not alter symbol resolutions.
3931
3932 2012-09-26  Steve Ellcey  <sellcey@mips.com>
3933
3934         PR web/54711
3935         * doc/install.texi: Fix example.
3936
3937 2012-09-26  Dehao Chen  <dehao@google.com>
3938
3939          * tree-ssa-live.c (clear_unused_block_pointer): Use explicitit (void)
3940         for function parameter.
3941         (remove_unused_locals): Don't use LOCATION_BLOCK if it is NULL.
3942
3943 2012-09-26  Oleg Endo  <olegendo@gcc.gnu.org>
3944
3945         * doc/extend.texi (bswap Builtins): Change signed types to unsigned
3946         types.
3947
3948 2012-09-26  Ian Lance Taylor  <iant@google.com>
3949
3950         * diagnostic.c (bt_callback): Cast pc when calling fprintf.
3951
3952 2012-09-26  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
3953
3954         PR tree-optimization/54674
3955         * gimple-ssa-strength-reduction.c (analyze_increments): Don't
3956         introduce a multiplication with a pointer operand.
3957
3958 2012-09-26  Georg-Johann Lay  <avr@gjlay.de>
3959
3960         PR middle-end/54635
3961         * doc/tm.texi.in (TARGET_MODE_DEPENDENT_ADDRESS_P): Document new
3962         parameter addrspace.
3963         * doc/tm.texi: Regenerate.
3964         * target.def (mode_dependent_address_p): Add addr_space_t parameter.
3965         * targhooks.h (default_mode_dependent_address_p): Ditto.
3966         * targhooks.c (default_mode_dependent_address_p): Ditto.
3967         * expr.c (convert_move): Pass address space to
3968         mode_dependent_address_p.
3969         * combine.c (combine_simplify_rtx): Ditto.
3970         (make_extraction): Ditto.
3971         (simplify_shift_const_1): Ditto.
3972         (gen_lowpart_for_combine): Ditto.
3973         * lower-subreg.c (simple_move_operand): Ditto.
3974         * recog.c (simplify_while_replacing): Ditto.
3975         (offsettable_address_addr_space_p): Ditto.
3976         (mode_dependent_address_p): Ditto.
3977         * simplify-rtx.c (simplify_unary_operation_1): Ditto.
3978         (simplify_subreg): Ditto.
3979         * config/m68k/m68k.md: Ditto.
3980         * config/vax/vax.md: Ditto.
3981         * config/vax/constraints.md (Q): Ditto.
3982         * config/vax/predicates.md (indexed_memory_operand): Ditto.
3983         * config/alpha/alpha.c (alpha_mode_dependent_address_p): Add
3984         unused addr_space_t parameter.
3985         * config/avr/avr.c (avr_mode_dependent_address_p): Ditto.
3986         * config/h8300/h8300.c (h8300_mode_dependent_address_p): Ditto.
3987         * config/m32r/m32r.c (m32r_mode_dependent_address_p): Ditto.
3988         * config/rs6000/rs6000.c (rs6000_mode_dependent_address_p): Ditto.
3989         * config/rx/rx.c (rx_mode_dependent_address_p): Ditto.
3990         * config/sparc/sparc.c (sparc_mode_dependent_address_p): Ditto.
3991         * config/stormy16/stormy16.c (xstormy16_mode_dependent_address_p):
3992         Ditto.
3993         * config/vax/vax.c (vax_mode_dependent_address_p): Ditto.
3994         * config/xtensa/xtensa.c (xtensa_mode_dependent_address_p): Ditto.
3995
3996 2012-09-26  Christophe Lyon <christophe.lyon@linaro.org>
3997
3998         * tree-ssa-math-opts.c (bswap_stats): Add found_16bit field.
3999         (execute_optimize_bswap): Add support for builtin_bswap16.
4000
4001 2012-09-26  Richard Guenther  <rguenther@suse.de>
4002
4003         * tree.h (DECL_IS_BUILTIN): Compare LOCATION_LOCUS.
4004
4005 2012-09-26  Ian Lance Taylor  <iant@google.com>
4006
4007         * diagnostic.c: Include "demangle.h" and "backtrace.h".
4008         (bt_stop): New static array.
4009         (bt_callback, bt_err_callback): New static functions.
4010         (diagnostic_action_after_output): Call backtrace_full for DK_ICE.
4011         * Makefile.in (BACKTRACE): New variable.
4012         (BACKTRACEINC, LIBBACKTRACE): New variables.
4013         (BACKTRACE_H): New variable.
4014         (LIBDEPS, LIBS): Add $(LIBBACKTRACE).
4015         (INCLUDES): Add $(BACKTRACEINC).
4016         (diagnostic.o): Depend upon $(DEMANGLE_H) and $(BACKTRACE_H).
4017
4018 2012-09-25  Segher Boessenkool  <segher@kernel.crashing.org>
4019
4020         PR target/51274
4021         PR target/53087
4022         * config/rs6000/rs6000.md (ne0si): Remove unnecessary
4023         earlyclobber.  Merge with...
4024         (ne0di): ... to...
4025         (ne0_<mode>): New.
4026         (plus_ne0si): Merge with...
4027         (plus_ne0di): ... to...
4028         (plus_ne0_<mode>): New.
4029         (compare_plus_ne0si): Merge with...
4030         (compare_plus_ne0di)... to...
4031         (compare_plus_ne0_<mode>): New.
4032         (compare_plus_ne0_<mode>_1): New.
4033         (plus_ne0si_compare): Merge with...
4034         (plus_ne0di_compare)... to...
4035         (plus_ne0_<mode>_compare): New.
4036
4037 2012-09-25  Oleg Endo  <olegendo@gcc.gnu.org>
4038
4039         PR target/54089
4040         * config/sh/constraints.md (Jhb): New constraint.
4041         * config/sh/predicates.md (negt_reg_shl31_operand): New predicate.
4042         * config/sh/sh.md (rotrsi3): New expander.
4043         (rotrsi3_1, *rotrsi3_1, *rotlsi3_1): New insns.
4044         (rotlsi3, rotlhi3): Use const_int_operand predicate instead of
4045         immediate_operand and remove CONST_INT_P checks in expansion code.
4046         (*rotcr): Cleanup variable usage.  Handle preceding nott insn.  Add
4047         split with swapped operands.
4048         (*rotcr_neg_t, *movt_msb, *negt_msb): New insns and splits.
4049
4050 2012-09-25  Aldy Hernandez  <aldyh@redhat.com>
4051
4052         PR middle-end/53850
4053         * trans-mem.c (expand_call_tm): Handle late built built-ins.
4054
4055 2012-09-25  Georg-Johann Lay  <avr@gjlay.de>
4056
4057         PR other/54701
4058         * config/avr/avr-log.c (avr_double_int_pop_digit): Rewrite using
4059         double_int::udivmod.
4060
4061 2012-09-25  Georg-Johann Lay  <avr@gjlay.de>
4062
4063         * config/avr/avr.c (avr_set_current_function): Check cfun->machine
4064         to be non-NULL.
4065
4066 2012-09-25  Georg-Johann Lay  <avr@gjlay.de>
4067
4068         PR target/54641
4069         * config/avr/t-avr: Use ALL_COMPILERFLAGS instead of ALL_CFLAGS
4070         for sources compiled with COMPILER.
4071
4072 2012-09-25  Richard Guenther  <rguenther@suse.de>
4073
4074         PR lto/54625
4075         * lto-symtab.c (lto_symtab_merge_cgraph_nodes_1): Do not merge
4076         cgraph nodes for builtins.
4077
4078 2012-09-25  Jakub Jelinek  <jakub@redhat.com>
4079
4080         PR tree-optimization/54676
4081         * tree-vrp.c (set_and_canonicalize_value_range): Handle
4082         one bit precision properly.
4083
4084         PR other/54692
4085         * configure.ac (CFLAGS, CXXFLAGS): Remove -Ofast or -Og properly.
4086         * configure: Regenerated.
4087
4088 2012-09-25  Georg-Johann Lay  <avr@gjlay.de>
4089
4090         PR other/54701
4091         * config/avr/avr.c (avr_map_decompose): Use double_int::from_uhwi
4092         instead of uhwi_to_double_int.
4093
4094 2012-09-25  Richard Guenther  <rguenther@suse.de>
4095
4096         * lto-symtab.c (lto_symtab_merge_decls_1): Properly merge
4097         all of the chain.
4098
4099 2012-09-25  Richard Guenther  <rguenther@suse.de>
4100
4101         PR tree-optimization/53663
4102         * tree-ssa-sccvn.c (vn_reference_lookup_3): Conditional
4103         native encode/interpret translation on VN_WALKREWRITE.
4104
4105 2012-09-24  Dehao Chen  <dehao@google.com>
4106
4107         * tree-cfg.c (move_stmt_op): Reset the expr block only when necessary.
4108         (move_block_to_fn): Reset the edge's goto block even
4109         when the goto locus is unknown.
4110
4111 2012-09-24  Lawrence Crowl  <crowl@google.com>
4112
4113         * double-int.h (double_int::from_pair): New.
4114         (double_int::wide_mul_with_sign): New.
4115         (double_int::sub_with_overflow): New.
4116         (double_int::neg_with_overflow): New.
4117         (double_int::divmod_with_overflow): New.
4118         (shwi_to_double_int): Remove.
4119         (uhwi_to_double_int): Remove.
4120         (double_int_to_shwi): Remove.
4121         (double_int_to_uhwi): Remove.
4122         (double_int_fits_in_uhwi_p): Remove.
4123         (double_int_fits_in_shwi_p): Remove.
4124         (double_int_fits_in_hwi_p): Remove.
4125         (double_int_mul): Remove.
4126         (double_int_mul_with_sign): Remove.
4127         (double_int_add): Remove.
4128         (double_int_sub): Remove.
4129         (double_int_neg): Remove.
4130         (double_int_div): Remove.
4131         (double_int_sdiv): Remove.
4132         (double_int_udiv): Remove.
4133         (double_int_mod): Remove.
4134         (double_int_smod): Remove.
4135         (double_int_umod): Remove.
4136         (double_int_divmod): Remove.
4137         (double_int_sdivmod): Remove.
4138         (double_int_udivmod): Remove.
4139         (double_int_multiple_of): Remove.
4140         (double_int_setbit): Remove.
4141         (double_int_ctz): Remove.
4142         (double_int_not): Remove.
4143         (double_int_ior): Remove.
4144         (double_int_and): Remove.
4145         (double_int_and_not): Remove.
4146         (double_int_xor): Remove.
4147         (double_int_lshift): Remove.
4148         (double_int_rshift): Remove.
4149         (double_int_lrotate): Remove.
4150         (double_int_rrotate): Remove.
4151         (double_int_negative_p): Remove.
4152         (double_int_cmp): Remove.
4153         (double_int_scmp): Remove.
4154         (double_int_ucmp): Remove.
4155         (double_int_max): Remove.
4156         (double_int_smax): Remove.
4157         (double_int_umax): Remove.
4158         (double_int_min): Remove.
4159         (double_int_smin): Remove.
4160         (double_int_umin): Remove.
4161         (double_int_ext): Remove.
4162         (double_int_sext): Remove.
4163         (double_int_zext): Remove.
4164         (double_int_mask): Remove.
4165         (double_int_max_value): Remove.
4166         (double_int_min_value): Remove.
4167         (double_int_zero_p): Remove.
4168         (double_int_one_p): Remove.
4169         (double_int_minus_one_p): Remove.
4170         (double_int_equal_p): Remove.
4171         (double_int_popcount): Remove.
4172         (extern add_double_with_sign): Remove.
4173         (#define add_double): Remove.
4174         (extern neg_double): Remove.
4175         (extern mul_double_with_sign): Remove.
4176         (extern mul_double_wide_with_sign): Remove.
4177         (#define mul_double): Remove.
4178         (extern lshift_double): Remove.
4179         (extern div_and_round_double): Remove.
4180         * double-int.c (add_double_with_sign): Make static.
4181         (#defined add_double): Localized from header.
4182         (neg_double): Make static.
4183         (mul_double_with_sign): Make static.
4184         (mul_double_wide_with_sign): Make static.
4185         (#defined mul_double): Localized from header.
4186         (lshift_double): Make static.
4187         (div_and_round_double): Make static.
4188         (double_int::wide_mul_with_sign): New.
4189         (double_int::sub_with_overflow): New.
4190         (double_int::neg_with_overflow): New.
4191         (double_int::divmod_with_overflow): New.
4192         * emit-rtl.c (init_emit_once): Change to new double_int API.
4193         * explow.c (plus_constant): Likewise.
4194         * expmed.c (choose_multiplier): Likewise.
4195         * fold-const.c (#define OVERFLOW_SUM_SIGN): Remove.
4196         (int_const_binop_1): Change to new double_int API.
4197         (fold_div_compare): Likewise.
4198         (maybe_canonicalize_comparison): Likewise.
4199         (pointer_may_wrap_p): Likewise.
4200         (fold_negate_const): Likewise.
4201         (fold_abs_const): Likewise.
4202         * simplify-rtx.c (simplify_const_unary_operation): Likewise.
4203         (simplify_const_binary_operation): Likewise.
4204         * tree-chrec.c (tree_fold_binomial): Likewise.
4205         * tree-vrp.c (extract_range_from_binary_expr_1): Likewise.
4206         * config/sparc/sparc.c (sparc_fold_builtin): Likewise.
4207         * config/avr/avr.c (avr_double_int_push_digit): Likewise.
4208         (avr_map): Likewise.
4209         (avr_map_decompose): Likewise.
4210         (avr_out_insert_bits): Likewise.
4211
4212 2012-09-24  Janis Johnson  <janisjo@codesourcery.com>
4213
4214         * doc/sourcebuild.texi (Selectors): Document the use of target
4215         and xfail used together.
4216
4217 2012-09-24  Richard Guenther  <rguenther@suse.de>
4218
4219         PR middle-end/54632
4220         * tree-ssa-live.c (clear_unused_block_pointer_1): Do not
4221         handle DECL_DEBUG_EXPR_IS_FROM here...
4222         (clear_unused_block_pointer): ... but here when walking all
4223         local decls.
4224
4225 2012-09-24  Richard Guenther  <rguenther@suse.de>
4226
4227         PR tree-optimization/54684
4228         * tree-ssa-ccp.c (optimize_unreachable): Properly update stmts.
4229
4230 2012-09-24  Marc Glisse  <marc.glisse@inria.fr>
4231
4232         * tree-ssa-forwprop.c: Include tree-ssa-propagate.h.
4233         (simplify_bitfield_ref): Handle constructors.
4234         * Makefile.in (tree-ssa-forwprop.o): Depend on tree-ssa-propagate.h.
4235
4236 2012-09-24  Richard Guenther  <rguenther@suse.de>
4237
4238         * tree-ssa-pre.c (bitmap_find_leader, create_expression_by_pieces,
4239         find_or_generate_expression): Remove dominating stmt argument.
4240         (find_leader_in_sets, phi_translate_1, bitmap_find_leader,
4241         create_component_ref_by_pieces_1, create_component_ref_by_pieces,
4242         do_regular_insertion, do_partial_partial_insertion): Adjust.
4243         (compute_avail): Do not set uids.
4244
4245 2012-09-24  Eric Botcazou  <ebotcazou@adacore.com>
4246
4247         * tree-streamer-in.c (unpack_ts_type_common_value_fields): Stream in
4248         TYPE_NONALIASED_COMPONENT flag.
4249         * tree-streamer-out.c (pack_ts_type_common_value_fields): Stream out
4250         TYPE_NONALIASED_COMPONENT flag.
4251
4252 2012-09-24  Jia Liu  <proljc@gmail.com>
4253
4254         * doc/lto.texi: Separate sections.
4255         * doc/plugins.texi: Likewise.
4256
4257 2012-09-24  Richard Guenther  <rguenther@suse.de>
4258
4259         PR middle-end/52173
4260         * gimple.c (gimple_copy): Properly mark the copy modified
4261         if SSA operands are present.
4262
4263 2012-09-23  Eric Botcazou  <ebotcazou@adacore.com>
4264
4265         PR tree-optimization/54669
4266         * tree-ssa-loop-ivcanon.c (propagate_into_all_uses): Invoke
4267         maybe_clean_or_replace_eh_stmt on the modified use statements.
4268
4269 2012-09-23  Marc Glisse  <marc.glisse@inria.fr>
4270
4271         * expr.c (do_store_flag): Remove duplicated code.
4272
4273 2012-09-22  Segher Boessenkool  <segher@kernel.crashing.org>
4274
4275         * config/rs6000/predicates.md (altivec_register_operand,
4276         vsx_register_operand, vfloat_operand, vint_operand,
4277         vlogical_operand, gpc_reg_operand, cc_reg_operand,
4278         cc_reg_not_cr0_operand, cc_reg_not_micro_cr0_operand):
4279         If op is a SUBREG, consider its SUBREG_REG instead.
4280
4281 2012-09-22  Uros Bizjak  <ubizjak@gmail.com>
4282
4283         * optabs.c (prepare_cmp_insn): Expand comparison of the result
4284         of memcmp through generic comparison expansion code.
4285
4286 2012-09-21  Anthony Green  <green@moxielogic.com>
4287
4288         * config/moxie/moxie.opt: Add -mno-crt0 option.
4289         * config/moxie/moxie.h (STARTFILE_SPEC): Handle -mno-crt0 option.
4290         * doc/invoke.texi (Option Summary): Document -mno-crt0 option.
4291
4292 2012-09-21  Jack Howarth  <howarth@bromo.med.uc.edu>
4293
4294         PR bootstrap/54642
4295         * Makefile.in (lto-symtab.o): Remove gt-lto-symtab.h dependency.
4296
4297 2012-09-21  Dehao Chen  <dehao@google.com>
4298
4299         PR go/54649
4300         * tree-eh.c (lower_try_finally_dup_block): Set the correct block for
4301         stmts in the duplicated EH block.
4302
4303 2012-09-21  Richard Guenther  <rguenther@suse.de>
4304
4305         PR tree-optimization/54647
4306         * tree-ssa-pre.c (compute_avail): Do not put COND_EXPR
4307         or VEC_COND_EXPR into EXP_GEN again.
4308
4309 2012-09-21  Jakub Jelinek  <jakub@redhat.com>
4310
4311         PR tree-optimization/54629
4312         * tree-loop-distribution.c (classify_partition): Free loop nest only
4313         after freeing ddr.  Free ddr and loop nest also if successful.
4314
4315 2012-09-21  Matthias Klose  <doko@ubuntu.com>
4316
4317         * config/arm/arm.c (arm_mangle_type): Don't warn anymore that
4318         4.4 has changed the `va_list' mangling.
4319
4320 2012-09-21  Eric Botcazou  <ebotcazou@adacore.com>
4321
4322         PR rtl-optimization/54290
4323         PR rtl-optimization/54644
4324         * reload1.c (choose_reload_regs): Fix thinko in previous change.
4325
4326 2012-09-20  Segher Boessenkool  <segher@kernel.crashing.org>
4327
4328         * config/rs6000/rs6000.md (define_split for plus_eqsi):
4329         Fix output pattern.
4330
4331 2012-09-20  Eric Botcazou  <ebotcazou@adacore.com>
4332
4333         * reload1.c (choose_reload_regs): Add missing #ifdef/#endif pair.
4334
4335 2012-09-20  Bernd Schmidt  <bernds@codesourcery.com>
4336
4337         PR bootstrap/54643
4338         * haifa-sched.c (schedule_block): Skip find_modifiable_mems if using
4339         SCHED_PRESSURE_MODEL.
4340
4341 2012-09-20  Joern Rennecke  <joern.rennecke@embecosm.com>
4342
4343         * rtlanal.c (dead_or_set_regno_p): Fix COND_EXEC handling.
4344
4345 2012-09-20  Marek Polacek  <polacek@redhat.com>
4346
4347         * tree-ssa-operands.c (get_expr_operands): Merge identical cases.
4348
4349 2012-09-20  Marek Polacek  <polacek@redhat.com>
4350
4351         * tree-ssa-threadupdate.c (mark_threaded_blocks): Don't cast XNEWVEC's
4352         result.
4353         (create_edge_and_update_destination_phis): Likewise.
4354
4355 2012-09-20  Martin Jambor  <mjambor@suse.cz>
4356
4357         * function.c (push_cfun): Check old current_function_decl matches
4358         old cfun, set new current_function_decl to the decl of the new cfun.
4359         (push_struct_function): Likewise.
4360         (pop_cfun): Likewise.
4361         (allocate_struct_function): Move call to
4362         invoke_set_current_function_hook to the end of the function.
4363         * cfgexpand.c (estimated_stack_frame_size): Do not set and restore
4364         current_function_decl.
4365         * cgraph.c (cgraph_release_function_body): Likewise.
4366         * cgraphunit.c (cgraph_process_new_functions): Likewise.
4367         (cgraph_add_new_function): Likewise.
4368         (cgraph_analyze_function): Likewise.
4369         (assemble_thunk): Set cfun to NULL at the end.
4370         (expand_function): Move call to set_cfun downwards.
4371         * gimple-low.c (record_vars_into): Only check current_function_decl
4372         before possibly doing push_cfun.
4373         * gimplify.c (gimplify_function_tree): Do not set and restore
4374         current_function_decl.
4375         * ipa-inline-analysis.c (compute_inline_parameters): Likewise.
4376         (inline_analyze_function): Likewise.
4377         * ipa-prop.c (ipa_analyze_node): Likewise.
4378         * ipa-pure-const.c (analyze_function): Likewise.
4379         * lto-streamer-in.c (lto_input_function_body): Do not set
4380         current_function_decl.
4381         * lto-streamer-out.c (output_function): Do not set and restore
4382         current_function_decl.
4383         * omp-low.c (finalize_task_copyfn): Likewise.
4384         (expand_omp_taskreg): Likewise.
4385         (create_task_copyfn): Likewise, move push_cfun up quite a bit.
4386         * passes.c (dump_passes): Do not set and restore current_function_decl.
4387         (do_per_function): Likewise.
4388         (do_per_function_toporder): Likewise.
4389         * trans-mem.c (ipa_tm_scan_irr_function): Likewise.
4390         (ipa_tm_transform_transaction): Likewise.
4391         (ipa_tm_transform_clone): Likewise.
4392         (ipa_tm_execute): Likewise.
4393         * tree-emutls.c (lower_emutls_function_body): Likewise.
4394         * tree-inline.c (initialize_cfun): Do not call pop_cfun.
4395         (tree_function_versioning): Do not call push_cfun, do not set and
4396         restore current_function_decl.  Remove assert checking consistency of
4397         cfun and current_function_decl.
4398         * tree-profile.c (tree_profiling): Do not set and restore
4399         current_function_decl.
4400         * tree-sra.c (convert_callers_for_node): Do not set
4401         current_function_decl.
4402         (convert_callers): Do not restore current_function_decl.
4403         (modify_function): Do not set current_function_decl.
4404         * tree-ssa-structalias.c (ipa_pta_execute): Do not set and restore
4405         current_function_decl.
4406
4407 2012-09-20  Diego Novillo  <dnovillo@google.com>
4408
4409         PR target/54631
4410         * config/vxworks.c (vxworks_emutls_var_init): Update for new
4411         VEC_quick_push interface.
4412
4413 2012-09-20  Richard Guenther  <rguenther@suse.de>
4414
4415         PR tree-optimization/54634
4416         * tree-data-ref.c (get_references_in_stmt): For now give
4417         up for pure functions.
4418
4419 2012-09-20  Chen Wei-Ren  <chenwj@iis.sinica.edu.tw>
4420
4421         * doc/lto.texi: Correct typo.
4422
4423 2012-09-19  Dehao Chen  <dehao@google.com>
4424
4425         * config/s390/s390.c (s390_chunkify_start): Replacing INSN_LOCATOR.
4426         * config/spu/spu.c (emit_nop_for_insn): Likewise.
4427         (pad_bb): Likewise.
4428         (spu_emit_branch_hint): Likewise.
4429         (insert_hbrp_for_ilb_runout): Likewise.
4430         * config/mep/mep.c (mep_make_bundle): Likewise.
4431         (mep_bundle_insns): Likewise.
4432         * config/sh/sh.c (gen_block_redirect): Likewise.
4433         * config/c6x/c6x.c (gen_one_bundle): Likewise.
4434         * config/rs6000/rs6000.c (rs6000_final_prescan_insn): Likewise.
4435         * config/picochip/picochip.c (picochip_reorg): Likewise.
4436         * config/arm/arm.c (require_pic_register): Likewise.
4437         * config/mips/mips.c (mips16_gp_pseudo_reg): Likewise.
4438         * config/bfin/bfin.c (gen_one_bundle): Likewise.
4439
4440 2012-09-19  Mark Kettenis  <kettenis@openbsd.org>
4441
4442         * config.gcc (hppa*-*-openbsd*): New target.
4443         * config/pa/pa-openbsd.h: New file.
4444         * config/pa/pa32-openbsd.h: New file.
4445         * config/host-openbsd.c: Update copyright year.
4446         (TRY_EXCEPT_VM_SPACE): Define for OpenBSD/hppa.
4447
4448 2012-09-19  Martin Jambor  <mjambor@suse.cz>
4449
4450         * ipa-prop.c (prune_expression_for_jf): New function.
4451         (ipa_set_jf_constant): Use it.
4452         (ipa_set_jf_arith_pass_through): Likewise.
4453         (determine_known_aggregate_parts): Likewise.
4454
4455 2012-09-19  Steve Ellcey  <sellcey@mips.com>
4456
4457         * config.gcc (mips*-mti-elf*): New target.
4458         * config/mips/mti-elf.h: New file.
4459         * config/mips/t-mti-elf: New file.
4460
4461 2012-09-19  Dehao Chen  <dehao@google.com>
4462
4463         * toplev.c (general_init): Init block_locations.
4464         * tree.c (tree_set_block): New.
4465         (tree_block): Change to use LOCATION_BLOCK.
4466         * tree.h (TREE_SET_BLOCK): New.
4467         * final.c (reemit_insn_block_notes): Change to use LOCATION_BLOCK.
4468         (final_start_function): Likewise.
4469         * input.c (expand_location_1): Likewise.
4470         * input.h (LOCATION_LOCUS): New.
4471         (LOCATION_BLOCK): New.
4472         (IS_UNKNOWN_LOCATION): New.
4473         * fold-const.c (expr_location_or): Change to use new location.
4474         * reorg.c (emit_delay_sequence): Likewise.
4475         (try_merge_delay_insns): Likewise.
4476         * modulo-sched.c (dump_insn_location): Likewise.
4477         * lto-streamer-out.c (lto_output_location_bitpack): Likewise.
4478         * lto-cgraph.c (output_node_opt_summary): Likewise.
4479         * jump.c (rtx_renumbered_equal_p): Likewise.
4480         * ifcvt.c (noce_try_move): Likewise.
4481         (noce_try_store_flag): Likewise.
4482         (noce_try_store_flag_constants): Likewise.
4483         (noce_try_addcc): Likewise.
4484         (noce_try_store_flag_mask): Likewise.
4485         (noce_try_cmove): Likewise.
4486         (noce_try_cmove_arith): Likewise.
4487         (noce_try_minmax): Likewise.
4488         (noce_try_abs): Likewise.
4489         (noce_try_sign_mask): Likewise.
4490         (noce_try_bitop): Likewise.
4491         (noce_process_if_block): Likewise.
4492         (cond_move_process_if_block): Likewise.
4493         (find_cond_trap): Likewise.
4494         * ipa-prop.c (ipa_set_jf_constant): Likewise.
4495         (ipa_write_jump_function): Likewise.
4496         * dwarf2out.c (add_src_coords_attributes): Likewise.
4497         * expr.c (expand_expr_real): Likewise.
4498         * tree-parloops.c (create_loop_fn): Likewise.
4499         * recog.c (peep2_attempt): Likewise.
4500         * function.c (free_after_compilation): Likewise.
4501         (expand_function_end): Likewise.
4502         (set_insn_locations): Likewise.
4503         (thread_prologue_and_epilogue_insns): Likewise.
4504         * print-rtl.c (print_rtx): Likewise.
4505         * profile.c (branch_prob): Likewise.
4506         * trans-mem.c (ipa_tm_scan_irr_block): Likewise.
4507         * gimplify.c (gimplify_call_expr): Likewise.
4508         * except.c (duplicate_eh_regions_1): Likewise.
4509         * emit-rtl.c (try_split): Likewise.
4510         (make_insn_raw): Likewise.
4511         (make_debug_insn_raw): Likewise.
4512         (make_jump_insn_raw): Likewise.
4513         (make_call_insn_raw): Likewise.
4514         (emit_pattern_after_setloc): Likewise.
4515         (emit_pattern_after): Likewise.
4516         (emit_debug_insn_after): Likewise.
4517         (emit_pattern_before): Likewise.
4518         (emit_insn_before_setloc): Likewise.
4519         (emit_jump_insn_before): Likewise.
4520         (emit_call_insn_before_setloc): Likewise.
4521         (emit_call_insn_before): Likeise.
4522         (emit_debug_insn_before_setloc): Likewise.
4523         (emit_copy_of_insn_after): Likewise.
4524         (insn_locators_alloc): Remove.
4525         (insn_locators_finalize): Remove.
4526         (insn_locators_free): Remove.
4527         (set_curr_insn_source_location): Remove.
4528         (get_curr_insn_source_location): Remove.
4529         (set_curr_insn_block): Remove.
4530         (get_curr_insn_block): Remove.
4531         (locator_scope): Remove.
4532         (insn_scope): Change to use new location.
4533         (locator_location): Remove.
4534         (insn_line): Change to use new location.
4535         (locator_file): Remove.
4536         (insn_file): Change to use new location.
4537         (locator_eq): Remove.
4538         (insn_locations_init): New.
4539         (insn_locations_finalize): New.
4540         (set_curr_insn_location): New.
4541         (curr_insn_location): New.
4542         * cfgexpand.c (gimple_assign_rhs_to_tree): Change to use new location.
4543         (expand_gimple_cond): Likewise.
4544         (expand_call_stmt): Likewise.
4545         (expand_gimple_stmt_1): Likewise.
4546         (expand_gimple_basic_block): Likewise.
4547         (construct_exit_block): Likewise.
4548         (gimple_expand_cfg): Likewise.
4549         * cfgcleanup.c (try_forward_edges): Likewise.
4550         * tree-ssa-live.c (remove_unused_scope_block_p): Likewise.
4551         (dump_scope_block): Likewise.
4552         (remove_unused_locals): Likewise.
4553         * rtl.c (rtx_equal_p_cb): Likewise.
4554         (rtx_equal_p): Likewise.
4555         * rtl.h (XUINT): New.
4556         (INSN_LOCATOR): Remove.
4557         (CURR_INSN_LOCATION): Remove.
4558         (INSN_LOCATION): New.
4559         (INSN_HAS_LOCATION): New.
4560         * tree-inline.c (remap_gimple_op_r): Change to use new location.
4561         (copy_tree_body_r): Likewise.
4562         (copy_phis_for_bb): Likewise.
4563         (expand_call_inline): Likewise.
4564         * tree-streamer-in.c (lto_input_ts_exp_tree_pointers): Likewise.
4565         * tree-streamer-out.c (write_ts_decl_minimal_tree_pointers): Likewise.
4566         * gimple-streamer-out.c (output_gimple_stmt): Likewise.
4567         * combine.c (try_combine): Likewise.
4568         * tree-outof-ssa.c (set_location_for_edge): Likewise.
4569         (insert_partition_copy_on_edge): Likewise.
4570         (insert_value_copy_on_edge): Likewise.
4571         (insert_rtx_to_part_on_edge): Likewise.
4572         (insert_part_to_rtx_on_edge): Likewise.
4573         * basic-block.h (edge_def): Remove field.
4574         * gimple.h (gimple_statement_base): Remove field.
4575         (gimple_bb): Change to use new location.
4576         (gimple_set_block): Likewise.
4577         (gimple_has_location): Likewise.
4578         * tree-cfg.c (make_cond_expr_edges): Likewise.
4579         (make_goto_expr_edges): Likewise.
4580         (gimple_can_merge_blocks_p): Likewise.
4581         (move_stmt_op): Likewise.
4582         (move_block_to_fn): Likewise.
4583         * config/alpha/alpha.c (alpha_output_mi_thunk_osf): Likewise.
4584         * config/sparc/sparc.c (sparc_output_mi_thunk): Likewise.
4585         * config/i386/i386.c (x86_output_mi_thunk): Likewise.
4586         * config/tilegx/tilegx.c (tilegx_output_mi_thunk): Likewise.
4587         * config/sh/sh.c (sh_output_mi_thunk): Likewise.
4588         * config/ia64/ia64.c (ia64_output_mi_thunk): Likewise.
4589         * config/rs6000/rs6000.c (rs6000_output_mi_thunk): Likewise.
4590         * config/score/score.c (score_output_mi_thunk): Likewise.
4591         * config/tilepro/tilepro.c (tilepro_asm_output_mi_thunk): Likewise.
4592         * config/mips/mips.c (mips_output_mi_thunk): Likewise.
4593         * cfgrtl.c (unique_locus_on_edge_between_p): Likewise.
4594         (unique_locus_on_edge_between_p): Likewise.
4595         (emit_nop_for_unique_locus_between): Likewise.
4596         (force_nonfallthru_and_redirect): Likewise.
4597         (fixup_reorder_chain): Likewise.
4598         (cfg_layout_merge_blocks): Likewise.
4599         * stmt.c (emit_case_nodes): Likewise.
4600
4601 2012-09-19  Bernd Schmidt  <bernds@codesourcery.com>
4602
4603         * dbgcnt.def (sched_breakdep): New counter.
4604         * haifa-sched.c (update_insn_after_change): New static function,
4605         broken out of haifa_change_pattern.
4606         (haifa_change_pattern): Call it.
4607         (dep_t heap vecs): Declare.
4608         (INSN_COST): Define earlier.
4609         (next_cycle_replace_deps, next_cycle_apply): New static variables.
4610         (apply_replacement): New static function.
4611         (recompute_todo_spec): New argument FOR_BACKTRACK.  All callers
4612         changed.  Handle DEP_REPLACE deps.
4613         (contributes_to_priority_p): False for replaceable deps.
4614         (must_restore_pattern_p, restore_pattern): New static functions.
4615         (schedule_insn): Use them.  Apply replacements for broken deps.
4616         (struct haifa_saved_data): Add new fields to keep track of
4617         replacements.
4618         (save_backtrack_point): Initialize them.
4619         (undo_replacements_for_backtrack): New static function.
4620         (restore_last_backtrack_point, free_topmost_backtrack_point):
4621         Use it and keep track of replacements.
4622         (perform_replacements_new_cycle, undo_all_replacements): New static
4623         functions.
4624         (schedule_block): Call these two as necessary.  Call
4625         find_modifiable_mems.
4626         (try_ready): Tweak the assert.  Check for DEP_POSTPONED.
4627         * sched-deps.c: Include "emit-rtl.h".
4628         (init_dep_1): Initialize DEP_NONREG, DEP_MULTIPLE and DEP_REPLACE.
4629         (dep_spec_p): True for DEP_REPLACE deps.
4630         (mark_as_hard): New static variable.
4631         (update_dep): Update DEP_NONREG and DEP_MULTIPLE.
4632         (add_dependence_list): New argument hard.  All callers changed.  Set
4633         and clear mark_as_hard around function body.
4634         (add_dependence_list_and_free): Likewise.
4635         (haifa_note_mem_dep): Set DEP_NONREG.
4636         (haifa_note_dep): Likewise if mark_as_hard is true.
4637         (sched_analyze_insn): Switch loop with if statement testing for
4638         sel_sched_p.
4639         (struct mem_inc_info): New.
4640         (attempt_change, parse_add_or_inc, find_inc, find_mem): New static
4641         functions.
4642         (find_modifiable_mems): New function.
4643         * sched-int.h (struct dep_replacement): New.
4644         (struct _dep): Add replace, nonreg and multiple fields.  Make type and
4645         cost bitfields.
4646         (UNKNOWN_DEP_COST): Change to match the bitfield.
4647         (DEP_NONREG, DEP_MULTIPLE, DEP_REPLACE): New macros.
4648         (DEP_POSTPONED): New macro.
4649         (DEP_CANCELLED): Renumber.
4650         (find_modifiable_mems): Declare.
4651         (enum SCHED_FLAGS): Add DONT_BREAK_DEPENDENCIES.
4652         * sched-rgn.c (init_ready_list): Set TODO_SPEC here.
4653         (new_ready): Don't set HARD_DEP, use DEP_POSTPONED.
4654         (debug_dependencies): Dump DEP_NONREG and DEP_MULTIPLE.
4655         * Makefile.in (sched-deps.o): Update dependencies.
4656         * config/c6x/c6x.c (in_hwloop): New static variable.
4657         (c6x_set_sched_flags): If it is true, add DONT_BREAK_DEPENDENCIES.
4658         (hwloop_optimize): Set and clear it around preliminary scheduling pass.
4659
4660 2012-09-19  Tulio Magno Quites Machado Filho  <tuliom@linux.vnet.ibm.com>
4661
4662         * config/rs6000/rs6000-builtin.def: Add __builtin_ppc_get_timebase
4663         and __builtin_ppc_mftb.
4664         * config/rs6000/rs6000.c (rs6000_expand_zeroop_builtin): New function
4665         to expand an expression that calls a built-in without arguments.
4666         (rs6000_expand_builtin): Add __builtin_ppc_get_timebase and
4667         __builtin_ppc_mftb.
4668         (rs6000_init_builtins): Likewise.
4669         * config/rs6000/rs6000.md (rs6000_get_timebase): New pattern.
4670         (rs6000_get_timebase_ppc32): New pattern.
4671         (rs6000_mftb_<mode>): New pattern.
4672
4673         * doc/extend.texi (PowerPC Built-in Functions): New section.
4674         (PowerPC AltiVec/VSX Built-in Functions): Move some built-ins
4675         unrelated to Altivec/VSX to the new section.
4676
4677 2012-09-19  David Edelsohn  <dje.gcc@gmail.com>
4678
4679         * rs6000.md (mac*): Remove extra spaces.
4680         (mulhw*): Same.
4681
4682 2012-09-19  Oleg Endo  <olegendo@gcc.gnu.org>
4683
4684         PR target/54089
4685         * config/sh/predicates.md (arith_reg_or_t_reg_operand): New predicate.
4686         * config/sh/sh.md (*rotcr): Use arith_reg_or_t_reg_operand predicate.
4687         Handle the case where one of the operands is T_REG.
4688         Add new pattern to handle MSB extraction.
4689
4690 2012-09-19  Oleg Endo  <olegendo@gcc.gnu.org>
4691
4692         PR target/54236
4693         * config/sh/sh.md (*addc): Add pattern to handle one bit left shifts.
4694
4695 2012-09-19  Oleg Endo  <olegendo@gcc.gnu.org>
4696
4697         * config/sh/sh.md (prologue, epilogue): Use braced strings.
4698
4699 2012-09-19  Eric Botcazou  <ebotcazou@adacore.com>
4700
4701         PR rtl-optimization/54290
4702         * reload1.c (choose_reload_regs): Also take into account secondary MEMs
4703         to remove address replacements for inherited reloads.
4704         (replaced_subreg): Move around.
4705
4706 2012-09-19  David Edelsohn  <dje.gcc@gmail.com>
4707
4708         * config/rs6000/aix61.h (TARGET_DEFAULT): Add MASK_PPC_GPOPT,
4709         MASK_PPC_GFXOPT, and MASK_MFCRF.
4710
4711 2012-09-19  Richard Guenther  <rguenther@suse.de>
4712
4713         * passes.c (init_optimization_passes): For -Og move
4714         pass_object_sizes inbetween CCP and copyprop.
4715
4716 2012-09-19  Richard Guenther  <rguenther@suse.de>
4717
4718         * tree-ssa-forwprop.c (get_prop_source_stmt): Simplify.
4719
4720 2012-09-19  Jan Hubicka  <jh@suse.cz>
4721
4722         * symtab.c (insert_to_assembler_name_hash): Do not insert
4723         register vars.
4724         (unlink_from_assembler_name_hash): NULL out pointers of unlinked var.
4725         (symtab_prevail_in_asm_name_hash): New.
4726         (symtab_initialize_asm_name_hash): Break out from ...
4727         (symtab_node_for_asm): ... here.
4728         (dump_symtab_base): Dump LTO file data.
4729         (verify_symtab_base): Register vars are not in symtab.
4730         * cgraph.h (symtab_initialize_asm_name_hash,
4731         symtab_prevail_in_asm_name_hash): New functions.
4732         (symtab_real_symbol_p): New inline.
4733         * lto-symtab.c: Do not include gt-lto-symtab.h.
4734         (lto_symtab_entry_def): Remove.
4735         (lto_symtab_entry_t): Remove.
4736         (lto_symtab_identifiers): Remove.
4737         (lto_symtab_free): Remove.
4738         (lto_symtab_entry_hash): Remove.
4739         (lto_symtab_entry_eq): Remove.
4740         (lto_symtab_entry_marked_p): Remove.
4741         (lto_symtab_maybe_init_hash_table): Remove.
4742         (resolution_guessed_p, set_resolution_guessed): New functions.
4743         (lto_symtab_register_decl): Only set resolution info.
4744         (lto_symtab_get, lto_symtab_get_resolution): Remove.
4745         (lto_symtab_merge): Reorg to work across symtab; do nothing if decls
4746         are same.
4747         (lto_symtab_resolve_replaceable_p): Reorg to work on symtab.
4748         (lto_symtab_resolve_can_prevail_p): Likewise; only real symbols can
4749         prevail.
4750         (lto_symtab_resolve_symbols): Reorg to work on symtab.
4751         (lto_symtab_merge_decls_2): Likewise.
4752         (lto_symtab_merge_decls_1): Likewise; add debug dumps.
4753         (lto_symtab_merge_decls): Likewise; do not merge at ltrans stage.
4754         (lto_symtab_merge_cgraph_nodes_1): Reorg to work on symtab.
4755         (lto_symtab_merge_cgraph_nodes): Likewise; do not merge at ltrans
4756         stage.
4757         (lto_symtab_prevailing_decl): Rewrite to lookup into symtab.
4758         * lto-streaer.h (lto_symtab_free): Remove.
4759         * lto-cgraph.c (add_references): Cleanup.
4760         * varpool.c (varpool_assemble_decl): Skip hard regs.
4761
4762 2012-09-19  Richard Guenther  <rguenther@suse.de>
4763
4764         PR other/53316
4765         * common/common-target.h (OPT_LEVELS_1_PLUS_NOT_DEBUG): Add.
4766
4767 2012-09-19  Richard Guenther  <rguenther@suse.de>
4768
4769         PR other/53316
4770         * common.opt (optimize_debug): New variable.
4771         (Og): New optimization level.
4772         * doc/invoke.texi (Og): Document.
4773         * opts.c (maybe_default_option): Add debug parameter.
4774         (maybe_default_options): Likewise.
4775         (default_options_optimization): Handle -Og.
4776         (common_handle_option): Likewise.
4777         * passes.c (gate_all_optimizations): Do not run with -Og.
4778         (gate_all_optimizations_g): New gate, run with -Og.
4779         (pass_all_optimizations_g): New container pass, run with -Og.
4780         (init_optimization_passes): Schedule pass_all_optimizations_g
4781         alongside pass_all_optimizations.
4782
4783 2012-09-19  Richard Guenther  <rguenther@suse.de>
4784
4785         PR tree-optimization/54132
4786         * tree-loop-distribution.c (classify_partition): Properly
4787         check dependences for memmove.
4788         * tree-data-ref.h (compute_affine_dependence): Declare.
4789         * tree-data-ref.c (compute_affine_dependence): Export.
4790
4791 2012-09-19  Zhenqiang Chen <zhenqiang.chen@arm.com>
4792
4793         PR middle-end/54364
4794         * bb-reorder.c (connect_better_edge_p): New added.
4795         (find_traces_1_round): When optimizing for size, ignore edge frequency
4796         and probability, and handle all in one round.
4797         (bb_to_key): Use bb->index as key when optimizing for size.
4798         (better_edge_p): The bb with smaller index is better when optimizing
4799         for size.
4800         (connect_traces): When optimizing for size, connect block n with
4801         block n + 1; connect trace m with trace m + 1 if falling through.
4802         (gate_handle_reorder_blocks): Enable bbro when optimizing for -Os.
4803
4804 2012-09-19  Bin Cheng  <bin.cheng@arm.com>
4805
4806         * fold-const.c (fold_truth_andor): Remove duplicated check on
4807         BRANCH_COST.
4808
4809 2012-09-18  Eric Botcazou  <ebotcazou@adacore.com>
4810
4811         PR middle-end/54617
4812         * expr.c (store_field): Handle a PARALLEL in more cases.
4813
4814 2012-09-18  Segher Boessenkool  <segher@kernel.crashing.org>
4815
4816         * config/rs6000/rs6000.md (sminsi3, smaxsi3, uminsi3, umaxsi3): Delete.
4817         (abssi2, abs<mode>2_isel, nabs<mode>2_isel, abssi2_nopower,
4818         nabs_nopower): Delete.
4819         (absdi2, absdi2_internal, nabsdi2): Delete.
4820         (smindi3, smaxdi3, umindi3, umaxdi3): Delete.
4821
4822 2012-09-18  Georg-Johann Lay  <avr@gjlay.de>
4823
4824         * config/avr/avr.md: Tidy up empty "".  Fix C code indentation.
4825         * config/avr/avr-fixed.md: Ditto.
4826
4827 2012-09-18  Maciej W. Rozycki  <macro@codesourcery.com>
4828
4829         * config/rs6000/rs6000.c (print_operand) <'c'>: Remove.
4830         * config/rs6000/spe.md: Remove a leftover comment.
4831
4832 2012-09-18  Jakub Jelinek  <jakub@redhat.com>
4833
4834         PR target/54592
4835         * config/i386/i386.c (ix86_rtx_costs): Limit > UNITS_PER_WORD
4836         AND/IOR/XOR cost calculation to MODE_INT class modes.
4837
4838 2012-09-18 Thomas Quinot  <quinot@adacore.com>
4839
4840         * doc/invoke.texi: Document -fada-spec-parent.
4841
4842 2012-09-18  Jakub Jelinek  <jakub@redhat.com>
4843
4844         PR tree-optimization/54610
4845         * tree-ssa-forwprop.c: Include optabs.h.  Don't include
4846         tree-vectorizer.h.
4847         (simplify_vector_constructor): Don't use vect_gen_perm_mask,
4848         instead create the mask constant here.
4849         * Makefile.in (tree-ssa-forwprop.o): Depend on $(OPTABS_H).
4850         Don't depend on $(TREE_VECTORIZER_H).
4851
4852 2012-09-18  Florian Weimer  <fweimer@redhat.com>
4853
4854         * Makefile.in (BASIC_BLOCK_H): Add cfg-flags.def.
4855
4856 2012-09-18  Richard Guenther  <rguenther@suse.de>
4857
4858         * statistics.h (CXX_MEM_STAT_INFO): New define.
4859         * gimple.h (gimple_build_assign_with_ops_stat,
4860         gimple_build_assign_with_ops, gimple_build_assign_with_ops3):
4861         Turn into an overload of the function gimple_build_assign_with_ops.
4862         * gimple.c (gimple_build_assign_with_ops_stat): Rename to ...
4863         (gimple_build_assign_with_ops): ... this.
4864         * tree-ssa-loop-im.c (move_computations_stmt): Adjust.
4865         * tree-ssa-math-opts.c (convert_mult_to_fma): Likewise.
4866         * tree-vect-data-refs.c (vect_permute_store_chain): Likewise.
4867         (vect_permute_load_chain): Likewise.
4868         * tree-vect-generic.c (expand_vector_divmod): Likewise.
4869         * tree-vect-patterns.c (vect_recog_dot_prod_pattern): Likewise.
4870         (vect_recog_divmod_pattern): Likewise.
4871         (vect_recog_mixed_size_cond_pattern): Likewise.
4872         (adjust_bool_pattern): Likewise.
4873         * tree-vect-slp.c (vect_create_mask_and_perm): Likewise.
4874         * tree-vect-stmts.c (vectorizable_operation): Likewise.
4875         (permute_vec_elements): Likewise.
4876         (vectorizable_load): Likewise.
4877
4878 2012-09-17  Paul Koning  <ni1d@arrl.net>
4879
4880         * doc/invoke.text (-feliminate-unused-debug-types): Update to
4881         reflect that this is enabled by default.
4882
4883 2012-09-17  Ben Cheng  <bccheng@google.com
4884
4885         * config/arm/linux-elf.h (LINUX_TARGET_LINK_SPEC): Suppress the
4886         dynamic linker commands for statically linked programs.
4887
4888 2012-09-17  Ulrich Weigand  <ulrich.weigand@linaro.org>
4889
4890         * config/arm/arm.c (arm_rtx_costs_1): Handle vec_extract and vec_set
4891         patterns.
4892         * config/arm/arm.md ("vec_set<mode>_internal"): Support memory source
4893         operands, implemented via vld1 instruction.
4894         ("vec_extract<mode>"): Support memory destination operands, implemented
4895         via vst1 instruction.
4896         ("neon_vst1_lane<mode>"): Use UNSPEC_VST1_LANE instead of vec_select.
4897         * config/arm/predicates.md ("neon_lane_number"): Remove.
4898
4899 2012-09-17  Ramana Radhakrishnan  <ramana.radhakrishnan@linaro.org>
4900             Ulrich Weigand  <ulrich.weigand@linaro.org>
4901
4902         * config/arm/arm.c (output_move_neon): Update comment.
4903         Use vld1.64/vst1.64 instead of vldm/vstm where possible.
4904         (neon_vector_mem_operand): Support double-word modes.
4905         * config/arm/neon.md (*neon_mov VD): Call output_move_neon
4906         instead of output_move_vfp.  Change constraint from Uv to Un.
4907
4908 2012-09-17  Richard Guenther  <rguenther@suse.de>
4909
4910         PR lto/54598
4911         * tree-streamer-in.c (unpack_ts_real_cst_value_fields): Use ggc'ed
4912         FIXED_VALUE_TYPE instead of struct fixed_value.
4913
4914 2012-09-17  Georg-Johann Lay  <avr@gjlay.de>
4915
4916         * config/avr/avr.c (CONST_FIXED_P): Remove define.
4917         * config/avr/avr.md (add<mode>3): Use CONST_FIXED_P.
4918
4919 2012-09-17  Georg-Johann Lay  <avr@gjlay.de>
4920
4921         PR target/54607
4922         * config.gcc (tm_file,avr): Add avr/avr-arch.h.
4923         * config/avr/t-avr (gen-avr-mmcu-texi): Use CC_FOR_BUILD to
4924         compile.  Don't depend on TM_H.  Use CFLAGS_FOR_BUILD.
4925         * config/avr/avr.h (avr_arch, base_arch_s, mcu_type_s): Source out
4926         to...
4927         * config/avr/avr-arch.h: ...this new file.
4928         * config/avr/gen-avr-mmcu-texi.c: Include avr-arch.h, stdio.h,
4929         stdlib.h.
4930         * comparator: Make letters smaller than digits.
4931         * config/avr/avr-devices.c: Don't include headers if used in
4932         gen-avr-mmcu-texi.c.
4933         * doc/avr-mmcu.texi: Regenerate.
4934
4935 2012-09-17  Georg-Johann Lay  <avr@gjlay.de>
4936
4937         * rtl.h (CONST_FIXED_P): New predicate macro.
4938
4939 2012-09-17  Eric Botcazou  <ebotcazou@adacore.com>
4940
4941         * tree-cfgcleanup. (cleanup_control_expr_graph) <GIMPLE_COND>: Remove
4942         code doing propagation from degenerate PHI nodes.
4943         * tree-ssa-loop-ivcanon.c (propagate_into_all_uses): New function.
4944         (propagate_constants_for_unrolling): Likewise.
4945         (tree_unroll_loops_completely): If the current loop has been unrolled
4946         and its father isn't the entire function, propagate constants within
4947         the new basic blocks by means of propagate_constants_for_unrolling.
4948
4949 2012-09-17  Jakub Jelinek  <jakub@redhat.com>
4950
4951         PR tree-optimization/54563
4952         * tree-ssa-math-opts.c (execute_cse_sincos): Call
4953         gimple_purge_dead_eh_edges if last call has been changed.
4954
4955 2012-09-17  Georg-Johann Lay  <avr@gjlay.de>
4956
4957         PR target/54222
4958         * config/avr/avr.c (avr_out_plus_symbol): Fix typo if PLUS and PSImode.
4959         (avr_out_plus_1): Remove log comments from assembler output.
4960
4961 2012-09-17  Ruben Buchatskiy  <ruben@ispras.ru>
4962
4963         * config/arm/vfp.md (*thumb2_movdf_vfp): Require one of the operands
4964         to be a register.
4965
4966 2012-09-16  Richard Sandiford  <rdsandiford@googlemail.com>
4967
4968         * calls.c (expand_call): Use emit_group_move for PARALLEL->PARALLEL
4969         moves.
4970
4971 2012-09-15  Tom de Vries  <tom@codesourcery.com>
4972
4973         * tree-vrp.c (extract_range_from_binary_expr_1): Fix bug in handling of
4974         LSHIFT_EXPR with shift range.  Handle more LSHIFT_EXPR cases with shift
4975         range.
4976
4977 2012-09-15  Georg-Johann Lay  <avr@gjlay.de>
4978
4979         PR target/54222
4980         * config/avr/avr-fixed.md (ALL2S, ALL4S, ALL24S, ALL124S,
4981         ALL124U): New mode iterators.
4982         (<code_stdname><mode>3): New insns for SS_PLUS, SS_MINUS.
4983         (<code_stdname><mode>3): New insns for US_PLUS, US_MINUS.
4984         (usneg<mode>2): New insns.
4985         (<code_stdname><mode>2): New expanders for SS_NEG, SS_ABS.
4986         (*<code_stdname><mode>2): New insns for SS_NEG, SS_ABS.
4987         * config/avr/avr-dimode.md (ALL8U, ALL8S): New mode iterators.
4988         (avr_out_plus64, avr_out_minus64): Use avr_out_plus instead.
4989         (<code_stdname><mode>3): New expanders for SS_PLUS, SS_MINUS.
4990         (<code_stdname><mode>3): New expanders for US_PLUS, US_MINUS.
4991         (<code_stdname><mode>3_insn): New insns.
4992         (<code_stdname><mode>3_const_insn): New insns.
4993         * config/avr/avr.md (cc): Add: plus. Remove: out_plus,
4994         out_plus_noclobber, minus.
4995         (length): Add: plus.  Remove: out_plus, out_plus_noclobber,
4996         plus64, minus, minus64.
4997         (abelian): New code_attr.
4998         (code_stdname): Handle: ss_plus, ss_minus, ss_neg, ss_abs,
4999         us_plus, us_minus, us_neg.
5000         (*add<mode>3, add<mode>3_clobber, add<mode>3, addpsi3, sub<mode>3):
5001         Use avr_out_plus to output.
5002         * config/avr/avr-protos.h (avr_out_plus): Change prototype.
5003         (avr_out_plus_noclobber, avr_out_minus): Remove.
5004         (avr_out_plus64, avr_out_minus64): Remove.
5005         * config/avr/avr.c (avr_out_plus_1): Add new default arguments
5006         code_sat, sign.  Saturate after operation if code_sat != UNKNOWN.
5007         (avr_out_plus_symbol): New static function.
5008         (avr_out_plus): Rewrite.
5009         (adjust_insn_length): Handle: ADJUST_LEN_PLUS.  Remove handling
5010         of: ADJUST_LEN_OUT_PLUS, ADJUST_LEN_PLUS64, ADJUST_LEN_MINUS,
5011         ADJUST_LEN_MINUS64, ADJUST_LEN_OUT_PLUS_NOCLOBBER.
5012         (notice_update_cc): Handle: CC_PLUS.  Remove handling of: CC_MINUS,
5013         CC_OUT_PLUS, CC_OUT_PLUS_NOCLOBBER
5014         (avr_out_plus_noclobber, avr_out_minus): Remove.
5015         (avr_out_plus64, avr_out_minus64): Remove.
5016         (avr_print_operand): Print raw REGNO if 'r' is used with REG.
5017
5018 2012-09-15  Oleg Endo  <olegendo@gcc.gnu.org>
5019
5020         * config/sh/sh.c (sh_rtx_costs): Add handling of MEM, SIGN_EXTEND,
5021         ZERO_EXTEND and PARALLEL cases.
5022         (sh_address_cost): Correct rtx parsing and tweak cost estimations.
5023
5024 2012-09-14  Sandra Loosemore  <sandra@codesourcery.com>
5025
5026         * doc/tm.texi.in (Stack Arguments): Update obsolete references
5027         to current_function_outgoing_args_size.
5028         (Function Entry): Likewise for current_function_pops_args,
5029         current_function_pretend_args_size,
5030         current_function_outgoing_args_size, and
5031         current_function_epilogue_delay_list.
5032         (Misc): Fix garbled sentence referencing nonexistent
5033         current_function_leaf_function.
5034         * doc/tm.texi: Regenerated.
5035
5036 2012-09-14  Dehao Chen  <dehao@google.com>
5037
5038          * tree-eh.c (goto_queue_node): New field.
5039         (record_in_goto_queue): New parameter.
5040         (record_in_goto_queue_label): New parameter.
5041         (lower_try_finally_dup_block): New parameter.
5042         (maybe_record_in_goto_queue): Update source location.
5043         (lower_try_finally_copy): Likewise.
5044         (honor_protect_cleanup_actions): Likewise.
5045         * gimplify.c (gimplify_expr): Reset the location to unknown.
5046
5047 2012-09-14  David Edelsohn  <dje.gcc@gmail.com>
5048
5049         * configure: Regenerated.
5050
5051 2012-09-14  Walter Lee  <walt@tilera.com>
5052
5053         * doc/invoke.texi (Option Summary): fix typesetting for -mcpu
5054         option for TILEPro and TILE-Gx.
5055         (TILE-Gx Options): Fix grammar and spellings in documentation for
5056         -mcmodel.
5057
5058 2012-09-14  Marc Glisse  <marc.glisse@inria.fr>
5059
5060         PR c++/54427
5061         * fold-const.c (fold_unary_loc): Disable for VECTOR_TYPE.
5062         (fold_binary_loc): Likewise.
5063         * gimple-fold.c (and_comparisons_1): Handle VECTOR_TYPE.
5064         (or_comparisons_1): Likewise.
5065
5066 2012-09-14  Richard Earnshaw  <rearnsha@arm.com>
5067
5068         PR target/54516
5069         PR rtl-optimization/54540
5070         * reload.c (find_dummy_reload): Don't use OUT as a reload reg
5071         for IN if it overlaps a fixed register.
5072
5073 2012-09-14  Eric Botcazou  <ebotcazou@adacore.com>
5074
5075         PR rtl-optimization/44194
5076         * calls.c (expand_call): In the PARALLEL case, copy the return value
5077         into pseudos instead of spilling it onto the stack.
5078         * emit-rtl.c (adjust_address_1): Rename ADJUST into ADJUST_ADDRESS and
5079         add new ADJUST_OBJECT parameter.
5080         If ADJUST_OBJECT is set, drop the underlying object if it cannot be
5081         proved that the adjusted memory access is still within its bounds.
5082         (adjust_automodify_address_1): Adjust call to adjust_address_1.
5083         (widen_memory_access): Likewise.
5084         * expmed.c (store_bit_field_1): Call adjust_bitfield_address instead
5085         of adjust_address.  Do not drop the underlying object of a MEM.
5086         (store_fixed_bit_field): Likewise.
5087         (extract_bit_field_1): Likewise.  Fix oversight in recursion.
5088         (extract_fixed_bit_field): Likewise.
5089         * expr.h (adjust_address_1): Adjust prototype.
5090         (adjust_address): Adjust call to adjust_address_1.
5091         (adjust_address_nv): Likewise.
5092         (adjust_bitfield_address): New macro.
5093         (adjust_bitfield_address_nv): Likewise.
5094         * expr.c (expand_assignment): Handle a PARALLEL in more cases.
5095         (store_expr): Likewise.
5096         (store_field): Likewise.
5097
5098         * dse.c: Fix typos in the head comment.
5099
5100 2012-09-14  Christian Bruel  <christian.bruel@st.com>
5101
5102         PR target/54546
5103         * config/sh/sh-protos.h (sh_need_epilogue): Delete.
5104         (sh_can_use_simple_return_p): Declare.
5105         * config/sh/sh.c (sh_can_use_simple_return_p): Define.
5106         (sh_need_epilogue, sh_need_epilogue_known): Delete.
5107         (sh_output_function_epilogue): Remove sh_need_epilogue_known.
5108         * config/sh/sh.md (simple_return, return): Define.
5109         (epilogue): Use inline return rtl.
5110         (sh_expand_epilogue): Cleanup parameters boolean type.
5111         * config/sh/iterators.md (any_return): New iterator.
5112
5113 2012-09-14  Christian Bruel  <christian.bruel@st.com>
5114
5115         * config/sh/predicates.md (t_reg_operand): Check REG_P for SUBREG.
5116         * config/sh/sh.c (sequence_insn_p): Check INSNP_P for SEQUENCE.
5117
5118 2012-09-14  Jakub Jelinek  <jakub@redhat.com>
5119
5120         PR target/54564
5121         * config/i386/sse.md (fmai_vmfmadd_<mode>): Use (match_dup 1)
5122         instead of (match_dup 0) as second argument to vec_merge.
5123         (*fmai_fmadd_<mode>, *fmai_fmsub_<mode>): Likewise.
5124         Remove third alternative.
5125         (*fmai_fnmadd_<mode>, *fmai_fnmsub_<mode>): Likewise.  Negate
5126         operand 2 instead of operand 1, but put it as first argument of fma.
5127         * config/i386/fmaintrin.h (_mm_fnmadd_sd, _mm_fnmadd_ss,
5128         _mm_fnmsub_sd, _mm_fnmsub_ss): Negate the second argument instead
5129         of the first.
5130
5131 2012-09-14  Richard Guenther  <rguenther@suse.de>
5132
5133         PR tree-optimization/54565
5134         * passes.c (init_optimization_passes): Adjust comments.
5135         (execute_function_todo): Do not execute execute_update_addresses_taken
5136         before processing TODO_rebuild_alias.
5137         * tree-ssa-ccp.c (do_ssa_ccp): Schedule TODO_update_address_taken.
5138
5139 2012-09-14  Richard Guenther  <rguenther@suse.de>
5140
5141         * tree-vrp.c (register_new_assert_for): Simplify for backward walk.
5142         (find_assert_locations_1): Walk the basic-block backwards, properly
5143         add/prune from live.  Use live for asserts derived from stmts.
5144
5145 2012-09-14  Marc Glisse  <marc.glisse@inria.fr>
5146
5147         * tree-ssa-forwprop.c (simplify_bitfield_ref): Call
5148         get_prop_source_stmt.
5149         (simplify_permutation): Likewise.
5150         (simplify_vector_constructor): Likewise.
5151
5152 2012-09-14  Richard Guenther  <rguenther@suse.de>
5153
5154         * builtin-types.def (BT_FN_CONST_STRING): Add.
5155         * builtins.def (BUILT_IN_FILE, BUILT_IN_FUNCTION,
5156         BUILT_IN_LINE): New builtins.
5157         * gimplify.c (gimplify_call_expr): Expand them.
5158         * doc/extend.texi (__builtin_LINE, __builtin_FUNCTION,
5159         __builtin_FILE): Document.
5160
5161 2012-09-13  Anthony Green  <green@moxielogic.com>
5162
5163         * config/moxie/moxie.h (LINK_SPEC): Add bi-endian support.
5164         (MULTILIB_DEFAULTS): Define.
5165         (ASM_SPEC): Define.
5166         (BYTES_BIG_ENDIAN, WORDS_BIG_ENDIAN): Add bi-endian support.
5167         (TARGET_CPU_CPP_BUILTINS): Add __MOXIE_LITTLE_ENDIAN__ and
5168         __MOXIE_BIG_ENDIAN__.
5169         * config/moxie/t-moxie (MULTILIB_DIRNAMES, MULTILIB_OPTIONS): Define.
5170         * config/moxie/moxie.opt: New file.
5171         * doc/invoke.texi (Moxie Options): Add section documenting -mel
5172         and -meb.
5173
5174 2012-09-13  Paolo Carlini  <paolo.carlini@oracle.com>
5175             Manuel López-Ibáñez  <manu@gcc.gnu.org>
5176
5177         PR c++/53210
5178         * doc/invoke.texi ([Winit-self]): Document as enabled by -Wall in C++.
5179
5180 2012-09-13  Eric Botcazou  <ebotcazou@adacore.com>
5181
5182         * config/sparc/predicates.md (input_operand): Do not consider TImode
5183         constants as 1-instruction integer constants.
5184         Use register_or_zero_operand instead of register_operand and tidy up.
5185         * config/sparc/sparc.md (movti): New expander.
5186         (movti_insn_sp64): New instruction.
5187         (movti_insn_sp64_hq): Likewise.
5188         (TImode splitters): New splitters.
5189         * config/sparc/sparc.c (sparc_expand_move) <TImode>: New case.
5190         (sparc_legitimate_address_p): Return 0 for REG+REG in TImode.
5191
5192         * config/sparc/sparc-protos.h (arith_double_4096_operand): Delete.
5193         (arith_4096_operand): Likewise.
5194         (zero_operand): Likewise.
5195         (fp_zero_operand): Likewise.
5196         (reg_or_0_operand): Likewise.
5197
5198 2012-09-13  Jakub Jelinek  <jakub@redhat.com>
5199
5200         * configure.ac (CXXFLAGS): Remove -O2 when not bootstrapping.
5201         * configure: Regenerated.
5202
5203 2012-08-13  Uros Bizjak  <ubizjak@gmail.com>
5204
5205         * config/i386/i386.md (prefetch): Do not assert mode of operand 0.
5206         (*prefetch_sse_<mode>): Do not set mode of address_operand predicate.
5207         Rename to ...
5208         (*prefetch_sse): ... this.
5209         (*prefetch_3dnow_<mode>): Do not set mode of address_operand predicate.
5210         Rename to ...
5211         (*prefetch_3dnow): ... this.
5212
5213 2012-09-13  Steven Bosscher  <steven@gcc.gnu.org>
5214
5215         * ipa-pure-const.c (state_from_flags, local_pure_const): Use
5216         current_function_name instead of lang_hooks.decl_printable_name.
5217
5218         * function.h (fndecl_name): New prototype.
5219         * function.c (fndecl_name): New function.
5220         * vecir.h (cgraph_node_p): New standard IR VEC type.
5221         * trans-mem.c (cgraph_node_p): No need anymore to define it here.
5222         * ipa-utils.h (ipa_get_nodes_in_cycle): New prototype.
5223         * ipa-utils.c (ipa_get_nodes_in_cycle): New function.
5224         * ipa-reference.c: Don't include langhooks.h, and certainly not twice.
5225         Fix many formatting issues (long lines, short lines, spacing, etc.).
5226         (get_static_name): Use fndecl_name.
5227         (dump_static_vars_set_to_file): New function split out from propagate.
5228         (union_static_var_sets): New function, union two sets and collapse
5229         to all_module_statics as quickly as possible.
5230         (intersect_static_var_sets): New function, similar to above.
5231         (copy_static_var_set): Renamed from copy_global_bitmap and rewritten
5232         to allocate a copy on the same bitmap_obstack as the source set.
5233         (propagate_bits): Simplify, and clarify by using union_static_var_sets.
5234         (generate_summary): Remove bm_temp.  Print UID of promotable globals.
5235         (read_write_all_from_decl): Use pass-by-reference, bless C++.
5236         (get_read_write_all_from_node): New function, split out from propagate.
5237         (propagate): Simplify and clarify with helper functions.  Use
5238         ipa_get_nodes_in_cycle to walk all nodes in a reduced node.
5239         (ipa_reference_read_optimization_summary): Use fndecl_name instead of
5240         lang_hooks.decl_printable_name.
5241
5242         * rtl.h (print_rtl_single_with_indent): New prototype.
5243         * print-rtl.c (print_rtl_single_with_indent): New function.
5244         * cfghooks.h (empty_block_p, split_block_before_cond_jump): New hooks.
5245         * cfghooks.c (empty_block_p, split_block_before_cond_jump): Implement.
5246         * cfgrtl.c (rtl_block_empty_p, rtl_split_block_before_cond_jump):
5247         Implement RTL specific hooks.
5248         (rtl_cfg_hooks, cfg_layout_rtl_cfg_hooks): Register the new hooks.
5249         * tree-cfg.c (gimple_empty_block_p,
5250         gimple_split_block_before_cond_jump): Implement GIMPLE specific hooks.
5251         (gimple_cfg_hooks): Register the new hooks.
5252         * tree-ssa-phiopt.c (empty_block_p): Remove in favor of new hook.
5253
5254 2012-09-13  Richard Guenther  <rguenther@suse.de>
5255
5256         * tree-ssa-sccvn.h (enum vn_kind): New.
5257         (vn_get_stmt_kind): Likewise.
5258         * tree-ssa-sccvn.c (vn_get_stmt_kind): New function, adjust
5259         ADDR_EXPR handling.
5260         (visit_use): Use it.
5261         * tree-ssa-pre.c (compute_avail): Likewise, simplify further.
5262
5263 2012-09-13  Venkataramanan Kumar  <venkataramanan.kumar@amd.com>
5264
5265         * config/i386/i386.c (processor_alias_table): Enable PTA_PRFCHW
5266         for targets bdver1, bdver2, btver1 and btver2.
5267
5268 2012-09-13  Christophe Lyon  <christophe.lyon@linaro.org>
5269             Richard Earnshaw  <rearnsha@arm.com>
5270
5271         * config/arm/arm.md (arm_rev): Factorize thumb1, thumb2 and arm
5272         variants for rev instruction..
5273         (thumb1_rev): Delete pattern.
5274         (arm_revsh): New pattern to support builtin_bswap16.
5275         (arm_rev16, bswaphi2): Likewise.
5276
5277 2012-09-12  Teresa Johnson  <tejohnson@google.com>
5278
5279         PR gcov-profile/54487
5280         * configure.ac (HOST_HAS_F_SETLKW): Set based on compile
5281         test using F_SETLKW with fcntl.
5282         * configure, config.in: Regenerate.
5283
5284 2012-09-12  Jan Hubicka  <jh@suse.cz>
5285
5286         PR fortran/48636
5287         * ipa-inline-analysis.c (dump_inline_hints): Dump loop stride.
5288         (set_hint_predicate): New function.
5289         (reset_inline_summary): Reset loop stride.
5290         (remap_predicate_after_duplication): New function.
5291         (remap_hint_predicate_after_duplication): New function.
5292         (inline_node_duplication_hook): Update.
5293         (dump_inline_summary): Dump stride summaries.
5294         (estimate_function_body_sizes): Compute strides.
5295         (remap_hint_predicate): New function.
5296         (inline_merge_summary): Use it.
5297         (inline_read_section): Read stride.
5298         (inline_write_summary): Write stride.
5299         * ipa-inline.c (want_inline_small_function_p): Handle strides.
5300         (edge_badness): Likewise.
5301         * ipa-inline.h (inline_hints_vals): Add stride hint.
5302         (inline_summary): Update stride.
5303
5304 2012-09-12  Uros Bizjak  <ubizjak@gmail.com>
5305
5306         * config/i386/i386.c (x86_prefetch_sse): Change to unsigned char.
5307         * config/i386/i386.h (x86_prefetch_sse): Ditto.
5308
5309 2012-09-12  H.J. Lu  <hongjiu.lu@intel.com>
5310
5311         PR target/54445
5312         * config/i386/predicates.md (x86_64_immediate_operand): Allow
5313         negative offset for UNSPEC_DTPOFF/UNSPEC_NTPOFF.
5314
5315 2012-09-12  Jan Hubicka  <jh@suse.cz>
5316
5317         * common.opt (flto-partition): Add "max".
5318         * invoke.texi (flto-partition): Document "max"
5319
5320 2012-09-12  Ganesh Gopalasubramanian  <Ganesh.Gopalasubramanian@amd.com>
5321
5322         * config/i386/i386.md : Comments on fma4 instruction selection
5323         reflect requirement on register pressure based cost model.
5324
5325         * config/i386/driver-i386.c (host_detect_local_cpu): fma4
5326         flag is set-reset as informed by the cpuid flag.
5327
5328         * config/i386/i386.c (processor_alias_table): fma4
5329         flag is enabled for bdver2.
5330
5331 2012-09-12  Richard Guenther  <rguenther@suse.de>
5332
5333         PR tree-optimization/54489
5334         * tree-ssa-pre.c: Include domwalk.h.
5335         (in_fre): Remove.
5336         (sccvn_valnum_from_value_id): New function.
5337         (debug_bitmap_sets_for): Simplify.
5338         (get_representative_for): Properly initialize the SCCVN valnum.
5339         (create_expression_by_pieces): Likewise.
5340         (insert_into_preds_of_block): Likewise.
5341         (can_PRE_operation): Remove.
5342         (make_values_for_phi): Simplify.
5343         (compute_avail): Likewise.
5344         (do_SCCVN_insertion): Remove.
5345         (eliminate_avail, eliminate_push_avail, eliminate_insert):
5346         New functions.
5347         (eliminate): Split and perform a domwalk.
5348         (eliminate_bb): Former eliminate part that is now dom-enter.
5349         (eliminate_leave_block): New function.
5350         (fini_eliminate): Likewise.
5351         (init_pre): Simplify.
5352         (fini_pre): Likewise.
5353         (execute_pre): Fold into do_pre and do_fre.
5354         (do_pre): Consume execute_pre.
5355         (do_fre): Likewise.
5356         * Makefile.in (tree-ssa-pre.o): Add domwalk.h dependency.
5357
5358 2012-09-12  Diego Novillo  <dnovillo@google.com>
5359
5360         * vec.h: Remove compatibility notes for previous distinction
5361         between vectors of objects and vectors of pointers.
5362
5363 2012-09-12  Christian Bruel  <christian.bruel@st.com>
5364
5365         * config/sh/newlib.h (NO_IMPLICIT_EXTERN_C): Define.
5366
5367 2012-09-12  Rainer Orth  <ro@CeBiTec.Uni-Bielefeld.DE>
5368
5369         * rtl.h (FFS, FLOAT, ABS, PC): Don't undef.
5370         * system.h (FFS, FLOAT, ABS, PC): Undef.
5371
5372 2012-09-12  Richard Guenther  <rguenther@suse.de>
5373
5374         PR middle-end/54553
5375         * common.opt (finline): Mark with Optimization.
5376
5377 2012-09-12  Jakub Jelinek  <jakub@redhat.com>
5378
5379         * config.gcc: Obsolete picochip-*.
5380
5381 2012-09-12  Nathan Froyd  <froydnj@gcc.gnu.org>
5382             Hans-Peter Nilsson  <hp@bitrange.com>
5383
5384         * config/mmix/mmix.h (MMIX_REG_OK_STRICT): Delete.
5385         (REG_CLASS_FROM_LETTER, CONST_OK_FOR_LETTER_P): Delete.
5386         (CONST_DOUBLE_OK_FOR_LETTER_P, EXTRA_CONSTRAINT): Delete.
5387         * config/mmix/mmix-protos.h (mmix_intval): Declare.
5388         (mmix_const_ok_for_letter_p, mmix_extra_constraint): Delete.
5389         (mmix_const_double_ok_for_letter_p): Delete.
5390         * config/mmix/constraints.md: New file.
5391         * config/mmix/mmix.md: Include it.
5392         (iordi3): Fix typo; use "I" instead of undefined "H" constraint.
5393         ("*call_real"): Update comment about not using the "p" constraint.
5394         * config/mmix/predicates.md (mmix_reg_or_8bit_operand): Use
5395         satisfies_constraint_I.
5396         (mmix_address_operand): New predicate.
5397         (mmix_symbolic_or_address_operand): Use it instead of address_operand.
5398         * config/mmix/mmix.c: #include tm-constrs.h.
5399         (mmix_intval): Delete declaration.  Make non-static.
5400         (mmix_const_ok_for_letter_p, mmix_extra_constraint): Delete.
5401         (mmix_const_double_ok_for_letter_p): Delete.
5402         (mmix_legitimate_address_p): Use satisfies_constraint_I.
5403         (mmix_print_operand_address): Likewise.
5404         (mmix_emit_sp_add): Adjust to use insn_const_int_ok_for_constraint
5405         when matching "L" constraint.
5406
5407 2012-09-11  Steven Bosscher  <steven@gcc.gnu.org>
5408
5409         * tree.h (expand_case): Move prototype ...
5410         * expr.h (expand_case): ...here.
5411         (expand_sjlj_dispatch_table): New prototype.
5412         * stmt.c: Include pointer-set.h instead of bitmap.h.
5413         (expand_case): Use a pointer set instead of a bitmap for
5414         already-seen labels.  Fold label values here.
5415         (add_case_node): Don't fold label values here.
5416         (expand_sjlj_dispatch_table): New function.
5417         * except.c (sjlj_emit_dispatch_table): Use it.
5418
5419 2012-09-11  Marc Glisse  <marc.glisse@inria.fr>
5420
5421         * tree-ssa-forwprop.c (simplify_vector_constructor): New function.
5422         (ssa_forward_propagate_and_combine): Call it.
5423
5424 2012-09-11  Diego Novillo  <dnovillo@google.com>
5425
5426         * var-tracking.c (vt_add_function_parameter): Adjust for VEC changes.
5427
5428 2012-09-11  Dominique Dhumieres  <dominiq@lps.ens.fr>
5429
5430         * config/darwin.c (darwin_asm_named_section): Adjust for VEC changes.
5431         (darwin_asm_dwarf_section): Likewise.
5432
5433 2012-09-11  Martin Jambor  <mjambor@suse.cz>
5434
5435         * dwarf2out.c (dwarf2out_abstract_function): Do not change cfun.
5436         (premark_used_types): New parameter fun, use it instead of cfun.
5437         (gen_subprogram_die): Use DECL_STRUCT_FUNCTION (decl) instead of cfun,
5438         also pass it to premark_used_types.
5439
5440 2012-09-11  Ramana Radhakrishnan  <ramana.radhakrishnan@arm.com>
5441
5442         * doc/sourcebuild.texi (arm_neon_v2_ok): Adjust command line.
5443
5444 2012-09-11  Tobias Burnus  <burnus@net-b.de>
5445
5446         * doc/sourcebuild.texi (arm_neon_v2_ok): Fix @anchor.
5447
5448 2012-09-11  Ramana Radhakrishnan  <ramana.radhakrishnan@arm.com>
5449             Matthew Gretton-Dann  <matthew.gretton-dann@arm.com>
5450
5451         * config/arm/neon.md (fma<VCVTF:mode>4): New pattern.
5452         (*fmsub<VCVTF:mode>4): Likewise.
5453         * doc/sourcebuild.texi (arm_neon_v2_ok, arm_neon_v2_hw):  Document it.
5454
5455 2012-09-11  Aldy Hernandez  <aldyh@redhat.com>
5456
5457         PR middle-end/54149
5458         * tree-ssa-loop-im.c (execute_sm_if_changed_flag_set): Only set
5459         flag for writes.
5460
5461 2012-09-11  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
5462
5463         PR tree-optimization/55492
5464         * doc/invoke.texi (max-slsr-cand-scan): New description.
5465         * gimple-ssa-strength-reduction.c (find_basis_for_candidate): Limit
5466         the time spent searching for a basis.
5467         * params.def (PARAM_MAX_SLSR_CANDIDATE_SCAN): New param.
5468
5469 2012-09-11  Richard Guenther  <rguenther@suse.de>
5470
5471         * gimple.h (gimple_register_type): Remove.
5472         (print_gimple_types_stats): Adjust prototype.
5473         * lto-streamer.h (print_lto_report): Likewise.
5474         * lto-streamer.c (print_lto_report): Adjust.
5475         * gimple.c (gimple_types, type_hash_cache, enum gtc_mode,
5476         struct type_pair_d, lookup_type_pair, struct sccs,
5477         next_dfs_num, gtc_next_dfs_num, struct gimple_type_leader_entry_s,
5478         gimple_type_leader, gimple_lookup_type_leader, compare_type_names_p,
5479         gtc_visit, gimple_types_compatible_p_1, gimple_types_compatible_p,
5480         visit, iterative_hash_name, struct type_hash_pair,
5481         type_hash_pair_compare, iterative_hash_gimple_type, gimple_type_hash,
5482         gimple_type_eq, gimple_register_type_1, gimple_register_type):
5483         Move to lto/lto.c.
5484         (print_gimple_types_stats): Adjust.
5485         (free_gimple_type_tables): Likewise.
5486
5487 2012-09-11  Richard Guenther  <rguenther@suse.de>
5488
5489         * graphite-scop-detection.c (move_sd_regions): Adjust for VEC changes.
5490         (scopdet_basic_block_info): Likewise.
5491         (build_scops_1): Likewise.
5492         (limit_scops): Likewise.
5493
5494 2012-09-11  Richard Guenther  <rguenther@suse.de>
5495
5496         PR middle-end/54515
5497         * gimple.c (get_base_address): Do not return NULL_TREE apart
5498         from for WITH_SIZE_EXPR.
5499         * gimple-fold.c (canonicalize_constructor_val): Do not call
5500         get_base_address when not necessary.
5501
5502 2012-09-10  Andrew Pinski  <apinski@cavium.com>
5503
5504         PR tree-opt/54362
5505         * trans-mem.c (thread_private_new_memory): Handle COND_EXPR also.
5506
5507 2012-09-10  Maxim Kuvyrkov  <maxim@codesourcery.com>
5508
5509         * config/m68k/m68k.c (m68k_sched_dfa_post_advance_cycle): Support
5510         starting scheduling from a pre-existing state.
5511
5512 2012-09-10  Diego Novillo  <dnovillo@google.com>
5513
5514         * vec.h (vec_t::quick_push): Remove overload that accepts 'T *'.
5515         Update all users.
5516         (vec_t::safe_push): Likewise.
5517         (vec_t::quick_insert): Likewise.
5518         (vec_t::lower_bound): Likewise.
5519         (vec_t::safe_insert): Likewise.
5520         (vec_t::replace): Change second argument to 'T &'.
5521
5522 2012-09-10  Maciej W. Rozycki  <macro@codesourcery.com>
5523
5524         * config/rs6000/rs6000.md: Move a splitter next to its insn.
5525
5526 2012-09-10  Oleg Endo  <olegendo@gcc.gnu.org>
5527
5528         PR target/54089
5529         * config/sh/sh.h (SH_DYNAMIC_SHIFT_COST): Set always to 1 if
5530         dynamic shifts are available.
5531         (SHIFT_COUNT_TRUNCATED): Always define to 0.  Correct comment.
5532         * config/sh/sh.c (ashl_lshr_seq, ext_ashl_lshr_seq): Add comments.
5533         * config/sh/predicates.md (shift_count_operand): Allow
5534         arith_reg_operand even if TARGET_DYNSHIFT is false.
5535         * config/sh/sh.md (ashlsi3, lshrsi3): Expand library call patterns
5536         if needed.
5537         (ashlsi3_d_call, lshrsi3_d_call): New insns.
5538
5539 2012-09-10  Richard Sandiford  <rdsandiford@googlemail.com>
5540
5541         * ira.c (setup_pressure_classes): Handle synonymous classes.
5542
5543 2012-09-10  Marc Glisse  <marc.glisse@inria.fr>
5544
5545         * tree-ssa-forwprop.c (simplify_bitfield_ref): New function.
5546         (ssa_forward_propagate_and_combine): Call it.
5547
5548 2012-09-10  Steve Ellcey  <sellcey@mips.com>
5549
5550         * config.gcc: Add mips*-mti-linux* target
5551         Handle with_synci like other options.
5552         * config/mips/gnu-user64.h (LINUX64_DRIVER_SELF_SPECS): New.
5553         (DRIVER_SELF_SPECS): Define in terms of LINUX64_DRIVER_SELF_SPECS.
5554         * config/mips/mips.h (MIPS_ISA_SYNCI_SPEC): New.
5555         * config/mips/mti-linux.h: New file.
5556         * config/mips/t-mti-linux: New file.
5557
5558 2012-09-10  Marc Glisse  <marc.glisse@inria.fr>
5559
5560         * tree-ssa-forwprop.c (simplify_permutation): Handle CONSTRUCTOR.
5561
5562 2012-09-10  Martin Jambor  <mjambor@suse.cz>
5563
5564         * params.def (PARAM_IPA_MAX_AGG_ITEMS): New parameter.
5565         * ipa-prop.c: Include params.h.
5566         (IPA_MAX_AFF_JF_ITEMS): Removed.
5567         (determine_known_aggregate_parts): Use param value of
5568         PARAM_IPA_MAX_AGG_ITEMS instead of IPA_MAX_AFF_JF_ITEMS.
5569         * Makefile.in (ipa-prop.o): Add PARAMS_H dependency.
5570
5571 2012-09-10  Richard Guenther  <rguenther@suse.de>
5572
5573         PR tree-optimization/54520
5574         * tree-ssa-threadupdate.c (def_split_header_continue_p):
5575         Properly consider sub-loops.
5576
5577 2012-09-10  Richard Henderson  <rth@redhat.com>
5578
5579         * config/alpha/predicates.md (small_symbolic_operand): Disallow
5580         large offsets.
5581
5582 2012-09-10  Georg-Johann Lay  <avr@gjlay.de>
5583
5584         PR target/54536
5585         * config/avr/avr-mcus.def (at90usb1287): Set LIBRARY_NAME to "usb1287".
5586
5587 2012-09-10  Jan Hubicka  <jh@suse.cz>
5588
5589         * lto-cgraph.c (compute_ltrans_boundary): Do not care about aliases.
5590         * symtab.c (symtab_make_decl_local): Remove user defined visibility
5591         when making symbol local.
5592
5593 2012-09-09  Mark Kettenis  <kettenis@gnu.org>
5594
5595         * config/openbsd-stdint.h (INTMAX_TYPE, UINTMAX_TYPE): Define.
5596
5597 2012-09-09  Jan Hubicka  <jh@suse.cz>
5598
5599         * passes.c (ipa_write_summaries_1): Set state;
5600         do not call compute_ltrans_boundary.
5601         (ipa_write_optimization_summaries): Likewise.
5602         (ipa_write_summaries): compute_ltrans_boundary here.
5603         * lto-streamer.h (lto_symtab_encoder_d): NODES are allocated in heap.
5604         (compute_ltrans_boundary): Update prototype.
5605
5606 2012-09-09  Ulrich Drepper  <drepper@gmail.com>
5607
5608         * config/i386/cpuid.h: Define signature_*_e[bcd]x macros for
5609         matching results of level 0 calls to __cpuid to processor
5610         manufacturers.
5611         * config/i386/driver-i386.c (vendor_signatures): Removed.
5612         (processor_signatures): Removed.
5613         (host_detect_local_cpu): Replace uses of now-removed SIG_*
5614         constants with the new signature_*_ebx constants.
5615
5616 2012-09-08  Jan Hubicka  <jh@suse.cz>
5617
5618         Replace cgraph_node_set and varpool_node_set by symtab_node_encoder
5619         in partitioning.
5620         * tree-pass.h (cgraph_node_set_def, varpool_node_set_def): Remove
5621         forward declaration.
5622         (lto_symtab_encoder_d): Forward declare.
5623         (ipa_write_optimization_summaries): Update.
5624         * lto-cgraph.c (lto_symtab_encoder_new): Do not initialize
5625         body, initializer and in_partition.
5626         (lto_symtab_encoder_delete): Update.
5627         (lto_symtab_encoder_encode): Update.
5628         (lto_symtab_encoder_lookup): Move inline.
5629         (lto_symtab_encoder_delete_node): New function.
5630         (lto_symtab_encoder_encode_body_p, lto_set_symtab_encoder_encode_body,
5631         lto_symtab_encoder_encode_initializer_p,
5632         lto_set_symtab_encoder_encode_initializer,
5633         lto_symtab_encoder_in_partition_p,
5634         lto_symtab_encoder_in_partition_p): Update.
5635         (compute_ltrans_boundary): Take encoder as an input.
5636         * passes.c (ipa_write_summaries_1): Update.
5637         (ipa_write_summaries_1): Update.
5638         (ipa_write_summaries): Update.
5639         (ipa_write_optimization_summaries): Update.
5640         * lto-streamer.c (print_lto_report): Report number of cgraph nodes.
5641         * lto-streamer.h (lto_stats_d): Replace num_output_cgraph_nodes by
5642         num_output_symtab_nodes.
5643         (lto_encoder_entry): New structure.
5644         (struct lto_symtab_encoder_d): Reorg.
5645         (lto_symtab_encoder_delete_node): Declare.
5646         (lto_symtab_encoder_lookup): Bring inline.
5647         (compute_ltrans_boundary): Update.
5648         (lto_symtab_encoder_size): Update.
5649         (lsei_node, lsei_cgraph_node, lsei_varpool_node): Update.
5650         (lto_symtab_encoder_deref): Update.
5651
5652 2012-09-08  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
5653
5654         * config/pa/pa.c (hppa_rtx_costs): Update costs for large
5655         integer modes.
5656
5657 2012-09-08  Andi Kleen  <ak@linux.intel.com>
5658
5659         * gcc/lto/lto.c (do_whole_program_analysis): Fix last broken patch.
5660
5661 2012-09-08  Andi Kleen  <ak@linux.intel.com>
5662
5663         * gcc/common.opt (-fmem-report-wpa): Add
5664         * gcc/doc/invoke.texi (-fmem-report-wpa): Document.
5665         * gcc/lto/lto.c (do_whole_program_analysis): Run mem_report
5666         when mem_report_wpa is set.
5667
5668 2012-09-07  Anthony Green  <green@moxielogic.com>
5669
5670         * config/moxie/moxie.c (moxie_expand_prologue): Optimize prologue
5671         for functions with large static stack requirements.
5672         (moxie_expand_epilogue): Use $r12 instead of $r5 for pulling saved
5673         values off of the stack.
5674
5675 2012-09-07  Nick Clifton  <nickc@redhat.com>
5676
5677         * config/v850/v850.h (DBX_DEBUGGING_INFO): Define.
5678         (ASM_GENERATE_INTERNAL_LABEL): Define if not already provided.
5679         * config/v850/v850.c (compute_register_save_size): Always include
5680         the link pointer.
5681         (increment_stack): New function - emits insns to increment or
5682         decrement the stack pointer.
5683         (expand_prologue, expand_epilogue): Use it.
5684         (expand_prologue): Set the function stack size, if requested.
5685         (v850_debug_unwind_info): New function.
5686         (TARGET_DEBUG_UNWIND_INFO): Define.
5687
5688 2012-09-07  Richard Earnshaw  <rearnsha@arm.com>
5689
5690         PR tree-ssa/54295
5691         * tree-ssa-math-opts.c (widening_mult_conversion_strippable_p):
5692         Sign-extension of a zero-extended value can be simplified to
5693         just zero-extension.
5694
5695 2012-09-07  Richard Guenther  <rguenther@suse.de>
5696
5697         PR middle-end/53667
5698         * tree-ssa-structalias.c (handle_rhs_call): Properly clobber
5699         EAF_NOESCAPED arguments.  Transitively close non-EAF_DIRECT
5700         arguments separately.
5701
5702 2012-09-07  Steven Bosscher  <steven@gcc.gnu.org>
5703
5704         * bitmap.c (bitmap_last_set_bit): Rewrite to return the correct bit.
5705
5706         * graphite.c (print_global_statistics): Use EDGE_COUNT instead
5707         of VEC_length.
5708         (print_graphite_scop_statistics): Likewise.
5709         * graphite-scop-detection.c (get_bb_type): Use single_succ_p.
5710         (print_graphite_scop_statistics): Use EDGE_COUNT, not VEC_length.
5711         (canonicalize_loop_closed_ssa): Use single_pred_p.
5712
5713         * alias.c (reg_seen): Make this an sbitmap.
5714         (record_set, init_alias_analysis): Update.
5715
5716         * tree-ssa-coalesce.c (ssa_conflicts_dump): Fix dumping.
5717
5718 2012-09-07  Tom de Vries  <tom@codesourcery.com>
5719
5720         PR tree-optimization/53986
5721         * tree-vrp.c (extract_range_from_multiplicative_op_1): Allow
5722         LSHIFT_EXPR.
5723         (extract_range_from_binary_expr_1): Handle LSHIFT with constant
5724         range as shift amount.
5725
5726 2012-09-07  Segher Boessenkool  <segher@kernel.crashing.org>
5727
5728         * config/rs6000/aix43.h (RS6000_CALL_GLUE): Delete.
5729         * config/rs6000/aix51.h (RS6000_CALL_GLUE): Delete.
5730         * config/rs6000/aix52.h (RS6000_CALL_GLUE): Delete.
5731         * config/rs6000/aix53.h (RS6000_CALL_GLUE): Delete.
5732         * config/rs6000/aix61.h (RS6000_CALL_GLUE): Delete.
5733         * config/rs6000/freebsd64.h (RS6000_CALL_GLUE): Delete.
5734         * config/rs6000/linux64.h (RS6000_CALL_GLUE): Delete.
5735         * config/rs6000/rs6000.c (print_operand) ['.']: Delete.
5736         * config/rs6000/rs6000.h (RS6000_CALL_GLUE): Delete.
5737         * config/rs6000/rs6000.md (tls_gd_aix<TLSmode:tls_abi_suffix>):
5738         Replace %. with nop.
5739         (tls_gd_call_aix<TLSmode:tls_abi_suffix>): Ditto.
5740         (tls_ld_aix<TLSmode:tls_abi_suffix>): Ditto.
5741         (tls_ld_call_aix<TLSmode:tls_abi_suffix>): Ditto.
5742         (call_nonlocal_aix32): Ditto.
5743         (call_nonlocal_aix64): Ditto.
5744         (call_value_nonlocal_aix32): Ditto.
5745         (call_value_nonlocal_aix64): Ditto.
5746
5747 2012-09-06  Andi Kleen  <ak@linux.intel.com>
5748
5749         * doc/invoke.texi (-ffat-lto-objects): Clarify that gcc-ar
5750         et.al. should be used.
5751
5752 2012-09-06  Andi Kleen  <ak@linux.intel.com>
5753
5754         * gcc/lto-streamer.h (res_pair): Add.
5755         (lto_file_decl_data): Replace resolutions with respairs.
5756         Add max_index.
5757         * gcc/lto/lto.c (lto_resolution_read): Remove max_index.  Add rp.
5758         Initialize respairs.
5759         (lto_file_finalize): Set up resolutions vector lazily from respairs.
5760
5761 2012-09-06  Lawrence Crowl  <crowl@google.com>
5762
5763         * double-int.h (double_int::operator &=): New.
5764         (double_int::operator ^=): New.
5765         (double_int::operator |=): New.
5766         (double_int::mul_with_sign): Modify overflow parameter to bool*.
5767         (double_int::add_with_sign): New.
5768         (double_int::ule): New.
5769         (double_int::sle): New.
5770         (binary double_int::operator *): Remove parameter name.
5771         (binary double_int::operator +): Likewise.
5772         (binary double_int::operator -): Likewise.
5773         (binary double_int::operator &): Likewise.
5774         (double_int::operator |): Likewise.
5775         (double_int::operator ^): Likewise.
5776         (double_int::and_not): Likewise.
5777         (double_int::from_shwi): Tidy formatting.
5778         (double_int::from_uhwi): Likewise.
5779         (double_int::from_uhwi): Likewise.
5780         * double-int.c (double_int::mul_with_sign): Modify overflow parameter
5781         to bool*.
5782         (double_int::add_with_sign): New.
5783         (double_int::ule): New.
5784         (double_int::sle): New.
5785         * builtins.c: Modify to use the new double_int interface.
5786         * cgraph.c: Likewise.
5787         * combine.c: Likewise.
5788         * dwarf2out.c: Likewise.
5789         * emit-rtl.c: Likewise.
5790         * expmed.c: Likewise.
5791         * expr.c: Likewise.
5792         * fixed-value.c: Likewise.
5793         * fold-const.c: Likewise.
5794         * gimple-fold.c: Likewise.
5795         * gimple-ssa-strength-reduction.c: Likewise.
5796         * gimplify-rtx.c: Likewise.
5797         * ipa-prop.c: Likewise.
5798         * loop-iv.c: Likewise.
5799         * optabs.c: Likewise.
5800         * stor-layout.c: Likewise.
5801         * tree-affine.c: Likewise.
5802         * tree-cfg.c: Likewise.
5803         * tree-dfa.c: Likewise.
5804         * tree-flow-inline.h: Likewise.
5805         * tree-object-size.c: Likewise.
5806         * tree-predcom.c: Likewise.
5807         * tree-pretty-print.c: Likewise.
5808         * tree-sra.c: Likewise.
5809         * tree-ssa-address.c: Likewise.
5810         * tree-ssa-alias.c: Likewise.
5811         * tree-ssa-ccp.c: Likewise.
5812         * tree-ssa-forwprop.c: Likewise.
5813         * tree-ssa-loop-ivopts.c: Likewise.
5814         * tree-ssa-loop-niter.c: Likewise.
5815         * tree-ssa-phiopt.c: Likewise.
5816         * tree-ssa-pre.c: Likewise.
5817         * tree-ssa-sccvn: Likewise.
5818         * tree-ssa-structalias.c: Likewise.
5819         * tree-ssa.c: Likewise.
5820         * tree-switch-conversion.c: Likewise.
5821         * tree-vect-loop-manip.c: Likewise.
5822         * tree-vrp.c: Likewise.
5823         * tree.h: Likewise.
5824         * tree.c: Likewise.
5825         * varasm.c: Likewise.
5826
5827 2012-09-06  Uros Bizjak  <ubizjak@gmail.com>
5828
5829         * configure.ac (hle prefixes): Remove .code64 directive.
5830         * configure: Regenerated.
5831
5832 2012-09-06  Kyrylo Tkachov  <kyrylo.tkachov@arm.com>
5833
5834         * config/arm/arm.c: Use CONST_INT_P, CONST_DOUBLE_P, REG_P, MEM_P,
5835         LABEL_P, JUMP_P, CALL_P, NOTE_P, BARRIER_P consistently.
5836         * config/arm/arm.h: Use REG_P, MEM_P consistently.
5837         * config/arm/arm.md: Use CONST_INT_P, REG_P, MEM_P, CONST_DOUBLE_P
5838         consistently.
5839         * config/arm/neon.md: Use REG_P consistently.
5840         * config/arm/predicates.md: Use CONST_INT_P, REG_P, MEM_P consistently.
5841         * config/arm/thumb2.md: Use CONST_INT_P, REG_P consistently.
5842         * config/arm/vec-common.md: Use REG_P consistently.
5843
5844 2012-09-06  Richard Guenther  <rguenther@suse.de>
5845
5846         PR tree-optimization/54498
5847         * tree-ssa-alias.h (get_continuation_for_phi): Add flag to
5848         abort when reaching an already visited region.
5849         * tree-ssa-alias.c (maybe_skip_until): Likewise.  And do it.
5850         (get_continuation_for_phi_1): Likewise.
5851         (walk_non_aliased_vuses): When we translated the reference,
5852         abort when we re-visit a region.
5853         * tree-ssa-pre.c (translate_vuse_through_block): Adjust.
5854
5855 2012-09-06  David Edelsohn  <dje.gcc@gmail.com>
5856
5857         * config/rs6000/rs6000.c (rs6000_xcoff_asm_named_section): Add TLS
5858         section.
5859         * config/rs6000/rs6000.c (rs6000_debug_address_cost): Add new
5860         arguments to TARGET_ADDRESS_COST call.
5861
5862 2012-09-06  Richard Guenther  <rguenther@suse.de>
5863
5864         * tree.h (MOVE_NONTEMPORAL): Remove.
5865         * tree-pretty-print.c (dump_generic_node): Remove
5866         MOVE_NONTEMPORAL handling.
5867         * expr.c (expand_expr_real_1): Likewise.
5868
5869 2012-09-06  Richard Guenther  <rguenther@suse.de>
5870
5871         * passes.c (execute_function_todo): Call compute_may_aliases
5872         only if flag_tree_pta is set.
5873
5874 2012-09-06  Andrew Pinski  <apinski@cavium.com>
5875
5876         PR tree-opt/54494
5877         * tree-inline.c (remap_gimple_op_r): Copy TREE_SIDE_EFFECTS also.
5878
5879 2012-09-06  Jakub Jelinek  <jakub@redhat.com>
5880
5881         PR rtl-optimization/54455
5882         * sel-sched-ir.c (maybe_tidy_empty_bb): Give up if previous fallthru
5883         bb ends up with asm goto referencing bb's label.
5884
5885 2012-09-06  Chen Liqin  <liqin.gcc@gmail.com>
5886
5887         * config/score/score.c: Remove TARGET_LEGITIMIZE_ADDRESS define and
5888         score_legitimize_address function, use compiler default code instead.
5889
5890 2012-09-05  Jan Hubicka  <jh@suse.cz>
5891
5892         * ipa-inline.c (want_inline_small_function_p): Use
5893         INLINE_HINT_loop_iterations hint.
5894
5895 2012-09-05  Andrew Pinski  <apinski@cavium.com>
5896
5897         * optabs.c (emit_conditional_add): Correct comment about the arguments.
5898         Remove code which might swap op2 and op3 since they cannot be swapped.
5899         * doc/md.texi (add@var{mode}cc): Fix document about how the arguments
5900         are used.
5901
5902 2012-09-05  Oleg Endo  <olegendo@gcc.gnu.org>
5903
5904         * hooks.c (hook_int_rtx_mode_as_bool_0): New function.
5905         * hooks.h (hook_int_rtx_mode_as_bool_0): Declare it.
5906         * output.h (default_address_cost): Add machine_mode and address space
5907         arguments.
5908         * target.def (address_cost): Likewise.
5909         * rtlanal.c (address_cost): Pass mode and address space to target hook.
5910         (default_address_cost): Add unnamed machine_mode and address space
5911         arguments.
5912         * doc/tm.texi: Regenerate.
5913         * config/alpha/alpha.c (TARGET_ADDRESS_COST): Use
5914         hook_int_rtx_mode_as_bool_0 instead of hook_int_rtx_bool_0.
5915         * config/arm/arm.c (arm_address_cost): Add machine_mode and address
5916         space arguments.
5917         * config/avr/avr.c (avr_address_cost): Likewise.
5918         * config/bfin/bfin.c (bfin_address_cost): Likewise.
5919         * config/cr16/cr16.c (cr16_address_cost): Likewise.
5920         * config/cris/cris.c (cris_address_cost): Likewise.
5921         * config/epiphany/epiphany.c (epiphany_address_cost): Likewise.
5922         * config/i386/i386.c (ix86_address_cost): Likewise.
5923         * config/ia64/ia64.c (TARGET_ADDRESS_COST): Use
5924         hook_int_rtx_mode_as_bool_0 instead of hook_int_rtx_bool_0.
5925         * config/iq2000/iq2000.c (iq2000_address_cost): Add machine_mode and
5926         address space arguments.  Pass them on in recursive invocation.
5927         * config/lm32/lm32.c (TARGET_ADDRESS_COST): Use
5928         hook_int_rtx_mode_as_bool_0 instead of hook_int_rtx_bool_0.
5929         * config/m32c/m32c.c (m32c_address_cost): Add machine_mode and address
5930         space arguments.
5931         * config/m32r/m32r.c (TARGET_ADDRESS_COST): Use
5932         hook_int_rtx_mode_as_bool_0 instead of hook_int_rtx_bool_0.
5933         * config/mcore/mcore.c (TARGET_ADDRESS_COST): Likewise.
5934         * config/mep/mep.c (mep_address_cost): Add machine_mode and address
5935         space arguments.
5936         * config/microblaze/microblaze.c (microblaze_address_cost): Likewise.
5937         * config/mips/mips.c (mips_address_cost): Likewise.
5938         * config/mmix/mmix.c (TARGET_ADDRESS_COST): Use
5939         hook_int_rtx_mode_as_bool_0 instead of hook_int_rtx_bool_0.
5940         * config/mn10300/mn10300.c (mn10300_address_cost): Add machine_mode and
5941         address space arguments.
5942         (mn10300_rtx_costs): Pass GET_MODE (x) and MEM_ADDR_SPACE (x) to
5943         mn10300_address_cost.
5944         * config/pa/pa.c (hppa_address_cost): Add machine_mode and address
5945         space arguments.
5946         * config/rs6000/rs6000.c (rs6000_debug_address_cost): Likewise.
5947         (TARGET_ADDRESS_COST): Use hook_int_rtx_mode_as_bool_0 instead of
5948         hook_int_rtx_bool_0.
5949         * config/rx/rx.c (rx_address_cost): Add machine_mode and address
5950         space arguments.
5951         * config/s390/s390.c (s390_address_cost): Likewise.
5952         * config/score/score-protos.h (score_address_cost): Likewise.
5953         * config/score/score.c (score_address_cost): Likewise.
5954         * config/sh/sh.c (sh_address_cost): Likewise.
5955         * config/sparc/sparc.c (TARGET_ADDRESS_COST): Use
5956         hook_int_rtx_mode_as_bool_0 instead of hook_int_rtx_bool_0.
5957         * config/spu/spu.c (TARGET_ADDRESS_COST): Likewise.
5958         * config/stormy16/stormy16.c (xstormy16_address_cost): Add machine_mode
5959         and address space arguments.
5960         * config/v850/v850.c (TARGET_ADDRESS_COST): Use
5961         hook_int_rtx_mode_as_bool_0 instead of hook_int_rtx_bool_0.
5962         * config/vax/vax.c (vax_address_cost): Add machine_mode and address
5963         space arguments.
5964         * config/xtensa/xtensa (TARGET_ADDRESS_COST): Use
5965         hook_int_rtx_mode_as_bool_0 instead of hook_int_rtx_bool_0.
5966
5967 2012-09-05  Diego Novillo  <dnovillo@google.com>
5968
5969         PR bootstrap/54484
5970         * vec.h (vec_t::lower_bound): Fix spelling of LESSTHAN argument.
5971
5972 2012-09-05  Jakub Jelinek  <jakub@redhat.com>
5973
5974         PR middle-end/54486
5975         * builtins.c (fold_builtin_strspn, fold_builtin_strcspn): Use
5976         build_int_cst with size_type_node instead of size_int.
5977
5978 2012-09-05  Uros Bizjak  <ubizjak@gmail.com>
5979
5980         * config/i386/sse.md (<sse4_1>_blendv<ssemodesuffix><avxsizesuffix>):
5981         Use register_operand instead of reg_not_xmm0_operand{,_maybe_avx}.
5982         Use nonimmediate_operand instead of
5983         nonimm_not_xmm0_operand{,_maybe_avx}.
5984         (<sse4_1_avx2>_pblendvb): Ditto.
5985         (sse4_2_pcmpestr): Ditto.
5986         (*sse4_2_pcmpestr_unaligned): Ditto.
5987         (sse4_2_pcmpistr): Ditto.
5988         (*sse4_2_pcmpistr_unaligned): Ditto.
5989         * config/i386/predicates.md (reg_not_xmm0_operand): Remove predicate.
5990         (nonimm_not_xmm0_operand): Ditto.
5991         (nonimm_not_xmm0_operand_maybe_avx): Ditto.
5992         (nonimm_not_xmm0_operand_maybe_avx): Ditto.
5993         * config/i386/i386.md (rdpmc): Do not force operand 1 into ecx.
5994
5995 2012-09-05  Eric Botcazou  <ebotcazou@adacore.com>
5996
5997         * bb-reorder.c: Clarify a few points in the head comment and fix
5998         long lines in other comments.
5999         (find_traces): Fix long line.
6000         (find_traces_1_round): Likewise.
6001         (better_edge_p): Likewise.
6002         (connect_traces): Likewise.
6003         (duplicate_computed_gotos): Likewise.
6004         (find_rarely_executed_basic_blocks_and_cr): Remove trailing spaces.
6005         (fix_up_fall_thru_edges): Fix formatting.
6006
6007 2012-09-05  Richard Guenther  <rguenther@suse.de>
6008
6009         PR tree-optimization/46590
6010         * tree-ssa-loop-ivcanon.c (try_unroll_loop_completely): Do not
6011         update SSA form here.
6012         (canonicalize_induction_variables): Assert we do not need to
6013         update SSA form.
6014         (tree_unroll_loops_completely): Update SSA form here.
6015         * tree-ssa-loop-manip.c (gimple_duplicate_loop_to_header_edge):
6016         Do not verify loop-closed SSA form if SSA form is not up-to-date.
6017
6018 2012-09-05  Georg-Johann Lay  <avr@gjlay.de>
6019
6020         PR target/54461
6021         * config.gcc (tm_file,target=avr-*-*): Add avr/avrlibc.h if
6022         not configured --with-avrlibc=no.
6023         (tm_defines,target=avr-*-*): Add WITH_AVRLIBC if not configured
6024         --with-avrlibc=no.
6025         * config/avr/avrlibc.h: New file.
6026         * config/avr/avr-c.c: Build-in define __WITH_AVRLIBC__ if
6027         not configured --with-avrlibc=no.
6028         * doc/invoke.texi (AVR Built-in Macros): Document __WITH_AVRLIBC__
6029
6030 2012-09-04  Teresa Johnson  <tejohnson@google.com>
6031
6032         * gcov-io.c (gcov_write_summary): Write out non-zero histogram
6033         entries to function summary along with an occupancy bit vector.
6034         (gcov_read_summary): Read in the histogram entries.
6035         (gcov_histo_index): New function.
6036         (void gcov_histogram_merge): Ditto.
6037         * gcov-io.h (gcov_type_unsigned): New type.
6038         (struct gcov_bucket_type): Ditto.
6039         (struct gcov_ctr_summary): Include histogram.
6040         (GCOV_TAG_SUMMARY_LENGTH): Update to include histogram entries.
6041         (GCOV_HISTOGRAM_SIZE): New macro.
6042         (GCOV_HISTOGRAM_BITVECTOR_SIZE): Ditto.
6043         * profile.c (NUM_GCOV_WORKING_SETS): Ditto.
6044         (gcov_working_sets): New global variable.
6045         (compute_working_sets): New function.
6046         (find_working_set): Ditto.
6047         (get_exec_counts): Invoke compute_working_sets.
6048         * coverage.c (read_counts_file): Merge histograms, and
6049         fix bug with accessing summary info for non-summable counters.
6050         * basic-block.h (gcov_type_unsigned): New type.
6051         (struct gcov_working_set_info): Ditto.
6052         (find_working_set): Declare.
6053         * gcov-dump.c (tag_summary): Dump out histogram.
6054
6055 2012-09-04  Diego Novillo  <dnovillo@google.com>
6056
6057         PR bootstrap/54484
6058         * vec.h (vec_t::embedded_init): Move default argument value
6059         to function declaration.
6060
6061 2012-09-04  Eric Botcazou  <ebotcazou@adacore.com>
6062
6063         * bb-reorder.c (gate_handle_reorder_blocks): Move around.
6064         (rest_of_handle_reorder_blocks): Likewise.
6065         (pass_reorder_blocks): Likewise.
6066         (gate_handle_partition_blocks): Likewise.
6067
6068 2012-09-04  Eric Botcazou  <ebotcazou@adacore.com>
6069
6070         PR rtl-optimization/54456
6071         * sched-rgn.c (gate_handle_sched): Return 1 only if optimize > 0.
6072
6073 2012-09-04  Diego Novillo  <dnovillo@google.com>
6074
6075         PR bootstrap/54478
6076         * vec.h (vec_t::alloc): Remove explicit type specification
6077         in call to reserve.
6078         (vec_t::copy): Likewise.
6079         (vec_t::reserve): Likewise.
6080         (vec_t::reserve_exact): Likewise.
6081         (vec_t::safe_splice): Likewise.
6082         (vec_t::safe_push): Likewise.
6083         (vec_t::safe_grow): Likewise.
6084         (vec_t::safe_grow_cleared): Likewise.
6085         (vec_t::safe_insert): Likewise.
6086
6087 2012-09-04  Richard Henderson  <rth@redhat.com>
6088
6089         * alias.c (read_dependence): Return true for ALIAS_SET_MEMORY_BARRIER.
6090
6091 2012-09-04  Richard Guenther  <rguenther@suse.de>
6092
6093         * tree-ssa-pre.c (value_expressions): Make it a vector of
6094         bitmaps containing expression IDs.
6095         (add_to_value): Adjust.
6096         (sorted_array_from_bitmap_set): Likewise.
6097         (bitmap_set_replace_value): Likewise.
6098         (print_value_expressions): Likewise.
6099         (get_constant_for_value_id): Likewise.
6100         (get_representative_for): Likewise.
6101         (phi_translate_1): Likewise.
6102         (bitmap_find_leader): Likewise.
6103         (find_or_generate_expression): Likewise.
6104         (do_regular_insertion): Likewise.
6105         (init_pre): Likewise.
6106         (fini_pre): Likewise.
6107
6108 2012-09-04  Diego Novillo  <dnovillo@google.com>
6109
6110         PR bootstrap/54479
6111         * vec.h (vec_t::copy): Add cast in call to reserve_exact.
6112
6113 2012-09-04  Richard Guenther  <rguenther@suse.de>
6114
6115         * tree-ssa-pre.c (add_to_exp_gen): Adjust.
6116         (make_values_for_phi): Do not add to PHI_GEN for FRE.
6117         (compute_avail): Stop processing after adding all defs to
6118         AVAIL_OUT for FRE.
6119         (init_pre): Do not allocate not needed bitmap sets for FRE.
6120
6121 2012-09-04  Diego Novillo  <dnovillo@google.com>
6122
6123         Rewrite VEC_* functions as member functions of vec_t.
6124
6125         * vec.h: Update documentation.
6126         (ALONE_VEC_CHECK_INFO): Define.
6127         (ALONE_VEC_CHECK_DECL): Define.
6128         (ALONE_VEC_CHECK_PASS): Define.
6129         (struct vec_prefix): Rename field NUM to NUM_.
6130         Rename field ALLOC to ALLOC_.
6131         Update all users.
6132         (struct vec_t): Rename field PREFIX to PREFIX_.
6133         Rename field VEC to VEC_.
6134         Update all users.
6135         (vec_t::length): Rename from VEC_length_1.  Update all users.
6136         (vec_t::empty): Rename from VEC_empty_1.  Update all users.
6137         (vec_t::address): Rename from VEC_address_1.  Update all users.
6138         (vec_address): New.
6139         (vec_t::last): Rename from VEC_last_1.  Update all users.
6140         (vec_t::operator[]): Rename from VEC_index_1.  Update all users.
6141         (vec_t::iterate): Rename from VEC_iterate_1.  Update all users.
6142         (vec_t::embedded_size): Rename from VEC_embedded_size_1.
6143         Update all users.
6144         (vec_t::embedded_init): Rename from VEC_embedded_init_1.
6145         Update all users.
6146         (vec_t::alloc): Rename from VEC_alloc_1.  Update all users.
6147         (vec_t::free): Rename from VEC_free_1.  Update all users.
6148         (vec_t::copy): Rename from VEC_copy_1.  Update all users.
6149         (vec_t::space): Rename from VEC_space_1.  Update all users.
6150         (vec_t::reserve): Rename from VEC_reserve_1.  Update all users.
6151         (vec_t::reserve_exact): Rename from VEC_reserve_exact_1.
6152         Update all users.
6153         (vec_t::splice): Rename from VEC_splice_1.  Update all users.
6154         (vec_t::safe_splice): Rename from VEC_safe_splice_1.  Update all users.
6155         (vec_t::quick_push): Rename from VEC_quick_push_1.  Update all users.
6156         (vec_t::safe_push): Rename from VEC_safe_push_1.  Update all users.
6157         (vec_t::pop): Rename from VEC_pop_1.  Update all users.
6158         (vec_t::truncate): Rename from VEC_truncate_1.  Update all users.
6159         (vec_t::safe_grow): Rename from VEC_safe_grow_1.  Update all users.
6160         (vec_t::safe_grow_cleared): Rename from VEC_safe_grow_cleared_1.
6161         Update all users.
6162         (vec_t::replace): Rename from VEC_replace_1.  Update all users.
6163         (vec_t::quick_insert): Rename from VEC_quick_insert_1.
6164         Update all users.
6165         (vec_t::safe_insert): Rename from VEC_safe_insert_1.  Update all users.
6166         (vec_t::ordered_remove): Rename from VEC_ordered_remove_1.
6167         Update all users.
6168         (vec_t::unordered_remove): Rename from VEC_unordered_remove_1.
6169         Update all users.
6170         (vec_t::block_remove): Rename from VEC_block_remove_1. Update all users.
6171         (vec_t::lower_bound): Rename from VEC_lower_bound_1. Update all users.
6172
6173 2012-09-04  Steven Bosscher  <steven@gcc.gnu.org>
6174
6175         * gimple.h (gimple_build_switch): Remove.
6176         (gimple_build_switch_vec): Promote to the new gimple_build_switch.
6177         (gimple_switch_default_label): Assert the default case label is
6178         really a default case label.
6179         (gimple_switch_set_default_label): Likewise.
6180         * gimple.c (gimple_build_switch_nlabels): Make sure a default label
6181         is passed in, and simplify accordingly.
6182         (gimple_build_switch): Removed.
6183         (gimple_build_switch_vec): Rename to gimple_build_switch.
6184         * gimplify.c (gimplify_switch_expr): Update gimple_build_switch use.
6185         * gimple-pretty-print.c (dump_gimple_switch): Do not accept a NULL
6186         case label.
6187         * stmt.c (expand_case): Simplify using the fact that every GIMPLE
6188         switch must have a default case.
6189         * tree-cfg.c (group_case_labels_stmt): Likewise.
6190         (verify_gimple_switch): Use gimple_switch_label in verifier to get
6191         the label at index 0, and verify that it is a valid default case.
6192         * except.c (sjlj_emit_dispatch_table): Rewrite construction of the
6193         switch for dispatching.
6194         * tree-eh.c (lower_try_finally_switch): Update gimple_build_switch use.
6195         (lower_eh_dispatch): Likewise.
6196         * tree-vrp.c (execute_vrp): Use gimple_switch_label to get the case
6197         label at index 0 before turning it into a default case label.
6198         * omp-low.c (expand_omp_sections): Update gimple_build_switch use.
6199         * tree-switch-conversion.c (emit_case_bit_tests): Get the default case
6200         label using gimple_switch_default_label.
6201         (collect_switch_conv_info): Likewise.
6202         (process_switch): Likewise.
6203         * doc/gimple.texi: Update documentation of gimple_build_switch.
6204
6205 2012-09-04  Georg-Johann Lay  <avr@gjlay.de>
6206
6207         PR target/54476
6208         * config/avr/avr.c (avr_expand_delay_cycles): Mask operand with
6209         SImode.
6210
6211 2012-09-04  Bin Cheng  <bin.cheng@arm.com>
6212
6213         PR target/45070
6214         * config/arm/arm.c (thumb1_extra_regs_pushed): Handle return value
6215         of size less than 4 bytes by using macro ARM_NUM_INTS.
6216         (thumb1_unexpanded_epilogue): Use macro ARM_NUM_INTS.
6217
6218 2012-09-04  Richard Guenther  <rguenther@suse.de>
6219
6220         PR tree-optimization/54458
6221         * tree-ssa-threadupdate.c (thread_through_loop_header): If we
6222         turn the loop into one with multiple latches mark it so.
6223
6224 2012-09-04  Senthil Kumar Selvaraj  <senthil_kumar.selvaraj@atmel.com>
6225
6226         PR target/54220
6227         * config/avr/avr.c (TARGET_ALLOCATE_STACK_SLOTS_FOR_ARGS): New
6228         define to...
6229         (avr_allocate_stack_slots_for_args): ...this new static function.
6230
6231 2012-09-04  Christophe Lyon  <christophe.lyon@linaro.org>
6232
6233         * config/arm/arm.c (arm_expand_builtin): Replace gen_rtx_CONST_INT
6234         by GEN_INT.
6235         (arm_emit_coreregs_64bit_shift): Likewise.
6236
6237 2012-09-04  Christophe Lyon  <christophe.lyon@linaro.org>
6238
6239         * config/arm/arm.c (arm_evpc_neon_vext): New function.
6240         (arm_expand_vec_perm_const_1): Add call to arm_evpc_neon_vext.
6241
6242 2012-09-04  Oleg Endo  <olegendo@gcc.gnu.org>
6243
6244         PR target/51244
6245         * config/sh/sh.c (prepare_cbranch_operands): Pull out comparison
6246         canonicalization code into...
6247         * (sh_canonicalize_comparison): This new function.
6248         * config/sh/sh-protos.h: Declare it.
6249         * config/sh/sh.h: Use it in new macro CANONICALIZE_COMPARISON.
6250         * config/sh/sh.md (cbranchsi4): Remove TARGET_CBRANCHDI4 check and
6251         always invoke expand_cbranchsi4.
6252
6253 2012-09-03  Andi Kleen  <ak@linux.intel.com>
6254
6255         * tree-ssa-sccvn.c (vn_reference_fold_indirect): Initialize
6256         addr_offset always.
6257
6258 2012-09-03  Andrew Pinski  <apinski@cavium.com>
6259
6260         PR tree-opt/53395
6261         * tree-if-conv.c (constant_or_ssa_name): New function.
6262         (fold_build_cond_expr): New function.
6263         (predicate_scalar_phi): Use fold_build_cond_expr instead of build3.
6264         (predicate_mem_writes): Likewise.
6265
6266 2012-09-03  Marc Glisse  <marc.glisse@inria.fr>
6267
6268         * fold-const.c (fold_ternary_loc): Constant-propagate after
6269         removing dead operands.
6270
6271 2012-09-03  Michael Matz  <matz@suse.de>
6272
6273         PR tree-optimization/46590
6274         * tree-cfg.c (gimple_duplicate_sese_region): Don't update
6275         SSA web here ...
6276         * tree-ssa-loop-ch.c (copy_loop_headers): ... but here.
6277
6278 2012-09-03  Sandra Loosemore  <sandra@codesourcery.com>
6279
6280         * doc/invoke.texi: Fix numerous typos and punctuation/grammatical
6281         errors throughout the file.  Re-word some awkward sentences and
6282         paragraphs.
6283
6284 2012-09-03  Richard Guenther  <rguenther@suse.de>
6285
6286         PR tree-optimization/54362
6287         * tree-ssa-structalias.c (find_func_aliases): Handle COND_EXPR.
6288
6289 2012-09-03  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
6290
6291         * config/s390/s390.c (s390_loadrelative_operand_p): New function.
6292         (s390_check_qrst_address, print_operand_address): Use
6293         s390_loadrelative_operand_p instead of s390_symref_operand_p.
6294         (s390_check_symref_alignment): Accept pointer size alignment for
6295         GOT slots.
6296         (legitimize_pic_address): Use load relative on z10 or later.
6297
6298 2012-09-03  Jakub Jelinek  <jakub@redhat.com>
6299
6300         PR debug/53923
6301         * valtrack.c (dead_debug_insert_temp): Drop non-reg uses
6302         from the chain.
6303
6304 2012-09-03  Joseph Myers  <joseph@codesourcery.com>
6305
6306         * common.opt (--no-sysroot-suffix): New driver option.
6307         * doc/invoke.texi (--no-sysroot-suffix): Document.
6308         * gcc.c (driver_handle_option): Handle --no-sysroot-suffix as not
6309         needing spec processing.
6310         (main): Do not process sysroot suffixes if no_sysroot_suffix.
6311
6312 2012-09-02  Oleg Endo  <olegendo@gcc.gnu.org>
6313
6314         PR target/33135
6315         * common/config/sh/sh-common.c: Update copyright years.
6316         (sh_option_init_struct): Delete.
6317         (TARGET_OPTION_INIT_STRUCT): Likewise.
6318
6319 2012-09-02  Oleg Endo  <olegendo@gcc.gnu.org>
6320
6321         PR target/54418
6322         * config/sh/sh.md (cmpgeusi_t): Remove N alternative.
6323         Check operands[1] in split condition instead of operands[0].
6324         Add comments.
6325
6326 2012-09-02  Mark Kettenis  <kettenis@openbsd.org>
6327
6328         * config.gcc (x86_64-*-openbsd*): New target.
6329         * config.host (*-*-openbsd*): New target.
6330         * config/openbsd.h (TARGET_C99_FUNCTIONS): Define.
6331         * config/i386/openbsdelf.h: Remove some superfluous defines and
6332         group things together in a more logical fashion.
6333         (DBX_REGISTER_NUMBER): Provide a
6334         definition that works on both 32-bit and 64-bit targets.
6335         (WCHAR_TYPE_SIZE): Hardcode as 32.
6336         (NO_DOLLAR_IN_LABEL): Remove undef.
6337         (TARGET_DEFAULT): Remove.
6338         (SET_ASM_OP): Remove.
6339         (DEFAULT_PCC_STRUCT_RETURN): Undef first to prevent warning.
6340         (ASM_OUTPUT_MAX_SKIP_ALIGN): Synch with x86-64.h
6341         (DWARF2_UNWIND_INFO): Remove define.
6342         (HAVE_ENABLE_EXECUTE_STACK): Define.
6343         * config/host-openbsd.c: New file.
6344         * config/t-openbsd (USER_H): Add EXTRA_HEADERS.
6345         * config/x-openbsd: New file.
6346
6347 2012-09-02  Oleg Endo  <olegendo@gcc.gnu.org>
6348
6349         * config/sh/sh.md (*extend<mode>si2_compact_mem_disp): Pass iterated
6350         mode to sh_legitimate_index_p instead of QImode.
6351
6352 2012-09-02  Eric Botcazou  <ebotcazou@adacore.com>
6353
6354         PR rtl-optimization/54369
6355         * config/mips/mips.c (mips_reorg): Invoke cleanup_barriers before
6356         calling dbr_schedule.
6357         * config/sparc/sparc.c (sparc_reorg): Likewise.
6358
6359 2012-09-01  Jakub Jelinek  <jakub@redhat.com>
6360
6361         PR target/54436
6362         * config/i386/i386.md (*mov<mode>_insv_1_rex64, *movsi_insv_1): If
6363         operands[1] is CONST_INT_P, convert it to QImode before printing.
6364
6365 2012-09-01  Andrew Pinski  <apinski@cavium.com>
6366
6367         * simplify-rtx.c (simplify_unary_operation_1 <case TRUNCATE>):
6368         A truncate of a memory is just loading the low part of the memory.
6369
6370 2012-09-01  Uros Bizjak  <ubizjak@gmail.com>
6371
6372         PR target/46829
6373         PR target/46843
6374         * config/i386/i386.c (ix86_legitimate_combined_insn): New function.
6375         (TARGET_LEGITIMATE_COMBINED_INSN): New macro.
6376
6377 2012-09-01  Uros Bizjak  <ubizjak@gmail.com>
6378
6379         * target.def (legitimate_combined_insn): New target hook.
6380         * doc/tm.texi.in (TARGET_LEGITIMATE_COMBINED_INSN): New hook.
6381         * doc/tm.texi: Regenerated.
6382         * combine.c (recog_for_combine): Call targetm.legitimate_combined_insn
6383         to allow targets to reject combined insn.
6384         * hooks.h (hook_bool_rtx_true): New.
6385         * hooks.c (hook_bool_rtx_true): Ditto.
6386
6387 2012-08-31  Martin Jambor  <mjambor@suse.cz>
6388
6389         * ipa-inline-analysis.c (estimate_function_body_sizes): Allocate
6390         nonconstant_names after calculate_dominance_info and
6391         loop_optimizer_init.
6392
6393 2012-08-31  Greta Yorsh  <Greta.Yorsh@arm.com>
6394
6395         * config/arm/arm.c (arm_expand_epilogue): Remove unused variable
6396         floats_from_frame.
6397
6398 2012-08-31  Martin Jambor  <mjambor@suse.cz>
6399
6400         PR middle-end/54409
6401         * ipa-inline-analysis.c (remap_predicate): Fix the offset_map
6402         checking condition.
6403
6404 2012-08-31  Martin Jambor  <mjambor@suse.cz>
6405
6406         * ipa-inline-analysis.c (phi_result_unknown_predicate): New function.
6407         (predicate_for_phi_result): Likewise.
6408         (estimate_function_body_sizes): Use the above two functions.
6409
6410 2012-08-31  Martin Jambor  <mjambor@suse.cz>
6411
6412         PR middle-end/54394
6413         * ipa-inline-analysis.c (estimate_function_body_sizes): Compute
6414         dominance info and loops whenever optimizing.
6415
6416 2012-08-29  Ramana Radhakrishnan  <ramana.radhakrishnan@arm.com>
6417             Richard Earnshaw  <richard.earnshaw@arm.com>
6418
6419         PR target/54252
6420         * config/arm/arm.c (neon_dereference_pointer): Adjust nelems by
6421         element size. Use elem_type from the formal parameter. New parameter
6422         fcode.
6423         (neon_expand_args): Adjust call to neon_dereference_pointer.
6424
6425 2012-08-29  Steven Bosscher  <steven@gcc.gnu.org>
6426
6427         * cfg.c (dump_bb_info): Print a newline if there were no edges to dump.
6428
6429 2012-08-29  Chung-Lin Tang  <cltang@codesourcery.com>
6430
6431         Revert:
6432         * config/mips/t-linux64 (MULTILIB_OSDIRNAMES): Change to use
6433         mapping style, add ../lib/mips16.
6434         (MULTILIB_OPTIONS,MULTILIB_DIRNAMES): Add mips16.
6435         (MULTILIB_EXCLUSIONS): Exclude mips16 when not -mabi=32.
6436
6437 2012-08-29  Richard Sandiford  <rdsandiford@googlemail.com>
6438
6439         * config/mips/mips.h (TARGET_CPU_CPP_BUILTINS): Define __mips_synci
6440         if TARGET_SYNCI.
6441
6442 2012-08-29  Oleg Endo  <olegendo@gcc.gnu.org>
6443
6444         * config/sh/sh.opt (menable-tas): Rename to mtas.
6445         * doc/invoke.texi (SH options): Likewise.
6446         * config/sh/sync.md: Update comments.
6447
6448 2012-08-29  Oleg Endo  <olegendo@gcc.gnu.org>
6449
6450         * config/sh/iterators.md: New file.
6451         * config/sh/sync.md (I124, I12, i124suffix): Delete.  Replace usage
6452         with new iterators QIHISI, QIHI, bw, bwl respectively throughout
6453         the file.
6454         * config/sh/sh.md: Include new file iterators.md.
6455         (zero_extendhisi2, zero_extendqisi2): Fold into zero_extend<mode>si2.
6456         (*zero_extendhisi2_compact, *zero_extendqisi2_compact): Fold into
6457         *zero_extend<mode>si2_compact.
6458         (*zero_extendqisi2_disp_mem, zero_extendhisi2_disp_mem): Fold into
6459         *zero_extend<mode>si2_disp_mem.
6460         (extendhisi2, extendqisi2): Fold into extend<mode>si2.
6461         (*extendqisi2_compact_reg, *extendhisi2_compact_reg): Fold into
6462         *extend<mode>si2_compact_reg.
6463         (*extendqisi2_compact_mem_disp, *extendhisi2_compact_mem_disp): Fold
6464         into *extend<mode>si2_compact_mem_disp.
6465         (*extendqisi2_compact_snd, *extendhisi2_compact_snd): Fold into
6466         *extend<mode>si2_compact_snd.
6467         (*movsi_index_disp, *movhi_index_disp): Fold with iterators and rename
6468         to *movsi_index_disp_load, *movhi_index_disp_load,
6469         *mov<mode>_index_disp_store.
6470         (*movqi_reg_reg, *movhi_reg_reg): Fold into *mov<mode>_reg_reg.
6471         (*movqi_store_mem_disp04, *movhi_store_mem_disp05): Fold into
6472         *mov<mode>_store_mem_disp04.
6473         (*movqi_store_mem_disp12, *movhi_store_mem_disp13): Fold into
6474         *mov<mode>_store_mem_disp12.
6475         (*movqi_load_mem_disp, *movhi_load_mem_disp): Fold into
6476         *mov<mode>_load_mem_disp04 and *mov<mode>_load_mem_disp12.
6477
6478 2012-08-29  Martin Jambor  <mjambor@suse.cz>
6479
6480         * ipa-inline.h (estimate_edge_hints): Call do_estimate_edge_hints, not
6481         do_estimate_edge_time.
6482
6483 2012-08-29  Chung-Lin Tang  <cltang@codesourcery.com>
6484
6485         * config/mips/mips.h (CRT_CALL_STATIC_FUNCTION): Add nomips16 asm
6486         directives, remove #ifndef __mips16 guards.
6487         * config/mips/t-linux64 (MULTILIB_OSDIRNAMES): Change to use
6488         mapping style, add ../lib/mips16.
6489         (MULTILIB_OPTIONS,MULTILIB_DIRNAMES): Add mips16.
6490         (MULTILIB_EXCLUSIONS): Exclude mips16 when not -mabi=32.
6491
6492 2012-08-28  Walter Lee  <walt@tilera.com>
6493         * confg/tilegx/tilegx.md: Fix code style.
6494         (*zero_extendsidi_truncdisi): Fix typo.
6495         * config/tilegx/tilegx.c: Fix code style.
6496         (tilegx_function_profiler): Fix typo.
6497
6498 2012-08-28  Walter Lee  <walt@tilera.com>
6499
6500         * doc/invoke.texi: Document -mcmodel=small, -mcmodel=large.
6501         * config/tilegx/tilegx.h: Include config/tilegx/tilegx-opts.h.
6502         (CRT_CALL_STATIC_FUNCTION): Define.
6503         * config/tilegx/predicates.md (const_last_symbolic_operand):
6504         Handle UNSPEC_HW2_LAST_PCREL, UNSPEC_HW1_LAST_PLT_PCREL, and
6505         UNSPEC_HW2_LAST_PLT_PCREL.
6506         (const_symbolic_operand): Handle UNSPEC_HW1_PCREL,
6507         UNSPEC_HW0_PLT_PCREL, and UNSPEC_HW1_PLT_PCREL.
6508         * config/tilegx/tilegx.md (UNSPEC_MOV_LARGE_PCREL_STEP4): Define,
6509         and renumber the constants that follow.
6510         (UNSPEC_HW1_PCREL): Ditto.
6511         (UNSPEC_HW2_LAST_PCREL): Ditto.
6512         (UNSPEC_HW0_PLT_PCREL): Define.
6513         (UNSPEC_HW1_PLT_PCREL): Define.
6514         (UNSPEC_HW1_LAST_PLT_PCREL): Define.
6515         (UNSPEC_HW2_LAST_PLT_PCREL): Define.
6516         (mov_large_pcrel_step1): Define.
6517         (mov_large_pcrel_step2): Define.
6518         (mov_large_pcrel_step3): Define.
6519         (mov_large_pcrel_step4): Define.
6520         (mov_plt_pcrel_step1): Define.
6521         (mov_plt_pcrel_step2): Define.
6522         (mov_plt_pcrel_step3): Define.
6523         (mov_plt_pcrel_step1_32bit): Define.
6524         (mov_plt_pcrel_step2_32bit): Define.
6525         (call): Handle tilegx_cmodel == CM_LARGE, CM_LARGE_PIC.
6526         (call_value): Ditto.
6527         * config/tilegx/tilegx.opt: Include config/tilegx/tilegx-opts.h.
6528         (mcmodel): New option.
6529         (enum cmodel): Define.
6530         (CM_SMALL): Define.
6531         (CM_LARGE): Define.
6532         * config/tilegx/tilegx-opts.h: New file.
6533         * config/tilegx/tilegx-protos.h (tilegx_compute_pcrel_address):
6534         Declare.
6535         (tilegx_compute_pcrel_plt_address): Declare.
6536         * config/tilegx/tilegx.c (tilegx_option_override): Handle
6537         tilegx_cmodel.
6538         (tilegx_function_ok_for_sibcall): Ditto.
6539         (compute_pcrel_address): Rename to tilegx_compute_pcrel_address,
6540         and don't declare static.  Handle tilegx_cmodel.
6541         (tilegx_compute_pcrel_plt_address): Define.
6542         (tilegx_legitimize_pic_address): Rename calls to
6543         compute_pcrel_address.
6544         (tilegx_delegitimize_address): Handle UNSPEC_HW1_PCREL,
6545         UNSPEC_HW2_LAST_PCREL, UNSPEC_HW0_PLT_PCREL, UNSPEC_HW1_PLT_PCREL,
6546         UNSPEC_HW1_LAST_PLT_PCREL, UNSPEC_HW2_LAST_PLT_PCREL.
6547         (load_pic_register): Rename call to compute_pcrel_address.
6548         (tilegx_print_operand): Handle UNSPEC_HW1_PCREL,
6549         UNSPEC_HW2_LAST_PCREL, UNSPEC_HW0_PLT_PCREL, UNSPEC_HW1_PLT_PCREL,
6550         UNSPEC_HW1_LAST_PLT_PCREL, UNSPEC_HW2_LAST_PLT_PCREL.
6551
6552 2012-08-27  Maxim Kuvyrkov  <maxim@codesourcery.com>
6553
6554         * sched-deps.c (add_dependence_list_and_free): Simplify.
6555         (flush_pending_list_and_free): Fix a hack that was fixing a hack.  Free
6556         lists when add_dependence_list_and_free doesn't free them.
6557
6558 2012-08-27  Uros Bizjak  <ubizjak@gmail.com>
6559
6560         PR target/46254
6561         * config/i386/predicates.md (cmpxchg8b_pic_memory_operand): Return
6562         true for TARGET_64BIT or !flag_pic.
6563         * config/i386/sync.md (*atomic_compare_and_swap_doubledi_pic): Remove.
6564         (atomic_compare_and_swap_double<mode>): Change operand 2 predicate
6565         to cmpxchg8b_pic_memory_operand.  Use DWIH mode iterator.
6566         Add insn constraint.  Conditionally emit xchg asm insns.
6567         (atomic_compare_and_swap<mode>): Update calls.  Check only
6568         cmpxchg8b_pic_memory_operand in memory address fixup.
6569         (DCASMODE): Remove.
6570         (CASHMODE): Rename from DCASHMODE.
6571         (doublemodesuffix): Update modes.
6572         (regprefix): New mode attribute.
6573
6574         (unspecv) <UNSPECV_CMPXCHG_{1,2,3,4}>: Remove.
6575         <UNSPECV_CMPXCHG>: New constant.
6576         (atomic_compare_and_swap<mode>_1): Rename from
6577         atomic_compare_and_swap_single<mode>.  Update calls and
6578         unspec_volatile constants.
6579         (atomic_compare_and_swap<mode>_doubleword): Rename from
6580         atomic_compare_and_swap_double<mode>.  Update calls and
6581         unspec_volatile constants.
6582
6583 2012-08-27  Walter Lee  <walt@tilera.com>
6584
6585         * doc/md.texi (TILE-Gx): Fix typo.
6586
6587 2012-08-27  Walter Lee  <walt@tilera.com>
6588
6589         * config/tilegx/tilegx.c (tilegx_function_profiler): Fix typo.
6590         * config/tilepro/tilepro.c (tilepro_function_profiler): Ditto.
6591
6592 2012-08-27  Walter Lee  <walt@tilera.com>
6593
6594         * config/tilegx/tilegx.md (*bfins): Rename to insn_bfins.
6595         (insn_bfins): Delete.
6596
6597 2012-08-27  Walter Lee  <walt@tilera.com>
6598
6599         * config/tilegx/sync.md (atomic_compare_and_swap_bare<mode>,
6600         atomic_exchange_bare<mode>,
6601         atomic_fetch_<fetchop_name>_bare<mode>): Set type to X1_remote.
6602         * config/tilegx/tilegx-generic.md (X1_remote): New
6603         insn_reservation.
6604         * config/tilegx/tilegx.md (type): Add X1_remove.
6605         (insn_cmpexch<four_if_si>, insn_exch<four_if_si>,
6606         insn_fetchadd<four_if_si>, insn_fetchaddgez<four_if_si>,
6607         insn_fetchand<four_if_si>, insn_fetchor<four_if_si>): Set type to
6608         X1_remote.
6609
6610 2012-08-27  Andreas Schwab  <schwab@linux-m68k.org>
6611
6612         * gdbinit.in: Fix syntax of skip command.
6613
6614 2012-08-27  Richard Sandiford  <rdsandiford@googlemail.com>
6615
6616         * config/mips/mips.c (mips_pic_call_symbol_from_set): Check for
6617         SYMBOL_REF SET_SRCs.
6618
6619 2012-08-27  Richard Sandiford  <rdsandiford@googlemail.com>
6620
6621         * config/mips/mips.c (vr4130_align_insns): Don't simulate
6622         ghost instructions.  Assert that the required instructions exist.
6623
6624 2012-08-26  Richard Sandiford  <rdsandiford@googlemail.com>
6625
6626         * config/mips/mips.h (AVOID_CCMODE_COPIES): Update rationale for
6627         definition.
6628         * config/mips/mips.c (machine_function): Add next_fcc.
6629         (mips_output_move): Remove handling of fcc moves.
6630         (mips_allocate_fcc): New function.
6631         (mips_emit_compare, mips_expand_vcondv2sf): Use it.
6632         (mips_hard_regno_mode_ok_p): Restrict CCmode to ST registers.
6633         Remove special case for CCmode reloads.
6634         (mips_expand_builtin_compare_1): Use mips_allocate_fcc and treat
6635         the result a fixed operand.
6636         * config/mips/mips.md (move_type): Remove lui_movf.
6637         (type, length): Remove references to it.
6638         (movcc, reload_incc, reload_outcc): Delete.
6639
6640 2012-08-26  Richard Sandiford  <rdsandiford@googlemail.com>
6641
6642         * config/mips/mips.c (mips_has_long_branch_p): New function,
6643         split out from...
6644         (mips_expand_ghost_gp_insns): ...here.  Look inside sequences.
6645
6646 2012-08-26  Richard Sandiford  <rdsandiford@googlemail.com>
6647
6648         * config/mips/mips.c (r10k_safe_mem_expr_p): Use get_inner_reference.
6649
6650 2012-08-26  Richard Sandiford  <rdsandiford@googlemail.com>
6651
6652         * config/mips/mips.c (mips_rtx_costs): Add costs for CINS.
6653
6654 2012-08-26  Richard Sandiford  <rdsandiford@googlemail.com>
6655
6656         * config/mips/mips.c (mips_rtx_costs): Add missing COSTS_N_INSNS
6657         to the size cost of multiplication.
6658
6659 2012-08-26  Gerald Pfeifer  <gerald@pfeifer.com>
6660
6661         * doc/install.texi (Specific): Clarify what needs to be added to
6662         this section.
6663
6664 2012-08-26  Gerald Pfeifer  <gerald@pfeifer.com>
6665
6666         * doc/tm.texi.in (Misc): Move descriptions of NO_DOLLAR_IN_LABEL
6667         and NO_DOT_IN_LABEL from here...
6668         (Label Output): ...to here.
6669         * doc/tm.texi: Regenerate.
6670
6671 2012-08-26  Gerald Pfeifer  <gerald@pfeifer.com>
6672
6673         * doc/invoke.texi (C++ Dialect Options): Add missing space.
6674
6675 2012-08-25  Eric Botcazou  <ebotcazou@adacore.com>
6676
6677         PR rtl-optimization/54088
6678         * jump.c (delete_related_insns): Robustify latest change.
6679
6680 2012-08-25  Ricardo Catalinas Jiménez  <jimenezrick@gmail.com>
6681
6682         * doc/extend.texi (__atomic Builtins): Remove space before comma.
6683
6684 2012-08-25  Richard Sandiford  <rdsandiford@googlemail.com>
6685             Andrew Pinski  <apinski@cavium.com>
6686
6687         * config/mips/mips.h (CASE_VECTOR_MODE): For not
6688         TARGET_MIPS16_SHORT_JUMP_TABLES use ptr_mode.
6689         (CASE_VECTOR_SHORTEN_MODE): Likewise.
6690
6691 2012-08-25  Uros Bizjak  <ubizjak@gmail.com>
6692
6693         * config/i386/i386.h (FP_REG_P): Remove macro.
6694         (FP_REGNO_P): Ditto.
6695         (HARD_REGNO_NREGS): Use STACK_REGNO_P instead of FP_REGNO_P.
6696         (HARD_REGNO_NREGS_HAS_PADDING): Ditto.
6697         (ANY_FP_REGNO_P): Ditto.
6698         (HARD_REGNO_RENAME_OK): Use STACK_REGNO_P.
6699         * config/i386/i386.c (output_387_ffreep): Use STACK_REGNO_P
6700         instead of FP_REGNO_P.
6701         (ix86_hard_regno_mode_ok): Ditto.
6702         * config/i386/predicates.md (fp_register_operand): Ditto.
6703         (register_and_not_fp_reg_operand): Ditto.
6704         * config/i386/sync.md (atomic_loaddi_fpu): Use STACK_REG_P instead
6705         of FP_REG_P.
6706
6707         * reg-stack.c (get_true_reg): Use STACK_REG_P instead of FP_REG_P.
6708
6709 2012-08-24  Jason Merrill  <jason@redhat.com>
6710
6711         * print-tree.c (print_node): Don't check TREE_LANG_FLAG_*
6712         on TREE_VEC or SSA_NAME.
6713
6714 2012-08-24  Jakub Jelinek  <jakub@redhat.com>
6715
6716         PR c/54363
6717         * gimplify.c (optimize_compound_literals_in_ctor): Only recurse
6718         if init is a CONSTRUCTOR.
6719
6720 2012-08-24  Steven Bosscher  <steven@gcc.gnu.org>
6721
6722         * tree-ssa-live.c (dump_var_map): Do not dump the partition
6723         map of virtual operands.
6724
6725 2012-08-24  Yuri Rumyantsev  <ysrumyan@gmail.com>
6726
6727         * config/i386/i386.c (ia32_multipass_dfa_lookahead) : Add
6728         case for Atom processor.
6729
6730 2012-08-24  Simon Baldwin  <simonb@google.com>
6731
6732         * dwarf2out.c (gen_producer_string): Omit command line switch if
6733         CL_NO_DWARF_RECORD flag set.
6734         * opts.h (CL_NO_DWARF_RECORD): New.
6735         * opt-functions.awk (switch_flags): Add NoDWARFRecord.
6736         * doc/options.texi: Document NoDWARFRecord option flag.
6737
6738 2012-08-24  H.J. Lu  <hongjiu.lu@intel.com>
6739
6740         PR debug/52857
6741         * dwarf2out.c (mem_loc_descriptor): Allow arg_pointer_rtx and
6742         frame_pointer_rtx for based_loc_descr.
6743
6744 2012-08-24  Martin Jambor  <mjambor@suse.cz>
6745
6746         * predict.c (maybe_hot_frequency_p): New parameter fun.  Use its decl
6747         instead of current_function_decl, use profile_status_for_function and
6748         ENTRY_BLOCK_PTR_FOR_FUNCTION with fun instead of their cfun variants.
6749         (maybe_hot_count_p): New parameter fun, use
6750         profile_status_for_function instead of its cfun_variant.
6751         (maybe_hot_bb_p): New parameter fun, checking-assert it, pass it to
6752         all callees.
6753         (maybe_hot_edge_p): Pass cfun to maybe_hot_count_p and
6754         maybe_hot_frequency_p.
6755         (probably_never_executed_bb_p): New parameter fun, use its decl
6756         instead of current_function_decl.
6757         (optimize_bb_for_size_p): Pass cfun to maybe_hot_bb_p.
6758         (rtl_profile_for_bb): Likewise.
6759         (compute_function_frequency): Pass cfun to maybe_hot_bb_p and
6760         probably_never_executed_bb_p.
6761         * tree-ssa-operands.c (ssa_operands_active): New operator fun.  Use it
6762         instead of cfun.
6763         (update_stmt_operands): Pass cfun as an argument of
6764         ssa_operands_active.
6765         (swap_tree_operands): Likewise.
6766         * gimple-iterator.c (update_modified_stmt): Likewise.
6767         (update_modified_stmts): Likewise.
6768         * tree-flow-inline.h (delink_stmt_imm_use): Likewise.
6769         * tree-ssa.c (delete_tree_ssa): Likewise.
6770         * bb-reorder.c (bb_to_key): Pass cfun to probably_never_executed_bb_p.
6771         (push_to_next_round_p): Likewise.
6772         (find_rarely_executed_basic_blocks_and_crossing_edges ): Likewise.
6773         * cfg.c: Inlude tree.h.
6774         (check_bb_profile): Use profile_status_for_function,
6775         EXIT_BLOCK_PTR_FOR_FUNCTION and ENTRY_BLOCK_PTR_FOR_FUNCTION with
6776         DECL_STRUCT_FUNCTION (current_function_decl) instead of their cfun
6777         variants.
6778         (dump_bb_info): Pass DECL_STRUCT_FUNCTION (current_function_decl) to
6779         maybe_hot_bb_p and probably_never_executed_bb_p.
6780         * gimple-pretty-print.c (gimple_dump_bb_buff): Checking-assert that
6781         DECL_STRUCT_FUNCTION (current_function_decl) is not NULL.  Pass it to
6782         dump_histograms_for_stmt.
6783         (dump_gimple_mem_ops): Pass
6784         DECL_STRUCT_FUNCTION (current_function_decl)
6785         as an argument to dump_gimple_mem_ops.
6786         * tree-cfg.c (dump_function_to_file): Rename parameter fn to fndecl.
6787         Do not change cfun.  Change and restore current_function_decl.
6788         * Makefile.in (cfg.o): Include TREE_H in dependencies.
6789
6790 2012-08-24  Georg-Johann Lay  <avr@gjlay.de>
6791
6792         PR target/54222
6793         * avr-modes.def (HA, SA, DA, TA, UTA): Adjust modes.
6794         * avr/avr-fixed.md: New file.
6795         * avr/avr.md: Include it.
6796         (cc): Add: minus.
6797         (adjust_len): Add: minus, minus64, ufract, sfract.
6798         (ALL1, ALL2, ALL4, ORDERED234): New mode iterators.
6799         (MOVMODE): Add: QQ, UQQ, HQ, UHQ, HA, UHA, SQ, USQ, SA, USA.
6800         (MPUSH): Add: HQ, UHQ, HA, UHA, SQ, USQ, SA, USA.
6801         (pushqi1, xload8_A, xload_8, movqi_insn, *reload_inqi, addqi3,
6802         subqi3, ashlqi3, *ashlqi3, ashrqi3, lshrqi3, *lshrqi3, *cmpqi,
6803         cbranchqi4, *cpse.eq): Generalize to handle all 8-bit modes in ALL1.
6804         (*movhi, reload_inhi, addhi3, *addhi3, addhi3_clobber, subhi3,
6805         ashlhi3, *ashlhi3_const, ashrhi3, *ashirhi3_const, lshrhi3,
6806         *lshrhi3_const, *cmphi, cbranchhi4): Generalize to handle all
6807         16-bit modes in ALL2.
6808         (subhi3, casesi, strlenhi): Add clobber when expanding minus:HI.
6809         (*movsi, *reload_insi, addsi3, subsi3, ashlsi3, *ashlsi3_const,
6810         ashrsi3, *ashrhi3_const, *ashrsi3_const, lshrsi3, *lshrsi3_const,
6811         *reversed_tstsi, *cmpsi, cbranchsi4): Generalize to handle all
6812         32-bit modes in ALL4.
6813         * avr-dimode.md (ALL8): New mode iterator.
6814         (adddi3, adddi3_insn, adddi3_const_insn, subdi3, subdi3_insn,
6815         subdi3_const_insn, cbranchdi4, compare_di2,
6816         compare_const_di2, ashrdi3, lshrdi3, rotldi3, ashldi3_insn,
6817         ashrdi3_insn, lshrdi3_insn, rotldi3_insn): Generalize to handle
6818         all 64-bit modes in ALL8.
6819         * config/avr/avr-protos.h (avr_to_int_mode): New prototype.
6820         (avr_out_fract, avr_out_minus, avr_out_minus64): New prototypes.
6821         * config/avr/avr.c (TARGET_FIXED_POINT_SUPPORTED_P): Define to...
6822         (avr_fixed_point_supported_p): ...this new static function.
6823         (TARGET_BUILD_BUILTIN_VA_LIST): Define to...
6824         (avr_build_builtin_va_list): ...this new static function.
6825         (avr_adjust_type_node): New static function.
6826         (avr_scalar_mode_supported_p): Allow if ALL_FIXED_POINT_MODE_P.
6827         (avr_builtin_setjmp_frame_value): Use gen_subhi3 and return new
6828         pseudo instead of gen_rtx_MINUS.
6829         (avr_print_operand, avr_operand_rtx_cost): Handle: CONST_FIXED.
6830         (notice_update_cc): Handle: CC_MINUS.
6831         (output_movqi): Generalize to handle respective fixed-point modes.
6832         (output_movhi, output_movsisf, avr_2word_insn_p): Ditto.
6833         (avr_out_compare, avr_out_plus_1): Also handle fixed-point modes.
6834         (avr_assemble_integer): Ditto.
6835         (output_reload_in_const, output_reload_insisf): Ditto.
6836         (avr_compare_pattern): Skip all modes > 4 bytes.
6837         (avr_2word_insn_p): Skip movuqq_insn, movqq_insn.
6838         (avr_out_fract, avr_out_minus, avr_out_minus64): New functions.
6839         (avr_to_int_mode): New function.
6840         (adjust_insn_length): Handle: ADJUST_LEN_SFRACT,
6841         ADJUST_LEN_UFRACT, ADJUST_LEN_MINUS, ADJUST_LEN_MINUS64.
6842         * config/avr/predicates.md (const0_operand): Allow const_fixed.
6843         (const_operand, const_or_immediate_operand): New.
6844         (nonmemory_or_const_operand): New.
6845         * config/avr/constraints.md (Ynn, Y00, Y01, Y02, Ym1, Ym2, YIJ):
6846         New constraints.
6847         * config/avr/avr.h (LONG_LONG_ACCUM_TYPE_SIZE): Define.
6848
6849 2012-08-23  Kenneth Zadeck <zadeck@naturalbridge.com>
6850
6851         * alias.c (rtx_equal_for_memref_p): Convert constant cases.
6852         * combine.c (find_single_use_1, mark_used_regs_combine): Convert
6853         to CASE_CONST_ANY.
6854         * cse.c (exp_equiv_p, canon_reg, fold_rtx, cse_process_notes_1,
6855         count_reg_usage): Convert constant cases.
6856         * cselib.c (cselib_expand_value_rtx_1): Convert to CASE_CONST_ANY.
6857         (cselib_subst_to_values): Convert constant cases.
6858         * df-scan.c (df_uses_record): Ditto.
6859         * dse.c (const_or_frame_p): Convert case statements to explicit
6860         if-then-else using mode classes.
6861         * emit-rtl.c (verify_rtx_sharing, copy_insn_1): Convert constant cases.
6862         * explow.c (convert_memory_address_addr_space): Ditto.
6863         * gcse.c (want_to_gcse_p, oprs_unchanged_p, compute_transp): Ditto.
6864         * genattrtab.c (attr_copy_rtx, clear_struct_flag): Ditto.
6865         * ira.c (equiv_init_varies_p, contains_replace_regs,
6866         memref_referenced_p, rtx_moveable_p): Ditto.
6867         * jump.c (mark_jump_label_1): Remove constant cases.
6868         (rtx_renumbered_equal_p): Convert to CASE_CONST_UNIQUE.
6869         * loop-invariant.c (check_maybe_invariant, hash_invariant_expr_1,
6870         invariant_expr_equal_p): Convert to CASE_CONST_ANY.
6871         * postreload-gcse.c (oprs_unchanged_p): Convert constant cases.
6872         * reginfo.c (reg_scan_mark_refs): Ditto.
6873         * regrename.c (scan_rtx): Ditto.
6874         * reload1.c (eliminate_regs_1, elimination_effects,
6875         scan_paradoxical_subregs): Ditto.
6876         * reload.c (operands_match_p, subst_reg_equivs):  Ditto.
6877         * resource.c (mark_referenced_resources, mark_set_resources): Ditto.
6878         * rtlanal.c (rtx_unstable_p, rtx_varies_p, count_occurrences)
6879         (reg_mentioned_p, modified_between_p, modified_in_p)
6880         (volatile_insn_p, volatile_refs_p, side_effects_p, may_trap_p_1,
6881         inequality_comparisons_p, computed_jump_p_1): Ditto.
6882         * rtl.c (copy_rtx, rtx_equal_p_cb, rtx_equal_p): Ditto.
6883         * sched-deps.c (sched_analyze_2): Ditto.
6884         * valtrack.c (cleanup_auto_inc_dec): Ditto.
6885         * rtl.h: (CASE_CONST_SCALAR_INT, CASE_CONST_UNIQUE,
6886         CASE_CONST_ANY): New macros.
6887
6888 2012-08-23  Julian Brown  <julian@codesourcery.com>
6889             Sandra Loosemore  <sandra@codesourcery.com>
6890
6891         * config/mips/mips.md
6892         (UNSPEC_CASESI_DISPATCH): New.
6893         (MIPS16_T_REGNUM): New constant.
6894         (tablejump): Don't use for MIPS16_SHORT_JUMP_TABLES.
6895         (casesi): New.
6896         (casesi_internal_mips16_<mode>): New.
6897         * config/mips/mips.c (mips16_split_long_branches): Adjust test
6898         to ignore casesi jump tables.
6899         * config/mips/mips.h (TARGET_MIPS16_SHORT_JUMP_TABLES): Update
6900         comment.
6901         (CASE_VECTOR_MODE): Use SImode unconditionally.
6902         (CASE_VECTOR_SHORTEN_MODE): Define.
6903         (ASM_OUTPUT_ADDR_DIFF_ELT): Output word-sized addr_diff_elts
6904         when necessary for MIPS16_SHORT_JUMP_TABLES.
6905
6906 2012-08-23  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
6907
6908         * config/rs6000/rs6000.c (rs6000_density_test): Free loop body.
6909
6910 2012-08-23  H.J. Lu  <hongjiu.lu@intel.com>
6911
6912         PR driver/54335
6913         * doc/invoke.texi: Add -da and remove -dm.
6914
6915 2012-08-23  Richard Guenther  <rguenther@suse.de>
6916
6917         * tree-vect-stmts.c (vect_finish_stmt_generation): Update
6918         virtual SSA form.
6919
6920 2012-08-23  Jakub Jelinek  <jakub@redhat.com>
6921
6922         * tree.c (copy_node_stat): Clear DECL_STRUCT_FUNCTION.
6923
6924 2012-08-23  Mingjie Xing  <mingjie.xing@gmail.com>
6925
6926         * doc/gty.texi: Fix typo.
6927
6928 2012-08-23  Richard Guenther  <rguenther@suse.de>
6929
6930         * tree-ssa-loop-manip.c (add_exit_phis_var): Allow virtual operands.
6931         (find_uses_to_rename_use): Likewise.
6932         (find_uses_to_rename_bb): Likewise.
6933         (find_uses_to_rename_stmt): Walk over all operands.
6934
6935 2012-08-22  Oleg Endo  <olegendo@gcc.gnu.org>
6936
6937         PR target/54089
6938         * config/sh/predicates (p27_rshift_count_operand,
6939         not_p27_rshift_count_operand): New predicates.
6940         * config/sh/sh.c (sh_ashlsi_clobbers_t_reg_p,
6941         sh_lshrsi_clobbers_t_reg_p, sh_dynamicalize_shift_p): Handle special
6942         case when shift amount is 31.
6943         (gen_ashift): Emit gen_shlr instead of gen_lshrsi3_m.
6944         * config/sh/sh.md (ashlsi3_d): Set type to 'dyn_shift' instead
6945         of 'arith'.
6946         (ashlsi_c): Rename to shll.  Adapt calls to gen_ashlsi_c throughout
6947         the file.
6948         (lshrsi3): Remove clobber from expander.  Use shift_count_operand
6949         instead of nonmemory_operand predicate for second operand.  Add
6950         handling of case lshrsi3_n_clobbers_t.
6951         (lshrsi3_k): Use p27_rshift_count_operand for second operand.
6952         (lshrsi3_d): Make insn_and_split.  Split dynamic shift to constant
6953         shift sequences if beneficial.
6954         (lshrsi3_n): Make insn_and_split.  Split constant shift sequence to
6955         dynamic shift if beneficial.
6956         (lshrsi3_n_clobbers_t): New insn_and_split.
6957         (lshrsi3_m): Delete.
6958
6959 2012-08-22  Steven Bosscher  <steven@gcc.gnu.org>
6960
6961         * tracer.c (mark_bb_seen): Use SBITMAP_SIZE.
6962
6963         * alias.c (MAX_ALIAS_LOOP_PASSES): Update comment with rationale,
6964         or rather a lack thereof.
6965         (init_alias_analysis): Propagate the latest information across
6966         the CFG in topological order to propagate as far as possible in
6967         each iteration.  Ignore debug insns.
6968
6969 2012-08-22  H.J. Lu  <hongjiu.lu@intel.com>
6970
6971         * doc/invoke.texi: Document -mlong-double-64/-mlong-double-80.
6972
6973         * config/i386/i386.c (flag_opts): Add -mlong-double-64.
6974         (TARGET_HAS_BIONIC): Default long double to 64-bit for Bionic.
6975
6976         * config/i386/i386.h (LONG_DOUBLE_TYPE_SIZE): Use 64 if
6977         TARGET_LONG_DOUBLE_64 is true.
6978         (LIBGCC2_LONG_DOUBLE_TYPE_SIZE): New macro.
6979         (WIDEST_HARDWARE_FP_SIZE): Defined to 80.
6980
6981         * config/i386/i386.opt (mlong-double-80): New option.
6982         (mlong-double-64): Likewise.
6983
6984         * config/i386/i386-c.c (ix86_target_macros): Define
6985         __LONG_DOUBLE_64__ for TARGET_LONG_DOUBLE_64.
6986
6987 2012-08-22  H.J. Lu  <hongjiu.lu@intel.com>
6988
6989         PR target/54347
6990         * config/i386/i386.c (ix86_split_to_parts): Replace
6991         REAL_VALUE_TO_TARGET_LONG_DOUBLE with real_to_target.
6992
6993 2012-08-22  Richard Guenther  <rguenther@suse.de>
6994
6995         * tree-vectorizer.c (vectorize_loops): Do not call
6996         mark_virtual_operands_for_renaming.
6997         * tree-vect-slp.c (vect_slp_transform_bb): Likewise.
6998         Do not update SSA form here.
6999
7000 2012-08-22  Dodji Seketeli  <dodji@redhat.com>
7001
7002         * tree.h (TREE_NOTHROW): Use the base.nothrow_flag.
7003
7004 2012-08-22  Richard Guenther  <rguenther@suse.de>
7005
7006         PR tree-optimization/46590
7007         * tree-ssa-alias.h (get_continuation_for_phi): Add alias query
7008         counter output argument.
7009         (walk_non_aliased_vuses): Add alias query counter argument
7010         to the walker callback.
7011         * tree-ssa-alias.c (maybe_skip_until): Add alias query counter
7012         output argument and count alias queries.
7013         (get_continuation_for_phi_1): Likewise.
7014         (get_continuation_for_phi): Likewise.
7015         (walk_non_aliased_vuses): Add alias query counter argument
7016         to the walker callback and allow it to abort the walk by
7017         returning -1.
7018         * tree-ssa-pre.c (translate_vuse_through_block): Adjust.
7019         * tree-ssa-sccvn.c (vn_reference_lookup_2): Add alias query
7020         counter parmeter, abort walk if that is bigger than
7021         --param sccvn-max-alias-queries-per-access.
7022         * params.def (sccvn-max-alias-queries-per-access): New param.
7023         * doc/invoke.texi (sccvn-max-alias-queries-per-access): Document.
7024
7025 2012-08-22  Richard Guenther  <rguenther@suse.de>
7026
7027         * tree-ssa-loop-ch.c (copy_loop_headers): Remove redundant checking.
7028         * tree-into-ssa.c (initialize_flags_in_bb): Use gcc_checking_assert
7029         instead of gcc_assert.
7030         (mark_block_for_update): Likewise.
7031         (add_new_name_mapping): Likewise.
7032         (mark_def_sites): Likewise.
7033         (insert_phi_nodes_for): Likewise.
7034         (rewrite_debug_stmt_uses): Likewise.
7035         (rewrite_stmt): Likewise.
7036         (maybe_register_def): Likewise.
7037         (rewrite_update_phi_arguments): Likewise.
7038         (rewrite_update_enter_block): Likewise.
7039         (mark_def_interesting): Likewise.
7040         (prepare_def_site_for): Likewise.
7041         (insert_updated_phi_nodes_for): Likewise.
7042
7043 2012-08-22  Jakub Jelinek  <jakub@redhat.com>
7044
7045         * tree-vect-loop.c (vect_transform_loop): Initialize
7046         check_profitability to false.
7047
7048         * tree-predcom.c (try_combine_chains): Free the worklist vector
7049         at the end.
7050
7051 2012-08-22  Marc Glisse  <marc.glisse@inria.fr>
7052
7053         PR tree-optimization/54317
7054         * tree-vrp.c (extract_range_from_binary_expr_1): Test for
7055         double_int overflow.
7056         Remove dead tests.
7057
7058 2012-08-22  Jakub Jelinek  <jakub@redhat.com>
7059
7060         * tree-vrp.c (find_assert_locations): Skip also edges
7061         from the entry block.
7062
7063         * tree-vect-loop-manip.c (slpeel_make_loop_iterate_ntimes): Call
7064         free_stmt_vec_info on orig_cond after gsi_removing it.
7065         * tree-vect-data-refs.c (vect_enhance_data_refs_alignment): Always
7066         free body_cost_vec vector.
7067         (vect_analyze_data_refs): If gather is unsuccessful,
7068         free_data_ref (dr).
7069         * tree-inline.c (tree_function_versioning): Free
7070         old_transforms_to_apply vector.
7071
7072 2012-08-22  Steven Bosscher  <steven@gcc.gnu.org>
7073
7074         * tree-ssa-coalesce.c (struct ssa_conflicts_d): Make contents
7075         of this a VEC and add a bitmap obstack.
7076         (ssa_conflicts_new): Allocate the obstack and grow the VEC cleared
7077         to the right size.
7078         (ssa_conflicts_delete): Free the VEC and release the obstack.
7079         (ssa_conflicts_test_p, ssa_conflicts_test_p, ssa_conflicts_add_one,
7080         ssa_conflicts_merge, ssa_conflicts_dump): Update for above changes.
7081         (truct live_track_d): Add another bitmap obstack here.
7082         (new_live_track): Initialize it and use it for all bitmaps.
7083         (delete_live_track): Don't free the bitmaps one at a time, just
7084         release the obstack.
7085         (create_outofssa_var_map): Fix to conform to GCC code style rules.
7086
7087 2012-08-21  Nathan Froyd  <froydnj@gcc.gnu.org>
7088
7089         * config/m32c/constraints.md: New file.
7090         * config/m32c/t-m32c (MD_FILES): Add constraints.
7091         * config/m32c/m32c-protos.h (m32c_const_ok_for_constraint_p): Delete.
7092         (m32c_extra_address_constraint, m32c_extra_memory_constraint): Delete.
7093         (m32c_reg_class_from_constraint): Delete.
7094         (m32c_extra_constraint_p, m32c_extra_constraint_p2): Delete.
7095         (m32c_matches_constraint_p): Declare.
7096         * config/m32c/m32c.h (CONSTRAINT_LEN): Delete.
7097         (REG_CLASS_FROM_CONSTRAINT): Delete.
7098         (CONST_OK_FOR_CONSTRAINT_P): Delete.
7099         (CONST_DOUBLE_OK_FOR_CONSTRAINT_P): Delete.
7100         (EXTRA_CONSTRAINT_STR): Delete.
7101         (EXTRA_MEMORY_CONSTRAINT, EXTRA_ADDRESS_CONSTRAINT): Delete.
7102         * config/m32c/m32c.c: Include tm-constrs.h
7103         (m32c_reg_class_from_constraint): Delete.
7104         (m32c_const_ok_for_constraint_p): Delete.
7105         (m32c_extra_constraint_p2): Rename to...
7106         (m32c_matches_constraint_p): ...this.  Make it return bool.  Tweak
7107         formatting.
7108         (m32c_extra_constraint_p): Delete.
7109         (m32c_extra_address_constraint, m32c_extra_memory_constraint): Delete.
7110         (m32c_split_move): Use satisfies_constraint_Ss.
7111         * config/m32c/predicates.md (memsym_operand): Use
7112         satisfies_constraint_Si.
7113         (memimmed_operand): Use satisfies_constraint_Sp.
7114         (m32c_psi_scale, m32c_1bit8_operand): Use satisfies_constraint_Ilb.
7115         (m32c_1bit16_operand): Use satisfies_constraint_Ilw.
7116         (m32c_1mask8_operand): Use satisfies_constraint_ImB.
7117         (m32c_1mask16_operand): Use satisfies_constraint_Imw.
7118
7119 2012-08-21  Nathan Froyd  <froydnj@gcc.gnu.org>
7120
7121         * config/mep/mep.h (REG_CLASS_FROM_CONSTRAINT): Delete.
7122         (CONST_OK_FOR_LETTER_P, CONST_DOUBLE_OK_FOR_LETTER_P): Delete.
7123         (CONSTRAINT_LEN, EXTRA_CONSTRAINT): Delete.
7124         * config/mep/mep.c (mep_reg_class_from_constraint): Delete.
7125         (mep_const_ok_for_letter_p, mep_extra_constraint): Delete.
7126         * config/mep/mep-protos.h (mep_reg_class_from_constraint): Delete.
7127         (mep_const_ok_for_letter_p, mep_extra_constraint): Delete.
7128
7129 2012-08-21  Oleg Endo  <olegendo@gcc.gnu.org>
7130
7131         * config/sh/sh.md (cmpeqdi_t, cmpgtdi_t, cmpgedi_t, cmpgeudi_t,
7132         cmpgtudi_t, *movsicc_t_false, *movsicc_t_true, divsi_inv20, negsi_cond,
7133         truncdihi2, ic_invalidate_line_i, ic_invalidate_line_sh4a,
7134         ic_invalidate_line_media, movdf_i4, calli_pcrel, call_valuei,
7135         call_valuei_pcrel, sibcalli_pcrel, sibcall_compact,
7136         sibcall_valuei_pcrel, sibcall_value_compact, casesi_worker_1,
7137         casesi_worker_2, bandreg_m2a, borreg_m2a, bxorreg_m2a, sp_switch_1,
7138         sp_switch_2, stack_protect_set_si, stack_protect_set_si_media,
7139         stack_protect_set_di_media, stack_protect_test_si,
7140         stack_protect_test_si_media, stack_protect_test_di_media): Convert to
7141         multi-line asm output strings.
7142         (divsi_inv_qitable, divsi_inv_hitable): Use single-alternative asm
7143         output.
7144         (*andsi3_bclr, rotldi3_mextr, rotrdi3_mextr, calli,
7145         call_valuei_tbr_rel, movml_push_banked, movml_pop_banked, bclr_m2a,
7146         bclrmem_m2a, bset_m2a, bsetmem_m2a, bst_m2a, bld_m2a, bldsign_m2a,
7147         bld_reg, *bld_regqi, band_m2a, bor_m2a, bxor_m2a, mextr_rl, *mextr_lr):
7148         Use tab char instead of '\\t'.
7149         (iordi3): Use braced string.
7150         (*movsi_pop): Use tab chars instead of spaces.
7151
7152 2012-08-21  Oleg Endo  <olegendo@gcc.gnu.org>
7153
7154         PR target/39423
7155         * config/sh/sh.md (*movhi_index_disp): Add support for SH2A
7156         movu.w insn.
7157
7158 2012-08-21  H.J. Lu  <hongjiu.lu@intel.com>
7159
7160         PR middle-end/54332
7161         * df-scan.c (df_bb_verify): Restore df_free_collection_rec call
7162         inside the insn traversal loop.
7163
7164         * vec.h (vec_reserve): Remove the stack allocation check.
7165
7166 2012-08-21  Marc Glisse  <marc.glisse@inria.fr>
7167
7168         * fold-const.c (fold_ternary_loc): Detect identity permutations.
7169         Canonicalize permutations more.
7170         * tree-ssa-forwprop.c (is_combined_permutation_identity): New function.
7171         (simplify_permutation): Likewise.
7172         (ssa_forward_propagate_and_combine): Call it.
7173
7174 2012-08-21  Richard Guenther  <rguenther@suse.de>
7175
7176         * tree-ssa-loop-im.c (tree_ssa_lim_finalize): Properly free
7177         the affine expansion cache.
7178         * tree-ssa-dom.c (free_expr_hash_elt_contents): New function,
7179         split out from ...
7180         (free_expr_hash_elt): ... this one.
7181         (record_cond): Properly free a not needed hashtable element.
7182         (lookup_avail_expr): Likewise.
7183         * tree-into-ssa.c (init_ssa_renamer): Specify a free function
7184         for the var_infos hashtable.
7185         (update_ssa): Likewise.
7186
7187 2012-08-21  Richard Guenther  <rguenther@suse.de>
7188
7189         * alloc-pool.c (pool_alloc): Fix valgrind annotation.
7190         * tree.h: Fix typo and complete flags documentation.
7191
7192 2012-08-21  Richard Guenther  <rguenther@suse.de>
7193
7194         * tree.h (struct tree_base): Add union to make it possible to
7195         re-use the upper 4 bytes for tree codes that do not need as
7196         many flags as others.  Move visited and default_def_flag to
7197         common bits section in exchange for saturating_flag and
7198         unsigned_flag.  Add SSA name version and tree vec length
7199         fields here.
7200         (struct tree_vec): Remove length field here.
7201         (struct tree_ssa_name): Remove version field here.
7202
7203 2012-08-20  Jan Hubicka  <jh@suse.cz>
7204
7205         PR fortran/48636
7206         * ipa-inline.c (want_inline_small_function_p): Take loop_iterations
7207         hint.
7208         (edge_badness): Likewise.
7209         * ipa-inline.h (inline_hints_vals): Add INLINE_HINT_loop_iterations.
7210         (inline_summary): Add loop_iterations.
7211         * ipa-inline-analysis.c: Include tree-scalar-evolution.h.
7212         (dump_inline_hints): Dump loop_iterations.
7213         (reset_inline_summary): Free loop_iterations.
7214         (inline_node_duplication_hook): Update loop_iterations.
7215         (dump_inline_summary): Dump loop_iterations.
7216         (will_be_nonconstant_expr_predicate): New function.
7217         (estimate_function_body_sizes): Analyze loops.
7218         (estimate_node_size_and_time): Set hint loop_iterations.
7219         (inline_merge_summary): Merge loop iterations.
7220         (inline_read_section): Stream in loop_iterations.
7221         (inline_write_summary): Stream out loop_iterations.
7222
7223 2012-08-20  Oleg Endo  <olegendo@gcc.gnu.org>
7224
7225         PR target/54089
7226         * config/sh/sh.md (rotcr, *rotcr, shar, shlr): New insns and splits.
7227         (ashrdi3_k, lshrdi3_k): Rewrite as insn_and_split.
7228         * config/sh/sh.c (sh_lshrsi_clobbers_t_reg_p): New function.
7229         * config/sh/sh-protos.h (sh_lshrsi_clobbers_t_reg_p): Declare it.
7230
7231 2012-08-20  Oleg Endo  <olegendo@gcc.gnu.org>
7232
7233         PR target/51244
7234         * config/sh/sh.md (*cset_zero): New insns.
7235
7236 2012-08-20  Mark Wielaard  <mjw@redhat.com>
7237
7238         * dwarf2out.h (enum dw_val_class): Add dw_val_class_high_pc.
7239         * dwarf2out.c (dw_val_equal_p): Handle dw_val_class_high_pc.
7240         (add_AT_low_high_pc): New function.
7241         (AT_lbl): Handle dw_val_class_high_pc.
7242         (print_die): Likewise.
7243         (attr_checksum): Likewise.
7244         (attr_checksum_ordered): Likewise.
7245         (same_dw_val_p): Likewise.
7246         (size_of_die): Likewise.
7247         (value_format): Likewise.
7248         (output_die): Likewise.
7249         (gen_subprogram_die): Use add_AT_low_high_pc.
7250         (add_high_low_attributes): Likewise.
7251         (dwarf2out_finish): Likewise.
7252
7253 2012-08-20  Jakub Jelinek  <jakub@redhat.com>
7254
7255         PR rtl-optimization/54294
7256         * fwprop.c (all_uses_available_at): Ignore debug insns in between
7257         def_insn and target_insn when checking whether the shortcut is
7258         possible.
7259
7260 2012-08-20  Eric Botcazou  <ebotcazou@adacore.com>
7261
7262         * config/sparc/sparc.h (MAX_FIXED_MODE_SIZE): Define.
7263
7264 2012-08-20  Patrick Marlier  <patrick.marlier@gmail.com>
7265
7266         PR middle-end/53992
7267         * omp-low.c (lower_omp_1): Handle GIMPLE_TRANSACTION.
7268
7269 2012-08-20  Richard Earnshaw  <rearnsha@arm.com>
7270
7271         PR tree-ssa/54295
7272         * tree-ssa-math-opts.c (is_widening_mult_rhs_p): Delete rhs_code
7273         declaration and setter.
7274
7275 2012-08-20  Richard Earnshaw  <rearnsha@arm.com>
7276
7277         PR tree-ssa/54295
7278         * tree-ssa-math-opts.c (widening_mult_conversion_strippable_p):
7279         New function.
7280         (is_widening_mult_rhs_p): Use it.
7281
7282 2012-08-20  Joseph Myers  <joseph@codesourcery.com>
7283
7284         * configure.ac (ffs): Check for declaration.
7285         * configure, config.in: Regenerate.
7286
7287 2012-08-20  Richard Guenther  <rguenther@suse.de>
7288
7289         * tree-flow.h (register_new_name_mapping): Remove.
7290         * tree-into-ssa.c (register_new_name_mapping): Likewise.
7291         (add_new_name_mapping): Do not push/pop timevar here.
7292         (create_new_def_for): Instead do it here.  Initialize
7293         update-ssa here, handle a NULL def.
7294         * tree-vrp.c (build_assert_expr_for): Use create_new_def_for.
7295
7296 2012-08-20  Richard Guenther  <rguenther@suse.de>
7297
7298         PR tree-optimization/54327
7299         * gimple-fold.c (get_maxval_strlen): Do not walk use-def chains
7300         if the use is registered for SSA update.
7301
7302 2012-08-20  Jakub Jelinek  <jakub@redhat.com>
7303
7304         PR tree-optimization/54321
7305         * tree-ssa-forwprop.c (simplify_builtin_call): Pass 0 instead of 1
7306         as second argument to tree_low_cst call on val2.
7307
7308 2012-08-20  Richard Guenther  <rguenther@suse.de>
7309
7310         * gimple.h (gimple_statement_base): Annotate with GTY chain_next.
7311
7312 2012-08-20  Richard Guenther  <rguenther@suse.de>
7313
7314         PR bootstrap/54326
7315         * genoutput.c (note_constraint): Properly use CONST_CAST.
7316
7317 2012-08-19  Nick Clifton  <nickc@redhat.com>
7318
7319         PR target/54306
7320         * config/arm/mmintrin.h: Remove spurious #endif.
7321
7322 2012-08-18  Jan-Benedict Glaw  <jbglaw@lug-owl.de>
7323
7324         * config/avr/avr-log.c (avr_log_vadump): Properly use
7325         int-promoted enum values.
7326         * config/avr/avr.h (struct mcu_type_s): Change `arch' from
7327         int to enum avr_arch.
7328         * config/avr/gen-avr-mmcu-texi.c (main): Use correct initializer.
7329
7330 2012-08-18  Jan Hubicka  <jh@suse.cz>
7331
7332         PR lto/45375
7333         * ipa-inline.c (want_inline_small_function_p): Bypass
7334         inline limits for hinted functions.
7335         (edge_badness): Dump hints; decrease badness for hinted funcitons.
7336         * ipa-inline.h (enum inline_hints_vals): New enum.
7337         (inline_hints): New type.
7338         (edge_growth_cache_entry): Add hints.
7339         (dump_inline_summary): Update.
7340         (dump_inline_hints): Declare.
7341         (do_estimate_edge_hints): Declare.
7342         (estimate_edge_hints): New inline function.
7343         (reset_edge_growth_cache): Update.
7344         * predict.c (cgraph_maybe_hot_edge_p): Do not ice on indirect edges.
7345         * ipa-inline-analysis.c (dump_inline_hints): New function.
7346         (estimate_edge_devirt_benefit): Return true when function should be
7347         hinted.
7348         (estimate_calls_size_and_time): New hints argument; set it when
7349         devritualization happens.
7350         (estimate_node_size_and_time): New hints argument.
7351         (do_estimate_edge_time): Cache hints.
7352         (do_estimate_edge_growth): Update.
7353         (do_estimate_edge_hints): New function
7354
7355 2012-08-18  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
7356
7357         PR middle-end/53823
7358         * expmed.c (expand_mult): Skip synth_mult for negative coefficients
7359         if the mode is larger than a wide int and it is too costly to multiply
7360         by a positive multiplier and negate the result.
7361
7362 2012-08-18  Steven Bosscher  <steven@gcc.gnu.org>
7363
7364         * sparseset.c (sparseset_alloc): Use non-clearing allocation.  Tell
7365         valgrind not to worry about reading from unitialized memory.
7366
7367 2012-08-18  Steven Bosscher  <steven@gcc.gnu.org>
7368
7369         PR middle-end/54313
7370         * dse.c (dse_step7): Don't free kill_on_calls bitmap, it is
7371         freed when its obstack is release.
7372
7373 2012-08-18  Andrew Pinski  <pinskia@gmail.com>
7374
7375         * alloc-pool.c (pool_alloc): Add valgrind markers.
7376         (pool_free): Likewise.
7377
7378 2012-08-17  Walter Lee  <walt@tilera.com>
7379
7380         * config/tilegx/feedback.h (FEEDBACK_ENTER_EXPLICIT): Define.
7381         (FEEDBACK_ENTER): Define.
7382         (FEEDBACK_REENTER): Define.
7383         (FEEDBACK_ENTRY): Define.
7384         * config/tilepro/feedback.h: (FEEDBACK_ENTER_EXPLICIT): Define.
7385         (FEEDBACK_ENTER): Define.
7386         (FEEDBACK_REENTER): Define.
7387         (FEEDBACK_ENTRY): Define.
7388
7389 2012-08-17  H.J. Lu  <hongjiu.lu@intel.com>
7390             Gary Funck <gary@intrepid.com>
7391
7392         PR target/20020
7393         * config/i386/i386.c (ix86_member_type_forces_blk): New function.
7394         (TARGET_MEMBER_TYPE_FORCES_BLK): New macro.
7395
7396         * config/i386/i386.h (MAX_FIXED_MODE_SIZE): New macro.
7397
7398 2012-08-17  Marc Glisse  <marc.glisse@inria.fr>
7399
7400         * simplify-rtx.c (simplify_binary_operation_1): Optimize shuffle of
7401         a concatenation.
7402
7403 2012-08-17  H.J. Lu  <hongjiu.lu@intel.com>
7404
7405         * stor-layout.c (compute_record_mode): Replace
7406         MEMBER_TYPE_FORCES_BLK with targetm.member_type_forces_blk.
7407         (layout_type): Likewise.
7408
7409         * system.h: Poison MEMBER_TYPE_FORCES_BLK.
7410
7411         * target.def (member_type_forces_blk): New target hook.
7412
7413         * targhooks.c (default_member_type_forces_blk): New.
7414         * targhooks.h (default_member_type_forces_blk): Likewise.
7415
7416         * doc/tm.texi.in (MEMBER_TYPE_FORCES_BLK): Removed.
7417         (TARGET_MEMBER_TYPE_FORCES_BLK): New hook.
7418         * doc/tm.texi: Regenerated.
7419
7420         * config/ia64/hpux.h (MEMBER_TYPE_FORCES_BLK): Removed.
7421
7422         * config/ia64/ia64.c (ia64_member_type_forces_blk): New function.
7423         (TARGET_MEMBER_TYPE_FORCES_BLK): New macro.
7424
7425         * config/rs6000/rs6000.c (TARGET_MEMBER_TYPE_FORCES_BLK): New macro.
7426         (rs6000_member_type_forces_blk): New function.
7427
7428         * config/rs6000/rs6000.h (MEMBER_TYPE_FORCES_BLK): Removed.
7429
7430         * config/xtensa/xtensa.c (xtensa_member_type_forces_blk): New function.
7431         (TARGET_MEMBER_TYPE_FORCES_BLK): New macro.
7432
7433         * config/xtensa/xtensa.h (MEMBER_TYPE_FORCES_BLK): Removed.
7434
7435 2012-08-17  Diego Novillo  <dnovillo@google.com>
7436
7437         PR bootstrap/54281
7438         * configure.ac: Add libintl.h to AC_CHECK_HEADERS list.
7439         * config.in: Regenerate.
7440         * configure: Regenerate.
7441         * intl.h: Always include libintl.h if HAVE_LIBINTL_H is set.
7442
7443 2012-08-17  Richard Guenther  <rguenther@suse.de>
7444
7445         * bitmap.h (struct bitmap_element_def): GTY annotate next/prev.
7446         (struct bitmap_head_def): GTY skip current field.
7447
7448 2012-08-17  Steven Bosscher  <steven@gcc.gnu.org>
7449
7450         PR middle-end/54146
7451         * tree-ssa-loop-im.c (lim_bitmap_obstack): New bitmap_obstack.
7452         (memref_free): Don't free the bitmaps individually here.
7453         (mem_ref_alloc): Allocate the bitmaps on the new bitmap obstack.
7454         (analyze_memory_references): Likewise.
7455         (tree_ssa_lim_initialize): Initialize the new bitmap obstack.
7456         (tree_ssa_lim_finalize): Release it.
7457         * dse.c (dse_bitmap_obstack): New bitmap obstack.
7458         (dse_obstack): New obstack.
7459         (get_group_info): Allocate the bitmaps on the new bitmap obstack.
7460         (dse_step0): Allocate the scratch bitmap on reg_obstack.  Initialize
7461         the new bitmap obstack and normal obstack.  Use XNEWVEC for bb_table.
7462         (record_store): Allocate regs_set on reg_obstack.
7463         (dse_step1): Allocate regs_live on reg_obstack.
7464         (dse_step2_init): Allocate offset_map_n and offset_map_p on the new
7465         obstack.
7466         (dse_step3_scan): Allocate bitmaps on the new bitmap obstack.
7467         (dse_step3): Likewise.
7468         (dse_confluence_0): Likewise.
7469         (dse_confluence_n): Likewise.
7470         (dse_transfer_function): Likewise.
7471         (dse_step7): Destroy the new obstacks, and everything allocated on
7472         them, in one big sweep.
7473         (rest_of_handle_dse): Update.
7474         * cfgexpand.c (stack_var_bitmap_obstack): New bitmap obstack.
7475         (add_stack_var_conflict): Allocate bitmaps on it.
7476         (add_scope_conflicts_1): Likewise.
7477         (add_scope_conflicts): Likewise.
7478         (update_alias_info_with_stack_vars): Likewise.
7479         (init_vars_expansion): Move TREE_USED fiddling expand_used_vars.
7480         Initialize the new bitmap obstack.
7481         (fini_vars_expansion): Release it.
7482         (estimated_stack_frame_size): Use init_vars_expansion to set things up
7483         and always clean up at the end.
7484         (expand_used_vars): Do the TREE_USED trickery here.  Always call
7485         fini_vars_expansion.
7486         * tree-ssa-live.h (struct tree_live_info_d): Make livein and liveout
7487         arrays of bitmap_head to avoid one indirection per bitmap access.
7488         (live_on_entry, live_on_exit, live_var_map, live_merge_and_clear,
7489         make_live_on_entry): Update.
7490         * tree-ssa-live.c (partition_view_bitmap): Don't double-free 'used'.
7491         (liveness_bitmap_obstack): New bitmap obstack.
7492         (remove_unused_locals): Use it to allocate all bitmaps on.  Update
7493         for livein/liveout changes in tree-ssa-live.h.
7494         (delete_tree_live_info): Release the bitmap obstack.
7495         (loe_visit_block, live_worklist, set_var_live_on_entry,
7496         calculate_live_on_exit, dump_live_info): Update.
7497         (calculate_live_ranges): Initialize the bitmap.
7498         * tree-ssa-ter.c (ter_bitmap_obstack): New bitmap obstack.
7499         (new_temp_expr_table): Allocate bitmap on it.
7500         (make_dependent_on_partition, add_to_partition_kill_list,
7501         add_dependence, process_replaceable): Likewise.
7502         (find_replaceable_exprs): Initialize and release the new obstack here.
7503         * df-problems.c (df_lr_add_problem): Allocate persistent bitmap
7504         for out_of_date_transfer_functions on df_bitmap_obstack.
7505         (df_live_add_problem): Likewise.
7506         (df_chain_add_problem): Likewise.
7507         (df_word_lr_add_problem): Likewise.
7508
7509 2012-08-17  Nick Clifton  <nickc@redhat.com>
7510
7511         * config/fr30/fr30.md (cbranchsi4): Remove mode from comparison.
7512         (branch_true): Likewise.
7513         (branch_false): Likewise.
7514
7515         * config/mcore/mcore.md (cbranchsi4): Remove mode from comparison.
7516
7517         * config/iq2000/iq2000.md (cbranchsi4): Remove mode from
7518         comparison and label.
7519         (branch_zero): Likewise.
7520         (branch_zero_inverted): Likewise.
7521         (branch_equality): Likewise.
7522         (branch_equality_inverted): Likewise.
7523         (extend-and-compare): Disable until reload issues can be resolved.
7524         * config/iq2000/iq2000.c (gen_conditional_branch): Use VOIDmode
7525         for comparison.
7526         (iq2000_function_arg_advance): Remove CONST_CAST2.
7527
7528         * config/mep/t-mep (mep-pragma.o): Use $(COMPILER) to compile
7529         mep-pragma.c.
7530
7531 2012-08-17  Georg-Johann Lay  <avr@gjlay.de>
7532
7533         * config/avr/t-avr (gen-avr-mmcu-texi): Use $(CC) to compile
7534         gen-avr-mmcu-texi.c.
7535
7536 2012-08-17  Richard Earnshaw  <rearnsha@arm.com>
7537
7538         * arm.md (arm_addsi3): New variant for Thumb2 16-bit ADD instruction.
7539         * arm.c (thumb2_reorg): Don't convert an ADD instruction that's
7540         already 16 bits.
7541
7542 2012-08-17  Richard Guenther  <rguenther@suse.de>
7543
7544         * hash-table.h (class hash_table): Use a descriptor template
7545         argument instead of decomposed element type and support functions.
7546         (struct pointer_hash): New generic typed pointer-hash.
7547         (struct typed_free_remove, struct typed_noop_remove): Generic
7548         hash_table support pieces.
7549         * coverage.c (struct counts_entry): Add hash_table support members.
7550         * tree-ssa-ccp.c (gimple_htab): Use pointer_hash.
7551         * tree-ssa-coalesce.c (struct ssa_name_var_hash): New generic
7552         SSA name by SSA_NAME_VAR hash.
7553         (coalesce_ssa_name): Use it.
7554         * tree-ssa-pre.c (struct pre_expr_d): Add hash_table support.
7555         (expression_to_id): Adjust.
7556         (struct expr_pred_trans_d): Add hash_table support.
7557         (phi_translate_table): Adjust.
7558         (phi_trans_lookup): Likewise.
7559         (phi_trans_add): Likewise.
7560         (do_regular_insertion): Likewise.
7561         * tree-ssa-tail-merge.c (struct same_succ_def): Add hash_table support.
7562         (same_succ_htab): Adjust.
7563         (find_same_succ_bb): Likewise.
7564         (find_same_succ): Likewise.
7565         (update_worklist): Likewise.
7566         * tree-ssa-threadupdate.c (struct redirection_data): Add hash_table
7567         support.
7568         (redirection_data): Adjust.
7569
7570 2012-08-17  Richard Guenther  <rguenther@suse.de>
7571
7572         * params.def (integer-share-limit): Decrease from 256 to 251,
7573         add rationale.
7574
7575 2012-08-17  Richard Guenther  <rguenther@suse.de>
7576
7577         * tree-sra.c (modify_function): Free redirect_callers vector.
7578         * ipa-split.c (split_function): Free args_to_pass vector.
7579         * tree-vect-data-refs.c (vect_peeling_hash_get_lowest_cost): Free
7580         body_cost_vec properly.
7581         (vect_enhance_data_refs_alignment): Likewise.
7582         * tree-vect-stmts.c (vectorizable_operation): Do not pre-allocate
7583         vec_oprnds.
7584         (new_stmt_vec_info): Do not pre-allocate STMT_VINFO_SAME_ALIGN_REFS.
7585         * tree-vect-slp.c (vect_free_slp_instance): Free the instance.
7586         (vect_analyze_slp_instance): Free everything.
7587         (destroy_bb_vec_info): Free the SLP instances.
7588
7589 2012-08-17  Iain Sandoe  <iain@codesourcery.com>
7590
7591         * config/rs6000/rs6000.c (macho_branch_islands): Adjust for changes
7592         to vec.h.
7593
7594 2012-08-17  Jakub Jelinek  <jakub@redhat.com>
7595
7596         * doc/invoke.texi (-Wsizeof-pointer-memaccess): Document.
7597
7598 2012-08-16  Sandra Loosemore  <sandra@codesourcery.com>
7599
7600         * config/mips/mips-dsp.md (mips_dpau_h_qbl, mips_dpau_h_qbr)
7601         (mips_dpsu_h_qbl, mips_dpsu_h_qbr, mips_dpaq_s_w_ph)
7602         (mips_dpsq_s_w_ph, mips_mulsaq_s_w_ph, mips_dpaq_sa_l_w)
7603         (mips_dpsq_sa_l_w, mips_maq_s_w_phl, mips_maq_s_w_phr)
7604         (mips_maq_sa_w_phl, mips_maq_sa_w_phr): Add accum_in attribute.
7605
7606 2012-08-16  Oleg Endo  <olegendo@gcc.gnu.org>
7607
7608         PR target/54236
7609         * config/sh/sh.md (addc): Add commutative modifier.
7610         (*addc, *minus_plus_one, *subc, *negc): New insns and splits.
7611
7612 2012-08-16  Oleg Endo  <olegendo@gcc.gnu.org>
7613
7614         PR target/39423
7615         * config/sh/sh.md (*movsi_index_disp, *movhi_index_disp): Handle
7616         potential T_REG clobber.  Convert zero extending split to
7617         insn_and_split.
7618
7619 2012-08-16  Oleg Endo  <olegendo@gcc.gnu.org>
7620
7621         PR target/54089
7622         * config/sh/sh.md (ashlsi3_d): Do not split if it would result
7623         in a T_REG clobber.  Correct comment.
7624         (ashlsi3_n): Correct comment.
7625
7626 2012-08-16  Hans-Peter Nilsson  <hp@axis.com>
7627
7628         PR middle-end/54261
7629         * optabs.c (expand_atomic_fetch_op): Save and restore code when
7630         retrying after failed attempt.
7631
7632 2012-08-16  Yuri Rumyantsev  <ysrumyan@gmail.com>
7633
7634         * config/i386/i386-protos.h (ix86_split_lea_for_addr) : Add
7635         additional argument.
7636         * config/i386/i386.md (ix86_split_lea_for_addr) : Add
7637         additional argument curr_insn.
7638         * config/i386/i386.c (ix86_split_lea_for_addr): Load base or index
7639         register first, depending on their defintion distances.
7640         (ix86_lea_outperforms): Prefer LEA only if split cost exceeds
7641         AGU stall.
7642         (find_nearest_reg-def): New function. Find register with
7643         nearest definition.
7644
7645 2012-08-16  Walter Lee  <walt@tilera.com>
7646
7647         * config.gcc (tilegx-*-linux*): Add feedback.h.
7648         (tilepro-*-linux*): Likewise.
7649         * config/tilegx/feedback.h: New file.
7650         * config/tilepro/feedback.h: New file.
7651
7652 2012-08-16  Diego Novillo  <dnovillo@google.com>
7653
7654         Revert
7655
7656         PR bootstrap/54281
7657         * double-int.h: Move including of gmp.h ...
7658         * system.h: ... here.
7659         * realmpfr.h: Do not include gmp.h.
7660         * tree-ssa-loop-niter.c: Do not include gmp.h.
7661
7662 2012-08-16  Segher Boessenkool  <segher@kernel.crashing.org>
7663
7664         * config/rs6000/darwin.h (TARGET_IEEE_QUAD): Fix comment.
7665
7666 2012-08-16  Richard Guenther  <rguenther@suse.de>
7667
7668         PR middle-end/54146
7669         * tree-ssa-loop-niter.c (find_loop_niter_by_eval): Free the
7670         exit vector.
7671         * ipa-pure-const.c (analyze_function): Use FOR_EACH_LOOP_BREAK.
7672         * cfgloop.h (FOR_EACH_LOOP_BREAK): Fix.
7673         * tree-ssa-structalias.c (handle_lhs_call): Properly free rhsc.
7674         * tree-into-ssa.c (get_ssa_name_ann): Allocate info only when needed.
7675         * tree-ssa-loop-im.c (analyze_memory_references): Adjust.
7676         (tree_ssa_lim_finalize): Free all mem_refs.
7677         * tree-ssa-sccvn.c (extract_and_process_scc_for_name): Free
7678         scc when bailing out.
7679         * modulo-sched.c (sms_schedule): Use FOR_EACH_LOOP_BREAK.
7680         * ira-build.c (loop_with_complex_edge_p): Free loop exit vector.
7681         * graphite-sese-to-poly.c (scop_ivs_can_be_represented): Use
7682         FOR_EACH_LOOP_BREAK.
7683
7684 2012-08-16  Diego Novillo  <dnovillo@google.com>
7685
7686         PR bootstrap/54281
7687         * double-int.h: Move including of gmp.h ...
7688         * system.h: ... here.
7689         * realmpfr.h: Do not include gmp.h.
7690         * tree-ssa-loop-niter.c: Do not include gmp.h.
7691
7692 2012-08-16  Steven Bosscher  <steven@gcc.gnu.org>
7693
7694         PR middle-end/54146
7695         * tree-flow.h (compute_global_livein): Remove prototype.
7696         * tree-into-ssa.c (compute_global_livein): Remove function.
7697         * tree-ssa-loop-manip.c: Include gimple-pretty-print.h.
7698         (find_sibling_superloop): New function.
7699         (compute_live_loop_exits): New function.
7700         (add_exit_phis_edge): Rename to add_exit_phi.  Do not allow
7701         inserting a PHI in a block that is not a loop exit for VAR.
7702         Add dumping if TDF_DETAILS.
7703         (add_exit_phis_var): Rewrite.
7704         (add_exit_phis): Update.
7705         (get_loops_exits): Rewrite to return an array of per-loop exits
7706         rather than one bitmap with all loop exits.
7707         (find_uses_to_rename_bb): Ignore virtual PHI nodes.
7708         (rewrite_into_loop_closed_ssa): Update.
7709
7710 2012-08-16  Nick Clifton  <nickc@redhat.com>
7711
7712         * config/i386/i386elf.h (ASM_OUTPUT_ASCII): Cast _ascii_bytes
7713         before passing it to ASM_OUTPUT_LIMITED_STRING.
7714
7715         * config/bfin/bfin.c (hwloop_optimize): Fix use of VEC_last macro.
7716
7717         * config/avr/t-avr: Replace occurrences of $(CC) with $(COMPILER).
7718         * config/avr/avr.c (avr_legitimize_reload_address): Add casts
7719         for reload_type enums.
7720         (DEF_BUILTIN): Cast the icode to enum insn_code.
7721
7722 2012-08-15  Segher Boessenkool  <segher@kernel.crashing.org>
7723
7724         * config/rs6000/aix43.h (ASM_CPU_SPEC): Use %(asm_default)
7725         instead of -mppc.
7726         * config/rs6000/aix51.h (ASM_CPU_SPEC): Ditto.
7727
7728 2012-08-15  Segher Boessenkool  <segher@kernel.crashing.org>
7729
7730         * config/rs6000/aix43.h (TARGET_DEFAULT): Delete MASK_NEW_MNEMONICS.
7731         (RS6000_CALL_GLUE): Adjust for single assembler syntax.
7732         * config/rs6000/aix51.h (TARGET_DEFAULT, RS6000_CALL_GLUE): Ditto.
7733         * config/rs6000/aix52.h (TARGET_DEFAULT, RS6000_CALL_GLUE): Ditto.
7734         * config/rs6000/aix53.h (TARGET_DEFAULT, RS6000_CALL_GLUE): Ditto.
7735         * config/rs6000/aix61.h (TARGET_DEFAULT, RS6000_CALL_GLUE): Ditto.
7736         * config/rs6000/darwin.h (TARGET_DEFAULT): Ditto.
7737         * config/rs6000/darwin.md (whole file): Adjust to single
7738         assembler syntax.
7739         * config/rs6000/darwin64.h (TARGET_DEFAULT): Delete MASK_NEW_MNEMONICS.
7740         * config/rs6000/default64.h (TARGET_DEFAULT): Ditto.
7741         * config/rs6000/dfp.md: (whole file): Adjust to single
7742         assembler syntax.
7743         * config/rs6000/eabi.h (TARGET_DEFAULT): Delete MASK_NEW_MNEMONICS.
7744         * config/rs6000/eabialtivec.h (TARGET_DEFAULT): Ditto.
7745         * config/rs6000/eabispe.h (TARGET_DEFAULT): Ditto.
7746         * config/rs6000/linuxaltivec.h (TARGET_DEFAULT): Ditto.
7747         * config/rs6000/linuxspe.h (TARGET_DEFAULT): Ditto.
7748         * config/rs6000/rs6000-cpus.def (whole file): Delete POWERPC_BASE_MASK.
7749         * config/rs6000/rs6000-tables.opt: Regenerate.
7750         * config/rs6000/rs6000.c (POWERPC_BASE_MASK): Delete.
7751         (num_insns_constant_wide): Adjust comments.
7752         (whole file): Adjust to single assembler syntax.
7753         (output_cbranch): Adjust comment.
7754         * config/rs6000/rs6000.h (ASSEMBLER_DIALECT): Delete.
7755         * config/rs6000/rs6000.md: (whole file): Adjust to single
7756         assembler syntax.
7757         * config/rs6000/rs6000.opt (mnew-mnemonics): Delete.
7758         (mold-mnemonics): Delete.
7759         * config/rs6000/spe.md: (whole file): Adjust to single
7760         assembler syntax.
7761         * config/rs6000/sync.md: (whole file): Adjust to single
7762         assembler syntax.
7763         * config/rs6000/sysv4.h (TARGET_DEFAULT): Delete MASK_NEW_MNEMONICS.
7764         (ASM_OUTPUT_REG_PUSH): Adjust.
7765         (ASM_OUTPUT_REG_POP): Adjust.
7766         * config/rs6000/sysv4le.h (TARGET_DEFAULT): Delete MASK_NEW_MNEMONICS.
7767         * config/rs6000/vsx.md: (whole file): Adjust to single
7768         assembler syntax.
7769         * config/rs6000/vxworks.h (TARGET_DEFAULT): Delete MASK_NEW_MNEMONICS.
7770         * doc/invoke.texi: Adjust documentation to reflect the
7771         removal of -mnew-mnemonics and -mold-mnemonics.
7772
7773 2012-08-15  Segher Boessenkool  <segher@kernel.crashing.org>
7774
7775         * common/config/rs6000/rs6000-common.c (rs6000_handle_option):
7776         Delete handling for -mno-powerpc and -mpowerpc.
7777         * config/rs6000/aix43.h (ASM_CPU_SPEC): Similar.
7778         (ASM_DEFAULT_SPEC): Use -mppc instead of -mcom.
7779         * config/rs6000/aix51.h (ASM_CPU_SPEC, ASM_DEFAULT_SPEC): Ditto.
7780         * config/rs6000/aix52.h (TARGET_DEFAULT): Delete MASK_POWERPC.
7781         * config/rs6000/aix53.h (TARGET_DEFAULT): Ditto.
7782         * config/rs6000/aix61.h (TARGET_DEFAULT): Ditto.
7783         * config/rs6000/darwin.h (TARGET_DEFAULT): Ditto.
7784         * config/rs6000/darwin64.h (TARGET_DEFAULT): Ditto.
7785         * config/rs6000/default64.h (TARGET_DEFAULT): Ditto.
7786         * config/rs6000/driver-rs6000.c (asm_names): Delete handling
7787         for -mcpu=common and -mpowerpc.
7788         * config/rs6000/eabi.h (TARGET_DEFAULT): Delete MASK_POWERPC.
7789         * config/rs6000/eabialtivec.h (TARGET_DEFAULT): Ditto.
7790         * config/rs6000/eabispe.h (TARGET_DEFAULT): Ditto.
7791         * config/rs6000/linuxaltivec.h (TARGET_DEFAULT): Ditto.
7792         * config/rs6000/linuxspe.h (TARGET_DEFAULT): Ditto.
7793         * config/rs6000/rs6000-builtin.def (RS6000_BUILTIN_CFSTRING):
7794         Use RS6000_BTM_ALWAYS instead of RS6000_BTM_POWERPC.
7795         * config/rs6000/rs6000-c.c (rs6000_target_modify_macros): Adjust.
7796         (rs6000_cpu_cpp_builtins): Adjust.
7797         * config/rs6000/rs6000.c (POWERPC_BASE_MASK): Delete MASK_POWERPC.
7798         (rs6000_builtin_mask_calculate): Adjust.
7799         (rs6000_emit_move): Delete code for ! TARGET_POWERPC.
7800         (rs6000_init_libfuncs): Ditto.
7801         (rs6000_output_function_prologue): Ditto.
7802         (rs6000_opt_masks): Delete MASK_POWERPC.
7803         (rs6000_builtin_mask_names): Delete RS6000_BTM_POWERPC.
7804         * config/rs6000/rs6000.h (ASM_CPU_SPEC): Delete handling for -mpowerpc.
7805         (RS6000_BTM_POWERPC): Delete.
7806         (RS6000_BTM_COMMON): Delete RS6000_BTM_POWERPC.
7807         * config/rs6000/rs6000.md (extendqisi2 patterns): Adjust for
7808         TARGET_POWERPC always on.
7809         (extendqihi2 patterns): Similar.
7810         (various unnamed subtract patterns): Similar.
7811         (bswaphi2 patterns): Similar.
7812         (divmodsi4): Similar.
7813         (udiv<GPR:mode>3): Similar.
7814         (div<GPR:mode>3 patterns): Similar.
7815         (udivmodsi4): Similar.
7816         (mulhcall): Delete.
7817         (mullcall): Delete.
7818         (divss_call): Delete.
7819         (divus_call): Delete.
7820         (quoss_call): Delete.
7821         (quous_call): Delete.
7822         (insvsi patterns): Adjust.
7823         (addsf3 patterns): Adjust.
7824         (subsf3 patterns): Adjust.
7825         (mulsf3 patterns): Adjust.
7826         (divsf3 patterns): Adjust.
7827         (*fmasf4_fpr): Adjust.
7828         (*fmssf4_fpr): Adjust.
7829         (*nfmasf4_fpr): Adjust.
7830         (*nfmssf4_fpr): Adjust.
7831         (*floatunssidf2_internal): Adjust.
7832         (fix_trunc<SFDF:mode>si2_internal): Adjust.
7833         (fctiwz_<SFDF:mode>): Adjust.
7834         (mulsidi3 patterns): Adjust.
7835         (smulsi3_highpart patterns): Adjust.
7836         (umulsi3_highpart patterns): Adjust.
7837         (fix_trunctfsi2 patterns): Adjust.
7838         (prefetch): Adjust.
7839         * config/rs6000/rs6000.opt (mpowerpc): Replace by stub option.
7840         (mno-powerpc): Delete.
7841         * config/rs6000/sync.md (load_locked<ATOMIC:mode>): Adjust.
7842         (store_conditional<ATOMIC:mode>): Adjust.
7843         (atomic_compare_and_swap<ATOMIC:mode>): Adjust.
7844         (atomic_exchange<ATOMIC:mode>): Adjust.
7845         (atomic_<fetchop_name><ATOMIC:mode>): Adjust.
7846         (atomic_nand<ATOMIC:mode>): Adjust.
7847         (atomic_fetch_<fetchop_name><ATOMIC:mode>): Adjust.
7848         (atomic_fetch_nand<ATOMIC:mode>): Adjust.
7849         (atomic_<fetchop_name>_fetch<ATOMIC:mode>): Adjust.
7850         (atomic_nand_fetch<ATOMIC:mode>): Adjust.
7851         * config/rs6000/sysv4.h (TARGET_DEFAULT): Delete MASK_POWERPC.
7852         * config/rs6000/sysv4le.h (TARGET_DEFAULT): Ditto.
7853         * config/rs6000/vxworks.h (TARGET_DEFAULT): Ditto.
7854         * doc/invoke.texi: Adjust documentation.
7855
7856 2012-08-15  Segher Boessenkool  <segher@kernel.crashing.org>
7857
7858         * config/rs6000/rs6000.h (RS6000_BTM_ALWAYS): New.
7859
7860 2012-08-15  Segher Boessenkool  <segher@kernel.crashing.org>
7861
7862         * config/rs6000/aix52.h (ASM_CPU_SPEC): Fix typo.
7863         * config/rs6000/aix53.h (ASM_CPU_SPEC): Ditto.
7864         * config/rs6000/aix61.h (ASM_CPU_SPEC): Ditto.
7865         * config/rs6000/driver-rs6000.c (asm_names): Ditto.
7866
7867 2012-08-15  Segher Boessenkool  <segher@kernel.crashing.org>
7868
7869         PR target/54142
7870         * config/rs6000/driver-rs6000.c (asm_names): Use %(asm_default)
7871         instead of -mcom.
7872         * config/rs6000/rs6000.h (ASM_CPU_SPEC): Ditto.
7873
7874 2012-08-15  Sandra Loosemore  <sandra@codesourcery.com>
7875             Maxim Kuvyrkov  <maxim@codesourcery.com>
7876             Julian Brown  <julian@codesourcery.com>
7877             MIPS Technologies, Inc.
7878
7879         * config/mips/mips.md (dspmac, dspmacsat, accext, accmod, dspalu)
7880         (dspalusat): Add insn types.
7881         * config/mips/mips-dsp.md (add<DSPV:mode>3)
7882         (mips_add<DSP:dspfmt1>_s_<DSP:dspfmt2>)
7883         (sub<DSPV:mode>3, mips_sub<DSP:dspfmt1>_s_<DSP:dspfmt2>, mips_addsc)
7884         (mips_addwc, mips_modsub, mips_raddu_w_qb, mips_absq_s_<DSPQ:dspfmt2>)
7885         (mips_precrq_qb_ph, mips_precrq_ph_w, mips_precrq_rs_ph_w)
7886         (mips_precrqu_s_qb_ph, mips_preceq_w_phl, mips_preceq_w_phr)
7887         (mips_precequ_ph_qbl, mips_precequ_ph_qbr, mips_precequ_ph_qbla)
7888         (mips_precequ_ph_qbra, mips_preceu_ph_qbl, mips_preceu_ph_qbr)
7889         (mips_preceu_ph_qbla, mips_preceu_ph_qbra, mips_shll_<DSPV:dspfmt2>)
7890         (mips_shll_s_<DSPQ:dspfmt2>, mips_shll_s_<DSPQ:dspfmt2>, mips_shrl_qb)
7891         (mips_shra_ph, mips_shra_r_<DSPQ:dspfmt2>, mips_bitrev, mips_insv)
7892         (mips_repl_qb, mips_repl_ph)
7893         (mips_cmp<DSPV:dspfmt1_1>_eq_<DSPV:dspfmt2>)
7894         (mips_cmp<DSPV:dspfmt1_1>_lt_<DSPV:dspfmt2>)
7895         (mips_cmp<DSPV:dspfmt1_1>_le_<DSPV:dspfmt2>, mips_cmpgu_eq_qb)
7896         (mips_cmpgu_lt_qb, mips_cmpgu_le_qb, mips_pick_<DSPV:dspfmt2>)
7897         (mips_packrl_ph, mips_wrdsp, mips_rddsp): Change type to dspalu.
7898         (mips_dpau_h_qbl, mips_dpau_h_qbr, mips_dpsu_h_qbl, mips_dpsu_h_qbr)
7899         (mips_dpaq_s_w_ph, mips_dpsq_s_w_ph, mips_mulsaq_s_w_ph)
7900         (mips_maq_s_w_phl, mips_maq_s_w_phr, mips_maq_sa_w_phr): Set type to
7901         dspmac.
7902         (mips_dpaq_sa_l_w, mips_dpsq_sa_l_w, mips_maq_sa_w_phl): Set type to
7903         dspmacsat.
7904         (mips_extr_w, mips_extr_r_w, mips_extr_rs_w, mips_extp, mips_extpdp):
7905         Set type to accext.
7906         (mips_shilo, mips_mthlip): Set type to accmod.
7907         * config/mips/mips-dspr2.md (mips_absq_s_qb, mips_addu_s_ph)
7908         (mips_adduh_r_qb): Set type to dspalusat.
7909         (mips_addu_ph, mips_adduh_qb, mips_append, mips_balign)
7910         (mips_cmpgdu_eq_qb, mips_cmpgdu_lt_qb, mips_cmpgdu_le_qb)
7911         (mips_precr_qb_ph, mips_precr_sra_ph_w, mips_precr_sra_r_ph_w)
7912         (mips_prepend, mips_shra_qb, mips_shra_r_qb, mips_shrl_ph)
7913         (mips_subu_ph, mips_subuh_qb, mips_subuh_r_qb, mips_addqh_ph)
7914         (mips_addqh_r_ph, mips_addqh_w, mips_addqh_r_w, mips_subqh_ph)
7915         (mips_subqh_r_ph, mips_subqh_w, mips_subqh_r_w): Set type to dspalu.
7916         (mips_dpa_w_ph, mips_dps_w_ph, mips_mulsa_w_ph, mips_dpax_w_ph)
7917         (mips_dpsx_w_ph, mips_dpaqx_s_w_ph, mips_dpsqx_s_w_ph): Set type to
7918         dspmac.  Set accum_in attribute.
7919         (mips_subu_s_ph): Set type to dspalusat.
7920         (mips_dpaqx_sa_w_ph, mips_dpsqx_sa_w_ph): Set type to dspmacsat.
7921         Set accum_in attribute.
7922         * config/mips/mips-protos.h (mips_dspalu_bypass_p): Add prototype.
7923         * config/mips/mips.c (dspalu_bypass_table): New.
7924         (mips_dspalu_bypass_p): New.
7925         * config/mips/24k.md (r24k_dsp_alu, r24k_dsp_mac, r24k_dsp_mac_sat)
7926         (r24k_dsp_acc_ext, r24k_dsp_acc_mod): New insn reservations.
7927         (r24k_int_mult, r24k_int_mthilo, r24k_dsp_mac, r24k_dsp_mac_sat)
7928         (r24k_dsp_acc_ext, r24k_dsp_acc_mod, r24k_dsp_alu): New bypasses.
7929         * config/mips/74k.md (r74k_dsp_alu, r74k_dsp_alu_sat, r74k_dsp_mac)
7930         (r74k_dsp_mac_sat, r74k_dsp_acc_ext, r74k_dsp_acc_mod): New insn
7931         reservations.
7932         (r74k_dsp_mac, r74k_dsp_mac_sat, r74k_int_mult, r74k_int_mul3)
7933         (r74k_dsp_mac, r74k_dsp_mac_sat): New bypasses.
7934
7935 2012-08-15  Ulrich Weigand  <Ulrich.Weigand@de.ibm.com>
7936
7937         * config/spu/spu.c: Include "cfgloop.h".
7938         (spu_machine_dependent_reorg): Call loop_optimizer_init and
7939         loop_optimizer_finalize.  Use bb_loop_depth instead of loop_depth.
7940         Directly compare loop_father values where appropriate.
7941         * config/spu/t-spu-elf (spu.o): Update dependencies.
7942
7943 2012-08-15  H.J. Lu  <hongjiu.lu@intel.com>
7944
7945         * Makefile.in (tree-cfg.o): Also depend on $(TARGET_H).
7946
7947 2012-08-15  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
7948
7949         PR tree-optimization/54245
7950         * gimple-ssa-strength-reduction.c (legal_cast_p_1): New function.
7951         (legal_cast_p): Split out logic to legal_cast_p_1.
7952         (analyze_increments): Avoid introducing multiplies in smaller types.
7953
7954 2012-08-15  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
7955
7956         PR tree-optimization/54240
7957         * tree-ssa-phiopt.c (hoist_adjacent_loads): Correct test for
7958         existence of conditional move with given mode.
7959
7960 2012-08-15  Richard Guenther  <rguenther@suse.de>
7961
7962         * double-int.h (double_int::from_unsigned): Rename to ...
7963         (double_int::from_uhwi): ... this.
7964         (double_int::from_signed): Rename to ...
7965         (double_int::from_shwi): ... this.
7966         (double_int::to_signed): Rename to ...
7967         (double_int::to_shwi): ... this.
7968         (double_int::to_unsigned): Rename to ...
7969         (double_int::to_uhwi): ... this.
7970         (double_int::fits_unsigned): Rename to ...
7971         (double_int::fits_uhwi): ... this.
7972         (double_int::fits_signed): Rename to ...
7973         (double_int::fits_shwi): ... this.
7974         (double_int::fits): Rename to ...
7975         (double_int::fits_hwi): ... this.
7976         * double-int.c: Likewise.
7977
7978 2012-08-15  Steven Bosscher  <steven@gcc.gnu.org>
7979
7980         * timevar.def (TV_VARPOOL, TV_WHOPR_WPA_LTRANS_EXEC, TV_LIFE,
7981         TV_LIFE_UPDATE, TV_DF_UREC, TV_INLINE_HEURISTICS,
7982         TV_TREE_LINEAR_TRANSFORM, TV_TREE_LOOP_INIT, TV_TREE_LOOP_FINI,
7983         TV_VPT, TV_LOCAL_ALLOC, TV_GLOBAL_ALLOC, TV_SEQABSTR): Remove.
7984         (TV_IPA_INLINING, TV_FLATTEN_INLINING, TV_EARLY_INLINING,
7985         TV_INLINE_PARAMETERS, TV_LOOP_INIT, TV_LOOP_FINI): New.
7986         * timevar.c (timevar_print): Make printing width of timevar names
7987         more flexible, but enforce maximum length.
7988         * ipa-inline.c (pass_early_inline): Use TV_EARLY_INLINING.
7989         (pass_ipa_inline): Use TV_IPA_INLINING.
7990         * ipa-inline-analysis.c (pass_inline_parameters): Use
7991         TV_INLINE_HEURISTICS.
7992         * tree-ssa-loop.c (pass_tree_loop_init): No timevar for wrapper pass.
7993         (pass_tree_loop_done): Likewise.
7994         * final.c (pass_shorten_branches): Use TV_SHORTEN_BRANCH.
7995         * loop-init.c (loop_optimizer_init): Push/pop TV_LOOP_INIT.
7996         (loop_optimizer_finalize): Push/pop TV_LOOP_FINI.
7997
7998 2012-08-15  Ramana Radhakrishnan  <ramana.radhakrishnan@linaro.org>
7999
8000         * config/arm/neon.md (neon_vaba<mode> VDQIW): Canonicalize operands.
8001         (neon_vabal<mode> VDQIW): Likewise.
8002
8003 2012-08-15  Ramana Radhakrishnan  <ramana.radhakrishnan@linaro.org>
8004
8005         PR target/54212
8006         * config/arm/neon.md (vec_set<mode>_internal VD,VQ): Do not
8007         mark as predicable. Adjust asm template.
8008         (vec_setv2di_internal): Likewise.
8009         (vec_extract<mode> VD, VQ): Likewise.
8010         (vec_extractv2di): Likewise.
8011         (neon_vget_lane<mode>_sext_internal VD, VQ): Likewise.
8012         (neon_vset_lane<mode>_sext_internal VD, VQ): Likewise.
8013         (neon_vdup_n<mode> VX, V32): Likewise.
8014         (neon_vdup_nv2di): Likewise.
8015
8016 2012-08-14  Maxim Kuvyrkov  <maxim@codesourcery.com>
8017
8018         * config/mips/mips.md (define_attr accum_in): New instruction
8019         attribute.  Set it for imadd and fmadd patterns.
8020         * config/mips/mips.c (mips_linked_madd_p): Use accum_in to extract
8021         accumulator register.
8022
8023 2012-08-14  Diego Novillo  <dnovillo@google.com>
8024
8025         Merge from cxx-conversion branch.  Configury.
8026
8027         * configure.ac (CXX_FOR_BUILD): Define and substitute.
8028         (BUILD_CXXFLAGS): Define.
8029         Remove all handlers of ENABLE_BUILD_WITH_CXX.
8030         Force all build to be with C++.
8031         * Makefile.in (BUILD_CXXFLAGS): Use it.
8032         Remove all handlers of ENABLE_BUILD_WITH_CXX.
8033         * configure: Regenerate.
8034         * config.in: Regenerate.
8035         * doc/install.texi: Remove documentation for --enable-build-with-cxx
8036         and --enable-build-poststage1-with-cxx.
8037
8038 2012-08-14  Diego Novillo  <dnovillo@google.com>
8039
8040         Merge from cxx-conversion branch.  Re-implement VEC in C++.
8041
8042         * vec.c (vec_heap_free): Convert into a template function.
8043         (vec_gc_o_reserve_1): Make extern.
8044         (vec_gc_p_reserve): Remove.
8045         (vec_gc_p_reserve_exact): Remove.
8046         (vec_gc_o_reserve): Remove.
8047         (vec_gc_o_reserve_exact): Remove.
8048         (vec_heap_o_reserve_1): Make extern.
8049         (vec_heap_p_reserve): Remove.
8050         (vec_heap_p_reserve_exact): Remove.
8051         (vec_heap_o_reserve): Remove.
8052         (vec_heap_o_reserve_exact): Remove.
8053         (vec_stack_p_reserve): Remove.
8054         (vec_stack_p_reserve_exact): Remove.
8055         * vec.h (VEC_CHECK_INFO, VEC_CHECK_DECL, VEC_CHECK_PASS, VEC_ASSERT,
8056         VEC_ASSERT_FAIL, vec_assert_fail): Move earlier in the file.
8057         (VEC): Define to vec_t<T>.
8058         (vec_allocation_t): Define.
8059         (struct vec_prefix): Move earlier in the file.
8060         (vec_t<T>): New template.
8061         (DEF_VEC_I, DEF_VECL_ALLOC_I, DEF_VEC_P, DEF_VEC_ALLOC_P,
8062         DEF_VEC_O, DEF_VEC_ALLOC_P, DEF_VEC_O, DEF_VEC_ALLOC_O,
8063         DEF_VEC_ALLOC_P_STACK, DEF_VEC_ALLOC_O_STACK,
8064         DEF_VEC_ALLOC_I_STACK): Expand to 'struct vec_swallow_trailing_semi'.
8065         (DEF_VEC_A): Provide template instantiations for
8066         GC/PCH markers that do not traverse the vector.
8067         (vec_stack_p_reserve): Remove.
8068         (vec_stack_p_reserve_exact): Remove.
8069         (vec_stack_p_reserve_exact_1): Remove.
8070         (vec_stack_o_reserve): Remove.
8071         (vec_stack_o_reserve_exact): Remove.
8072         (vec_stack_free): Re-write as a template function.
8073         (vec_reserve): New template function.
8074         (vec_reserve_exact): New template function.
8075         (vec_heap_free): New template function if GATHER_STATISTICS is
8076         defined.  Otherwise, macro that expands to free().
8077         (VEC_length_1): New template function.
8078         (VEC_length): Call it.
8079         (VEC_empty_1): New template function.
8080         (VEC_empty): Call it.
8081         (VEC_address_1): New template function.
8082         (VEC_address): Call it.
8083         (VEC_last_1): New template function.
8084         (VEC_last): Call it.  Change return type to T&.
8085         Change all users that used VEC_Os.
8086         (VEC_index_1): New template function.
8087         (VEC_index): Call it.  Return a T& instead of a T*.
8088         Update all callers that were using VEC_O before.
8089         (VEC_iterate_1): New template function.
8090         (VEC_iterate): Call it.
8091         (VEC_embedded_size_1): New template function.
8092         (VEC_embedded_size): Call it.
8093         (VEC_embedded_init_1): New template function.
8094         (VEC_embedded_init): Call it.
8095         (VEC_alloc_1): New template function.
8096         (VEC_alloc): Call it.  If A is 'stack', call XALLOCAVAR to
8097         do the allocation.
8098         (VEC_free_1): New template function.
8099         (VEC_free): Call it.
8100         (VEC_copy_1): New template function.
8101         (VEC_copy): Call it.
8102         (VEC_space_1): New template function
8103         (VEC_space): Call it.
8104         (VEC_reserve_1): New template function.
8105         (VEC_reserve): Call it.
8106         (VEC_reserve_exact_1): New template function.
8107         (VEC_reserve_exact): Call it.
8108         (VEC_splice_1): New template function.
8109         (VEC_splice): Call it.
8110         (VEC_safe_splice_1): New template function.
8111         (VEC_safe_splice): Call it.
8112         (VEC_quick_push_1): New template function.  Create two overloads, one
8113         accepting T, the other accepting T *.  Update all callers
8114         where T and T * are ambiguous.
8115         (VEC_quick_push): Call it.
8116         (VEC_safe_push_1): New template function. Create two overloads, one
8117         accepting T, the other accepting T *.  Update all callers
8118         where T and T * are ambiguous.
8119         (VEC_safe_push): Call it.
8120         (VEC_pop_1): New template function.
8121         (VEC_pop): Call it.
8122         (VEC_truncate_1): New template function.
8123         (VEC_truncate): Call it.
8124         (VEC_safe_grow_1): New template function.
8125         (VEC_safe_grow): Call it.
8126         (VEC_safe_grow_cleared_1): New template function.
8127         (VEC_safe_grow_cleared): Call it.
8128         (VEC_replace_1): New template function.
8129         (VEC_replace): Call it.  Always accept T instead of T*.
8130         Update all callers that used VEC_Os.
8131         (VEC_quick_insert_1): New template function.
8132         (VEC_quick_insert): Call it.
8133         (VEC_safe_insert_1): New template function.
8134         (VEC_safe_insert): Call it.
8135         (VEC_ordered_remove_1): New template function.
8136         (VEC_ordered_remove): Call it.
8137         (VEC_unordered_remove_1): New template function.
8138         (VEC_unordered_remove): Call it.
8139         (VEC_block_remove_1): New template function.
8140         (VEC_block_remove): Call it.
8141         (VEC_lower_bound_1): New template function.
8142         (VEC_lower_bound): Call it.
8143         (VEC_OP): Remove.
8144         (DEF_VEC_FUNC_P): Remove.
8145         (DEF_VEC_ALLOC_FUNC_P): Remove.
8146         (DEF_VEC_NONALLOC_FUNCS_P): Remove.
8147         (DEF_VEC_FUNC_O): Remove.
8148         (DEF_VEC_ALLOC_FUNC_O): Remove.
8149         (DEF_VEC_NONALLOC_FUNCS_O): Remove.
8150         (DEF_VEC_ALLOC_FUNC_I): Remove.
8151         (DEF_VEC_NONALLOC_FUNCS_I): Remove.
8152         (DEF_VEC_ALLOC_FUNC_P_STACK): Remove.
8153         (DEF_VEC_ALLOC_FUNC_O_STACK): Remove.
8154         (DEF_VEC_ALLOC_FUNC_I_STACK): Remove.
8155         (vec_reserve_exact): New template function.
8156
8157         * gengtype-lex.l (DEF_VEC_ALLOC_[IOP]/{EOID}): Remove.
8158         * gengtype-parse.c (token_names): Remove DEF_VEC_ALLOC_[IOP].
8159         (typedef_name): Emit vec_t<C1> instead of VEC_C1_C2.
8160         (def_vec_alloc): Remove.  Update all callers.
8161         * gengtype.c (filter_type_name): New.
8162         (output_mangled_typename): Call it.
8163         (write_func_for_structure): Likewise.
8164         (write_types): Likewise.
8165         (write_root): Likewise.
8166         (write_typed_alloc_def): Likewise.
8167         (note_def_vec): Emit vec_t<TYPE_NAME> instead of VEC_TYPE_NAME_base.
8168         (note_def_vec_alloc): Remove.
8169         * gengtype.h (note_def_vec_alloc): Remove.
8170         (DEFVEC_ALLOC): Remove token code.
8171
8172         * df-scan.c (df_bb_verify): Remove call to df_free_collection_rec
8173         inside the insn traversal loop.
8174         * gimplify.c (gimplify_compound_lval): Rename STACK to EXPR_STACK.
8175         * ipa-inline.c (inline_small_functions): Rename HEAP to EDGE_HEAP.
8176         * reg-stack.c (stack): Rename to STACK_PTR.  Update all users.
8177         * tree-vrp.c (stack): Rename to EQUIV_STACK.  Update all users.
8178
8179         * config/bfin/bfin.c (hwloop_optimize): Update some calls to
8180         VEC_* for vectors of non-pointers.
8181         * config/c6x/c6x.c (try_rename_operands): Likewise.
8182         (reshuffle_units): Likewise.
8183         * config/mips/mips.c (mips_multi_start): Likewise.
8184         (mips_multi_add): Likewise.
8185         (mips_multi_copy_insn): Likewise.
8186         (mips_multi_set_operand): Likewise.
8187         * hw-doloop.c (discover_loop): Likewise.
8188         (discover_loops): Likewise.
8189         (reorg_loops): Likewise.
8190
8191 2012-08-14  Diego Novillo  <dnovillo@google.com>
8192
8193         Merge from cxx-conversion branch.  C++ support in gengtype.
8194
8195         * coretypes.h (gt_pointer_operator): Move from ...
8196         * ggc.h: ... here.
8197         * doc/gty.texi: Document support for C++ templates and
8198         user-provided markers.
8199         * gcc/gengtype-lex.l: Update copyright year.
8200         Remove support for recognizing DEF_VEC_O, DEF_VEC_P and DEFVEC_I.
8201         * gengtype-parse.c: Update copyright year.
8202         (token_names): Remove DEF_VEC_O, DEF_VEC_P and DEF_VEC_I.
8203         (require_template_declaration): New.
8204         (typedef_name): Call it.
8205         (type): Replace IS_UNION with KIND. Replace all users.
8206         (def_vec): Remove.  Update all users.
8207         * gengtype-state.c (type_lineloc): Handle TYPE_USER_STRUCT.
8208         (write_state_user_struct_type): New.
8209         (write_state_type): Call it.
8210         (read_state_user_struct_type): New.
8211         (read_state_type): Call it.
8212         * gengtype.c: Update copyright year.
8213         (dump_pair): Move declaration to the top.
8214         (dump_type): Likewise.
8215         (dump_type_list): Likewise.
8216         (dbgprint_count_type_at): Handle TYPE_USER_STRUCT.
8217         (create_user_defined_type): New.
8218         (resolve_typedef): Call it.
8219         (new_structure): Replace argument ISUNION with KIND.
8220         Change users to refer to KIND directly.
8221         Update all callers.
8222         (find_structure): Likewise.
8223         (set_gc_used_type): Handle TYPE_USER_STRUCT.
8224         (create_file): Update HDR to include new copyright year.
8225         (struct walk_type_data): Add field IN_PTR_FIELD.
8226         (output_mangled_typename): Handle TYPE_USER_STRUCT.
8227         (walk_type): Set D->IN_PTR_FIELD when walking a TYPE_POINTER.
8228         Clear it afterwards.
8229         Handle TYPE_USER_STRUCT.
8230         (write_types_process_field): Handle TYPE_USER_STRUCT.
8231         (get_type_specifier): Move earlier in the file.
8232         (write_type_decl): New.
8233         (write_marker_function_name): New.
8234         (write_user_func_for_structure_ptr): New.
8235         (write_user_func_for_structure_body): New.
8236         (write_user_marking_functions): New.
8237         (write_func_for_structure): Call write_marker_function_name
8238         and write_type_decl.
8239         Do not call walk_type for TYPE_USER_STRUCT. Emit a call to the user
8240         function directly.
8241         Call write_user_marking_functions on TYPE_USER_STRUCTs.
8242         (write_types_local_user_process_field): New.
8243         (write_pch_user_walking_for_structure_body): New.
8244         (write_pch_user_walking_functions): New.
8245         (write_types_local_process_field): Handle TYPE_USER_STRUCT.
8246         (write_local_func_for_structure): Do not call walk_type for
8247         TYPE_USER_STRUCT. Instead, emit the call to gt_pch_nx directly.
8248         Call write_pch_user_walking_functions for TYPE_USER_STRUCTs.
8249         (write_root): Handle TYPE_USER_STRUCT.
8250         (vec_prefix_type): Remove.  Update all users.
8251         (note_def_vec): Remove.  Update all users.
8252         (dump_typekind): Handle TYPE_USER_STRUCT.
8253         (dump_type): Initialize SEEN_TYPES, if needed.
8254         Handle TYPE_USER_STRUCT.
8255         (dump_everything): Do not initialize SEEN_TYPES.
8256         * gengtype.h: Update copyright year.
8257         (enum typekind): Add TYPE_USER_STRUCT.
8258         (union_or_struct_p): Rename from UNION_OR_STRUCT_P.
8259         Convert into function.
8260         Add an overload taking const_type_p.
8261         Update all callers.
8262         (new_structure): Change second field to type enum typekind.
8263         Update all users.
8264         (find_structure): Likewise.
8265         (note_def_vec): Remove.
8266         (DEFVEC_OP): Remove.
8267         (DEFVEC_I): Remove.
8268         * ggc-page.c (gt_ggc_mx): Add entry points for marking
8269         'const char *&', 'unsigned char *&' and 'unsigned char&'.
8270         * ggc-zone.c (gt_ggc_mx): Add entry points for marking
8271         'const char *&' and 'unsigned char *&'.
8272         * stringpool.c (gt_pch_nx): Add entry points for marking
8273         'const char *&', 'unsigned char *&' and 'unsigned char&'.
8274         Add an entry point for the overload taking arguments 'unsigned char
8275         *', 'gt_pointer_operator' and 'void *'.
8276         * vec.h (struct vec_prefix): Remove GTY marker.
8277         (struct vec_t): Remove GTY((length)) attribute from field 'vec'.
8278         (gt_ggc_mx (vec_t<T> *)): New template function.
8279         (gt_pch_nx (vec_t<T> *)): New template function.
8280         (gt_pch_nx (vec_t<T *> *, gt_pointer_operator, void *)): New template
8281         function.
8282         (gt_pch_nx (vec_t<T> *, gt_pointer_operator, void *)): New template
8283         function.
8284
8285         * basic-block.h (struct edge_def): Mark GTY((user)).
8286         Remove all GTY markers from fields.
8287         (gt_ggc_mx): Declare.
8288         (gt_pch_nx): Declare.
8289         * tree-cfg.c (gt_ggc_mx): New.
8290         (gt_pch_nx): New.
8291
8292         * gengtype-lex.l (USER_GTY): Add pattern for "user".
8293         * gengtype-parse.c (option): Handle USER_GTY.
8294         (opts_have): New.
8295         (type): Call it.
8296         If the keyword 'user' is used, do not walk the fields
8297         of the structure.
8298         * gengtype.h (USER_GTY): Add.
8299         * doc/gty.texi: Update.
8300
8301 2012-08-14  Lawrence Crowl  <crowl@google.com>
8302
8303         Merge cxx-conversion branch.  Implement C++ hash table.
8304
8305         * hash-table.h: New. Implementation borrowed from libiberty/hashtab.c.
8306         * hash-table.c: Likewise.
8307         * tree-ssa-tail-merge.c: Include hash-table.h instead of hashtab.h.
8308         (static htab_t same_succ_htab): Change type to hash_table;
8309         move specification of helper functions from create call to declaration.
8310         Change users to invoke member functions.
8311         (same_succ_print_traverse): Make extern ssa_.... Change callers.
8312         Remove void* casting.
8313         (same_succ_hash): Likewise.
8314         (same_succ_equal): Likewise.
8315         (same_succ_delete): Likewise.
8316         * tree-ssa-threadupdate.c: Include hash-table.h.
8317         (struct local_info): Rename to ssa_local_info_t to avoid overloading
8318         the type name local_info with the variable name local_info.
8319         (static htab_t redirection_data): Change type to hash_table.
8320         Move specification of helper functions from create call to declaration.
8321         Change users to invoke member functions.
8322         (redirection_data_hash): Make extern ssa_.... Change callers.
8323         Remove void* casting.
8324         (redirection_data_eq): Likewise.
8325         (fix_duplicate_block_edges): Likewise.
8326         (create_duplicates): Likewise.
8327         (fixup_template_block): Likewise.
8328         (redirect_edges): Likewise.
8329         (lookup_redirection_data): Change types associated with the hash table
8330         from void* to their actual type. Remove unnecessary casts.
8331         * tree-ssa-ccp.c: Include hash-table.h.
8332         (typedef gimple_htab): New.  Uses hash_table.  Replace specific uses
8333         of htab_t with gimple_htab.  Change users to invoke member functions.
8334         Move specification of helper functions from create call to declaration.
8335         * tree-ssa-coalesce.c: Include hash-table.h instead of hashtab.h.
8336         (hash_ssa_name_by_var): Make extern. Remove void* casting.
8337         (eq_ssa_name_by_var): Likewise.
8338         (coalesce_ssa_name): Change type of local static htab_t ssa_name_hash
8339         to hash_table. Change users to invoke member functions.
8340         Move specification of helper functions from create call to declaration.
8341         * coverage.c: Include hash-table.h instead of hashtab.h.
8342         (static htab_t counts_hash): Change type to hash_table;
8343         move specification of helper functions from create call to declaration.
8344         Change users to invoke member functions.
8345         (htab_counts_entry_hash): Make extern. Rename with coverage_... instead
8346         of htab_... Remove void* casting.
8347         (htab_counts_entry_eq): Likewise.
8348         (htab_counts_entry_del): Likewise.
8349         * tree-ssa-pre.c: Include hash-table.h instead of hashtab.h.
8350         (static htab_t expression_to_id): Change type to hash_table.
8351         Move specification of helper functions from create call to declaration.
8352         Change users to invoke member functions.
8353         (static htab_t phi_translate_table): Likewise.
8354         (pre_expr_eq): Make extern ssa_.... Change callers.
8355         Remove void* casting.
8356         (pre_expr_hash): Likewise.
8357         (expr_pred_trans_hash): Likewise.
8358         (expr_pred_trans_eq): Likewise.
8359         (alloc_expression_id): Change types associated with the hash table
8360         from void* to their actual type. Remove unnecessary casts.
8361         (lookup_expression_id): Likewise.
8362         (phi_trans_lookup): Likewise.
8363         (phi_trans_add): Likewise.
8364         * stringpool.c: Rename uses of libcpp typedef hash_table to
8365         cpp_hash_table.
8366         * Makefile.in: Add hash-table.o to OBJS-libcommon-target.
8367         Add $(HASH_TABLE_H). Add new dependences on $(HASH_TABLE_H).
8368
8369 2012-08-14  Lawrence Crowl  <crowl@google.com>
8370
8371         Merge from cxx-conversion branch.  Re-write double_int in C++.
8372
8373         * hash-table.h
8374         (typedef double_int): Change to struct (POD).
8375         (double_int::make): New overloads for int to double-int conversion.
8376         (double_int::mask): New.
8377         (double_int::max_value): New.
8378         (double_int::min_value): New.
8379         (double_int::operator ++): New.
8380         (double_int::operator --): New.
8381         (double_int::operator *=): New.
8382         (double_int::operator +=): New.
8383         (double_int::operator -=): New.
8384         (double_int::to_signed): New.
8385         (double_int::to_unsigned): New.
8386         (double_int::fits_unsigned): New.
8387         (double_int::fits_signed): New.
8388         (double_int::fits): New.
8389         (double_int::trailing_zeros): New.
8390         (double_int::popcount): New.
8391         (double_int::multiple_of): New.
8392         (double_int::set_bit): New.
8393         (double_int::mul_with_sign): New.
8394         (double_int::operator * (binary)): New.
8395         (double_int::operator + (binary)): New.
8396         (double_int::operator - (binary)): New.
8397         (double_int::operator - (unary)): New.
8398         (double_int::operator ~ (unary)): New.
8399         (double_int::operator & (binary)): New.
8400         (double_int::operator | (binary)): New.
8401         (double_int::operator ^ (binary)): New.
8402         (double_int::and_not): New.
8403         (double_int::lshift): New.
8404         (double_int::rshift): New.
8405         (double_int::alshift): New.
8406         (double_int::arshift): New.
8407         (double_int::llshift): New.
8408         (double_int::lrshift): New.
8409         (double_int::lrotate): New.
8410         (double_int::rrotate): New.
8411         (double_int::div): New.
8412         (double_int::sdiv): New.
8413         (double_int::udiv): New.
8414         (double_int::mod): New.
8415         (double_int::smod): New.
8416         (double_int::umod): New.
8417         (double_int::divmod): New.
8418         (double_int::sdivmod): New.
8419         (double_int::udivmod): New.
8420         (double_int::ext): New.
8421         (double_int::zext): New.
8422         (double_int::sext): New.
8423         (double_int::is_zero): New.
8424         (double_int::is_one): New.
8425         (double_int::is_minus_one): New.
8426         (double_int::is_negative): New.
8427         (double_int::cmp): New.
8428         (double_int::ucmp): New.
8429         (double_int::scmp): New.
8430         (double_int::ult): New.
8431         (double_int::ugt): New.
8432         (double_int::slt): New.
8433         (double_int::sgt): New.
8434         (double_int::max): New.
8435         (double_int::smax): New.
8436         (double_int::umax): New.
8437         (double_int::min): New.
8438         (double_int::smin): New.
8439         (double_int::umin): New.
8440         (double_int::operator ==): New.
8441         (double_int::operator !=): New.
8442         (shwi_to_double_int): Change implementation to use member function.
8443         (double_int_minus_one): Likewise.
8444         (double_int_zero): Likewise.
8445         (double_int_one): Likewise.
8446         (double_int_two): Likewise.
8447         (double_int_ten): Likewise.
8448         (uhwi_to_double_int): Likewise.
8449         (double_int_to_shwi): Likewise.
8450         (double_int_to_uhwi): Likewise.
8451         (double_int_fits_in_uhwi_p): Likewise.
8452         (double_int_fits_in_shwi_p): Likewise.
8453         (double_int_fits_in_hwi_p): Likewise.
8454         (double_int_mul): Likewise.
8455         (double_int_mul_with_sign): Likewise.
8456         (double_int_add): Likewise.
8457         (double_int_sub): Likewise.
8458         (double_int_neg): Likewise.
8459         (double_int_div): Likewise.
8460         (double_int_sdiv): Likewise.
8461         (double_int_udiv): Likewise.
8462         (double_int_mod): Likewise.
8463         (double_int_smod): Likewise.
8464         (double_int_umod): Likewise.
8465         (double_int_divmod): Likewise.
8466         (double_int_sdivmod): Likewise.
8467         (double_int_udivmod): Likewise.
8468         (double_int_multiple_of): Likewise.
8469         (double_int_setbit): Likewise.
8470         (double_int_ctz): Likewise.
8471         (double_int_not): Likewise.
8472         (double_int_ior): Likewise.
8473         (double_int_and): Likewise.
8474         (double_int_and_not): Likewise.
8475         (double_int_xor): Likewise.
8476         (double_int_lshift): Likewise.
8477         (double_int_rshift): Likewise.
8478         (double_int_lrotate): Likewise.
8479         (double_int_rrotate): Likewise.
8480         (double_int_cmp): Likewise.
8481         (double_int_scmp): Likewise.
8482         (double_int_ucmp): Likewise.
8483         (double_int_max): Likewise.
8484         (double_int_smax): Likewise.
8485         (double_int_umax): Likewise.
8486         (double_int_min): Likewise.
8487         (double_int_smin): Likewise.
8488         (double_int_umin): Likewise.
8489         (double_int_ext): Likewise.
8490         (double_int_sext): Likewise.
8491         (double_int_zext): Likewise.
8492         (double_int_mask): Likewise.
8493         (double_int_max_value): Likewise.
8494         (double_int_min_value): Likewise.
8495         (double_int_zero_p): Likewise.
8496         (double_int_one_p): Likewise.
8497         (double_int_minus_one_p): Likewise.
8498         (double_int_equal_p): Likewise.
8499         (double_int_popcount): Likewise.
8500         * hash-table.c
8501         (double_int_mask): Reuse implementation for double_int::mask.
8502         (double_int_max_value): Likewise.
8503         (double_int_min_value): Likewise.
8504         (double_int_ext): Likewise.
8505         (double_int_zext): Likewise.
8506         (double_int_sext): Likewise.
8507         (double_int_mul_with_sign): Likewise.
8508         (double_int_divmod): Likewise.
8509         (double_int_sdivmod): Likewise.
8510         (double_int_udivmod): Likewise.
8511         (double_int_div): Likewise.
8512         (double_int_sdiv): Likewise.
8513         (double_int_udiv): Likewise.
8514         (double_int_mod): Likewise.
8515         (double_int_smod): Likewise.
8516         (double_int_umod): Likewise.
8517         (double_int_multiple_of): Likewise.
8518         (double_int_lshift): Likewise.
8519         (double_int_rshift): Likewise.
8520         (double_int_lrotate): Likewise.
8521         (double_int_rrotate): Likewise.
8522         (double_int_cmp): Likewise.
8523         (double_int_ucmp): Likewise.
8524         (double_int_scmp): Likewise.
8525         (double_int_max): Likewise.
8526         (double_int_smax): Likewise.
8527         (double_int_umax): Likewise.
8528         (double_int_min): Likewise.
8529         (double_int_smin): Likewise.
8530         (double_int_umin): Likewise.
8531         (double_int_min): Likewise.
8532         (double_int_min): Likewise.
8533         (double_int_min): Likewise.
8534         (double_int_min): Likewise.
8535         (double_int_min): Likewise.
8536         (double_int_min): Likewise.
8537         (double_int::alshift): New.
8538         (double_int::arshift): New.
8539         (double_int::llshift): New.
8540         (double_int::lrshift): New.
8541         (double_int::ult): New.
8542         (double_int::ugt): New.
8543         (double_int::slt): New.
8544         (double_int::sgt): New.
8545         (double_int_setbit): Reuse implementation for double_int::set_bit,
8546         which avoids a name conflict with a macro.
8547         (double_int_double_int_ctz): Reuse implementation for
8548         double_int::trailing_zeros.
8549         (double_int_fits_in_shwi_p): Reuse implementation for
8550         double_int::fits_signed.
8551         (double_int_fits_in_hwi_p): Reuse implementation for double_int::fits.
8552         (double_int_mul): Reuse implementation for binary
8553         double_int::operator *.
8554         (double_int_add): Likewise.
8555         (double_int_sub): Likewise.
8556         (double_int_neg): Reuse implementation for unary
8557         double_int::operator -.
8558         (double_int_max_value): Likewise.
8559         * fixed-value.c: Change to use member functions introduced above.
8560
8561 2012-08-14  Lawrence Crowl  <crowl@google.com>
8562
8563         Merge cxx-conversion branch.  Support tree macro calling from gdb.
8564
8565         * tree.h (tree_check): New.
8566         (TREE_CHECK): Use inline function above instead of __extension__.
8567         (tree_not_check): New.
8568         (TREE_NOT_CHECK): Use inline function above instead of __extension__.
8569         (tree_check2): New.
8570         (TREE_CHECK2): Use inline function above instead of __extension__.
8571         (tree_not_check2): New.
8572         (TREE_NOT_CHECK2): Use inline function above instead of __extension__.
8573         (tree_check3): New.
8574         (TREE_CHECK3): Use inline function above instead of __extension__.
8575         (tree_not_check3): New.
8576         (TREE_NOT_CHECK3): Use inline function above instead of __extension__.
8577         (tree_check4): New.
8578         (TREE_CHECK4): Use inline function above instead of __extension__.
8579         (tree_not_check4): New.
8580         (TREE_NOT_CHECK4): Use inline function above instead of __extension__.
8581         (tree_check5): New.
8582         (TREE_CHECK5): Use inline function above instead of __extension__.
8583         (tree_not_check5): New.
8584         (TREE_NOT_CHECK5): Use inline function above instead of __extension__.
8585         (contains_struct_check): New.
8586         (CONTAINS_STRUCT_CHECK): Use inline function above instead of
8587         __extension__.
8588         (tree_class_check): New.
8589         (TREE_CLASS_CHECK): Use inline function above instead of __extension__.
8590         (tree_range_check): New.
8591         (TREE_RANGE_CHECK): Use inline function above instead of __extension__.
8592         (omp_clause_subcode_check): New.
8593         (OMP_CLAUSE_SUBCODE_CHECK): Use inline function above instead of
8594         __extension__.
8595         (omp_clause_range_check): New.
8596         (OMP_CLAUSE_RANGE_CHECK): Use inline function above instead of
8597         __extension__.
8598         (expr_check): New.
8599         (EXPR_CHECK): Use inline function above instead of __extension__.
8600         (non_type_check): New.
8601         (NON_TYPE_CHECK): Use inline function above instead of __extension__.
8602         (tree_vec_elt_check): New.
8603         (TREE_VEC_ELT_CHECK): Use inline function above instead of
8604         __extension__.
8605         (omp_clause_elt_check): New.
8606         (OMP_CLAUSE_ELT_CHECK): Use inline function above instead of
8607         __extension__.
8608         (tree_operand_check): New.
8609         (TREE_OPERAND_CHECK): Use inline function above instead of
8610         __extension__.
8611         (tree_operand_check_code): New.
8612         (TREE_OPERAND_CHECK_CODE): Use inline function above instead of
8613         __extension__.
8614         (TREE_CHAIN): Simplify implementation.
8615         (TREE_TYPE): Simplify implementation.
8616         (tree_operand_length): Move for compilation dependences.
8617         * gdbinit.in: (macro define __FILE__): New.
8618         (macro define __LINE__): New.
8619         (skip "tree.h"): New.
8620
8621 2012-08-14  Oleg Endo  <olegendo@gcc.gnu.org>
8622
8623         PR target/52933
8624         * config/sh/sh.md (cmp_div0s_0, cmp_div0s_1, *cmp_div0s_0,
8625         *cmp_div0s_1, *cbranch_div0s, *movsicc_div0s): New insns.
8626         * config/sh/sh.c (sh_rtx_costs): Handle div0s patterns.
8627
8628 2012-08-14  Oleg Endo  <olegendo@gcc.gnu.org>
8629
8630         PR target/50751
8631         * config/sh/constraints.md (Sra): New constraint.
8632         * config/sh/predicates.md (simple_mem_operand,
8633         displacement_mem_operand, zero_extend_movu_operand): New predicates.
8634         (zero_extend_operand): Check zero_extend_movu_operand for SH2A.
8635         * config/sh/sh.md (*zero_extendqisi2_disp_mem,
8636         *zero_extendhisi2_disp_mem): Add new insns and two new related
8637         peephole2 patterns.
8638
8639 2012-08-14  Steven Bosscher  <steven@gcc.gnu.org>
8640
8641         * graphite-scop-detection.c (create_sese_edges): Compute dominance
8642         info before trying to fix loop structure.
8643         * cfgloopmanip.c (fix_loop_structure): Require fast DOM queries.
8644         * tree-cfgcleanup.c (repair_loop_structures): Likewise.
8645         * cfgloop.c (verify_loop_structure): Verify loop fathers.
8646
8647         * dominance.c (init_dom_info): Use gcc_checking_assert, not gcc_assert.
8648         (dom_convert_dir_to_idx, compute_dom_fast_query,
8649         get_immediate_dominator, set_immediate_dominator, get_dominated_by,
8650         redirect_immediate_dominators, nearest_common_dominator,
8651         (dominated_by_p, bb_dom_dfs_in, bb_dom_dfs_out, recompute_dominator,
8652         iterate_fix_dominators, add_to_dominance_info,
8653         delete_from_dominance_info): Likewise.
8654
8655 2012-08-14  Richard Guenther  <rguenther@suse.de>
8656
8657         * cfgexpand.c (expand_used_vars): Use virtual_operand_p.
8658         * gimple-pretty-print.c (dump_phi_nodes): Likewise.
8659         * gimple-streamer-out.c (output_bb): Likewise.
8660         * graphite-sese-to-poly.c (scalar_close_phi_node_p): Likewise.
8661         (rewrite_reductions_out_of_ssa): Likewise.
8662         (rewrite_commutative_reductions_out_of_ss): Likewise.
8663         * ipa-split.c (verify_non_ssa_vars): Likewise.
8664         (consider_split): Likewise.
8665         (visit_bb): Likewise.
8666         (split_function): Likewise.
8667         * lto-streamer-out.c (output_ssa_names): Likewise.
8668         * sese.c (rename_uses): Likewise.
8669         * tree-cfg.c (replace_uses_by): Likewise.
8670         (gimple_merge_blocks): Likewise.
8671         (gimple_cfg2dot): Likewise.
8672         (verify_gimple_phi): Likewise.
8673         (replace_ssa_name): Likewise.
8674         (move_block_to_fn): Likewise.
8675         * tree-eh.c (cleanup_empty_eh_merge_phis): Likewise.
8676         * tree-if-conv.c (if_convertible_phi_p): Likewise.
8677         (predicate_scalar_phi): Likewise.
8678         * tree-inline.c (update_ssa_across_abnormal_edges): Likewise.
8679         (copy_phis_for_bb): Likewise.
8680         * tree-loop-distribution.c (generate_loops_for_partition): Likewise.
8681         (destroy_loop): Likewise.
8682         * tree-outof-ssa.c (eliminate_useless_phis): Likewise.
8683         (insert_backedge_copies): Likewise.
8684         * tree-parloops.c (transform_to_exit_first_loop): Likewise.
8685         (gather_scalar_reductions): Likewise.
8686         (try_create_reduction_list): Likewise.
8687         * tree-scalar-evolution.c (analyze_scalar_evolution_for_all_loop_ph):
8688         Likewise.
8689         (scev_const_prop): Likewise.
8690         * tree-ssa-ccp.c (debug_lattice_value): Likewise.
8691         (get_default_value): Likewise.
8692         (ccp_initialize): Likewise.
8693         * tree-ssa-coalesce.c (create_outofssa_var_map): Likewise.
8694         * tree-ssa-copy.c (may_propagate_copy): Likewise.
8695         (init_copy_prop): Likewise.
8696         * tree-ssa-dce.c (propagate_necessity): Likewise.
8697         (remove_dead_phis): Likewise.
8698         (forward_edge_to_pdom): Likewise.
8699         (eliminate_unnecessary_stmts): Likewise.
8700         * tree-ssa-live.c (partition_view_init): Likewise.
8701         (remove_unused_locals): Likewise.
8702         (register_ssa_partition_check): Likewise.
8703         * tree-ssa-loop-im.c (movement_possibility): Likewise.
8704         (move_computations_stmt): Likewise.
8705         * tree-ssa-loop-ivopts.c (determine_biv_step): Likewise.
8706         (record_invariant): Likewise.
8707         (find_interesting_uses_outside): Likewise.
8708         (determine_set_costs): Likewise.
8709         * tree-ssa-loop-manip.c (add_exit_phis_var): Likewise.
8710         (find_uses_to_rename_use): Likewise.
8711         (check_loop_closed_ssa_use): Likewise.
8712         (rewrite_phi_with_iv): Likewise.
8713         (canonicalize_loop_ivs): Likewise.
8714         * tree-ssa-math-opts.c (execute_cse_reciprocals): Likewise.
8715         * tree-ssa-phiopt.c (hoist_adjacent_loads): Likewise.
8716         * tree-ssa-pre.c (make_values_for_phi): Likewise.
8717         (compute_avail): Likewise.
8718         (eliminate): Likewise.
8719         * tree-ssa-propagate.c (substitute_and_fold): Likewise.
8720         * tree-ssa-reassoc.c (phi_rank): Likewise.
8721         * tree-ssa-strlen.c (strlen_enter_block): Likewise.
8722         * tree-ssa-structalias.c (compute_points_to_sets): Likewise.
8723         (ipa_pta_execute): Likewise.
8724         * tree-ssa-tail-merge.c (same_succ_hash): Likewise.
8725         (release_last_vdef): Likewise.
8726         (same_phi_alternatives_1): Likewise.
8727         (bb_has_non_vop_phi): Likewise.
8728         (vop_phi): Likewise.
8729         * tree-ssa-threadedge.c (record_temporary_equivalences_from_phis):
8730         Likewise.
8731         * tree-ssa-uninit.c (warn_uninitialized_phi): Likewise.
8732         (execute_late_warn_uninitialized): Likewise.
8733         * tree-ssa.c (verify_ssa_name): Likewise.
8734         (verify_phi_args): Likewise.
8735         (verify_ssa): Likewise.
8736         * tree-stdarg.c (execute_optimize_stdarg): Likewise.
8737         * tree-vect-loop-manip.c (slpeel_update_phi_nodes_for_guard1):
8738         Likewise.
8739         (slpeel_tree_peel_loop_to_edge): Likewise.
8740         (vect_can_advance_ivs_p): Likewise.
8741         (vect_update_ivs_after_vectorizer): Likewise.
8742         * tree-vect-loop.c (vect_analyze_scalar_cycles_1): Likewise.
8743         * tree-vrp.c (remove_range_assertions): Likewise.
8744         * value-prof.c (gimple_divmod_values_to_profile): Likewise.
8745
8746 2012-08-14  Richard Guenther  <rguenther@suse.de>
8747
8748         PR tree-optimization/54146
8749         * tree-ssa-pre.c (do_regular_insertion): Use a VEC
8750         indexed by pred edge index for avail.
8751         (do_partial_partial_insertion): Likewise.
8752         (insert_into_preds_of_block): Adjust.
8753
8754 2012-08-14  Richard Guenther  <rguenther@suse.de>
8755
8756         * gimplify.c (create_tmp_from_val): Mark temporary with
8757         DECL_GIMPLE_REG_P here ...
8758         (internal_get_tmp_var): ... instead of here.  If we go into
8759         SSA create an SSA name instead of a VAR_DECL.
8760         (gimplify_modify_expr): Do not create SSA names here, assert
8761         we already got them.
8762         (force_gimple_operand_1): Create an SSA name if we go into SSA.
8763         * sese.c (rename_uses): Simplify.
8764
8765 2012-08-14  Richard Guenther  <rguenther@suse.de>
8766
8767         * tree-into-ssa.c: Include diagnostic-core.h.
8768         * Makefile.in (tree-into-ssa.o): Adjust.
8769
8770 2012-08-14  Richard Guenther  <rguenther@suse.de>
8771
8772         * tree-into-ssa.c (update_ssa): Verify we do not rename
8773         symbols that are already partly in SSA form.
8774
8775 2012-08-14  Jakub Jelinek  <jakub@redhat.com>
8776
8777         PR middle-end/53411
8778         PR rtl-optimization/53495
8779         * ira.c (ira): Move delete_trivially_dead_insns call before
8780         find_moveable_pseudos call.
8781
8782 2012-08-13  Steven Bosscher  <steven@gcc.gnu.org>
8783
8784         * tree-ssa-pre.c (do_regular_insertion): Add FIXME markers at points
8785         of potentially huge memset overhead.
8786         (do_partial_partial_insertion): Likewise.
8787         * cfgexpand.c (gimple_expand_cfg): Use XCNEWVEC instead of xcalloc.
8788         * tree-vrp.c (find_assert_locations): Use XNEWVEC instead of XCNEWVEC
8789         for arrays to be filled by pre_and_rev_post_order_compute.  Allocate
8790         the right number of slots, not that number plus NUM_FIXED_BLOCKS.
8791         * tree-ssa-reassoc.c (init_reassoc): Likewise.
8792         * cfganal.c (dfs_enumerate_from): Use XNEWVEC instead of XCNEWVEC for
8793         array used as stack.
8794         * tree-ssa-sccvn.c (init_scc_vn): Use XNEWVEC instead of XCNEWVEC for
8795         arrays to be filled by pre_and_rev_post_order_compute.
8796         * cfgloopmanip.c (find_path): Use XNEWVEC instead of XCNEWVEC for
8797         array to be filled by dfs_enumerate_from.
8798         (remove_path): Likewise.
8799         (duplicate_loop_to_header_edge): Use XNEWVEC instead of XCNEWVEC for
8800         array of loops that is filled on the next lines.
8801         * cfgloop.c (get_loop_body): Use XNEWVEC instead of XCNEWVEC for
8802         array of basic blocks to be returned.
8803         (get_loop_body_in_dom_order): Likewise.
8804         (get_loop_body_in_bfs_order): Likewise.
8805         * tree-ssa-loop-manip.c (loop_renamer_obstack): New static obstack
8806         for all bitmaps used for rewriting into loop-closed SSA form.
8807         (add_exit_phis_var): Allocate the def bitmap on it.  Clear the livein
8808         bitmap at the end to release a lot of memory.
8809         (add_exit_phis): Allocate the exits bitmap on the new obstack.
8810         (get_loops_exits): Allocate the exits bitmap on the new obstack.
8811         (find_uses_to_rename_use): Allocate a use_blocks bitmap if ver is
8812         seen for the first time.
8813         (find_uses_to_rename): Add "???" for why the whole function must
8814         be re-scanned if changed_bbs is empty.
8815         (rewrite_into_loop_closed_ssa): Allocate bitmaps on the new obstack.
8816         Use XNEWVEC to allocate the use_blocks array.  Initialize the new
8817         obstack, and free it at the end.  Remove loop over all SSA names.
8818         (check_loop_closed_ssa_stmt): Look only at SSA_OP_USE operands.
8819         * tree-cfg.c (move_sese_region_to_fn): Use XNEWVEC instead of
8820         xcalloc to allocate edge_pred and edge_flag arrays.
8821
8822 2012-08-13  Uros Bizjak  <ubizjak@gmail.com>
8823
8824         * config/i386/i386.h (FIXED_REGISTERS): Do not mark REX registers here.
8825         (CALL_USED_REGISTERS): Use bitmaps to mark call-used registers
8826         for different ABIs.
8827         (enum reg_class): Move CLOBBERED_REGS just before GENERAL_REGS.
8828         (REG_CLASS_NAMES): Update.
8829         (REG_CLASS_CONTENTS): Update.  Clear CLOBBERED_REGS members.
8830         * config/i386/i386.c (ix86_conditional_register_usage): Disable
8831         REX registers on 32bit targets.  Handle bitmaps from
8832         CALL_USED_REGISTERS initializer.  Calculate CLOBBERED_REGS register
8833         set from GENERAL_REGS also for 32bit targets.  Do not change call
8834         used register set for TARGET_64BIT_MS_ABI separately.
8835
8836 2012-08-13  Richard Guenther  <rguenther@suse.de>
8837
8838         * basic-block.h (struct basic_block): Remove loop_depth
8839         member, move flags and index members next to each other.
8840         * cfgloop.h (bb_loop_depth): New inline function.
8841         * cfghooks.c (split_block): Do not set loop_depth.
8842         (duplicate_block): Likewise.
8843         * cfgloop.c (flow_loop_nodes_find): Likewise.
8844         (flow_loops_find): Likewise.
8845         (add_bb_to_loop): Likewise.
8846         (remove_bb_from_loops): Likewise.
8847         * cfgrtl.c (force_nonfallthru_and_redirect): Likewise.
8848         * gimple-streamer-in.c (input_bb): Do not stream loop_depth.
8849         * gimple-streamer-out.c (output_bb): Likewise.
8850         * bt-load.c: Include cfgloop.h.
8851         (migrate_btr_defs): Use bb_loop_depth.
8852         * cfg.c (dump_bb_info): Likewise.
8853         * final.c (compute_alignments): Likewise.
8854         * ira.c (update_equiv_regs): Likewise.
8855         * tree-ssa-copy.c (init_copy_prop): Likewise.
8856         * tree-ssa-dom.c (loop_depth_of_name): Likewise.
8857         * tree-ssa-forwprop.c: Include cfgloop.h.
8858         (forward_propagate_addr_expr): Use bb_loop_depth.
8859         * tree-ssa-pre.c (insert_into_preds_of_block): Likewise.
8860         * tree-ssa-sink.c (select_best_block): Likewise.
8861         * ipa-inline-analysis.c: Include cfgloop.h.
8862         (estimate_function_body_sizes): Use bb_loop_depth.
8863         * Makefile.in (tree-ssa-forwprop.o): Depend on $(CFGLOOP_H).
8864         (ipa-inline-analysis.o): Likewise.
8865         (bt-load.o): Likewise.
8866
8867 2012-08-13  Ganesh Gopalasubramanian  <Ganesh.Gopalasubramanian@amd.com>
8868             Jakub Jelinek  <jakub@redhat.com>
8869
8870         PR driver/54210
8871         * config/i386/driver-i386.c (host_detect_local_cpu): Test bit_PRFCHW
8872         bit of CPUID 0x80000001 %ecx instead of CPUID 7 %ecx.
8873         * config/i386/cpuid.h (bits_PRFCHW): Move definition to CPUID
8874         0x80000001 %ecx flags.
8875
8876 2012-08-13  Richard Guenther  <rguenther@suse.de>
8877
8878         * tree-cfg.c (print_loop): Avoid ICEing for loops marked for
8879         removal and loops with multiple latches.
8880
8881 2012-08-13  Jakub Jelinek  <jakub@redhat.com>
8882
8883         PR c/53968
8884         * tree.c (integer_pow2p): Avoid undefined signed overflows.
8885         * simplify-rtx.c (neg_const_int): Likewise.
8886         * expr.c (fixup_args_size_notes): Likewise.
8887         * stor-layout.c (set_min_and_max_values_for_integral_type): Likewise.
8888         * double-int.c (mul_double_wide_with_sign): Likewise.
8889         (double_int_mask): Likewise.
8890         * tree-ssa-loop-ivopts.c (get_address_cost): Likewise.
8891
8892 2012-08-13  Richard Guenther  <rguenther@suse.de>
8893
8894         PR tree-optimization/54200
8895         * tree-ssa-copyrename.c (rename_ssa_copies): Do not add
8896         PHI results to another partition if not all PHI arguments
8897         have the same partition.
8898
8899 2012-08-12  Jan Hubicka  <jh@suse.cz>
8900
8901         * tree-pass.h (write_summary, write_optimization_summary): Remove
8902         set and vset arguments.
8903         * ipa-cp.c (ipcp_write_summary): Remove set and vset arugments.
8904         (write_node_summary_p): Likewise; use the encoder.
8905         (ipa_reference_write_optimization_summary): Likewise.
8906         * lto-cgraph.c (output_cgraph_opt_summary): Use encoder.
8907         (lto_symtab_encoder_new): Initialize in_partition field.
8908         (lto_symtab_encoder_delete): Destroy in_partition field.
8909         (LCC_NOT_FOUND): Move to lto-streamer.h
8910         (lto_symtab_encoder_deref): Likewise.
8911         (lto_symtab_encoder_in_partition_p,
8912         lto_set_symtab_encoder_in_partition): New functions.
8913         (referenced_from_other_partition_p): Rewrite to use encoder.
8914         (reachable_from_other_partition_p): Likewise.
8915         (referenced_from_this_partition_p): Likewise.
8916         (reachable_from_this_partition_p): Likewise.
8917         (lto_output_node): Likewise.
8918         (lto_output_varpool_node): Likewise.
8919         (output_refs): Likewise.
8920         (compute_ltrans_boundary): Initialize in_partition fileds of
8921         the encoder.
8922         (output_symtab): Likewise.
8923         (input_refs): Match the changes in output_refs.
8924         (output_cgraph_opt_summary_p): Remove set argument.
8925         (output_node_opt_summary): Replace set by encoder.
8926         (output_cgraph_opt_summary): Remove set argument; use
8927         the encoder.
8928         * ipa-pure-const.c (pure_const_write_summary): Remove set and vset
8929         arguments; use the encoder.
8930         * lto-streamer-out.c (lto_output): Remove set and vset argument; use
8931         the encoder.
8932         (produce_symtab): Likewise.
8933         * ipa-inline.h (inline_write_summary): Remove set and vset arguments.
8934         * ipa-inline-analysis.c (inline_write_summary): Likewise.
8935         * ipa-prop.c (ipa_prop_write_jump_functions): Remove set argument;
8936         use encoder.
8937         * ipa-prop.h (ipa_prop_write_jump_functions): Likewise.
8938         * passes.c (ipa_write_summaries_2): Remove set and vset arguments.
8939         (ipa_write_summaries_1): Update.
8940         (ipa_write_optimization_summaries_1): Likewise.
8941         (ipa_write_optimization_summaries): Likewise.
8942         * lto-streamer.h (lto_symtab_encoder_t): Add in_partition.
8943         (lto_symtab_encoder_iterator): New type.
8944         (lto_symtab_encoder_deref): Make inline.
8945         (output_symtab, referenced_from_other_partition_p,
8946         reachable_from_other_partition_p, referenced_from_this_partition_p,
8947         reachable_from_this_partition_p): Update.
8948         (lsei_end_p, lsei_next, lsei_node, lsei_cgraph_node,
8949         lsei_varpool_node): New inline functions.
8950         (LCC_NOT_FOUND): New macro.
8951         (lto_symtab_encoder_deref, lsei_start, lsei_next_in_partition,
8952         lsei_start_in_partition, lsei_next_function_in_partition,
8953         lsei_start_function_in_partition, lsei_next_variable_in_partition,
8954         lsei_start_variable_in_partition): New inline functions.
8955
8956 2012-08-12  Oleg Endo  <olegendo@gcc.gnu.org>
8957
8958         * config/sh/sh.md (prefetch): Simplify expander.  Fix condition to
8959         allow SH3.
8960         (*prefetch_media): Move insn below expander.
8961         (*prefetch): Fix condition to allow SH3.
8962
8963 2012-08-12  Oleg Endo  <olegendo@gcc.gnu.org>
8964
8965         PR target/51244
8966         * config/sh/sh.md: Add splits for inverted compare and branch
8967         opportunities.
8968         (*cmpeqsi_t): New insn.
8969         (cmpgtsi_t, cmpgesi_t): Swap r and N alternatives.
8970         (cmpgeusi_t): Use satisfies_constraint_Z.  Emit sett insn in
8971         replacement insn list and not in the preparation statements.
8972         (clrt, sett): Add mt_group attribute.
8973
8974 2012-08-12 Marc Glisse <marc.glisse@inria.fr>
8975
8976         PR middle-end/54193
8977         * gimple-pretty-print.c (dump_ternary_rhs): Handle 4 arguments.
8978
8979 2012-08-12  Oleg Endo  <olegendo@gcc.gnu.org>
8980
8981         PR target/39423
8982         * config/sh/predicates.md (mem_index_disp_operand): Check for
8983         arith_reg_operand instead of REG_P.
8984
8985 2012-08-11  Bernd Schmidt  <bernds@codesourcery.com>
8986
8987         * reload1.c (replaced_subreg, gen_reload): Add
8988         SECONDARY_MEMORY_NEEDED ifdefs as necessary.
8989
8990 2012-08-11  Jan Hubicka  <jh@suse.cz>
8991
8992         * lto-section-in.c (lto_section_name): Do not use "symtab" as part of
8993         symtab_node sectoin name; it confuses plugin.
8994
8995 2012-08-11  Uros Bizjak  <ubizjak@gmail.com>
8996
8997         * config/alpha/alpha.c (alpha_stdarg_optimize_hook): Shift DECL_UID
8998         index in the va_list_vars bitmap by num_ssa_names.
8999
9000 2012-08-11  Uros Bizjak  <ubizjak@gmail.com>
9001
9002         * config/i386/sse.md (xop integer multiply/add insns): Use
9003         register_operand for operand 3 predicate.
9004         (xop_phadd<u>bq):  Fix vec_select selectors.
9005
9006 2012-08-11  Martin Jambor  <mjambor@suse.cz>
9007
9008         PR fortran/48636
9009         * ipa-inline.h (condition): New fields offset, agg_contents and by_ref.
9010         * ipa-inline-analysis.c (agg_position_info): New type.
9011         (add_condition): New parameter aggpos, also store agg_contents, by_ref
9012         and offset.
9013         (dump_condition): Also dump aggregate conditions.
9014         (evaluate_conditions_for_known_args): Also handle aggregate
9015         conditions.  New parameter known_aggs.
9016         (evaluate_properties_for_edge): Gather known aggregate contents.
9017         (inline_node_duplication_hook): Pass NULL known_aggs to
9018         evaluate_conditions_for_known_args.
9019         (unmodified_parm): Split into unmodified_parm and unmodified_parm_1.
9020         (unmodified_parm_or_parm_agg_item): New function.
9021         (set_cond_stmt_execution_predicate): Handle values passed in
9022         aggregates.
9023         (set_switch_stmt_execution_predicate): Likewise.
9024         (will_be_nonconstant_predicate): Likewise.
9025         (estimate_edge_devirt_benefit): Pass new parameter known_aggs to
9026         ipa_get_indirect_edge_target.
9027         (estimate_calls_size_and_time): New parameter known_aggs, pass it
9028         recrsively to itself and to estimate_edge_devirt_benefit.
9029         (estimate_node_size_and_time): New vector known_aggs, pass it o
9030         functions which need it.
9031         (remap_predicate): New parameter offset_map, use it to remap aggregate
9032         conditions.
9033         (remap_edge_summaries): New parameter offset_map, pass it recursively
9034         to itself and to remap_predicate.
9035         (inline_merge_summary): Also create and populate vector offset_map.
9036         (do_estimate_edge_time): New vector of known aggregate contents,
9037         passed to functions which need it.
9038         (inline_read_section): Stream new fields of condition.
9039         (inline_write_summary): Likewise.
9040         * ipa-cp.c (ipa_get_indirect_edge_target): Also examine the aggregate
9041         contents.  Let all local callers pass NULL for known_aggs.
9042
9043 2012-08-11  Jan Hubicka  <jh@suse.cz>
9044
9045         * lto-cgraph.c (output_cgraph): Rename to ...
9046         (output_symtab): ... this one. Update for LTO_section_symtab_nodes.
9047         (input_cgraph): Rename to ...
9048         (input_symtab): ... this one. Update for LTO_section_symtab_nodes.
9049         * lto-streamer-out.c (create_output_block): Do not set
9050         section_type.
9051         (produce_asm): Likewise.
9052         (lto_output_toplevel_asms): Likewise.
9053         (produce_asm_for_decls): Likewise.
9054         (lto_output): Use output_symtab.
9055         * lto-section-in.c (lto_section_name): Update.
9056         * lto-section-out.c (lto_destroy_simple_output_block): Remove
9057         section_type.
9058         * lto-streamer.h (enum lto_section_type): Remove LTO_section_varpool;
9059         rename LTO_section_cgraph to LTO_section_symtab_nodes.
9060         (struct lto_header): Remove section_type.
9061
9062 2012-08-11  Jan Hubicka  <jh@suse.cz>
9063
9064         * cgraph.h (vector types for symtab_node): Add.
9065         * ipa-reference.c (ipa_reference_write_optimization_summary): Update
9066         for new symtab encoder.
9067         (ipa_reference_read_optimization_summary): Likewise.
9068         * lto-cgraph.c (output_varpool): Remove.
9069         (input_cgraph_opt_summary): Take symtab nodes vector as argument.
9070         (LTO_cgraph_tags): Rename to ...
9071         (LTO_symtab_tags): ... this one; add LTO_symtab_variable.
9072         (lto_cgraph_encoder_new): Rename to ...
9073         (lto_symtab_encoder_new): ... this on.
9074         (lto_cgraph_encoder_encode): Rename to ...
9075         (lto_symtab_encoder_encode): ... this one.
9076         (lto_cgraph_encoder_delete): Rename to ...
9077         (lto_symtab_encoder_delete): ... this one.
9078         (lto_cgraph_encoder_deref): Rename to ...
9079         (lto_symtab_encoder_deref): ... this one.
9080         (lto_cgraph_encoder_encode_body_p): Rename to ...
9081         (lto_symtab_encoder_encode_body_p): ... this one.
9082         (lto_varpool_encoder_new, lto_varpool_encoder_delete,
9083         lto_varpool_encoder_encode, lto_varpool_encoder_lookup,
9084         lto_varpool_encoder_deref): Remove.
9085         (lto_varpool_encoder_encode_initializer_p): Rename to ...
9086         (lto_symtab_encoder_encode_initializer_p): ... this one.
9087         (lto_set_varpool_encoder_encode_initializer): Rename to ...
9088         (lto_set_symtab_encoder_encode_initializer): ... this one.
9089         (lto_output_edge): Update.
9090         (lto_output_node): Update.
9091         (lto_output_varpool_node): Update; stream out LTO_symtab_variable tag.
9092         (lto_output_ref): Drop varpool_encoder; update.
9093         (add_node_to): Update.
9094         (add_references): Update.
9095         (output_outgoing_cgraph_edges): Update.
9096         (output_refs): Update.
9097         (compute_ltrans_boundary): Update.
9098         (output_cgraph): Update; output varpools too.
9099         (input_overwrite_node): Update.
9100         (output_varpool): Remove.
9101         (input_node): Update.
9102         (input_ref): Update.
9103         (input_edge): Update.
9104         (input_cgraph_1): Update; input varpool too; unify fixup code.
9105         (input_varpool_1): Remove.
9106         (input_refs): Update.
9107         (input_cgraph): Update.
9108         (output_node_opt_summary): Update.
9109         (input_cgraph_opt_section): Update.
9110         (input_cgraph_opt_summary): Update.
9111         * ipa-pure-const.c (pure_const_write_summary): Update.
9112         (pure_const_read_summary): Update.
9113         * lto-streamer-out.c (lto_write_tree): Update.
9114         (lto_output): Likewise.
9115         (produce_symtab): Update.
9116         (produce_asm_for_decls): Update.
9117         * ipa-inline-analysis.c (inline_read_section): Update.
9118         (inline_write_summary): Update.
9119         * ipa-prop.c (ipa_write_node_info): Update.
9120         (ipa_prop_read_section): Update.
9121         * lto-streamer.h (lto_cgraph_encoder_d): Rename to ...
9122         (lto_symtab_encoder_d): ... this one;  add initializer.
9123         (lto_cgraph_encoder_t): Rename to ...
9124         (lto_symtab_encoder_t): ... this one.
9125         (lto_cgraph_encoder_size): Rename to ...
9126         (lto_symtab_encoder_size): ... this one.
9127         (lto_varpool_encoder_d): ... remove.
9128         (lto_varpool_encoder_t): Remove.
9129         (lto_out_decl_state): Remove cgraph_node_encoder, varpool_node_encoder
9130         add symtab_node_encoder.
9131         (lto_file_decl_data): Likewise.
9132         (lto_cgraph_encoder_deref, lto_cgraph_encoder_lookup,
9133         lto_cgraph_encoder_new, lto_cgraph_encoder_encode,
9134         lto_cgraph_encoder_delete, lto_cgraph_encoder_encode_body_p,
9135         lto_varpool_encoder_encode_body_p, lto_varpool_encoder_deref,
9136         lto_varpool_encoder_lookup, lto_varpool_encoder_new,
9137         lto_varpool_encoder_encode, lto_varpool_encoder_delete,
9138         lto_varpool_encoder_encode_initializer_p): Remove.
9139         (lto_symtab_encoder_deref, lto_symtab_encoder_lookup,
9140         lto_symtab_encoder_t, lto_symtab_encoder_encode,
9141         lto_symtab_encoder_delete, lto_symtab_encoder_encode_body_p,
9142         lto_symtab_encoder_encode_initializer_p): New.
9143
9144 2012-08-11  Uros Bizjak  <ubizjak@gmail.com>
9145
9146         * config/i386/i386.md (isa): Add fma and fma4.
9147         (enabled): Handle fma and fma4.
9148         * config/i386/sse.md (*fma_fmadd_<mode>): Merge *fma4_fmadd_<mode>.
9149         (*fma_fmsub_<mode>): Merge *fma4_fmsub_<mode>.
9150         (*fma_fnmadd_<mode>): Merge *fma4_fnmadd_<mode>.
9151         (*fma_fnmsub_<mode>): Merge *fma4_fnmsub_<mode>.
9152         (*fma_fmaddsub_<mode>): Merge *fma4_fmaddsub_<mode>.
9153         (*fma_fmsubadd_<mode>): Merge *fma4_fmsubadd_<mode>.
9154
9155 2012-08-10  Uros Bizjak  <ubizjak@gmail.com>
9156
9157         * config/i386/sse.md (*fma_fmadd_<mode>, *fma_fmsub_<mode>,
9158         *fma_fnmadd_<mode>, *fma_fnmsub_<mode>, *fma_fmaddsub_<mode>,
9159         *fma_fmsubadd_<mode>): Move FMA3 insn patterns before FMA4 patterns.
9160
9161 2012-08-10  Uros Bizjak  <ubizjak@gmail.com>
9162
9163         * config/i386/i386.md (simple LEA peephole2s): Add zero-extend
9164         variants of PLUS and MULT simple LEA patterns.  Disable PLUS
9165         patterns for TARGET_OPT_AGU.
9166
9167 2012-08-10  Richard Guenther  <rguenther@suse.de>
9168
9169         * Makefile.in (OBJS): Remove matrix-reorg.o.
9170         (matrix-reorg.o): Remove dependence rule.
9171         (GTFILES): Remove matrix-reorg.c.
9172         * matrix-reorg.c: Remove.
9173         * passes.c (init_optimization_passes): Do not schedule
9174         pass_ipa_matrix_reorg.
9175         * tree-pass.h (pass_ipa_matrix_reorg): Remove.
9176         * common.opt (fipa-matrix-reorg): Stub out.
9177         * doc/invoke.texi (fipa-matrix-reorg): Remove documentation.
9178
9179 2012-08-10  Richard Guenther  <rguenther@suse.de>
9180
9181         PR middle-end/54219
9182         * fold-const.c (fold_ternary_loc): Do not reverse the mask
9183         when canonicalizing it when folding VEC_PERM_EXPR.
9184
9185 2012-08-10  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
9186
9187         PR middle-end/54211
9188         * gimple-ssa-strength-reduction.c (analyze_candidates_and_replace):
9189         Use cand_type to determine whether pointer arithmetic will be generated.
9190
9191 2012-08-10  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
9192
9193         * doc/sourcebuild.texi: Document long_neq_int effective target.
9194
9195 2012-08-10  Richard Guenther  <rguenther@suse.de>
9196
9197         PR tree-optimization/54109
9198         * tree-ssa-forwprop.c
9199         (forward_propagate_addr_into_variable_array_index): Remove.
9200         (forward_propagate_addr_expr_1): Adjust.
9201
9202 2012-08-10  Richard Guenther  <rguenther@suse.de>
9203
9204         * tree-cfg.c (dump_function_to_file): Make sure to dump
9205         anonymous SSA names when there are no local decls.
9206
9207 2012-08-10  Steven Bosscher  <steven@gcc.gnu.org>
9208
9209         * tree-ssa-pre.c (alloc_expression_id): Fix use of VEC_reserve.
9210         * tree-into-ssa.c (get_ssa_name_ann): Likewise.
9211         (mark_phi_for_rewrite): Likewise.
9212         (compute_global_livein): Use VEC_reserve outside the innermost
9213         loop and VEC_quick_push instead of VEC_safe_push in that loop.
9214         (update_ssa): Re-organize to avoid unnecessary sbitmap_zero'ing
9215         of new_ssa_names and old_ssa_names.  Allocate phis_to_rewrite to
9216         the correct initial size.
9217
9218 2012-08-10  Richard Guenther  <rguenther@suse.de>
9219
9220         * tree-ssa-pre.c (pretemp, storetemp, prephitemp): Remove.
9221         (need_creation): Remove.
9222         (get_representative_for): Use anonymous named SSA names.
9223         (create_expression_by_pieces): Likewise.
9224         (insert_into_preds_of_block): Likewise.
9225         (init_pre): Do not init removed vars.
9226         (fini_pre): Do not free need_creation.
9227         * tree-ssa-forwprop.c (simplify_bitwise_binary): Use anonymous
9228         SSA names.
9229         * tree-ssa-loop-manip.c (create_iv): Likewise.
9230         * value-prof.c (gimple_divmod_fixed_value): Likewise.
9231         (gimple_mod_pow2): Likewise.
9232         (gimple_mod_subtract): Likewise.
9233         (gimple_ic): Likewise.
9234         (gimple_stringop_fixed_value): Likewise.
9235         * tree-ssa-phiopt.c (condstoretemp): Remove.
9236         (tree_ssa_phiopt_worker): Use anonymous named SSA names.
9237         (conditional_replacement): Likewise.
9238         (abs_replacement): Likewise.
9239         (cond_store_replacement): Likewise.
9240         (cond_if_else_store_replacement_1): Likewise.
9241         * tree-ssa-loop-im.c (rewrite_reciprocal): Likewise.
9242         (rewrite_bittest): Likewise.
9243         * tree-ssa-reassoc.c (build_and_add_sum): Get type from callers
9244         and build anonymous SSA names.
9245         (undistribute_ops_list): Adjust.
9246         (eliminate_redundant_comparison): Use anonymous SSA names.
9247         (rewrite_expr_tree_parallel): Likewise.
9248         (get_reassoc_pow_ssa_name): Remove.
9249         (attempt_builtin_powi): Adjust.
9250         (reassociate_bb): Likewise.
9251         * tree-ssa-strlen.c (get_string_length): Use anonymous SSA names.
9252         * tree-switch-conversion.c (emit_case_bit_tests): Likewise.
9253         (build_arrays): Likewise.
9254         * tree-tailcall.c (adjust_return_value_with_ops): Likewise.
9255         (create_tailcall_accumulator): Likewise.
9256         * tree-vect-generic.c (expand_vector_divmod): Likewise.
9257         * tree-profile.c (gcov_type_tmp_var): Remove.
9258         (gimple_init_edge_profiler): Do not initialize it and use anonymous
9259         SSA names.
9260         (gimple_gen_ic_profiler): Likewise.
9261         (tree_profiling): Adjust.
9262         * tree-sra.c (build_ref_for_offset): Use anonymous SSA names.
9263         * tree-ssa-math-opts.c (execute_cse_sincos_1): Likewise.
9264         (powi_as_mults_1): Likewise.
9265         (powi_as_mults): Likewise.
9266         (build_and_insert_call): Adjust.
9267         (build_and_insert_binop): Likewise.
9268         (build_and_insert_ref): Likewise.
9269         (build_and_insert_cast): Likewise.
9270         (gimple_expand_builtin_pow): Likewise.
9271         (gimple_expand_builtin_cabs): Likewise.
9272         (execute_optimize_bswap): Use anonymous SSA names.
9273         (convert_mult_to_widen): Likewise.
9274         (convert_plusminus_to_widen): Likewise.
9275         * tree-ssa-phiprop.c (phiprop_insert_phi): Likewise.
9276         * tree-ssa-propagate.c (update_call_from_tree): Likewise.
9277         * tree-if-conv.c (ifc_temp_var): Likewise.
9278         * tree-loop-distribution.c (generate_memset_builtin): Likewise.
9279         * tree-parloops.c (take_address_of): Likewise.
9280         * tree-vect-data-refs.c (vect_permute_store_chain): Likewise.
9281         (vect_permute_load_chain): Likewise.
9282         * tree-vect-loop-manip.c (vect_create_cond_for_align_checks): Likewise.
9283         * tree-vect-patterns.c (vect_recog_temp_ssa_var): Likewise.
9284         (vect_handle_widen_op_by_const): Likewise.
9285         (vect_operation_fits_smaller_type): Likewise.
9286         (vect_recog_over_widening_pattern): Likewise.
9287         * tree-vect-stmts.c (vect_init_vector): Likewise.
9288         * tree-vrp.c (simplify_truth_ops_using_ranges): Likewise.
9289         (simplify_float_conversion_using_ranges): Likewise.
9290
9291 2012-08-10  Michael Zolotukhin  <michael.v.zolotukhin@intel.com>
9292
9293         * config/i386/i386.c (ix86_init_mmx_sse_builtins): Fix
9294         target mask of __builtin_ia32_rdseed_di_step builtin.
9295
9296 2012-08-10  Richard Guenther  <rguenther@suse.de>
9297
9298         PR tree-optimization/54027
9299         * tree-vrp.c (extract_range_from_binary_expr_1): Merge RSHIFT_EXPR
9300         and LSHIFT_EXPR handling, force -fwrapv for the multiplication used
9301         to handle LSHIFT_EXPR with a constant.
9302
9303 2012-08-10  Richard Guenther  <rguenther@suse.de>
9304
9305         * tree.h (SSA_NAME_VAR): Return NULL_TREE if an IDENTIFIER_NODE
9306         is recorded as var.
9307         (SSA_NAME_IDENTIFIER): Return the IDENTIFIER_NODE of the SSA_NAME
9308         or its SSA_NAME_VAR.
9309         (SET_SSA_NAME_VAR_OR_IDENTIFIER): New setter.
9310         * tree-ssanames.c (make_ssa_name_fn): Handle creating anonymous
9311         SSA names by passing a type instead of a variable decl.
9312         (release_ssa_name): Use SET_SSA_NAME_VAR_OR_IDENTIFIER.
9313         (copy_ssa_name_fn): Handle anonymous SSA names.
9314         (replace_ssa_name_symbol): Use SET_SSA_NAME_VAR_OR_IDENTIFIER.
9315         * tree-flow-inline.h (make_temp_ssa_name): New inline function.
9316         * tree-pretty-print.c (dump_generic_node): Use SSA_NAME_IDENTIFIER,
9317         dump SSA names without a name as <anon>.
9318         * cfgexpand.c (expand_used_vars): Assing anonymous SSA names we are
9319         going to expand a decl.
9320         (gimple_expand_cfg): Assign all SSA names of a partition the
9321         decl we created for its leader.
9322         * tree-ssa.c (target_for_debug_bind): Handle SSA_NAMEs.
9323         (verify_ssa_name): Handle anonymous SSA names.
9324         (verify_def): Likewise.
9325         * tree-predcom.c (eliminate_temp_copies): Likewise.
9326         * tree-ssa-copyrename.c (copy_rename_partition_coalesce): Likewise.
9327         * tree-ssa-live.c (var_map_base_init): Compute conflicts for
9328         anonymous SSA names with the same type.
9329         (mark_all_vars_used_1): Handle anonymous SSA names.
9330         (verify_live_on_entry): Likewise.
9331         * tree-ssa-coalesce.c (abnormal_corrupt): Remove.
9332         (create_outofssa_var_map): Adjust with respect to conflicts we
9333         compute for anonymous SSA names.  Do not restrict abnormal
9334         coalescing.
9335         (coalesce_partitions): Do not restrict abnormal coalescing.
9336         Assert we only ever coalesce variables we computed conflicts for.
9337         * tree-ssa-ter.c (process_replaceable): Do not restrict TER
9338         of anonymous names.
9339         * expr.c (expand_expr_real_1): Handle anonymous SSA names
9340         expanded from IVOPTs by creating a raw REG here.
9341         * tree-cfg.c (replace_ssa_name): Handle anonymous SSA names.
9342         (dump_function_to_file): Dump anonymous SSA names alongside
9343         with their types in the variable list.
9344         (verify_gimple_return): Guard use of SSA_NAME_VAR.
9345         * tree-into-ssa.c (mark_for_renaming): Handle a NULL symbol.
9346         (rewrite_into_ssa): Make SSA names anonymous.
9347         * tree-ssa-structalias.c (alias_get_name): Rewrite.
9348         * tree-ssa-uninit.c (ssa_undefined_value_p): Handle anonymous
9349         SSA names.
9350         (warn_uninitialized_phi): Likewise.
9351         * tree-ssa-loop-ivopts.c (prepare_decl_rtl): Defer expanding
9352         anonymous SSA names to the expander.
9353         (determine_iv_cost): Anonymous SSA names are artificial.
9354         * tree-ssa-loop-manip.c (tree_transform_and_unroll_loop):
9355         Handle anonymous SSA names.
9356         * lto-streamer-out.c (output_ssa_names): Stream SSA_NAME_VAR
9357         or if NULL, the type of the SSA name.
9358         * tree-inline.c (remap_ssa_name): Handle anonymous SSA names,
9359         remap names as anonymous where appropriate.
9360         (insert_init_stmt): Pass SSA names down to insert_init_debug_bind.
9361         * tree-ssa-uncprop.c (uncprop_into_successor_phis): Adjust
9362         according to what we create conflicts for in out-of-SSA
9363         coalescing.
9364         * tree-parloops.c (separate_decls_in_region_name): Handle
9365         anonymous SSA names.
9366         (add_field_for_name): Likewise.
9367         * tree.c (get_name): Handle SSA names.
9368         * tree-ssa-loop-im.c (gen_lsm_tmp_name): Defer to get_name for
9369         SSA_NAMEs.
9370         * tree-vect-loop-manip.c (adjust_debug_stmts): Use
9371         virtual_operand_p.
9372         * tree-sra.c (create_access_replacement): Give up generating
9373         a DECL_DEBUG_EXPR for SSA names in the memory reference.
9374         (replace_removed_params_ssa_names): Guard use of SSA_NAME_VAR.
9375         * tree-complex.c (get_component_ssa_name): Handle anonymous
9376         SSA names.
9377         (set_component_ssa_name): Likewise.
9378         * tree-ssa-sccvn.c (visit_reference_op_load): Likewise.
9379         * tree-object-size.c (collect_object_sizes_for): Handle
9380         uninitialized SSA names properly.
9381         * ipa-inline-analysis.c (eliminated_by_inlining_prob): Guard use of
9382         SSA_NAME_VAR.
9383         * ipa-split.c (test_nonssa_use): Likewise.
9384         (consider_split): Likewise.
9385         (mark_nonssa_use): Likewise.
9386
9387 2012-08-09  Jan Hubicka  <jh@suse.cz>
9388
9389         PR middle-end/54146
9390         * ipa-inline-transform.c (inline_call): Add UPDATE_OVERALL_SUMMARY
9391         parameter; honnor it.
9392         * ipa-inline.c (recursive_inlining): Update call
9393         of inline_call.
9394         (inline_small_functions): Likewise.
9395         (ipa_inline): Likewise.
9396         (inline_always_inline_functions): Likewise.
9397         (early_inline_small_functions): Likewise.
9398         (flatten_function): Do separate update of summary info.
9399         * ipa-inline.h (inline_update_overall_summary): Declare.
9400         (inline_call): Update.
9401         * ipa-inline-analysis.c (inline_merge_summary): Break out
9402         updating code to ...
9403         (inline_update_overall_summary): Likewise.
9404
9405 2012-08-09  Richard Henderson  <rth@redhat.com>
9406
9407         * config/s390/s390.c (s390_expand_insv): Use VOIDmode in gen_rtx_SET.
9408
9409         * config/s390/s390.c (s390_expand_cs_hqi): Copy val to a temp before
9410         performing the compare for the restart loop.
9411
9412 2012-08-09  DJ Delorie  <dj@redhat.com>
9413
9414         * config/rl78/rl78.c (rl78_alloc_physical_registers): Check for
9415         SET before extracting SET_SRC.
9416         (rl78_remove_unused_sets): Check for REG before extractnig REGNO.
9417
9418 2012-08-09  Oleg Endo  <olegendo@gcc.gnu.org>
9419
9420         PR target/54089
9421         * config/sh/sh-protos (shift_insns_rtx): Delete.
9422         (sh_ashlsi_clobbers_t_reg_p): Add.
9423         * config/sh/sh.c (shift_insns, shift_amounts, ext_shift_insns,
9424         ext_shift_amounts): Merge arrays of ints to array of structs.
9425         Adapt usage of arrays throughout the file.
9426         (shift_insns_rtx): Delete unused function.
9427         (sh_ashlsi_clobbers_t_reg_p): New function.
9428         * config/sh/sh.md (ashlsi3): Emit ashlsi3_n_clobbers_t insn if the
9429         final shift sequence will clobber T_REG.
9430         (ashlsi3_n): Split only if the final shift sequence will not
9431         clobber T_REG.
9432         (ashlsi3_n_clobbers_t): New insn_and_split.
9433
9434 2012-08-09  Steven Bosscher  <steven@gcc.gnu.org>
9435
9436         * calls.c (mem_overlaps_already_clobbered_arg_p): Use SBITMAP_SIZE
9437         instead of looking at sbitmap n_bits member directly.
9438         * gcse.c (hoist_code): Likewise.
9439         * sched-rgn.c (split_edges): Likewise.
9440         * tree-into-ssa.c (is_old_name, is_new_name, add_new_name_mapping,
9441         update_ssa): Likewise.
9442
9443 2012-08-09  Uros Bizjak  <ubizjak@gmail.com>
9444
9445         * config/i386/i386.h (LIMIT_RELOAD_CLASS): Return preferred
9446         single unit register class for classes that contain registers form
9447         multiple units.
9448         (REG_CLASS_CONTENTS): Add missing "frame" register to FLOAT_INT_REGS,
9449         INT_SSE_REGS and FLOAT_INT_SSE_REGS register classes.
9450
9451 2012-08-09  Martin Jambor  <mjambor@suse.cz>
9452
9453         * cgraph.h (cgraph_indirect_call_info): Field anc_offse renamd to
9454         offset, updated all users.  New field agg_contents.
9455         * ipa-prop.h (jump_func_type): Removed IPA_JF_CONST_MEMBER_PTR.
9456         (ipa_pass_through_data): New field agg_preserved.
9457         (ipa_ancestor_jf_data): Likewise.
9458         (ipa_member_ptr_cst): Removed.
9459         (ipa_agg_jf_item): New type.
9460         (ipa_agg_jump_function): Likewise.
9461         (ipa_jump_func): New field agg.  Removed field member_cst.
9462         (ipa_get_jf_pass_through_agg_preserved): New function.
9463         (ipa_get_jf_ancestor_agg_preserved): Likewise.
9464         (ipa_get_jf_member_ptr_pfn): Removed.
9465         (ipa_find_agg_cst_for_param): Declare.
9466         (ipa_load_from_parm_agg): Likewise.
9467         * ipa-prop.c (param_analysis_info): Fields modified and
9468         visited_statements rename to parm_modified and parm_visited_statements
9469         respectively, added fields ref_modified, ref_visited_statements,
9470         pt_modified and pt_visited_statements.
9471         (ipa_print_node_jump_functions_for_edge): Do not dump const member
9472         functions.  Dump agg_preserved flags and aggregate jump functions.
9473         (ipa_set_jf_simple_pass_through): Set also agg_preserved.
9474         (ipa_set_ancestor_jf): Likewise.
9475         (ipa_set_jf_arith_pass_through): Clear agg_preserved.
9476         (ipa_set_jf_member_ptr_cst): Removed.
9477         (is_parm_modified_before_stmt): Logic reversed, renamed to
9478         parm_preserved_before_stmt_p.  Cache visited bitmap only for
9479         naked DECL parameters.  All callers updated.
9480         (load_from_unmodified_param): Allow NULL parms_ainfo.
9481         (parm_ref_data_preserved_p): New function.
9482         (parm_ref_data_pass_through_p): Likewise.
9483         (ipa_load_from_parm_agg_1): Likewise.
9484         (ipa_load_from_parm_agg): Likewise.
9485         (compute_complex_assign_jump_func): Check if aggregate contents are
9486         preserved.
9487         (compute_complex_ancestor_jump_func): Likewise.
9488         (compute_scalar_jump_functions): Removed.
9489         (type_like_member_ptr_p): Also check field position are known and sane.
9490         (compute_pass_through_member_ptrs): Removed.
9491         (determine_cst_member_ptr): Likewise.
9492         (ipa_known_agg_contents_list): New type.
9493         (determine_known_aggregate_parts): New function.
9494         (compute_cst_member_ptr_arguments): Removed.
9495         (ipa_compute_jump_functions_for_edge): Compute all kinds of jump
9496         functions (scalar, aggregate and member pointer).
9497         (ipa_get_member_ptr_load_param): Incorporate into
9498         ipa_get_stmt_member_ptr_load_param, also pass back an offset.
9499         (ipa_note_param_call): Clear agg_contents.
9500         (ipa_analyze_indirect_call_uses): Also look for simple pointers loaded
9501         from aggregates.  In such cases, store offset of the called field.
9502         (ipa_analyze_node): Initialize new fields of param_analysis_info.
9503         (update_jump_functions_after_inlining): Handle aggregate contents.
9504         (ipa_find_agg_cst_for_param): New function.
9505         (try_make_edge_direct_simple_call): Handle called aggregate values.
9506         (update_indirect_edges_after_inlining): Make sure aggregate preserving
9507         jump functions comply with type compatibility requirements.
9508         (ipa_edge_duplication_hook): Copy also aggregate jump functions.
9509         (ipa_write_jump_function): Stream agg_preserved flags and aggregate
9510         jump functions.  Do not stream member pointer constant jump functions.
9511         (ipa_read_jump_function): Likewise.
9512         (ipa_write_indirect_edge_info): Stream new cgraph_indirect_call_info
9513         fields.
9514         (ipa_read_indirect_edge_info): Likewise.
9515
9516 2012-08-09  Oleg Endo  <olegendo@gcc.gnu.org>
9517
9518         PR target/39423
9519         * config/sh/predicates.md (mem_index_disp_operand): New predicate.
9520         * config/sh/sh.md (*movsi_index_disp): Rewrite insns to use the new
9521         mem_index_disp_operand predicate.
9522
9523 2012-08-09  Oleg Endo  <olegendo@gcc.gnu.org>
9524
9525         PR target/51244
9526         * config/sh/sh.md: Add negc extu sequence peephole.
9527         (movrt, movnegt, movrt_negc, nott): Use t_reg_operand predicate.
9528         (*movrt_negc): New insn.
9529         * config/sh/sync.md (atomic_test_and_set): Pass gen_t_reg_rtx to
9530         gen_movnegt.
9531         * config/sh/sh.c (expand_cbranchsi4, sh_emit_scc_to_t,
9532         sh_emit_compare_and_branch, sh_emit_compare_and_set): Use
9533         get_t_reg_rtx.
9534         (sh_expand_t_scc): Pass gen_t_reg_rtx to gen_movnegt.
9535
9536 2012-08-09  Oleg Endo  <olegendo@gcc.gnu.org>
9537
9538         PR target/50751
9539         * config/sh/sh.md (*extendqisi2_compact_reg, *extendhisi2_compact_reg):
9540         Use arith_reg_operand predicate instead of register_operand.
9541         * config/sh/predicates.md (movsrc_no_disp_mem_operand): Accept
9542         only mem, simplify.
9543
9544 2012-08-09  Uros Bizjak  <ubizjak@gmail.com>
9545
9546         * config/alpha/alpha.c (alpha_pad_noreturn): Rename to ...
9547         (alpha_pad_function_end): ... this.  Also insert NOP between
9548         sibling call and GP load.
9549         (alpha_reorg): Update call to alpha_pad_function_end.  Expand comment.
9550
9551 2012-08-09  Michael Zolotukhin  <michael.v.zolotukhin@intel.com>
9552
9553         * config/i386/adxintrin.h: Remove guarding __ADX__ check.
9554         * config/i386/x86intrin.h: Likewise.
9555         * config/i386/i386.c (ix86_init_mmx_sse_builtins): Remove
9556         OPTION_MASK_ISA_ADX from needed options for
9557         __builtin_ia32_addcarryx_u32 and __builtin_ia32_addcarryx_u64.
9558         (ix86_expand_builtin): Use add<mode>3_carry in expanding of
9559         IX86_BUILTIN_ADDCARRYX32 and IX86_BUILTIN_ADDCARRYX64.
9560
9561 2012-08-09  Andrey Belevantsev  <abel@ispras.ru>
9562
9563         PR rtl-optimization/53701
9564         * sel-sched.c (vinsn_vec_has_expr_p): Clarify function comment.
9565         Process not only expr's vinsns but all old vinsns from expr's
9566         history of changes.
9567         (update_and_record_unavailable_insns): Clarify comment.
9568
9569 2012-08-09  Bernd Schmidt  <bernds@codesourcery.com>
9570
9571         * reload.c (find_valid_class_1): New static function.
9572         (push_reload): Use it when reloading a SYMBOL_REG as the inner
9573         of a subreg.  Keep better track of needed classes for the
9574         secondary memory case.
9575         * config/i386/i386.h (LIMIT_RELOAD_CLASS): Limit INT_SSE_REGS to
9576         GENERAL_REGS.
9577         * reload1.c (replaced_subreg): New static function.
9578         (gen_reload): Use it when deciding whether to use secondary
9579         memory.
9580
9581 2012-08-09  Richard Guenther  <rguenther@suse.de>
9582
9583         * tree.h (SSA_VAR_P): Simplify.
9584         * tree-ssanames.c (make_ssa_name_fn): Strengthen assert.
9585         * fold-const.c (fold_comparison): Check for default def first
9586         before checking for PARM_DECL.
9587         * tree-complex.c (get_component_ssa_name): Likewise.
9588         * tree-inline.c (remap_ssa_name): Likewise.
9589         * tree-ssa-loop-ivopts.c (parm_decl_cost): Likewise.
9590         * tree-ssa-structalias.c (get_fi_for_callee): Likewise.
9591         (find_what_p_points_to): Likewise.
9592         * tree-ssa-operands.c (add_stmt_operand): Simplify.
9593
9594 2012-08-08  Joseph Myers  <joseph@codesourcery.com>
9595
9596         * simplify-rtx.c (simplify_binary_operation_1): Do not simplify
9597         IOR to a constant if one operand has side effects.
9598
9599 2012-08-08  Ulrich Weigand  <Ulrich.Weigand@de.ibm.com>
9600
9601         * builtins.c (expand_builtin_atomic_compare_exchange): Pass old
9602         value operand as MEM to expand_atomic_compare_and_swap.
9603
9604         * config/s390/s390.md ("atomic_compare_and_swap<mode>"): Accept
9605         nonimmediate_operand for old value; generate load and store if
9606         needed.
9607         * config/s390/s390.c (s390_expand_cs_hqi): Accept any operand
9608         as vtarget.
9609
9610 2012-08-08  Steven Bosscher  <steven@gcc.gnu.org>
9611
9612         PR middle-end/54146
9613         * gimpify.c (gimplify_body): Only verify_gimple_in_seq with
9614         checking enabled.
9615         * tree-ssa-loop-manip.c (add_exit_phis_var): Assert that var is
9616         a gimple_reg if checking is enabled.
9617         (find_uses_to_rename_stmt): Only look at non-virtual USE operands.
9618         * tree-into-ssa (compute_global_livein): Change the worklist
9619         type from an array to a VEC.
9620
9621 2012-08-08  Richard Guenther  <rguenther@suse.de>
9622
9623         * tree-ssa-operands.h (virtual_operand_p): Declare.
9624         * tree-ssa-operands.c (virtual_operand_p): New predicate.
9625         * gimple.c (is_gimple_reg): Use virtual_operand_p.
9626         * tree-into-ssa.c (prepare_block_for_update): Likewise.
9627         * tree-vect-loop-manip.c (adjust_debug_stmts): Likewise.
9628
9629 2012-08-08  Richard Guenther  <rguenther@suse.de>
9630
9631         * tree-call-cdce.c (check_pow): Simplify.
9632         (gen_conditions_for_pow_int_base): Likewise.
9633         * tree-ssa-dom.c (propagate_rhs_into_lhs): Do not handle
9634         virtual operands here.
9635         * tree-ssa-operands.c (get_name_decl): Remove unused function.
9636         * gimplify.c (gimple_regimplify_operands): Remove dead code.
9637         * tree-vrp.c (get_value_range): Move SSA_NAME_VAR access.
9638         * tree-parloops.c (create_phi_for_local_result): Use copy_ssa_name.
9639         * value-prof.c (gimple_ic): Use duplicate_ssa_name.
9640         (gimple_stringop_fixed_value): Likewise.
9641         * tree.c (needs_to_live_in_memory): Remove SSA name handling.
9642         * tree-stdarg.c (find_va_list_reference): Store SSA_NAME_VERSIONs
9643         in the bitmap alongside shifted DECL_UIDs.
9644         (va_list_counter_struct_op): Likewise.
9645         (va_list_ptr_read): Likewise.
9646         (va_list_ptr_write): Likewise.
9647         (check_va_list_escapes): Likewise.
9648         (check_all_va_list_escapes): Likewise.
9649         (execute_optimize_stdarg): Likewise.
9650         * tree-outof-ssa.c (insert_backedge_copies): Use copy_ssa_name.
9651
9652 2012-08-08  Richard Sandiford  <rdsandiford@googlemail.com>
9653             H.J. Lu  <hongjiu.lu@intel.com>
9654
9655         PR rtl-optimization/54157
9656         * combine.c (gen_lowpart_for_combine): Don't return identity
9657         for CONST or symbolic reference.
9658
9659 2012-08-08  Michael Zolotukhin  <michael.v.zolotukhin@intel.com>
9660
9661         * common/config/i386/i386-common.c (OPTION_MASK_ISA_ADX_SET): New.
9662         (OPTION_MASK_ISA_ADX_UNSET): Likewise.
9663         (ix86_handle_option): Handle madx option.
9664         * config.gcc (i[34567]86-*-*): Add adxintrin.h.
9665         (x86_64-*-*): Likewise.
9666         * config/i386/adxintrin.h: New header.
9667         * config/i386/driver-i386.c (host_detect_local_cpu): Detect ADCX/ADOX
9668         support.
9669         * config/i386/i386-builtin-types.def
9670         (UCHAR_FTYPE_UCHAR_UINT_UINT_PUNSIGNED): New function type.
9671         (UCHAR_FTYPE_UCHAR_ULONGLONG_ULONGLONG_PULONGLONG): Likewise.
9672         * config/i386/i386-c.c: Define __ADX__ if needed.
9673         * config/i386/i386.c (ix86_target_string): Define -madx option.
9674         (PTA_ADX): New.
9675         (ix86_option_override_internal): Handle new option.
9676         (ix86_valid_target_attribute_inner_p): Add OPT_madx.
9677         (ix86_builtins): Add IX86_BUILTIN_ADDCARRYX32,
9678         IX86_BUILTIN_ADDCARRYX64.
9679         (ix86_init_mmx_sse_builtins): Define corresponding built-ins.
9680         (ix86_expand_builtin): Handle these built-ins.
9681         (ix86_expand_args_builtin): Handle new function types.
9682         * config/i386/i386.h (TARGET_ADX): New.
9683         * config/i386/i386.md (adcx<mode>3): New define_insn.
9684         * config/i386/i386.opt (madx): New.
9685         * config/i386/x86intrin.h: Include adxintrin.h.
9686
9687 2012-08-08  Nick Clifton  <nickc@redhat.com>
9688
9689         * config/rl78/rl78.c: Include tree-pass.h.
9690
9691 2012-08-08  Steven Bosscher  <steven@gcc.gnu.org>
9692
9693         PR middle-end/54146
9694         * ira.c (init_live_subregs): Take live_subregs_used as a bitmap.
9695         (build_insn_chain): Make live_subregs_used a bitmap.
9696         Use SBITMAP_SIZE to ignore the paradoxical bytes of subregs.
9697         Use sbitmap_free to free the live_subreg sbitmaps.
9698
9699         PR middle-end/54146
9700         * ifcvt.c: Include pointer-set.h.
9701         (cond_move_process_if_block): Change type of then_regs and
9702         else_regs from alloca'd array to pointer_sets.
9703         (check_cond_move_block): Update for this change.
9704         (cond_move_convert_if_block): Likewise.
9705         * Makefile.in: Fix dependencies for ifcvt.o.
9706
9707 2012-08-07  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
9708
9709         * gimple-ssa-strength-reduction.c (struct incr_info_d): New struct.
9710         (incr_vec): New static var.
9711         (incr_vec_len): Likewise.
9712         (address_arithmetic_p): Likewise.
9713         (stmt_cost): Remove dead assignment.
9714         (dump_incr_vec): New function.
9715         (cand_abs_increment): Likewise.
9716         (lazy_create_slsr_reg): Likewise.
9717         (incr_vec_index): Likewise.
9718         (count_candidates): Likewise.
9719         (record_increment): Likewise.
9720         (record_increments): Likewise.
9721         (unreplaced_cand_in_tree): Likewise.
9722         (optimize_cands_for_speed_p): Likewise.
9723         (lowest_cost_path): Likewise.
9724         (total_savings): Likewise.
9725         (analyze_increments): Likewise.
9726         (ncd_for_two_cands): Likewise.
9727         (nearest_common_dominator_for_cands): Likewise.
9728         (profitable_increment_p): Likewise.
9729         (insert_initializers): Likewise.
9730         (introduce_cast_before_cand): Likewise.
9731         (replace_rhs_if_not_dup): Likewise.
9732         (replace_one_candidate): Likewise.
9733         (replace_profitable_candidates): Likewise.
9734         (analyze_candidates_and_replace): Handle candidates with SSA-name
9735         strides.
9736
9737 2012-08-07  Steven Bosscher  <steven@gcc.gnu.org>
9738
9739         * cfg.c (debug_bb): Do not set TDF_BLOCKS.
9740         * cfghooks.c (dump_bb): Honor ~TDF_BLOCKS.
9741         * pretty-print.c (pp_base_flush): Do not add a newline, and do not
9742         clear pp_needs_newline.
9743         * pretty-print.h (pp_newline_and_flush): New macro with the behavior
9744         of pp_base_flush before the above change.
9745         * langhooks.c (lhd_print_error_function): Use pp_newline_and_flush
9746         instead of pp_flush.
9747         * diagnostic.c (diagnostic_finish): Likewise.
9748         (diagnostic_report_diagnostic): Likewise.
9749         (verbatim): Likewise.
9750         (error_recursion): Likewise.
9751         * tree-pretty-print.c (print_generic_stmt): Likewise.
9752         (print_generic_stmt_indented): LIkewise.
9753         * gimple-pretty-print.c (print_gimple_stmt): Likewise.
9754         (print_gimple_seq): Likewise.
9755         (gimple_dump_bb_buff): Likewise.
9756
9757 2012-08-07  Uros Bizjak  <ubizjak@gmail.com>
9758
9759         PR debug/54177
9760         * var-tracking.c (var_lowpart): Exit early for matched modes.
9761
9762 2012-08-07  Richard Henderson  <rth@redhat.com>
9763
9764         * config/s390/s390.c (s390_emit_compare_and_swap): Update for
9765         atomic_compare_and_swapsi_internal name change.
9766         (s390_expand_insv): Try RISBG last, not requiring operands in
9767         registers but forcing them there.  Try a limited form of ICM.
9768         (s390_two_part_insv): New.
9769         (s390_expand_cs_hqi): Use it.  Update for atomic optabs.
9770         * config/s390/s390.md (UNSPEC_MOVA): New.
9771         (TDSI): Remove mode iterator.
9772         (DGPR, DINT, TDI): New mode iterators.
9773         (td): New mode attribute.
9774         (mem_signal_fence): New.
9775         (mem_thread_fence): Rename from memory_barrier; update for model arg.
9776         (mem_thread_fence_1): Rename from *memory_barrier.
9777         (atomic_load<DINT>, atomic_store<DINT>): New expanders.
9778         (atomic_loaddi_1, atomic_loadti_1): New.
9779         (atomic_storedi_1, atomic_storeti_1): New.
9780         (sync_compare_and_swap<TDSI>, sync_compare_and_swap<HQI>): Remove.
9781         (atomic_compare_and_swap<DGPR>, atomic_compare_and_swap<HQI>): New.
9782         (atomic_compare_and_swap<DGPR>_internal): New.
9783         (*sync_compare_and_swap<DW>, *sync_compare_and_swap<GPR>): Remove.
9784         (*atomic_compare_and_swap<TDI>_1): New.
9785         (*atomic_compare_and_swapdi_2, *atomic_compare_and_swapsi_3): New.
9786         (sync_<ATOMIC_Z196><GPR>, sync_old_<ATOMIC_Z196><GPR>): Remove.
9787         (atomic_fetch_<ATOMIC_Z196><GPR>): New.
9788         (atomic_fetch_<ATOMC_Z196><GPR>_iaf): New.
9789         (sync_<ATOMIC><HQI>, sync_old_<ATOMIC><HQI>): Remove.
9790         (sync_new_<ATOMIC><HQI>): Remove.
9791         (atomic_<ATOMIC><HQI>, atomic_fetch_<ATOMIC><HQI>): New.
9792         (atomic_<ATOMIC>_fetch<HQI>): New.
9793         (sync_lock_test_and_set<HQI>): Remove.
9794         (atomic_exchange<HQI>): New.
9795
9796 2012-08-07  Paul Brook  <paul@codesourcery.com>
9797             Sandra Loosemore  <sandra@codesourcery.com>
9798
9799         * except.c (switch_to_exception_section): Place tables for
9800         DECL_ONE_ONLY functions in comdat groups.
9801
9802 2012-08-07  Richard Guenther  <rguenther@suse.de>
9803
9804         * tree-flow.h (copy_ssa_name_fn): New function.
9805         (duplicate_ssa_name_fn): Likewise.
9806         * tree-flow-inline.h (copy_ssa_name): New function.
9807         (duplicate_ssa_name): Likewise.
9808         * tree-ssanames.c (copy_ssa_name_fn): New function.
9809         (duplicate_ssa_name): Rename to ...
9810         (duplicate_ssa_name_fn): ... this and adjust.
9811         * tree-tailcall.c (update_accumulator_with_ops): Use copy_ssa_name.
9812         * tree-vect-loop-manip.c (slpeel_update_phi_nodes_for_guard1):
9813         Likewise.
9814         (slpeel_update_phi_nodes_for_guard2): Likewise.
9815         (slpeel_tree_peel_loop_to_edge): Likewise.
9816         (vect_loop_versioning): Likewise.
9817         * tree-parloops.c (transform_to_exit_first_loop): Likewise.
9818         (create_parallel_loop): Likewise.
9819         * ipa-split.c (split_function): Likewise.
9820         * tree-vect-loop.c (vect_is_simple_reduction_1): Likewise.
9821         (vect_create_epilog_for_reduction): Likewise.
9822         * tree-vect-data-refs.c (bump_vector_ptr): Likewise.
9823         (vect_setup_realignment): Likewise.
9824         * tree-vect-stmts.c (vectorizable_load): Likewise.
9825         * tree-switch-conversion.c (build_one_array): Likewise.
9826         (gen_def_assigns): Likewise.
9827         * tree-cfg.c (gimple_make_forwarder_block): Likewise.
9828         * graphite-sese-to-poly.c (rewrite_close_phi_out_of_ssa): Call
9829         create_zero_dim_array with the SSA name.
9830         (rewrite_phi_out_of_ssa): Likewise.
9831         (rewrite_cross_bb_scalar_dependence): Likewise.  Use copy_ssa_name.
9832
9833 2012-08-07  Richard Guenther  <rguenther@suse.de>
9834
9835         * tree-dfa.c (set_ssa_default_def): Clear the SSA_NAME_DEFAULT_DEF
9836         bit of the old name when we clear the slot.
9837         * tree-ssa-live.c (remove_unused_locals): Release any default
9838         def associated with an unused var.
9839         * tree-ssa-copy.c (may_propagate_copy_into_asm): Always return true.
9840
9841 2012-08-07  Richard Guenther  <rguenther@suse.de>
9842
9843         * tree-into-ssa.c (rewrite_stmt): Remove clobbers for variables
9844         we rewrite into SSA form.
9845         (rewrite_enter_block): Adjust.
9846         * gimple-iterator.c (gsi_replace): Also allow replacement with
9847         a stmt without a lhs.
9848         * tree-ssa-live.c (remove_unused_locals): Remove code handling
9849         clobbers of SSA names.
9850         * tree-nested.c (convert_local_reference_stmt): Remove clobbers
9851         for variables we access through the local chain.
9852         * tree-cfg.c (verify_gimple_assign_single): Verify clobbers
9853         clobber full decls only.
9854
9855 2012-08-07  Richard Guenther  <rguenther@suse.de>
9856
9857         * gimple.h (gimple_phi_set_result): Adjust SSA_NAME_DEF_STMT.
9858         * tree-phinodes.c (make_phi_node): Allow a NULL var.
9859         * tree-into-ssa.c (insert_phi_nodes_for): Simplify.
9860         * tree-complex.c (update_phi_components): Likewise.
9861         * tree-ssa-loop-manip.c (create_iv): Likewise.
9862         (add_exit_phis_edge): Likewise.
9863         (split_loop_exit_edge): Likewise.
9864         (tree_transform_and_unroll_loop): Likewise.
9865         * value-prof.c (gimple_ic): Likewise.
9866         (gimple_stringop_fixed_value): Likewise.
9867         * tree-tailcall.c (tree_optimize_tail_calls_1): Likewise.
9868         * omp-low.c (expand_parallel_call): Likewise.
9869         (expand_omp_for_static_chunk): Likewise.
9870         (expand_omp_atomic_pipeline): Likewise.
9871         * tree-parloops.c (create_phi_for_local_result): Likewise.
9872         (transform_to_exit_first_loop): Likewise.
9873         * tree-vect-data-refs.c (vect_setup_realignment): Likewise.
9874         * graphite-scop-detection.c (canonicalize_loop_closed_ssa): Likewise.
9875         * tree-predcom.c (initialize_root_vars): Likewise.
9876         (initialize_root_vars_lm): Likewise.
9877         * sese.c (sese_add_exit_phis_edge): Likewise.
9878         * gimple-streamer-in.c (input_phi): Likewise.
9879         * tree-inline.c (copy_phis_for_bb): Likewise.
9880         * tree-ssa-phiprop.c (phiprop_insert_phi): Likewise.
9881         * tree-cfg.c (gimple_make_forwarder_block): Likewise.
9882         (gimple_duplicate_bb): Likewise.
9883
9884 2012-08-07  Nick Clifton  <nickc@redhat.com>
9885
9886         * config/mn10300/mn10300.c (mn10300_expand_prologue): Report
9887         stack usage if requested.
9888
9889 2012-08-06  Cary Coutant  <ccoutant@google.com>
9890
9891         * cgraphunit.c (assemble_thunk): Add source line info.
9892         * final.c (final): Check for non-null cfg pointer.
9893
9894 2012-08-06  Sandra Loosemore  <sandra@codesourcery.com>
9895             Maxim Kuvyrkov  <maxim@codesourcery.com>
9896             Julian Brown  <julian@codesourcery.com>
9897
9898         * config/mips/24k.md (r24k_unknown_store): Delete special handling
9899         for cprestore.
9900         (r24k_int_load, r24k_int_arith, r24k_int_mul3, r24k_int_mfhilo)
9901         (r24k_int_cop, r24k_int_multi)
9902         (r24kf2_1_fcvt_f2i, r24kf2_1_fxfer)
9903         (r24kf1_1_fcvt_f2i, r24kf1_1_fxfer): Use mips_store_data_bypass_p
9904         instead of store_data_bypass_p.
9905         * config/mips/74k.md (r74k_int_store): Delete special handling for
9906         cprestore.
9907         (r74k_int_load, r74k_int_logical, r74k_int_arith, r74k_int_cmove):
9908         Use mips_store_data_bypass_p instead of store_data_bypass_p.
9909
9910 2012-08-06  Marc Glisse  <marc.glisse@inria.fr>
9911
9912         PR tree-optimization/51938
9913         PR tree-optimization/52005
9914         * tree-ssa-ifcombine.c (ifcombine_ifandif): New parameters for
9915         inverted conditions.
9916         (ifcombine_iforif): Remove, merge code into ifcombine_ifandif.
9917         (tree_ssa_ifcombine_bb): Update calls to the above. Detect !a&&b
9918         and !a||b patterns.
9919
9920 2012-08-06  Olivier Hainque  <hainque@adacore.com>
9921
9922         * tree-emutls.c (new_emutls_decl): When a var_section is requested by
9923         the target, attach the new decl to that, not to the template section.
9924
9925 2012-08-06  Tom de Vries  <tom@codesourcery.com>
9926
9927         * tree-switch-conversion.c (emit_case_bit_tests): Generate MINUS_EXPR in
9928         unsigned type.
9929
9930 2012-08-05  Venkataramanan Kumar  <venkataramanan.kumar@amd.com>
9931
9932         * doc/invoke.texi: Document AMD btver2.
9933         * doc/extend.texi: Document AMD btver1 and btver2.
9934
9935 2012-08-04  Sandra Loosemore  <sandra@codesourcery.com>
9936             Richard Sandiford  <rdsandiford@googlemail.com>
9937
9938         * config/mips/mips.c (mips_option_override): Check -fpic
9939         for compatibility with -mabicalls and ABI.
9940
9941 2012-08-04  Catherine Moore  <clm@codesourcery.com>
9942             Sandra Loosemore  <sandra@codesourcery.com>
9943
9944         * config/mips/xlr.md (ir_xlr_alu_clz): New insn_reservation.
9945         (ir_xlr_alu): Remove clz.
9946         * config/mips/mips-cpus.def (xlr): Set PTF_AVOID_BRANCHLIKELY.
9947
9948 2012-08-04  Richard Earnshaw  <rearnsha@arm.com>
9949
9950         * arm.c (arm_gen_constant): Use SImode when preparing operands for
9951         gen_extzv_t2.
9952
9953 2012-08-04  Uros Bizjak  <ubizjak@gmail.com>
9954
9955         * config/i386/i386.h (QI_REGNO_P): New define.
9956         (ANY_QI_REGNO_P): Ditto.
9957         (GENERAL_REGNO_P): Use IN_RANGE macro.
9958         (QI_REG_P): Use QI_REGNO_P.
9959         (ANY_QI_REG_P): Use GENERAL_REGNO_P and QI_REGNO_P.
9960         (HARD_REGNO_CALLER_SAVE_MODE): Use QI_REGNO_P.
9961         * config/i386/i386.c (ix86_hard_regno_mode_ok): Ditto.
9962         (x86_extended_QIreg_mentioned_p): Ditto.  Also check if
9963         register is a general register.
9964
9965 2012-08-03  Uros Bizjak  <ubizjak@gmail.com>
9966
9967         * config/i386/sync.md (*atomic_fetch_add_cmp<mode>): Use
9968         incdec_operand predicate to return INC or DEC insn mnemonic.
9969         Add %K operand modifier.
9970         (atomic_add<mode>): Use incdec_operand predicate to
9971         return INC or DEC insn mnemonic.
9972         (atomic_dec<mode>): Ditto.
9973
9974 2012-08-03  Michael Matz  <matz@suse.de>
9975
9976         PR tree-optimization/54146
9977         * cfgexpand.c (add_scope_conflicts_1): Use bitmap_ior_into.
9978         (add_scope_conflicts): Iterate in RPO order.
9979         (add_stack_protection_conflicts): Iterate over the other triangle.
9980         (fini_vars_expansion): Clear stack_vars_sorted.
9981
9982 2012-08-03  Marc Glisse  <marc.glisse@inria.fr>
9983
9984         PR tree-optimization/30318
9985         * double-int.c (mul_double_wide_with_sign): New function.
9986         (mul_double_with_sign): Call the new function.
9987         * double-int.h (mul_double_wide_with_sign): Declare the new function.
9988         * tree-vrp.c (extract_range_from_binary_expr_1) [MULT_EXPR]:
9989         Handle integer types that wrap on overflow.
9990         (quad_int_cmp): New helper function.
9991         (quad_int_pair_sort): Likewise.
9992
9993 2012-08-03  Richard Guenther  <rguenther@suse.de>
9994
9995         * tree-vect-loop-manip.c (vect_can_advance_ivs_p): Query
9996         is_gimple_reg on the SSA name, not its variable.
9997         (vect_update_ivs_after_vectorizer): Likewise.
9998         * tree-ssa-copyrename.c (rename_ssa_copies): Likewise.
9999         * tree-if-conv.c (if_convertible_phi_p): Likewise.
10000         (predicate_scalar_phi): Likewise.
10001         * tree-vect-loop.c (vect_analyze_scalar_cycles_1): Likewise.
10002         (vect_analyze_scalar_cycles_1): Likewise.
10003         * tree-ssa-live.c (register_ssa_partition_check): Likewise.
10004         * tree-outof-ssa.c (eliminate_useless_phis): Likewise.
10005         * tree-ssa-reassoc.c (phi_rank): Likewise.
10006         * tree-parloops.c (separate_decls_in_region_name): Use
10007         replace_ssa_name_symbol.
10008         * tree-predcom.c (base_names_in_chain_on): Likewise.
10009         * matrix-reorg.c (update_type_size): Query the type of the SSA name,
10010         not its variable.
10011         * gimple-ssa-strength-reduction.c (create_mul_ssa_cand): Likewise.
10012         (create_mul_imm_cand): Likewise.
10013         (create_add_ssa_cand): Likewise.
10014         (create_add_imm_cand): Likewise.
10015         (slsr_process_add): Likewise.
10016         * tree-inline.c (remap_ssa_name): Do not set the type of the
10017         new SSA_NAME.
10018         * tree-ssa-structalias.c (get_constraint_for_ssa_var): Clarify assert.
10019         Check for default def first.
10020
10021 2012-08-04  Steven Bosscher  <steven@gcc.gnu.org>
10022
10023         * cfgrtl.c (print_rtl_with_bb): Do not print a newline between insns.
10024
10025         * sched-vis.c (print_pattern): Handle SEQUENCE also.
10026
10027 2012-08-02  Richard Henderson  <rth@redhat.com>
10028
10029         Revert:
10030         PR 34548
10031         * function.h (struct rtl_data): Add max_dynamic_stack_alignment.
10032         * cfgexpand.c (gimple_expand_cfg): Initialise it.
10033         * explow.c (allocate_dynamic_stack_space): Set it.  Simplify
10034         alignment requirements given the known alignment of dynamic_offset.
10035         * function.c (instantiate_virtual_regs): Align dtnamic_offset.
10036
10037 2012-08-02  Kenneth Zadeck <zadeck@naturalbridge.com>
10038
10039         * cfgexpand.c (expand_debug_locations):  Encapsulate test for
10040         CONST_DOUBLE in macro.
10041         * combine.c (try_combine, gen_lowpart_for_combine): Ditto.
10042         * cprop.c (implicit_set_cond_p): Ditto.
10043         * cselib.c (rtx_equal_for_cselib_1): Ditto.
10044         * expmed.c (expand_mult): Ditto.
10045         * expr.c (convert_modes): Ditto.
10046         * ira-costs.c (record_reg_classes): Ditto.
10047         * ira-lives.c (single_reg_class): Ditto.
10048         * optabs.c (expand_copysign_absneg, expand_copysign): Ditto.
10049         * print-rtl.c (print_rtx): Ditto.
10050         * recog.c (simplify_while_replacing, const_double_operand)
10051         (asm_operand_ok, constrain_operands): Ditto.
10052         * reg-stack.c (subst_stack_regs_pat): Ditto.
10053         * reload.c (find_reloads, find_equiv_reg): Ditto.
10054         * rtlanal.c (replace_rtx): Remove test.
10055         * rtlanal.c (constant_pool_constant_p, split_double): Encapsulate
10056         test for CONST_DOUBLE in macro.
10057         * simplify-rtx.c (mode_signbit_p, avoid_constant_pool_reference)
10058         (simplify_unary_operation_1, simplify_const_unary_operation)
10059         (simplify_binary_operation_1, simplify_const_binary_operation)
10060         (simplify_relational_operation_1)
10061         (simplify_const_relational_operations)
10062         (implify_subreg): Ditto.
10063         * varasm.c (output_constant_pool_2): Ditto.
10064         * rtl.h (CONST_DOUBLE_AS_INT_P, CONST_DOUBLE_AS_FLOAT_P): New macros.
10065         * rtl.def (CONST_DOUBLE):  Updated comments.
10066
10067 2012-08-02  Richard Sandiford  <rdsandiford@googlemail.com>
10068
10069         PR target/51931
10070         * config/mips/mips-protos.h (mips_strip_unspec_address): Declare.
10071         * config/mips/mips.c (mips_strip_unspec_address): Make extern.
10072         (mips16_rewrite_pool_constant): Make a copy of the pool constant
10073         before adding to a PC-relative table.
10074         (mips16_lay_out_constants): Add a SPLIT_P parameter.
10075         (mips16_load_branch_target, mips16_split_long_branches): New functions.
10076         (mips_reorg): Update call to mips16_lay_out_constants.
10077         Call mips16_split_long_branches.
10078         * config/mips/predicates.md (pc_or_label_operand): Delete.
10079         * config/mips/mips.md (length): Add a calculation for MIPS16 branches.
10080         Move the extended_mips16 handling further down.
10081         (*branch_equality<mode>_mips16): Replace use pc_or_label_operand
10082         with explicit label_ref and pc.  Follow the usual operand numbering.
10083         (*branch_equality<mode>_mips16_inverted): New pattern.
10084         (*jump_mips16): Add length attribute.
10085         (indirect_jump_and_restore_<mode>): New pattern.
10086         (consttable_int): Call mips_strip_unspec_address on the operand.
10087
10088 2012-08-02  Richard Sandiford  <rdsandiford@googlemail.com>
10089
10090         * recog.c (split_insn): Copy the original SET_SRC before using
10091         it as a note.
10092
10093 2012-08-02  Richard Sandiford  <rdsandiford@googlemail.com>
10094
10095         * reorg.c (dbr_schedule): Delete REG_BR_PRED loop.
10096
10097 2012-08-02  Marc Glisse  <marc.glisse@inria.fr>
10098
10099         PR tree-optimization/53805
10100         * fold-const.c (invert_tree_comparison): Invert ORDERED_EXPR and
10101         UNORDERED_EXPR even for trapping floating point.
10102
10103 2012-08-02  H.J. Lu  <hongjiu.lu@intel.com>
10104
10105         PR middle-end/53321
10106         PR middle-end/53865
10107         * ipa-inline-analysis.c (inline_free_summary): Return if
10108         inline_edge_summary_vec is NULL.
10109
10110         * ipa-split.c (execute_split_functions): Check if a function
10111         is inlinable only if inline_edge_summary_vec != NULL.
10112
10113         * ipa.c (symtab_remove_unreachable_nodes): Restore
10114         cgraph_propagate_frequency call when something was changed.
10115         (free_inline_summary): New function.
10116         (pass_ipa_free_inline_summary): New pass.
10117
10118         * passes.c (init_optimization_passes): Add
10119         pass_ipa_free_inline_summary before pass_ipa_tree_profile.
10120
10121         * timevar.def (TV_IPA_FREE_INLINE_SUMMARY): New.
10122
10123         * tree-pass.h (pass_ipa_free_inline_summary): New.
10124
10125 2012-08-02  Richard Earnshaw  <rearnsha@arm.com>
10126
10127         * arm.c (arm_gen_constant): Use UBFX for some AND operations when
10128         available.
10129
10130 2012-08-02  Richard Guenther  <rguenther@suse.de>
10131
10132         * tree-into-ssa.c (struct common_info_d): New struct.
10133         (struct var_info_d, struct ssa_name_info): Use it.
10134         (get_ssa_name_ann): Adjust.
10135         (get_phi_state, set_phi_state): Remove.
10136         (get_common_info): New function.
10137         (get_current_def, set_current_def): Adjust.
10138         (get_def_blocks_for): Take a common info as param.
10139         (set_def_block): Call get_common_info once.
10140         (set_livein_block): Likewise.
10141         (find_def_blocks_for): Adjust.
10142         (insert_phi_nodes): Likewise.
10143         (register_new_def): Call get_common_info once.
10144         (get_reaching_def): Likewise.
10145         (rewrite_debug_stmt_uses): Likewise.
10146         (rewrite_leave_block): Likewise.
10147         (dump_currdefs): Likewise.
10148         (debug_var_infos_r): Adjust.
10149         (register_new_update_single): Call get_common_info once.
10150         (maybe_replace_use_in_debug_stmt): Likewise.
10151         (rewrite_update_leave_block): Likewise.
10152         (mark_use_interesting): Adjust.
10153         (create_new_def_for): Likewise.
10154         (update_ssa): Likewise.
10155
10156 2012-08-02  Michael Matz  <matz@suse.de>
10157
10158         * tree-ssa-live.c (set_is_used): Return a bool.
10159         (mark_all_vars_used): Don't take data argument.
10160         (mark_all_vars_used_1): Adjust calls to above, merge handling
10161         of local and global vars.
10162         (remove_unused_scope_block_p): Don't take global_unused_vars,
10163         merge handling of local and global vars.
10164         (remove_unused_locals): Don't allocate/fill/pass global_unused_vars,
10165         use is_used_p for local and global vars.
10166
10167 2012-08-02  Richard Guenther  <rguenther@suse.de>
10168
10169         * tree-flow.h (make_rename_temp): Remove.
10170         * tree-dfa.c (make_rename_temp): Likewise.
10171         * cgraphunit.c (thunk_adjust, assemble_thunk): Use create_tmp_reg
10172         instead of make_rename_temp.
10173         * omp-low.c (expand_omp_for_generic, expand_omp_for_static_nochunk,
10174         expand_omp_atomic_pipeline): Likewise.
10175         * trans-mem.c (tm_log_emit_save_or_restores, build_tm_load,
10176         build_tm_store, expand_call_tm, expand_transaction,
10177         ipa_tm_insert_gettmclone_call): Likewise.
10178         * tree-complex.c (expand_complex_div_wide): Likewise.
10179         * tree-mudflap.c (mf_decl_cache_locals, mf_build_check_statement_for):
10180         Likewise.
10181         * tree-ssa-loop-im.c (execute_sm_if_changed_flag_set, execute_sm):
10182         Likewise.
10183         * tree-ssa-math-opts.c (insert_reciprocals): Likewise.
10184         * value-prof.c (gimple_divmod_fixed_value, gimple_mod_pow2,
10185         gimple_mod_subtract): Likewise.
10186
10187 2012-08-02  Richard Guenther  <rguenther@suse.de>
10188
10189         * tree-flow.h (set_default_def): Rename to ...
10190         (set_ssa_default_def): ... this.  Take a struct function argument.
10191         (gimple_default_def): Rename to ...
10192         (ssa_default_def): ... this.
10193         (get_or_create_ssa_default_def): New function.
10194         * tree-dfa.c: Likewise.
10195         (dump_variable): Adjust.
10196         * ipa-prop.c (ipa_analyze_params_uses): Adjust, properly check
10197         for used parameters.
10198         * ipa-split.c (consider_split): Adjust, avoid repeated default-def
10199         lookups.
10200         (split_function): Likewise.
10201         * lto-streamer-in.c (input_ssa_names): Adjust.
10202         * omp-low.c (expand_omp_taskreg): Likewise.
10203         * tree-cfg.c (replace_ssa_name): Adjust, no need to push/pop cfun.
10204         * tree-complex.c (init_parameter_lattice_values): Adjust.
10205         (get_component_ssa_name): Likewise.
10206         (update_parameter_components): Likewise.
10207         * tree-inline.c (remap_ssa_name): Likewise.
10208         (setup_one_parameter): Likewise.
10209         (initialize_inlined_parameters): Likewise.
10210         (declare_return_variable): Likewise.
10211         (expand_call_inline): Likewise.
10212         (tree_function_versioning): Likewise.
10213         * tree-into-ssa.c (get_default_def_for): Remove.
10214         (get_reaching_def): Use get_or_create_ssa_default_def instead.
10215         * tree-predcom.c (replace_ref_with): Adjust.
10216         * tree-sra.c (get_repl_default_def_ssa_name): Likewise.
10217         (is_unused_scalar_param): Likewise.
10218         (ptr_parm_has_direct_uses): Likewise.
10219         (sra_ipa_reset_debug_stmts): Likewise.
10220         * tree-ssa-coalesce.c (create_outofssa_var_map): Adjust.
10221         * tree-ssa-copyrename.c (copy_rename_partition_coalesce): Likewise.
10222         * tree-ssa-live.c (verify_live_on_entry): Likewise.
10223         * tree-ssa-math-opts.c (execute_cse_reciprocals): Likewise,
10224         avoid repeated default def lookups.
10225         * tree-ssa-sccvn.c (run_scc_vn): Likewise.
10226         * tree-tailcall.c (arg_needs_copy_p): Adjust.
10227         (tree_optimize_tail_calls_1): Likewise.
10228
10229 2012-08-02  Richard Guenther  <rguenther@suse.de>
10230
10231         PR tree-optimization/50672
10232         Revert
10233         2012-08-01  Richard Guenther  <rguenther@suse.de>
10234
10235         * tree-ssa-tail-merge.c (release_last_vdef): Remove.
10236         (replace_block_by): Adjust.
10237
10238 2012-08-02  Richard Guenther  <rguenther@suse.de>
10239
10240         * tree-dfa.c (referenced_var_lookup): Remove.
10241         (find_referenced_vars): Remove.
10242         (pass_referenced_vars): Likewise.
10243         (make_rename_temp): Do not add referenced vars.
10244         (dump_referenced_vars): Remove.
10245         (debug_referenced_vars): Likewise.
10246         (dump_dfa_stats): Do not dump referenced var stats.
10247         (find_vars_r): Remove.
10248         (find_referenced_vars_in): Likewise.
10249         (referenced_var_check_and_insert): Likewise.
10250         (add_referenced_var_1): Likewise.
10251         (remove_referenced_var): Likewise.
10252         * tree-flow.h (referenced_var_lookup): Likewise.
10253         (struct gimple_df): Remove referenced_vars member.
10254         (typedef referenced_var_iterator): Remove.
10255         (FOR_EACH_REFERENCED_VAR): Likewise.
10256         (num_referenced_vars): Likewise.
10257         (debug_referenced_vars, dump_referenced_vars): Likewise.
10258         (add_referenced_var_1, add_referenced_var): Likewise.
10259         (remove_referenced_var): Likewise.
10260         (find_referenced_vars_in): Likewise.
10261         * tree-flow-inline.h (gimple_referenced_vars): Remove.
10262         (first_referenced_var): Likewise.
10263         (end_referenced_vars_p): Likewise.
10264         (next_referenced_var): Likewise.
10265         * cfgexpand.c (update_alias_info_with_stack_vars): Remove assert.
10266         * gimple-pretty-print.c (pp_points_to_solution): Dump UIDs
10267         unconditionally.
10268         * tree-into-ssa.c (dump_decl_set): Likewise.
10269         (pass_build_ssa): Do not require PROP_referenced_vars.
10270         * tree-ssa.c (target_for_debug_bind): Virtual operands are
10271         not suitable, but all register type vars are.
10272         (init_tree_ssa): Do not allocate referenced vars.
10273         (delete_tree_ssa): Do not free referenced vars.
10274         * cgraphunit.c (init_lowered_empty_function): Do not set
10275         PROP_referenced_vars.
10276         (assemble_thunk): Do not add referenced vars.
10277         * gimple-fold.c (canonicalize_constructor_val): Likewise.
10278         (gimplify_and_update_call_from_tree): Likewise.
10279         * gimple-streamer-in.c (input_bb): Likewise.
10280         * passes.c (init_optimization_passes): Do not run
10281         pass_referenced_vars.
10282         (dump_properties): Do not dump PROP_referenced_vars.
10283         * tree-inline.c (remap_decl): Do not add referenced vars.
10284         (remap_gimple_op_r): Likewise.
10285         (copy_tree_body_r): Likewise.
10286         (copy_bb): Likewise.
10287         (setup_one_parameter): Likewise.
10288         (declare_return_variable): Likewise.
10289         (copy_decl_for_dup_finish): Likewise.
10290         (copy_arguments_for_versioning): Likewise.
10291         (tree_function_versioning): Likewise.
10292         * tree-pass.h (PROP_referenced_vars): Remove.
10293         (pass_referenced_vars): Likewise.
10294         * tree-profile.c (gimple_gen_edge_profiler): Do not add
10295         referenced vars.
10296         (gimple_gen_interval_profiler): Likewise.
10297         (gimple_gen_pow2_profiler): Likewise.
10298         (gimple_gen_one_value_profiler): Likewise.
10299         (gimple_gen_ic_profiler): Likewise.
10300         (gimple_gen_average_profiler): Likewise.
10301         (gimple_gen_ior_profiler): Likewise.
10302         * tree-ssa-live.c (remove_unused_locals): Do not touch referenced vars.
10303         * tree-cfg.c (replace_ssa_name): Do not add referenced vars.
10304         (move_stmt_op): Likewise.
10305         * tree-ssa-operands.c (create_vop_var): Likewise.
10306         * gimple-low.c (record_vars_into): Likewise.
10307         * gimplify.c (gimple_regimplify_operands): Likewise.
10308         (force_gimple_operand_1): Likewise.
10309         * omp-low.c (expand_omp_for_generic): Likewise.
10310         (expand_omp_for_static_chunk): Likewise.
10311         (expand_omp_atomic_pipeline): Likewise.
10312         * graphite-clast-to-gimple.c (graphite_create_new_loop): Likewise.
10313         (translate_clast_assignment): Likewise.
10314         * graphite-sese-to-poly.c (create_zero_dim_array): Likewise.
10315         (handle_scalar_deps_crossing_scop_limits): Likewise.
10316         * ipa-prop.c (ipa_modify_formal_parameters): Likewise.
10317         * ipa-split.c (split_function): Likewise.
10318         * matrix-reorg.c (transform_access_sites): Likewise.
10319         * trans-mem.c (tm_log_add): Likewise.
10320         (ipa_tm_insert_gettmclone_call): Likewise.
10321         * tree-complex.c (create_one_component_var): Likewise.
10322         * tree-if-conv.c (ifc_temp_var): Likewise.
10323         * tree-parloops.c (take_address_of): Likewise.
10324         (initialize_reductions): Likewise.
10325         (separate_decls_in_region_name): Likewise.
10326         (create_call_for_reduction_1): Likewise.
10327         (separate_decls_in_region): Likewise.
10328         * tree-predcom.c (predcom_tmp_var): Likewise.
10329         (reassociate_to_the_same_stmt): Likewise.
10330         * tree-sra.c (build_ref_for_offset): Likewise.
10331         (create_access_replacement): Likewise.
10332         (get_replaced_param_substitute): Likewise.
10333         (sra_ipa_reset_debug_stmts): Likewise.
10334         * tree-ssa-loop-im.c (rewrite_reciprocal): Likewise.
10335         (rewrite_bittest): Likewise.
10336         * tree-ssa-loop-ivopts.c (create_new_iv): Likewise.
10337         * tree-ssa-loop-manip.c (create_iv): Likewise.
10338         (tree_transform_and_unroll_loop): Likewise.
10339         * tree-ssa-math-opts.c (powi_as_mults): Likewise.
10340         (build_and_insert_call): Likewise.
10341         (gimple_expand_builtin_cabs): Likewise.
10342         (execute_optimize_bswap): Likewise.
10343         * tree-ssa-phiopt.c (conditional_replacement): Likewise.
10344         (abs_replacement): Likewise.
10345         (cond_store_replacement): Likewise.
10346         (cond_if_else_store_replacement_1): Likewise.
10347         * tree-ssa-phiprop.c (phiprop_insert_phi): Likewise.
10348         * tree-ssa-pre.c (get_representative_for): Likewise.
10349         (create_expression_by_pieces): Likewise.
10350         (insert_into_preds_of_block): Likewise.
10351         * tree-ssa-propagate.c (update_call_from_tree): Likewise.
10352         * tree-ssa-reassoc.c (undistribute_ops_list): Likewise.
10353         (eliminate_redundant_comparison): Likewise.
10354         (rewrite_expr_tree_parallel): Likewise.
10355         (get_reassoc_pow_ssa_name): Likewise.
10356         * tree-ssa-strlen.c (get_string_length): Likewise.
10357         * tree-switch-conversion.c (emit_case_bit_tests): Likewise.
10358         (build_arrays): Likewise.
10359         * tree-tailcall.c (adjust_return_value_with_ops): Likewise.
10360         (create_tailcall_accumulator): Likewise.
10361         * tree-vect-data-refs.c (vect_get_new_vect_var): Likewise.
10362         (vect_create_addr_base_for_vector_ref): Likewise.
10363         (vect_permute_store_chain): Likewise.
10364         (vect_permute_load_chain): Likewise.
10365         * tree-vect-generic.c (expand_vector_divmod): Likewise.
10366         * tree-vect-loop-manip.c (set_prologue_iterations): Likewise.
10367         (vect_build_loop_niters): Likewise.
10368         (vect_generate_tmps_on_preheader): Likewise.
10369         (vect_update_ivs_after_vectorizer): Likewise.
10370         (vect_gen_niters_for_prolog_loop): Likewise.
10371         (vect_do_peeling_for_alignment): Likewise.
10372         (vect_create_cond_for_align_checks): Likewise.
10373         * tree-vect-patterns.c (vect_recog_temp_ssa_var): Likewise.
10374         (vect_handle_widen_op_by_const): Likewise.
10375         (vect_operation_fits_smaller_type): Likewise.
10376         (vect_recog_over_widening_pattern): Likewise.
10377         * tree-vect-stmts.c (vect_init_vector): Likewise.
10378
10379 2012-08-01  Alexandre Oliva  <aoliva@redhat.com>
10380
10381         PR debug/52983
10382         * valtrack.c (dead_debug_insert_temp): Use cleanup_auto_inc_dec.
10383
10384 2012-08-01  Alexandre Oliva  <aoliva@redhat.com>
10385
10386         PR debug/52983
10387         * valtrack.c (cleanup_auto_inc_dec): Implement unconditionally,
10388         falling back to copy_rtx on non-autoinc machines.
10389         (propagate_for_debug_subst): Always use cleanup_auto_inc_dec.
10390
10391 2012-08-01  Alexandre Oliva  <aoliva@redhat.com>
10392
10393         PR debug/52983
10394         * valtrack.h, valtrack.c: New.
10395         * Makefile.in (VALTRACK_H): New.
10396         (OBJS): Add valtrack.o.
10397         (valtrack.o): New.
10398         (cselib.o, dce.o, df-problems.o, combine.o): Add VALTRACK_H.
10399         * combine.c: Include valtrack.h.
10400         (make_compound_operation): Publish.
10401         (cleanup_auto_inc_dec): Move to valtrack.c.
10402         (struct rtx_subst_pair, propagate_for_debug_subst): Likewise.
10403         (propagate_for_debug): Likewise.  Add this_basic_block parameter.
10404         Adjust all callers.
10405         * cselib.c: Include valtrack.h.
10406         * dce.c: Likewise.
10407         * df-problems.c: Likewise.
10408         (dead_debug_init, dead_debug_reset_uses): Move to valtrack.c.
10409         (dead_debug_finish, dead_debug_add): Likewise.
10410         (dead_debug_insert_temp): Likewise.
10411         * df.h (struct dead_debug_use): Move to valtrack.h.
10412         (struct dead_debug, enum debug_temp_where): Likewise.
10413         (dead_debug_init, dead_debug_reset_uses): Move to valtrack.h.
10414         (dead_debug_finish, dead_debug_add): Likewise.
10415         (dead_debug_insert_temp): Likewise.
10416         * rtl.h (make_compound_operation): Declare.
10417
10418 2012-08-01  Catherine Moore  <clm@codesourcery.com>
10419             Sandra Loosemore  <sandra@codesourcery.com>
10420
10421         * config/mips/mips-cpus.def (34kn): New.
10422         * config/mips/mips.h (MIPS_ARCH_FLOAT_SPEC): Add 34kn.
10423         (BASE_DRIVER_SELF_SPECS): Do not imply -mdsp for the 34kn.
10424         * config/mips/mips-tables.opt: Regenerate.
10425         * doc/invoke.texi (MIPS Options): Document -march=34kn.
10426
10427 2012-08-01  Richard Henderson  <rth@redhat.com>
10428
10429         * expmed.h (NUM_MODE_PARTIAL_INT): New.
10430         (NUM_MODE_VECTOR_INT, NUM_MODE_IP_INT, NUM_MODE_IPV_INT): New.
10431         (struct expmed_op_cheap): Size one array on NUM_MODE_IPV_INT.
10432         (struct expmed_op_costs): Likewise.
10433         (struct target_expmed): Size x_convert_cost on NUM_MODE_IP_INT.
10434         (expmed_mode_index): New.
10435         (expmed_op_cheap_ptr, expmed_op_cost_ptr): Use expmed_mode_index.
10436         (convert_cost_ptr): Likewise.
10437         * expmed.c (struct init_expmed_rtl): Rename convert to trunc.
10438         (init_expmed_one_conv): Split out from ...
10439         (init_expmed_one_mode): ... here.  Iterate conversions over
10440         partial integer modes too.
10441         (init_expmed): Iterate over partial integer modes too.
10442
10443 2012-08-01  Richard Henderson  <rth@redhat.com>
10444
10445         * config/m32c/m32c.c (TARGET_INIT_LIBFUNCS): Remove.
10446         (m32c_init_libfuncs): Remove.
10447         * config/m32c/cond.md (cstore<QHPSI>4_16): Rename from cstore<QHPSI>4.
10448         (cstore<QHPSI>4): New expander.
10449
10450 2012-08-01  Richard Guenther  <rguenther@suse.de>
10451
10452         * tree-flow-inline.h (referenced_var): Remove.
10453         * tree-ssa-coalesce.c (create_outofssa_var_map): Remove duplicate
10454         checking code.
10455         * tree-sra.c (candidates): New global hashtable.
10456         (candidate): New function.
10457         (sra_initialize): Initialize candidates.
10458         (sra_deinitialize): Free candidates.
10459         (disqualify_candidate): Remove candidate from candidates.
10460         (maybe_add_sra_candidate): New function.
10461         (find_var_candidates): Walk over all local decls and parameters,
10462         add candidates to candidates hashtable.
10463         (find_param_candidates): Add candidates to candidates hashtable.
10464         (analyze_all_variable_accesses): Use candidate instead of
10465         referenced_var.
10466
10467 2012-08-01  Tom de Vries  <tom@codesourcery.com>
10468
10469         * tree-vrp.c (find_case_label_ranges): New function.
10470         (vrp_visit_switch_stmt, simplify_switch_using_ranges): Use
10471         find_case_label_ranges instead of find_case_label_range.  Handle second
10472         range.
10473
10474 2012-08-01  Michael Matz  <matz@suse.de>
10475
10476         * tree-complex.c (init_parameter_lattice_values): Don't call var_ann.
10477         * tree-dfa.c (struct dfa_stats_d): Remove num_var_anns member.
10478         (dump_dfa_stats): Don't dump stats about var anns.
10479         (collect_dfa_stats): Don't collect them.
10480         (add_referenced_var_1): Don't set var annotation pointers.
10481         (remove_referenced_var): Ditto, and only remove it it's in the
10482         hash table.
10483
10484         * tree-flow-inline.h (var_ann): Remove.
10485         * tree-flow.h (struct var_ann_d, var_ann_t): Remove.
10486
10487         * tree-inline.c (remapped_type): Remove.
10488         (can_be_nonlocal): Most variable will be considered live here,
10489         return false earlier.
10490         (remap_decls): Don't call var_ann, all variables will be considered
10491         referenced here.
10492         (copy_debug_stmt): Ditto, and use is_global_var.
10493
10494         * tree-into-ssa.c (rewrite_debug_stmt_uses): Use get_current_def to
10495         determine if a variable was referred to, not var_ann.
10496         * tree-ssa-live.c (remove_unused_scope_block_p): Don't check var_ann.
10497         (remove_unused_locals): Ditto.
10498         * tree-ssa.c (delete_tree_ssa): Don't free/clear var ann pointers.
10499         * tree-tailcall.c (arg_needs_copy_p): Don't check var_ann.
10500         * tree.c (copy_node_stat): Don't clear var ann pointer.
10501         * tree.h (tree_result_decl, tree_parm_decl, tree_var_decl): Remove
10502         ann member.
10503         (DECL_VAR_ANN_PTR): Remove.
10504
10505 2012-08-01  Michael Matz  <matz@suse.de>
10506
10507         * tree-flow.h (struct var_ann_d): Rename used member.
10508         (set_is_used): Don't declare.
10509         * tree-flow-inline.h (clear_is_used): Remove.
10510         (set_is_used, is_used_p): Move to ...
10511         * tree-ssa-live.c (set_is_used, is_used_p): ... here, and use
10512         on the side bitmap.
10513         (usedvars): New bitmap.
10514         (dump_scope_block): Don't dump unusedness.
10515         (remove_unused_locals): Allocate and free usedvars.
10516         * tree-nrv.c (tree_nrv): Don't clear used flags here.
10517
10518 2012-08-01  Michael Matz  <matz@suse.de>
10519
10520         * tree-flow.h (struct var_ann_d): Remove base_var_processed and
10521         base_index members.
10522         * tree-ssa-live.h (struct _var_map): Remove basevars member.
10523         (VAR_ANN_BASE_INDEX): Remove.
10524         * tree-ssa-live.c (var_map_base_init): Use a hash table instead
10525         of var annotation to compress index space.  Don't deal with above
10526         removed members.
10527         (var_map_base_fini): Don't free basevars.
10528         (init_var_map): Don't clear basevars.
10529
10530 2012-08-01  Bill Schmidt  <wschmidt@linux.ibm.com>
10531
10532         * gimple-ssa-strength-reduction.c (struct slsr_cand_d): Change
10533         base_name to base_expr.
10534         (struct cand_chain_d): Likewise.
10535         (base_cand_hash): Likewise.
10536         (base_cand_eq): Likewise.
10537         (record_potential_basis): Likewise.
10538         (alloc_cand_and_find_basis): Likewise.
10539         (create_mul_ssa_cand): Likewise.
10540         (create_mul_imm_cand): Likewise.
10541         (create_add_ssa_cand): Likewise.
10542         (create_add_imm_cand): Likewise.
10543         (slsr_process_cast): Likewise.
10544         (slsr_process_copy): Likewise.
10545         (dump_candidate): Likewise.
10546         (base_cand_dump_callback): Likewise.
10547         (unconditional_cands_with_known_stride_p): Likewise.
10548         (cand_increment): Likewise.
10549
10550 2012-08-01  Bill Schmidt  <wschmidt@linux.ibm.com>
10551
10552         PR tree-optimization/46556
10553         * gimple-ssa-strength-reduction.c (enum cand_kind): Add CAND_REF.
10554         (base_cand_map): Change to hash table.
10555         (base_cand_hash): New function.
10556         (base_cand_free): Likewise.
10557         (base_cand_eq): Likewise.
10558         (lookup_cand): Change base_cand_map to hash table.
10559         (find_basis_for_candidate): Likewise.
10560         (base_cand_from_table): Exclude CAND_REF.
10561         (restructure_reference): New function.
10562         (slsr_process_ref): Likewise.
10563         (find_candidates_in_block): Call slsr_process_ref.
10564         (dump_candidate): Handle CAND_REF.
10565         (base_cand_dump_callback): New function.
10566         (dump_cand_chains): Change base_cand_map to hash table.
10567         (replace_ref): New function.
10568         (replace_refs): Likewise.
10569         (analyze_candidates_and_replace): Call replace_refs.
10570         (execute_strength_reduction): Change base_cand_map to hash table.
10571
10572 2012-08-01  Uros Bizjak  <ubizjak@gmail.com>
10573
10574         * config/i386/i386.c (ix86_address_subreg_operand): Reject
10575         stack pointer.
10576         (ix86_print_operand_address): Assert that parts.base and parts.index
10577         are non-NULL after call to simplify_subreg.
10578
10579 2012-08-01  Richard Guenther  <rguenther@suse.de>
10580
10581         * doc/tree-ssa.texi: Remove pieces mentioning mark_sym_for_renaming.
10582
10583 2012-08-01  Richard Guenther  <rguenther@suse.de>
10584
10585         * graphite-clast-to-gimple.c (translate_clast_user): Rename
10586         virtual operands.
10587         * sese.c (graphite_copy_stmts_from_block): Do not rename virtual
10588         operands here.
10589         * tree-call-cdce.c (tree_call_cdce): Use
10590         mark_virtual_operands_for_renaming.
10591         * tree-eh.c (sink_clobbers): Simplify.
10592         * tree-flow.h (mark_sym_for_renaming): Remove.
10593         (mark_virtual_operands_for_renaming): New function.
10594         * tree-if-conv.c (tree_if_conversion): Use
10595         mark_virtual_operands_for_renaming.
10596         * tree-inline.c (update_ssa_across_abnormal_edges): Likewise.
10597         * tree-into-ssa.c (mark_sym_for_renaming): Remove.
10598         (mark_virtual_operands_for_renaming): New function.
10599         * tree-loop-distribution.c (tree_loop_distribution): Use
10600         mark_virtual_operands_for_renaming.
10601         * tree-ssa-dce.c (mark_virtual_operand_for_renaming): Do not
10602         update stmts, use mark_virtual_operands_for_renaming.
10603         * tree-ssa-tail-merge.c (release_last_vdef): Remove.
10604         (replace_block_by): Adjust.
10605         (tail_merge_optimize): Use mark_virtual_operands_for_renaming.
10606         * tree-tailcall.c (tree_optimize_tail_calls_1): Use
10607         mark_virtual_operands_for_renaming.
10608         * tree-vect-slp.c (vect_slp_transform_bb): Likewise.
10609         * tree-vectorizer.c (vectorize_loops): Likewise.
10610
10611 2012-08-01  Richard Guenther  <rguenther@suse.de>
10612
10613         * tree-flow.h (struct gimple_df): Remove syms_to_rename member,
10614         add ssa_renaming_needed and rename_vops flags.
10615         (SYMS_TO_RENAME): Remove.
10616         (symbol_marked_for_renaming): Likewise.
10617         (mark_virtual_ops_for_renaming): Likewise.
10618         * tree-into-ssa.c (symbols_to_rename_set, symbols_to_rename):
10619         New globals.
10620         (mark_for_renaming, marked_for_renaming): New functions.
10621         (symbol_marked_for_renaming): Remove.
10622         (dump_currdefs): Adjust.
10623         (maybe_replace_use): Likewise.
10624         (maybe_replace_use_in_debug_stmt): Likewise.
10625         (maybe_register_def): Likewise.
10626         (rewrite_update_phi_arguments): Likewise.
10627         (rewrite_update_enter_block): Likewise.
10628         (fini_ssa_renamer): Clear update SSA status here ...
10629         (delete_update_ssa): ... not here.  Free rename set.
10630         (prepare_block_for_update): Compute which decls need renaming.
10631         (dump_update_ssa): Adjust.
10632         (mark_sym_for_renaming): Adjust update SSA status for virtuals.
10633         (need_ssa_update_p): Adjust.
10634         (insert_updated_phi_nodes_for): Likewise.
10635         (update_ssa): Likewise.
10636         * tree-ssa-operands.c (finalize_ssa_defs): Adjust update SSA status
10637         for virtual and real operands.
10638         (finalize_ssa_uses): Likewise.
10639         * tree-ssanames.c (init_ssanames): Adjust.
10640         * tree-ssa.c (maybe_rewrite_mem_ref_base, maybe_optimize_var,
10641         execute_update_addresses_taken): Add bitmap to keep track of which
10642         candidates are suitable for rewriting and later renaming by SSA update.
10643         * matrix-reorg.c (transform_access_sites): Do not rename all defs.
10644         * tree-dfa.c (make_rename_temp): Do not mark real operands for
10645         renaming.
10646         * cgraphunit.c (assemble_thunk): Likewise.
10647         * gimplify.c (gimple_regimplify_operands): Likewise.
10648         (force_gimple_operand_1): Likewise.
10649         * ipa-prop.c (ipa_modify_formal_parameters): Likewise.
10650         * tree-inline.c (declare_return_variable): Likewise.
10651         * tree-parloops.c (separate_decls_in_region_stmt): Do not call
10652         mark_virtual_ops_for_renaming.
10653         (create_stores_for_reduction): Likewise.
10654         (create_loads_and_stores_for_name): Likewise.
10655         * tree-predcom.c (mark_virtual_ops_for_renaming): Remove.
10656         (initialize_root_vars_lm): Do not call mark_virtual_ops_for_renaming.
10657         (execute_load_motion): Likewise.
10658         (remove_stmt): Likewise.
10659         (execute_pred_commoning_chain): Likewise.
10660         * tree-sra.c (create_access_replacement): Do not rename real operands.
10661         (get_unrenamed_access_replacement): Unify with ...
10662         (get_access_replacement): ... this.
10663         (get_repl_default_def_ssa_name): Adjust.
10664         * tree-ssa-loop-im.c (move_computations_stmt): Manually update
10665         virtual SSA form.
10666         (rewrite_mem_ref_loc): Do not call mark_virtual_ops_for_renaming.
10667         * tree-ssa-loop-prefetch.c (emit_mfence_after_loop): Likewise.
10668
10669 2012-07-31  DJ Delorie  <dj@redhat.com>
10670
10671         * config/s390/s390.c (s390_option_override): Disable DWARF 3/4
10672         extensions for TPF, unless specifically selected.
10673
10674 2012-08-01  Alan Modra  <amodra@gmail.com>
10675
10676         PR target/54131
10677         * config/rs6000/rs6000.c (mem_operand_gpr): Don't limit range
10678         of lo_sum offsets.  Comment.  Assert mode at least word size
10679         rather than bypassing powerpc64 word offset check.
10680
10681 2012-07-31  Bill Schmidt  <wschmidt@linux.ibm.com>
10682
10683         * config/rs6000/rs6000.c (rs6000_builtin_vectorization_cost): Revise
10684         costs for vec_perm and vec_promote_demote down to more natural values.
10685         (struct _rs6000_cost_data): New data structure.
10686         (rs6000_density_test): New function.
10687         (rs6000_init_cost): Change to use rs6000_cost_data.
10688         (rs6000_add_stmt_cost): Likewise.
10689         (rs6000_finish_cost): Perform density test when vectorizing a loop.
10690
10691 2012-07-31  Steven Bosscher  <steven@gcc.gnu.org>
10692
10693         * sched-vis.c (print_exp): Handle FMA explicitly.  Simplify handling
10694         of RTX_UNARY function-like operations.  Print unknown expression
10695         RTX classes as pseudo-functions.
10696         (print_pattern): Simplify return pattern printing.
10697         (dump_insn_slim): Print the value of notes as a pattern for proper
10698         printing of CFA notes.
10699
10700 2012-07-31  Dehao Chen  <dehao@google.com>
10701
10702         * predict.c (tree_estimate_probability_driver): Normalize the
10703         loop when initializing the loop optimizer.
10704
10705 2012-07-31  Richard Guenther  <rguenther@suse.de>
10706
10707         * tree-flow.h (struct var_ann_d): Remove need_phi_state
10708         and current_def members.
10709         * tree-into-ssa.c (struct def_blocks_d): Remove var member.
10710         (def_blocks): Remove.
10711         (struct var_info_d): New.
10712         (var_infos): New hashtable.
10713         (struct ssa_name_info): Add def_blocks member.
10714         (get_ssa_name_ann): Adjust.
10715         (get_var_info): New function.
10716         (get_phi_state, set_phi_state, get_current_def,
10717         set_current_def, get_def_blocks_for, find_def_blocks_for): Adjust.
10718         (insert_phi_nodes_compare_def_blocks): Rename to ...
10719         (insert_phi_nodes_compare_var_infos): ... this and adjust.
10720         (insert_phi_nodes): Adjust.
10721         (dump_tree_ssa, dump_tree_ssa_stats): Adjust.
10722         (def_blocks_hash, def_blocks_eq, def_blocks_free): Remove.
10723         (debug_def_blocks_r): Rename to ...
10724         (debug_var_infos_r): ... this and adjust.
10725         (var_info_hash): New function.
10726         (var_info_eq): Likewise.
10727         (rewrite_blocks): Adjust.
10728         (init_ssa_renamer): Likewise.
10729         (fini_ssa_renamer): Likewise.
10730         (delete_update_ssa): Likewise.
10731         (update_ssa): Likewise.
10732         * tree-ssanames.c (release_dead_ssa_names): Do not clear current defs.
10733
10734 2012-07-31  Bill Schmidt  <wschmidt@linux.ibm.com>
10735
10736         PR tree-optimization/53773
10737         * tree-vectorizer.h (struct _loop_vec_info): Add operands_swapped.
10738         (LOOP_VINFO_OPERANDS_SWAPPED): New macro.
10739         * tree-vect-loop.c (new_loop_vec_info): Initialize
10740         LOOP_VINFO_OPERANDS_SWAPPED field.
10741         (destroy_loop_vec_info): Restore canonical form.
10742         (vect_is_slp_reduction): Set LOOP_VINFO_OPERANDS_SWAPPED field.
10743         (vect_is_simple_reduction_1): Likewise.
10744
10745 2012-07-31  Steven Bosscher  <steven@gcc.gnu.org>
10746
10747         * sched-vis.c (dump_insn_slim): Print print_rtx_head at the
10748         start of each new line.
10749         * final.c (final_scan_insn): If the final dump is requested as
10750         slim RTL, dump slim RTL to the assembly file also.
10751
10752 2012-07-31  Andrey Belevantsev  <abel@ispras.ru>
10753
10754         PR target/53975
10755
10756         * sel-sched-ir.c (has_dependence_note_reg_use): Clarify comment.
10757
10758         Revert
10759         2011-08-04  Sergey Grechanik  <mouseentity@ispras.ru>
10760
10761         * sel-sched-ir.c (has_dependence_note_reg_use): Call ds_full_merge
10762         only if producer writes to the register given by regno.
10763
10764 2012-07-31  Nick Clifton  <nickc@redhat.com>
10765
10766         * config/stormy16/stormy16.c (xstormy16_expand_prologue): Add
10767         support for reporting stack usage.
10768
10769         * config/frv/frv.c (QUAD): Fix typo.
10770         (frv_expand_prologue): Report stack usage.
10771
10772 2012-07-31  Steven Bosscher  <steven@gcc.gnu.org>
10773
10774         PR pch/53880
10775         * gengtype.c (struct walk_type_data): Add have_this_obj field.
10776         (walk_type): For functions that take a this_obj argument and
10777         that process fields with a GTY((length)) argument, write the
10778         test that write_types_local_process_field will write also at the
10779         head of the loop, effectively unswitching the loop.
10780         (write_func_for_structure, write_local_func_for_structure): Clear
10781         have_this_obj before calling walk_type.
10782         (write_local_func_for_structure): Set have_this_obj before walk_type.
10783         (write_array): Set have_this_obj for output of local pointer walking
10784         functions but not for marker functions.
10785         (write_types_local_process_field): Assert have_this_obj is set.
10786
10787         * rtl.h (simplify_using_condition): Adjust prototype using bitmap
10788         from coretypes.h.
10789
10790 2012-07-30  Nathan Froyd  <froydnj@gcc.gnu.org>
10791
10792
10793         * defaults.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete.
10794         * targhooks.c (default_mode_dependent_address_p): Delete code
10795         for GO_IF_MODE_DEPENDENT_ADDRESS.
10796         * system.h (GO_IF_MODE_DEPENDENT_ADDRESS): Poison.
10797         * doc/tm.texi.in (GO_IF_MODE_DEPENDENT_ADDRESS): Delete documention.
10798         * doc/tm.texi: Regenerate.
10799         * config/alpha.h (GO_IF_MODE_DEPENDENT_ADDRESS): Move code to...
10800         * config/alpha.c (alpha_mode_dependent_address_p): ...here.  New
10801         function.
10802         (TARGET_MODE_DEPENDENT_ADDRESS_P): Define.
10803         * config/cr16/cr16.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete.
10804         * config/mep/mep.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete.
10805         * config/vax/vax-protos.h (vax_mode_dependent_address_p): Delete.
10806         * config/vax/vax.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete.
10807         * config/vax/vax.c (vax_mode_dependent_address_p): Make static.
10808         Take a const_rtx.
10809         (TARGET_MODE_DEPENDENT_ADDRESS_P): Define.
10810
10811 2012-07-30  Nathan Froyd  <froydnj@gcc.gnu.org>
10812
10813         * expmed.h (NUM_MODE_VECTOR_INT): Define.
10814         (struct expmed_op_cheap, struct expmed_op_costs): New structures.
10815         (struct target_expmed): Convert x_mul_highpart_cost and
10816         x_mul_widen_cost fields to be indexed by integer modes.
10817         Convert x_sdiv_pow2_cheap and x_smod_pow2_cheap fields to be
10818         of type struct expmed_op_cheap.  Convert other cost fields to be
10819         of type struct_expmed_op_costs.
10820         (mul_widen_cost_ptr, mul_highpart_cost_ptr): Adjust for new
10821         indexing of respective fields.
10822         (expmed_op_cheap_ptr): New function.
10823         (sdiv_pow2_cheap_ptr, smod_pow2_cheap_ptr): Call it.
10824         (expmed_op_cost_ptr): New function.
10825         (add_cost_ptr, neg_cost_ptr, shift_cost_ptr, shiftadd_cost_ptr,
10826         shiftsub0_cost_ptr, shiftsub1_cost_ptr, mul_cost_ptr,
10827         sdiv_cost_ptr, udiv_cost_ptr): Call it.
10828
10829 2012-07-30  Sandra Loosemore  <sandra@codesourcery.com>
10830             Julian Brown  <julian@codesourcery.com>
10831
10832         * doc/invoke.texi (MIPS Options): Document -mno-float.
10833         * config/mips/mips.h (MIPS_ARCH_FLOAT_SPEC): Make it know
10834         about -mno-float.
10835
10836 2012-07-30  Joseph Myers  <joseph@codesourcery.com>
10837
10838         * doc/sourcebuild.texi (Subdirectories): Document common subdirectory.
10839
10840 2012-07-30  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
10841
10842         PR middle-end/53823
10843         * expmed.c (expand_mult): Skip synth_mult for constant double op1 except
10844         for special cases.  Don't initialize coeff and is_neg.
10845
10846 2012-07-30  Ulrich Weigand  <ulrich.weigand@linaro.org>
10847             Richard Earnshaw  <rearnsha@arm.com>
10848
10849         * target.def (vector_alignment): New target hook.
10850         * doc/tm.texi.in (TARGET_VECTOR_ALIGNMENT): Document new hook.
10851         * doc/tm.texi: Regenerate.
10852         * targhooks.c (default_vector_alignment): New function.
10853         * targhooks.h (default_vector_alignment): Add prototype.
10854         * stor-layout.c (layout_type): Use targetm.vector_alignment.
10855         * config/arm/arm.c (arm_vector_alignment): New function.
10856         (TARGET_VECTOR_ALIGNMENT): Define.
10857
10858         * tree-vect-data-refs.c (vect_update_misalignment_for_peel): Use
10859         vector type alignment instead of size.
10860         * tree-vect-loop-manip.c (vect_do_peeling_for_loop_bound): Use
10861         element type size directly instead of computing it from alignment.
10862         Fix variable naming and comment.
10863
10864 2012-07-30  Kirill Yukhin  <kirill.yukhin@intel.com>
10865             Michael Zolotukhin  <michael.v.zolotukhin@intel.com>
10866
10867         * common/config/i386/i386-common.c (OPTION_MASK_ISA_RDSEED_SET): New.
10868         (OPTION_MASK_ISA_RDSEED_UNSET): Likewise.
10869         (ix86_handle_option): Handle mrdseed option.
10870         * config.gcc (i[34567]86-*-*): Add rdseedintrin.h.
10871         (x86_64-*-*): Likewise.
10872         * config/i386/prfchwintrin.h: New header.
10873         * config/i386/cpuid.h (bit_RDSEED): New.
10874         * config/i386/driver-i386.c (host_detect_local_cpu): Detect
10875         RDSEED support.
10876         * config/i386/i386-c.c: Define __RDSEED__ if needed.
10877         * config/i386/i386.c (ix86_target_string): Define -mrdseed option.
10878         (PTA_RDSEED): New.
10879         (ix86_option_override_internal): Handle new option.
10880         (ix86_valid_target_attribute_inner_p): Add OPT_mrdseed.
10881         (ix86_builtins): Add enum entries for RDSEED* builtins.
10882         (ix86_init_mmx_sse_builtins): Define new builtins.
10883         (ix86_expand_builtin): Expand RDSEED* builtins.
10884         * config/i386/i386.h (TARGET_RDSEED): New.
10885         * config/i386/i386.md (rdseed<mode>_1): New.
10886         * config/i386/i386.opt (mrdseed): New.
10887         * config/i386/x86intrin.h: Include rdseedintrin.h.
10888
10889 2012-07-30  Richard Guenther  <rguenther@suse.de>
10890
10891         * tree-into-ssa.c (mark_def_sites): Also process virtual operands.
10892         (rewrite_stmt): Likewise.
10893         (rewrite_enter_block): Likewise.
10894         (pass_build_ssa): Do not update virtual SSA form during TODO.
10895         (mark_symbol_for_renaming): Do nothing if we are not in SSA form.
10896         * lto-streamer-in.c (lto_read_body): Set in_ssa_p earlier.
10897
10898 2012-07-30  Oleg Endo  <olegendo@gcc.gnu.org>
10899
10900         PR target/39423
10901         * config/gcc/sh/sh.md (*movsi_index_disp, *movhi_index_disp): New
10902         insns.
10903
10904 2012-07-30  Oleg Endo  <olegendo@gcc.gnu.org>
10905
10906         PR target/51244
10907         * config/sh/sh.md (mov_neg_si_t): Move to Scc instructions section.
10908         Use t_reg_operand predicate.  Add split for negated case.
10909         (ashrsi2_31): Pass get_t_reg_rtx to gen_mov_neg_si_t.
10910         * config/sh/sh.c (expand_ashiftrt): Likewise.
10911
10912 2012-07-30  Oleg Endo  <olegendo@gcc.gnu.org>
10913
10914         PR target/54089
10915         * config/sh/sh.md (ashlsi3_d): Invoke gen_shifty_op directly instead
10916         of trying to emit ashlsi3_n.
10917
10918 2012-07-30  Laurynas Biveinis  <laurynas.biveinis@gmail.com>
10919             Steven Bosscher  <steven@gcc.gnu.org>
10920
10921         * gengtype.c (adjust_field_type): Diagnose duplicate "length"
10922         option applications and option being applied to arrays of atomic types.
10923         (walk_type): Allow "atomic" option on strings too.
10924         * dwarf2out.h (struct dw_vec_struct): Use the "atomic" GTY option
10925         for the array field.
10926         * vec.h: Describe the atomic object "A" type of the macros in
10927         the header comment.
10928         (VEC_T_GTY_ATOMIC, DEF_VEC_A, DEF_VEC_ALLOC_A): Define.
10929         * emit-rtl.c (locations_locators_vals): use the atomic object vector.
10930         * doc/gty.texi: Clarify that GTY option "length" is only for
10931         arrays of non-atomic objects.  Fix typo in the description of the
10932         "atomic" option.
10933
10934 2012-07-27  Uros Bizjak  <ubizjak@gmail.com>
10935
10936         * config/i386/i386.c (ix86_avoid_lea_for_addr): Handle
10937         zero-extended addresses.  Return false if the address has less
10938         than two components.
10939         (ix86_split_lea_for_addr): Unconditionally convert target and
10940         all address operands to requested mode.
10941         * config/i386/i386.md (*lea<mode>): Recover operands from curr_insn.
10942         Pass SImode to ix86_split_lea_for_addr when splitting zero-extended
10943         address.
10944         (zero-extended add splitter): New splitter to conditionally split
10945         non-destructive adds.
10946         (*zero_extendsidi2_rex64): Conditionally emit leal instead of movl.
10947
10948 2012-07-28  Alan Modra  <amodra@gmail.com>
10949
10950         PR target/54093
10951         * config/rs6000/rs6000.c (rs6000_secondary_reload): Limit 32-bit
10952         multi-gpr reload to cases where predicate passes.  Do the same for
10953         64-bit multi-gpr reload.
10954
10955 2012-07-27  Nathan Froyd  <froydnj@gcc.gnu.org>
10956
10957         * expmed.h (alg_hash, alg_hash_used_p, sdiv_pow2_cheap,
10958         smod_pow2_cheap, zero_cost, add_cost, neg_cost, shift_cost)
10959         shiftadd_cost, shiftsub0_cost, shiftsub1_cost, mul_cost,
10960         sdiv_cost, udiv_cost, mul_widen_cost, mul_highpart_cost): Delete
10961         macro definitions and re-purpose as inline functions.
10962         (alg_hash_entry_ptr, set_alg_hash_used_p, sdiv_pow2_cheap_ptr,
10963         set_sdiv_pow2_cheap, smod_pow2_cheap_ptr, set_smod_pow2_cheap,
10964         zero_cost_ptr, set_zero_cost, add_cost_ptr, set_add_cost,
10965         neg_cost_ptr, set_neg_cost, shift_cost_ptr, set_shift_cost,
10966         shiftadd_cost_ptr, set_shiftadd_cost, shiftsub0_cost_ptr,
10967         set_shiftsub0_cost, shiftsub1_cost_ptr, set_shiftsub1_cost,
10968         mul_cost_ptr, set_mul_cost, sdiv_cost_ptr, set_sdiv_cost,
10969         udiv_cost_ptr, set_udiv_cost, mul_widen_cost_ptr,
10970         set_mul_widen_cost, mul_highpart_cost_ptr, set_mul_highpart_cost):
10971         New functions.
10972         (convert_cost_ptr): New function, split out from...
10973         (set_convert_cost, convert_cost): ...here.
10974         * expmed.c, tree-ssa-loop-ivopts.c: Update for new functions.
10975         * gimple-ssa-strength-reduction.c: Likewise.
10976
10977 2012-07-20  Ryan Mansfield  <rmansfield@qnx.com>
10978
10979         * gcc.c (main): Move GCC_DRIVER_HOST_INITIALIZATION after
10980         diagnostic_initialize.
10981
10982 2012-07-27  Oleg Endo  <olegendo@gcc.gnu.org>
10983
10984         PR target/54089
10985         * config/sh/sh.c (shiftcosts): Remove case where first operand
10986         is a const_int.  Move COSTS_N_INSNS usage into caller ...
10987         (sh_rtx_costs) ... here.  Return false when shiftcosts cannot be
10988         calculated instead of MAX_COST.
10989
10990 2012-07-27  Richard Guenther  <rguenther@suse.de>
10991
10992         * tree-cfg.c (gimple_can_merge_blocks_p): Do more fine-grained
10993         check whether SSA form is not up-to-date.
10994         * tree-flow.h (name_mappings_registered_p): Remove.
10995         * tree-into-ssa.c (struct repl_map_d): Remove.
10996         (repl_tbl): Likewise.
10997         (struct ssa_name_info): Add repl_set member.
10998         (update_ssa_obstack): New static global.
10999         (get_ssa_name_ann): Initialize repl_set.
11000         (clear_ssa_name_info): Assert age did not wrap.
11001         (repl_map_hash, repl_map_eq, repl_map_free): Remove.
11002         (names_replaced_by): Adjust.
11003         (add_to_repl_tbl): Likewise.
11004         (dump_tree_ssa_stats): Likewise.
11005         (init_update_ssa): Initialize update_ssa_obstack.
11006         (delete_update_ssa): Free update_ssa_obstack.
11007         (name_mappings_registered_p): Remove.
11008         (update_ssa): Adjust.
11009
11010 2012-07-27  Segher Boessenkool  <segher@kernel.crashing.org>
11011
11012         * config/rs6000/constraints.md: Delete "q" constraint.
11013         * config/rs6000/dfp.md (movsd_hardfloat, movsd_softfloat):
11014         Delete the "q" alternative.
11015         * config/rs6000/predicates.md (gpc_reg_operand): Adjust.
11016         * config/rs6000/rs6000.c (rs6000_debug_reg_global)
11017         (rs6000_init_hard_regno_mode_ok, rs6000_dbx_register_number):
11018         adjust to MQ_REGNO removal.
11019         * config/rs6000/rs6000.h (FIRST_PSEUDO_REGISTER): Adjust
11020         comment.
11021         (REG_ALLOC_ORDER): Adjust comment.  Remove MQ from alloc order.
11022         (enum reg_class): Adjust comment.  Delete MQ_REGS.
11023         (REG_CLASS_CONTENTS): Adjust.
11024         (REGISTER_NAMES, ADDITIONAL_REGISTER_NAMES): Adjust comment.
11025         * config/rs6000/rs6000.md: Delete MQ_REGNO.
11026         (movsi_internal1, movsi_internal1_single, movhi_internal,
11027         movqi_internal, movcc_internal1, movsf_hardfloat,
11028         movsf_softfloat): Delete the "q" alternative.
11029         (ctr<mode>_internal1, ctr<mode>_internal2, ctr<mode>_internal5,
11030         ctr<mode>_internal6): Delete "q" constraint.
11031
11032 2012-07-27  Richard Guenther  <rguenther@suse.de>
11033
11034         * tree-into-ssa.c (def_blocks_p): New typedef.
11035         (insert_phi_nodes_compare_def_blocks): New function.
11036         (insert_phi_nodes): Do not walk over referenced vars, instead
11037         walk over recorded def_blocks, record relevant ones and sort
11038         them to avoid repeated hashtable lookups.
11039
11040 2012-07-27  Richard Guenther  <rguenther@suse.de>
11041
11042         * doc/invoke.texi (min-virtual-mappings, virtual-mappings-ratio):
11043         Remove param documentation.
11044         * params.def (PARAM_MIN_VIRTUAL_MAPPINGS,
11045         PARAM_VIRTUAL_MAPPINGS_TO_SYMS_RATIO): Remove.
11046         * tree-flow.h (mark_set_for_renaming): Remove.
11047         * tree-into-ssa.c (struct update_ssa_stats_d): Remove.
11048         (add_new_name_mapping): Remove bookkeeping code.
11049         (dump_update_ssa): Remove stats dumping code.
11050         (init_update_ssa): Remove stats allocation code.
11051         (delete_update_ssa): Remove stats freeing code.
11052         (mark_set_for_renaming): Remove.
11053         (switch_virtuals_to_full_rewrite_p): Likewise.
11054         (switch_virtuals_to_full_rewrite): Likewise.
11055         (update_ssa): Do not call switch_virtuals_to_full_rewrite.
11056
11057 2012-07-27  Marek Polacek  <polacek@redhat.com>
11058
11059         * cgraphunit.c: Rename varpool_finalize_variable to
11060         varpool_finalize_decl in a comment.
11061
11062 2012-07-27  Segher Boessenkool  <segher@kernel.crashing.org>
11063
11064         * common/config/rs6000/rs6000-common.c (rs6000_handle_option):
11065         Delete code for -mno-power, -mpower, and -mpower2.
11066         * config/rs6000/aix43.h (NON_POWERPC_MASKS): Delete.
11067         (SUBTARGET_OVERRIDE_OPTIONS): Delete check for POWER together
11068         with -maix64.
11069         (ASM_CPU_SPEC): Delete support for POWER and POWER2.
11070         * config/rs6000/aix51.h (NON_POWERPC_MASKS): Delete.
11071         (SUBTARGET_OVERRIDE_OPTIONS): Delete check for POWER together
11072         with -maix64.
11073         (ASM_CPU_SPEC): Delete support for POWER and POWER2.
11074         * config/rs6000/aix52.h (NON_POWERPC_MASKS): Delete.
11075         (SUBTARGET_OVERRIDE_OPTIONS): Delete check for POWER together
11076         with -maix64.
11077         (TARGET_POWER): Delete.
11078         * config/rs6000/aix53.h (NON_POWERPC_MASKS): Delete.
11079         (SUBTARGET_OVERRIDE_OPTIONS): Delete check for POWER together
11080         with -maix64.
11081         (TARGET_POWER): Delete.
11082         * config/rs6000/aix61.h (NON_POWERPC_MASKS): Delete.
11083         (SUBTARGET_OVERRIDE_OPTIONS): Delete check for POWER together
11084         with -maix64.
11085         (TARGET_POWER): Delete.
11086         * config/rs6000/darwin.h (TARGET_POWER): Delete.
11087         * config/rs6000/driver-rs6000.c (struct asm_names): Delete
11088         support for -mpower, -mpower2, and -mno-power.
11089         * config/rs6000/rs6000-c.c (rs6000_target_modify_macros):
11090         Likewise.
11091         (rs6000_cpu_cpp_builtins): Likewise.
11092         * config/rs6000/rs6000-cpus.def: Likewise.
11093         * config/rs6000/rs6000-tables.opt: Regenerate.
11094         * config/rs6000/rs6000.c (POWER_MASKS): Delete.
11095         (rs6000_option_override_internal): Adjust.
11096         (rs6000_conditional_register_usage): Adjust.
11097         (rs6000_emit_move): Adjust.
11098         (rs6000_common_init_builtins): Adjust.
11099         (rs6000_init_libfuncs): Adjust.
11100         (rs6000_output_function_prologue): Adjust.
11101         (rs6000_adjust_cost): Adjust.
11102         (struct rs6000_opt_masks): Delete MASK_POWER and MASK_POWER2.
11103         * config/rs6000/rs6000.h (ASM_CPU_SPEC): Delete support for
11104         POWER and POWER2.
11105         (TARGET_DEFAULT): Adjust.
11106         (PROCESSOR_POWER): Delete.
11107         (SHIFT_COUNT_TRUNCATED): Adjust.
11108         * config/rs6000/rs6000.md (extendqisi2): Delete POWER support.
11109         (extendqisi2_power): Delete.
11110         (extendqisi2_no_power): Adjust.
11111         (extendqihi2, extendqihi2_power, extendqihi2_no_power):
11112         Likewise.
11113         (sminsi3, smaxsi3, uminsi3, umaxsi3): Adjust.
11114         (anonymous doz insn patterns): Delete.
11115         (abssi2): Adjust.
11116         (abssi2_power): Delete.
11117         (abssi2_nopower): Adjust.
11118         (nabs_power, nabs_nopower): Likewise.
11119         (mulsi3, mulsi3_mq, mulsi3_no_mq, mulsi3_mq_internal1):
11120         Likewise.  Delete anonymous post-reload splitter.
11121         (mulsi3_no_mq_internal1): rename to...
11122         (mulsi3_internal1): New define_insn.
11123         (mulsi3_mq_internal2, mulsi3_no_mq_internal2, mulsi3_internal2):
11124         Likewise.
11125         (divmodsi4, divmodsi4_internal, udiv<mode>3, udivsi3_mq,
11126         udivsi3_no_mq, udivsi3, div<mode>3, divsi3_mq, div<mode>3_no_mq,
11127         udivmodsi4_normal, udivmodsi4_tests, udivmodsi4): Likewise.
11128         (mulh_call, mull_call, divss_call, divus_call, quoss_call,
11129         quous_call): Likewise.
11130         (maskir_internal1, maskir_internal2, maskir_internal3,
11131         maskir_internal4, maskir_internal5, maskir_internal6,
11132         maskir_internal7, maskir_internal8): Delete.
11133         (ashlsi3, ashlsi3_power, ashlsi3_no_power): Adjust.
11134         (anonymous sl insn patterns): Delete.
11135         (lshrsi3, lshrsi3_power, lshrsi3_no_power): Adjust.
11136         (lshrsi3_64): Adjust.
11137         (anonymous sr insn patterns): Delete.
11138         (anonymous rrib insn patterns): Delete.
11139         (ashrsi3, ashrsi3_power, ashrsi3_no_power): Adjust.
11140         (anonymous sra insn patterns): Delete.
11141         (sqrtsf2, sqrtdf2, sqrtdf2_fpr): Adjust.
11142         (fix_trunc<mode>si2, fix_trunc<mode>si2_internal,
11143         fctiwz_<mode>): Adjust.
11144         (mulsidi3, mulsidi3_mq, mulsidi3_no_mq, umulsidi3, umulsidi3_mq,
11145         umulsidi3_no_mq, smulsi3_highpart, smulsi3_highpart_mq,
11146         smulsi3_highpart_no_mq, umulsi3_highpart, umulsi3_highpart_mq,
11147         umulsi3_highpart_no_mq): Adjust.
11148         (ashldi3_power, lshrdi3_power, ashrdi3_power): Delete.
11149         (ashrdi3_no_power, ashldi3, ashldi3_internal1,
11150         lshrdi3_internal1): Adjust.
11151         (fix_trunctfsi2, fix_trunctfsi2_fprs): Adjust.
11152         (movti_power): Delete.
11153         (movti_string): Adjust.
11154         (stmsi8, stmsi7, stmsi6, stmsi5, stmsi4, stmsi3): Adjust.
11155         (stmsi8_power, stmsi7_power, stmsi6_power, stmsi5_power,
11156         stmsi4_power, stmsi3_power): Delete.
11157         (anonymous movmemsi insn patterns): Adjust.
11158         (lfq_power2, stfq_power2): Delete.
11159         (eq<mode>, eq<mode>_compare): Adjust.
11160         (eqsi_power): Delete.
11161         (ne0si): Adjust.
11162         (anonymous le, lt, ge, gt insn patterns): Delete.
11163         * config/rs6000/rs6000.opt (mpower, mno-power, mpower2): Delete.
11164         * config/rs6000/sysv4.h (TARGET_POWER): Delete.
11165         * config/rs6000/t-aix43 (MULTILIB_OPTIONS, MULTILIB_DIRNAMES,
11166         MULTILIB_MATCHES): Adjust.
11167         * doc/invoke.texi (RS/6000 and PowerPC Options): Delete
11168         -mpower, -mno-power, -mpower2, -mno-power2 documentation.
11169         Delete -mcpu=power and -mcpu=power2 documentation.
11170
11171 2012-07-27  Segher Boessenkool  <segher@kernel.crashing.org>
11172
11173         * config/rs6000/601.md: New file.
11174         * config/rs6000/aix43.h (ASM_CPU_SPEC): Delete support for
11175         RIOS CPUs.
11176         * config/rs6000/aix51.h (ASM_CPU_SPEC): Likewise.
11177         * config/rs6000/driver-rs6000.c (detect_processor_aix,
11178         struct asm_names): Likewise.
11179         * config/rs6000/rios1.md: Delete file.
11180         * config/rs6000/rios2.md: Delete file.
11181         * config/rs6000/rs6000-cpus.def: Delete definitions for RIOS
11182         CPUs.
11183         * config/rs6000/rs6000-opts.h (enum processor_type): Delete
11184         PROCESSOR_RIOS1 and PROCESSOR_RIOS2.
11185         * config/rs6000/rs6000-tables.opt: Regenerated.
11186         * config/rs6000/rs6000.c (struct rios1_cost, struct rios2_cost):
11187         Delete.
11188         (rs6000_option_override_internal): Delete support for RIOS CPUs.
11189         (rs6000_conditional_register_usage): Adjust comment.
11190         (rs6000_issue_rate):Delete support for RIOS CPUs.
11191         * config/rs6000/rs6000.h (ASM_CPU_SPEC): Delete support for
11192         RIOS CPUs.
11193         (PROCESSOR_POWER): Change to PROCESSOR_PPC601.
11194         (PROCESSOR_DEFAULT): Change to PROCESSOR_PPC603.
11195         * config/rs6000/rs6000.md (define_attr "cpu"): Delete rios1
11196         and rios2.
11197         (include "rios1.md", include "rios2.md"): Delete.
11198         (include "601.md"): New.
11199         * config/rs6000/rs6000.opt (enum rs6000_cpu): Default to
11200         PROCESSOR_PPC603.
11201         * config/rs6000/t-aix43 (MULTILIB_MATCHES): Delete support
11202         for RIOS CPUs.
11203         * config/rs6000/t-rs6000 (MD_INCLUDES): Delete rios1.md and
11204         rios2.md .  Add 601.md .
11205
11206 2012-07-26  Richard Henderson  <rth@redhat.com>
11207
11208         * doc/extend.texi (attribute): Document hot/cold for labels.
11209         * predict.c (tree_estimate_probability_bb): Handle hot/cold
11210         attributes on user labels.
11211         * predict.def (PRED_HOT_LABEL, PRED_COLD_LABEL): New.
11212
11213 2012-07-26  Andrew Jenner  <andrew@codesourcery.com>
11214             Sandra Loosemore  <sandra@codesourcery.com>
11215
11216         * cse.c (find_comparison_args): Check for cycles of any length.
11217
11218 2012-07-26  Nick Clifton  <nickc@redhat.com>
11219
11220         * config/mn10300/mn10300.c (REG_SAVE_BYTES): Delete.
11221         (mn10300_get_live_callee_saved_regs): If requested return a count
11222         of the number of bytes in the mask.
11223         (mn10300_expand_prologue): Add argument to invocation of
11224         mn10300_get_live_callee_regs.
11225         (mn10300_expand_epilogue): Compute reg_save_bytes by calling
11226         mn10300_get_live_callee_saved_regs.
11227         (mn10300_initial_offset): Likewise.
11228         * config/mn10300/mn10300-protos.h (mn10300_get_live_callee_saved_regs):
11229         Update prototype.
11230         * config/mn10300/mn10300.md (return_ret): Add argument to
11231         invocation of mn10300_get_live_callee_saved_regs.
11232
11233 2012-07-26  Steven Bosscher  <steven@gcc.gnu.org>
11234
11235         PR regression/54084
11236         * sel-sched-ir.c (cmp_v_in_regset_pool): Clarify logic, fix
11237         pointer difference check.
11238
11239 2012-07-26  Bill Schmidt  <wschmidt@linux.ibm.com>
11240
11241         * tree-ssa-loop-ivopts.c (mbc_entry_hash): Remove.
11242         (mbc_entry_eq): Likewise.
11243         (mult_costs): Likewise.
11244         (cost_tables_exist): Likewise.
11245         (initialize_costs): Likewise.
11246         (finalize_costs): Likewise.
11247         (tree_ssa_iv_optimize_init): Remove call to initialize_costs.
11248         (add_regs_cost): Remove.
11249         (multiply_regs_cost): Likewise.
11250         (add_const_cost): Likewise.
11251         (extend_or_trunc_reg_cost): Likewise.
11252         (negate_reg_cost): Likewise.
11253         (struct mbc_entry): Likewise.
11254         (multiply_by_const_cost): Likewise.
11255         (get_address_cost): Change add_regs_cost calls to add_cost lookups;
11256         change multiply_by_const_cost to mult_by_coeff_cost.
11257         (force_expr_to_var_cost): Likewise.
11258         (difference_cost): Change multiply_by_const_cost to mult_by_coeff_cost.
11259         (get_computation_cost_at): Change add_regs_cost calls to add_cost
11260         lookups; change multiply_by_const_cost to mult_by_coeff_cost.
11261         (determine_iv_cost): Change add_regs_cost calls to add_cost lookups.
11262         (tree_ssa_iv_optimize_finalize): Remove call to finalize_costs.
11263         * tree-ssa-address.c (expmed.h): New #include.
11264         (most_expensive_mult_to_index): Change multiply_by_const_cost to
11265         mult_by_coeff_cost.
11266         * gimple-ssa-strength-reduction.c (expmed.h): New #include.
11267         (stmt_cost): Change to use mult_by_coeff_cost, mul_cost, add_cost,
11268         neg_cost, and convert_cost instead of IVOPTS interfaces.
11269         (execute_strength_reduction): Remove calls to initialize_costs and
11270         finalize_costs.
11271         * expmed.c (struct init_expmed_rtl): Add convert rtx_def.
11272         (init_expmed_one_mode): Initialize convert rtx_def; initialize
11273         x_convert_cost for related modes.
11274         (mult_by_coeff_cost): New function.
11275         * expmed.h (NUM_MODE_INT): New #define.
11276         (struct target_expmed): Add x_convert_cost matrix.
11277         (set_convert_cost): New inline function.
11278         (convert_cost): Likewise.
11279         (mult_by_coeff_cost): New extern decl.
11280         * tree-flow.h (initialize_costs): Remove decl.
11281         (finalize_costs): Likewise.
11282         (multiply_by_const_cost): Likewise.
11283         (add_regs_cost): Likewise.
11284         (multiply_regs_cost): Likewise.
11285         (add_const_cost): Likewise.
11286         (extend_or_trunc_reg_cost): Likewise.
11287         (negate_reg_cost): Likewise.
11288         * Makefile.in (gimple-ssa-strength-reduction.o): Update dependencies.
11289         (tree-ssa-address.o): Update dependencies.
11290
11291 2012-07-26  Steven Bosscher  <steven@gcc.gnu.org>
11292
11293         * bitmap.h: Add explanation of sparse set as linked-list bitmap.
11294         * sbitmap.h: Add explanation about non-sparse sets as simple bitmap.
11295         (TEST_BIT): Make a static inline function for stronger type checking.
11296         (SET_BIT): Don't handle sbitmaps with popcount.
11297         (RESET_BIT): Likewise.
11298         (SET_BIT_WITH_POPCOUNT): New, like SET_BIT but with popcount.
11299         (RESET_BIT_WITH_POPCOUNT): New, like RESET_BIT but with popcount.
11300         * ebitmap.c (ebitmap_clear_bit): Use SET_BIT_WITH_POPCOUNT and
11301         RESET_BIT_WITH_POPCOUNT on wordmask bitmaps.
11302         (ebitmap_set_bit, ebitmap_and_into, ebitmap_and, ebitmap_ior_into,
11303         ebitmap_and_compl_into, ebitmap_and_compl): Likewise.
11304         * sparseset.h: Add explanation of sparse set representation.
11305
11306 2012-07-26  Richard Guenther  <rguenther@suse.de>
11307
11308         PR tree-optimization/54098
11309         * tree-vrp.c (vrp_visit_phi_node): Iterate once more if the
11310         original range was UNDEFINED.
11311
11312 2012-07-26  Ramana Radhakrishnan  <ramana.radhakrishnan@linaro.org>
11313
11314         * config/arm/neon.ml (ops): Fix regexp for vld1Q_dups64 and
11315         vld1Q_dupu64 tests.
11316
11317 2012-07-26  Oleg Endo  <olegendo@gcc.gnu.org>
11318
11319         PR target/51244
11320         * config/sh/sh.opt (mzdcbranch): New option.
11321         * doc/invoke.texi: Document it.
11322         * config/sh/sh.md (negsi_cond): Use TARGET_ZDCBRANCH as condition
11323         instead of TARGET_HARD_SH4.
11324         * config/sh/sh.c (sh_option_override): Set TARGET_ZDCBRANCH as default
11325         for TARGET_HARD_SH4.
11326
11327 2012-07-25  Oleg Endo  <olegendo@gcc.gnu.org>
11328
11329         PR target/54089
11330         * config/sh/predicates.md (shift_count_operand): Handle not-SHMEDIA
11331         case.
11332         (p27_shift_count_operand, not_p27_shift_count_operand): New predicates.
11333         * config/sh/sh.md (ashlsi3): Remove parallel and T_REG clobber
11334         from expander.  Do not emit shift insn for not-SHMEDIA case.
11335         (ashlsi3_std): Replace with ...
11336         (ashlsi3_k, ashlsi3_d): ... these new insns.
11337         * config/sh/sh.c (gen_ashift): Make static.  Add sanity checks.
11338         Emit ashlsi3_k insn instead of ashlsi3_std in ASHIFT case.
11339         (gen_ashift_hi): Make static.
11340         * config/sh/sh-protos.h (gen_ashift, gen_ashift_hi): Remove forward
11341         declaration.
11342
11343 2012-07-25  Bharathi Seshadri  <bseshadr@cisco.com>
11344             Jim Wilson  <jimwilso@cisco.com>
11345
11346         * config/arm/bpabi.h (BE8_LINK_SPEC): Set according to
11347         TARGET_BIG_ENDIAN_DEFAULT.
11348
11349 2012-07-25  Eric Botcazou  <ebotcazou@adacore.com>
11350
11351         * gimple-low.c (lower_try_catch): New function.
11352         (lower_stmt) <GIMPLE_TRY>: Use it to lower GIMPLE_TRY_CATCH.
11353         <GIMPLE_CATCH>: Delete.
11354         <GIMPLE_EH_FILTER>: Likewise.
11355
11356 2012-07-25  Eric Botcazou  <ebotcazou@adacore.com>
11357
11358         * expr.c (expand_expr_real_1): Do not expand operand #1 and #2
11359         of BIT_FIELD_REF for ignored results.
11360         * fold-const.c (fold_ternary_loc) <BIT_FIELD_REF>: Check that the
11361         CONSTRUCTOR has vector type before using vector accessors on it.
11362         * gimplify.c (gimplify_compound_lval): Do not gimplify operand #1 and
11363         #2 of BIT_FIELD_REF.
11364         (gimplify_expr) <BIT_FIELD_REF>: Likewise.
11365         * tree-nested.c (convert_nonlocal_reference_op) <BIT_FIELD_REF>: Do
11366         not process operand #1 and #2.
11367         (convert_local_reference_op): Likewise.
11368         * tree-ssa-pre.c (create_component_ref_by_pieces_1): Remove superfluous
11369         breaks throughout.
11370         <BIT_FIELD_REF>: Reuse operand #1 and #2 directly.
11371         * tree.c (stabilize_reference) <BIT_FIELD_REF>: Do not stabilize
11372         operand #1 and #2.
11373         (UPDATE_FLAGS): Do not consider operand #2 of BIT_FIELD_REF.
11374         (build6_stat): Delete.
11375         * tree.h (build6_stat, build6, build6_stat_loc, build6_loc): Likewise.
11376
11377 2012-07-25 Marc Glisse <marc.glisse@inria.fr>
11378
11379         PR tree-optimization/30318
11380         * tree-vrp.c (extract_range_from_binary_expr_1) [PLUS_EXPR]:
11381         Handle __int128.
11382         [MINUS_EXPR]: Merge with PLUS_EXPR.
11383
11384 2012-07-25  Sandra Loosemore  <sandra@codesourcery.com>
11385             Paul Brook  <paul@codesourcery.com>
11386
11387         PR target/53633
11388         * target.def (warn_func_return): New hook.
11389         * doc/tm.texi.in (TARGET_WARN_FUNC_RETURN): New hook.
11390         * doc/tm.texi: Regenerate.
11391         * doc/sourcebuild.texi (Effective-Target Keywords): Document
11392         naked_functions.
11393         * ipa-pure-const.c (warn_function_noreturn): Check
11394         targetm.warn_func_return.
11395         * tree-cfg.c (execute_warn_function_return): Likewise.
11396         * config/spu/spu.c (spu_warn_func_return): New.
11397         (TARGET_WARN_FUNC_RETURN): Define.
11398         * config/rx/rx.c (rx_warn_func_return): New.
11399         (TARGET_WARN_FUNC_RETURN): Define.
11400         * config/avr/avr.c (avr_warn_func_return): New.
11401         (TARGET_WARN_FUNC_RETURN): Define.
11402         * config/arm/arm.c (arm_warn_func_return): New.
11403         (TARGET_WARN_FUNC_RETURN): Define.
11404         * config/mcore/mcore.c (mcore_warn_func_return): New.
11405         (TARGET_WARN_FUNC_RETURN): Define.
11406         (saved_warn_return_type, saved_warn_return_type_count): Remove.
11407         (mcore_reorg, mcore_handle_naked_attribute): Remove warn_return hack.
11408
11409 2012-07-25  Siddhesh Poyarekar  <siddhesh@redhat.com>
11410
11411         * final.c [ASSEMBLER_DIALECT](do_assembler_dialects): New
11412         function to implement assembler dialects.
11413         (output_asm_insn): Use do_assembler_dialects.
11414         (asm_fprintf): Likewise.
11415
11416 2012-07-25  Richard Henderson  <rth@redhat.com>
11417
11418         PR bootstrap/54092
11419         * libfuncs.h: Don't include optabs.h.
11420         (struct libfunc_entry): Use "int" for op, mode1, mode2 members.
11421         * optabs.c (hash_libfunc): Don't cast members to int.
11422         * Makefile.in (LIBFUNCS_H): Don't include OPTABS_H.
11423
11424 2012-07-25  Dodji Seketeli  <dodji@redhat.com>
11425
11426         * basic-block.c: Fix typo in comment.
11427
11428 2012-07-25  Kirill Yukhin  <kirill.yukhin@intel.com>
11429             Michael Zolotukhin  <michael.v.zolotukhin@intel.com>
11430
11431         * common/config/i386/i386-common.c (OPTION_MASK_ISA_PRFCHW_SET): New.
11432         (OPTION_MASK_ISA_PRFCHW_UNSET): Likewise.
11433         (ix86_handle_option): Handle mprfchw option.
11434         * config.gcc (i[34567]86-*-*): Add prfchwintrin.h.
11435         (x86_64-*-*): Likewise.
11436         * config/i386/prfchwintrin.h: New header.
11437         * config/i386/cpuid.h (bit_PRFCHW): New.
11438         (bit_BMI): Formatting fix.
11439         (bit_HLE): Likewise.
11440         (bit_RTM): Likewise.
11441         * config/i386/driver-i386.c (host_detect_local_cpu): Detect
11442         PREFETCHW support.
11443         * config/i386/i386-c.c: Define __PRFCHW__ if needed.
11444         * config/i386/i386.c (ix86_target_string): Define
11445         -mprfchw option. Formatting fixes.
11446         (PTA_HLE): Formatting fix.
11447         (PTA_PRFCHW): New.
11448         (ix86_option_override_internal): Handle new option.
11449         (ix86_valid_target_attribute_inner_p): Add OPT_mprfchw.
11450         * config/i386/i386.h (TARGET_PRFCHW): New.
11451         * config/i386/i386.md (prefetch): Enable for TARGET_PRFCHW.
11452         * config/i386/i386.opt (mprfchw): New.
11453         * config/i386/mm3dnow.h: Move _m_prefetchw from here to prfchwintrin.h.
11454         * config/i386/x86intrin.h: Include prfchwintrin.h.
11455
11456 2012-07-25 Sergey Melnikov <sergey.melnikov@intel.com>
11457
11458         * config/i386/i386.md (stack_protect_set): Disable the pattern
11459         for Android since Android libc (bionic) does not provide random
11460         value for stack protection guard at gs:0x14. Guard value
11461         will be provided from external symbol (default implementation).
11462         (stack_protect_set_<mode>): Likewise.
11463         (stack_protect_test): Likewise.
11464         (stack_protect_test_<mode>): Likewise.
11465         * gcc/defaults.h: Define macro TARGET_HAS_BIONIC to 0 - target does
11466         not have Bionic by default
11467         * config/linux.h: Redefine macro TARGET_HAS_BIONIC to (OPTION_BIONIC)
11468         Macro OPTION_BIONIC is defined in this file and provides Bionic
11469         accessibility status
11470
11471 2012-07-25  Steven Bosscher  <steven@gcc.gnu.org>
11472
11473         * gimple-pretty-print.c (gimple_dump_bb_buff): Call pp_flush.
11474
11475 2012-07-25  Venkataramanan Kumar  <venkataramanan.kumar@amd.com>
11476
11477         btver2 Enablement
11478         * config.gcc (i[34567]86-*-linux* | ...): Add btver2.
11479         (case ${target}): Add btver2.
11480         * config/i386/driver-i386.c (host_detect_local_cpu): Let
11481         -march=native recognize btver2 processors.
11482         * config/i386/i386-c.c (ix86_target_macros_internal): Add
11483         btver2 def_and_undef
11484         * config/i386/i386.c (struct processor_costs btver2_cost): New
11485         btver2 cost table.
11486         (m_BTVER2): New definition.
11487         (m_AMD_MULTIPLE): Includes m_BTVER2.
11488         (initial_ix86_tune_features): Add btver2 tune.
11489         (processor_target_table): Add btver2 entry.
11490         (static const char *const cpu_names): Add btver2 entry.
11491         (software_prefetching_beneficial_p): Add btver2.
11492         (ix86_option_override_internal): Add btver2 instruction sets.
11493         (ix86_issue_rate): Add btver2.
11494         (ix86_adjust_cost): Add btver2.
11495         * config/i386/i386.h (TARGET_BTVER2): New definition.
11496         (enum target_cpu_default): Add TARGET_CPU_DEFAULT_btver2.
11497         (enum processor_type): Add PROCESSOR_BTVER2.
11498         * config/i386/i386.md (define_attr "cpu"): Add btver2.
11499
11500 2012-07-24  Bill Schmidt  <wschmidt@linux.ibm.com>
11501
11502         * doc/tm.texi: Regenerate.
11503         * targhooks.c (default_init_cost): Add prologue and epilogue costs.
11504         (default_add_stmt_cost): Likewise; also handle NULL stmt_info.
11505         (default_finish_cost): Add prologue and epilogue costs.
11506         * targhooks.h (default_add_stmt_cost): Change parameter list.
11507         (default_finish_cost): Likewise.
11508         * target.def (init_cost): Change documentation string.
11509         (add_stmt_cost): Change documentation string and parameter list.
11510         (finish_cost): Likewise.
11511         * target.h (vect_cost_model_location): New enum.
11512         * tree-vectorizer.h (struct _slp_tree): Remove cost substruct.
11513         (struct _slp_instance): Remove cost substruct; rename stmt_cost_vec
11514         to body_cost_vec.
11515         (SLP_INSTANCE_OUTSIDE_OF_LOOP_COST): Remove.
11516         (SLP_INSTANCE_STMT_COST_VEC): Rename to SLP_INSTANCE_BODY_COST_VEC.
11517         (SLP_TREE_OUTSIDE_OF_LOOP_COST): Remove.
11518         (struct _vect_peel_extended_info): Rename stmt_cost_vec to
11519         body_cost_vec.
11520         (struct _stmt_vec_info): Remove cost substruct.
11521         (STMT_VINFO_OUTSIDE_OF_LOOP_COST): Remove.
11522         (stmt_vinfo_set_outside_of_loop_cost): Remove.
11523         (builtin_vectorization_cost): New function.
11524         (vect_get_stmt_cost): Change to use builtin_vectorization_cost.
11525         (add_stmt_cost): Change parameter list.
11526         (finish_cost): Likewise.
11527         (vect_model_simple_cost): Likewise.
11528         (vect_model_store_cost): Likewise.
11529         (vect_model_load_cost): Likewise.
11530         (record_stmt_cost): Likewise.
11531         (vect_get_load_cost): Likewise.
11532         (vect_get_known_peeling_cost): Likewise.
11533         * tree-vect-loop.c (vect_get_known_peeling_cost): Change parameter
11534         list; call record_stmt_cost for prologue and epilogue costs.
11535         (vect_estimate_min_profitable_iters): Call add_stmt_cost for
11536         prologue and epilogue costs; remove computation of vec_outside_cost;
11537         return vec_prologue_cost and vec_epilogue_cost from finish_cost.
11538         (vect_model_reduction_cost): Revise call to add_stmt_cost for body
11539         costs; call add_stmt_cost for prologue and epilogue costs.
11540         (vect_model_induction_cost): Revise call to add_stmt_cost for body
11541         costs; call add_stmt_cost for prologue costs.
11542         * tree-vect-data-refs.c (vect_get_data_access_cost): Change parameter
11543         list for function and arguments for calls to vect_get_load_cost and
11544         vect_get_store_cost.
11545         (vect_peeling_hash_get_lowest_cost): Change argument list for calls to
11546         vect_get_data_access_cost and vect_get_known_peeling_cost; use
11547         temporary vectors prologue_cost_vec and epilogue_cost_vec for the
11548         latter call and discard their results; rename stmt_cost_vec to
11549         body_cost_vec; correct possible storage leak for body_cost_vec.
11550         (vect_peeling_hash_choose_best_peeling): Rename stmt_cost_vec to
11551         body_cost_vec.
11552         (vect_enhance_data_refs_alignment): Rename stmt_cost_vec to
11553         body_cost_vec; add extra dummy parameter on calls to
11554         vect_get_data_access_cost; tolerate null si->stmt; add vect_body to
11555         argument list on call to add_stmt_cost.
11556         * tree-vect-stmts.c (record_stmt_cost): Change parameter list;
11557         rename stmt_cost_vec to body_cost_vec; tolerate null stmt_info; call
11558         builtin_vectorization_cost; add "where" parameter on call to
11559         add_stmt_cost.
11560         (vect_model_simple_cost): Change parameter list; call record_stmt_cost
11561         for prologue costs; remove call to stmt_vinfo_set_outside_of_loop_cost;
11562         rename stmt_cost_vec to body_cost_vec.
11563         (vect_model_promotion_demotion_cost): Add vect_body argument to call
11564         to add_stmt_cost; call add_stmt_cost for prologue costs; remove call
11565         to stmt_vinfo_set_outside_of_loop_cost.
11566         (vect_model_store_cost): Change parameter list; call record_stmt_cost
11567         for prologue costs; add vect_body argument to call to record_stmt_cost;
11568         rename stmt_cost_vec to body_cost_vec; remove call to
11569         stmt_vinfo_set_outside_of_loop_cost.
11570         (vect_get_store_cost): Rename stmt_cost_vec to body_cost_vec; add
11571         vect_body argument to calls to record_stmt_cost.
11572         (vect_model_load_cost): Change parameter list; rename stmt_cost_vec to
11573         body_cost_vec; add vect_body argument to calls to record_stmt_cost;
11574         remove call to stmt_vinfo_set_outside_of_loop_cost.
11575         (vect_get_load_cost): Change parameter list; rename stmt_cost_vec to
11576         body_cost_vec; add vect_body argument to calls to record_stmt_cost;
11577         call record_stmt_cost for prologue costs.
11578         (vectorizable_store): Change argument list for call to
11579         vect_model_store_cost.
11580         (vectorizable_load): Change argument list for call to
11581         vect_model_load_cost.
11582         (new_stmt_vec_info): Remove assignment to
11583         STMT_VINFO_OUTSIDE_OF_LOOP_COST.
11584         * config/spu/spu.c (spu_init_cost): Add prologue and epilogue costs.
11585         (spu_add_stmt_cost): Likewise; also handle NULL stmt_info.
11586         (spu_finish_cost): Add prologue and epilogue costs.
11587         * config/i386/i386.c (i386_init_cost): Add prologue and epilogue costs.
11588         (i386_add_stmt_cost): Likewise; also handle NULL stmt_info.
11589         (i386_finish_cost): Add prologue and epilogue costs.
11590         * config/rs6000/rs6000.c (rs6000_init_cost): Add prologue and epilogue
11591         costs.
11592         (rs6000_add_stmt_cost): Likewise; also handle NULL stmt_info.
11593         (rs6000_finish_cost): Add prologue and epilogue costs.
11594         * tree-vect-slp.c (vect_free_slp_instance): Rename
11595         SLP_INSTANCE_STMT_COST_VEC to SLP_INSTANCE_BODY_COST_VEC.
11596         (vect_create_new_slp_node): Remove assignment to
11597         SLP_TREE_OUTSIDE_OF_LOOP_COST.
11598         (vect_get_and_check_slp_defs): Change parameter list; change argument
11599         lists to calls to vect_model_store_cost and vect_model_simple_cost.
11600         (vect_build_slp_tree): Change parameter list; change argument lists
11601         to calls to vect_model_load_cost, vect_get_and_check_slp_defs, and
11602         recursive self-calls; remove setting of outside_cost from
11603         SLP_TREE_OUTSIDE_OF_LOOP_COST; add vect_body argument to call to
11604         record_stmt_cost.
11605         (vect_analyze_slp_instance): Rename stmt_cost_vec to body_cost_vec;
11606         rename SLP_INSTANCE_STMT_COST_VEC to SLP_INSTANCE_BODY_COST_VEC;
11607         remove assignment to SLP_INSTANCE_OUTSIDE_OF_LOOP_COST; record SLP
11608         prologue costs.
11609         (vect_bb_vectorization_profitable_p): Rename stmt_cost_vec to
11610         body_cost_vec; handle null ci->stmt; add vect_body argument to call
11611         to add_stmt_cost; simplify calls to targetm.vectorize.
11612         builtin_vectorization_cost; return vec_prologue_cost and
11613         vec_epilogue_cost from finish_cost.
11614         (vect_update_slp_costs_according_to_vf): Rename stmt_cost_vec to
11615         body_cost_vec; add vect_body argument to call to add_stmt_cost.
11616
11617 2012-07-24  Richard Henderson  <rth@redhat.com>
11618
11619         * system.h (FIXUNS_TRUNC_LIKE_FIX_TRUNC): Poison.
11620         * config/cris/cris.h (FIXUNS_TRUNC_LIKE_FIX_TRUNC): Remove.
11621         * config/h8300/h8300.h (FIXUNS_TRUNC_LIKE_FIX_TRUNC): Remove.
11622         * config/mn10300/mn10300.h (FIXUNS_TRUNC_LIKE_FIX_TRUNC): Remove.
11623         * config/rs6000/rs6000.h (FIXUNS_TRUNC_LIKE_FIX_TRUNC): Remove
11624         comment reference.
11625         * config/v850/v850.h (FIXUNS_TRUNC_LIKE_FIX_TRUNC): Remove.
11626         * config/v850/v850.md (fixuns_truncsfsi2, fixuns_truncdfsi2): New.
11627         (fix_truncsfsi2, fix_truncdfsi2): Avoid double FIX.
11628         * config/vax/vax.h (FIXUNS_TRUNC_LIKE_FIX_TRUNC): Remove.
11629         * config/vax/vax.md (fixuns_trunc<VAXfp><VAXint>): New.
11630         * doc/tm.texi.in (FIXUNS_TRUNC_LIKE_FIX_TRUNC): Remove.
11631         * doc/tm.texi: Rebuild.
11632
11633 2012-07-24  Richard Henderson  <rth@redhat.com>
11634
11635         * optabs.def: New file.
11636         * Makefile.in (OPTABS_H): Add insn-opinit.h.
11637         (MOSTLYCLEANFILES): Likewise.
11638         (insn-opinit.o): Remove reload.h
11639         (simple_rtl_generated_c): Remove insn-opinit.c.
11640         (s-opinit): New rule.
11641         (build/genopinit.o): Add optabs.def.
11642         * genopinit.c (rtx_upname): New.
11643         (optabs): Extract to optabs.def
11644         (enum optab_tag, struct optab_def_d, optabs): New.
11645         (struct pattern_d, patterns): New.
11646         (match_pattern): Split out from ...
11647         (gen_insn): ... here.  Push matches on patterns vec.
11648         (pattern_cmp, optab_kind_cmp, optab_rcode_cmp): New.
11649         (header_file_name, source_file_name, handle_arg): New.
11650         (open_outfile): New.
11651         (main): Sort and emit new tables.  Generate lookup_handler,
11652         raw_optab_handler, swap_optab_enable.
11653         * libfuncs.h (libfunc_entry): Change "size_t optab" to "optab op".
11654         * optabs.c (code_to_optab_): Remove.
11655         (hash_libfunc): Update for optab name change.
11656         (eq_libfunc): Likewise.
11657         (convert_optab_libfunc): Update computation of optab member;
11658         use the new convlib_def table.
11659         (optab_libfunc): Similarly.
11660         (set_optab_libfunc, set_conv_libfunc): Likewise.
11661         (sign_expand_binop): Use swap_optab_enable instead of fake optabs.
11662         (init_insn_codes, init_optab, init_optabv, init_convert_optab): Remove.
11663         (init_optabs): Don't call them; export the data to optabs.def.
11664         (gen_int_libfunc, gen_fp_libfunc): Export non-static.
11665         (gen_fixed_libfunc, gen_signed_fixed_libfunc): Likewise.
11666         (gen_unsigned_fixed_libfunc, gen_int_fp_libfunc): Likewise.
11667         (gen_intv_fp_libfunc, gen_int_fp_fixed_libfunc): Likewise.
11668         (gen_int_fp_signed_fixed_libfunc, gen_int_fixed_libfunc): Likewise.
11669         (gen_int_signed_fixed_libfunc): Likewise.
11670         (gen_int_unsigned_fixed_libfunc): Likewise.
11671         (gen_interclass_conv_libfunc, gen_int_to_fp_conv_libfunc): Likewise.
11672         (gen_ufloat_conv_libfunc): Likewise.
11673         (gen_int_to_fp_nondecimal_conv_libfunc): Likewise.
11674         (gen_fp_to_int_conv_libfunc, gen_intraclass_conv_libfunc): Likewise.
11675         (gen_trunc_conv_libfunc, gen_extend_conv_libfunc): Likewise.
11676         (gen_fract_conv_libfunc, gen_fractuns_conv_libfunc): Likewise.
11677         (gen_satfract_conv_libfunc, gen_satfractuns_conv_libfunc): Likewise.
11678         (debug_optab_libfuncs): Update for optab representation change.
11679         * optabs.h: Include insn-opinit.h.
11680         (optab, convert_optab, direct_optab): New typedefs.
11681         (struct optab_handlers, struct widening_optab_handlers): Remove.
11682         (struct optab_libcall_d): Rename from optab_d; remove code_,
11683         handlers, widening members.
11684         (struct convert_optab_libcall_d): Rename from convert_optab_d;
11685         remove code_ and handlers members.
11686         (enum optab_index, enum convert_optab_index): Remove.
11687         (enum direct_optab_index): Remove.
11688         (code_to_optab_): Fix array range.
11689         (optab_to_code): Covert to inline function.
11690         (optab_to_code_, convlib_def, normlib_def): Declare.
11691         (raw_optab_handler, swap_optab_enable): Declare.
11692         (unknown_optab): Remove; export to optabs.def
11693         (ssadd_optab, usadd_optab, sssub_optab, ussub_optab, ssmul_optab,
11694         usmul_optab, ssdiv_optab, usdiv_optab, ssneg_optab, usneg_optab,
11695         ssashl_optab, usashl_optab, add_optab, sub_optab, smul_optab,
11696         addv_optab, subv_optab, smul_highpart_optab, umul_highpart_optab,
11697         smul_widen_optab, umul_widen_optab, usmul_widen_optab,
11698         smadd_widen_optab, umadd_widen_optab, ssmadd_widen_optab,
11699         usmadd_widen_optab, smsub_widen_optab, umsub_widen_optab,
11700         ssmsub_widen_optab, usmsub_widen_optab, sdiv_optab, smulv_optab,
11701         sdivv_optab, sdivmod_optab, udiv_optab, udivmod_optab, smod_optab,
11702         umod_optab, fmod_optab, remainder_optab, ftrunc_optab, and_optab,
11703         ior_optab, xor_optab, ashl_optab, lshr_optab, ashr_optab, rotl_optab,
11704         rotr_optab, vashl_optab, vlshr_optab, vashr_optab, vrotl_optab,
11705         vrotr_optab, smin_optab, smax_optab, umin_optab, umax_optab, pow_optab,
11706         atan2_optab, fma_optab, fms_optab, fnma_optab, fnms_optab, mov_optab,
11707         movstrict_optab, movmisalign_optab, storent_optab, neg_optab,
11708         negv_optab, abs_optab, absv_optab, one_cmpl_optab, bswap_optab,
11709         ffs_optab, clz_optab, ctz_optab, clrsb_optab, popcount_optab,
11710         parity_optab, sqrt_optab, sincos_optab, sin_optab, asin_optab,
11711         cos_optab, acos_optab, exp_optab, exp10_optab, exp2_optab, expm1_optab,
11712         ldexp_optab, scalb_optab, significand_optab, logb_optab, ilogb_optab,
11713         log_optab, log10_optab, log2_optab, log1p_optab, floor_optab,
11714         ceil_optab, btrunc_optab, round_optab, nearbyint_optab, rint_optab,
11715         tan_optab, atan_optab, copysign_optab, signbit_optab, isinf_optab,
11716         cmp_optab, ucmp_optab, eq_optab, ne_optab, gt_optab, ge_optab,
11717         lt_optab, le_optab, unord_optab, strlen_optab, cbranch_optab,
11718         cmov_optab, cstore_optab, ctrap_optab, push_optab, addcc_optab,
11719         reduc_smax_optab, reduc_umax_optab, reduc_smin_optab, reduc_umin_optab,
11720         reduc_splus_optab, reduc_uplus_optab, ssum_widen_optab,
11721         usum_widen_optab, sdot_prod_optab, udot_prod_optab, vec_set_optab,
11722         vec_extract_optab, vec_init_optab, vec_shl_optab, vec_shr_optab,
11723         vec_realign_load_optab, vec_widen_umult_hi_optab,
11724         vec_widen_umult_lo_optab, vec_widen_smult_hi_optab,
11725         vec_widen_smult_lo_optab, vec_widen_umult_even_optab,
11726         vec_widen_umult_odd_optab, vec_widen_smult_even_optab,
11727         vec_widen_smult_odd_optab, vec_widen_ushiftl_hi_optab,
11728         vec_widen_ushiftl_lo_optab, vec_widen_sshiftl_hi_optab,
11729         vec_widen_sshiftl_lo_optab, vec_unpacks_hi_optab, vec_unpacks_lo_optab,
11730         vec_unpacku_hi_optab, vec_unpacku_lo_optab, vec_unpacks_float_hi_optab,
11731         vec_unpacks_float_lo_optab, vec_unpacku_float_hi_optab,
11732         vec_unpacku_float_lo_optab, vec_pack_trunc_optab, vec_pack_ssat_optab,
11733         vec_pack_usat_optab, vec_pack_sfix_trunc_optab,
11734         vec_pack_ufix_trunc_optab, powi_optab, sync_compare_and_swap_optab,
11735         sync_lock_test_and_set_optab, sync_old_add_optab, sync_old_sub_optab,
11736         sync_old_ior_optab, sync_old_and_optab, sync_old_xor_optab,
11737         sync_old_nand_optab, sync_new_add_optab, sync_new_sub_optab,
11738         sync_new_ior_optab, sync_new_and_optab, sync_new_xor_optab,
11739         sync_new_nand_optab, sext_optab, zext_optab, trunc_optab, sfix_optab,
11740         ufix_optab, sfixtrunc_optab, ufixtrunc_optab, sfloat_optab,
11741         ufloat_optab, lrint_optab, lround_optab, lfloor_optab, lceil_optab,
11742         fract_optab, fractuns_optab, satfract_optab, satfractuns_optab,
11743         vec_load_lanes_optab, vec_store_lanes_optab, vcond_optab, vcondu_optab,
11744         movcc_optab, reload_in_optab, reload_out_optab, movmem_optab,
11745         setmem_optab, cmpstr_optab, cmpstrn_optab, cmpmem_optab,
11746         sync_lock_release_optab, sync_add_optab, sync_sub_optab,
11747         sync_ior_optab, sync_and_optab, sync_xor_optab, sync_nand_optab,
11748         atomic_exchange_optab, atomic_compare_and_swap_optab,
11749         atomic_load_optab, atomic_store_optab, atomic_add_fetch_optab,
11750         atomic_sub_fetch_optab, atomic_and_fetch_optab,
11751         atomic_nand_fetch_optab, atomic_xor_fetch_optab, atomic_or_fetch_optab,
11752         atomic_fetch_add_optab, atomic_fetch_sub_optab, atomic_fetch_and_optab,
11753         atomic_fetch_nand_optab, atomic_fetch_xor_optab, atomic_fetch_or_optab,
11754         atomic_add_optab, atomic_sub_optab, atomic_and_optab,
11755         atomic_nand_optab, atomic_xor_optab, atomic_or_optab,
11756         atomic_always_lock_free_optab, atomic_is_lock_free_optab,
11757         atomic_thread_fence_optab, atomic_signal_fence_optab,
11758         vec_perm_optab, vec_perm_const_optab): Likewise.
11759         (struct target_optabs): Remove x_optab_table, x_convert_optab_table,
11760         and x_direct_optab_table members; add pat_enable.
11761         (optab_table, convert_optab_table, direct_optab_table): Remove.
11762         (optab_handler): Use raw_optab_handler.
11763         (widening_optab_handler, convert_optab_handler): Likewise.
11764         (set_optab_handler, set_widening_optab_handler): Remove.
11765         (set_convert_optab_handler, set_direct_optab_handler): Remove.
11766         (direct_optab_handler): Defer to optab_handler.
11767         * rtl.h (NON_GENERATOR_NUM_RTX_CODE): New.
11768
11769 2012-07-24  Jason Merrill  <jason@redhat.com>
11770
11771         * bitmap.c (bitmap_descriptor): Adjust order of parameters to
11772         match MEM_STAT_DECL.
11773         * statistics.h (ALONE_FINAL_MEM_STAT_DECL): Correct typo.
11774
11775 2012-07-24  Richard Henderson  <rth@redhat.com>
11776
11777         * optabs.h (struct optab_d): Rename code member to code_.
11778         (struct convert_optab_h): Likewise.
11779         (code_to_optab_): Rename from code_to_optab.
11780         (code_to_optab, optab_to_code): New.
11781         * dojump.c (do_compare_rtx_and_jump): Use code_to_optab.
11782         * ifcvt.c (noce_emit_move_insn): Likewise.
11783         * optabs.c (simplify_expand_binop): Use optab_to_code.
11784         (expand_simple_binop, shift_optab_p, commutative_optab_p): Likewise.
11785         (avoid_expensive_constant, expand_binop_directly): Likewise.
11786         (expand_binop, expand_simple_unop, expand_unop_direct): Likewise.
11787         (expand_unop, prepare_float_lib_cmp, expand_fixed_convert): Likewise.
11788         (have_insn_for, debug_optab_libfuncs): Likewise.
11789         (init_optab, init_optabv, init_convert_optab): Update for optab
11790         member name change.
11791
11792         * libfuncs.h: Include optabs.h.
11793         * dwarf2out.c, lto-streamer.in.c: Don't include libfuncs.h.
11794         * Makefile.in (LIBFUNCS_H): Add OPTABS_H.
11795         (lto-streamer-in.o, dwarf2out.o): Update deps.
11796
11797         * optabs.h (unknown_optab): New.
11798         * builtins.c (interclass_mathfn_icode): Use it.
11799         * dojump.c (do_compare_rtx_and_jump): Likewise.
11800         * optabs.c (optab_for_tree_code, expand_binop): Likewise.
11801         * tree-vect-generic.c (add_rshift, expand_vector_divmod): Likewise.
11802         (expand_vector_operations_1): Likewise.
11803         * tree-vect-patterns.c (vect_recog_divmod_pattern): Likewise.
11804         * tree-vect-stmts.c (supportable_narrowing_operation): Likewise.
11805
11806 2012-07-24  Steven Bosscher  <steven@gcc.gnu.org>
11807
11808         * alloc-pool.c (create_alloc_pool): Fix ENABLE_CHECKING check.
11809
11810 2012-07-24  Ramana Radhakrishnan  <ramana.radhakrishnan@linaro.org>
11811
11812         PR target/54051
11813         * config/arm/arm.c (arm_print_operand_address): Remove superfluous
11814         printing of 0.
11815         * config/arm/neon.md ("neon_vld3_lane<mode>":VD): Remove alignment
11816         specifier.
11817         ("neon_vld3_lane<mode>":VMQ): Likewise.
11818         ("neon_vld3_dup<mode>":VDX): Likewise.
11819         ("neon_vst3_lane<mode>":VD): Likewise.
11820         ("neon_vst3_lane<mode>":VMQ): Likewise.
11821
11822 2012-07-24  Roland McGrath  <mcgrathr@google.com>
11823
11824         * arm.c (arm_get_frame_offsets): Don't use fixed regs for
11825         stack alignment padding.
11826
11827 2012-07-24  Uros Bizjak  <ubizjak@gmail.com>
11828
11829         PR target/53961
11830         * config/i386/i386.c (ix86_legitimate_address_p): Move check for
11831         negative constant address for TARGET_X32 ...
11832         (ix86_decompose_address): ... here.  Reject constant addresses
11833         that don't satisfy x86_64_immediate_operand predicate.
11834
11835 2012-07-24  Julian Brown  <julian@codesourcery.com>
11836
11837         * doc/sourcebuild.texi (arm_hf_eabi): Document effective-target check.
11838
11839 2012-07-24  Steven Bosscher  <steven@gcc.gnu.org>
11840
11841         * sbitmap.h (SBITMAP_ELT_BITS): Use "1u" trick as for BITMAP_WORD_BITS.
11842         Move test to check that there is a popcount function for the the number
11843         of bits in SBITMAP_ELT_BITS to sbitmap.c.
11844         * sbitmap.c: Test SBITMAP_ELT_BITS, not HOST_BITS_PER_WIDEST_FAST_INT.
11845         MEM_STAT_INFO): Define in terms of their ALONE counterparts.
11846
11847         * configure.ac (GATHER_STATISTICS): Always define, non-zero if enabled.
11848         * configure: Regenerate.
11849         * statistics.h (GATHER_STATISTICS): Error out if it is not defined.
11850         (GCC_MEM_STAT_ARGUMENTS): New define.
11851         (ALONE_MEM_STAT_DECL): Define in terms of GCC_MEM_STAT_ARGUMENTS.
11852         (ALONE_FINAL_MEM_STAT_DECL, ALONE_FINAL_PASS_MEM_STAT): New defines.
11853         (MEM_STAT_DECL, FINAL_MEM_STAT_DECL, PASS_MEM_STAT,
11854         FINAL_PASS_MEM_STAT): Define.
11855         * ggc-internal.h (ggc_record_overhead): Use FINAL_MEM_STAT_DECL.
11856         * ggc.h (ggc_record_overhead, ggc_free_overhead,
11857         ggc_prune_overhead_list): Remove internal prototypes, they are defined
11858         already in ggc-internal.h.
11859         * ggc-common.c (struct loc_descriptor): Remove #ifdef GATHER_STATISTICS
11860         wrappers.
11861         (add_statistics): Likewise.
11862         (dump_ggc_loc_statistics): Likewise. Return if GATHER_STATISTICS is 0.
11863         * ggc-zone.c (struct page_entry): Remove #ifdef GATHER_STATISTICS
11864         wrappers around "survived" and "stats" members.
11865         (alloc_large_page): Always initialize survived.
11866         (ggc_internal_alloc_zone_stat): Likewise.
11867         Remove #ifdef GATHER_STATISTICS wrappers.  Record overhead if
11868         GATHER_STATISTICS is non-0.
11869         (ggc_free): Convert #ifdef GATHER_STATISTICS to if-code.
11870         (sweep_pages): Always increase survived.
11871         (ggc_collect_1): Convert #ifdef GATHER_STATISTICS to if-code.
11872         (calculate_average_page_survival): Always define.
11873         (ggc_collect): Convert #ifdef GATHER_STATISTICS to if-code.
11874         (ggc_print_statistics): Likewise.
11875         (ggc_pch_read): Likewise.
11876         * ggc-page.c (struct globals): Always define "stats" member.
11877         (ggc_internal_alloc_stat): Convert #ifdef GATHER_STATISTICS to if-code.
11878         (ggc_free): Likewise.
11879         (ggc_collec): Likewise.
11880         (ggc_print_statistics): Likewise.
11881         * bitmap.h (struct bitmap_head_def): Always define "desc" member.
11882         (bitmap_initialize_stat): Convert #ifdef GATHER_STATISTICS to if-code.
11883         * gimple.h (enum gimple_alloc_kind): Always define.
11884         (gimple_alloc_kind): Likewise.
11885         * tree-flow.h (phinodes_print_statistics): Always define.
11886         (ssanames_print_statistics): Likewise.
11887         * vec.h (vec_heap_free): Always define.
11888         (VEC_stack_alloc): Define if GATHER_STATISTICS is non-0.
11889         * alloc-pool.c (alloc_pool_descriptor): Always define.
11890         (create_alloc_pool): Convert #ifdef GATHER_STATISTICS to if-code.
11891         (empty_alloc_pool): Likewise.
11892         (pool_alloc): Likewise.
11893         (pool_free): Likewise.
11894         (dump_alloc_pool_statistics): Likewise.
11895         (print_statistics): Always define.
11896         * bitmap.c (struct bitmap_descriptor): Always define.
11897         (bitmap_register): Pass ALONE_FINAL_PASS_MEM_STAT.
11898         (register_overhead): Always define.
11899         (bitmap_element_free): Convert #ifdef GATHER_STATISTICS to if-code.
11900         (bitmap_element_allocate): Likewise.
11901         (bitmap_elt_clear_from): Likewise.
11902         (bitmap_obstack_alloc_stat): Likewise.
11903         (bitmap_gc_alloc_stat): Likewise.
11904         (bitmap_obstack_free): Likewise.
11905         (bitmap_find_bit): Likewise.
11906         (bitmap_ior_and_into):  Likewise.
11907         (bitmap_print): Likewise.
11908         (dump_bitmap_statistics): Likewise. Return if GATHER_STATISTICS is 0.
11909         * gimple.c (gimple_alloc_counts, gimple_alloc_sizes): Always define.
11910         (gimple_alloc_kind_names): Likewise.
11911         (gimple_alloc_stat): Convert #ifdef GATHER_STATISTICS to if-code.
11912         (dump_gimple_statistics): Likewise. Return if GATHER_STATISTICS is 0.
11913         * rtl.c (rtx_alloc_counts, rtx_alloc_sizes, rtvec_alloc_counts,
11914         rtvec_alloc_sizes): Always define.
11915         (rvec_alloc): Convert #ifdef GATHER_STATISTICS to if-code.
11916         (rtx_alloc_stat): Likewise.
11917         (dump_rtx_statistics): Likewise. Return if GATHER_STATISTICS is 0.
11918         * tree.c (_obstack_allocated_p, tree_code_counts, tree_node_counts,
11919         tree_node_sizes, tree_node_kind_names): Always define.
11920         (record_node_allocation_statistics): Convert #ifdef GATHER_STATISTICS
11921         to if-code.
11922         (type_hash_canon): Likewise.
11923         (dump_tree_statistics): Likewise.
11924         * tree-ssanames.c (ssa_name_nodes_reused, ssa_name_nodes_created):
11925         Always define.
11926         (ssanames_print_statistics): Likewise.
11927         (make_ssa_name_fn): Convert #ifdef GATHER_STATISTICS to if-code.
11928         * tree-phinodes.c (phi_nodes_reused, phi_nodes_created): Always define.
11929         (phinodes_print_statistics): Likewise.
11930         (allocate_phi_node): Convert #ifdef GATHER_STATISTICS to if-code.
11931         * vec.c (struct vec_descriptor): Always define.
11932         (hash_descriptor, eq_descriptor, ptr_hash_entry, hash_ptr, eq_ptr,
11933         vec_descriptor, rester_overhead, free_overhead): Likewise.
11934         (cmp_statistic): Likewise.
11935         (vec_heap_free): Convert #ifdef GATHER_STATISTICS to if-code.
11936         (vec_heap_o_reserve_1): Likewise.
11937         (dump_vec_loc_statistics): Likewise.
11938
11939 2012-07-24  Richard Guenther  <rguenther@suse.de>
11940
11941         PR tree-optimization/53616
11942         * tree-loop-distribution.c (ldist_gen): Do not change
11943         partition ordering when merging partitions.
11944
11945 2012-07-24  Alan Modra  <amodra@gmail.com>
11946
11947         PR target/53914
11948         PR target/54009
11949         * config/rs6000/constraints.md (Y): Use mem_operand_gpr.
11950         * config/rs6000/predicates.md (word_offset_memref_operand): Delete.
11951         Adjust all rs6000_legitimate_offset_address_p calls.
11952         * config/rs6000/rs6000-protos.h (mem_operand_gpr): Declare.
11953         (rs6000_secondary_reload_gpr): Declare.
11954         (rs6000_legitimate_offset_address_p): Update prototype.
11955         (rs6000_offsettable_memref_p): Delete.
11956         (rs6000_secondary_reload_ppc64): Delete.
11957         * config/rs6000/rs6000.c (address_offset): New function.
11958         (mem_operand_gpr): Likewise.
11959         (rs6000_legitimate_offset_address_p): Add worst_case param.  When
11960         not worst_case assume class of regs with least restrictive offsets.
11961         Adjust all calls.
11962         (legitimate_lo_sum_address_p): Simplify register mode tests.
11963         (rs6000_legitimize_address): Likewise.  Assume best case offset
11964         addressing.  Combine ELF and MACHO lo_sum code.
11965         (rs6000_mode_dependent_address): Correct offset addressing limits.
11966         (rs6000_offsettable_memref_p): Make static, add reg_mode param.
11967         Use reg_mode to help rs6000_legitimate_offset_address_p.
11968         (rs6000_secondary_reload): Use address_offset.  Handle 32-bit multi
11969         gpr load/store when offset too large.
11970         (rs6000_secondary_reload_gpr): Renamed rs6000_secondary_reload_ppc64.
11971         (rs6000_split_multireg_move): Adjust rs6000_offsettable_memref_p calls.
11972         * config/rs6000/rs6000.md (movdf_hardfloat32): Use 'Y' constraint
11973         for gpr load/store.  Order alternatives as r->Y,Y->r,r->r and
11974         d->m,m->d,d->d.  Correct size of gpr load/store.
11975         (movdf_softfloat32): Use 'Y' constraint for gpr load/store.  Order
11976         alternatives.
11977         (movti_ppc64): Likewise.
11978         (movdi_internal32): Likewise.  Also disparage fprs.
11979         (movdi_mfpgpr, movdi_internal64): Likewise.
11980         (movtf_internal): Use 'm' for fpr load/store.  Order alternatives.
11981         (movtf_softfloat): Order alternatives.
11982         (extenddftf2_internal): Use 'm' and 'Y' for store.
11983         (movti_power, movti_string): Use 'Y' for gpr load/store.  Order.
11984         (stack_protect_setdi, stack_protect_testdi): Likewise.
11985         (movdf_hardfloat64_mfpgpr, movdf_hardfloat64): Order alternatives.
11986         (movdf_softfloat64): Likewise.
11987         (reload_<mode>_store): Adjust reload_di_store to provide
11988         reload_si_store as well.
11989         (reload_<mode>_load): Likewise.
11990
11991 2012-07-23  Oleg Endo  <olegendo@gcc.gnu.org>
11992
11993         PR target/51244
11994         * config/sh/predicates.md (general_movsrc_operand,
11995         general_movdst_operand): Reject T_REG.
11996         * config/sh/sh.md (*extendqisi2_compact_reg, *extendhisi2_compact_reg,
11997         movsi_i, movsi_ie, movsi_i_lowpart, *movqi_reg_reg, *movhi_reg_reg):
11998         Remove T_REG alternatives.
11999         (*negtstsi): New insn.
12000
12001 2012-07-23  Oleg Endo  <olegendo@gcc.gnu.org>
12002
12003         PR target/53511
12004         * config/sh/sh.md (mulsf3_ie): Delete.
12005         (mulsf3_i4): Rename to mulsf3_i.
12006         (mulsf3): Emit mulsf3_i insn.
12007
12008 2012-07-23  Oleg Endo  <olegendo@gcc.gnu.org>
12009
12010         * config/sh/sh.md (addc1, subc1): Delete.
12011         (adddi3_compact): Use addc instead of addc1.
12012         (subdi3_compact): Use subc instead of subc1.
12013
12014 2012-07-23  Uros Bizjak  <ubizjak@gmail.com>
12015
12016         * config/i386/i386-protos.h (ix86_lea_outperforms): Remove prototype.
12017         * config/i386/i386.c (ix86_lea_outperforms): Make static.  Make
12018         split_cost argument signed.
12019         (ix86_avoid_lea_for_add): Cleanup.
12020         (ix86_use_lea_for_mov): Use INVALID_REGNUM instead of -1.
12021         (ix86_avoid_lea_for_addr): Ditto.  Make split_cost signed.
12022         Use gen_lowpart instead of gen_rtx_SUBREG.  Cleanup.
12023
12024 2012-07-23  Ulrich Weigand  <ulrich.weigand@linaro.org>
12025
12026         * config/arm/arm.c (arm_reorg): Ensure all insns are split.
12027
12028 2012-07-23  Uros Bizjak  <ubizjak@gmail.com>
12029
12030         PR target/53961
12031         * config/i386/i386.md (*lea): Add asserts to detect invalid addresses.
12032         * config/i386/i386.c (ix86_print_operand_address): Ditto.
12033         (ix86_decompose_address): Allow (zero_extend:DI (subreg:SI (...)))
12034         addresses.  Prevent zero extensions of CONST_INT operands.
12035
12036 2012-07-23  Steven Bosscher  <steven@gcc.gnu.org>
12037
12038         * sbitmap.h (struct int_list): Remove.
12039         (sbitmap_intersect_of_predsucc, sbitmap_union_of_predsucc):
12040         Remove prototypes of non-existing function.
12041         (sbitmap_intersect_of_predecessors, sbitmap_intersect_of_successors,
12042         sbitmap_union_of_predecessors, sbitmap_union_of_successors): Remove
12043         unused defines.
12044         (sbitmap_intersection_of_succs, sbitmap_intersection_of_preds,
12045         sbitmap_union_of_succs, sbitmap_union_of_preds): Move prototypes to...
12046         * basic-block.h: ... here.
12047         * sbitmap.c: Do not include basic-block.h.
12048         (sbitmap_intersection_of_succs, sbitmap_intersection_of_preds,
12049         sbitmap_union_of_succs, sbitmap_union_of_preds): Move functions to...
12050         * cfganal.c: ... here.
12051         * bt-load.c (compute_out, link_btr_uses): Update for above changes.
12052         * gcse.c (compute_code_hoist_vbeinout): Likewise.
12053         * lcm.c (compute_antinout_edge, compute_available): Likewise.
12054         * Makefile.in: Fix sbitmap.o dependencies.
12055
12056 2012-07-23  Jan-Benedict Glaw  <jbglaw@lug-owl.de>
12057             Nick Clifton  <nickc@redhat.com>
12058
12059         * config/frv/frv-protos.h (frv_ifcvt_machdep_init): Prototype.
12060         * config/frv/frv.c (frv_ifcvt_machdep_init): Change type of
12061         (unused) parameter to void *.
12062
12063 2012-07-23  Richard Guenther  <rguenther@suse.de>
12064
12065         * tree-ssa-alias.c (dump_alias_info): Walk over local decls
12066         instead of referenced vars.
12067
12068 2012-07-23  Steven Bosscher  <steven@gcc.gnu.org>
12069
12070         * coverage.c: Refer to "notes file" instead of "graph file"
12071         in all comments.  Explain history of bbg prefix.
12072         * gcov-io.h: Likewise.
12073         * gcov.c: Likewise.
12074         (find_source): Likewise in fnotice.
12075         (read_graph_file): Likewise.
12076         (read_count_file): Likewise.
12077         * doc/gcov.texi: Document -fprofile-dir flag.  Add "notes file"
12078         and "data file" explicitly in the explanation of the files.
12079
12080 2012-07-22  Steven Bosscher  <steven@gcc.gnu.org>
12081
12082         PR tree-optimization/53881
12083         * tree-cfg.c (group_case_labels_stmt): Look up the basic block
12084         for each label and compare them instead of labels.
12085
12086 2012-07-22  Steven Bosscher <steven@gcc.gnu.org>
12087
12088         * opts.c (common_handle_option): Do not set
12089         flag_value_profile_transformations for -fprofile-generate.
12090         * profile.c (instrument_values): Use COUNTER_FOR_HIST_TYPE.
12091         (BB_TO_GCOV_INDEX): Remove.
12092         (output_location): Don't use it.
12093         (branch_prob): Likewise.  Don't fiddle with the index of
12094         ENTRY_BLOCK_PTR and EXIT_BLOCK_PTR.  Use clear_aux_for_blocks.
12095         (find_spanning_tree):
12096         * gcov.c (struct function_info): Document that blocks 0 and 1
12097         are the entry resp. exit blocks in gcov, too, like in GCC itself.
12098         (solve_flow_graph): Use ENTRY_BLOCK and EXIT_BLOCK for special
12099         blocks identification.
12100         (output_lines): Likewise.
12101         * value-prof.c (gimple_value_profile_transformations): Do not
12102         test flag_value_profile_transformations again.
12103         (gimple_ic_transform): Take a gimple_stmt_iterator like all other
12104         transformation functions.
12105         (gimple_values_to_profile):
12106         Don't test flag_value_profile_transformations
12107         * tree-profile.c (tree_profiling): Assert that the cgraph is in
12108         the CGRAPH_STATE_IPA_SSA state.
12109         Do not set, or look at, after_tree_profile.
12110         * function.h (struct function): Remove after_tree_profile bit.
12111         * omp-low.c (expand_omp_taskreg): Don't set after_tree_profile.
12112         * tree-inline.c (initialize_cfun): Don't copy it.
12113         * lto-streamer-out.c (output_struct_function_base): Don't stream it.
12114         * lto-streamer-in.c (input_struct_function_base): Likewise.
12115
12116 2012-07-22  Oleg Endo  <olegendo@gcc.gnu.org>
12117
12118         * config/sh/sh.h (TARGET_DYNSHIFT): New macro.
12119         (SH_DYNAMIC_SHIFT_COST): Use it.
12120         * config/sh/sh.c (expand_ashiftrt, shl_sext_kind): Likewise.
12121         (sh_dynamicalize_shift_p): Add TARGET_DYNSHIFT condition.
12122         Add sanity check for input value.  Add function description.
12123         * config/sh/sh.md (ashlsi3, ashlsi3_std, ashrsi3_d, lshrsi3,
12124         lshrsi3_d): Use TARGET_DYNSHIFT.
12125
12126 2012-07-22  Oleg Endo  <olegendo@gcc.gnu.org>
12127
12128         * config/sh/sh.md (negc): Delete expander.
12129         (*negc): Rename insn to negc.
12130
12131 2012-07-22  Uros Bizjak  <ubizjak@gmail.com>
12132
12133         PR target/53961
12134         * config/i386/i386.md (*lea): New insn pattern.
12135         (*lea_1): Remove.
12136         (*lea<mode>_2): Ditto.
12137         (*lea_{3,4,5,6}_zext): Ditto.
12138         * config/i386/predicates.md (lea_address_operand): Do not reject
12139         zero-extended address operands.
12140         * config/i386/constraints.md (j): Remove address constraint.
12141         * config/i386/i386.c (ix86_decompose_address): Allow SImode subreg
12142         of an address.
12143         (ix86_print_operand_address): Handle SImode subreg of an address.
12144         (ix86_avoid_lea_for_addr): Reject zero-extended addresses for now.
12145
12146 2012-07-22  Hans-Peter Nilsson  <hp@axis.com>
12147
12148         Emit executable-stack note correctly for CRIS targets.
12149         * config/cris/cris.c (cris_file_end): New function.
12150         (TARGET_ASM_FILE_END): Define.
12151
12152 2012-07-22  Chung-Lin Tang  <cltang@codesourcery.com>
12153             Maxim Kuvyrkov  <maxim@codesourcery.com>
12154             NetLogic Microsystems Inc.
12155
12156         * config/mips/mips.c (mips_issue_rate): Handle XLP.
12157         * config/mips/mips.md: Include xlp.md.
12158         * config/mips/xlp.md: New file.
12159
12160 2012-07-21  Steven Bosscher <steven@gcc.gnu.org>
12161
12162         PR gcov-profile/32543
12163         * profile.c (branch_prob): Update total_num_edges_instrumented and
12164         report the number of edges to instrument.
12165
12166 2012-07-21  Oleg Endo  <olegendo@gcc.gnu.org>
12167
12168         * config/sh/sh.md: Correct comment regarding clrt and sett insns.
12169
12170 2012-07-21  Andrew Pinski  <apinski@cavium.com>
12171
12172         * config/mips/mips.md (*popcountdi2_trunc): New pattern
12173         to handle popcount of a truncation.
12174
12175 2012-07-21  Andrew Pinski  <apinski@cavium.com>
12176
12177         * config/mips/mips-protos.h (mips_expand_ext_as_unaligned_load):
12178         Add a bool argument.
12179         * config/mips/mips.c (mips_block_move_straight): Update call to
12180         mips_expand_ext_as_unaligned_load.
12181         (mips_expand_ext_as_unaligned_load): Add unsigned_p argument.
12182         Accept DImode dest when the width is that of SImode.
12183         * config/mips/mips.md (extv): Update call to
12184         mips_expand_ext_as_unaligned_load.
12185         (extzv): Likewise.
12186
12187 2012-07-21  Andrew Pinski  <apinski@cavium.com>
12188
12189         * config/mips/mips.c (mips_get_unaligned_mem): Copy *op after calling
12190         adjust_address.
12191
12192 2012-07-20  Maxim Kuvyrkov  <maxim@codesourcery.com>
12193
12194         * config/mips/mips.md (define_attr sync_*): Move before "type".
12195         (define_attr "type"): New values "atomic" and "syncloop".
12196         * config/mips/sync.md (atomic_exchange<mode>, atomic_fetch_add<mode>):
12197         Set "type" attribute.
12198         * config/mips/generic.md (generic_atomic, generic_syncloop):
12199         New reservations.
12200         * gcc/config/mips/10000.md, gcc/config/mips/20kc.md,
12201         * gcc/config/mips/24k.md, gcc/config/mips/4130.md,
12202         * gcc/config/mips/4k.md, gcc/config/mips/5400.md,
12203         * gcc/config/mips/5500.md, gcc/config/mips/5k.md,
12204         * gcc/config/mips/7000.md, gcc/config/mips/74k.md,
12205         * gcc/config/mips/9000.md, gcc/config/mips/loongson2ef.md,
12206         * gcc/config/mips/loongson3a.md, gcc/config/mips/octeon.md,
12207         * gcc/config/mips/sb1.md, gcc/config/mips/sr71k.md,
12208         * gcc/config/mips/xlr.md: Handle "atomic" and "syncloop" types.
12209
12210 2012-07-20  Oleg Endo  <olegendo@gcc.gnu.org>
12211
12212         * config/sh/sh.md: Group and sort shift related patterns.
12213         (ashlsi3_n, *ashlhi3_n, lshrsi3_n): Remove length attributes.
12214
12215 2012-07-20  Hans-Peter Nilsson  <hp@axis.com>
12216
12217         * config/cris/cris.c (cris_asm_output_ident): Remove unused
12218         local variables section_asm_op, size, buf.
12219
12220 2012-07-20  Pat Haugen <pthaugen@us.ibm.com>
12221             Steven Bosscher  <steven@gcc.gnu.org>
12222
12223         * config/rs6000/power4.md (power4-store-update): Fix reservation.
12224         (power4-three): Likewise.
12225
12226 2012-07-20  Sameera Deshpande  <sameera.deshpande@arm.com>
12227             Greta Yorsh  <Greta.Yorsh@arm.com>
12228
12229         * config/arm/arm.c (arm_cortex_a15_tune): New tune.
12230         * config/arm/arm-cores.def (cortex-a15): Use it.
12231
12232 2012-07-20  Sameera Deshpande  <sameera.deshpande@arm.com>
12233             Greta Yorsh  <Greta.Yorsh@arm.com>
12234
12235         * config/arm/arm-protos.h (tune_params): Add prefer_ldrd_strd.
12236         * config/arm/arm.c (arm_slowmul_tune): Initialize it.
12237         (arm_fastmul_tune, arm_strongarm_tune): Likewise.
12238         (arm_xscale_tune, arm_9e_tune, arm_v6t2_tune): Likewise.
12239         (arm_cortex_tune, arm_cortex_a5_tune, arm_cortex_a9_tune): Likewise.
12240         (arm_fa726te_tune): Likewise.
12241
12242 2012-07-20  Richard Guenther  <rguenther@suse.de>
12243
12244         * tree-dfa.c (collect_dfa_stats): Simplify.
12245         * tree-ssa-structalias.c (compute_may_aliases): Do not dump
12246         referenced vars.
12247         * cfgexpand.c (estimated_stack_frame_size): Walk over local
12248         decls instead of referenced vars.
12249         * tree-ssa.c (delete_tree_ssa): Simplify.
12250         * tree-tailcall.c (find_tail_calls): Walk over local decls
12251         instead of referenced vars.
12252         (add_virtual_phis): Remove.
12253         (tree_optimize_tail_calls_1): Instead mark the virtual operand
12254         for renaming.
12255
12256 2012-07-20  Steven Bosscher  <steven@gcc.gnu.org>
12257
12258         * basic-block.h (BB_FLAGS_TO_PRESERVE): New define.
12259         (brief_dump_cfg): Update prototype to take flags argument.
12260         (check_bb_profile): Remove prototype.
12261         * tracer.c (tracer): Update brief_dump_cfg calls.
12262         * cfghooks.c (dump_bb): Do not pass TDF_COMMENT to dump_bb_info.
12263         Call dump_bb_info before and after the cfghook dump_bb.  Terminate
12264         the dump with a newline.
12265         (dump_flow_info): Do not call check_bb_profile.
12266         * cfg.c (clear_bb_flags): Update using BB_FLAGS_TO_PRESERVE.
12267         (check_bb_profile): Make static.  Take indent and flags arguments.
12268         (dump_bb_info): Always dump loop depth.  With TDF_DETAILS, call
12269         check_bb_profile.  Print one edge per line.
12270         (brief_dump_cfg): Take a flags argument, and filter out
12271         TDF_COMMENT and TDF_DETAILS.
12272         * pretty-print.c (pp_base_newline): Set pp_needs_newline to false.
12273         * gimple-pretty-print.c (dump_gimple_bb_header): Do not use
12274         dump_bb_info here, it is already called from dump_bb.  Idem for
12275         check_bb_profile.
12276         (dump_gimple_bb_footer): Likewise.
12277         (gimple_dump_bb_buff): Call pp_flush after dump_gimple_stmt to
12278         avoid broken dumps for statement histograms.
12279         (gimple_dump_bb): Handle ENTRY_BLOCK and EXIT_BLOCK.  Do
12280         not call pp_flush here, the buffer should be empty.
12281         * sched-rgn.c (debug_region): Pass TDF_BLOCKS to dump_bb.
12282         * sched-vis.c (debug_bb_slim): Likewise.
12283         * tree-cfg.c (remove_bb): Pass dump_flags to dump_bb.
12284         (gimple_debug_bb): Pass TDF_BLOCKS to dump_bb.
12285         (gimple_dump_cfg): Do brief_dump_cfg with TDF_COMMENT.
12286         (dump_function_to_file): Do not call check_bb_profile on
12287         ENTRY_BLOCK and EXIT_BLOCK, check_bb_profile doesn't handle them.
12288         Use dump_bb instead of gimple_dump_bb.
12289         (print_loops_bb): Use dump_bb instead of gimple_dump_bb.
12290         * passes.c (execute_function_dump): Always call print_rtl_with_bb
12291         for RTL dumps.
12292         * cfgrtl.c (print_rtl_with_bb): Handle printing without an up-to-date
12293         CFG.  With TDF_BLOCKS and TDF_DETAILS, do DF dumps at the top and
12294         bottom of each basic block.
12295
12296 2012-07-20  Richard Guenther  <rguenther@suse.de>
12297
12298         PR tree-optimization/54031
12299         * tree-ssa-ccp.c (get_value_from_alignment): Use
12300         get_pointer_alignment_1.
12301
12302 2012-07-20  Richard Guenther  <rguenther@suse.de>
12303
12304         * tree-inline.c (add_local_variables): Remove check_var_ann
12305         parameter and dead code.
12306         (expand_call_inline): Adjust.
12307         (tree_function_versioning): Likewise.
12308
12309 2012-07-20  Jakub Jelinek  <jakub@redhat.com>
12310
12311         PR c++/28656
12312         * tree-vrp.c (nonnull_arg_p): Handle all nonnull attributes instead
12313         of just the first one.
12314
12315 2012-07-20  Richard Guenther  <rguenther@suse.de>
12316
12317         * builtins.c (get_object_alignment_2): Correct offset handling
12318         when using type alignment of a MEM_REF kind base.
12319
12320 2012-07-20  Kirill Yukhin  <kirill.yukhin@intel.com>
12321
12322         PR target/53877
12323         * config/i386/lzcntintrin.h (_lzcnt_u32): New.
12324         (_lzcnt_u64): Ditto.
12325
12326 2012-07-19  Eric Botcazou  <ebotcazou@adacore.com>
12327
12328         * config/sparc/sparc.md (adddi3_insn_sp32): Add earlyclobber.
12329
12330 2012-07-19  Eric Botcazou  <ebotcazou@adacore.com>
12331
12332         * tree-ssa-forwprop.c (combine_conversions): Punt if the RHS of the
12333         defining statement is a SSA name that occurs in abnormal PHIs.
12334
12335 2012-07-19  Eric Botcazou  <ebotcazou@adacore.com>
12336
12337         * gimple-fold.c (canonicalize_constructor_val): Strip only useless type
12338         conversions.
12339
12340 2012-07-19  Jakub Jelinek  <jakub@redhat.com>
12341
12342         PR rtl-optimization/53942
12343         * function.c (assign_parm_setup_reg): Avoid zero/sign extension
12344         directly from likely spilled non-fixed hard registers, move them
12345         to pseudo first.
12346
12347 2012-07-19  Steve Ellcey  <sellcey@mips.com>
12348
12349         * config/mips/mips.c (mips_set_mips16_mode): Clear SYNCI_MASK in
12350         MIPS16 mode.
12351
12352 2012-07-19  Jason Merrill  <jason@redhat.com>
12353
12354         PR debug/53235
12355         * dwarf2out.c (get_die_parent): New.
12356         (generate_type_signature): Use it.
12357
12358 2012-07-19  Richard Henderson  <rth@redhat.com>
12359
12360         * config/ia64/vect.md (smulv4hi3_highpart): New.
12361         (umulv4hi3_highpart): New.
12362         (vec_widen_smult_even_v4hi): Rename from pmpy2_even.
12363         (vec_widen_smult_odd_v4hi): Rename from pmpy2_odd.
12364         (udot_prodv8qi, sdot_prodv8qi): Remove.
12365         (sdot_prodv4hi, udot_prodv4hi): Remove.
12366         * config/ia64/ia64.c (ia64_expand_dot_prod_v8qi): Remove.
12367         * config/ia64/ia64-protos.h: Update.
12368
12369         * tree-vect-patterns.c (vect_recog_divmod_pattern): Do not require
12370         vectors larger than UNITS_PER_WORD.
12371
12372         * expr.c (store_constructor): Initialize icode with CODE_FOR_nothing.
12373         * tree-vect-stmts.c (vectorizable_operation): Use LAST_INSN_CODE for
12374         dummy != CODE_FOR_nothing value.
12375
12376 2012-07-19  Uros Bizjak  <ubizjak@gmail.com>
12377
12378         * doc/tm.texi.in (MODE_AFTER): Add entity as the first macro argument.
12379         * doc/tm.texi: Regenerate.
12380         * mode-switching.c (optimize_mode_switching): Update MODE_AFTER call.
12381         * config/sh/sh.h (MODE_AFTER): Update.
12382         * config/epiphany/epiphany.h (MODE_AFTER): Update.
12383
12384 2012-07-19  Jakub Jelinek  <jakub@redhat.com>
12385
12386         PR middle-end/54017
12387         * tree-cfgcleanup.c (cleanup_omp_return): Remove.
12388         (cleanup_tree_cfg_bb): Don't call it.
12389         * omp-low.c (expand_omp_sections): Fix up the !exit_reachable case
12390         handling.
12391
12392 2012-07-19  Christian Bruel  <christian.bruel@st.com>
12393
12394         PR target/54029
12395         * config/sh/sh.c (gen_far_branch): Set JUMP_LABEL for return jumps.
12396
12397 2012-07-19  Richard Guenther  <rguenther@suse.de>
12398             Eric Botcazou  <ebotcazou@adacore.com>
12399
12400         * tree-ssa-ccp.c (valid_lattice_transition): Clarify comment
12401         about transition from invariant to known bits.
12402         (likely_value): Addresses with UNDEFINED components are UNDEFINED.
12403
12404 2012-07-19  Richard Guenther  <rguenther@suse.de>
12405
12406         PR tree-optimization/53970
12407         * tree-vect-data-refs.c (not_size_aligned): Avoid sign-compare warning.
12408
12409 2012-07-19  Tristan Gingold  <gingold@adacore.com>
12410             Richard Henderson  <rth@redhat.com>
12411
12412         * opts.c (finish_options): Handle UI_SEH.
12413         * expr.c (build_personality_function): Handle UI_SEH.
12414         * dwarf2out.c (dwarf2out_begin_prologue): Handle UI_SEH.
12415         * coretypes.h (unwind_info_type): Add UI_SEH.
12416         * config/i386/winnt.c (i386_pe_seh_emit_except_personality):
12417         New function.
12418         (i386_pe_seh_init_sections): Likewise.
12419         * config/i386/cygming.h (TARGET_ASM_EMIT_EXCEPT_PERSONALITY): Define.
12420         (TARGET_ASM_INIT_SECTIONS): Define.
12421         * common/config/i386/i386-common.c (TARGET_EXCEPT_UNWIND_INFO): Define.
12422         (i386_except_unwind_info): New function.
12423
12424 2012-07-18  Maciej W. Rozycki  <macro@codesourcery.com>
12425             Chao-ying Fu  <fu@mips.com>
12426
12427         * config/mips/mips.opt (mmcu): New option.
12428         * config/mips/mips.h (TARGET_CPU_CPP_BUILTINS): Define
12429         _mips_mcu when TARGET_MCU.
12430         (ASM_SPEC): Pass mcu options to the assembler.
12431         * doc/invoke.texi (MIPS Options): Document -mmcu and -mno-mcu.
12432
12433 2012-07-18  Ralf Corsépius  <ralf.corsepius@rtems.org>
12434
12435         * config.gcc (v850-*-rtems*): New target.
12436         * config/v850/rtems.h: New.
12437         * config/v850/t-rtems: New.
12438
12439 2012-07-18  Bill Schmidt  <wschmidt@linux.ibm.com>
12440
12441         * doc/invoke.texi: Add -fhoist-adjacent-loads and -ftree-slsr to list
12442         of flags controlling optimization; add -ftree-slsr to list of flags
12443         enabled by default at -O; add -fhoist-adjacent-loads to list of flags
12444         enabled by default at -O2; add -fvect-cost-model to list of flags
12445         enabled by default at -O3; document -fhoist-adjacent-loads and
12446         -ftree-slsr.
12447         * opts.c (default_option): Make -ftree-slsr default at -O1 and above.
12448         * gimple-ssa-strength-reduction.c (gate_strength_reduction): Use
12449         flag_tree_slsr.
12450         * common.opt: Add -ftree-slsr with flag_tree_slsr.
12451
12452 2012-07-18  Jie Zhang  <jzhang918@gmail.com>
12453             Julian Brown  <julian@codesourcery.com>
12454
12455         * config/arm/arm.c (arm_rtx_costs_1): Adjust cost for CONST_VECTOR.
12456         (arm_size_rtx_costs): Likewise.
12457         (neon_valid_immediate): Add a case for double 0.0.
12458
12459 2012-07-18  Andrew Stubbs  <ams@codesourcery.com>
12460             Mark Shinwell  <shinwell@codesourcery.com>
12461             Julian Brown  <julian@codesourcery.com>
12462
12463         * config/arm/vfp.md (*arm_movsi_vfp, *thumb2_movsi_vfp)
12464         (*movdi_vfp_cortexa8, *movsf_vfp, *thumb2_movsf_vfp)
12465         (*movdf_vfp, *thumb2_movdf_vfp, *movsfcc_vfp)
12466         (*thumb2_movsfcc_vfp, *movdfcc_vfp, *thumb2_movdfcc_vfp): Add
12467         neon_type.
12468         * config/arm/arm.md (neon_type): Update comment.
12469
12470 2012-07-18  Richard Guenther  <rguenther@suse.de>
12471
12472         PR tree-optimization/53970
12473         * tree.h (contains_packed_reference): Remove.
12474         * expr.c (contains_packed_reference): Likewise.
12475         * tree-vect-data-refs.c (not_size_aligned): New function.
12476         (vector_alignment_reachable_p): Use it.
12477         (vect_supportable_dr_alignment): Likewise.
12478
12479 2012-07-18  Richard Guenther  <rguenther@suse.de>
12480
12481         * tree.h (get_object_or_type_alignment): Remove.
12482         * builtins.c (get_object_alignment_2): New function copied from
12483         get_object_alignment_1.  Take extra argument to indicate whether
12484         we take the address of EXP.  Rework to use type alignment information
12485         if not, and return whether the result is an approximation or not.
12486         (get_object_alignment_1): Wrap around get_object_alignment_2.
12487         (get_pointer_alignment_1): Call get_object_alignment_2 indicating
12488         we take the address.
12489         (get_object_or_type_alignment): Remove.
12490         * expr.c (expand_assignment): Call get_object_alignment.
12491         (expand_expr_real_1): Likewise.
12492
12493 2012-07-18  Nick Clifton  <nickc@redhat.com>
12494
12495         * doc/invoke.texi (ARM Options): Document -munaligned-access.
12496
12497 2012-07-18  Oleg Endo  <olegendo@gcc.gnu.org>
12498
12499         * config/sh/sh.md (mulsidi3, umulsidi3): Remove constraints in
12500         expander.  Use arith_reg_dest predicate.
12501         (rotldi3, rotrdi3): Remove constraints in expander.
12502         (adddi3_compact, subdi3_compact, mulsidi3_compact, umulsidi3_compact,
12503         ashlsi3_n, *ashlhi3_n, ashrsi2_16, ashrsi2_31, lshrsi3_n): Convert to
12504         insn_and_split.
12505
12506 2012-07-18  Oleg Endo  <olegendo@gcc.gnu.org>
12507
12508         PR target/33135
12509         * config/sh/sh.opt (mieee): Use Var instead of Mask.  Correct
12510         description.
12511         * config/sh/sh.c (sh_option_override): Do not change
12512         flag_finite_math_only.  Set TARGET_IEEE to complement of
12513         flag_finite_math_only.
12514         * doc/invoke.texi (SH options): Add mno-ieee.  Correct description
12515         of mieee and mno-ieee behavior.
12516
12517 2012-07-18  Steven Bosscher  <steven@gcc.gnu.org>
12518
12519         * graphite-poly.c (print_pbb_body): Fixup dump_bb call.
12520
12521 2012-07-18  Steven Bosscher  <steven@gcc.gnu.org>
12522
12523         * dumpfile.h (TDF_COMMENT): New define.
12524         * basic-block.h (EDGE_FALLTHRU, EDGE_ABNORMAL, EDGE_ABNORMAL_CALL,
12525         EDGE_EH, EDGE_FAKE, EDGE_DFS_BACK, EDGE_CAN_FALLTHRU,
12526         EDGE_IRREDUCIBLE_LOOP, EDGE_SIBCALL, EDGE_LOOP_EXIT, EDGE_TRUE_VALUE,
12527         EDGE_FALSE_VALUE, EDGE_EXECUTABLE, EDGE_CROSSING, EDGE_PRESERVE):
12528         Move to new file cfg-flags.h.
12529         (enum cfg_edge_flags): New enum, using cfg-flags.h.
12530         (EDGE_ALL_FLAGS): Compute value automatically.
12531         (BB_NEW, BB_REACHABLE, BB_IRREDUCIBLE_LOOP, BB_SUPERBLOCK,
12532         BB_DISABLE_SCHEDULE, BB_HOT_PARTITION, BB_COLD_PARTITION,
12533         BB_DUPLICATED, BB_NON_LOCAL_GOTO_TARGET, BB_RTL,
12534         BB_FORWARDER_BLOCK, BB_NONTHREADABLE_BLOCK, BB_MODIFIED, BB_VISITED,
12535         BB_IN_TRANSACTION): Move to new file cfg-flags.h.
12536         (enum bb_flags): Rename to cfg_bb_flags.  Use cfg-flags.h.
12537         (BB_ALL_FLAGS): New, compute value automatically.
12538         (dump_bb_info): Update prototype.
12539         (dump_edge_info): Update prototype.
12540         * cfg-flags.h: New file.
12541         * cfg.c (dump_edge_info): Take flags argument.  Be verbose only if
12542         TDF_DETAILS and not TDF_SLIM.  Include cfg-flags.h for bitnames.
12543         Check that the edge flags are within the range of EDGE_ALL_FLAGS.
12544         (debug_bb): Update dump_bb call.
12545         (dump_cfg_bb_info): Remove.
12546         (dump_bb_info): New function.  Use cfg-flags.h for bitnames.
12547         Adjust verbosity using TDF_* flags.  Check that the basic block flags
12548         are within the range of BB_ALL_FLAGS.
12549         (brief_dump_cfg): Use dump_bb_info instead of dump_cfg_bb_info.
12550         * cfghooks.h (struct cfghooks): Update dump_bb hook, take a FILE
12551         first for consistency with other dump functions.
12552         (dump_bb): Update prototype accordingly.
12553         * cfghooks.c: Include dumpfile.h.
12554         (verify_flow_info): Update dump_edge_info calls.
12555         (dump_bb): Take a flags argument and pass it around.
12556         Use dump_bb_info to dump common information about a basic block.
12557         (dump_flow_info): Moved here from cfgrtl.c.  Make IL agnostic.
12558         (debug_flow_info): Moved here from cfgrtl.c.
12559         * profile.c (is_edge_inconsistent): Update dump_bb calls.
12560         * loop-invariant.c (find_defs): Update print_rtl_with_bb call.
12561         * rtl.h (debug_bb_n_slim, debug_bb_slim, print_rtl_slim,
12562         print_rtl_slim_with_bb): Remove prototypes.
12563         (dump_insn_slim): Adjust prototype to take a const_rtx.
12564         (print_rtl_with_bb): Adjust prototype.
12565         * sched-rgn.c (debug_region): Use dump_bb instead of debug_bb_n_slim.
12566         * sched-vis.c (dump_insn_slim): Take a const_rtx.
12567         (debug_insn_slim): Prototype here near DEBUG_FUNCTION marker.
12568         (print_rtl_slim_with_bb): Remove.
12569         (print_rtl_slim): Rename to debug_rtl_slim.  Print only insn info,
12570         not basic block info (print_rtl_with_bb with TDF_SLIM should be used
12571         for that.  Prototype here near DEBUG_FUNCTION marker.
12572         (debug_bb_slim): Prototype here near DEBUG_FUNCTION marker.
12573         Use dump_bb.
12574         (debug_bb_n_slim): Prototype here near DEBUG_FUNCTION marker.
12575         * tree-cfg.c (gimple_can_merge_blocks_p): Use EDGE_COMPLEX.
12576         (remove_bb): Update dump_bb call.
12577         (gimple_debug_bb): Use dump_bb.
12578         (dump_function_to_file): Update gimple_dump_bb call.
12579         (print_loops_bb): Likewise.
12580         * tree-flow.h (gimple_dump_bb): Update prototype.
12581         * gimple-pretty-print.c (dump_bb_header): Rename to
12582         dump_gimple_bb_header.  Write to a stream instead of a pretty
12583         printer.  Use dump_bb_info to dump basic block info.
12584         (dump_bb_end): Rename to dump_gimple_bb_footer.  Write to a
12585         stream instead of a pretty printer.  Use dump_bb_info.
12586         (gimple_dump_bb_buff): Do not call dump_bb_header and dump_bb_end.
12587         (gimple_dump_bb): Do it here with dump_gimple_bb_header and
12588         dump_gimple_bb_footer.
12589         * cfgrtl.c (rtl_dump_bb): Update prototype.  Only dump DF if the
12590         dump flags have TDF_DETAILS.  Use dump_insn_slim if TDF_SLIM.
12591         (print_rtl_with_bb): Take a flags argument and pass it around.
12592         Use dump_insn_slim if TDF_SLIM.
12593         (dump_bb_info): Removed and re-incarnated in cfg.c.
12594         (dump_flow_info): Moved to cfghooks.c.
12595         (debug_flow_info): Moved to cfghooks.c.
12596         * passes.c (execute_function_dump): Unconditionally use
12597         print_rtl_with_bb for RTL dumps, now that it understands TDF_SLIM.
12598         * final.c (dump_basic_block_info): Update dump_edge_info calls.
12599         * tree-vrp.c (dump_asserts_for): Likewise.
12600         * ifcvt.c (if_convert): Unconditionally use print_rtl_with_bb.
12601         * tree-if-conv.c (if_convertible_bb_p): Don't look at
12602         EDGE_ABNORMAL_CALL, it has no meaning in the GIMPLE world.
12603         * trans-mem.c (make_tm_edge): Don't set EDGE_ABNORMAL_CALL,
12604         for the same reason.
12605         * config/rl78/rl78.c (rl78_reorg): Update print_rtl_with_bb calls.
12606
12607 2012-07-17  Richard Guenther  <rguenther@suse.de>
12608
12609         * tree-vect-data-refs.c (vect_get_new_vect_var): Add referenced
12610         vars here, use create_tmp_reg where appropriate.
12611         (vect_create_addr_base_for_vector_ref): Do not add referenced
12612         vars here, use create_tmp_reg where appropriate.
12613         (vect_create_data_ref_ptr): Likewise.
12614         (vect_create_destination_var): Likewise.
12615         (vect_permute_store_chain): Likewise.
12616         (vect_permute_load_chain): Likewise.
12617         * tree-vect-loop-manip.c (vect_create_cond_for_align_checks):
12618         Likewise.
12619         * tree-vect-loop.c (get_initial_def_for_induction): Likewise.
12620         * tree-vect-patterns.c (vect_recog_temp_ssa_var): Likewise.
12621         (vect_handle_widen_op_by_const): Likewise.
12622         * tree-vect-stmts.c (vect_init_vector): Likewise.
12623         (vectorizable_load): Likewise.
12624
12625 2012-07-17  Tom de Vries  <tom@codesourcery.com>
12626
12627         * hwint.c: Fix loop range.
12628
12629 2012-07-17  Tom de Vries  <tom@codesourcery.com>
12630
12631         * double-int.h (double_int_popcount): New inline function.
12632         * hwint.c (popcount_hwi): New function.
12633         * hwint.h (popcount_hwi): Declare function.  New inline function.
12634
12635 2012-07-17  Richard Henderson  <rth@redhat.com>
12636
12637         * tree-vect-stmts.c (supportable_widening_operation): Remove decl
12638         parameters.
12639         (vectorizable_conversion): Update supportable_widening_operation call.
12640         * tree-vect-patterns.c (vect_recog_widen_mult_pattern): Likewise.
12641         (vect_recog_widen_shift_pattern): Likewise.
12642         * tree-vectorizer.h: Update decl.
12643
12644 2012-07-17  Ramana Radhakrishnan  <ramana.radhakrishnan@linaro.org>
12645             Ulrich Weigand  <ulrich.weigand@linaro.org>
12646
12647         * common/config/arm/arm-common.c (arm_option_optimization_table):
12648         Enable -fsched-pressure by default while optimizing.
12649         * config/arm/arm.c (arm_option_override): Use the alternate scheduler
12650         pressure algorithm by default.
12651
12652 2012-07-16  Oleg Endo  <olegendo@gcc.gnu.org>
12653
12654         * config/sh/sh.h (CONST_OK_FOR_I06): Delete.
12655         (CONST_OK_FOR_I10): Move macro to ...
12656         * config/sh/sh.c: ... here.
12657         (sh_legitimate_index_p): Use satisfies_constraint_I06 instead of
12658         CONST_OK_FOR_I06.
12659
12660 2012-07-16  Oleg Endo  <olegendo@gcc.gnu.org>
12661
12662         * config/sh/sh.md: Delete mov related define_peephole patterns.
12663
12664 2012-07-16  Jonathan Wakely  <jwakely.gcc@gmail.com>
12665
12666         PR c++/53919
12667         * doc/install.texi (Installing GCC): Refer to instructions for
12668         released versions. Fix hyphenation.
12669
12670 2012-07-16  Ulrich Weigand  <Ulrich.Weigand@de.ibm.com>
12671
12672         * config/spu/spu.c (targetm): Move to bottom of file.
12673         (spu_attribute_table): Likewise.
12674         (spu_option_override, spu_init_builtins, spu_builtin_decl,
12675         spu_scalar_mode_supported_p, spu_vector_mode_supported_p,
12676         spu_legitimate_address_p, spu_addr_space_legitimate_address_p,
12677         adjust_operand, get_pic_reg, need_to_save_reg, frame_emit_store,
12678         frame_emit_load, frame_emit_add_imm, emit_nop_for_insn,
12679         insn_clobbers_hbr, spu_emit_branch_hint, spu_emit_vector_compare,
12680         get_branch_target, spu_machine_dependent_reorg, spu_sched_issue_rate,
12681         spu_sched_variable_issue, spu_sched_adjust_cost, spu_sched_init_global,
12682         spu_sched_init, spu_sched_reorder, spu_handle_fndecl_attribute,
12683         spu_handle_vector_attribute, spu_pass_by_reference, spu_function_arg,
12684         spu_function_arg_advance, spu_build_builtin_va_list, spu_va_start,
12685         spu_gimplify_va_arg_expr, store_with_one_insn_p, reg_aligned_for_addr,
12686         spu_assemble_integer, spu_asm_globalize_label, spu_rtx_costs,
12687         spu_function_ok_for_sibcall, spu_init_libfuncs, spu_return_in_memory,
12688         spu_encode_section_info, spu_legitimize_address,
12689         spu_addr_space_legitimize_address, spu_builtin_mask_for_load,
12690         spu_builtin_vectorization_cost, spu_vector_alignment_reachable,
12691         spu_addr_space_pointer_mode, spu_addr_space_address_mode,
12692         spu_addr_space_subset_p, spu_addr_space_convert, spu_sms_res_mii,
12693         spu_section_type_flags, spu_select_section, spu_unique_section,
12694         spu_trampoline_init, spu_conditional_register_usage,
12695         spu_ref_may_alias_errno, spu_output_mi_thunk, spu_unwind_word_mode,
12696         spu_libgcc_cmp_return_mode, spu_libgcc_shift_count_mode,
12697         spu_setup_incoming_varargs): Remove prototypes.
12698         (spu_legitimize_address): Add "static" to definition.
12699
12700 2012-07-16  Jakub Jelinek  <jakub@redhat.com>
12701
12702         * config/i386/rtmintrin.h (_xabort): Remove trailing semicolon.
12703
12704 2012-07-16  Ulrich Weigand  <ulrich.weigand@linaro.org>
12705
12706         * tree-ssa-ccp.c (optimize_unreachable): Check gsi_end_p
12707         before calling gsi_stmt.
12708
12709 2012-07-16  Kirill Yukhin  <kirill.yukhin@intel.com>
12710
12711         Revert
12712         2012-07-16 Sergey Melnikov <sergey.melnikov@intel.com>
12713
12714         * config/i386/i386.md (stack_protect_set): Disable the pattern
12715         for Android since Android libc (bionic) does not provide random
12716         value for stack protection guard at gs:0x14. Guard value
12717         will be provided from external symbol (default implementation).
12718         (stack_protect_set_<mode>): Likewise.
12719         (stack_protect_test): Likewise.
12720         (stack_protect_test_<mode>): Likewise.
12721
12722 2012-07-16  H.J. Lu  <hongjiu.lu@intel.com>
12723
12724         PR middle-end/53959
12725         PR bootstrap/53963
12726         * gimple.c (gimple_types_compatible_p_1): Restore type attribute
12727         comparison.
12728
12729 2012-07-16  Bill Schmidt  <wschmidt@linux.ibm.com>
12730
12731         * opts.c (default_option): Add -fvect-cost-model to default options
12732         at -O3 and above.
12733
12734 2012-07-16  Steven Bosscher  <steven@gcc.gnu.org>
12735
12736         * graphite-clast-to-gimple.c, graphite-dependences.c,
12737         graphite-sese-to-poly.c: Include tree-pass.h instead of dumpfile.h
12738         for pass TODO flags.
12739         * Makefile.in: Fix dependencies.
12740
12741 2012-07-16  Steven Bosscher  <steven@gcc.gnu.org>
12742
12743         * haifa-sched.c (init_before_recovery): Do not set EDGE_CAN_FALLTHRU.
12744         * cfgrtl.c (force_nonfallthru_and_redirect): Likewise.
12745
12746         * function.c (stack_protect_epilogue): Use expand_call to expand
12747         targetm.stack_protect_fail.
12748         * stmt.c (expand_expr_stmt): Remove now-unused function.
12749         * tree.h (expand_expr_stmt): Remove prototype.
12750         * doc/tm.texi.in (TARGET_STACK_PROTECT_FAIL): Document that this
12751         hook must return a CALL_EXPR.
12752         * doc/tm.texi: Regenerate.
12753
12754         * emit-rtl.c (emit_label_before): Do not allow the same label
12755         to be emitted twice.
12756         (emit_label_after): Likewise.
12757         (emit_label): Likewise.
12758
12759         * flags.h (TYPE_OVERFLOW_WRAPS, TYPE_OVERFLOW_UNDEFINED,
12760         TYPE_OVERFLOW_TRAPS, POINTER_TYPE_OVERFLOW_UNDEFINED): Move to tree.h.
12761         * tree.h (TYPE_OVERFLOW_WRAPS, TYPE_OVERFLOW_UNDEFINED,
12762         TYPE_OVERFLOW_TRAPS, POINTER_TYPE_OVERFLOW_UNDEFINED): New home.
12763
12764 2012-07-16  Steven Bosscher  <steven@gcc.gnu.org>
12765
12766         * system.h (dump_file): Do not define.
12767         * tree-pass.h: Include dumpfile.h, which is a new file containing...
12768         (enum tree_dump_index, TDF_*, get_dump_file_name, dump_enabled_p,
12769         dump_initialized_p, dump_begin, dump_end, dump_node, dump_switch_p,
12770         dump_flag_name, dump_file, dump_flags, dump_file_name,
12771         get_dump_file_info, struct dump_file_info): all of this, moved to...
12772         * dumpfile.h: Here, new file.
12773         * tree-dump.h: Include dumpfile.h, but not tree-pass.h.
12774         (dump_stmt): Remove prototype for C++ specific function.
12775         (dump_enumerated_decls): Move prototype from here...
12776         * tree-flow.h (dump_enumerated_decls): ... to here.
12777         (get_ref_base_and_extent) Move prototype from here ...
12778         * tree.h (get_ref_base_and_extent) ... to here.
12779         * tree-ssa-live.c: Do not inclde tree-pretty-print.h, because
12780         gimple-pretty-print.h is enough.  Do not include tree-dump.h,
12781         include timevar.h and dumpfile.h instead.
12782         (struct numbered_tree_d, compare_decls_by_uid,
12783         dump_enumerated_decls_push, dump_enumerated_decls): Move from here ...
12784         * tree-dfa.c:(struct numbered_tree_d, compare_decls_by_uid,
12785         dump_enumerated_decls_push, dump_enumerated_decls):... to here.
12786         Do not include timevar.h.
12787         * tree.c: Do not include timevar.h.
12788         * tree-cfg.c: Do not include langhooks.h, tree-pretty-print.h, and
12789         timevar.h.
12790         (dump_cfg_stats): Use current_function_name.
12791         (gimple_cfg2vcg): Likewise.
12792         (dump_function_to_file): Likewise.
12793         * df-scan.c: Do not include tree-pass.h and timevar.h.
12794         Include dumpfile.h.
12795         (df_entry_block_bitmap_verify, df_exit_block_bitmap_verify): Do not
12796         use print_current_pass.
12797         * df-problems.c: Include dumpfile.h.
12798         Always define REG_DEAD_DEBUGGING, avoid #ifdef code, because it
12799         leads to errors in the code not selected.
12800         (df_note_compute): Do not print_rtl_with_bb here.  Fix compilation
12801         bug if REG_DEAD_DEBUGGING is not 0, get_insns is not available here.
12802         * lcm.c: Include dumpfile.h.
12803         Remove obsolete include of insn-attr.h.
12804         * dojump.c (do_compare_rtx_and_jump): Remove failure printing for
12805         missing probability notes.
12806         * stmt.c: Include dumpfile.h.
12807         (emit_case_decision_tree): Re-enable printing expand details only
12808         if TDF_DETAILS.
12809         * alias.c, auto-inc-dec.c, bb-reorder.c, caller-save.c, cfg.c,
12810         cfgcleanup.c, cfgexpand.c, cfgloop.c, cfgloopmanip.c, cgraph.c,
12811         cgraphclones.c, cgraphunit.c, combine.c, combine-stack-adj.c,
12812         coverage.c, cprop.c, cse.c, cselib.c, dbgcnt.c, dce.c, df-core.c,
12813         dse.c, dwarf2out.c, emit-rtl.c, except.c, expr.c, final.c,
12814         function.c, fwprop.c, gcse.c, gimple-fold.c,
12815         gimple-pretty-print.c, gimple-ssa-strength-reduction.c,
12816         gimplify.c, graphite-blocking.c, graphite-clast-to-gimple.c,
12817         graphite-dependences.c, graphite-interchange.c,
12818         graphite-optimize-isl.c, graphite-poly.c,
12819         graphite-sese-to-poly.c, haifa-sched.c, hw-doloop.c, ifcvt.c,
12820         ipa.c, ipa-cp.c, ipa-inline-analysis.c, ipa-inline.c,
12821         ipa-inline-transform.c, ipa-prop.c, ipa-pure-const.c,
12822         ipa-reference.c, ipa-split.c, ipa-utils.c, ira.c, ira-emit.c,
12823         jump.c, loop-doloop.c, loop-init.c, loop-invariant.c, loop-iv.c,
12824         loop-unroll.c, loop-unswitch.c, lower-subreg.c,
12825         lto-section-out.c, lto-streamer-in.c, matrix-reorg.c, mcf.c,
12826         mode-switching.c, modulo-sched.c, omega.c, omp-low.c, passes.c,
12827         plugin.c, postreload.c, postreload-gcse.c, predict.c, print-rtl.c,
12828         print-tree.c, profile.c, recog.c, ree.c, regcprop.c, reginfo.c,
12829         regmove.c, regrename.c, reg-stack.c, reload1.c, reorg.c,
12830         sched-rgn.c, sched-vis.c, sel-sched.c, sel-sched-ir.c,
12831         store-motion.c, tracer.c, trans-mem.c, tree-affine.c,
12832         tree-call-cdce.c, tree-cfgcleanup.c, tree-chrec.c,
12833         tree-data-ref.c, tree-diagnostic.c, tree-dump.c,
12834         tree-eh.c, tree-flow-inline.h, tree-if-conv.c, tree-into-ssa.c,
12835         tree-mudflap.c, tree-nrv.c, tree-object-size.c,
12836         tree-optimize.c, tree-outof-ssa.c, tree-predcom.c,
12837         tree-pretty-print.c, tree-profile.c, tree-scalar-evolution.c,
12838         tree-sra.c, tree-ssa-address.c, tree-ssa-alias.c, tree-ssa.c,
12839         tree-ssa-ccp.c, tree-ssa-coalesce.c, tree-ssa-copy.c,
12840         tree-ssa-copyrename.c,, tree-ssa-dce.c, tree-ssa-dom.c,
12841         tree-ssa-dse.c, tree-ssa-forwprop.c, tree-ssa-ifcombine.c,
12842         tree-ssa-loop.c, tree-ssa-loop-ch.c, tree-ssa-loop-im.c,
12843         tree-ssa-loop-ivcanon.c, tree-ssa-loop-ivopts.c,
12844         tree-ssa-loop-manip.c, tree-ssa-loop-niter.c,
12845         tree-ssa-loop-prefetch.c, tree-ssa-loop-unswitch.c,
12846         tree-ssa-math-opts.c, tree-ssa-operands.c, tree-ssa-phiopt.c,
12847         tree-ssa-phiprop.c, tree-ssa-pre.c, tree-ssa-propagate.c,
12848         tree-ssa-reassoc.c, tree-ssa-sccvn.c, tree-ssa-sink.c,
12849         tree-ssa-structalias.c, tree-ssa-tail-merge.c, tree-ssa-ter.c,
12850         tree-ssa-threadedge.c, tree-ssa-threadupdate.c,
12851         tree-ssa-uncprop.c, tree-ssa-uninit.c,
12852         tree-switch-conversion.c, tree-tailcall.c,
12853         tree-vect-data-refs.c, tree-vect-loop.c,
12854         tree-vect-loop-manip.c, tree-vectorizer.c,
12855         tree-vect-patterns.c, tree-vect-slp.c, tree-vect-stmts.c,
12856         tree-vrp.c, value-prof.c, var-tracking.c, web.c: Include tree-pass.h
12857         only if needed.  If tree-pass.h is included, do not include timevar.h
12858         and dumpfile.h.  If tree-pass.h is not included but dump_file, or
12859         dump_flags, or the TDF_* flags are used, include dumpfile.h.
12860         If gimple-pretty-print.h is included, don't include
12861         tree-pretty-print.h.  Remove assorted unnecessary includes.
12862
12863         * config/mn10300/mn10300.c, config/c6x/c6x.c, config/ia64/ia64.c,
12864         config/arm/arm.c, config/bfin/bfin.c, config/frv/frv.c,
12865         config/spu/spu.c, config/mep/mep.c, config/i386/i386.c:
12866         Include dumpfile.h.
12867         * config/rl78/rl78.c: Include dumpfile.h instead of tree-pass.h.
12868         * arm/t-arm, avr/t-avr, i386/t-i386, ia64/t-ia64, mep/t-mep,
12869         spu/t-spu-elf: Fix dependencies.
12870
12871 2012-07-16  Dehao Chen  <dehao@google.com>
12872
12873         Revert
12874         2012-07-10  Dehao Chen  <dehao@google.com>
12875
12876         * tree.h (phi_arg_d): New field.
12877         * tree-flow-inline.h (gimple_phi_arg_block): New function.
12878         (gimple_phi_arg_block_from_edge): New function.
12879         (gimple_phi_arg_set_block): New function.
12880         (gimple_phi_arg_has_block): New function.
12881         (redirect_edge_var_map_block): New function.
12882         * tree-flow.h (_edge_var_map): New field.
12883         * tree-ssa-live.c (remove_unused_locals): Mark phi_arg's block as used.
12884         * tree-eh.c (cleanup_empty_eh_merge_phis): Add block debug info for
12885         redirect_edge_var_map_add.
12886         * tree-outof-ssa.c (_elim_graph): New field.
12887         (insert_partition_copy_on_edge): New parameter.
12888         (insert_value_copy_on_edge): New parameter.
12889         (insert_rtx_to_part_on_edge): New parameter.
12890         (insert_part_to_rtx_on_edge): New parameter.
12891         (elim_graph_add_edge): New parameter.
12892         (elim_graph_remove_succ_edge): New parameter.
12893         (FOR_EACH_ELIM_GRAPH_SUCC): New parameter.
12894         (FOR_EACH_ELIM_GRAPH_PRED): New parameter.
12895         (new_elim_graph): Add block debug info.
12896         (clear_elim_graph): Likewise.
12897         (delete_elim_graph): Likewise.
12898         (elim_graph_add_node): Likewise.
12899         (elim_graph_add_edge): Likewise.
12900         (elim_graph_remove_succ_edge): Likewise.
12901         (eliminate_build): Likewise.
12902         (elim_forward): Likewise.
12903         (elim_unvisited_predecessor): Likewise.
12904         (elim_backward): Likewise.
12905         (elim_create): Likewise.
12906         (eliminate_phi): Likewise.
12907         (insert_backedge_copies): Likewise.
12908         * tree-into-ssa.c (insert_phi_nodes_for): Add block debug info for
12909         add_phi_arg.
12910         (rewrite_add_phi_arguments): Likewise.
12911         * tree-ssa-loop-im.c (execute_sm_if_changed): Likewise.
12912         * tree-ssa-tail-merge.c (replace_block_by): Likewise.
12913         * tree-ssa-threadupdate.c (copy_phi_args): Likewise.
12914         * tree-loop-distribution.c (update_phis_for_loop_copy): Likewise.
12915         * tree-ssa-loop-manip.c (create_iv): Likewise.
12916         (add_exit_phis_edge): Likewise.
12917         (split_loop_exit_edge): Likewise.
12918         (copy_phi_node_args): Likewise.
12919         (tree_transform_and_unroll_loop): Likewise.
12920         * value-prof.c (gimple_ic): Likewise.
12921         (gimple_stringop_fixed_value): Likewise.
12922         * tree-tailcall.c (add_successor_phi_arg): Likewise.
12923         (eliminate_tail_call): Likewise.
12924         (create_tailcall_accumulator): Likewise.
12925         (tree_optimize_tail_calls_1): Likewise.
12926         * tree-phinodes.c (add_phi_arg): Likewise.
12927         (make_phi_node): Likewise.
12928         (resize_phi_node): Likewise.
12929         (remove_phi_arg_num): Likewise.
12930         * omp-low.c (expand_parallel_call): Likewise.
12931         (expand_omp_for_static_chunk): Likewise.
12932         * tree-vect-loop-manip.c (slpeel_update_phis_for_duplicate_loop):
12933         Likewise.
12934         (slpeel_update_phi_nodes_for_guard1): Likewise.
12935         (slpeel_update_phi_nodes_for_guard2): Likewise.
12936         (slpeel_tree_duplicate_loop_to_edge_cfg): Likewise.
12937         (set_prologue_iterations): Likewise.
12938         (slpeel_tree_peel_loop_to_edge): Likewise.
12939         (vect_loop_versioning): Likewise.
12940         * tree-parloops.c (create_phi_for_local_result): Likewise.
12941         (transform_to_exit_first_loop): Likewise.
12942         (create_parallel_loop): Likewise.
12943         * ipa-split.c (split_function): Likewise.
12944         * tree-vect-loop.c (get_initial_def_for_induction): Likewise.
12945         (vect_create_epilog_for_reduction): Likewise.
12946         * tree-vect-data-refs.c (vect_setup_realignment): Likewise.
12947         * graphite-scop-detection.c (canonicalize_loop_closed_ssa): Likewise.
12948         * tree-ssa-phiopt.c (cond_store_replacement): Likewise.
12949         (cond_if_else_store_replacement_1): Likewise.
12950         * tree-cfgcleanup.c (remove_forwarder_block): Likewise.
12951         (remove_forwarder_block_with_phi): Likewise.
12952         * tree-ssa-pre.c (insert_into_preds_of_block): Likewise.
12953         * tree-predcom.c (initialize_root_vars): Likewise.
12954         (initialize_root_vars_lm): Likewise.
12955         * sese.c (sese_add_exit_phis_edge): Likewise.
12956         * tree-ssa-dce.c (forward_edge_to_pdom): Likewise.
12957         * tree-ssa.c (flush_pending_stmts): Likewise.
12958         (redirect_edge_var_map_add): Likewise.
12959         (ssa_redirect_edge): Likewise.
12960         * gimple-streamer-in.c (input_phi): Likewise.
12961         * tree-vect-stmts.c (vectorizable_load): Likewise.
12962         * tree-inline.c (copy_phis_for_bb): Likewise.
12963         * tree-ssa-phiprop.c (phiprop_insert_phi): Likewise.
12964         * tree-switch-conversion.c (fix_phi_nodes): Likewise.
12965         * tree-cfg.c (reinstall_phi_args): Likewise.
12966         (gimple_make_forwarder_block): Likewise.
12967         (add_phi_args_after_copy_edge): Likewise.
12968         (gimple_duplicate_sese_tail): Likewise.
12969
12970 2012-07-16 Sergey Melnikov <sergey.melnikov@intel.com>
12971
12972         * config/i386/i386.md (stack_protect_set): Disable the pattern
12973         for Android since Android libc (bionic) does not provide random
12974         value for stack protection guard at gs:0x14. Guard value
12975         will be provided from external symbol (default implementation).
12976         (stack_protect_set_<mode>): Likewise.
12977         (stack_protect_test): Likewise.
12978         (stack_protect_test_<mode>): Likewise.
12979
12980 2012-07-16  Hans-Peter Nilsson  <hp@axis.com>
12981
12982         * config/cris/cris-protos.h (cris_legitimate_address_p): Declare.
12983         * config/cris/cris.h (CONSTANT_ADDRESS_P): Define in terms of
12984         CONSTANT_P and cris_legitimate_address_p.
12985         * config/cris/cris.c (cris_legitimate_address_p): Make non-static.
12986         (cris_preferred_reload_class): Don't return GENERAL_REGS as
12987         preferred to MOF_SRP_REGS.
12988
12989         * config/cris/cris.c (cris_init_libfuncs): Handle initialization
12990         of library functions for basic atomic compare-and-swap.
12991         * config/cris/cris.h (TARGET_ATOMICS_MAY_CALL_LIBFUNCS): New macro.
12992         * config/cris/cris.opt (munaligned-atomic-may-use-library): New option.
12993         * config/cris/sync.md ("atomic_fetch_<atomic_op_name><mode>")
12994         ("cris_atomic_fetch_<atomic_op_name><mode>_1")
12995         ("atomic_compare_and_swap<mode>")
12996         ("cris_atomic_compare_and_swap<mode>_1"): Make conditional on
12997         TARGET_ATOMICS_MAY_CALL_LIBFUNCS for sizes larger than byte.
12998         * config/cris/cris.c (cris_print_operand) <case 'P', 'q'>: New cases.
12999         * config/cris/sync.md (atomic_op_op_cnstr): New code_attr.
13000         (atomic_op_op_pred): Ditto.
13001         (atomic_op_mnem_pre_op2): Renamed from atomic_op_mnem_pre; to
13002         reflect the change to include %2 in expansion.  All callers changed.
13003         (qm3): New mode_attr.
13004         ("atomic_fetch_<atomic_op_name><mode>"): Use <atomic_op_op_pred>
13005         as predicate for operand 2.
13006         ("cris_atomic_fetch_<atomic_op_name><mode>_1"): Update FIXME.  Use
13007         "<atomic_op_op_pred>" "<atomic_op_op_cnstr>" for predicate and
13008         constraint for operand 2.
13009         ("atomic_compare_and_swap<mode>"): Add FIXME.  Change predicate to
13010         nonmemory_operand for operand 3.
13011         ("cris_atomic_compare_and_swap<mode>_1"): Change operand 3 to
13012         exclude memory.  Improve emitted sync code for v10 and v32.  Use
13013         <qm3> instead of <m> for size designator for cmp.
13014         ("atomic_compare_and_swap<mode>"): Change predicate to
13015         nonmemory_operand for operand 3.  Add FIXME.
13016         ("cris_atomic_compare_and_swap<mode>_1"): Change predicates and
13017         constraints for operand 3 to exclude memory.
13018         ("atomic_fetch_<atomic_op_name><mode>")
13019         ("atomic_compare_and_swap<mode>"): Gate expand_mem_thread_fence
13020         calls on result of call to need_atomic_barrier_p.
13021
13022 2012-07-15  Richard Sandiford  <rdsandiford@googlemail.com>
13023
13024         * config/mips/mips.md (move_type): Replace mfhilo and mthilo
13025         with mflo and mtlo.
13026         (type): Split mfhilo into mfhi and mflo.  Split mthilo into mthi
13027         and mtlo.  Adjust move_type->type mapping.
13028         (may_clobber_hilo): Split mthilo into mthi and mtlo.
13029         (*movdi_32bit, *movdi_32bit_mips16, *movdi_64bit, *movdi_64bit_mips16)
13030         (*mov<mode>_internal, *mov<mode>_mips16, *movhi_internal)
13031         (*movhi_mips16, *movqi_internal, *movqi_mips16): Use mtlo and mflo
13032         instead of mthilo and mfhilo.
13033         (mfhi<GPR:mode>_<HILO:mode>): Use mfhi instead of mfhilo.
13034         (mthi<GPR:mode>_<HILO:mode>): Use mthi instead of mthilo.
13035         * config/mips/mips-dsp.md (mips_extr_w, mips_extr_r_w, mips_extr_rs_w)
13036         (mips_extr_s_h, mips_extp, mips_extpdp, mips_shilo, mips_mthlip):
13037         Use mflo instead of mfhilo.
13038         * config/mips/10000.md (r10k_arith): Split mthilo.
13039         (r10k_mfhi, r10k_mflo): Use mfhi and mflo directly.
13040         * config/mips/sb1.md (ir_sb1_mfhi, ir_sb1_mflo): Likewise.
13041         (ir_sb1_mthilo): Split mthilo into mthi and mtlo.
13042         * config/mips/20kc.md (r20kc_imthilo, r20kc_imfhilo): Split
13043         mthilo and mfhilo.
13044         * config/mips/24k.md (r24k_int_mfhilo, r24k_int_mthilo): Likewise.
13045         * config/mips/4130.md (vr4130_class, vr4130_mfhilo, vr4130_mthilo):
13046         Likewise.
13047         * config/mips/4k.md (r4k_int_mthilo, r4k_int_mfhilo): Likewise.
13048         * config/mips/5400.md (ir_vr54_hilo): Likewise.
13049         * config/mips/5500.md (ir_vr55_mthilo, ir_vr55_mfhilo): Likewise.
13050         * config/mips/5k.md (r5k_int_mthilo, r5k_int_mfhilo): Likewise.
13051         * config/mips/7000.md (rm7_mthilo, rm7_mfhilo): Likewise.
13052         * config/mips/74k.md (r74k_int_mfhilo, r74k_int_mthilo): Likewise.
13053         * config/mips/9000.md (rm9k_mfhilo, rm9k_mthilo): Likewise.
13054         * config/mips/generic.md (generic_hilo): Likewise.
13055         * config/mips/loongson2ef.md (ls2_alu): Likewise.
13056         * config/mips/loongson3a.md (ls3a_mfhilo): Likewise.
13057         * config/mips/octeon.md (octeon_imul_o1, octeon_imul_o2)
13058         (octeon_mfhilo_o1, octeon_mfhilo_o2): Likewise.
13059         * config/mips/sr71k.md (ir_sr70_hilo): Likewise.
13060         * config/mips/xlr.md (xlr_hilo): Likewise.
13061
13062 2012-07-14  Andrew Stubbs  <ams@codesourcery.com>
13063             Sandra Loosemore  <sandra@codesourcery.com>
13064
13065         * config/sh/sh.h (SH_ASM_SPEC): Add spaces between options.
13066
13067 2012-07-14  Uros Bizjak  <ubizjak@gmail.com>
13068
13069         * config/i386/i386.c (ix86_set_reg_reg_cost): Enable TFmode/TCmode
13070         for TARGET_SSE.
13071
13072 2012-07-14  Steven Bosscher  <steven@gcc.gnu.org>
13073
13074         * toplev.c (init_asm_output): Open asm_out_file in 'w' mode.
13075
13076 2012-07-13  Bill Schmidt  <wschmidt@linux.ibm.com>
13077
13078         PR bootstrap/53955
13079         * config/spu/spu.c (spu_init_cost): Mark static.
13080         (spu_add_stmt_cost): Likewise.
13081         (spu_finish_cost): Likewise.
13082         (spu_destroy_cost_data): Likewise.
13083         * config/i386/i386.c (ix86_init_cost): Mark static.
13084         (ix86_add_stmt_cost): Likewise.
13085         (ix86_finish_cost): Likewise.
13086         (ix86_destroy_cost_data): Likewise.
13087         * config/rs6000/rs6000.c (rs6000_init_cost): Mark static.
13088         (rs6000_add_stmt_cost): Likewise.
13089         (rs6000_finish_cost): Likewise.
13090         (rs6000_destroy_cost_data): Likewise.
13091
13092 2012-07-13  Steven Bosscher  <steven@gcc.gnu.org>
13093
13094         * ggc.h (ggc_internal_alloc_stat, ggc_alloc_typed_stat,
13095         ggc_internal_cleared_alloc_stat, ggc_cleared_alloc_htab_ignore_args,
13096         ggc_cleared_alloc_ptr_array_two_args, ggc_splay_alloc): Add
13097         ATTRIBUTE_MALLOC.
13098         * alloc-pool.h (pool_alloc): Likewise.
13099
13100         * final.c (final): Do not loop to find max_uid.
13101
13102 2012-07-13  Steven Bosscher  <steven@gcc.gnu.org>
13103
13104         * emit-rtl.c (make_debug_insn_raw, make_jump_insn_raw): Make static.
13105         * rtl.h (make_debug_insn_raw, make_jump_insn_raw): Remove prototypes.
13106
13107 2012-07-13  Richard Guenther  <rguenther@suse.de>
13108
13109         PR tree-optimization/53907
13110         * tree-ssa-forwprop.c (associate_pointerplus): New function.
13111         (ssa_forward_propagate_and_combine): Call it.
13112
13113 2012-07-13  Richard Guenther  <rguenther@suse.de>
13114
13115         PR tree-optimization/53922
13116         * tree-vrp.c (value_inside_range): Change prototype to take
13117         min/max instead of value-range.
13118         (range_includes_zero_p): Likewise.  Return the result from
13119         value_inside_range.
13120         (extract_range_from_binary_expr_1): Adjust to handle dont-know
13121         return value from range_includes_zero_p.
13122         (extract_range_from_unary_expr_1): Likewise.
13123         (compare_range_with_value): Likewise.
13124         (vrp_meet_1): Likewise.
13125
13126 2012-07-13  Bill Schmidt  <wschmidt@linux.ibm.com>
13127
13128         * doc/tm.texi: Regenerate.
13129         * doc/tm.texi.in (TARGET_VECTORIZE_INIT_COST): New hook.
13130         (TARGET_VECTORIZE_ADD_STMT_COST): Likewise.
13131         (TARGET_VECTORIZE_FINISH_COST): Likewise.
13132         (TARGET_VECTORIZE_DESTROY_COST_DATA): Likewise.
13133         * targhooks.c (default_init_cost): New function.
13134         (default_add_stmt_cost): Likewise.
13135         (default_finish_cost): Likewise.
13136         (default_destroy_cost_data): Likewise.
13137         * targhooks.h (default_init_cost): New decl.
13138         (default_add_stmt_cost): Likewise.
13139         (default_finish_cost): Likewise.
13140         (default_destroy_cost_data): Likewise.
13141         * target.def (init_cost): New DEFHOOK.
13142         (add_stmt_cost): Likewise.
13143         (finish_cost): Likewise.
13144         (destroy_cost_data): Likewise.
13145         * target.h (struct _stmt_vec_info): New extern decl.
13146         (stmt_vectype): Likewise.
13147         (stmt_in_inner_loop_p): Likewise.
13148         * tree-vectorizer.h (stmt_info_for_cost): New struct/typedef.
13149         (stmt_vector_for_cost): New VEC/typedef.
13150         (add_stmt_info_to_vec): New function.
13151         (struct _slp_tree): Remove cost.inside_of_loop field.
13152         (struct _slp_instance): Remove cost.inside_of_loop field; add
13153         stmt_cost_vec field.
13154         (SLP_INSTANCE_INSIDE_OF_LOOP_COST): Remove macro.
13155         (SLP_INSTANCE_STMT_COST_VEC): New accessor macro.
13156         (SLP_TREE_INSIDE_OF_LOOP_COST): Remove macro.
13157         (struct _vect_peel_extended_info): Add stmt_cost_vec field.
13158         (struct _loop_vec_info): Add target_cost_data field.
13159         (LOOP_VINFO_TARGET_COST_DATA): New accessor macro.
13160         (struct _bb_vec_info): Add target_cost_data field.
13161         (BB_VINFO_TARGET_COST_DATA): New accessor macro.
13162         (struct _stmt_vec_info): Remove cost.inside_of_loop field.
13163         (STMT_VINFO_INSIDE_OF_LOOP_COST): Remove macro.
13164         (stmt_vinfo_set_inside_of_loop_cost): Remove function.
13165         (init_cost): New function.
13166         (add_stmt_cost): Likewise.
13167         (finish_cost): Likewise.
13168         (destroy_cost_data): Likewise.
13169         (vect_model_simple_cost): Change parameter list.
13170         (vect_model_store_cost): Likewise.
13171         (vect_model_load_cost): Likewise.
13172         (record_stmt_cost): New extern decl.
13173         (vect_get_load_cost): Change parameter list.
13174         (vect_get_store_cost): Likewise.
13175         * tree-vect-loop.c (new_loop_vec_info): Call init_cost.
13176         (destroy_loop_vec_info): Call destroy_cost_data.
13177         (vect_estimate_min_profitable_iters): Remove old calculation of
13178         inside costs; call finish_cost instead.
13179         (vect_model_reduction_cost): Call add_stmt_cost instead of old
13180         inside-costs calculation.
13181         (vect_model_induction_cost): Likewise.
13182         * tree-vect-data-refs.c (vect_get_data_access_cost): Change to
13183         return a stmt_vector_for_cost; modify calls to vect_get_load_cost
13184         and vect_get_store_cost to obtain the value to return.
13185         (vect_peeling_hash_get_lowest_cost): Obtain a stmt_cost_vec from
13186         vect_get_data_access_cost and store it in the minimum peeling
13187         structure.
13188         (vect_peeling_hash_choose_best_peeling): Change the parameter list
13189         to add a (stmt_vector_for_cost *) output parameter, and set its value.
13190         (vect_enhance_data_refs_alignment): Ignore the new return value from
13191         calls to vect_get_data_access_cost; obtain stmt_cost_vec from
13192         vect_peeling_hash_choose_best_peeling and pass its contents to the
13193         target cost model.
13194         * tree-vect-stmts.c (stmt_vectype): New function.
13195         (stmt_in_inner_loop_p): Likewise.
13196         (record_stmt_cost): Likewise.
13197         (vect_model_simple_cost): Add stmt_cost_vec parameter; call
13198         record_stmt_cost instead of old calculation; don't call
13199         stmt_vinfo_set_inside_of_loop_cost.
13200         (vect_model_promotion_demotion_cost): Call add_stmt_cost instead of
13201         old calculation; don't call stmt_vinfo_set_inside_of_loop_cost.
13202         (vect_model_store_cost): Add stmt_cost_vec parameter; call
13203         record_stmt_cost instead of old calculation; add stmt_cost_vec
13204         parameter to vect_get_store_cost call; don't call
13205         stmt_vinfo_set_inside_of_loop_cost.
13206         (vect_get_store_cost): Add stmt_cost_vec parameter; call
13207         record_stmt_cost instead of old calculation.
13208         (vect_model_load_cost): Add stmt_cost_vec parameter; call
13209         record_stmt_cost instead of old calculation; add stmt_cost_vec
13210         parameter to vect_get_load_cost call; don't call
13211         stmt_vinfo_set_inside_of_loop_cost.
13212         (vect_get_load_cost): Add stmt_cost_vec parameter; call
13213         record_stmt_cost instead of old calculation.
13214         (vectorizable_call): Add NULL parameter to vect_model_simple_cost call.
13215         (vectorizable_conversion): Likewise.
13216         (vectorizable_assignment): Likewise.
13217         (vectorizable_shift): Likewise.
13218         (vectorizable_operation): Likewise.
13219         (vectorizable_store): Add NULL parameter to vect_model_store_cost call.
13220         (vectorizable_load): Add NULL parameter to vect_model_load_cost call.
13221         (new_stmt_vec_info): Don't set STMT_VINFO_INSIDE_OF_LOOP_COST.
13222         * config/spu/spu.c (TARGET_VECTORIZE_INIT_COST): New macro def.
13223         (TARGET_VECTORIZE_ADD_STMT_COST): Likewise.
13224         (TARGET_VECTORIZE_FINISH_COST): Likewise.
13225         (TARGET_VECTORIZE_DESTROY_COST_DATA): Likewise.
13226         (spu_init_cost): New function.
13227         (spu_add_stmt_cost): Likewise.
13228         (spu_finish_cost): Likewise.
13229         (spu_destroy_cost_data): Likewise.
13230         * config/i386/i386.c (ix86_init_cost): New function.
13231         (ix86_add_stmt_cost): Likewise.
13232         (ix86_finish_cost): Likewise.
13233         (ix86_destroy_cost_data): Likewise.
13234         (TARGET_VECTORIZE_INIT_COST): New macro def.
13235         (TARGET_VECTORIZE_ADD_STMT_COST): Likewise.
13236         (TARGET_VECTORIZE_FINISH_COST): Likewise.
13237         (TARGET_VECTORIZE_DESTROY_COST_DATA): Likewise.
13238         * config/rs6000/rs6000.c (TARGET_VECTORIZE_INIT_COST): New macro def.
13239         (TARGET_VECTORIZE_ADD_STMT_COST): Likewise.
13240         (TARGET_VECTORIZE_FINISH_COST): Likewise.
13241         (TARGET_VECTORIZE_DESTROY_COST_DATA): Likewise.
13242         (rs6000_init_cost): New function.
13243         (rs6000_add_stmt_cost): Likewise.
13244         (rs6000_finish_cost): Likewise.
13245         (rs6000_destroy_cost_data): Likewise.
13246         * tree-vect-slp.c (vect_free_slp_instance): Free stmt_cost_vec.
13247         (vect_create_new_slp_node): Don't set SLP_TREE_INSIDE_OF_LOOP_COST.
13248         (vect_get_and_check_slp_defs): Add stmt_cost_vec parameter; add
13249         stmt_cost_vec parameter to vect_model_store_cost and
13250         vect_model_simple_cost calls.
13251         (vect_build_slp_tree): Remove inside_cost parameter; add stmt_cost_vec
13252         parameter; add stmt_cost_vec parameter to vect_get_and_check_slp_defs,
13253         vect_model_load_cost, and recursive vect_build_slp_tree calls; prevent
13254         calculating cost more than once for loads; remove inside_cost
13255         parameter from recursive vect_build_slp_tree calls; call
13256         record_stmt_cost instead of old calculation.
13257         (vect_analyze_slp_instance): Allocate stmt_cost_vec and save it with
13258         the instance; free it on premature exit; remove inside_cost parameter
13259         from vect_build_slp_tree call; add stmt_cost_vec parameter to
13260         vect_build_slp_tree call; don't set SLP_INSTANCE_INSIDE_OF_LOOP_COST.
13261         (new_bb_vec_info): Call init_cost.
13262         (destroy_bb_vec_info): Call destroy_cost_data.
13263         (vect_bb_vectorization_profitable_p): Call add_stmt_cost for each
13264         statement recorded with an SLP instance; call finish_cost instead of
13265         the old calculation.
13266         (vect_update_slp_costs_according_to_vf): Record statement costs from
13267         SLP instances, multiplying by the appropriate number of copies; don't
13268         update SLP_INSTANCE_INSIDE_OF_LOOP_COST.
13269
13270 2012-07-13  Richard Guenther  <rguenther@suse.de>
13271
13272         PR middle-end/53937
13273         * builtins.c (get_pointer_alignment_1): Handle constant
13274         pointers.
13275
13276 2012-07-13  Richard Sandiford  <rdsandiford@googlemail.com>
13277             Steven Bosscher  <steven@gcc.gnu.org>
13278             Bernd Schmidt  <bernds@codesourcery.com>
13279
13280         PR rtl-optimization/53908
13281         * df-problems.c (can_move_insns_across): When doing
13282         memory-reference book-keeping, handle call insns.
13283
13284 2012-07-13  Richard Guenther  <rguenther@suse.de>
13285
13286         * gimple.c (gimple_types_compatible_p_1): Remove redundant
13287         type attribute comparisons.
13288         (gimple_canonical_types_compatible_p): Likewise.
13289
13290 2012-07-12  Hans-Peter Nilsson  <hp@axis.com>
13291
13292         PR rtl-optimization/53176
13293         * rtlanal.c (rtx_cost): Adjust default cost for X with a
13294         UNITS_PER_WORD factor for all X according to the size of
13295         its mode, not just for SUBREGs with untieable modes.
13296         Handle SET.  Use factor * factor for MULT, DIV, UDIV,
13297         MOD, UMOD.
13298
13299 2012-07-12  Uros Bizjak  <ubizjak@gmail.com>
13300
13301         * config/i386/i386.md (QImode and HImode cmove splitters): Merge
13302         QImode and HImode splitters.  Use ix86_comparison_operator.
13303         Explicitly match FLAGS_REG.
13304         (DFmode cmove splitter): Explicitly match FLAGS_REG.
13305
13306 2012-07-11  Steven Bosscher  <steven@gcc.gnu.org>
13307
13308         * expr.h (can_move_by_pieces): Move prototype from here ...
13309         * tree.h (can_move_by_pieces): ... to here.
13310         * optabs.h (set_widening_optab_handler): Use XCNEW.
13311         * gimplify.c: Do not include expr.h.
13312
13313         * toplev.c: Do not include dwarf2out.h.
13314         * config/ia64/ia64.c: Likewise.
13315         * config/sparc/sparc.c: Likewise.
13316         * config/sparc/t-sparc (sparc.o): Fix dependencies.
13317
13318         * Makefile.in (toplev.o): Fix dependencies
13319         (c-family/c-gimplify.o): Likewise.
13320         (c-family/c-common.o): Likewise.
13321
13322 2012-07-11  Steven Bosscher  <steven@gcc.gnu.org>
13323
13324         * basic-block.h (struct edge_def): Use basic_block instead of
13325         basic_block_def *.
13326         * cfgloop.h (struct loop_exit, struct loop): Likewise.
13327         * gengenrtl.c (type_from_format): Likewise.  Also for 'tree'
13328         instead of union tree_node *.
13329         * rtl.h (union rtunion_def, emit_insn_before_noloc,
13330         emit_insn_after_noloc, add_insn_before, add_insn_after,
13331         debug_bb_slim): Likewise.
13332         * tree-inline.h (struct copy_body_data): Likewise.
13333         * sched-rgn.c (dump_region_dot): Likewise.
13334         * gimple.h (struct gimple_statement_base, gimple_set_bb,
13335         gsi_move_to_bb_end): Likewise.
13336         * sched-vis.c (debug_bb_slim): Likewise.
13337         (debug_bb_n_slim): Likewise.
13338         * config/mn10300/mn10300.c (mn10300_insert_setlb_lcc): Likewise.
13339         (mn10300_block_contains_call):
13340
13341 2012-07-11  Greta Yorsh  <Greta.Yorsh@arm.com>
13342
13343         PR target/53859
13344         * config/arm/arm.c (arm_early_load_addr_dep): Handle new
13345         epilogue patterns.
13346
13347 2012-07-11  Jonathan Wakely  <jwakely.gcc@gmail.com>
13348
13349         * doc/extend.texi (Namespace Association): Alter cautionary text.
13350
13351 2012-07-10  Oleg Endo  <olegendo@gcc.gnu.org>
13352
13353         PR target/53911
13354         * config/sh/sh.md: Remove displacement addresssing related splits.
13355
13356 2012-07-10  Xinliang David Li  <davidxl@google.com>
13357
13358         * doc/invoke.texi: New option documented.
13359         * flag-types.h: New enum type.
13360         * gimplify.c (gimplify_bind_expr): Control
13361         clobber generation with new option.
13362         (gimplify_target_expr): Ditto.
13363         * common.opt: New option.
13364
13365 2012-07-10  Julian Brown  <julian@codesourcery.com>
13366
13367         * config/arm/arm.md (movsi): Don't split symbol refs here.
13368         (define_split): New.
13369
13370 2012-07-10  Andreas Schwab  <schwab@linux-m68k.org>
13371
13372         PR bootstrap/53913
13373         * config/m68k/m68k.c (m68k_epilogue_uses): New.
13374         * config/m68k/m68k.h (EPILOGUE_USES): Use it.
13375         * config/m68k/m68k-protos.h (m68k_epilogue_uses): Add prototype.
13376
13377 2012-07-10  Richard Henderson  <rth@redhat.com>
13378
13379         * target.def (builtin_mul_widen_even, builtin_mul_widen_odd): Remove.
13380         * system.h (TARGET_VECTORIZE_BUILTIN_MUL_WIDEN_EVEN): Poison.
13381         (TARGET_VECTORIZE_BUILTIN_MUL_WIDEN_ODD): Poison.
13382         * config/i386/i386.c (IX86_BUILTIN_VEC_WIDEN_SMUL_ODD_V4SI): Remove.
13383         (IX86_BUILTIN_VEC_WIDEN_SMUL_ODD_V8SI): Remove.
13384         (IX86_BUILTIN_VEC_WIDEN_UMUL_ODD_V4SI): Remove.
13385         (IX86_BUILTIN_VEC_WIDEN_UMUL_ODD_V8SI): Remove.
13386         (IX86_BUILTIN_VEC_WIDEN_SMUL_EVEN_V4SI): Remove.
13387         (IX86_BUILTIN_VEC_WIDEN_UMUL_EVEN_V4SI): Remove.
13388         (IX86_BUILTIN_VEC_WIDEN_UMUL_EVEN_V8SI): Remove.
13389         (bdesc_args): Remove entries to match.
13390         (ix86_builtin_mul_widen_even, ix86_builtin_mul_widen_odd): Remove.
13391         (TARGET_VECTORIZE_BUILTIN_MUL_WIDEN_EVEN): Remove.
13392         (TARGET_VECTORIZE_BUILTIN_MUL_WIDEN_ODD): Remove.
13393         * config/rs6000/rs6000.c (rs6000_builtin_mul_widen_even): Remove.
13394         (rs6000_builtin_mul_widen_odd): Remove.
13395         (TARGET_VECTORIZE_BUILTIN_MUL_WIDEN_EVEN): Remove.
13396         (TARGET_VECTORIZE_BUILTIN_MUL_WIDEN_ODD): Remove.
13397         * config/spu/spu.c (spu_builtin_mul_widen_even): Remove.
13398         (spu_builtin_mul_widen_odd): Remove.
13399         (TARGET_VECTORIZE_BUILTIN_MUL_WIDEN_EVEN): Remove.
13400         (TARGET_VECTORIZE_BUILTIN_MUL_WIDEN_ODD): Remove.
13401         * doc/tm.texi.in: Don't document the removed hooks.
13402
13403         * tree-vect-stmts.c (supportable_widening_operation): Expand
13404         WIDEN_MULT_EXPR via VEC_WIDEN_MULT_EVEN/ODD_EXPR if possible.
13405
13406         * expmed.c (expmed_mult_highpart): Rename from expand_mult_highpart.
13407         (expmed_mult_highpart_optab): Rename from expand_mult_highpart_optab.
13408         * optabs.c (can_mult_highpart_p): New.
13409         (expand_mult_highpart): New.
13410         * expr.c (expand_expr_real_2) [MULT_HIGHPART_EXPR): Use it.
13411         * tree-vect-generic.c (expand_vector_operations_1): Don't expand
13412         by pieces if can_mult_highpart_p.
13413         (expand_vector_divmod): Use can_mult_highpart_p and always
13414         generate MULT_HIGHPART_EXPR.
13415         * tree-vect-patterns.c (vect_recog_divmod_pattern): Likewise.
13416         * tree-vect-stmts.c (vectorizable_operation): Likewise.
13417
13418         * config/spu/spu-builtins.md (spu_mpy): Move to spu.md.
13419         (spu_mpyu, spu_mpyhhu, spu_mpyhh): Likewise.
13420         * config/spu/spu.md (vec_widen_smult_odd_v8hi): Rename from spu_mpy.
13421         (vec_widen_umult_odd_v8hi): Rename from spu_mpyu.
13422         (vec_widen_smult_even_v8hi): Rename from spu_mpyhh.
13423         (vec_widen_umult_even_v8hi): Rename from spu_mpyhhu.
13424         * config/spu/spu-builtins.def: Update pattern names to match.
13425
13426         * config/rs6000/altivec.md (vec_widen_umult_even_v16qi): Rename
13427         from altivec_vmuleub.
13428         (vec_widen_smult_even_v16qi): Rename from altivec_vmulesb.
13429         (vec_widen_umult_even_v8hi): Rename from altivec_vmuleuh.
13430         (vec_widen_smult_even_v8hi): Rename from altivec_vmulesh.
13431         (vec_widen_umult_odd_v16qi): Rename from altivec_vmuloub.
13432         (vec_widen_smult_odd_v16qi): Rename from altivec_vmulosb.
13433         (vec_widen_umult_odd_v8hi): Rename from altivec_vmulouh.
13434         (vec_widen_smult_odd_v8hi): Rename from altivec_vmulosh.
13435         * config/rs6000/rs6000-builtin.def: Update pattern names to match.
13436
13437         * config/i386/sse.md (vec_widen_umult_even_v8si): Rename from
13438         avx2_umulv4siv4di3.
13439         (vec_widen_umult_even_v4si): Rename from sse2_umulv2siv2di3.
13440         (vec_widen_smult_even_v8si): Rename from avx2_mulv4siv4di3.
13441         (mulv4si3): Remove XOP test shadowed by SSE4 test.
13442         * config/i386/i386.c (bdesc_args): Update pattern names.
13443         (ix86_expand_sse2_mulvxdi3): Likewise.
13444         (ix86_expand_mul_widen_evenodd): Likewise.  Remove XOP test
13445         shadowed by SSE4 test.
13446
13447         * tree.def (VEC_WIDEN_MULT_EVEN_EXPR, VEC_WIDEN_MULT_ODD_EXPR): New.
13448         * cfgexpand.c (expand_debug_expr): Handle them.
13449         * expr.c (expand_expr_real_2): Likewise.
13450         * fold-const.c (fold_binary_loc): Likewise.
13451         * gimple-pretty-print.c (dump_binary_rhs): Likewise.
13452         * optabs.c (optab_for_tree_code): Likewise.
13453         * tree-cfg.c (verify_gimple_assign_binary): Likewise.
13454         * tree-inline.c (estimate_operator_cost): Likewise.
13455         * tree-pretty-print.c (dump_generic_node): Likewise.
13456         * tree.c (commutative_tree_code): Likewise.
13457         * tree-vect-generic.c (expand_vector_operations_1): Likewise.
13458         Handle type change before looking up optab.
13459         * optabs.h (OTI_vec_widen_umult_even, OTI_vec_widen_umult_odd): New.
13460         (OTI_vec_widen_smult_even, OTI_vec_widen_smult_odd): New.
13461         (vec_widen_umult_even_optab, vec_widen_umult_odd_optab): New.
13462         (vec_widen_smult_even_optab, vec_widen_smult_odd_optab): New.
13463         * genopinit.c (optabs): Initialize them.
13464         * doc/md.texi: Document them.
13465
13466 2012-07-10  Dehao Chen  <dehao@google.com>
13467
13468         * tree.h (phi_arg_d): New field.
13469         * tree-flow-inline.h (gimple_phi_arg_block): New function.
13470         (gimple_phi_arg_block_from_edge): New function.
13471         (gimple_phi_arg_set_block): New function.
13472         (gimple_phi_arg_has_block): New function.
13473         (redirect_edge_var_map_block): New function.
13474         * tree-flow.h (_edge_var_map): New field.
13475         * tree-ssa-live.c (remove_unused_locals): Mark phi_arg's block as used.
13476         * tree-eh.c (cleanup_empty_eh_merge_phis): Add block debug info for
13477         redirect_edge_var_map_add.
13478         * tree-outof-ssa.c (_elim_graph): New field.
13479         (insert_partition_copy_on_edge): New parameter.
13480         (insert_value_copy_on_edge): New parameter.
13481         (insert_rtx_to_part_on_edge): New parameter.
13482         (insert_part_to_rtx_on_edge): New parameter.
13483         (elim_graph_add_edge): New parameter.
13484         (elim_graph_remove_succ_edge): New parameter.
13485         (FOR_EACH_ELIM_GRAPH_SUCC): New parameter.
13486         (FOR_EACH_ELIM_GRAPH_PRED): New parameter.
13487         (new_elim_graph): Add block debug info.
13488         (clear_elim_graph): Likewise.
13489         (delete_elim_graph): Likewise.
13490         (elim_graph_add_node): Likewise.
13491         (elim_graph_add_edge): Likewise.
13492         (elim_graph_remove_succ_edge): Likewise.
13493         (eliminate_build): Likewise.
13494         (elim_forward): Likewise.
13495         (elim_unvisited_predecessor): Likewise.
13496         (elim_backward): Likewise.
13497         (elim_create): Likewise.
13498         (eliminate_phi): Likewise.
13499         (insert_backedge_copies): Likewise.
13500         * tree-into-ssa.c (insert_phi_nodes_for): Add block debug info for
13501         add_phi_arg.
13502         (rewrite_add_phi_arguments): Likewise.
13503         * tree-ssa-loop-im.c (execute_sm_if_changed): Likewise.
13504         * tree-ssa-tail-merge.c (replace_block_by): Likewise.
13505         * tree-ssa-threadupdate.c (copy_phi_args): Likewise.
13506         * tree-loop-distribution.c (update_phis_for_loop_copy): Likewise.
13507         * tree-ssa-loop-manip.c (create_iv): Likewise.
13508         (add_exit_phis_edge): Likewise.
13509         (split_loop_exit_edge): Likewise.
13510         (copy_phi_node_args): Likewise.
13511         (tree_transform_and_unroll_loop): Likewise.
13512         * value-prof.c (gimple_ic): Likewise.
13513         (gimple_stringop_fixed_value): Likewise.
13514         * tree-tailcall.c (add_successor_phi_arg): Likewise.
13515         (eliminate_tail_call): Likewise.
13516         (create_tailcall_accumulator): Likewise.
13517         (tree_optimize_tail_calls_1): Likewise.
13518         * tree-phinodes.c (add_phi_arg): Likewise.
13519         (make_phi_node): Likewise.
13520         (resize_phi_node): Likewise.
13521         (remove_phi_arg_num): Likewise.
13522         * omp-low.c (expand_parallel_call): Likewise.
13523         (expand_omp_for_static_chunk): Likewise.
13524         * tree-vect-loop-manip.c (slpeel_update_phis_for_duplicate_loop):
13525         Likewise.
13526         (slpeel_update_phi_nodes_for_guard1): Likewise.
13527         (slpeel_update_phi_nodes_for_guard2): Likewise.
13528         (slpeel_tree_duplicate_loop_to_edge_cfg): Likewise.
13529         (set_prologue_iterations): Likewise.
13530         (slpeel_tree_peel_loop_to_edge): Likewise.
13531         (vect_loop_versioning): Likewise.
13532         * tree-parloops.c (create_phi_for_local_result): Likewise.
13533         (transform_to_exit_first_loop): Likewise.
13534         (create_parallel_loop): Likewise.
13535         * ipa-split.c (split_function): Likewise.
13536         * tree-vect-loop.c (get_initial_def_for_induction): Likewise.
13537         (vect_create_epilog_for_reduction): Likewise.
13538         * tree-vect-data-refs.c (vect_setup_realignment): Likewise.
13539         * graphite-scop-detection.c (canonicalize_loop_closed_ssa): Likewise.
13540         * tree-ssa-phiopt.c (cond_store_replacement): Likewise.
13541         (cond_if_else_store_replacement_1): Likewise.
13542         * tree-cfgcleanup.c (remove_forwarder_block): Likewise.
13543         (remove_forwarder_block_with_phi): Likewise.
13544         * tree-ssa-pre.c (insert_into_preds_of_block): Likewise.
13545         * tree-predcom.c (initialize_root_vars): Likewise.
13546         (initialize_root_vars_lm): Likewise.
13547         * sese.c (sese_add_exit_phis_edge): Likewise.
13548         * tree-ssa-dce.c (forward_edge_to_pdom): Likewise.
13549         * tree-ssa.c (flush_pending_stmts): Likewise.
13550         (redirect_edge_var_map_add): Likewise.
13551         (ssa_redirect_edge): Likewise.
13552         * gimple-streamer-in.c (input_phi): Likewise.
13553         * tree-vect-stmts.c (vectorizable_load): Likewise.
13554         * tree-inline.c (copy_phis_for_bb): Likewise.
13555         * tree-ssa-phiprop.c (phiprop_insert_phi): Likewise.
13556         * tree-switch-conversion.c (fix_phi_nodes): Likewise.
13557         * tree-cfg.c (reinstall_phi_args): Likewise.
13558         (gimple_make_forwarder_block): Likewise.
13559         (add_phi_args_after_copy_edge): Likewise.
13560         (gimple_duplicate_sese_tail): Likewise.
13561
13562 2012-07-09  Oleg Endo  <olegendo@gcc.gnu.org>
13563
13564         PR target/53886
13565         * config/sh/sh.c (sequence_insn_p): New function.
13566         (find_barrier, sh_insn_length_adjustment): Use it.
13567
13568 2012-07-09  Iain Sandoe  <iain@codesourcery.com>
13569
13570         PR target/53283
13571         * config/i386/i386.c (ix86_fold_builtin): Call SUBTARGET_FOLD_BUILTIN
13572         if defined.
13573         * config/darwin.h: Rename TARGET_FOLD_BUILTIN to
13574         SUBTARGET_FOLD_BUILTIN.
13575         * config/rs6000/darwin.h: Map TARGET_FOLD_BUILTIN onto
13576         SUBTARGET_FOLD_BUILTIN.
13577
13578 2012-07-09  Iain Sandoe  <iain@codesourcery.com>
13579
13580         * config/darwin.h (SUBTARGET_C_COMMON_OVERRIDE_OPTIONS): Move NeXT
13581         runtime exceptions model setting from here ...
13582         * config/darwin.c (darwin_override_options): ... to here.
13583
13584 2012-07-09  Steven Bosscher  <steven@gcc.gnu.org>
13585
13586         PR tree-optimization/53887
13587         * tree-cfg.c (group_case_labels_stmt): Make non-static.
13588         * tree-flow.h (group_case_labels_stmt): Add prototype.
13589         * tree-switch-conversion.c (process_switch): Use group_case_labels_stmt
13590         to pre-process every switch.
13591
13592 2012-07-09  Jason Merrill  <jason@redhat.com>
13593
13594         PR c++/53882
13595         * tree.c (type_contains_placeholder_1): Handle NULLPTR_TYPE.
13596         (type_hash_eq): Likewise.
13597
13598 2012-07-09  Tom de Vries  <tom@codesourcery.com>
13599             Richard Guenther  <rguenther@suse.de>
13600
13601         * tree-ssa-ccp.c (optimize_unreachable): New function.
13602         (execute_fold_all_builtins): Use optimize_unreachable to optimize
13603         BUILT_IN_UNREACHABLE.  Don't optimize after BUILT_IN_UNREACHABLE.
13604
13605 2012-07-09  Richard Guenther  <rguenther@suse.de>
13606
13607         PR bootstrap/53898
13608         * graphite-optimize-isl.c: Make sure CU is not empty.
13609
13610 2012-07-09  Steven Bosscher  <steven@gcc.gnu.org>
13611
13612         * gensupport.c (init_rtx_reader_args_cb): Start counting code
13613         generating patterns from 1 to free up 0 for CODE_FOR_nothing.
13614         * gencodes.c (main): Give CODE_FOR_nothing the value 0.  Add
13615         the LAST_INSN_CODE marker at the end.
13616         * genoutput.c (nothing): New static struct data.
13617         (idata): Initialize to &nothing.
13618         (idata_end): Initialize to &nothing.next.
13619         (init_insn_for_nothing): New function to create dummy 'nothing' insn.
13620         (main): Use it.
13621         * genpeep.c (insn_code_number): Remove global variable.
13622         (gen_peephole): Take it as an argument instead.
13623         (main): Take insn_code_number from read_md_rtx.
13624         * optabs.h: Revert r161809:
13625         (optab_handlers): Change type of insn_code back to insn_code.
13626         (optab_handler, widening_optab_handler, set_optab_handler,
13627         set_widening_optab_handler, convert_optab_handler,
13628         set_convert_optab_handler, direct_optab_handler,
13629         set_direct_optab_handler): Remove int casts.
13630         Revert to treating the insn_code field as "insn_code".
13631
13632 2012-07-08  Oleg Endo  <olegendo@gcc.gnu.org>
13633
13634         * config/sh/sh.md (*return_i): Move trap_exit attribute check to ...
13635         * config/sh/sh.c (sh_cfun_trap_exit_p): ... this new function.
13636         * config/sh/sh-protos.h: Declare it.
13637
13638 2012-07-08  Steven Bosscher  <steven@gcc.gnu.org>
13639
13640         * mcf.c: Do not include tm.h, tree.h, and langhooks.h.
13641         (dump_fixup_graph): Use current_function_name.
13642         (adjust_cfg_counts): Likewise.
13643         * ira-conflicts.c: Do not include tree.h.
13644         (ira_build_conflicts): Use REG_USERVAR_P instead of DECL_ARTIFICIAL.
13645
13646 2012-07-08  Oleg Endo  <olegendo@gcc.gnu.org>
13647
13648         PR target/51244
13649         * config/sh/sh.md (*branch_true_eq, *branch_false_ne, nott): New insns.
13650
13651 2012-07-08  Steven Bosscher  <steven@gcc.gnu.org>
13652
13653         * basic-block.h: Re-group most prototypes per file.
13654         (struct edge_list): Remove num_blocks field.
13655         (dump_bb_info): Adjust prototypes.
13656         (dump_reg_info): Move prototype to regs.h.
13657         * function.h: Do not include tree.h.
13658         Include vec.h, vecir.h, input.h and machmode.h to compensate.
13659         (function_name): New prototype.
13660         * gimple.h: Include tree.h to compensate for basic-block.h change.
13661         * langhooks.h: Note that tree.h is only necessary for enum tree_code.
13662         * regs.h (dump_reg_info): Prototype here.
13663         * regset.h: Adjust file reference in comment.
13664         (debug_regset): Remove prototype.
13665         * rtl.h: Include flags.h for flag_var_tracking_assignments.
13666         (MAY_HAVE_DEBUG_INSNS): Define as flag_var_tracking_assignments
13667         instead of no-longer-available tree.h's MAY_HAVE_DEBUG_STMTS.
13668         (dump_reg_info, dump_flow_info): Remove prototypes.
13669         * bb-reorder.c (set_edge_can_fallthru_flag): Move from cfganal.c
13670         to here, the only user.  Make static.
13671         (reorder_basic_blocks): Call dump_reg_info before dump_flow_info.
13672         * cfg.c: Do not include tm.h, tree.h, rtl.h, hard-reg-set.h, regs.h,
13673         flags.h, function.h, except.h, diagnostic-core.h, tm_p.h, timevar.h,
13674         tree-pass.h, cfgloop.h, and tree-flow.h.
13675         Include basic-block.h, the first header I'd expect to be included.
13676         (reg_obstack): Move to df-core.c.
13677         (free_edge): Remove bogus ATTRIBUTE_UNUSED.
13678         (remove_edge_raw): Do not call tree-ssa's redirect_edge_var_map_clear.
13679         (redirect_edge_succ_nodup): Move to cfghooks.c.
13680         (dump_regset, debug_regset): Move to df-core.c.
13681         (dump_bb_info): Move to cfgrtl.c.
13682         (dump_reg_info): Move to regstat.c.
13683         (dump_flow_info): Move to cfgrtl.c.
13684         (debug_flow_info): Likewise.
13685         (dump_edge_info): Do not look at cfun, a CFG without cfun is nonsense.
13686         * cfganal.c: Do not include tm.h, rtl.h, obstack.h, hard-reg-set.h,
13687         insn-config.h, recog.h, diagnostic-core.h, tm_p.h, and cfgloop.h.
13688         (flow_active_insn_p, forwarder_block_p, can_fallthru,
13689         could_fall_through): Move to cfgrtl.c.
13690         (set_edge_can_fallthru_flag): Moved to bb-reorder.c.
13691         (create_edge_list): Do not set edge_list's removed num_blocks.
13692         (print_edge_list): Look at n_basic_blocks instead of num_blocks.
13693         (flow_nodes_print): Remove.
13694         (flow_edge_list_print): Remove.
13695         (inverted_post_order_compute): Use FOR_ALL_BB.
13696         * cfgrtl.c (dump_flow_info): Moved from cfg.c.
13697         Do not call dump_reg_info.
13698         (debug_flow_info): Moved from cfg.c
13699         (dump_bb_info): Moved from cfg.c.  Take 'verbose' argument
13700         to avoid looking at TDF_* flags from tree-pass.h.
13701         (flow_active_insn_p, forwarder_block_p, can_fallthru,
13702         could_fall_through): Moved from cfganal.c.
13703         (print_rtl_with_bb): Adjust dump_bb_info calls.
13704         * cfghooks.c (redirect_edge_succ_nodup): Moved from cfg.c.
13705         (remove_edge): Call redirect_edge_var_map_clear if IR_GIMPLE.
13706         (cfgcleanup.c): Look at MAY_HAVE_DEBUG_INSNS, not MAY_HAVE_DEBUG_STMTS.
13707         * cselib.c: Include tree.h with a FIXME.
13708         * df-core.c (reg_obstack): Moved from cfg.c.
13709         (dump_regset): Likewise.
13710         (debug_regset): Likewise.  Make a DEBUG_FUNCTION.
13711         * final.c (compute_alignments): Call dump_reg_info before
13712         dump_flow_info.
13713         * function.c (function_name): New function.
13714         (current_function_name): Use it.
13715         * ifcvt.c (rest_of_handle_if_conversion): Call dump_reg_info before
13716         dump_flow_info.
13717         * ira-conflicts.c: Include tree.h with a note.
13718         * regstat.c (dump_reg_info): Moved here from cfg.c.
13719         * loop-init.c: Include regs.h instead of hard-reg-set.h.
13720         (rtl_loop_init): Call dump_reg_info before dump_flow_info.
13721         (rtl_loop_done): Likewise.
13722         * mcf.c: Include tree.h before langhooks.h.
13723         * predict.c (maybe_hot_count_p): Assert we have cfun.
13724         (probably_never_executed_bb_p): Likewise.
13725         * profile.c (compute_branch_probabilities): Use gimple_dump_cfg
13726         instead of dump_flow_info.
13727         * sched-deps.c: Include tree.h with a FIXME.
13728         (call_may_noreturn_p): Add FIXME note why this function has to
13729         look at function decls instead of function decl flags.
13730         * sched-vis.c: Include tree.h with a FIXME.
13731         (print_rtl_slim): Adjust dump_bb_info uses.
13732         * statistics.c (statistics_fini_pass_2): Use current_function_name
13733         to avoid including tree.h.
13734         (statistics_counter_event): Use function_name for the same reason.
13735         (statistics_histogram_event): Likewise.
13736         * tracer.c (tracer): Remove bogus gcc_assert.  Use brief_dump_cfg
13737         instead of dump_flow_info.
13738         * var-tracking.c (variable_tracking_main_1): Call dump_reg_info
13739         before dump_flow_info.
13740         * doc/cfg.texi: Update CFG documentation.
13741         * Makefile.in (RTL_H): Depend on FLAGS_H.
13742         (GIMPLE_H): Depend on TREE_H.
13743         (FUNCTION_H): Depend on VEC_H, vecir.h, INPUT_H and MACHMODE_H,
13744         but no longer on TREE_H.
13745         (C_COMMON_H): Depend on TREE_H.
13746         (cselib.o, cse.o, cfganal.o, loop-init.o, ira-conflicts.o,
13747         sched-deps.o, sched-vis.o): Fixup dependencies.
13748
13749 2012-07-08  Steven Bosscher  <steven@gcc.gnu.org>
13750
13751         * alias.h: Do not include coretypes.h in header files.
13752         * cppbuiltin.h: Likewise.
13753         * double-int.h: Likewise.
13754         * gimple-fold.h: Likewise.
13755         * flags.h: Likewise.
13756         * tree-ssa-alias.h: Likewise.
13757         * gengtype.h (obstack_chunk_alloc, obstack_chunk_free,
13758         OBSTACK_CHUNK_SIZE): Define here to avoid dependency on coretypes.h.
13759         * Makefile.in (RTL_BASE_H): Depend on coretypes.h.
13760         (TREE_H): Likewise.
13761         (ALIAS_H): Do not depend on coretypes.h.
13762         (FLAGS_H): Likewise.
13763         (realmpfr.o): Depend on coretypes.h.
13764
13765 2012-07-08  Steven Bosscher  <steven@gcc.gnu.org>
13766
13767         * Makefile.in (gengtype-lex.o, gengtype-parse.o, gengtype-state.o,
13768         gengtype.o): Add -DGENERATOR_FILE manually for host gengtype objects.
13769
13770 2012-07-07  Richard Earnshaw  <rearnsha@arm.com>
13771
13772         * arm.h (TARGET_CPU_CPP_BUILTINS): Remove Maverick support.
13773         (TARGET_FPA): Delete definition.
13774         (TARGET_MAVERICK): Likewise.
13775         (TARGET_FPA_EMU2): Likewise.
13776         (arm_fp_model): Remove FPA and Maverick models.
13777         (arm_arch_cirrus): Delete declaration.
13778         (FLOAT_WORDS_BIG_ENDIAN): Delete definition.
13779         (FIXED_REGISTERS): Remove FPA and Maverick support.  Reorganize.
13780         (CALL_USED_REGISTERS): Likewise.
13781         (FIRST_FPA_REGNUM, LAST_FPA_REGNUM): Delete definition.
13782         (FIRST_VFP_REGNUM): Renumbered.
13783         (D7_VFP_REGNUM): Chain definition.
13784         (LAST_LO_VFP_REGNUM): Likewise.
13785         (FIRST_HI_VFP_REGNUM): Likewise.
13786         (LAST_HI_VFP_REGNUM): Likewise.
13787         (FIRST_IWMMXT_GR_REGNUM): Likewise.
13788         (LAST_IWMMXT_GR_REGNUM): Likewise.
13789         (FIRST_IWMMXT_REGNUM): Likewise.
13790         (LAST_IWMMXT_REGNUM): Likewise.
13791         (FRAME_POINTER_REGNUM): Renumbered.
13792         (ARG_POINTER_REGNUM): Renumbered.
13793         (FIRST_PSEUDO_REGISTER): Remove FPA and Maverick registers.
13794         (FIRST_CIRRUS_FP_REGNUM, LAST_CIRRUS_FP_REGNUM): Delete definitions.
13795         (HARD_REGNO_REGNUM): Remove FPA support.
13796         (REG_ALLOC_ORDER): Remove FPA and Maverick registers.  Reorganize.
13797         (reg_class): Likewise.
13798         (REG_CLASS_NAMES): Likewise.
13799         (REG_CLASS_CONTENTS): Likewise.
13800         (CANNOT_CHANGE_MODE_CLASS): Never true.  Update comment.
13801         (SECONDARY_INPUT_RELOAD_CLASS): Remove Maverick support.
13802         (CLASS_MAX_NREGS): Remove FPA and Maverick support.
13803         * aout.h (REGISTER_NAMES): Remove FPA and Maverick registers.
13804         Reorganize.  Use AAPCS preferred names.
13805         (ADDITIONAL_REGISTER_NAMES): Remove aliases for Maverick.  Update
13806         comments.
13807         (OVERLAPPING_REGISTER_NAMES): Update register numbering.
13808         * arm.c (FL_CIRRUS): Delete definition.
13809         (arm_arch_cirrus): Delete variable.
13810         (arm_float_words_big_endian): Delete function.
13811         (cirrus_memory_offset): Delete function.
13812         (output_mov_long_double_fpa_from_arm): Delete function.
13813         (output_mov_long_double_arm_from_fpa): Delete function.
13814         (output_mov_double_fpa_from_arm): Delete function.
13815         (output_mov_double_arm_from_fpa): Delete function.
13816         (emit_sfm): Delete function.
13817         (maybe_get_arm_condition_code): Update comment.
13818         (arm_file_start): Always use softvfp for softfloat systems.
13819         (thumb_core_reg_alloc_order): Adjust for updated register allocation.
13820         (arm_option_override): Remove FPA and Maverick support.  Always
13821         default to vfp as the fallback FPU format.
13822         (use_return_insn): Remove FPA support.
13823         (arm_get_frame_offsets): Likewise.
13824         (arm_save_coproc_regs): Likewise.
13825         (arm_canonicalize_comparison): Remove Maverick support.
13826         (arm_select_cc_mode): Likewise.
13827         (arm_gen_compare_reg): Likewise.
13828         (arm_print_operand): Likewise.
13829         (arm_libcall_value_1): Remove FPA and Maverick support.
13830         (arm_function_value_regno_p): Likewise.
13831         (arm_apply_result_size): Likewise.
13832         (arm_legitimate_index_p): Likewise.
13833         (thumb2_legitimate_index_p): Likewise.
13834         (legitimize_reload_address): Likewise.
13835         (arm_register_move_cost): Likewise.
13836         (arm_hard_regno_mode_ok): Likewise.
13837         (arm_regno_class): Likewise.
13838         (arm_dbx_register_number): Likewise.
13839         (arm_emit_unwind_sequence): Likewise.
13840         (arm_conditional_register_usage): Likewise.
13841         * arm-protos.h (neg_const_double_rtx_ok_for_fpa): Remove declaration.
13842         (cirrus_memory_offset): Likewise.
13843         (output_move_long_double_fpa_from_arm): Likewise.
13844         (output_move_long_double_arm_from_fpa): Likewise.
13845         (output_move_double_fpa_from_arm): Likewise.
13846         (output_move_double_arm_from_fpa): Likewise.
13847         (arm_float_words_big_endian): Likewise.
13848         * arm.md (CC_REGNUM): Renumbered.
13849         (VFPCC_REGNUM): Moved here.  Renumbered.
13850         (FPA_F0_REGNUM, FPA_F7_REGNUM): Delete.
13851         (attr fpu): Remove FPA and Maverick support.
13852         * vfp.md (VFPCC_REGNUM): Delete.  Moved to arm.md.
13853         * arm-cores.def (ep9312): Remove Maverick support.
13854         * arm-arches.def (ep9312): Delete architecture.
13855         * arm-tables.opt: Regenerated.
13856
13857         * arm/linux-elf.h (FPUTYPE_DEFAULT): Set to vfp.
13858
13859 2012-07-07  Steven Bosscher  <steven@gcc.gnu.org>
13860
13861         PR tree-optimization/53881
13862         * tree-switch-conversion.c (emit_case_bit_tests): Do not rely on
13863         comparing labels to establish uniqueness of a switch case target,
13864         use the CFG instead.
13865
13866 2012-07-07  Ulrich Weigand  <ulrich.weigand@linaro.org>
13867
13868         * combine.c (force_to_mode) [LSHIFTRT]: Avoid undefined behaviour
13869         due to negative shift amount.
13870
13871 2012-07-07  Hans-Peter Nilsson  <hp@axis.com>
13872
13873         Fix configure test for "stack protector support in target C library".
13874         * configure.ac (test_prefix, test_exec_prefix): Move setting from
13875         inside sysroot handling to before and outside it.
13876         * configure: Regenerate.
13877
13878 2012-07-06  Kai Tietz  <ktietz@redhat.com>
13879
13880         PR bootstrap/52947
13881         * config/i386/mingw32.h (NATIVE_SYSTEM_HEADER_DIR): Define it always
13882         as "/mingw/include".
13883
13884 2012-07-06  Alexandre Oliva  <aoliva@redhat.com>
13885
13886         PR debug/53820
13887         * var-tracking.c (vt_add_function_parameter): Convert
13888         internal_arg_pointer into arg_pointer-based address even
13889         without DRAP.
13890
13891 2012-07-06  Alexandre Oilva  <aoliva@redhat.com>
13892
13893         PR rtl-optimization/53827
13894         PR debug/53671
13895         PR debug/49888
13896         * alias.c (memrefs_conflict_p): Adjust offset and size by the
13897         same amount for alignment ANDs.
13898
13899 2012-07-06  Tom de Vries  <tom@codesourcery.com>
13900
13901         PR tree-optimization/51879
13902         * tree-ssa-sccvn.c (copy_reference_ops_from_call)
13903         (visit_reference_op_call): Handle case that lhs is not an SSA_NAME.
13904         (visit_use): Also call visit_reference_op_call for calls with a vdef.
13905
13906 2012-07-06  Tom de Vries  <tom@codesourcery.com>
13907
13908         PR tree-optimization/52009
13909         * tree-ssa-tail-merge.c (gimple_equal_p): For GIMPLE_ASSIGN, compare
13910         value numbers of gimple_vdef.
13911         * tree-ssa-sccvn.h (vn_reference_insert): Add vdef parameter to
13912         prototype.
13913         * tree-ssa-sccvn.c (copy_reference_ops_from_ref): Handle MODIFY_EXPR.
13914         (vn_reference_insert): Add and handle vdef parameter.
13915         (visit_reference_op_load): Add argument to vn_reference_insert call.
13916         (visit_reference_op_store): Find value number of vdef of store.  Insert
13917         value number of vdef of store.
13918
13919 2012-07-06  Uros Bizjak  <ubizjak@gmail.com>
13920
13921         * config/i386/i386.md (simple lea to add peephole): Also transform
13922         RTXes where second PLUS operand matches output.
13923
13924 2012-07-06  Uros Bizjak  <ubizjak@gmail.com>
13925
13926         * config/i386/i386.c (construct_plt_address): Make static.
13927         * config/i386/i386-protos.h (construct_plt_address): Remove.
13928
13929 2012-07-06  Nick Clifton  <nickc@redhat.com>
13930
13931         * config/mn10300/mn10300.c (mn10300_encode_section_info): Call
13932         default_encode_section_info.
13933
13934 2012-07-06  Uros Bizjak  <ubizjak@gmail.com>
13935
13936         PR target/53853
13937         * config/i386/i386.c (x86_output_mi_thunk): For CM_LARGE_PIC model,
13938         emit PIC sequence for fnaddr symbol reference in advance.
13939
13940 2012-07-06  Eric Botcazou  <ebotcazou@adacore.com>
13941
13942         Revert
13943         2012-06-14  Eric Botcazou  <ebotcazou@adacore.com>
13944
13945         * dwarf2out.c (function_possibly_abstracted_p): New static function.
13946         (gen_subprogram_die): Use it function_possibly_abstracted_p in lieu of
13947         cgraph_function_possibly_inlined_p.
13948         (gen_inlined_subroutine_die): Return if the origin is to be ignored.
13949         (process_scope_var): Do not emit concrete instances of abstracted
13950         nested functions from here.
13951         (gen_decl_die): Emit the abstract instance if the function is possibly
13952         abstracted and not only possibly inlined.
13953         (dwarf2out_finish): Find the first non-abstract parent instance and
13954         attach concrete instances on the limbo list to it.
13955
13956 2012-07-05  Ramana Radhakrishnan  <ramana.radhakrishnan@linaro.org>
13957             Julian Brown  <julian@codesourcery.com>
13958
13959         PR target/48941
13960         PR target/51980
13961         * config/arm/neon-gen.ml (return_by_ptr): Delete.
13962         (print_function): Handle empty strings.
13963         (return): Delete use of return_by_ptr.
13964         (mask_shape_for_shuffle): New function.
13965         (mask_elems): Likewise.
13966         (shuffle_fn): Likewise.
13967         (params): Simplify and remove use of return_by_ptr.
13968         (get_shuffle): New function.
13969         (print_variant): Update.
13970         * config/arm/neon.ml (rev_elems): New function.
13971         (permute_range): Likewise.
13972         (zip_range): Likewise.
13973         (uzip_range): Likewise.
13974         (trn_range): Likewise.
13975         (zip_elems): Likewise.
13976         (uzip_elems): Likewise.
13977         (trn_elems): Likewise.
13978         (features): New enumeration Use_shuffle. Delete ReturnPtr.
13979         (pf_su_8_16): New.
13980         (suf_32): New.
13981         (ops): Update entries for Vrev64, Vrev32, Vrev16, Vtr, Vzip, Vuzp.
13982         * config/arm/arm_neon.h: Regenerate.
13983
13984 2012-07-05  Richard Guenther  <rguenther@suse.de>
13985
13986         * tree-pretty-print.c (dump_generic_node): Properly test
13987         the result of exact_log2.
13988
13989 2012-07-05  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
13990
13991         * config/s390/s390-protos.h (s390_expand_movmem)
13992         (s390_expand_cmpmem): Add return value.
13993         * config/s390/s390.c (s390_expand_movmem, s390_expand_cmpmem):
13994         Return FALSE to use the library function in some cases.
13995         * config/s390/s390.md (movmem, cmpmem): Evaluate return value of C
13996         helper functions.
13997
13998 2012-07-05  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
13999
14000         * config.gcc: Enable ifunc attribute by default on s390 and s390x.
14001
14002 2012-07-05  Steven Bosscher  <steven@gcc.gnu.org>
14003
14004         * expr.c (try_casesi): Remove bogus ATTRIBUTE_UNUSED markers.
14005         * stmt.c (dump_case_nodes): New.
14006         (expand_case): Split out code generation parts into new functions.
14007         (expand_switch_as_decision_tree_p): Split out from expand_case.
14008         (emit_case_decision_tree): Likewise.
14009         (emit_case_dispatch_table): Likewise.
14010
14011 2012-07-05  Matthew Gretton-Dann  <matthew.gretton-dann@arm.com>
14012
14013         * config/arm/iterators.md (SDF): New mode iterator.
14014         (V_if_elem): Add support for SF and DF modes.
14015         (V_reg): Likewise.
14016         (F_constraint): New mode iterator attribute.
14017         (F_fma_type): Likewise.
14018         config/arm/vfp.md (fma<SDF:mode>4): New pattern.
14019         (*fmsub<SDF:mode>4): Likewise.
14020         (*fmnsub<SDF:mode>4): Likewise.
14021         (*fmnadd<SDF:mode>4): Likewise.
14022
14023 2012-07-04  Uros Bizjak  <ubizjak@gmail.com>
14024
14025         * expmed.c (expand_mult): Initialize coeff and is_neg.
14026
14027 2012-07-04  Oleg Endo  <olegendo@gcc.gnu.org>
14028
14029         * config/sh/predicates.md (zero_extend_operand): New predicate.
14030         * config/sh/sh.md (zero_extendhisi2): Simplify by using new
14031         zero_extend_operand predicate.
14032         (zero_extendqisi2): Likewise.
14033
14034 2012-07-04  Uros Bizjak  <ubizjak@gmail.com>
14035
14036         PR middle-end/53321
14037         * ipa.c (symtab_remove_unreachable_nodes): Partially revert r187375
14038         to not call cgraph_propagate_frequency if something was changed.
14039
14040 2012-07-04  Richard Guenther  <rguenther@suse.de>
14041
14042         PR middle-end/53433
14043         * gimple-fold.c (get_base_constructor): Do not return an
14044         error_mark_node DECL_INITIAL.
14045
14046 2012-07-04  Richard Guenther  <rguenther@suse.de>
14047
14048         PR tree-optimization/53844
14049         * tree-ssa-dse.c (dse_possible_dead_store_p): Properly handle
14050         the loop virtual PHI.
14051
14052 2012-07-04  Richard Guenther  <rguenther@suse.de>
14053
14054         PR tree-optimization/53849
14055         * tree-cfg.c (move_stmt_op): Only call add_referenced_var
14056         for duplicated locals.  Use add_referenced_var_1 to avoid
14057         pushing/popping cfun.
14058
14059 2012-07-04  Kai Tietz  <ktietz@redhat.com>
14060
14061         * config/i386/winnt.c (i386_pe_reloc_rw_mask): New function.
14062         * config/i386/i386-protos.h (i386_pe_reloc_rw_mask): Add
14063         prototype.
14064         * config/i386/cygming.h (TARGET_ASM_RELOC_RW_MASK): Define
14065         as i386_pe_reloc_rw_mask.
14066
14067 2012-07-04  Richard Guenther  <rguenther@suse.de>
14068
14069         * tree.c (find_decls_types_r): Handle TYPE_CONTEXT the same
14070         as in free_lang_data_in_type.
14071
14072 2012-07-04  Tobias Grosser <tobias@grosser.es>
14073             Michael Matz  <matz@suse.de>
14074
14075         * Makefile.in (OBJS): Add graphite-optimize-isl.o.
14076         (graphite-optimize-isl.o): Add dependencies.
14077         * common.opt (floop-nest-optimize): New flag.
14078         * doc/invoke.texi (floop-nest-optimize): Document.
14079         * graphite-dependences.c (compute_deps): Export.
14080         * graphite-poly.h (compute_deps): Declare.
14081         * graphite-optimize-isl.c: New file.
14082         * graphite-poly.c (apply_poly_transforms): Run the loop
14083         nest optimizer.
14084         * tree-ssa-loop.c (gate_graphite_transforms): Enable graphite
14085         if -floop-nest-optimize is enabled.
14086
14087 2012-07-03  Oleg Endo  <olegendo@gcc.gnu.org>
14088
14089         * config/sh/predicates.md (logical_and_operand): New predicate.
14090         * config/sh/constraints.md (Jmb, Jmw): New constraints.
14091         * config/sh/sh.md (andsi3): Move expander above insns.  Add handling
14092         of 0xFFFF constant.  Use logical_and_operand predicate and
14093         satisfies_constraint_Jmb, satisfies_constraint_Jmw.
14094         (*andsi3_compact): Make it an insn_and_split.  Use
14095         logical_and_operand predicate.  Add Jmb,Jmw alternatives.
14096
14097 2012-07-03  Jason Merrill  <jason@redhat.com>
14098
14099         PR c++/53826
14100         * tree.c (build_zero_cst): Handle NULLPTR_TYPE.
14101
14102 2012-07-03  Nick Clifton  <nickc@redhat.com>
14103
14104         * config/mep/mep.c (mep_reorg_regmove): Use
14105         next_nonnote_non_debug_insn to advance to the next insn.  Do not
14106         expect delete_insn to return an rtx.
14107
14108 2012-07-03  Richard Guenther  <rguenther@suse.de>
14109
14110         * doc/install.texi (CLooG): Clarify how CLooG needs to be
14111         configured and that it needs to be built against ISL 0.10.
14112
14113 2012-07-03  Uros Bizjak  <ubizjak@gmail.com>
14114
14115         * config/i386/i386.c (ix86_option_override_internal): Fix wrong
14116         code model string in the error message.
14117
14118 2012-07-03  Uros Bizjak  <ubizjak@gmail.com>
14119
14120         PR target/53811
14121         * config/i386/i386.c (x86_output_mi_thunk): Check if fnaddr satisfies
14122         sibcall_insn_operand.  Move it to a temporary register if not.
14123
14124 2012-07-03  Andreas Schwab  <schwab@linux-m68k.org>
14125
14126         PR target/28896
14127         * config/m68k/m68k.c (m68k_option_override): Reset stack_limit_rtx
14128         if !TARGET_68020.
14129
14130 2012-07-03  Uros Bizjak  <ubizjak@gmail.com>
14131
14132         * config/i386/xmmintrin.h (_mm_sfence): Use __builtin_ia32_pause.
14133
14134 2012-07-03  Roland McGrath  <mcgrathr@google.com>
14135
14136         * configure.ac (HAVE_AS_IX86_REP_LOCK_PREFIX): Also require that the
14137         assembler accept 'rep bsf ...', 'rep bsr ...', 'rep ret' and 'rep nop'.
14138         * configure: Regenerated.
14139         * config/i386/i386.md (simple_return_internal_long): Use %;
14140         (ctz<mode>2): Likewise.
14141         (*pause): Likewise.
14142
14143 2012-07-02  Oleg Endo  <olegendo@gcc.gnu.org>
14144
14145         PR target/51244
14146         * config/sh/predicates.md (t_reg_operand, negt_reg_operand): New
14147         predicates.
14148         * config/sh/sh-protos.h (get_t_reg_rtx): New prototype.
14149         * config/sh/sh.c (get_t_reg_rtx): New function.  Use it when invoking
14150         gen_branch_true and gen_branch_false.
14151         * config/sh/sh.md: Use get_t_reg_rtx when invoking gen_branch_true and
14152         gen_branch_false.
14153         (branch_true, branch_false): Use t_reg_operand predicate.
14154         (*branch_true, *branch_false): Delete.
14155         (movt): Use t_reg_operand predicate.
14156         (*negnegt): Use negt_reg_operand predicate and fold little and big
14157         endian variants.
14158         (*movtt): Use t_reg_operand and fold little and big endian variants.
14159         (*movt_qi): Delete.
14160
14161 2012-07-02  Steven Bosscher  <steven@gcc.gnu.org>
14162
14163         * stmt.c (emit_case_bit_tests): Remove.
14164         (expand_case): Remove expand_switch_using_bit_tests_p code.
14165         * tree-switch-conversion.c (hoist_edge_and_branch_if_true): New.
14166         (MAX_CASE_BIT_TESTS): Moved from stmt.c to here.
14167         (lshift_cheap_p): Likewise.
14168         (expand_switch_using_bit_tests_p): Likewise.
14169         (struct case_bit_test): Likewise.
14170         (case_bit_test_cmp): Likewise.
14171         (emit_case_bit_tests): New implementation for GIMPLE.
14172         (gen_inbound_check): Do not release post-dominator info here.
14173         (process_switch): Reorder code.  Expand as bit tests if it
14174         looks like a win.
14175         (do_switchconv): Release post-dominator info here if something changed.
14176         (struct gimple_opt_pass): Verify more.
14177         * tree.h (expand_switch_using_bit_tests_p): Remove prototype.
14178
14179 2012-07-02  Martin Jambor  <mjambor@suse.cz>
14180
14181         PR middle-end/38474
14182         * ipa-prop.c (compute_known_type_jump_func): Put BINFO check before a
14183         dynamic type change check.
14184
14185 2012-07-02  Richard Guenther  <rguenther@suse.de>
14186             Michael Matz  <matz@suse.de>
14187             Tobias Grosser <tobias@grosser.es>
14188             Sebastian Pop <sebpop@gmail.com>
14189
14190         * Makefile.in: Remove PPL flags in favor of ISL ones.
14191         (BACKENDLIBS): Remove PPL libs.
14192         (INCLUDES): Remove PPL includes in favor of ISL ones.
14193         (graphite-clast-to-gimple.o): Remove graphite-dependences.h and
14194         graphite-cloog-compat.h dependencies.
14195         (graphite-dependences.o): Likewise.
14196         (graphite-poly.o): Likewise.
14197         * configure.ac: Declare ISL vars instead of PPL ones.
14198         * configure: Regenerated.
14199         * doc/install.texi: Replace PPL requirement documentation with ISL one.
14200         * graphite-blocking.c: Remove PPL code, add ISL equivalent.
14201         * graphite-clast-to-gimple.c: Likewise.
14202         * graphite-dependences.c: Likewise.
14203         * graphite-interchange.c: Likewise.
14204         * graphite-poly.h: Likewise.
14205         * graphite-poly.c: Likewise.
14206         * graphite-sese-to-poly.c: Likewise.
14207         * graphite.c: Likewise.
14208         * graphite-scop-detection.c: Re-arrange includes.
14209         * graphite-cloog-util.c: Remove.
14210         * graphite-cloog-util.h: Likewise.
14211         * graphite-ppl.h: Likewise.
14212         * graphite-ppl.c: Likewise.
14213         * graphite-dependences.h: Likewise.
14214
14215 2012-07-02  Richard Guenther  <rguenther@suse.de>
14216
14217         Merge from graphite branch
14218         2011-07-21  Tobias Grosser  <tobias@grosser.es>
14219
14220         * Makefile.in (graphite-clast-to-gimple.o, graphite-cloog-util.o):
14221         Remove graphite-cloog-util.h.
14222         * graphite-clast-to-gimple.c (gcc_type_for_iv_of_clast_loop,
14223         build_iv_mapping, translate_clast_user, translate_clast,
14224         free_scattering, initialize_cloog_names, build_cloog_prog,
14225         create_params_index): Do not use old compatibility functions.
14226         (clast_name_to_index, set_cloog_options): Remove code for legacy cloog.
14227         * graphite-cloog-util.c (openscop_print_cloog_matrix): Do not use old
14228         compatibility functions.
14229         (new_Cloog_Scattering_from_ppl_Polyhedron): Remove code for legacy
14230         cloog.
14231         * graphite-cloog-util.h: Remove include of graphite-cloog-util.h.
14232         * graphite.c (graphite.c): Do not call outdated cloog_initialize() and
14233         cloog_finalize().
14234         * graphite-cloog-compat.h: Remove.
14235
14236         2011-08-09  Tobias Grosser <tobias@grosser.es>
14237
14238         * graphite-clast-to-gimple.c (new_clast_name_index): Store a copy
14239         of the string, no just a reference.
14240         (clast_name_index): Add a new field, that specifies if we need to free
14241         the name.
14242         (free_clast_name_index): If necessary, free the name string.
14243         (clast_name_index_elt_info): Calculate the hash based on the string
14244         content, not the memory location it is stored in.
14245         (clast_name_to_level): Specify that we do not need to free the name.
14246         (clast_name_to_index): Dito.
14247         (clast_name_to_lb_ub): Dito.
14248         (eq_clast_name_indexes): Compare the strings, not their base pointers.
14249         (free_scattering): Removed.
14250         (initialize_cloog_names): Renamed to add_names_to_union_domain().
14251         (add_names_to_union_domain): Changed to work on a union_domain,
14252         instead of a CloogNames structure.
14253         (build_cloog_prog): Removed.
14254         (build_cloog_union_domain): New.
14255         (generate_cloog_input): New.
14256         (scop_to_clast): Use CloogInput instead of CloogProgram.
14257         (print_generated_program): Adapt to new scop_to_clast() and do not
14258         print the CloogProgram any more.
14259         (create_params_index): Removed, functionality integrated in
14260         add_names_to_union_domain().
14261         (gloog): Adapt to new scop_to_clast().
14262         * graphite-clast-to-gimple.h (scop_to_clast): Remove.
14263
14264         2012-01-11  Tobias Grosser <tobias@grosser.es>
14265
14266         * graphite-clast-to-gimple.c (clast_name_to_index,
14267         clast_name_to_lb_ub, clast_name_to_gcc): Change types.
14268         (clast_to_gcc_expression): Add clast_expr_name as a new
14269         case. Do not assume a clast_expr_term points always to a
14270         clast_expr_name.
14271         (type_for_clast_term): Do not assume a clast_expr_term points always to
14272         a clast_expr_name.
14273         (type_for_clast_name): New.
14274         (type_for_clast_expr): Add clast_expr_name as a new case.
14275
14276         2011-08-03  Sebastian Pop <sebpop@gmail.com>
14277
14278         * graphite-cloog-util.c (new_Cloog_Domain_from_ppl_Polyhedron,
14279         new_Cloog_Scattering_from_ppl_Polyhedron,
14280         new_Cloog_Domain_from_ppl_Pointset_Powerset): Remove ATTRIBUTE_UNUSED.
14281
14282 2012-07-02  Jakub Jelinek  <jakub@redhat.com>
14283
14284         PR tree-optimization/53645
14285         * tree-vect-generic.c (expand_vector_divmod): Use TYPE_MODE (type)
14286         instead of TYPE_MODE (wider_type) as can_vec_perm_p argument.
14287
14288 2012-07-01  Wei Guozhi  <carrot@google.com>
14289
14290         PR target/53447
14291         * config/arm/arm-protos.h (const_ok_for_dimode_op): New prototype.
14292         * config/arm/arm.c (const_ok_for_dimode_op): New function.
14293         * config/arm/constraints.md (Dd): New constraint.
14294         * config/arm/predicates.md (arm_adddi_operand): New predicate.
14295         * config/arm/arm.md (adddi3): Extend it to handle constants.
14296         (arm_adddi3): Likewise.
14297         (addsi3_carryin_<optab>): Extend it to handle sbc case.
14298         (addsi3_carryin_alt2_<optab>): Likewise.
14299         * config/arm/neon.md (adddi3_neon): Extend it to handle constants.
14300
14301 2012-06-30  Nathan Sidwell  <nathan@acm.org>
14302
14303         * coverage.c (bbg_file_stamp): New.
14304         (read_counts_file): Merge incoming stamp with bbg_file_stamp.
14305         (build_info): Write bbg_file_stamp.
14306         (coverage_init): Initialize bbg_file_stamp.  Read counts file
14307         before writing graph header.
14308         (coverage_finish): Don't unlink the data file if we can generate a
14309         unique file stamp.
14310         * tree.h (crc32_unsigned): Declare.
14311         * tree.c (crc32_unsigned_bits): New, broken out of ...
14312         (crc32_byte): ... here.  Use it.
14313         (crc32_unsigned): New.
14314
14315 2012-06-29  Cary Coutant  <ccoutant@google.com>
14316
14317         * dwarf2out.c (add_pubname_string): Don't check for want_pubnames.
14318         (gen_subprogram_die): Don't add pubname if want_pubnames is false.
14319         (gen_variable_die): Likewise.
14320         (gen_namespace_die): Likewise.
14321
14322 2012-06-29  Eric Botcazou  <ebotcazou@adacore.com>
14323
14324         * tree-eh.c (lower_try_finally_switch): Really put the location of the
14325         last statement of the finally block onto the switch.
14326
14327 2012-06-29  H.J. Lu  <hongjiu.lu@intel.com>
14328
14329         PR target/53539
14330         * config/i386/gnu-user64.h (WCHAR_TYPE): Use "int" only for
14331         TARGET_LP64.
14332
14333 2012-06-29  Sterling Augustine  <saugustine@google.com>
14334
14335         * dwarf2out.c (add_pubname): Add comment.
14336         (add_pubtype): Fix indentation.
14337         (gen_enumeration_type_die): Likewise.
14338
14339 2012-06-29  Jakub Jelinek  <jakub@redhat.com>
14340
14341         * tree-vect-generic.c (expand_vector_divmod): For even/odd
14342         widening multiply, put even always as first argument to VEC_PERM_EXPR.
14343
14344 2012-06-29  Richard Henderson  <rth@redhat.com>
14345
14346         * tree-vect-generic.c: Include target.h.
14347         (expand_vector_divmod): Use builtin_mul_widen_even/odd if supported.
14348         * Makefile.in (tree-vect-generic.o): Update.
14349
14350 2012-06-29  Steven Bosscher  <steven@gcc.gnu.org>
14351
14352         * configure.ac: Remove special gtfiles case for C.
14353         * configure: Regenerate.
14354         * Makefile.in: Remove C front-end hooks and build hooks that
14355         will be picked up from c/Make-lang.in now.
14356         Add tree-mudflap to C_COMMON_OBJS.
14357         * gengtype.c (files_rules): Adjust gt-files for c/c-decl.c.
14358         * config/vms/vms.c: Look for c-tree.h in c/.
14359         * doc/gty.texi: Remove reference to c-config-lang.in.
14360         * doc/sourcebuild.texi: Document the c/ subdirectory.
14361
14362 2012-06-29  Steven Bosscher  <steven@gcc.gnu.org>
14363
14364         * system.h (CASE_USE_BIT_TESTS): Poison.
14365         * stmt.c (CASE_USE_BIT_TESTS): Fold away into its only user ...
14366         (expand_switch_using_bit_tests_p): ...here.
14367         * doc/tm.texi.in (CASE_USE_BIT_TESTS): Remove documentation.
14368         * doc/tm.texi (CASE_USE_BIT_TESTS): Regenerate.
14369
14370 2012-06-29  Steven Bosscher  <steven@gcc.gnu.org>
14371
14372         * system.h (IFCVT_EXTRA_FIELDS): Poison.
14373         (IFCVT_INIT_EXTRA_FIELDS): Poison.
14374         * basic-block.h (struct ce_if_block): Remove IFCVT_EXTRA_FIELDS.
14375         * ifcvt.c (find_if_header): Use IFCVT_MACHDEP_INIT instead of
14376         IFCVT_INIT_EXTRA_FIELDS.
14377         * gengtype-parse.c (struct_field_seq): Remove obsolete comment.
14378         * config/frv/frv.h (IFCVT_INIT_EXTRA_FIELDS): Rename to
14379         IFCVT_MACHDEP_INIT.
14380         * config/frv/frv.c (frv_ifcvt_init_extra_fields): Rename to
14381         frv_ifcvt_machdep_init.
14382         * doc/tm.texi.in (IFCVT_INIT_EXTRA_FIELDS, IFCVT_EXTRA_FIELDS):
14383         Remove documentation.
14384         (IFCVT_MACHDEP_INIT): Document.
14385         * doc/tm.texi: Regenerate.
14386
14387 2012-06-29  Nick Clifton  <nickc@redhat.com>
14388
14389         * config/lm32/lm32.c (lm32_compute_frame_size): Fix typo.
14390
14391 2012-06-29  Jakub Jelinek  <jakub@redhat.com>
14392
14393         * tree-vect-stmts.c (vectorizable_operation): Check both
14394         VEC_WIDEN_MULT_LO_EXPR and VEC_WIDEN_MULT_HI_EXPR optabs.
14395         Verify that operand[0]'s mode is TYPE_MODE (wide_vectype).
14396
14397 2012-06-28  Richard Henderson  <rth@redhat.com>
14398
14399         * doc/generic.texi (MULT_HIGHPART_EXPR): Document it.
14400
14401 2012-06-28  Jakub Jelinek  <jakub@redhat.com>
14402
14403         PR tree-optimization/51581
14404         * tree-vect-stmts.c (permute_vec_elements): Add forward decl.
14405         (vectorizable_operation): Handle vectorization of MULT_HIGHPART_EXPR
14406         also using VEC_WIDEN_MULT_*_EXPR or builtin_mul_widen_* plus
14407         VEC_PERM_EXPR if vector MULT_HIGHPART_EXPR isn't supported.
14408         * tree-vect-patterns.c (vect_recog_divmod_pattern): Use
14409         MULT_HIGHPART_EXPR instead of VEC_WIDEN_MULT_*_EXPR and shifts.
14410
14411         PR tree-optimization/53645
14412         * tree-vect-generic.c (expand_vector_divmod): Use MULT_HIGHPART_EXPR
14413         instead of VEC_WIDEN_MULT_{HI,LO}_EXPR followed by VEC_PERM_EXPR
14414         if possible.
14415
14416 2012-06-28  Georg-Johann Lay  <avr@gjlay.de>
14417
14418         PR 53595
14419         * config/avr/avr.c (avr_hard_regno_call_part_clobbered): New.
14420         * config/avr/avr-protos.h (avr_hard_regno_call_part_clobbered): New.
14421         * config/avr/avr.h (HARD_REGNO_CALL_PART_CLOBBERED): Forward to
14422         avr_hard_regno_call_part_clobbered.
14423
14424 2012-06-28  Richard Guenther  <rguenther@suse.de>
14425
14426         PR middle-end/53790
14427         * expr.c (expand_expr_real_1): Verify if the type is complete
14428         before inspecting its size.
14429
14430 2012-06-28  Andreas Schwab  <schwab@linux-m68k.org>
14431
14432         * doc/include/gpl.texi: Remove.
14433         * doc/sourcebuild.texi (Texinfo Manuals): Don't mention gpl.texi.
14434
14435 2012-06-28  Jakub Jelinek  <jakub@redhat.com>
14436
14437         PR tree-optimization/53645
14438         * tree-vect-generic.c (add_rshift): New function.
14439         (expand_vector_divmod): New function.
14440         (expand_vector_operation): Use it for vector integer
14441         TRUNC_{DIV,MOD}_EXPR by VECTOR_CST.
14442         * tree-vect-patterns.c (vect_recog_divmod_pattern): Replace
14443         unused lguup variable with dummy_int.
14444
14445 2012-06-28  OLivier Hainque  <hainque@adacore.com>
14446
14447         * expr.c (convert_move): Latch mem integer inputs into a
14448         register before expanding a multi-instructions sequence.
14449
14450 2012-06-28  Alexandre Oliva  <aoliva@redhat.com>
14451             Uros Bizjak  <ubizjak@gmail.com>
14452             Jakub Jelinek  <jakub@redhat.com>
14453
14454         PR debug/53706
14455         PR debug/47624
14456         * var-tracking.c (vt_emit_notes): Release loc_exp_dep_pool...
14457         (vt_finalize): ... here instead, if needed.
14458
14459 2012-06-28  Alexandre Oliva  <aoliva@redhat.com>
14460
14461         PR debug/53740
14462         PR debug/52983
14463         PR debug/48866
14464         * dce.c (word_dce_process_block): Check whether inserting debug
14465         temps are needed even for needed insns.
14466         (dce_process_block): Likewise.
14467         * df-problems.c (dead_debug_add): Add comment about multi-regs.
14468         (dead_debug_insert_temp): Likewise.  Don't subreg when we're
14469         setting fewer regs than a multi-reg requires.
14470
14471 2012-06-27  Richard Henderson  <rth@redhat.com>
14472
14473         * config/alpha/alpha.c (alpha_dimode_u): New.
14474         (alpha_init_builtins): Initialize it, and use it.
14475         (alpha_fold_builtin_cmpbge): Use alpha_dimode_u.
14476         (alpha_fold_builtin_zapnot, alpha_fold_builtin_insxx): Likewise.
14477         (alpha_fold_vector_minmax, alpha_fold_builtin_perr): Likewise.
14478         (alpha_fold_builtin_pklb, alpha_fold_builtin_pkwb): Likewise.
14479         (alpha_fold_builtin_unpkbl, alpha_fold_builtin_unpkbw): Likewise.
14480         (alpha_fold_builtin_cttz, alpha_fold_builtin_ctlz): Likewise.
14481         (alpha_fold_builtin_ctpop): Likewise.
14482         (alpha_fold_builtin_umulh): Remove.
14483         (alpha_fold_builtin): Use MULT_HIGHPART_EXPR for UMULH; fix
14484         typo in MAX_ARGS check.
14485
14486 2012-06-27  Richard Henderson  <rth@redhat.com>
14487
14488         * tree.def (MULT_HIGHPART_EXPR): New.
14489         * cfgexpand.c (expand_debug_expr): Ignore it.
14490         * expr.c (expand_expr_real_2): Handle it.
14491         * fold-const.c (int_const_binop_1): Likewise.
14492         * optabs.c (optab_for_tree_code): Likewise.
14493         * tree-cfg.c (verify_gimple_assign_binary): Likewise.
14494         * tree-inline.c (estimate_operator_cost): Likewise.
14495         * tree-pretty-print.c (dump_generic_node): Likewise.
14496         (op_code_prio, op_symbol_code): Likewise.
14497         * tree.c (commutative_tree_code): Likewise.  Also handle
14498         WIDEN_MULT_EXPR, VEC_WIDEN_MULT_HI_EXPR, VEC_WIDEN_MULT_LO_EXPR.
14499
14500 2012-06-27  Richard Henderson  <rth@redhat.com>
14501
14502         PR target/53749
14503         * config/i386/i386.c (ix86_rtx_costs): Fix typo vs UNITS_PER_WORD
14504         in 2012-06-23 change.  Adjust two other DImode tests as well.
14505
14506 2012-06-27  Nick Clifton  <nickc@redhat.com>
14507
14508         * config/rx/rx.md (comparesi3_extend): Remove = modifier from
14509         input operand.
14510
14511 2012-06-27  Richard Guenther  <rguenther@suse.de>
14512
14513         PR middle-end/53676
14514         * tree-chrec.c (chrec_convert_1): Represent truncation to
14515         a type with undefined overflow as truncation to an unsigned
14516         type converted to the type with undefined overflow.
14517         * tree-scalar-evolution.c (interpret_rhs_expr): For computing
14518         the scalar evolution of a truncated widened operation avoid
14519         looking at the non-existing evolution of the widened operation
14520         result.
14521
14522 2012-06-27  Richard Guenther  <rguenther@suse.de>
14523
14524         PR tree-optimization/53774
14525         * tree-ssa-reassoc.c (get_rank): All default defs have
14526         precomputed rank.
14527         (init_reassoc): Precompute rank for all SSA default defs.
14528
14529 2012-06-27  Nick Clifton  <nickc@redhat.com>
14530
14531         * config/rx/rx.md (simple_return): Use the simple_return rtx.
14532
14533 2012-06-26  Richard Henderson  <rth@redhat.com>
14534
14535         * config/i386/i386.c (ix86_rtx_costs): Use standard_sse_constant_p
14536         and don't fall thru from standard_80387_constant_p to the memory
14537         fallback.
14538
14539 2012-06-26  Richard Henderson  <rth@redhat.com>
14540
14541         * config/i386/i386.c (bdesc_args): Update.  Change
14542         IX86_BUILTIN_VEC_WIDEN_SMUL_ODD_V4SI to OPTION_MASK_ISA_SSE2.
14543         (IX86_BUILTIN_VEC_WIDEN_SMUL_EVEN_V4SI): New.
14544         (ix86_builtin_mul_widen_even): Use it.
14545         (ix86_builtin_mul_widen_odd): Relax SMUL_ODD from sse4 to sse2.
14546         (ix86_expand_mul_widen_evenodd): Handle signed for sse2.
14547         * config/i386/sse.md (vec_widen_<s>mult_hi_<V124_AVX2>): Allow
14548         for all SSE2.
14549         (vec_widen_<s>mult_lo_<V124_AVX2>): Likewise.
14550         (vec_widen_<s>mult_odd_<VI4_AVX2>): Likewise.  Relax from V124_AVX2.
14551         (vec_widen_smult_even_v4si): New.
14552
14553 2012-06-26  Richard Henderson  <rth@redhat.com>
14554
14555         * config/i386/sse.md (mul<VI8_AVX2>3): Change from insn_and_split
14556         to expander; move guts to ...
14557         * config/i386/i386.c (ix86_expand_sse2_mulvxdi3): ... here.  Add
14558         highparts before shifting up.
14559         * config/i386/i386-protos.h: Update.
14560
14561 2012-06-26  Steven Bosscher  <steven@gcc.gnu.org>
14562
14563         * system.h (USE_COMMON_FOR_ONE_ONLY): Poison.
14564         * defaults.h (USE_COMMON_FOR_ONE_ONLY): Do not provide default.
14565         * config/darwin.h (USE_COMMON_FOR_ONE_ONLY): Do not define.
14566
14567 2012-06-26  Alexandre Oliva  <aoliva@redhat.com>
14568
14569         * var-tracking.c (vt_add_function_parameter): Use a preserved
14570         VALUE for the MEM address of an incoming parameter.
14571
14572 2012-06-26  Sterling Augustine <saugustine@google.com>
14573
14574         * dwarf2out.c (output_pubnames): Add check for DW_TAG_enumerator.
14575         (prune_unused_types): Likewise.
14576
14577 2012-06-26  Steven Bosscher  <steven@gcc.gnu.org>
14578
14579         * system.h (UNALIGNED_SHORT_ASM_OP, UNALIGNED_INT_ASM_OP,
14580         UNALIGNED_LONG_ASM_OP, UNALIGNED_DOUBLE_INT_ASM_OP): Poison.
14581         * vmsdbgout.c (UNALIGNED_SHORT_ASM_OP, UNALIGNED_INT_ASM_OP,
14582         UNALIGNED_LONG_ASM_OP, UNALIGNED_DOUBLE_INT_ASM_OP): Rename to
14583         VMS_UNALIGNED_SHORT_ASM_OP, VMS_UNALIGNED_INT_ASM_OP,
14584         VMS_UNALIGNED_LONG_ASM_OP, and VMS_UNALIGNED_DOUBLE_INT_ASM_OP.
14585         * config/microblaze/microblaze.h (UNALIGNED_SHORT_ASM_OP,
14586         UNALIGNED_INT_ASM_OP, UNALIGNED_DOUBLE_INT_ASM_OP): Do not define.
14587         * doc/tm.texi.in: Remove UNALIGNED_INT_ASM_OP reference from the
14588         documentation.
14589         * doc/tm.texi: Regenerate.
14590         * doc/cpp.texi: Make example for #error generic.
14591         * config/frv/frv.h: Fix example text to match tm.texi.
14592
14593 2012-06-26  Bill Schmidt  <wschmidt@linux.ibm.com>
14594
14595         * tree-pass.h (pass_strength_reduction): New decl.
14596         * tree-ssa-loop-ivopts.c (initialize_costs): Make non-static.
14597         (finalize_costs): Likewise.
14598         * timevar.def (TV_TREE_SLSR): New timevar.
14599         * gimple-ssa-strength-reduction.c: New.
14600         * tree-flow.h (initialize_costs): New decl.
14601         (finalize_costs): Likewise.
14602         * Makefile.in (tree-ssa-strength-reduction.o): New dependencies.
14603         * passes.c (init_optimization_passes): Add pass_strength_reduction.
14604
14605 2012-06-26  Matt Turner  <mattst88@gmail.com>
14606
14607         * doc/extend.texi (__builtin_arm_tinsrb): Add missing second parameter.
14608         (__builtin_arm_tinsrh): Likewise.
14609         (__builtin_arm_tinsrw): Likewise.
14610         (__builtin_arm_wsadb): Add missing v2si parameter.
14611         (__builtin_arm_wsadh): Likewise.
14612         (__builtin_arm_getwcx): Delete.
14613         (__builtin_arm_setwcx): Delete.
14614         (__builtin_arm_getwcgr0): Add.
14615         (__builtin_arm_getwcgr1): Add.
14616         (__builtin_arm_getwcgr2): Add.
14617         (__builtin_arm_getwcgr3): Add.
14618         (__builtin_arm_setwcgr0): Add.
14619         (__builtin_arm_setwcgr1): Add.
14620         (__builtin_arm_setwcgr2): Add.
14621         (__builtin_arm_setwcgr3): Add.
14622
14623 2012-06-26  Richard Guenther  <rguenther@suse.de>
14624
14625         Revert
14626         2012-06-21  Richard Guenther  <rguenther@suse.de>
14627
14628         * tree-inline.c (estimate_num_insns): Estimate call cost for
14629         tailcalls properly.
14630
14631 2012-06-26  Steven Bosscher  <steven@gcc.gnu.org>
14632
14633         PR other/33190
14634         * doc/tm.texi.in: Document LOGICAL_OP_NON_SHORT_CIRCUIT.
14635         * doc/tm.texi: Regenerate.
14636
14637 2012-06-26  Steven Bosscher  <steven@gcc.gnu.org>
14638
14639         PR other/33190
14640         * config/mips/mips.h: Do not define ALL_COP_ADDITIONAL_REGISTER_NAMES.
14641         * config/frv/frv.h: Do not define REVERSE_CONDEXEC_PREDICATES_P.
14642         * doc/tm.texi.in: Remove documentation for unused target macros
14643         ALL_COP_ADDITIONAL_REGISTER_NAMES, DBX_OUTPUT_LBRAC, DBX_OUTPUT_NFUN,
14644         DBX_OUTPUT_RBRAC, RANGE_TEST_NON_SHORT_CIRCUIT, REAL_VALUE_TRUNCATE,
14645         REVERSE_CONDEXEC_PREDICATES_P, TARGET_ALIGN_ANON_BITFIELDS, and
14646         TARGET_NARROW_VOLATILE_BITFIELDS.
14647         Document that MD_HANDLE_UNWABI is a macro in libgcc.
14648         * doc/tm.texi: Regenerate.
14649         * system.h: Poison target macros
14650         ALL_COP_ADDITIONAL_REGISTER_NAMES, DBX_OUTPUT_LBRAC, DBX_OUTPUT_NFUN,
14651         DBX_OUTPUT_RBRAC, RANGE_TEST_NON_SHORT_CIRCUIT, REAL_VALUE_TRUNCATE,
14652         REVERSE_CONDEXEC_PREDICATES_P, TARGET_ALIGN_ANON_BITFIELDS, and
14653         TARGET_NARROW_VOLATILE_BITFIELDS
14654
14655 2012-06-26  Jan Hubicka  <jh@suse.cz>
14656
14657         PR lto/53572
14658         * cgraph.h (varpool_can_remove_if_no_refs): Fix handling of
14659         used symbols.
14660
14661 2012-06-26  Dehao Chen  <dehao@google.com>
14662
14663         * tree-inline.c: (expand_call_inline): Ensure that lexical block's
14664         source location is consistant with the call stmt.
14665
14666 2012-06-26  Ulrich Weigand  <ulrich.weigand@linaro.org>
14667
14668         PR tree-optimization/53729
14669         PR tree-optimization/53636
14670         * tree-vect-slp.c (vect_slp_analyze_bb_1): Delay call to
14671         vect_verify_datarefs_alignment until after statements have
14672         been marked as relevant/irrelevant.
14673         * tree-vect-data-refs.c (vect_verify_datarefs_alignment):
14674         Skip irrelevant statements.
14675         (vect_enhance_data_refs_alignment): Use STMT_VINFO_RELEVANT_P
14676         instead of STMT_VINFO_RELEVANT.
14677         (vect_get_data_access_cost): Do not check for supportable
14678         alignment before calling vect_get_load_cost/vect_get_store_cost.
14679         * tree-vect-stmts.c (vect_get_store_cost): Do not abort when
14680         handling unsupported alignment.
14681         (vect_get_load_cost): Likewise.
14682
14683 2012-06-25  Steven Bosscher  <steven@gcc.gnu.org>
14684
14685         * config/rl78/rl78.h: Do not undefine DONT_USE_BUILTIN_SETJMP.
14686         Do not define JMP_BUF_SIZE.
14687
14688 2012-06-26  Jakub Jelinek  <jakub@redhat.com>
14689
14690         PR tree-optimization/53748
14691         * tree-ssa-phiopt.c (conditional_replacement): Only optimize
14692         if arg0/arg1 have integral or pointer types.
14693
14694 2012-06-25  Richard Henderson  <rth@redhat.com>
14695
14696         * config/i386/sse.md (sse2_sse4_1): Remove code attr.
14697         (<s>dot_prodv4si, <s>dot_prodv8si): Remove
14698         (sdot_prodv4si): New; handle only XOP.
14699
14700 2012-06-25  Richard Henderson  <rth@redhat.com>
14701
14702         * config/i386/i386-builtin-types.def (V4UDI, V8USI): New.
14703         (V2UDI_FUNC_V4USI_V4USI): New.
14704         (V4UDI_FUNC_V8USI_V8USI): New.
14705         * config/i386/i386.c (ix86_expand_args_builtin): Handle them.
14706         (IX86_BUILTIN_VEC_WIDEN_SMUL_ODD_V4SI): New.
14707         (IX86_BUILTIN_VEC_WIDEN_SMUL_ODD_V8SI): New.
14708         (IX86_BUILTIN_VEC_WIDEN_UMUL_ODD_V4SI): New.
14709         (IX86_BUILTIN_VEC_WIDEN_UMUL_ODD_V8SI): New.
14710         (IX86_BUILTIN_VEC_WIDEN_UMUL_EVEN_V4SI): New.
14711         (IX86_BUILTIN_VEC_WIDEN_UMUL_EVEN_V8SI): New.
14712         (bdesc_args): Add them.
14713         (ix86_builtin_mul_widen_even, ix86_builtin_mul_widen_odd): New.
14714         (TARGET_VECTORIZE_BUILTIN_MUL_WIDEN_EVEN): New.
14715         (TARGET_VECTORIZE_BUILTIN_MUL_WIDEN_ODD): New.
14716         (ix86_expand_mul_widen_evenodd): Use xop_pmacsdqh.
14717         * config/i386/sse.md (vec_widen_<s>mult_odd_<V124_AVX2>): New.
14718
14719 2012-06-25  Richard Henderson  <rth@redhat.com>
14720
14721         * config/i386.sse.md (mul<VI4_AVX2>3): Use xop_pmacsdd.
14722
14723 2012-06-25  Richard Henderson  <rth@redhat.com>
14724
14725         * config/i386/i386.c (ix86_rtx_costs) [MULT]: Only apply XOP cost
14726         to V16QImode.
14727         (ix86_expand_vec_interleave): New.
14728         (ix86_expand_mul_widen_evenodd): New.
14729         (ix86_expand_mul_widen_hilo): New.
14730         (ix86_expand_sse2_mulv4si3): Use ix86_expand_mul_widen_evenodd.
14731         * config/i386/i386.md (u_bool) New code attr.
14732         * config/i386/predicates.md
14733         (nonimmediate_or_const_vector_operand): Remove.
14734         * config/i386/sse.md (mul<VI4_AVX2>3): Don't use it; don't test
14735         both AVX and SSE4_1.
14736         (vec_widen<s>mult_hi_<VI2_AVX2>): Remove.
14737         (vec_widen<s>mult_lo_<VI2_AVX2>): Remove.
14738         (vec_widen<s>mult_hi_v8si): Remove.
14739         (vec_widen<s>mult_lo_v8si): Remove.
14740         (vec_widen_smult_hi_v4si): Remove.
14741         (vec_widen_smult_lo_v4si): Remove.
14742         (vec_widen_umult_hi_v4si): Remove.
14743         (vec_widen_umult_lo_v4si): Remove.
14744         (vec_widen_<s>mult_hi_<VI124_AVX2>): New.
14745         (vec_widen_<s>mult_lo_<VI124_AVX2>): New.
14746         * config/i386/i386-protos.h: Update.
14747
14748 2012-06-25  Christophe Lyon  <christophe.lyon@st.com>
14749
14750         * config/arm/neon.md (UNSPEC_VLD1_DUP): Remove.
14751         (neon_vld1_dup): Restrict to VQ operands.
14752         (neon_vld1_dupv2di): New, fixes vld1q_dup_s64.
14753
14754 2012-06-25  Matthew Gretton-Dann  <matthew.gretton-dann@arm.com>
14755             James Greenhalgh  <james.greenhalgh@arm.com>
14756
14757         * config/arm/arm.h (TARGET_CPU_CPP_BUILTINS): Add new built-ins.
14758         (TARGET_FMA): New macro.
14759         (TARGET_ARM_QBIT, TARGET_ARM_SAT): Likewise.
14760         (TARGET_ARM_ARCH): Likewise.
14761         (TARGET_ARM_ARCH_ISA_THUMB): Likewise.
14762         (TARGET_V6M, TARGET_V7M): Likewise.
14763         (TARGET_ARM_ARCH_PROFILE): Likewise.
14764         (TARGET_ARM_FEATURE_LDREX): Likewise.
14765         (TARGET_ARM_FP, TARGET_NEON_FP): Likewise.
14766         (ARM_MIN_ENUM_SIZE): Likewise.
14767         * config/arm/arm.c (arm_file_start): Refactor appropriately.
14768         (base_architecture): New enumeration.
14769         (arm_base_arch): New global variable.
14770         (processors): Add field base_arch.
14771         (ARM_ARCH, ARM_CORE): Adjust accordingly.
14772         (arm_option_override): Add initialization of arm_base_arch.
14773         * doc/cpp.texi (system-specific predefined macros.): Change.
14774
14775 2012-06-25  Jakub Jelinek  <jakub@redhat.com>
14776
14777         PR target/53759
14778         * config/i386/sse.md (sse_loadlps): Use x m x constraints instead
14779         of x x x in the vmovlps load alternative.
14780
14781 2012-06-25  Richard Sandiford  <rdsandiford@googlemail.com>
14782
14783         PR debug/53740
14784         * df.h (dead_debug_add): Remove third argument.
14785         * df-problems.c (dead_debug_add): Likewise.  Use the REGNO of the
14786         REG that we want to replace instead.
14787         (dead_debug_insert_temp): Use the REGNO of the reg that we want
14788         to replace instead of DF_REF_REGNO.  Require there to always be
14789         at least one such use.  Check for cases where the same location
14790         has more than df_ref associated with it.
14791         (df_note_bb_compute): Remove third dead_debug_add argument.
14792         * dce.c (word_dce_process_block): Likewise.
14793
14794 2012-06-25  Steven Bosscher  <steven@gcc.gnu.org>
14795
14796         * config/v850/v850.c: Remove redundant extern declarations for
14797         last_assemble_variable_decl and size_directive_output.
14798
14799         * doc/tm.texi.in: Document JMP_BUF_SIZE.
14800         * doc/tm.texi: Regenerate.
14801         * config/sparc/sparc.h (JMP_BUF_SIZE): Do not define.
14802         * config/pa/pa.h (JMP_BUF_SIZE): Likewise.
14803         * config/stormy16/stormy16.h: Likewise.
14804
14805         * config/picochip/picochip.c: Do not define DONT_USE_BUILTIN_SETJMP.
14806
14807         * doc/sourcebuild.texi: Add missing subdirectories.
14808
14809 2012-06-25  Tristan Gingold  <gingold@adacore.com>
14810
14811         * config/i386/i386.h: Fix typo.
14812
14813 2012-06-25  Tristan Gingold  <gingold@adacore.com>
14814
14815         * config/i386/winnt.c (i386_pe_seh_end_prologue): Move code to ...
14816         (seh_cfa_adjust_cfa): ... that function.
14817         (seh_emit_stackalloc): Do not emit out of range values.
14818         * config/i386/i386.md: Delete unused UNSPEC_REG_SAVE,
14819         UNSPEC_DEF_CFA constants.
14820         * config/i386/i386.h (SEH_MAX_FRAME_SIZE): Define.
14821         * config/i386/i386.c (ix86_frame_pointer_required): Required
14822         for very large frames on SEH target.
14823         (ix86_compute_frame_layout): Save area is before frame pointer
14824         on SEH target.  Handle very large frames.
14825         (ix86_expand_prologue): Likewise.
14826
14827 2012-06-24  Steven Bosscher  <steven@gcc.gnu.org>
14828
14829         * output.h: (current_function_is_leaf,
14830         current_function_sp_is_unchanging,
14831         current_function_uses_only_leaf_regs): Remove.
14832         * function.c (current_function_is_leaf,
14833         current_function_sp_is_unchanging,
14834         current_function_uses_only_leaf_regs): Remove.
14835         (rest_of_handle_check_leaf_regs): Set crtl->uses_only_leaf_regs
14836         instead of current_function_uses_only_leaf_regs.
14837         * function.h (struct rtl_data): New fields sp_is_unchanging,
14838         is_leaf, uses_only_leaf_regs.
14839         * resource.c (init_resource_info): Replace current_function_is_leaf,
14840         current_function_sp_is_unchanging, and
14841         current_function_uses_only_leaf_regs with new crtl fields.
14842         * sdbout.c (sdbout_symbol): Likewise.
14843         * df-core.c (rest_of_handle_df_initialize): Likewise.
14844         * ira.c (ira): Likewise.
14845         * final.c (final_start_function): Likewise.
14846         * reorg.c (fill_simple_delay_slots): Likewise.
14847         * regrename.c (check_new_reg_p): Likewise.
14848         * stack-ptr-mod.c (notice_stack_pointer_modification_1): Likewise.
14849         (notice_stack_pointer_modification): Likewise.
14850         * dbxout.c (dbxout_symbol): Likewise.
14851         (dbxout_parms): Likewise.
14852         * sel-sched.c (init_regs_for_mode): Likewise.
14853         * dwarf2out.c (dbx_reg_number): Likewise.
14854         (multiple_reg_loc_descriptor): Likewise.
14855         * config/i386/i386.c (ix86_frame_pointer_required): Likewise.
14856         (gen_pop): Likewise.
14857         (ix86_select_alt_pic_regnum): Likewise.
14858         (ix86_compute_frame_layout): Likewise.
14859         (ix86_finalize_stack_realign_flags): Likewise.
14860         (ix86_expand_epilogue): Likewise.
14861         * config/rs6000/rs6000.c (rs6000_stack_info): Likewise.
14862         * config/h8300/h8300.c (byte_reg): Likewise.
14863         * config/c6x/c6x.c (must_reload_pic_reg_p): Likewise.
14864         (c6x_save_reg): Likewise.
14865         (c6x_compute_frame_layout): Likewise.
14866         * config/pa/pa.c (pa_compute_frame_size): Likewise.
14867         (pa_output_function_prologue): Likewise.
14868         * config/stormy16/stormy16.c (struct xstormy16_stack_layout): Likewise.
14869         * config/sparc/sparc.md (attr "leaf_function"): Likewise.
14870         * config/sparc/sparc.c (sparc_initial_elimination_offset): Likewise.
14871         (sparc_expand_prologue): Likewise.
14872         (sparc_flat_expand_prologue): Likewise.
14873         (sparc_asm_function_prologue): Likewise.
14874         (sparc_output_mi_thunk): Likewise.
14875         (sparc_frame_pointer_required): Likewise.
14876         * config/epiphany/epiphany.c (epiphany_compute_function_type):
14877         Likewise.
14878         (epiphany_compute_frame_size): Likewise.
14879         * config/lm32/lm32.c (lm32_compute_frame_size): Likewise.
14880         * config/cris/cris.c (cris_md_asm_clobbers): Likewise.
14881         (cris_frame_pointer_required): Likewise.
14882         * config/tilepro/tilepro.c (emit_sp_adjust): Likewise.
14883         (tilepro_current_function_is_leaf): Likewise.
14884         * config/arm/arm.c (arm_compute_save_reg0_reg12_mask): Likewise.
14885         * config/pdp11/pdp11.c (pdp11_expand_epilogue): Likewise.
14886         * config/ia64/ia64.c (find_gr_spill): Likewise.
14887         (ia64_compute_frame_size): Likewise.
14888         (ia64_can_eliminate): Likewise.
14889         (ia64_initial_elimination_offset): Likewise.
14890         * config/m68k/m68k.c (m68k_save_reg): Likewise.
14891         (m68k_expand_epilogue): Likewise.
14892         * config/rx/rx.c (rx_get_stack_layout): Likewise.
14893         * config/tilegx/tilegx.c (tilegx_current_function_is_leaf): Likewise.
14894         * config/picochip/picochip.c (picochip_can_eliminate_link_sp_save):
14895         Likewise.
14896         (picochip_output_frame_debug): Likewise.
14897         * config/sh/sh.c (sh_media_register_for_return): Likewise.
14898         (sh_allocate_initial_value): Likewise.
14899         (sh_output_mi_thunk): Likewise.
14900         * config/microblaze/microblaze.c (microblaze_must_save_register):
14901         Likewise.
14902         (compute_frame_size): Likewise.
14903         (microblaze_initial_elimination_offset): Likewise.
14904         (microblaze_expand_prologue): Likewise.
14905         (microblaze_expand_epilogue): Likewise.
14906         * config/frv/frv.c (frv_expand_epilogue): Likewise.
14907         (frv_frame_pointer_required): Likewise.
14908         * config/spu/spu.c (get_pic_reg): Likewise.
14909         (direct_return): Likewise.
14910         (spu_expand_prologue): Likewise.
14911         (spu_expand_epilogue): Likewise.
14912         (spu_initial_elimination_offset): Likewise.
14913         * config/mips/mips.c (mips_global_pointer): Likewise.
14914         (mips_cfun_might_clobber_call_saved_reg_p): Likewise.
14915         (mips_compute_frame_info): Likewise.
14916         * config/mep/mep.c (mep_interrupt_saved_reg): Likewise.
14917         (mep_reload_pointer): Likewise.
14918         * config/rl78/rl78.c (need_to_save): Likewise.
14919         * config/cr16/cr16.c (cr16_compute_save_regs): Likewise.
14920         * config/score/score.c (score_compute_frame_size): Likewise.
14921         (score_function_prologue): Likewise.
14922         * config/bfin/bfin.c (must_save_p): Likewise.
14923         (expand_prologue_reg_save): Likewise.
14924         (expand_epilogue_reg_restore): Likewise.
14925         (bfin_frame_pointer_required): Likewise.
14926         (n_regs_saved_by_prologue): Likewise.
14927         (add_to_reg): Likewise.
14928         (expand_interrupt_handler_prologue): Likewise.
14929         (expand_interrupt_handler_epilogue): Likewise.
14930         (bfin_expand_prologue): Likewise.
14931         * config/avr/avr.c (avr_regs_to_save): Likewise.
14932         (avr_prologue_setup_frame): Likewise.
14933         (expand_epilogue): Likewise.
14934         * config/s390/s390.c (s390_regs_ever_clobbered): Likewise.
14935         (s390_register_info): Likewise.
14936         (s390_frame_info): Likewise.
14937         (s390_init_frame_layout): Likewise.
14938         (s390_emit_prologue): Likewise.
14939
14940
14941 2012-06-24  Steven Bosscher  <steven@gcc.gnu.org>
14942
14943         * system.h: Poison ASM_BYTE_OP and ASM_OUTPUT_BYTE.
14944         * vmsdbgout: Do not undefine it if defined.
14945         Rename local ASM_BYTE_OP definition to VMS_ASM_BYTE_OP.
14946         * config/microblaze/microblaze/h: Do no define ASM_BYTE_OP.
14947         * config/mep/mep.h: Do not define ASM_OUTPUT_BYTE.
14948
14949 2012-06-24  Richard Sandiford  <rdsandiford@googlemail.com>
14950
14951         * config/mips/mips.c (mips_process_sync_loop): Add missing enum cast.
14952
14953 2012-06-23  Richard Henderson  <rth@redhat.com>
14954
14955         PR target/53749
14956         * config/i386/i386.c (ix86_rtx_costs): Add reasonable costs for
14957         V*QImode shifts and multiply.
14958         (ix86_expand_vecop_qihi): Support shifts.
14959         * config/i386/i386.md (any_shift): New code iterator.
14960         * config/i386/sse.md (ashlv16qi3): Merge ...
14961         (<any_shiftrt>v16qi3): ... into ...
14962         (<any_shift><VI1_AVX2>3): ... here.  Use ix86_expand_vecop_qihi
14963         to support SSE and AVX.
14964
14965         * config/i386/i386.c (ix86_expand_sse_unpack): Split operands[]
14966         parameter into src and dest.
14967         * config/i386/sse.md (vec_unpacku_hi_<V124_AVX2>): Update call.
14968         (vec_unpacks_hi_<V124_AVX2>): Likewise.
14969         (vec_unpacku_lo_<V124_AVX2>): Likewise.
14970         (vec_unpacks_lo_<V124_AVX2>): Likewise.
14971         * config/i386/i386-protos.h: Update.
14972
14973         * config/i386/sse.md (mul<VI1_AVX2>3): Change from insn_and_split to
14974         pure expander; move expansion code ...
14975         * config/i386/i386.c (ix86_expand_vecop_qihi): ... here.  New function.
14976         * config/i386/i386-protos.h: Update.
14977
14978 2012-06-22  Edmar Wienskoski  <edmar@freescale.com>
14979
14980         * config/rs6000/rs6000.md (define_attr "type"): New type popcnt.
14981         (popcntb<mode>2): Add attribute type popcnt.
14982         (popcntd<mode>2): Ditto.
14983         * config/rs6000/power4.md (define_insn_reservation): Add type popcnt.
14984         * config/rs6000/power5.md (define_insn_reservation): Ditto.
14985         * config/rs6000/power7.md (define_insn_reservation): Ditto.
14986         * config/rs6000/476.md (define_insn_reservation): Ditto.
14987         * config/rs6000/power6.md (define_insn_reservation): New
14988         reservation for popcnt instructions.
14989
14990 2012-06-22  H.J. Lu  <hongjiu.lu@intel.com>
14991
14992         * doc/invoke.texi: Update -mpreferred-stack-boundary=3 warning.
14993
14994 2012-06-22  H.J. Lu  <hongjiu.lu@intel.com>
14995
14996         PR target/53383
14997         * doc/invoke.texi: Add a warning for -mpreferred-stack-boundary=3.
14998
14999         * config/i386/i386.c (ix86_option_override_internal): Allow
15000         -mpreferred-stack-boundary=3 for 64-bit if SSE is disabled.
15001
15002         * config/i386/i386.h (MIN_STACK_BOUNDARY): Set to 64 for 64-bit
15003         if SSE is disabled.
15004
15005 2012-06-22  Bill Schmidt  <wschmidt@linux.ibm.com>
15006
15007         * double-int.c (double_int_multiple_of): New function.
15008         * double-int.h (double_int_multiple_of): New decl.
15009         * tree-ssa-loop-ivopts.c (add_cost, zero_cost): Remove undefs.
15010         (mbc_entry_hash): New forward decl.
15011         (mbc_entry_eq): Likewise.
15012         (zero_cost): Change to no_cost.
15013         (mult_costs): New static var.
15014         (cost_tables_exist): Likewise.
15015         (initialize_costs): New function.
15016         (finalize_costs): Likewise.
15017         (tree_ssa_iv_optimize_init): Call initialize_costs.
15018         (add_cost): Change to add_regs_cost; distinguish costs by speed.
15019         (multiply_regs_cost): New function.
15020         (add_const_cost): Likewise.
15021         (extend_or_trunc_reg_cost): Likewise.
15022         (negate_reg_cost): Likewise.
15023         (multiply_by_cost): Change to multiply_by_const_cost; distinguish
15024         costs by speed.
15025         (get_address_cost): Change add_cost to add_regs_cost; change
15026         multiply_by_cost to multiply_by_const_cost.
15027         (force_expr_to_var_cost): Change zero_cost to no_cost; change
15028         add_cost to add_regs_cost; change multiply_by_cost to
15029         multiply_by_const_cost.
15030         (split_cost): Change zero_cost to no_cost.
15031         (ptr_difference_cost): Likewise.
15032         (difference_cost): Change zero_cost to no_cost; change multiply_by_cost
15033         to multiply_by_const_cost.
15034         (get_computation_cost_at): Change add_cost to add_regs_cost; change
15035         multiply_by_cost to multiply_by_const_cost.
15036         (determine_use_iv_cost_generic): Change zero_cost to no_cost.
15037         (determine_iv_cost): Change add_cost to add_regs_cost.
15038         (iv_ca_new): Change zero_cost to no_cost.
15039         (tree_ssa_iv_optimize_finalize): Call finalize_costs.
15040         * tree-ssa-address.c (most_expensive_mult_to_index): Change
15041         multiply_by_cost to multiply_by_const_cost.
15042         * tree-flow.h (multiply_by_cost): Change to multiply_by_const_cost.
15043         (add_regs_cost): New decl.
15044         (multiply_regs_cost): Likewise.
15045         (add_const_cost): Likewise.
15046         (extend_or_trunc_reg_cost): Likewise.
15047         (negate_reg_cost): Likewise.
15048
15049 2012-06-22  Richard Guenther  <rguenther@suse.de>
15050
15051         Merge from graphite branch
15052         2011-08-10  Sebastian Pop <sebpop@gmail.com>
15053
15054         * graphite-sese-to-poly.c (build_scop_drs): Fix memory leak.
15055
15056         2012-01-13  Tobias Grosser  <tobias@grosser.es>
15057
15058         * tree-flow.h (parallelized_function_p): Declare.
15059         * tree-parloops.c (parallelized_function_p): Export.
15060         * graphite.c (graphite_transform_loops): Do not run graphite on
15061         already parallel functions.
15062
15063 2012-06-22  Alan Modra  <amodra@gmail.com>
15064
15065         * config/rs6000/rs6000.c (rs6000_pre_atomic_barrier): Pass in and
15066         return mem.  Convert to indirect addressing if not indirect or
15067         indexed.  Adjust all callers.
15068
15069 2012-06-22  Richard Guenther  <rguenther@suse.de>
15070
15071         * gcov-iov.c: Include bconfig.h and system.h.
15072
15073 2012-06-22  Andreas Schwab  <schwab@linux-m68k.org>
15074
15075         * doc/include/texinfo.tex: Update to version 2012-06-05.14.
15076
15077 2012-06-22  Richard Guenther  <rguenther@suse.de>
15078
15079         PR gcov-profile/53744
15080         * gcov-iov.c (main): Treat "" and "prerelease" the same.
15081
15082 2012-06-22  Eric Botcazou  <ebotcazou@adacore.com>
15083
15084         PR debug/53704
15085         * dwarf2out.c (gen_compile_unit_die): Use DW_LANG_Fortran90 as language
15086         for GNU Fortran if in strict DWARF2 mode.
15087
15088 2012-06-22  Eric Botcazou  <ebotcazou@adacore.com>
15089
15090         * tree-ssa-live.c (remove_unused_scope_block_p): Remove again
15091         DECL_IGNORED_P non-reg vars even if they are used.
15092
15093 2012-06-21  Alexandre Oliva  <aoliva@redhat.com>
15094
15095         PR debug/53671
15096         PR debug/49888
15097         * var-tracking.c (vt_get_canonicalize_base): New.
15098         (vt_canonicalize_addr, vt_stack_offset_p): New.
15099         (vt_canon_true_dep): New.
15100         (drop_overlapping_mem_locs): Use vt_canon_true_dep.
15101         (clobber_overlaping_mems): Use vt_canonicalize_addr.
15102
15103 2012-06-21  Alexandre Oliva  <aoliva@redhat.com>
15104
15105         PR debug/53671
15106         PR debug/49888
15107         * var-tracking.c (vt_initialize): Record initial offset between
15108         arg pointer and stack pointer.
15109
15110 2012-06-21  Alexandre Oliva  <aoliva@redhat.com>
15111
15112         PR debug/53671
15113         PR debug/49888
15114         * var-tracking.c (vt_init_cfa_base): Drop redundant recording of
15115         CFA base.
15116
15117 2012-06-21  Alexandre Oliva  <aoliva@redhat.com>
15118
15119         PR debug/53671
15120         PR debug/49888
15121         * alias.c (memrefs_conflict_p): Improve handling of AND for alignment.
15122
15123 2012-06-21  Alexandre Oliva  <aoliva@redhat.com>
15124
15125         * ddg.c (build_intra_loop_deps): Discard deps of nondebug on debug.
15126
15127 2012-06-21  Alexandre Oliva  <aoliva@redhat.com>
15128
15129         PR debug/53682
15130         * cselib.c (promote_debug_loc): Don't crash on NULL argument.
15131
15132 2012-06-21  Meador Inge  <meadori@codesourcery.com>
15133
15134         PR c/53702
15135         * c-decl.c (c_push_function_context): Restore the behavior to reuse
15136         the language function allocated for -Wunused-local-typedefs.
15137         (c_pop_function_context): If necessary, clear the language function
15138         created in c_push_function_context.  Always clear out the
15139         x_cur_stmt_list field of the restored language function.
15140
15141 2012-06-21  Sterling Augustine  <saugustine@google.com>
15142             Cary Coutant  <ccoutant@google.com>
15143
15144         * dwarf2out.c (is_cu_die, is_namespace_die, is_class_die,
15145         add_AT_pubnames, add_enumerator_pubname, want_pubnames): New functions.
15146         (comdat_type_struct): New field 'skeleton_die'.
15147         (breakout_comdat_types): Update it.
15148         (add_pubname): Rework logic.  Call is_class_die, is_cu_die and
15149         is_namespace_die.  Fix minor style violation.  Call want_pubnames.
15150         (add_pubname_string): Call want_pubnames.
15151         (add_pubtype): Rework logic for calculating type name.  Call
15152         is_namespace_die.  Call want_pubnames.
15153         (output_pubnames): Move conditional logic deciding when to produce the
15154         section from dwarf2out_finish.  Use new skeleton_die field.
15155         (base_type_die): Call add_pubtype.
15156         (gen_enumeration_type_die): Unconditionally call add_pubtype.
15157         (gen_subprogram_die): Adjust calls to add_pubname.
15158         (gen_namespace_die): Call add_pubname_string.
15159         (dwarf2out_finish): Call add_AT_pubnames; Move logic on when to
15160         produce pubnames and pubtypes sections to output_pubnames.
15161         * common.opt (-gpubnames): New option.
15162         * doc/invoke.texi: Document it.
15163
15164 2012-06-21  Steven Bosscher  <steven@gcc.gnu.org>
15165
15166         * config/m32c/m32c-pragma.c: Remove unnecessary includes.
15167
15168 2012-06-21  Michael Matz  <matz@suse.de>
15169
15170         PR middle-end/53688
15171         * builtins.c (get_memory_rtx): Always build an all-aliasing MEM_REF
15172         with correct size.
15173
15174 2012-06-21  Richard Guenther  <rguenther@suse.de>
15175
15176         * tree-inline.c (estimate_num_insns): Estimate call cost for
15177         tailcalls properly.
15178
15179 2012-06-20  Rüdiger Sonderfeld  <ruediger@c-plusplus.de>
15180
15181         * tree.h (DECL_SOURCE_COLUMN): New accessor.
15182
15183 2012-06-20  Uros Bizjak  <ubizjak@gmail.com>
15184
15185         * config/i386/i386.md (SINCOS): New int iterator.
15186         (sincos): New int attribute.
15187         (*<sincos>xf2_i387): Macroize insn from *{sin,cos}xf2_i387 using
15188         SINCOS int iterator.
15189         (*<sincos>_extend<mode>xf2_i387): Macroize insn from
15190         *{sin,cos}_extend<mode>xf2_i387 using SINCOS int iterator.
15191
15192 2012-06-20  Uros Bizjak  <ubizjak@gmail.com>
15193
15194         * config/i386/i386.md (RDFSGSBASE): New int iterator.
15195         (WRFSGSBASE): Ditto.
15196         (fsgs): New int attribute.
15197         (rd<fsgs>base<mode>): Macroize insn from rd<fsgs>base<mode> using
15198         RDFSGSBASE int iterator.
15199         (wr<fsgs>base<mode>): Macroize insn from wr<fsgs>base<mode> using
15200         WRFSGSBASE int iterator.
15201
15202 2012-06-20  Uros Bizjak  <ubizjak@gmail.com>
15203
15204         * config/i386/i386.md (<rounding_insn><mode>2): Macroize expander
15205         from {floor,ceil,btrunc}<mode>2 using FIST_ROUNDING int iterator.
15206         (l<rounding_insn><MODEF:mode><SWI48:mode>2): Macroize expander
15207         from l{floor,ceil}<MODEF:mode><SWI48:mode>2 using FIST_ROUNDING
15208         int iterator.
15209
15210 2012-06-20  Steven Bosscher  <steven@gcc.gnu.org>
15211
15212         * system.h: Poison ASM_OUTPUT_IDENT and IDENT_ASM_OP.
15213
15214 2012-06-20  Richard Guenther  <rguenther@suse.de>
15215
15216         PR tree-optimization/30318
15217         * tree-vrp.c (range_int_cst_p): Do not reject overflowed
15218         constants here.
15219         (range_int_cst_singleton_p): But explicitely here.
15220         (zero_nonzero_bits_from_vr): And here.
15221         (extract_range_from_binary_expr_1): Re-implement PLUS_EXPR
15222         to cover all cases we can perform arbitrary precision
15223         arithmetic with double-ints.
15224         (intersect_ranges): Handle adjacent anti-ranges.
15225
15226 2012-06-20  Uros Bizjak  <ubizjak@gmail.com>
15227
15228         * config/i386/i386.md (rounding_insn): New int attribute.
15229         (<rounding_insn>xf2): Macroize insn from
15230         {floor,ceil,btrunc}xf2 using FRNDINT_ROUNDING int iterator.
15231         (l<rounding_insn>xf<mode>2): Rename from l<rounding>xf<mode>2.
15232
15233 2012-06-20  Uros Bizjak  <ubizjak@gmail.com>
15234
15235         * config/i386/i386.md (IEEE_MAXMIN): New int iterator.
15236         (ieee_maxmin): New int attribute.
15237         (*ieee_s<ieee_maxmin><mode>3): Macroize insn from
15238         *ieee_s{max,min}<mode>3 using IEEE_MAXMIN int iterator.
15239
15240 2012-06-20  Steven Bosscher  <steven@gcc.gnu.org>
15241
15242         * config/arm/arm.h (EMIT_EABI_ATTRIBUTE): Remove.
15243         * config/arm/arm.c: Do not include c-pragma.h.
15244         (arm_emit_eabi_attribute): New function based on EMIT_EABI_ATTRIBUTE.
15245         (arm_file_start): Replace uses of EMIT_EABI_ATTRIBUTE with calls
15246         to arm_emit_eabi_attribute.
15247         * arm-c.c: Do not include output.h.
15248         (arm_output_c_attributes): Replace use of EMIT_EABI_ATTRIBUTE with a
15249         call to arm_emit_eabi_attribute.
15250         * config/arm/arm-protos.h (arm_emit_eabi_attribute): Prototype it.
15251
15252 2012-06-20  Richard Guenther  <rguenther@suse.de>
15253
15254         * tree-vect-data-refs.c (vect_can_force_dr_alignment_p):
15255         Allow adjusting alignment of user-aligned decls again.
15256
15257 2012-06-20  Steven Bosscher  <steven@gcc.gnu.org>
15258
15259         * config/rl78/rl78-c.c: Remove unnecessary includes.
15260
15261 2012-06-20  Steven Bosscher  <steven@gcc.gnu.org>
15262
15263         * config/cris/cris.c: Include cgraph.h.
15264         (cris_option_override): Do not set non-existing flag_no_gcc_ident.
15265
15266 2012-06-19  Maxim Kuvyrkov  <maxim@codesourcery.com>
15267
15268         * emit-rtl.c (need_atomic_barrier_p): New function.
15269         * emit-rtl.h (need_atomic_barrier_p): Declare it.
15270         * config/alpha/alpha.c (alpha_{pre,post}_atomic_barrier): Use it.
15271         * config/arm/arm.c (arm_{pre,post}_atomic_barrier): Use it.
15272         * config/tilegx/tilegx.c (tile_{pre,post}_atomic_barrier): Use it.
15273         * config/mips/mips.c (mips_{pre,post}_atomic_barrier_p): Remove.
15274         (mips_process_sync_loop): Use generic version instead.
15275
15276 2012-06-19  Maxim Kuvyrkov  <maxim@codesourcery.com>
15277
15278         * config/mips/mips.c (mips_process_sync_loop): Emit cmp result only if
15279         it is used.
15280
15281 2012-06-19  Tom de Vries  <vries@codesourcery.com>
15282             Maxim Kuvyrkov  <maxim@codesourcery.com>
15283
15284         * config/mips/constraints.md (ZR): New constraint.
15285         * config/mips/predicates.md (mem_noofs_operand): New predicate.
15286         * config/mips/mips.c (mips_print_operand): Handle new print modifier.
15287         * config/mips/mips.h (TARGET_XLP): Define.
15288         (TARGET_SYNC_AFTER_SC): Update.
15289         (ISA_HAS_SWAP, ISA_HAS_LDADD): Define.
15290         * config/mips/sync.md (atomic_exchange, atomic_fetch_add): Use
15291         XLP-specific swap and ldadd patterns.
15292         (atomic_exchange_swap, atomic_fetch_add_ldadd): New patterns.
15293
15294 2012-06-19  Tom de Vries  <vries@codesourcery.com>
15295             Maxim Kuvyrkov  <maxim@codesourcery.com>
15296
15297         * config/mips/mips.c (mips_emit_pre_atomic_barrier_p,)
15298         (mips_emit_post_atomic_barrier_p): New static functions.
15299         (mips_process_sync_loop): Use them.  Emit sync memory barriers in
15300         accordance with memory model semantics.  Add return of CMP result for
15301         compare_and_swap.
15302         * config/mips/mips.md: Update comment.
15303         (sync_cmp): New attribute.
15304         (sync_memmodel): New attribute replacing sync_release_barrier.
15305         * config/mips/sync.md (UNSPEC_ATOMIC_COMPARE_AND_SWAP,)
15306         (UNSPEC_ATOMIC_EXCHANGE, UNSPEC_ATOMIC_FETCH_OP): New constants.
15307         (sync_lock_test_and_set, test_and_set_12): Update.
15308         (atomic_compare_and_swap, atomic_exchange, atomic_exchange_llsc,)
15309         (atomic_fetch_add, atomic_fetch_add_llsc): New patterns.
15310
15311 2012-06-19  Joseph Myers  <joseph@codesourcery.com>
15312
15313         * config/rs6000/spe.md (*mov_si<mode>_e500_subreg0): Rename to
15314         mov_si<mode>_e500_subreg0.
15315         (*mov_si<mode>_e500_subreg0_elf_low)
15316         (*mov_si<mode>_e500_subreg4_elf_low): New patterns.
15317
15318 2012-06-19  Richard Henderson  <rth@redhat.com>
15319
15320         * config/alpha/alpha.c: Include params.h.
15321         (alpha_option_override): Initialize PARAM_L1_CACHE_LINE_SIZE,
15322         PARAM_L1_CACHE_SIZE, PARAM_L2_CACHE_SIZE for the cpu tuning.
15323
15324 2012-06-19  Steven Bosscher  <steven@gcc.gnu.org>
15325
15326         * doc/tm.texi.in (TARGET_OBJC_DECLARE_UNRESOLVED_CLASS_REFERENCE,
15327         TARGET_OBJC_DECLARE_CLASS_DEFINITION): Add @hooks.
15328         (ASM_DECLARE_CLASS_REFERENCE, ASM_DECLARE_UNRESOLVED_REFERENCE):
15329         Remove.
15330         * doc/tm.texi: Regenerate.
15331         * config/darwin.h (ASM_OUTPUT_LABELREF): Remove special case for
15332         .objc_class_name_*.
15333         * config/darwin-c.c: Include target.h.
15334         (darwin_objc_declare_unresolved_class_reference): New function.
15335         (darwin_objc_declare_class_definition): New function.
15336         (TARGET_OBJC_DECLARE_UNRESOLVED_CLASS_REFERENCE): Define.
15337         (TARGET_OBJC_DECLARE_CLASS_DEFINITION): Define.
15338
15339 2012-06-19  Steven Bosscher  <steven@gcc.gnu.org>
15340
15341         * target.def (output_ident): New hook.
15342         * targhooks.h (default_asm_output_ident_directive): Add prototype.
15343         * varasm.c (assemble_asm): Only prefix a tab if the string does not
15344         already start with one.
15345         (default_asm_output_ident_directive): New function to emit
15346         .ident as a top-level asm node while parsing, or directly to
15347         asm_out_file after parsing.
15348         * toplev.c (compile_file): Print a GCC .ident with
15349         targetm.asm_out.output_ident.
15350         * doc/tm.texi.in (ASM_OUTPUT_IDENT): Remove documentation for macro.
15351         (TARGET_ASM_OUTPUT_IDENT): Add @hook for this.
15352         * doc/tm.texi: Update.
15353
15354         * config/elfos.h (ASM_OUTPUT_IDENT, IDENT_ASM_OP): Remove.
15355         (TARGET_ASM_OUTPUT_IDENT): Define.
15356         * config/i386/djgpp.h (IDENT_ASM_OP): Remove.
15357         * config/i386/gas.h (ASM_OUTPUT_IDENT): Remove.
15358         * config/arm/aout.h (ASM_OUTPUT_IDENT): Remove.
15359         * config/sparc/sparc.h (IDENT_ASM_OP): Remove.
15360         (TARGET_ASM_OUTPUT_IDENT): Define.
15361         * config/picochip/picochip.h (IDENT_ASM_OP): Remove.
15362         (TARGET_ASM_OUTPUT_IDENT): Define.
15363
15364         * config/cris/cris-protos.h (cris_asm_output_ident): Add prototype.
15365         * config/cris/cris.c (cris_asm_output_ident): New function.
15366         * config/cris/cris.h (ASM_OUTPUT_IDENT, IDENT_ASM_OP): Remove.
15367
15368         * config/microblaze/microblaze-protos.h (microblaze_asm_output_ident):
15369         Add prototype.
15370         * config/microblaze/microblaze.c: Include cgraph.h for add_asm_node.
15371         (microblaze_asm_output_ident): Rewrite to work similar to
15372         default_asm_output_ident_directive for front-end .idents.
15373         * config/microblaze/microblaze.h (ASM_OUTPUT_IDENT): Remove.
15374         (TARGET_ASM_OUTPUT_IDENT): Define.
15375
15376         * config/mips/mips.h (ASM_OUTPUT_IDENT): Remove.
15377         * config/mips/sde.h (IDENT_ASM_OP, ASM_OUTPUT_IDENT): Remove.
15378
15379         * config/rx/rx.c: Include cgraph.h for add_asm_node.
15380         (rx_asm_output_ident): New function, similar to
15381         default_asm_output_ident_directive, but handle AS100 syntax also, so
15382         that #ident also works for rx in AS100 syntax.
15383         (TARGET_ASM_OUTPUT_IDENT): Define.
15384         * config/rx/rx.h (IDENT_ASM_OP): Remove.
15385
15386         * Makefile.in: Fix dependencies for c-family/c-lex.o.
15387
15388 2012-06-19  Uros Bizjak  <ubizjak@gmail.com>
15389
15390         * config/i386/i386.md (FIST_ROUNDING): New int iterator.
15391         (rounding): Handle UNSPEC_FIST_{FLOOR,CEIL}.
15392         (ROUNDING): Ditto.
15393         (*fist<mode>2_<rounding>_1): Macroize insn from
15394         *fist<mode>2_{floor,ceil}_1 using FIST_ROUNDING int iterator.
15395         (fistdi2_<rounding>): Macroize insn from
15396         fistdi2_{floor,ceil} using FIST_ROUNDING int iterator.
15397         (fistdi2_<rounding>_with_temp and splitters): Macroize insn and
15398         corresponding splitters from fistdi2_{floor,ceil} and corresponding
15399         splitters using FIST_ROUNDING int iterator.
15400         (fist<mode>2_<rounding>): Macroize insn from
15401         fist<mode>2_{floor,ceil} using FIST_ROUNDING int iterator.
15402         (fist<mode>2_<rounding>_with_temp and splitters): Macroize insn and
15403         corresponding splitters from fist<mode>2_{floor,ceil} and corresponding
15404         splitters using FIST_ROUNDING int iterator.
15405         (l<rounding>xf<mode>2): Macroize expander from l{floor,ceil}xf<mode>2
15406         using FIST_ROUNDING int iterator.
15407
15408 2012-06-19  Richard Henderson  <rth@redhat.com>
15409
15410         * config/i386/i386-protos.h (ix86_expand_sse2_mulv4si3): Declare.
15411         * config/i386/i386.c (ix86_expand_sse2_mulv4si3): New.
15412         * config/i386/predicates.md (nonimmediate_or_const_vector_operand): New.
15413         * config/i386/sse.md (sse2_mulv4si3): Delete.
15414         (mul<VI4_AVX2>3): Use ix86_expand_sse2_mulv4si3 and
15415         nonimmediate_or_const_vector_operand.
15416
15417 2012-06-19  Richard Henderson  <rth@redhat.com>
15418
15419         * expmed.c (struct init_expmed_rtl): Split ...
15420         (init_expmed_one_mode): ... out of ...
15421         (init_expmed): ... here.  Initialize integer vector modes also.
15422         (synth_mult): Handle integer vector modes.
15423         (choose_mult_variant): Likewise.
15424         (expand_mult_const): Likewise.
15425         (expand_mult): Likewise.
15426         * machmode.h (GET_MODE_UNIT_BITSIZE): New.
15427
15428 2012-06-19  Richard Henderson  <rth@redhat.com>
15429
15430         * config/i386/i386.c (ix86_rtx_costs): Handle CONST_VECTOR, and
15431         integral vector modes.
15432
15433 2012-06-19  Uros Bizjak  <ubizjak@gmail.com>
15434
15435         * config/i386/i386.md (FRNDINT_ROUNDING): New int iterator.
15436         (rounding): New int attribute.
15437         (ROUNDING): Ditto.
15438         (frndintxf2_<rounding>): Macroize insn from
15439         frndintxf2_{floor,ceil,trunc} using FRNDINT_ROUNDING int iterator.
15440         (frndintxf2_<rounding>_i387): Macroize insn from
15441         frndintxf2_{floor,ceil,trunc}_i387 using FRNDINT_ROUNDING int iterator.
15442
15443 2012-06-19  Richard Guenther  <rguenther@suse.de>
15444
15445         * tree-vrp.c (union_ranges): New function.
15446         (vrp_meet_1): Use union_ranges.
15447         (vrp_meet): Dump what we union and call vrp_meet_1.
15448
15449 2012-06-19  Richard Earnshaw  <rearnsha@arm.com>
15450
15451         * arm.md (enum unspec): Delete UNSPEC_SIN and UNSPEC_COS.
15452         (attr type): Remove fmul, ffmul, farith, ffarith, float_em
15453         f_fpa_load, f_fpa_store, f_mem_r, r_mem_f.
15454         (attr write_conflict, attr core_cycles): Update.
15455         * arm-generic.md (r_mem_f_wbuf): Delete reservation.
15456
15457 2012-06-19  Richard Guenther  <rguenther@suse.de>
15458
15459         * tree-vrp.c (intersect_ranges): Handle more cases.
15460         (vrp_intersect_ranges): Dump what we intersect and call ...
15461         (vrp_intersect_ranges_1): ... this.
15462
15463 2012-06-19  Richard Guenther  <rguenther@suse.de>
15464
15465         PR tree-optimization/53708
15466         * tree-vect-data-refs.c (vect_can_force_dr_alignment_p): Preserve
15467         user-supplied alignment and alignment of decls with the used
15468         attribute.
15469
15470 2012-06-18  Lawrence Crowl  <crowl@google.com>
15471
15472         * timevar.def (TV_PHASE_GENERATE): Rename to TV_PHASE_LATE_ASM.
15473         (TV_PHASE_CGRAPH): Rename to TV_PHASE_OPT_GEN.
15474         (TV_PHASE_STREAM_IN): New.
15475         (TV_PHASE_STREAM_OUT): New.
15476         * timevar.c (validate_phases): New.
15477         (timevar_print): Call validate_phases.
15478         * c-decl.c (c_write_global_declarations): Rename use of TV_PHASE_CGRAPH
15479         to TV_PHASE_OPT_GEN.
15480         * langhooks.c (write_global_declarations): Rename use of
15481         TV_PHASE_CGRAPH to TV_PHASE_OPT_GEN.  Use TV_PHASE_DBGINFO instead of
15482         TV_PHASE_CHECK_DBGINFO.
15483         * toplev.c (compile_file): Rename use of TV_PHASE_GENERATE to
15484         TV_PHASE_LATE_ASM.  Move start of TV_PHASE_LATE_ASM to after call to
15485         lang_hooks.decls.final_write_globals.
15486
15487 2012-06-18  David Edelshn  <dje.gcc@gmail.com>
15488
15489         * config/rs6000/aix52.h (TARGET_EXTRA_BUILTINS): Define as 0.
15490
15491 2012-06-18  Uros Bizjak  <ubizjak@gmail.com>
15492
15493         PR target/53712
15494         * config/i386/sse.md (*sse4_2_pcmpestr_unaligned): New.
15495         (*sse4_2_pcmpistr_unaligned): New.
15496
15497 2012-06-18  Ian Bolton  <ian.bolton@arm.com>
15498             Sameera Deshpande  <sameera.deshpande@arm.com>
15499             Greta Yorsh  <greta.yorsh@arm.com>
15500
15501         * config/arm/arm-protos.h (arm_output_epilogue): Remove.
15502         * config/arm/arm.c (print_multi_reg): Remove.
15503         (vfp_output_fldmd): Likewise.
15504         (arm_output_epilogue): Likewise.
15505         * config/arm/arm.md (epilogue_insns): Update condition and code.
15506
15507 2012-06-18  Ian Bolton  <ian.bolton@arm.com>
15508             Sameera Deshpande  <sameera.deshpande@arm.com>
15509             Greta Yorsh  <greta.yorsh@arm.com>
15510
15511         * config/arm/arm-protos.h (thumb2_expand_return): New declaration.
15512         * config/arm/arm.c (thumb2_expand_return): New function.
15513         * config/arm/arm.md (return): Update condition and code.
15514
15515 2012-06-18  Ian Bolton  <ian.bolton@arm.com>
15516             Sameera Deshpande  <sameera.deshpande@arm.com>
15517             Greta Yorsh  <greta.yorsh@arm.com>
15518
15519         * config/arm/arm-protos.h (output_return_instruction): New parameter
15520         and int to bool change of parameter types.
15521         * config/arm/arm.c (output_return_instruction): Likewise.
15522         * config/arm/arm.md (arm_simple_return): New pattern.
15523         (arm_return, cond_return, cond_return_inverted): Add new arguments.
15524         * config/arm/thumb2.md (thumb2_return): Update condition and code.
15525
15526 2012-06-18  Ian Bolton  <ian.bolton@arm.com>
15527             Sameera Deshpande  <sameera.deshpande@arm.com>
15528             Greta Yorsh  <greta.yorsh@arm.com>
15529
15530         * config/arm/arm-protos.h (arm_expand_epilogue): New declaration.
15531         * config/arm/arm.c (arm_expand_epilogue): New function.
15532         * config/arm/arm.md (epilogue): Update condition and code.
15533         (sibcall_epilogue): Likewise.
15534
15535 2012-06-18  Ian Bolton  <ian.bolton@arm.com>
15536             Sameera Deshpande  <sameera.deshpande@arm.com>
15537             Greta Yorsh  <greta.yorsh@arm.com>
15538
15539         * config/arm/arm.c (arm_expand_epilogue_apcs_frame): New function.
15540         * config/arm/arm.md (arm_addsi3) Add an alternative.
15541
15542 2012-06-18  Ian Bolton  <ian.bolton@arm.com>
15543             Sameera Deshpande  <sameera.deshpande@arm.com>
15544             Greta Yorsh  <greta.yorsh@arm.com>
15545
15546         * config/arm/arm.md (vfp_pop_multiple_with_writeback) New define_insn.
15547         * config/arm/predicates.md (pop_multiple_fp) New special predicate.
15548         * config/arm/arm.c (arm_emit_vfp_multi_reg_pop): New function.
15549
15550 2012-06-18  Ian Bolton  <ian.bolton@arm.com>
15551             Sameera Deshpande  <sameera.deshpande@arm.com>
15552             Greta Yorsh  <greta.yorsh@arm.com>
15553
15554         * config/arm/arm.md (load_multiple_with_writeback) New define_insn.
15555         (load_multiple, pop_multiple_with_writeback_and_return) Likewise.
15556         (pop_multiple_with_return, ldr_with_return) Likewise.
15557         * config/arm/predicates.md (pop_multiple_return) New special predicate.
15558         * config/arm/arm-protos.h (arm_output_multireg_pop) New declaration.
15559         * config/arm/arm.c (arm_output_multireg_pop) New function.
15560         (arm_emit_multi_reg_pop): New function.
15561
15562 2012-06-18  Greta Yorsh  <Greta.Yorsh@arm.com>
15563
15564         * config/arm/arm.c (ldm_stm_operation_p): Require SP
15565         as base register for loads if SP is in the register list.
15566
15567 2012-06-18  Richard Guenther  <rguenther@suse.de>
15568
15569         PR tree-optimization/53693
15570         * tree-vect-patterns.c (vect_operation_fits_smaller_type):
15571         Reject operands with more than one use.
15572
15573 2012-06-18  Bill Schmidt  <wschmidt@linux.ibm.com>
15574
15575         PR tree-optimization/53703
15576         * tree-ssa-phiopt.c (hoist_adjacent_loads): Skip virtual phis;
15577         correctly set bb_for_def[12].
15578
15579 2012-06-18  Steven Bosscher  <steven@gcc.gnu.org>
15580
15581         * config/vax/vax.h (VMS_TARGET): Remove.
15582
15583 2012-06-18  Richard Guenther  <rguenther@suse.de>
15584
15585         * tree-vrp.c (extract_range_from_assert): Split out range
15586         intersecting code.
15587         (intersect_ranges): New function.
15588         (vrp_intersect_ranges): Likewise.
15589
15590 2012-06-18  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
15591
15592         * config/s390/s390.c (s390_gimplify_va_arg): Revert change from
15593         r187965.
15594
15595 2012-06-18  Tejas Belagod  <tejas.belagod@arm.com>
15596
15597         * doc/md.texi: Document int iterators.
15598         * read-rtl.c (ints): New iterator group.
15599         (find_int): Int iterator group callback.
15600         (apply_int_iterator): Likewise.
15601         (apply_iterators): Traverse int iterator table and add all the used
15602         iterators to list.
15603         (initialize_iterators): Initialize data structures and callbacks for
15604         int iterators.
15605         (read_rtx): Parse and read mappings for int iterators.
15606         (read_rtx_code): Record int iterator usage.
15607
15608 2012-06-18  Richard Sandiford  <rdsandiford@googlemail.com>
15609
15610         PR middle-end/53698
15611         * expr.c (expand_expr_addr_expr_1): Convert to tmode before
15612         performing an addition.
15613
15614 2012-06-17  Steven Bosscher  <steven@gcc.gnu.org>
15615
15616         * output.h (split_double): Move prototype to rtl.h.
15617         (constructor_static_from_elts_p): Move prototype to tree.c.
15618         * rtl.h (split_double): Moved here from output.h.
15619         * tree.h (constructor_static_from_elts_p): Moved here from output.h.
15620         * final.c (split_double): Move from here ...
15621         * rtlanal.c (split_double): ... to here.
15622         * expr.c: Do not include output.h.
15623
15624 2012-06-17  Steven Bosscher  <steven@gcc.gnu.org>
15625
15626         * cfglayout.h: Remove.
15627         * cfglayout.c: Remove.
15628         * function.h (struct function): Remove x_last_location field.
15629         * function.c: Do not include cfglayout.h.
15630         (expand_function_start): Do not call no-op force_next_line_note.
15631         (expand_function_end): Likewise.
15632         * cfgrtl.c: Do not include cfglayout.h.  Include gt-cfgrtl.h.
15633         (unlink_insn_chain): Moved here from cfglayout.c.
15634         (skip_insns_after_block, label_for_bb, record_effective_endpoints,
15635         into_cfg_layout_mode, outof_cfg_layout_mode,
15636         pass_into_cfg_layout_mode, pass_outof_cfg_layout_mode,
15637         relink_block_chain, fixup_reorder_chain, verify_insn_chain,
15638         fixup_fallthru_exit_predecessor, force_one_exit_fallthru,
15639         cfg_layout_can_duplicate_bb_p, duplicate_insn_chain,
15640         cfg_layout_duplicate_bb, cfg_layout_initialize, break_superblocks,
15641         cfg_layout_finalize): Likewise.
15642         (rtl_can_remove_branch_p): Likewise.
15643         * rtl.h (insn_scope): Move prototype from cfglayout.h here.
15644         (duplicate_insn_chain): Likewise.
15645         (force_next_line_note): Remove prototype.
15646         * emit-rtl.c: Do not include tree-flow.h, egad.  Include vecprim.h.
15647         (last_location): Remove #define to emit.x_last_location.
15648         (force_next_line_note): Remove no-op function.
15649         (init_emit): Don't set x_last_location.
15650         (block_locators_locs, block_locators_blocks, locations_locators_locs,
15651         locations_locators_vals, prologue_locator, epilogue_locator,
15652         curr_location, last_location, curr_block, last_block, curr_rtl_loc):
15653         Move POD to here from cfglayout.c.
15654         (insn_locators_alloc, insn_locators_finalize, insn_locators_free,
15655         set_curr_insn_source_location, get_curr_insn_source_location,
15656         set_curr_insn_block, get_curr_insn_block, curr_insn_locator,
15657         locator_scope, insn_scope, locator_location, locator_line, insn_line,
15658         locator_file, insn_file, locator_eq): Move to here from cfglayout.c.
15659         * cfghooks.h: Remove double-include protection.
15660         (can_copy_bbs_p, copy_bbs): Move prototypes from cfglayout.h to here.
15661         * cfghooks.c (can_copy_bbs_p, copy_bbs): Move to here from cfglayout.c.
15662         * final.c: Do not include cfglayout.h.
15663         (choose_inner_scope, change_scope): Move to here from cfglayout.c.
15664         (reemit_insn_block_notes): Likewise.  Make static.
15665         * tree-flow.h (tree_could_trap_p, operation_could_trap_helper_p,
15666         operation_could_trap_p, tree_could_throw_p): Move from here...
15667         * tree.h: ... to here.
15668         * gengtype.c (open_base_files): Remove cfglayout.h from the list.
15669         * profile.c: Do not include cfghooks.h.
15670         * cfgloopmanip.c: Do not include cfglayout.h and cfghooks.h.
15671         * modulo-sched.c: Likewise.
15672         * loop-unswitch.c: Do not include cfglayout.h.
15673         * sched-ebb.c: Likewise.
15674         * tracer.c: Likewise.
15675         * ddg.c: Likewise.
15676         * tree-vect-loop-manip.c: Likewise.
15677         * loop-init.c: Likewise.
15678         * dwarf2out.c: Likewise.
15679         * hw-doloop.c: Likewise.
15680         * loop-unroll.c: Likewise.
15681         * cfgcleanup.c: Likewise.
15682         * bb-reorder.c: Likewise.
15683         * sched-rgn.c: Likewise.
15684         * tree-cfg.c: Likewise.
15685         * config/alpha/alpha.c: Likewise.
15686         * config/spu/spu.c: Likewise.
15687         * config/sparc/sparc.c: Likewise.
15688         * config/sh/sh.c: Likewise.
15689         * config/c6x/c6x.c: Likewise.
15690         * config/ia64/ia64.c: Likewise.
15691         * config/rs6000/rs6000.c: Likewise.
15692         * config/score/score.c: Likewise.
15693         * config/mips/mips.c: Likewise.
15694         * config/bfin/bfin.c: Likewise.
15695         * Makefile.in (CFGAYOUT_H): Remove, and fixup users.
15696         * config/rs6000/t-rs6000 (rs6000.o): Do not depend on cfglayout.h.
15697         * config/spu/t-spu-elf (spu.o: $): Likewise.
15698         * config/sparc/t-sparc (sparc.o): Do not depend on CFGLAYOUT_H.
15699
15700 2012-06-17  Steven Bosscher  <steven@gcc.gnu.org>
15701
15702         * cfgloop.h: Do not include rtl.h.
15703         (enum iv_extend_code): New.
15704         (struct rtx_iv): Use iv_extend_code instead of rtx_code.
15705         * Makefile.in (CFGLOOP_H): Do not depend on RTL_H.
15706         * loop-iv.c (iv_extend_to_rtx_code): New function to translate
15707         an IV_EXTEND_CODE to an RTX_CODE.
15708         (dump_iv_info): Update for rtx_iv field type change.
15709         (iv_constant): Likewise.
15710         (iv_subreg): Likewise.
15711         (iv_extend): Likewise.
15712         (iv_neg): Likewise.
15713         (iv_add): Likewise.
15714         (iv_mult): Likewise.
15715         (iv_shift): Likewise.
15716         (get_biv_step_1): Likewise.
15717         (get_biv_step): Likewise.
15718         (iv_analyze_biv): Likewise.
15719         (get_iv_value): Likewise.
15720         (shorten_into_mode): Likewise.
15721         (canonicalize_iv_subregs): Likewise.
15722         * sese.c (sese_build_liveouts): Use MAY_HAVE_DEBUG_STMTS instead
15723         of MAY_HAVE_DEBUG_INSNS.
15724         * tree-ssa-loop-ivopts.c: Include recog.h after expr.h.
15725         * tree-ssa-loop-prefetch.c: Likewise.
15726
15727 2012-06-17  Steven Bosscher  <steven@gcc.gnu.org>
15728
15729         * expmed.c (ceil_log2): Move from here...
15730         * hwint.c: ... to here for older GCCs...
15731         * hwint.h: ... and here for newer GCCs.
15732         * rtl.h (ceil_log2): Remove prototype.
15733
15734         * tree-phinodes.c: Do not include rtl.h.
15735         * Makefile.in (tree-phinodes.o): Do not depend on RTL_H.
15736
15737 2012-06-17  Steven Bosscher  <steven@gcc.gnu.org>
15738
15739         * config/cris/cris.h (TARGET_ELF): Remove.
15740         (FORCE_EH_FRAME_INFO_IN_DATA_SECTION): Remove.
15741         (CRIS_ASM_OUTPUT_ALIGNED_DECL_COMMON): Simpify using TARGET_ELF==1.
15742         (LOCAL_LABEL_PREFIX): Likewise.
15743         * config/cris/cris.c (cris_target_asm_named_section): Remove.
15744         (cris_option_override): Simpify using TARGET_ELF==1.
15745         (cris_file_start): Likewise.
15746         * config/cris/cris-protos.h (cris_target_asm_named_section): Remove.
15747
15748 2012-06-17  Uros Bizjak  <ubizjak@gmail.com>
15749
15750         * config/i386/sse.md (vcvtph2ps): Fix vec_select selector.
15751
15752 2012-06-16  Eric Botcazou  <ebotcazou@adacore.com>
15753
15754         PR middle-end/53590
15755         * tree-inline.c (initialize_cfun): Copy can_delete_dead_exceptions.
15756
15757 2012-06-15  Easwaran Raman  <eraman@google.com>
15758
15759         * passes.c (init_optimization_passes): Remove pass_call_cdce
15760         from its current position and insert after pass_dce.
15761
15762 2012-06-15  Walter Lee  <walt@tilera.com>
15763
15764         * config/tilegx/sync.md (atomic_fetch_<fetchop_name><mode>): Fix typo.
15765
15766 2012-06-15  Richard Earnshaw  <rearnsha@arm.com>
15767
15768         * arm.c (note_invalid_constants): Don't return a result.
15769         (arm_memory_load_p): Delete function.
15770         (arm_const_double_rtx): Delete iterator variable i;
15771         (fp_immediate_constant): Likewise.
15772         (fp_const_from_val): Likewise.
15773
15774         * arm.c (arm_init_iwmmxt_builtins): Delete void_ftype_void.
15775
15776 2012-06-15  Marc Glisse  <marc.glisse@inria.fr>
15777
15778         PR c++/51033
15779         * c-typeck.c (c_build_vec_perm_expr): Move to c-family/c-common.c.
15780         * c-tree.h (c_build_vec_perm_expr): Move to c-family/c-common.h.
15781
15782 2012-06-15  Georg-Johann Lay  <avr@gjlay.de>
15783
15784         * config/avr/avr.c (avr_default_expand_builtin): New function.
15785         (avr_expand_builtin): Use it.
15786         (avr_expand_unop_builtin): Remove.
15787         (avr_expand_binop_builtin): Remove.
15788         (avr_expand_triop_builtin): Remove.
15789
15790 2012-06-15  Michael Matz  <matz@suse.de>
15791
15792         PR middle-end/38474
15793         * cfgexpand.c (add_alias_set_conflicts): Remove.
15794         (expand_used_vars): Don't call it.
15795         (aggregate_contains_union_type): Remove.
15796         * function.c (n_temp_slots_in_use): New static data.
15797         (make_slot_available, assign_stack_temp_for_type): Update it.
15798         (init_temp_slots): Zero it.
15799         (remove_unused_temp_slot_addresses): Use it for quicker removal.
15800         (remove_unused_temp_slot_addresses_1): Use htab_clear_slot.
15801
15802 2012-06-15  Michael Matz  <matz@suse.de>
15803
15804         * gimplify.c (gimplify_compound_literal_expr): Take gimple_test_f
15805         argument, don't emit assign statement if value is directly usable.
15806         (gimplify_expr): Adjust.
15807
15808 2012-06-15  Michael Matz  <matz@suse.de>
15809
15810         * gimplify.c (gimplify_modify_expr): Fold generated statements.
15811         * gimple-fold.c (can_refer_decl_in_current_unit_p): Check flag_ltrans.
15812
15813 2012-06-15  Richard Guenther  <rguenther@suse.de>
15814
15815         * tree-vrp.c (set_and_canonicalize_value_range): Use canonical
15816         predicates to set VR_UNDEFINED and VR_VARYING.  Drop a case
15817         we assert for in set_value_range to VR_VARYING.
15818
15819 2012-06-15  Richard Earnshaw  <rearnsha@arm.com>
15820
15821         * arm.md (addsf3, adddf3): Use s_register_operand.
15822         (subsf3, subdf3): Likewise.
15823         (mulsf3, muldf3): Likewise.
15824         (difsf3, divdf3): Likewise.
15825         (movsfcc, movdfcc): Likewise.
15826         * predicates.md (f_register_operand): Delete.
15827         (arm_float_rhs_operand): Delete.
15828         (arm_float_add_operand): Delete.
15829         (arm_float_compare_operand): Use s_register_operand when
15830         there's no VFP.
15831         (cirrus_register_operand): Delete.
15832         (cirrus_fp_register): Delete.
15833         (cirrus_shift_const): Delete.
15834         (cmpdi_operand): Remove Maverick support.
15835         * constraints.md (f, v, H): Delete constraints.
15836         (G): Update documentation.
15837         * arm.c (fp_consts_inited): Convert to bool.
15838         (strings_fp): Delete.
15839         (values_fp): Delete.
15840         (value_fp0): New variable.
15841         (init_fp_table): Simplify logic.
15842         (arm_const_double_rtx): Likewise.
15843         (fp_immediate_constant): Likewise.
15844         (fp_const_from_val): Likewise.
15845         (neg_const_double_rtx_ok_for_fpa): Delete.
15846         * doc/md.texi (ARM constraints): Update documentation.
15847
15848 2012-06-15  Ulrich Weigand  <ulrich.weigand@linaro.org>
15849
15850         PR tree-optimization/53636
15851         * tree-vect-data-refs.c (vect_compute_data_ref_alignment): Verify
15852         stride when doing basic-block vectorization.
15853
15854 2012-06-15  Ramana Radhakrishnan  <ramana.radhakrishnan@linaro.org>
15855
15856         * tree-vect-generic.c (lower_vec_perm): Propagate vector constants
15857         into VEC_PERM_EXPR.
15858
15859 2012-06-15  Jakub Jelinek  <jakub@redhat.com>
15860
15861         * tree-vect-patterns.c (vect_pattern_recog): Don't unnecessarily
15862         allocate and free bbs array for the SLP case.
15863
15864         PR tree-optimization/51581
15865         * expr.h (choose_multiplier): New prototype.
15866         * expmed.c (choose_multiplier): No longer static.
15867         Change multiplier_ptr from rtx * to UHWI *.
15868         (expand_divmod): Adjust callers.
15869         * tree-vect-patterns.c (vect_recog_sdivmod_pow2_pattern): Renamed to...
15870         (vect_recog_divmod_pattern): ... this.  Pass bb_vinfo as last
15871         argument to new_stmt_vec_info.  Attempt to optimize also divisions
15872         by non-pow2 constants if integer vector division isn't supported.
15873         * tree-vect-stmts.c (vect_analyze_stmt): If node != NULL,
15874         don't look at pattern stmts and sequences.
15875
15876 2012-06-15  Eric Botcazou  <ebotcazou@adacore.com>
15877
15878         PR middle-end/53590
15879         * common.opt (-fdelete-dead-exceptions): New switch.
15880         * doc/invoke.texi (Code Gen Options): Document it.
15881         * cse.c (count_reg_usage) <CALL_INSN>: Use !insn_nothrow_p in lieu of
15882         insn_could_throw_p predicate.  Do not skip an insn that could throw
15883         if dead exceptions can be deleted.
15884         (insn_live_p): Likewise, do not return true in that case.
15885         * dce.c (can_alter_cfg): New flag.
15886         (deletable_insn_p): Do not return false for an insn that can throw if
15887         the CFG can be altered and dead exceptions can be deleted.
15888         (init_dce): Set can_alter_cfg to false for fast DCE, true otherwise.
15889         * dse.c (scan_insn): Use !insn_nothrow_p in lieu of insn_could_throw_
15890         predicate. Do not preserve an insn that could throw if dead exceptions
15891         can be deleted.
15892         * function.h (struct function): Add can_delete_dead_exceptions flag.
15893         * function.c (allocate_struct_function): Set it.
15894         * lto-streamer-in.c (input_struct_function_base): Stream it.
15895         * lto-streamer-out.c (input_struct_function_base): Likewise.
15896         * tree-ssa-dce.c (mark_stmt_if_obviously_necessary): Do not mark a
15897         statement that could throw as necessary if dead exceptions can be
15898         deleted.
15899
15900 2012-06-14  Maxim Kuvyrkov  <maxim@codesourcery.com>
15901
15902         * config/tilegx/sync.md (atomic_fetch_sub<mode>): Fix typo.
15903
15904 2012-06-14  Oleg Endo  <olegendo@gcc.gnu.org>
15905
15906         PR target/53568
15907         * config/sh/sh.md: Add peephole for swapbsi2.
15908         (*swapbisi2_and_shl8, *swapbhisi2): New insns and splits.
15909
15910 2012-06-14  Uros Bizjak  <ubizjak@gmail.com>
15911
15912         * config/i386/i386.md (*zero_extendsidi2): Remove x,x alternative.
15913         (*zero_extendsidi2_rex64): Ditto.  Remove isa attribute.
15914
15915 2012-06-14  Jakub Jelinek  <jakub@redhat.com>
15916
15917         PR target/53639
15918         * config/i386/i386.md (*anddi_1 into *andsi_1_zext splitter): New.
15919
15920 2012-06-14  Richard Earnshaw  <rearnsha@arm.com>
15921
15922         * arm.c (arm_cirrus_insn_p): Delete.
15923         (cirrus_reorg): Delete.
15924         (arm_reorg): Don't call cirrus_reorg.
15925         (arm_final_prescan_insn_p): Don't check for cirrus insns.
15926         * arm.md (define_attr "type"): Remove mav_farith and mav_dmult.
15927         (adddi3, subdi3): Remove Maverick support.
15928         (arm_adddi3): Likewise.
15929         (adddi_sesidi_di, adddi_zesidi_di): Likewise.
15930         (addsf3, adddf3): Likewise.
15931         (subsf3, subdf3): Likewise.
15932         (mulsf3, muldf3): Likewise.
15933         (ashldi3, ashrdi3, lshrdi3): Likewise.
15934         (floatsisf2, floatsidf2): Likewise.
15935         (fix_truncsfsi2, fix_truncdfsi2): Likewise.
15936         (arm_movdi, thumb1_movdi_insn): Likewise.
15937         (arm_cmpdi_insn): Likewise.
15938         (cirrus_cmpsf, cirrus_cmpdf, cirrus_cmpdi): Likewise.
15939         (cirrus.md): Don't include.
15940         * cirrus.md: Delete file.
15941         * t-arm (MD_INCLUDES): Remove cirrus.md.
15942
15943 2012-06-14  Eric Botcazou  <ebotcazou@adacore.com>
15944
15945         * dwarf2out.c (function_possibly_abstracted_p): New static function.
15946         (gen_subprogram_die): Use it function_possibly_abstracted_p in lieu of
15947         cgraph_function_possibly_inlined_p.
15948         (gen_inlined_subroutine_die): Return if the origin is to be ignored.
15949         (process_scope_var): Do not emit concrete instances of abstracted
15950         nested functions from here.
15951         (gen_decl_die): Emit the abstract instance if the function is possibly
15952         abstracted and not only possibly inlined.
15953         (dwarf2out_finish): Find the first non-abstract parent instance and
15954         attach concrete instances on the limbo list to it.
15955
15956 2012-06-14  Richard Earnshaw  <rearnsha@arm.com>
15957
15958         * arm.md (divsf3, divdf3): Remove FPA support.
15959         (negsf2, negdf2): Likewise.
15960         (sqrtsf2, sqrtdf2): Likewise.
15961         (movdfcc): Likewise.
15962         (modsf3, moddf3, movxf): Delete.
15963         (push_fp_multi): Delete.
15964         (fpa.md): Don't include it.
15965         * fpa.md: Delete file.
15966         * t-arm (MD_INCLUDES): Remove fpa.md.
15967
15968 2012-06-14  Bill Schmidt  <wschmidt@linux.ibm.com>
15969
15970         * tree-vectorizer.h (vect_get_stmt_cost): Move from tree-vect-stmts.c.
15971         (cost_for_stmt): Remove decl.
15972         (vect_get_single_scalar_iteration_cost): Correct typo in name.
15973         * tree-vect-loop.c (vect_get_cost): Remove.
15974         (vect_get_single_scalar_iteration_cost): Correct typo in name; use
15975         vect_get_stmt_cost rather than vect_get_cost.
15976         (vect_get_known_peeling_cost): Use vect_get_stmt_cost rather than
15977         vect_get_cost.
15978         (vect_estimate_min_profitable_iters): Correct typo in call to
15979         vect_get_single_scalar_iteration_cost; use vect_get_stmt_cost rather
15980         than vect_get_cost.
15981         (vect_model_reduction_cost): Use vect_get_stmt_cost rather than
15982         vect_get_cost.
15983         (vect_model_induction_cost): Likewise.
15984         * tree-vect-data-refs.c (vect_peeling_hash_get_lowest_cost): Correct
15985         typo in call to vect_get_single_scalar_iteration_cost.
15986         * tree-vect-stmts.c (vect_get_stmt_cost): Move to tree-vectorizer.h.
15987         (cost_for_stmt): Remove unnecessary function.
15988         * Makefile.in (TREE_VECTORIZER_H): Update dependencies.
15989
15990 2012-06-14  Richard Earnshaw  <rearnsha@arm.com>
15991
15992         * arm.opt (mfp=2, mfp=3, mfpe, mfpe=2, mfpe=3): Delete options.
15993         * arm-fpus.def (fpa, fpe2, fpe3, maverick): Delete FPU types.
15994         * arm-tables.opt: Regenerated.
15995         * doc/invoke.texi: Remove references to deleted options.
15996
15997 2012-06-14  Sandeep Kumar Singh  <Sandeep.Singh2@kpitcummins.com>
15998
15999         * config/h8300/genmova.sh: Modified to add offset bits of
16000         mova/Sz assembly instruction for memory access.
16001         * config/h8300/h8300.c: Likewise.
16002         * config/h8300/mova.md: Likewise.
16003
16004 2012-06-12  Christian Bruel  <christian.bruel@st.com>
16005
16006         PR target/53621
16007         * config/sh/sh.c (sh_option_override): Don't force
16008          flag_omit_frame_pointer and maccumulate_outgoing_args.
16009         * config/sh/sh.opt (maccumulate-outgoing-args): Init as Var.
16010
16011 2012-06-14  Richard Guenther  <rguenther@suse.de>
16012
16013         * tree-vrp.c (VR_INITIALIZER): New define.
16014         (ranges_from_anti_range): New function.
16015         (extract_range_from_binary_expr_1): Decompose operations on
16016         VR_ANTI_RANGEs to operations on VR_RANGE.
16017         (extract_range_from_unary_expr_1): Likewise.
16018         (extract_range_from_binary_expr_1, extract_range_from_binary_expr,
16019         extract_range_from_unary_expr_1, extract_range_from_unary_expr,
16020         extract_range_from_cond_expr, adjust_range_with_scev,
16021         vrp_visit_assignment_or_call, vrp_visit_phi_node,
16022         simplify_bit_ops_using_ranges): Use VR_INITIALIZER.
16023
16024 2012-06-13  Richard Henderson  <rth@redhat.com>
16025
16026         * hwint.h (HOST_WIDEST_INT_C): New.
16027         (HOST_WIDE_INT_C): New.
16028         (HOST_WIDE_INT_1): Use it.
16029         * config/alpha/alpha.c (alpha_trampoline_init): Use it.
16030
16031 2012-06-13  Alexandre Oliva  <aoliva@redhat.com>
16032
16033         PR debug/49888
16034         * var-tracking.c: Include alias.h.
16035         (overlapping_mems): New struct.
16036         (drop_overlapping_mem_locs): New.
16037         (clobber_overlapping_mems): New.
16038         (var_mem_delete_and_set, var_mem_delete): Call it.
16039         (val_bind): Likewise, but only if modified.
16040         (compute_bb_dataflow, emit_notes_in_bb): Call it on MEMs.
16041         * Makefile.in (var-tracking.o): Depend in $(ALIAS_H).
16042
16043 2012-06-13  Alexandre Oliva  <aoliva@redhat.com>
16044
16045         PR debug/47624
16046         * var-tracking.c (loc_exp_dep_pool): New.
16047         (vt_emit_notes): Create and release the pool.
16048         (compute_bb_dataflow): Use value-based locations in MO_VAL_SET.
16049         (emit_notes_in_bb): Likewise.
16050         (loc_exp_dep_insert): Deal with NOT_ONEPART vars.
16051         (notify_dependents_of_changed_value): Likewise.
16052         (notify_dependents_of_resolved_value): Check that NOT_ONEPART
16053         variables don't have a VAR_LOC_DEP_LST.
16054         (emit_note_insn_var_location): Expand NOT_ONEPART locs that are
16055         VALUEs or MEMs of VALUEs.
16056
16057 2012-06-13  Alexandre Oliva  <aoliva@redhat.com>
16058
16059         PR debug/52983
16060         PR debug/48866
16061         * dce.c (word_dce_process_block): Insert debug temps only if the
16062         insn is not marked.
16063         (dce_process_block): Likewise, and if debug.used is not empty,
16064         and only after iterating over all DEFs that might mark the insn.
16065
16066 2012-06-13  Alexandre Oliva  <aoliva@redhat.com>
16067
16068         * common.opt (ftree-coalesce-inlined-vars): New.
16069         (ftree-coalesce-vars): New.
16070         * doc/invoke.texi: Document them.
16071         * tree-ssa-copyrename.c (copy_rename_partition_coalesce):
16072         Implement them.
16073
16074 2012-06-13  Richard Sandiford  <rdsandiford@googlemail.com>
16075
16076         * read-rtl.c (mapping): Remove index field.  Add current_value field.
16077         Define heap vectors.
16078         (iterator_group): Fix long line.  Remove num_builtins field and
16079         uses_iterator fields.  Make apply_iterator take a void * parameter.
16080         (iterator_use, atttribute_use): New structures.
16081         (iterator_traverse_data, BELLWETHER_CODE, bellwether_codes): Delete.
16082         (current_iterators, iterator_uses, attribute_uses): New variables.
16083         (uses_mode_iterator_p, uses_code_iterator_p): Delete.
16084         (apply_mode_iterator, apply_code_iterator): Take a void * parameter.
16085         (map_attr_string, apply_iterator_to_string): Remove iterator
16086         and value parameters.  Look through all current iterator values
16087         for a matching attribute.
16088         (mode_attr_index, apply_mode_maps): Delete.
16089         (apply_iterator_to_rtx): Replace with...
16090         (copy_rtx_for_iterators): ...this new function.
16091         (uses_iterator_p, apply_iterator_traverse): Delete.
16092         (apply_attribute_uses, add_current_iterators, apply_iterators): New
16093         functions.
16094         (add_mapping): Remove index field.  Set current_value field.
16095         (initialize_iterators): Don't set num_builtins and uses_iterator_p
16096         fields.
16097         (find_iterator): Delete.
16098         (record_iterator_use, record_attribute_use): New functions.
16099         (record_potential_iterator_use): New function.
16100         (check_code_iterator): Remove handling of bellwether codes.
16101         (read_rtx): Remove mode maps.  Truncate iterator and attribute uses.
16102         (read_rtx_code, read_nested_rtx, read_rtx_variadic): Remove mode_maps
16103         parameter.  Use the first code iterator value instead of the
16104         bellwether_codes array.  Use record_potential_iterator_use for modes.
16105
16106 2012-06-13  Oleg Endo  <olegendo@gcc.gnu.org>
16107
16108         PR target/53568
16109         * config/sh/sh.md (bswapsi2): New expander.
16110         (swapbsi2): New insn.
16111
16112 2012-06-13  H.J. Lu  <hongjiu.lu@intel.com>
16113
16114         PR target/53647
16115         * config/i386/i386.c (ix86_tune_cost): New variable.
16116         (ix86_option_override_internal): Set ix86_tune_cost.  Use
16117         ix86_tune_cost for simultaneous_prefetches, prefetch_block,
16118         l1_cache_size and l2_cache_size.
16119
16120 2012-06-13  Richard Guenther  <rguenther@suse.de>
16121
16122         * tree-vrp.c (vrp_meet): Properly meet equivalent ranges.
16123         Handle meeting two VR_RANGE to an VR_ANTI_RANGE.  Implement
16124         all possible meetings of VR_RANGE with VR_ANTI_RANGE and
16125         VR_ANTI_RANGE with VR_ANTI_RANGE.
16126
16127 2012-06-13  Richard Earnshaw  <rearnsha@arm.com>
16128
16129         * config.gcc (unsupported): Move obsoleted FPA-based configurations
16130         here from ...
16131         (obsolete): ... here.
16132         (arm*-*-freebsd*): Remove.
16133         (arm*-*-linux*): Only accept EABI variants.  Simplify logic.
16134         (arm*-*-uclinux*): Likewise.
16135         (arm*-*-ecos-elf): Remove.
16136         (arm*-*-rtems*): Remove.
16137         (arm*-*-elf): Remove.
16138         (arm*-wince-pe*): Remove.
16139         (arm, --with-fpu): Remove support for fpa and Maverick variants.
16140         * arm/ecos-elf.h: Delete.
16141         * arm/t-strongarm-elf: Delete.
16142         * arm/rtems-elf.h: Delete.
16143         * arm/wince-pe.h: Delete.
16144         * arm/pe.c: Delete.
16145         * arm/pe.h: Delete.
16146         * arm/t-wince-pe: Delete.
16147
16148 2012-06-13  Bill Schmidt  <wschmidt@linux.ibm.com>
16149
16150         PR tree-optimization/53647
16151         * tree-ssa-phiopt.c (gate_hoist_loads): Skip transformation for
16152         targets with no defined cache line size.
16153
16154 2012-06-13  Bill Schmidt  <wschmidt@linux.ibm.com>
16155
16156         * targhooks.c (default_builtin_vectorized_conversion): Handle
16157         vec_construct, using vectype to base cost on subparts.
16158         * target.h (enum vect_cost_for_stmt): Add vec_construct.
16159         * tree-vect-stmts.c (vect_model_load_cost): Use vec_construct
16160         instead of scalar_to-vec.
16161         * config/spu/spu.c (spu_builtin_vectorization_cost): Handle
16162         vec_construct in same way as default for now.
16163         * config/i386/i386.c (ix86_builtin_vectorization_cost): Likewise.
16164         * config/rs6000/rs6000.c (rs6000_builtin_vectorization_cost):
16165         Handle vec_construct, including special case for 32-bit loads.
16166
16167 2012-06-13  Xinyu Qi <xyqi@marvell.com>
16168
16169         * config/arm/arm.c (FL_IWMMXT2): New define.
16170         (arm_arch_iwmmxt2): New variable.
16171         (arm_option_override): Enable use of iWMMXt with VFP.
16172         Disable use of iWMMXt with NEON. Disable use of iWMMXt under
16173         Thumb mode. Set arm_arch_iwmmxt2.
16174         (arm_expand_binop_builtin): Accept VOIDmode op.
16175         (enum arm_builtins): Revise built-in fcode.
16176         (IWMMXT2_BUILTIN): New define.
16177         (IWMMXT2_BUILTIN2): Likewise.
16178         (iwmmx2_mbuiltin): Likewise.
16179         (builtin_description bdesc_2arg): Revise built in declaration.
16180         (builtin_description bdesc_1arg): Likewise.
16181         (arm_init_iwmmxt_builtins): Revise built in initialization.
16182         (arm_expand_builtin): Revise built in expansion.
16183         (arm_output_iwmmxt_shift_immediate): New function.
16184         (arm_output_iwmmxt_tinsr): Likewise.
16185         * config/arm/arm-protos.h (arm_output_iwmmxt_shift_immediate): Declare.
16186         (arm_output_iwmmxt_tinsr): Likewise.
16187         * config/arm/iwmmxt.md (WCGR0, WCGR1, WCGR2, WCGR3): New constant.
16188         (iwmmxt_psadbw, iwmmxt_walign, iwmmxt_tmrc, iwmmxt_tmcr): Delete.
16189         (rorv4hi3, rorv2si3, rordi3): Likewise.
16190         (rorv4hi3_di, rorv2si3_di, rordi3_di): Likewise.
16191         (ashrv4hi3_di, ashrv2si3_di, ashrdi3_di): Likewise.
16192         (lshrv4hi3_di, lshrv2si3_di, lshrdi3_di): Likewise.
16193         (ashlv4hi3_di, ashlv2si3_di, ashldi3_di): Likewise.
16194         (iwmmxt_tbcstqi, iwmmxt_tbcsthi, iwmmxt_tbcstsi): Likewise
16195         (*iwmmxt_clrv8qi, *iwmmxt_clrv4hi, *iwmmxt_clrv2si): Likewise.
16196         (tbcstv8qi, tbcstv4hi, tbsctv2si): New pattern.
16197         (iwmmxt_clrv8qi, iwmmxt_clrv4hi, iwmmxt_clrv2si): Likewise.
16198         (*and<mode>3_iwmmxt, *ior<mode>3_iwmmxt, *xor<mode>3_iwmmxt): Likewise.
16199         (ror<mode>3, ror<mode>3_di): Likewise.
16200         (ashr<mode>3_di, lshr<mode>3_di, ashl<mode>3_di): Likewise.
16201         (ashli<mode>3_iwmmxt, iwmmxt_waligni, iwmmxt_walignr): Likewise.
16202         (iwmmxt_walignr0, iwmmxt_walignr1): Likewise.
16203         (iwmmxt_walignr2, iwmmxt_walignr3): Likewise.
16204         (iwmmxt_setwcgr0, iwmmxt_setwcgr1): Likewise.
16205         (iwmmxt_setwcgr2, iwmmxt_setwcgr3): Likewise.
16206         (iwmmxt_getwcgr0, iwmmxt_getwcgr1): Likewise.
16207         (iwmmxt_getwcgr2, iwmmxt_getwcgr3): Likewise.
16208         (All instruction patterns): Add wtype attribute.
16209         (*iwmmxt_arm_movdi, *iwmmxt_movsi_insn): iWMMXt coexist with vfp.
16210         (iwmmxt_uavgrndv8qi3, iwmmxt_uavgrndv4hi3): Revise the pattern.
16211         (iwmmxt_uavgv8qi3, iwmmxt_uavgv4hi3): Likewise.
16212         (ashr<mode>3_iwmmxt, ashl<mode>3_iwmmxt, lshr<mode>3_iwmmxt): Likewise.
16213         (iwmmxt_tinsrb, iwmmxt_tinsrh, iwmmxt_tinsrw):Likewise.
16214         (eqv8qi3, eqv4hi3, eqv2si3, gtuv8qi3): Likewise.
16215         (gtuv4hi3, gtuv2si3, gtv8qi3, gtv4hi3, gtv2si3): Likewise.
16216         (iwmmxt_wunpckihh, iwmmxt_wunpckihw, iwmmxt_wunpckilh): Likewise.
16217         (iwmmxt_wunpckilw, iwmmxt_wunpckehub, iwmmxt_wunpckehuh): Likewise.
16218         (iwmmxt_wunpckehuw, iwmmxt_wunpckehsb, iwmmxt_wunpckehsh): Likewise.
16219         (iwmmxt_wunpckehsw, iwmmxt_wunpckelub, iwmmxt_wunpckeluh): Likewise.
16220         (iwmmxt_wunpckeluw, iwmmxt_wunpckelsb, iwmmxt_wunpckelsh): Likewise.
16221         (iwmmxt_wunpckelsw, iwmmxt_wmadds, iwmmxt_wmaddu): Likewise.
16222         (iwmmxt_wsadb, iwmmxt_wsadh, iwmmxt_wsadbz, iwmmxt_wsadhz): Likewise.
16223         (iwmmxt2.md): Include.
16224         * config/arm/arm.h (TARGET_CPU_CPP_BUILTINS): Define __IWMMXT2__.
16225         (TARGET_IWMMXT2): New define.
16226         (TARGET_REALLY_IWMMXT2): Likewise.
16227         (arm_arch_iwmmxt2): Declare.
16228         * config/arm/mmintrin.h: Use __IWMMXT__ to enable iWMMXt intrinsics.
16229         Use __IWMMXT2__ to enable iWMMXt2 intrinsics.
16230         Use C name-mangling for intrinsics.
16231         (__v8qi): Redefine.
16232         (_mm_cvtsi32_si64, _mm_andnot_si64, _mm_sad_pu8): Revise.
16233         (_mm_sad_pu16, _mm_align_si64, _mm_setwcx, _mm_getwcx): Likewise.
16234         (_m_from_int): Likewise.
16235         (_mm_sada_pu8, _mm_sada_pu16): New intrinsic.
16236         (_mm_alignr0_si64, _mm_alignr1_si64, _mm_alignr2_si64): Likewise.
16237         (_mm_alignr3_si64, _mm_tandcb, _mm_tandch, _mm_tandcw): Likewise.
16238         (_mm_textrcb, _mm_textrch, _mm_textrcw, _mm_torcb): Likewise.
16239         (_mm_torch, _mm_torcw, _mm_tbcst_pi8, _mm_tbcst_pi16): Likewise.
16240         (_mm_tbcst_pi32): Likewise.
16241         (_mm_abs_pi8, _mm_abs_pi16, _mm_abs_pi32): New iWMMXt2 intrinsic.
16242         (_mm_addsubhx_pi16, _mm_absdiff_pu8, _mm_absdiff_pu16): Likewise.
16243         (_mm_absdiff_pu32, _mm_addc_pu16, _mm_addc_pu32): Likewise.
16244         (_mm_avg4_pu8, _mm_avg4r_pu8, _mm_maddx_pi16, _mm_maddx_pu16): Likewise.
16245         (_mm_msub_pi16, _mm_msub_pu16, _mm_mulhi_pi32): Likewise.
16246         (_mm_mulhi_pu32, _mm_mulhir_pi16, _mm_mulhir_pi32): Likewise.
16247         (_mm_mulhir_pu16, _mm_mulhir_pu32, _mm_mullo_pi32): Likewise.
16248         (_mm_qmulm_pi16, _mm_qmulm_pi32, _mm_qmulmr_pi16): Likewise.
16249         (_mm_qmulmr_pi32, _mm_subaddhx_pi16, _mm_addbhusl_pu8): Likewise.
16250         (_mm_addbhusm_pu8, _mm_qmiabb_pi32, _mm_qmiabbn_pi32): Likewise.
16251         (_mm_qmiabt_pi32, _mm_qmiabtn_pi32, _mm_qmiatb_pi32): Likewise.
16252         (_mm_qmiatbn_pi32, _mm_qmiatt_pi32, _mm_qmiattn_pi32): Likewise.
16253         (_mm_wmiabb_si64, _mm_wmiabbn_si64, _mm_wmiabt_si64): Likewise.
16254         (_mm_wmiabtn_si64, _mm_wmiatb_si64, _mm_wmiatbn_si64): Likewise.
16255         (_mm_wmiatt_si64, _mm_wmiattn_si64, _mm_wmiawbb_si64): Likewise.
16256         (_mm_wmiawbbn_si64, _mm_wmiawbt_si64, _mm_wmiawbtn_si64): Likewise.
16257         (_mm_wmiawtb_si64, _mm_wmiawtbn_si64, _mm_wmiawtt_si64): Likewise.
16258         (_mm_wmiawttn_si64, _mm_merge_si64): Likewise.
16259         (_mm_torvscb, _mm_torvsch, _mm_torvscw): Likewise.
16260         (_m_to_int): New define.
16261         * config/arm/arm-cores.def (iwmmxt2): Add FL_IWMMXT2.
16262         * config/arm/arm-arches.def (iwmmxt2): Likewise.
16263         * config/arm/t-arm (MD_INCLUDES): Add marvell-f-iwmmxt.md and
16264         iwmmxt2.md.
16265         * config/arm/arm.md (marvell-f-iwmmxt.md): Include.
16266         (arch): Add "iwmmxt2".
16267         (arch_enabled): Handle "iwmmxt2".
16268         (wtype): New attribute.
16269         (UNSPEC_WMADDS, UNSPEC_WMADDU): Delete.
16270         (UNSPEC_WALIGNI): New unspec.
16271         * config/arm/predicates.md (imm_or_reg_operand): New predicate.
16272         * config/arm/iterators.md (VMMX2): New mode_iterator.
16273         * config/arm/marvell-f-iwmmxt.md: New file.
16274         * config/arm/iwmmxt2.md: New file.
16275
16276 2012-06-12  Jakub Jelinek  <jakub@redhat.com>
16277
16278         PR c/53532
16279         PR c/51034
16280         PR c/53196
16281         * c-decl.c (build_compound_literal): Call c_incomplete_type_error
16282         if type isn't complete.
16283
16284 2012-06-12  Uros Bizjak  <ubizjak@gmail.com>
16285
16286         * config/ia64/sync.md (fetchop_name): Change ior attribute to "or".
16287
16288 2012-06-12  Richard Henderson  <rth@redhat.com>
16289
16290         * config/rs6000/sync.md (atomic_load, atomic_store): Use INT1 mode
16291         iterator instead of INT.
16292
16293 2012-06-12  Bill Schmidt  <wschmidt@linux.ibm.com>
16294
16295         * opts.c: Add -fhoist-adjacent-loads to -O2 and above.
16296         * tree-ssa-phiopt.c (tree_ssa_phiopt_worker): Add argument to forward
16297         declaration.
16298         (hoist_adjacent_loads, gate_hoist_loads): New forward declarations.
16299         (tree_ssa_phiopt): Call gate_hoist_loads.
16300         (tree_ssa_cs_elim): Add parm to tree_ssa_phiopt_worker call.
16301         (tree_ssa_phiopt_worker): Add do_hoist_loads to formal arg list; call
16302         hoist_adjacent_loads.
16303         (local_mem_dependence): New function.
16304         (hoist_adjacent_loads): Likewise.
16305         (gate_hoist_loads): Likewise.
16306         * common.opt (fhoist-adjacent-loads): New switch.
16307         * Makefile.in (tree-ssa-phiopt.o): Added dependencies.
16308
16309 2012-06-12  Michael Matz  <matz@suse.de>
16310
16311         * alias.c (nonoverlapping_component_refs_p): Take two rtx arguments.
16312         (nonoverlapping_memrefs_p): Don't call it here ...
16313         (true_dependence_1): ... but here.
16314
16315 2012-06-12  Richard Guenther  <rguenther@suse.de>
16316
16317         * emit-rtl.c (set_mem_attributes_minus_bitpos): Remove dead code.
16318         * alias.c (ao_ref_from_mem): MEM_EXPR is conservative, MEM_OFFSET
16319         and MEM_SIZE only refines it.  Reflect that and be less conservative
16320         if either of the latter is not known.
16321
16322 2012-06-12  Jakub Jelinek  <jakub@redhat.com>
16323
16324         PR rtl-optimization/53589
16325         * cfgrtl.c (force_nonfallthru_and_redirect): Do asm_goto_edge
16326         discovery even when e->dest != target.  If any LABEL_REF points
16327         to e->dest label, redirect it to target's label.
16328
16329 2012-06-12  Chung-Lin Tang  <cltang@codesourcery.com>
16330
16331         * config/sh/sh.c (output_stack_adjust): Remove !epilogue_p
16332         condition for generating REG_FRAME_RELATED_EXPR note.
16333         (pop): Add code for generating REG_CFA_RESTORE,
16334         REG_CFA_ADJUST_CFA notes. Set RTX_FRAME_RELATED_P to 1.
16335         (sh_expand_epilogue): Use frame_insn() for FP to SP move.
16336         Set 'frame_p' of calls to output_stack_adjust() to 'true'.
16337
16338 2012-06-11  Richard Henderson  <rth@redhat.com>
16339
16340         * config/alpha/alpha.c (HWI_HEX2): Add missing shift.
16341         * vmsdbgout.c (VMS_EPOCH_OFFSET): Add LL suffix.
16342
16343         * config/alpha/alpha.c (alpha_trampoline_init): Split large constants.
16344
16345 2012-06-12  Hans-Peter Nilsson  <hp@axis.com>
16346
16347         * doc/tm.texi.in (Addressing Modes) <TARGET_LEGITIMIZE_ADDRESS>:
16348         Mention that this hook needs to be defined for native TLS.
16349         * doc/tm.texi: Regenerate.
16350
16351 2012-06-11  Mike Stump  <mikestump@comcast.net>
16352
16353         * emit-rtl.c (init_emit_once): Iterate through the
16354         MODE_PARTIAL_INT modes with MIN_MODE_PARTIAL_INT and
16355         MAX_MODE_PARTIAL_INT, as GET_MODE_WIDER_MODE doesn't step through
16356         all the MIN_MODE_PARTIAL_INT modes anymore.
16357
16358 2012-06-12  Maxim Kuvyrkov  <maxim@codesourcery.com>
16359
16360         * gcc/config/mips/mips-tables.opt (xlp): Fix merge typo.
16361
16362 2012-06-11  Roland McGrath  <mcgrathr@google.com>
16363
16364         * dwarf2out.c (const_ok_for_output_1): Detect a TLS UNSPEC using
16365         SYMBOL_REF_TLS_MODEL rather than DECL_THREAD_LOCAL_P, in case it's
16366         not a VAR_DECL.  Also don't limit it to UNSPECs with exactly one
16367         operand.
16368
16369 2012-06-11  Oleg Endo  <olegendo@gcc.gnu.org>
16370
16371         PR target/53511
16372         * config/sh/sh.md (fmasf4): New expander.
16373         (*macsf3): Rename to fmasf4_i.  Adapt to fma pattern.
16374         (mac_media): Rename to fmasf4_media.  Adapt to fma pattern.
16375         * config/sh/sh.opt (mfused-madd): Remove.
16376         * config/sh/sh.c (sh_option_override): Remove mfused-madd handling.
16377         (builtin_description bdesc): Remove __builtin_sh_media_FMAC_S.
16378         * config.gcc (sh[123456789lbe]*-*-* | sh-*-*): Add fused-madd.opt
16379         as extra options.
16380         * doc/invoke.texi (SH Options): Update mfused-madd and mno-fused-madd
16381         descriptions.
16382
16383 2012-06-11  Richard Henderson  <rth@redhat.com>
16384
16385         * dwarf2cfi.c (scan_trace): Handle annulled branch-taken delay slots.
16386
16387 2012-06-11  Richard Guenther  <rguenther@suse.de>
16388
16389         PR middle-end/53470
16390         * tree.c (free_lang_data_in_type): Do not clear TYPE_CONTEXT but
16391         replace it with the first non-BLOCK context.
16392
16393 2012-06-11  Richard Guenther  <rguenther@suse.de>
16394
16395         * alias.c (aliases_everything_p): Remove.
16396         (DIFFERENT_ALIAS_SETS_P): Likewise.
16397         (true_dependence_1): Use mems_in_disjoint_alias_sets_p directly.
16398         Do not use aliases_everything_p or special-case ANDs.  Do not
16399         special-case BLKmode moves.
16400         (may_alias_p): Likewise.  Handle BLKmode similar like everywhere
16401         - for SCATCH only.
16402
16403 2012-06-09  Hans-Peter Nilsson  <hp@axis.com>
16404
16405         Fix CRIS build errors with --enable-build-with-cxx.
16406         * config/cris/cris.c (cris_emit_trap_for_misalignment): Rename
16407         variable "and" to "andop".
16408         * config/cris/sync.md ("atomic_fetch_<atomic_op_name><mode>"): Use
16409         temporary variable for memory model, passing C++-type-correct
16410         parameter type to expand_mem_thread_fence.
16411         ("atomic_compare_and_swap<mode>"): Ditto.
16412
16413 2012-06-09  Richard Henderson  <rth@redhat.com>
16414
16415         PR c++/53602
16416         * cfgcleanup.c (execute_jump): Rename from rest_of_handle_jump2.
16417         (pass_jump): Rename from pass_jump2.
16418         (execute_jump2, pass_jump2): New.
16419         * combine-stack-adj.c (rest_of_handle_stack_adjustments): Don't
16420         perform cfg cleanup here.  Move the test of PUSH_ROUNDING
16421         and ACCUMULATE_OUTGOING_ARGS test...
16422         (gate_handle_stack_adjustments): ... here.
16423         * passes.c (init_optimization_passes): Update for pass_jump2 rename.
16424         Place new pass_jump2 after pass_stack_adjustments.
16425         * tree-pass.h (pass_jump): Declare.
16426
16427 2012-06-09  Kenneth Zadeck <zadeck@naturalbridge.com>
16428
16429         * simplify-rtx.c (simplify_const_binary_operation): Fixed shift
16430         count trucation.
16431
16432 2012-06-08  Richard Henderson  <rth@redhat.com>
16433
16434         PR c++/53602
16435         * combine-stack-adj.c (force_move_args_size_note): Add ARGS_SIZE
16436         note to a clobber insn when no other insn is available.
16437
16438 2012-06-08  Georg-Johann Lay  <avr@gjlay.de>
16439
16440         * config/avr/avr.c (avr_case_values_threshold): Return 7.
16441
16442 2012-06-07  Andreas Schwab  <schwab@linux-m68k.org>
16443
16444         * genhooks.c (main): Set progname.
16445         (emit_documentation): Remove variable found_start, always bail out
16446         when a place is missing.
16447         * doc/tm.texi.in (C++ ABI): Add @hook TARGET_CXX_DECL_MANGLING_CONTEXT.
16448
16449 2012-06-07  Jakub Jelinek  <jakub@redhat.com>
16450
16451         PR middle-end/53580
16452         * omp-low.c (scan_omp): Change first argument to gimple_seq *,
16453         call walk_gimple_seq_mod instead of walk_gimple_seq.
16454         (scan_sharing_clauses, scan_omp_parallel, scan_omp_task,
16455         scan_omp_for, scan_omp_sections, scan_omp_single,
16456         execute_lower_omp): Adjust callers.
16457         (scan_omp_1_stmt): Likewise.  If check_omp_nesting_restrictions
16458         returns false, replace stmt with GIMPLE_NOP.
16459         (check_omp_nesting_restrictions): Instead of issuing warnings,
16460         issue errors and return false if any errors were reported.
16461
16462 2012-06-06  Steven Bosscher  <steven@gcc.gnu.org>
16463
16464         * doc/invoke.texi (fconserve-space): Remove documentation.
16465
16466 2012-06-06  Edmar Wienskoski  <edmar@freescale.com>
16467
16468         * config/rs6000/rs6000-tables.opt: Regenerated.
16469
16470 2012-06-06  Richard Guenther  <rguenther@suse.de>
16471
16472         PR tree-optimization/53081
16473         * tree-data-ref.h (adjacent_store_dr_p): Rename to ...
16474         (adjacent_dr_p): ... this and make it work for reads, too.
16475         * tree-loop-distribution.c (enum partition_kind): Add PKIND_MEMCPY.
16476         (struct partition_s): Change main_stmt to main_dr, add
16477         secondary_dr member.
16478         (build_size_arg_loc): Change to date data-reference and not
16479         gimplify here.
16480         (build_addr_arg_loc): New function split out from ...
16481         (generate_memset_builtin): ... here.  Use it and simplify.
16482         (generate_memcpy_builtin): New function.
16483         (generate_code_for_partition): Adjust.
16484         (classify_partition): Streamline pattern detection.  Detect memcpy.
16485         (ldist_gen): Adjust.
16486         (tree_loop_distribution): Adjust seed statements for memcpy
16487         recognition.
16488
16489 2012-06-06  Matt Turner  <mattst88@gmail.com>
16490
16491         * config/arm/mmintrin.h (_mm_empty): New.
16492         (_m_empty): New.
16493
16494 2012-06-06  Richard Sandiford  <r.sandiford@uk.ibm.com>
16495
16496         * doc/invoke.texi (sched-pressure-algorithm): Document new --param.
16497         * common.opt (fsched-pressure-algorithm=): Remove.
16498         * flag-types.h (sched_pressure_algorithm): Move to...
16499         * sched-int.h (sched_pressure_algorithm): ...here.
16500         * params.def (sched-pressure-algorithm): New param.
16501         * haifa-sched.c (sched_init): Use it to initialize sched_pressure.
16502         * common/config/s390/s390-common.c (s390_option_optimization_table):
16503         Remove OPT_fsched_pressure_algorithm_ entry.
16504         * config/s390/s390.c (s390_option_override): Set a default value for
16505         PARAM_SCHED_PRESSURE_ALGORITHM.
16506
16507 2012-06-05  Michael Meissner  <meissner@linux.vnet.ibm.com>
16508
16509         PR target/53487
16510         * config/rs6000/rs6000.c (rs6000_generate_compare): If we are
16511         doing an unsigned compare, make sure the second argument is not a
16512         negative constant.
16513         (rs6000_emit_cmove): Don't allow floating point comparisons when
16514         generating ISEL moves.
16515
16516 2012-06-05  Edmar Wienskoski  <edmar@freescale.com>
16517
16518         * config/rs6000/e5500.md: New file.
16519         * config/rs6000/e6500.md: New file.
16520         * config/rs6000/rs6000.c (processor_costs): Add new costs for
16521         e5500 and e6500.
16522         (rs6000_option_override_internal): Altivec and Spe options not
16523         allowed with e5500. Spe options not allowed with e6500. Increase
16524         move inline limit for e5500 and e6500. Disable string instructions
16525         for e5500 and e6500. Enable branch targets alignment for e5500 and
16526         e6500. Initialize rs6000_cost for e5500 and e6500.
16527         (rs6000_adjust_cost): Add extra scheduling cycles between compare
16528         and brnach for e5500 and e6500.
16529         (rs6000_issue_rate): Set issue rate for e5500 and e6500.
16530         * config/rs6000/rs6000-cpus.def: Add cpu definitions for e5500 and
16531         e6500.
16532         * config/rs6000/rs6000.h (ASM_CPU_SPEC): Add e5500 and e6500.
16533         * config/rs6000/rs6000.md (define_attr "cpu"): Add ppce5500 and
16534         ppce6500.
16535         Include e5500.md and e6500.md.
16536         * config/rs6000/rs6000-opt.h (processor_type): Add
16537         PROCESSOR_PPCE5500 and PROCESSOR_PPCE6500.
16538         * config.gcc (cpu_is_64bit): Add new cores e5500, e6500.
16539         (powerpc*-*-*): Add new cores e5500, e6500.
16540         * doc/invoke.texi: (item -mcpu): Add e5500 and e6500 to list of cpus.
16541
16542 2012-06-05  Richard Guenther  <rguenther@suse.de>
16543
16544         * tree-vect-data-refs.c (vect_analyze_data_refs): Fix last change.
16545
16546 2012-06-05  H.J. Lu  <hongjiu.lu@intel.com>
16547
16548         PR target/53575
16549         * config.gcc: Select x32 run-time library if --with-abi={x32|mx32}
16550         is used for x86_64-*-*.
16551
16552 2012-06-05  Richard Guenther  <rguenther@suse.de>
16553
16554         PR tree-optimization/30442
16555         * tree-vect-data-refs.c (vect_analyze_data_refs): For basic-block
16556         vectorization stop analysis at the first stmt we cannot compute
16557         a data-reference for instead of giving up completely.
16558
16559 2012-06-05  Richard Guenther  <rguenther@suse.de>
16560
16561         * tree-loop-distribution.c (struct partition_s): Add has_writes member.
16562         (partition_alloc): Initialize it.
16563         (partition_has_writes): New function.
16564         (rdg_flag_uses): Adjust.
16565         (rdg_flag_vertex): Likewise.
16566         (rdg_flag_vertex_and_dependent): Likewise.
16567         (rdg_flag_loop_exits): Likewise.
16568         (build_rdg_partition_for_component): Likewise.
16569         (rdg_build_partitions): Likewise.
16570
16571 2012-06-05  Richard Guenther  <rguenther@suse.de>
16572
16573         PR tree-optimization/53081
16574         * tree-loop-distribution.c (generate_memset_builtin): Handle all
16575         kinds of byte-sized stores.
16576         (classify_partition): Likewise.
16577         (tree_loop_distribution): Adjust seed statements used for
16578         !flag_tree_loop_distribution.
16579
16580 2012-06-05  Alan Modra  <amodra@gmail.com>
16581
16582         * config/rs6000/rs6000.c (ptr_regno_for_savres): Comment.
16583         (rs6000_emit_prologue): Ensure register used for inline saves
16584         of vector regs is not the static chain register.  Revise comment.
16585
16586 2012-06-04  Oleg Endo  <olegendo@gcc.gnu.org>
16587
16588         * doc/md.texi (Standard Pattern Names For Generation): Document
16589         sincos pattern.
16590
16591 2012-06-04  H.J. Lu  <hongjiu.lu@intel.com>
16592
16593         PR bootstrap/53555
16594         * config/i386/i386.c (ix86_sched_reorder) Skip debug insns.
16595
16596 2012-06-04  Jason Merrill  <jason@redhat.com>
16597
16598         * dwarf2out.c (is_unit_die): New.
16599         (copy_declaration_context, copy_ancestor_tree): Use it.
16600         (copy_decls_walk): Likewise.
16601
16602 2012-06-04  Paolo Carlini  <paolo.carlini@oracle.com>
16603
16604         PR c++/53524
16605         * doc/invoke.texi (Wenum-compare): Update documentation.
16606
16607 2012-06-04  Dodji Seketeli  <dodji@redhat.com>
16608
16609         PR preprocessor/53463
16610         * parser.c (cp_parser_assignment_expression): Use the location
16611         for the '=' as the default location for the expression.
16612
16613 2012-06-04  Edmar Wienskoski  <edmar@freescale.com>
16614
16615         PR target/53559
16616         * config/rs6000/altivec.md (altivec_stvlx): Change machine mode of
16617         operands.
16618         (altivec_stvlxl): Ditto.
16619         (altivec_stvrx): Ditto.
16620         (altivec_stvrxl): Ditto.
16621
16622 2012-06-04  Vladimir Makarov  <vmakarov@redhat.com>
16623
16624         * ira-int.h (struct target_ira_int): Add member x_ira_uniform_class_p.
16625         (ira_uniform_class_p): New macro.
16626
16627         * ira.c (setup_uniform_class_p): New function.
16628         (setup_allocno_and_important_classes): Call the function.
16629         (print_unform_and_important_classes): New function.
16630         (print_classes): Rename to print_translated_classes.
16631         (ira_debug_allocno_classes): Add call of
16632         print_unform_and_important_classes.
16633
16634         * ira-costs.c (setup_regno_cost_classes_by_aclass): Use uniform
16635         classes instead of pressure classes.
16636
16637 2012-06-04  Aldy Hernandez  <aldyh@redhat.com>
16638
16639         PR middle-end/47530
16640         * trans-mem.c (expand_block_edges): Do not skip the first
16641         statement when resetting the BB.
16642
16643 2012-06-04  Richard Guenther  <rguenther@suse.de>
16644
16645         * tree-data-ref.c (stores_from_loop): Remove.
16646         (stmt_with_adjacent_zero_store_dr_p): Likewise.
16647         (stores_zero_from_loop): Likewise.
16648         * tree-data-ref.h (stores_from_loop, stores_zero_from_loop,
16649         stmt_with_adjacent_zero_store_dr_p, stride_of_unit_type_p): Remove.
16650         (adjacent_store_dr_p): New function.
16651         * tree-loop-distribution.c (generate_memset_builtin): Pass
16652         the RDG, use the already available data-reference.
16653         (generate_code_for_partition): Pass down RDG.
16654         (classify_partition): Inline parts of the former
16655         stmt_with_adjacent_zero_store_dr_p here and use adjacent_store_dr_p.
16656         (ldist_gen): Remember if there was any detected builtin and
16657         do less work if not and flag_tree_loop_distribution is not set.
16658         (tree_loop_distribution): Inline and fuse stores_from_loop
16659         and stores_zero_from_loop here.
16660
16661 2012-06-04  Richard Guenther  <rguenther@suse.de>
16662
16663         PR middle-end/53471
16664         * dwarf2out.c (dwarf2out_finish): If generating LTO do not
16665         create new assembler names.
16666
16667 2012-06-04  Richard Guenther  <rguenther@suse.de>
16668
16669         * tree-data-ref.c (struct rdg_vertex_info): Remove.
16670         (rdg_vertex_for_stmt): Simplify using gimple_uid.
16671         (create_rdg_vertices): Pass loop argument, remove stmt to RDG index
16672         hashtable.  Record stmt data-references.
16673         (hash_stmt_vertex_info): Remove.
16674         (eq_stmt_vertex_info): Likewise.
16675         (hash_stmt_vertex_del): Likewise.
16676         (build_empty_rdg): Simplify.
16677         (build_rdg): Adjust.
16678         (free_rdg): Likewise.
16679         (ref_base_address): Remove.
16680         (have_similar_memory_accesses): Likewise.
16681         * tree-data-ref.h (create_rdg_vertices): Remove.
16682         (struct rdg_vertex): Add datarefs member.
16683         (RDGV_DATAREFS): New define.
16684         (RDG_DATAREFS): Likewise.
16685         (have_similar_memory_accesses): Remove.
16686         (rdg_has_similar_memory_accesses): Likewise.
16687         * tree-loop-distribution.c (ref_base_address): Re-implement here.
16688         (similar_memory_accesses): Re-implement using existing data-references.
16689         (tree_loop_distribution): Initialize stmt uids for the stmt to
16690         RDG index mapping.
16691         * tree-vect-loop.c (vect_create_epilog_for_reduction): Only
16692         access stmt vinfo for stmts in loop.
16693
16694 2012-06-04  Andreas Schwab  <schwab@linux-m68k.org>
16695
16696         PR target/53461
16697         * config/m68k/m68k.md ("tablejump"): Fix check for
16698         CASE_VECTOR_PC_RELATIVE.
16699
16700 2012-06-04  Steven Bosscher  <steven@gcc.gnu.org>
16701
16702         * output.h (merge_weak, assemble_alias,
16703         initializer_constant_valid_p,
16704         initializer_constant_valid_for_bitfield_p): Move protos from here...
16705         * tree.h: ... to here.
16706         * cgraphclones.c: Do not include output.h.
16707         * gimplify.c: Likewise.
16708         * reload.c: Likewise.
16709         * recog.c: Likewise.
16710         * tree-ssa-loop-ivopts.c: Likewise.
16711         * tree-switch-conversion.c: Likewise.
16712         * c-parser.c: Likewise.
16713         * c-typeck.c: Likewise.
16714         * Makefile.in: Fix dependencies.
16715
16716 2012-06-04  Georg-Johann Lay  <avr@gjlay.de>
16717
16718         PR target/46261
16719         * config/avr/avr-stdint.h: New file.
16720         * config.gcc (avr-*-*,tm_file): Use avr/avr-stdint.h instead of
16721         newlib-stdint.h
16722
16723 2012-06-04  Jakub Jelinek  <jakub@redhat.com>
16724
16725         PR tree-optimization/53550
16726         * tree-ssa-loop-niter.c (number_of_iterations_cond): If type
16727         is POINTER_TYPE_P, use sizetype as step type instead of type.
16728
16729 2012-06-04  Richard Guenther  <rguenther@suse.de>
16730
16731         * tree-data-ref.c (have_similar_memory_accesses_1): Remove.
16732         (ref_base_address_1): Likewise.
16733         (remove_similar_memory_refs): Likewise.
16734         * tree-data-ref.h (remove_similar_memory_refs): Remove.
16735         * tree-loop-distribution.c (classify_partition): Do not classify
16736         as builtin if -ftree-loop-distribute-patterns is not enabled.
16737         (fuse_partitions_with_similar_memory_accesses): Inline ...
16738         (ldist_gen): ... here.  Fuse all non-builtin partitions if
16739         -ftree-loop-distribution is not enabled.  Properly return
16740         the number of created partitions.  Do not update SSA form here but ...
16741         (tree_loop_distribution): ... once here for the whole function.
16742         Only walk innermost loops, constrain loops we consider here
16743         further.  Do not call remove_similar_memory_refs.
16744         (distribute_loop): Do not check number of loop nodes here.
16745
16746 2012-06-04  Steven Bosscher  <steven@gcc.gnu.org>
16747
16748         * Makefile.in (GIMPLE_H): Do not depend on TARGET_H.
16749
16750 2012-06-03  Martin Jambor  <mjambor@suse.cz>
16751
16752         * ipa-prop.h (ipa_get_jf_known_type_offset): New function.
16753         (ipa_get_jf_known_type_base_type): Likewise.
16754         (ipa_get_jf_known_type_component_type): Likewise.
16755         (ipa_get_jf_constant): Likewise.
16756         (ipa_get_jf_pass_through_formal_id): Likewise.
16757         (ipa_get_jf_pass_through_operation): Likewise.
16758         (ipa_get_jf_ancestor_offset): Likewise.
16759         (ipa_get_jf_ancestor_type): Likewise.
16760         (ipa_get_jf_ancestor_formal_id): Likewise.
16761         (ipa_get_jf_member_ptr_pfn): Likewise.
16762         * ipa-prop.c (ipa_set_jf_known_type): New function.
16763         (ipa_set_jf_constant): Likewise.
16764         (ipa_set_jf_simple_pass_through): Likewise.
16765         (ipa_set_jf_arith_pass_through): Likewise.
16766         (ipa_set_ancestor_jf): Likewise.
16767         (fill_member_ptr_cst_jump_function): Moved up and renamed to
16768         ipa_set_jf_member_ptr_cst.
16769         (detect_type_change_1): Use the new jump function creation functions.
16770         (compute_complex_assign_jump_func): Likewise.
16771         (compute_complex_ancestor_jump_func): Likewise.
16772         (compute_known_type_jump_func): Likewise.
16773         (compute_scalar_jump_functions): Likewise.
16774         (compute_pass_through_member_ptrs): Likewise.
16775         (determine_cst_member_ptr): Likewise.
16776         (combine_known_type_and_ancestor_jfs): Likewise.
16777         (try_make_edge_direct_simple_call): Likewise.
16778         (try_make_edge_direct_virtual_call): Likewise.
16779         (update_indirect_edges_after_inlining): Likewise.
16780         * ipa-cp.c (ipa_get_jf_pass_through_result): Use jump function
16781         access functions.  Incorporat NOP_EXPR and BINFO handling from its
16782         callers.
16783         (ipa_get_jf_ancestor_result): Likewise.  Incorporate handling BINFOs
16784         which was in its callers.
16785         (ipa_value_from_jfunc): Use jump function access functions.  Some
16786         functionality moved to functions above.
16787         (propagate_vals_accross_ancestor): Likewise.
16788         (propagate_vals_accross_pass_through): Use jump function access
16789         functions.
16790         (propagate_accross_jump_function): Likewise.
16791         * ipa-inline-analysis.c (remap_edge_change_prob): Use jump function
16792         access functions.
16793         (inline_merge_summary): Likewise.
16794
16795 2012-06-03  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
16796
16797         * config/pa/pa.h (MAX_PCREL17F_OFFSET): Define.
16798         * config/pa/pa.c (pa_attr_length_millicode_call): Use
16799         MAX_PCREL17F_OFFSET instead of fixed offset.
16800         (pa_attr_length_call): Likewise.
16801         (pa_attr_length_indirect_call): Likewise.
16802
16803 2012-06-03  Oleg Endo  <olegendo@gcc.gnu.org>
16804
16805         PR target/53512
16806         * config/sh/sh.opt (mfsca, mfsrra): New options.
16807         * config/sh/sh.md (rsqrtsf2): Use TARGET_FPU_ANY and TARGET_FSRRA
16808         condition.
16809         (fsca): Use TARGET_FPU_ANY and TARGET_FSCA condition.
16810         (sinssf2, cossf2): Fold expanders to ...
16811         (sincossf3): ... this new expander.  Use TARGET_FPU_ANY and
16812         TARGET_FSCA condition.
16813         * config/sh/sh.c (sh_option_override): Handle TARGET_FSRRA and
16814         TARGET_FSCA.
16815         * doc/invoke.texi (SH Options): Add descriptions for -mfsca,
16816         -mno-fsca, -mfsrra, -mno-fsrra.
16817
16818 2012-06-03  Matt Turner  <mattst88@gmail.com>
16819
16820         * config/mips/4600.md (r4700_imul_si): New.
16821         (r4700_imul_di): New.
16822         (r4700_fmul_single): New.
16823         (r4700_fmul_double): New.
16824         * config/mips/mips-cpus.def: Add r4700.
16825         * config/mips/mips.c: Likewise.
16826         * config/mips/mips.md: Likewise.
16827         * config/mips/mips-tables.opt: Regenerate.
16828
16829 2012-06-02  Steven Bosscher  <steven@gcc.gnu.org>
16830
16831         * config/sparc/sparc.h (INITIAL_ELIMINATION_OFFSET): Split out to
16832         new function sparc_initial_elimination_offset.
16833         * config/sparc/sparc.c (sparc_initial_elimination_offset): New
16834         function.
16835         * config/sparc/sparc-protos.h (sparc_initial_elimination_offset):
16836         Prototype it.
16837
16838 2012-06-02  Kenneth Zadeck <zadeck@naturalbridge.com>
16839
16840         * expmed.c (expand_mult, choose_multiplier): Change
16841         "2 * HOST_BITS_PER_WIDE_INT" to "HOST_BITS_PER_DOUBLE_INT".
16842         * expr.c (convert_modes): Likewise.
16843         * explow.c (plus_constant): Likewise.
16844         * fixed-value.c (fixed_saturate1, fixed_saturate2)
16845         (do_fixed_add, do_fixed_multiply, do_fixed_multiply)
16846         (do_fixed_multiply, do_fixed_multiply, do_fixed_divide)
16847         (do_fixed_divide, do_fixed_divide, do_fixed_divide)
16848         (do_fixed_divide, do_fixed_divide, do_fixed_shift, do_fixed_shift)
16849         (do_fixed_shift, fixed_convert, fixed_convert)
16850         (fixed_convert_from_int, fixed_convert_from_int)
16851         (fixed_convert_from_real): Likewise.
16852         * fold-const.c (fold_convert_const_int_from_fixed, sign_bit_p)
16853         (native_interpret_int, fold_binary_loc, fold_ternary_loc): Likewise.
16854         * varasm.c (output_constructor_bitfield): Likewise.
16855         * tree-vrp.c (register_edge_assert_for_2): Likewise.
16856         * double-int.c (rshift_double, lshift_double): Likewise.
16857         * double-int.h (double_int_fits_in_uhwi_p, double_int, double_int):
16858         Likewise.
16859         * simplify-rtx.c (mode_signbit_p)
16860         (simplify_const_unary_operation, simplify_binary_operation_1)
16861         (simplify_immed_subreg): Likewise.
16862         * builtins.c (c_readstr, fold_builtin_bitop): Likewise.
16863         * tree-vect-generic.c (build_replicated_const): Likewise.
16864         * dbxout.c (stabstr_O): Likewise.
16865         * emit-rtl.c (immed_double_int_const, immed_double_const)
16866         (gen_lowpart_common, init_emit_once): Likewise.
16867         * tree.c (integer_pow2p, tree_log2, tree_floor_log2)
16868         (widest_int_cst_value, upper_bound_in_type): Likewise.
16869         * stor-layout.c (initialize_sizetypes, fixup_signed_type)
16870         (fixup_unsigned_type): Likewise.
16871         * real.c (real_to_integer2, real_from_integer): Likewise.
16872         * dwarf2out.c (size_of_loc_descr, size_of_die, output_die)
16873         (clz_loc_descriptor, mem_loc_descriptor): Likewise.
16874
16875 2012-06-01  Eric Botcazou  <ebotcazou@adacore.com>
16876
16877         PR middle-end/53501
16878         * fold-const.c (fold_binary_loc): Refine previous change.
16879
16880 2012-06-01  Olivier Hainque  <hainque@adacore.com>
16881
16882         * config/rs6000/vxworks.h (SUBSUBTARGET_OVERRIDE_OPTIONS): Restore
16883         the "do {" part of the do-while(0) loop.
16884
16885 2012-06-01  Yuri Rumyantsev  <yuri.s.rumyantsev@intel.com>
16886
16887         * config/i386/i386.c (x86_sched_reorder): New function.
16888         Added new function x86_sched_reorder.
16889
16890 2012-06-01  Richard Guenther  <rguenther@suse.de>
16891
16892         * tree-loop-distribution.c (stmt_has_scalar_dependences_outside_loop):
16893         Handle PHIs.
16894         (classify_partition): Likewise.
16895
16896 2012-06-01  Richard Guenther  <rguenther@suse.de>
16897
16898         * tree-loop-distribution.c (enum partition_kind): New enum.
16899         (struct partition_s): Add kind and main_stmt members.
16900         (partition_alloc): Initialize kind to PKIND_NORMAL.
16901         (partition_builtin_p): New function.
16902         (copy_loop_before): Remove failure path and assert instead.
16903         (generate_loops_for_partition): Likewise.
16904         (generate_memset_zero): Fold into ...
16905         (generate_memset_builtin): ... this.
16906         (classify_partition): New function with code from
16907         can_generate_builtin and generate_builtin.
16908         (generate_builtin): Remove.
16909         (can_generate_builtin): Likewise.
16910         (fuse_partitions_with_similar_memory_accesses): Call
16911         partition_builtin_p instead of can_generate_builtin.
16912         (rdg_build_partitions): Do not call
16913         fuse_partitions_with_similar_memory_accesses here...
16914         (ldist_gen): ... but here after classifying all partitions.
16915         Remove failure path of generate_code_for_partition.
16916         (generate_code_for_partition): Generate code according
16917         to partition classification.
16918
16919 2012-06-01  Manuel López-Ibáñez  <manu@gcc.gnu.org>
16920             Jonathan Wakely  <jwakely.gcc@gmail.com>
16921
16922         PR c++/50134
16923         * doc/invoke.texi (Warning Options): Explain purpose and differences
16924         between -Wmissing-prototypes and -Wmissing-declarations.
16925
16926 2012-06-01  Christian Bruel  <christian.bruel@st.com>
16927
16928         * gcc.c (save_switch): Add user_p parameter.
16929         (read_specs): Likewise.
16930         (set_specs): Likewise.
16931         (validate_switches): Likewise.
16932         (validate_switches_from_spec): Likewise.
16933         (validate_all_switches): Pass on user_p parameter.
16934         (struct spec_list): Add user_p field.
16935         (struct switchstr): Add known field.
16936         (save_switch): Add known parameter.
16937         (INIT_STATIC_SPEC): Initialize user_p;
16938         (driver_unknown_option_callbac): call save_switch if
16939         OPT_SPECIAL_unknown.
16940         (driver_handle_option): Propagate OPT_specs.
16941         (do_spec_1): Set validated only if known.
16942         (check_live_switch): Likewise.
16943         (validate_switches): Set validated if known or user_spec.
16944
16945 2012-06-01  Hans-Peter Nilsson  <hp@axis.com>
16946
16947         Add CRIS atomic patterns for 1, 2, and 4 bytes.
16948         * config/cris/cris.c (cris_emit_trap_for_misalignment): New function.
16949         * config/cris/cris-protos.h: Declare it.
16950         * config/cris/cris.h [!TARGET_DEFAULT, TARGET_CPU_DEFAULT == 32]
16951         (TARGET_DEFAULT): Add alignment by 32.
16952         [!TARGET_DEFAULT, TARGET_CPU_DEFAULT == 10] (TARGET_DEFAULT): New
16953         case, as TARGET_CPU_DEFAULT == 0 but with alignment as for
16954         TARGET_CPU_DEFAULT == 32.
16955         (TARGET_TRAP_UNALIGNED_ATOMIC): New macro.
16956         * config/cris/cris.md: Include sync.md.  Avoid allocating specific
16957         numbers by replacing the define_constants for all UNSPECs with the
16958         equivalent define_c_enum construct.
16959         * config/cris/cris.opt (mtrap-unaligned-atomic): New option.
16960         * config/cris/sync.md: New file.
16961
16962 2012-05-31  Matt Turner  <mattst88@gmail.com>
16963
16964         * config/mips/4600.md (r4600_imul_si): Rename from r4600_imul.
16965         (r4600_imul_di): New.
16966         (r4600_idiv_si): Rename from r4600_idiv.
16967         (r4600_idiv_di): New.
16968
16969 2012-05-31  Steven Bosscher  <steven@gcc.gnu.org>
16970
16971         * output.h (__gcc_host_wide_int__): Move to hwint.h.
16972         (decl_default_tls_model): Move to tree.h
16973         (dump_file): Move to system.h.
16974         (default_stabs_asm_out_destructor, default_stabs_asm_out_constructor,
16975         dbxout_int, dbxout_stabd, dbxout_begin_stabn, dbxout_begin_stabn_sline,
16976         dbxout_begin_empty_stabs, dbxout_begin_simple_stabs,
16977         dbxout_begin_simple_stabs_desc, dbxout_stab_value_zero,
16978         dbxout_stab_value_zero, dbxout_stab_value_label_diff,
16979         dbxout_stab_value_internal_label,
16980         dbxout_stab_value_internal_label_diff): Move from here ...
16981         * dbxout.h: ... to here.
16982         * system.h (dump_file): Moved here from output.h.
16983         * hwint.h (__gcc_host_wide_int__): Moved here from output.h.
16984         * tree.h (decl_default_tls_model): Moved here from output.h.
16985         * varasm.c (default_stabs_asm_out_destructor,
16986         default_stabs_asm_out_constructor): Move from here ...
16987         * dbxout.c: ... to here.
16988
16989         * gcov-dump.c (dump_file): Rename to dump_gcov_file.  Update callers.
16990
16991         * collect2.h (dump_file): Rename to dump_ld_file.
16992         * collect2.c: Likewise.
16993         * tlink.c: Likewise.
16994
16995         * alias.c: Do not include output.h.
16996         * auto-inc-dec.c: Likewise.
16997         * bt-load.c: Likewise.
16998         * caller-save.c: Likewise.
16999         * cfg.c: Likewise.
17000         * cfgbuild.c: Likewise.
17001         * cfgcleanup.c: Likewise.
17002         * cfglayout.c: Likewise.
17003         * cfgloop.c: Likewise.
17004         * cfgloopanal.c: Likewise.
17005         * cfgloopmanip.c: Likewise.
17006         * cfgrtl.c: Likewise.
17007         * cgraph.c: Likewise.
17008         * cgraphclones.c: Likewise.
17009         * combine-stack-adj.c: Likewise.
17010         * combine.c: Likewise.
17011         * cprop.c: Likewise.
17012         * cse.c: Likewise.
17013         * cselib.c: Likewise.
17014         * dbgcnt.c: Likewise.
17015         * df-problems.c: Likewise.
17016         * df-scan.c: Likewise.
17017         * dojump.c: Likewise.
17018         * fwprop.c: Likewise.
17019         * gcse.c: Likewise.
17020         * graph.c: Likewise.
17021         * haifa-sched.c: Likewise.
17022         * hw-doloop.c: Likewise.
17023         * ipa-inline-transform.c: Likewise.
17024         * ipa-pure-const.c: Likewise.
17025         * ipa-reference.c: Likewise.
17026         * ipa-utils.c: Likewise.
17027         * ira-build.c: Likewise.
17028         * ira-emit.c: Likewise.
17029         * lcm.c: Likewise.
17030         * loop-doloop.c: Likewise.
17031         * loop-invariant.c: Likewise.
17032         * loop-iv.c: Likewise.
17033         * loop-unroll.c: Likewise.
17034         * loop-unswitch.c: Likewise.
17035         * lto-cgraph.c: Likewise.
17036         * lto-section-in.c: Likewise.
17037         * lto-streamer-in.c: Likewise.
17038         * mcf.c: Likewise.
17039         * mode-switching.c: Likewise.
17040         * postreload-gcse.c: Likewise.
17041         * postreload.c: Likewise.
17042         * predict.c: Likewise.
17043         * profile.c: Likewise.
17044         * ree.c: Likewise.
17045         * reg-stack.c: Likewise.
17046         * regcprop.c: Likewise.
17047         * regmove.c: Likewise.
17048         * regstat.c: Likewise.
17049         * reload1.c: Likewise.
17050         * sched-ebb.c: Likewise.
17051         * sel-sched-dump.c: Likewise.
17052         * simplify-rtx.c: Likewise.
17053         * stor-layout.c: Likewise.
17054         * store-motion.c: Likewise.
17055         * tracer.c: Likewise.
17056         * tree-affine.c: Likewise.
17057         * tree-cfg.c: Likewise.
17058         * tree-cfgcleanup.c: Likewise.
17059         * tree-dfa.c: Likewise.
17060         * tree-into-ssa.c: Likewise.
17061         * tree-nomudflap.c: Likewise.
17062         * tree-optimize.c: Likewise.
17063         * tree-pretty-print.c: Likewise.
17064         * tree-profile.c: Likewise.
17065         * tree-ssa-address.c: Likewise.
17066         * tree-ssa-ccp.c: Likewise.
17067         * tree-ssa-copy.c: Likewise.
17068         * tree-ssa-dom.c: Likewise.
17069         * tree-ssa-loop-ch.c: Likewise.
17070         * tree-ssa-loop-im.c: Likewise.
17071         * tree-ssa-loop-manip.c: Likewise.
17072         * tree-ssa-loop-niter.c: Likewise.
17073         * tree-ssa-loop-prefetch.c: Likewise.
17074         * tree-ssa-loop-unswitch.c: Likewise.
17075         * tree-ssa-loop.c: Likewise.
17076         * tree-ssa-propagate.c: Likewise.
17077         * tree-ssa-structalias.c: Likewise.
17078         * tree-ssa-tail-merge.c: Likewise.
17079         * tree-ssa-threadedge.c: Likewise.
17080         * tree-ssa-threadupdate.c: Likewise.
17081         * tree-ssa-uncprop.c: Likewise.
17082         * tree-ssa-uninit.c: Likewise.
17083         * tree-ssa.c: Likewise.
17084         * value-prof.c: Likewise.
17085         * var-tracking.c: Likewise.
17086         * web.c: Likewise.
17087
17088         * config/m32r/m32r.c: Include dbxout.h.
17089         * config/pa/pa.c: Likewise.
17090         * config/rs6000/rs6000.c: Likewise.
17091
17092         * Makefile.in: Fix dependencies.
17093         * config/rs6000/t-rs5000: Likewise.
17094
17095 2012-05-31  Aldy Hernandez  <aldyh@redhat.com>
17096
17097         * tree-ssa-loop-im.c (execute_sm): Do not check flag_tm.
17098         * gimple.h (block_in_transaction): Check for flag_tm.
17099
17100 2012-05-31  Aldy Hernandez  <aldyh@redhat.com>
17101
17102         PR tree-optimization/52558
17103         * cfg.c (alloc_aux_for_edge): Fix comment.
17104         (alloc_aux_for_edge): Remove static.
17105         * basic-block.h (alloc_aux_for_edge): Protoize.
17106         * tree-ssa-loop-im.c (execute_sm_if_changed): New.
17107         (execute_sm_if_changed_flag): New.
17108         (execute_sm_if_changed_flag_set): New.
17109         (execute_sm): Do not generate data races unless requested.
17110         (tree_ssa_lim_initialize): Call alloc_aux_for_edges.
17111         (tree_ssa_lim_finalize): Call free_aux_for_edges.
17112         * gimple.h (block_in_transaction): New.
17113         (gimple_in_transaction): Use block_in_transaction.
17114
17115 2012-05-31  Georg-Johann Lay  <avr@gjlay.de>
17116
17117         PR target/51345
17118         * config/avr/avr.opt (-msp8): Document it.
17119         * doc/invoke.texi (AVR Options): Ditto.  And document related
17120         built-in macros.
17121
17122 2012-05-31  Diego Novillo  <dnovillo@google.com>
17123
17124         * configure.ac (CXX_FOR_BUILD): Define and substitute.
17125         (BUILD_CXXFLAGS): Define and substitute.
17126         * Makefile.in (BUILD_CXXFLAGS): Define.
17127         (CXX_FOR_BUILD): Define.
17128         (COMPILER_FOR_BUILD): Set to CXX_FOR_BUILD if building with C++.
17129         (LINKER_FOR_BUILD): Likewise.
17130         (BUILD_COMPILERFLAGS): Set to BUILD_CXXFLAGS if building with C++.
17131         (BUILD_LINKERFLAGS): Likewise.
17132         * configure: Regenerate.
17133
17134 2012-05-31  Steven Bosscher  <steven@gcc.gnu.org>
17135
17136         * Makefile.in: Fix many dependencies.
17137         * tree-profile.c: Don't include regs.h.
17138         * tree-vectorizer.c: Don't include cfglayout.h.
17139         * tree-vect-stmts.c: Likewise.
17140         * tree-vect-slp.c: Likewise.
17141         * tree-vect-loop.c: Likewise.
17142         * reg-stack.c: Likewise.
17143         * tree-ssa-loop-manip.c: Likewise.
17144         * toplev.c: Likewise.
17145         * varasm.c: Don't include cfglayout.h, basic-block.h,
17146         and tree-iterator.h.
17147         * tree-cfgcleanup.c: Don't include cfglayout.h.
17148         * passes.c: Don't include cfglayout.h, dwarf2asm.h,
17149         dwarf2out.h, dbxout.h, sdbout.h, and xcoffout.h.
17150         * cgraphclones.c: Don't include plugin.h.
17151
17152 2012-05-31  Georg-Johann Lay  <avr@gjlay.de>
17153
17154         * config/avr/t-avr: Correct avr-mmcu.texi dependencies.
17155         (s-avr-mmcu-texi): Don't sed on gen-avr-mmcu-texi output.
17156         * doc/avr-mmcu.texi (svn:eol-style): Set to native.
17157
17158 2012-05-31  Richard Guenther  <rguenther@suse.de>
17159
17160         * tree-loop-distribution.c (struct partition_s): New struct,
17161         typedef and vector type.
17162         (partition_alloc, partition_free): New functions.
17163         (generate_loops_for_partition, generate_builtin,
17164         generate_code_for_partition, rdg_flag_uses, rdg_flag_vertex,
17165         rdg_flag_vertex_and_dependent, rdg_flag_loop_exits,
17166         build_rdg_partition_for_component, can_generate_builtin,
17167         similar_memory_accesses, fuse_partitions_with_similar_memory_accesses,
17168         rdg_build_partitions, dump_rdg_partitions, debug_rdg_partitions,
17169         number_of_rw_in_partition, partition_contains_all_rw,
17170         ldist_gen): Use partition_t instead of bitmap.
17171
17172 2012-05-31  Georg-Johann Lay  <avr@gjlay.de>
17173
17174         * config/avr/gen-avr-mmcu-texi.c: Sort MCUs.
17175         * doc/avr-mmcu.texi: Regenerate.
17176
17177 2012-05-31  Richard Guenther  <rguenther@suse.de>
17178
17179         * tree-loop-distribution.c (stmt_has_scalar_dependences_outside_loop):
17180         Use FOR_EACH_SSA_DEF_OPERAND.
17181         (generate_builtin): Adjust.
17182         (stmt_generated_in_another_partition): Remove.
17183         (add_scalar_computations_to_partition): Likewise.
17184         (rdg_build_partitions): Do not call
17185         add_scalar_computations_to_partition.
17186
17187 2012-05-31  Eric Botcazou  <ebotcazou@adacore.com>
17188
17189         * tree-dfa.c (get_ref_base_and_extent): Compute the offset using
17190         double ints throughout.
17191         * tree-sra.c (build_user_friendly_ref_for_offset) <RECORD_TYPE>:
17192         Check that the position of the field is representable as an integer.
17193
17194 2012-05-31  Richard Guenther  <rguenther@suse.de>
17195
17196         * tree-data-ref.c (dr_analyze_innermost): Properly convert
17197         the MEM_REF offset to sizetype.
17198
17199 2012-05-31  Georg-Johann Lay  <avr@gjlay.de>
17200
17201         * doc/invoke.texi (AVR Options): Fix typos.
17202
17203 2012-05-31  Hans-Peter Nilsson  <hp@axis.com>
17204
17205         * config/cris/cris.h (CC1_SPEC): Pass through all -march=
17206         and -mcpu= options.
17207         (ASM_SPEC): Ditto, not just -march=v32, but translate non-v10,
17208         non-v32 into --march=v0_v10.
17209
17210 2012-05-31  Richard Sandiford  <rdsandiford@googlemail.com>
17211
17212         * ira-int.h (target_ira_int): Rename x_move_cost to
17213         x_ira_register_move_cost, x_may_move_in_cost to
17214         x_ira_may_move_in_cost and x_may_move_out_cost to
17215         x_ira_may_move_out_cost.  Delete the old fields with
17216         those names and also x_ira_max_register_move_cost,
17217         x_ira_max_may_move_in_cost and x_ira_max_may_move_out_cost.
17218         (move_cost, may_move_in_cost, may_move_out_cost)
17219         (ira_max_register_move_cost, ira_max_may_move_in_cost)
17220         (ira_max_may_move_out_cost): Delete.
17221         * ira.c (init_move_cost): Rename to...
17222         (ira_init_register_move_cost): ...this, deleting the old
17223         function with that name.  Apply above variable renamings.
17224         Retain asserts for null fields.
17225         (ira_init_once): Don't initialize register move costs here.
17226         (free_register_move_costs): Apply above variable renamings.
17227         Remove code for deleted fields.
17228
17229 2012-05-31  Richard Sandiford  <rdsandiford@googlemail.com>
17230
17231         * ira.c (init_move_cost): Adjust choice of subclasses to match
17232         the current ira_init_register_move_cost choice.  Use
17233         ira_class_subset_p instead of reg_class_subset_p.
17234         (ira_init_register_move_cost): Assert that move_cost,
17235         may_move_in_cost and may_move_out_cost already hold the desired
17236         values for their ira_* equivalents.  For the latter two,
17237         ignore classes that can't store a register of the given mode.
17238
17239 2012-05-31  Richard Sandiford  <rdsandiford@googlemail.com>
17240
17241         * ira.c (setup_allocno_and_important_classes): Use
17242         ira_class_hard_regs_num to check whether a class has any
17243         allocatable registers.
17244         (ira_init_register_move_cost): Likewise.
17245
17246 2012-05-31  Richard Sandiford  <rdsandiford@googlemail.com>
17247
17248         * ira.c (init_move_cost): Adjust local variable names to match
17249         file conventions.  Use ira_assert instead of gcc_assert.
17250
17251 2012-05-31  Richard Sandiford  <rdsandiford@googlemail.com>
17252
17253         * regs.h (move_table, move_cost, may_move_in_cost, may_move_out_cost):
17254         Move these definitions and associated target_globals fields to...
17255         * ira-int.h: ...here.
17256         * rtl.h (init_move_cost): Delete.
17257         * reginfo.c (last_mode_for_init_move_cost, init_move_cost): Move to...
17258         * ira.c: ...here, making the latter static.
17259
17260 2012-05-31  Richard Sandiford  <rdsandiford@googlemail.com>
17261
17262         * ira-costs.c (copy_cost): Use ira_init_register_move_cost_if_necessary
17263         and ira_register_move_cost instead of init_move_cost and move_cost.
17264
17265 2012-05-31  Richard Sandiford  <rdsandiford@googlemail.com>
17266
17267         * ira.h (target_ira): Delete x_ira_available_class_regs.
17268         (ira_available_class_regs): Delete.
17269         * ira.c (setup_available_class_regs): Delete.
17270         (setup_alloc_classes): Don't call it.
17271         (setup_pressure_classes): Use ira_class_hard_regs_num instead of
17272         ira_available_class_regs.
17273         * haifa-sched.c (print_curr_reg_pressure, setup_insn_reg_pressure_info)
17274         (model_spill_cost): Likewise.
17275         * ira-build.c (low_pressure_loop_node_p): Likewise.
17276         * ira-color.c (color_pass): Likewise.
17277         * ira-emit.c (change_loop): Likewise.
17278         * ira-lives.c (inc_register_pressure, dec_register_pressure)
17279         (single_reg_class, ira_implicitly_set_insn_hard_regs)
17280         (process_bb_node_lives): Likewise.
17281         * loop-invariant.c (gain_for_invariant): Likewise.
17282
17283 2012-05-30  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
17284
17285         PR target/52999
17286         * config/pa/pa.c (TARGET_SECTION_TYPE_FLAGS): Define.
17287         (pa_section_type_flags): New.
17288         (pa_legitimate_constant_p): Revert previous change.
17289
17290 2012-05-30  Steven Bosscher  <steven@gcc.gnu.org>
17291
17292         * ira.c (allocate_initial_values): Make static.
17293
17294 2012-05-30  Uros Bizjak  <ubizjak@gmail.com>
17295
17296         * config/i386/i386.c (legitimize_tls_address) <TLS_MODEL_INITIAL_EXEC>:
17297         Generate tls_initial_exec_64_sun only when !TARGET_X32.
17298
17299 2012-05-30  Richard Guenther  <rguenther@suse.de>
17300
17301         PR middle-end/53501
17302         * fold-const.c (fold_binary_loc): Make sure to call
17303         fold_plusminus_mult_expr with the original sign of operands.
17304
17305 2012-05-30  Steven Bosscher  <steven@gcc.gnu.org>
17306
17307         * Makefile.in: Fix many dependencies.
17308         (DWARF2_H): Depend on dwarf2.def.
17309         (RTL_ERROR_H): Depend on rtl-error.h.
17310         (TREE_PRETTY_PRINT_H, GIMPLE_PRETTY_PRINT_H): New.  Replace
17311         all gimple-pretty-print.h and tree-pretty-print.h references.
17312
17313 2012-05-30  Marc Glisse  <marc.glisse@inria.fr>
17314
17315         * simplify-rtx.c (simplify_binary_operation_1): Optimize shuffle of
17316         concatenations.
17317
17318 2012-05-30  Richard Guenther  <rguenther@suse.de>
17319
17320         PR middle-end/53522
17321         * tree-emutls.c (gen_emutls_addr): Do not add globals to
17322         referenced-vars.
17323
17324 2012-05-30  Eric Botcazou  <ebotcazou@adacore.com>
17325
17326         * explow.c (probe_stack_range): Restore simple control flow and stop
17327         again when the probe cannot be generated if HAVE_check_stack.
17328
17329 2012-05-30  Jakub Jelinek  <jakub@redhat.com>
17330
17331         PR rtl-optimization/53519
17332         * combine.c (simplify_shift_const_1) <case NOT>: Use constm1_rtx
17333         instead of GEN_INT (GET_MODE_MASK (mode)) as second operand of XOR.
17334
17335 2012-05-30  Ramana Radhakrishnan  <ramana.radhakrishnan@linaro.org>
17336
17337         * config/arm/arm.c (arm_evpc_neon_vrev): Adjust off by one error.
17338
17339 2012-05-29  Jack Howarth  <howarth@bromo.med.uc.edu>
17340
17341         PR debug/53453
17342         * doc/tm.texi: Update.
17343         * doc/tm.texi.in (SDB and DWARF) <TARGET_FORCE_AT_COMP_DIR>: Add @hook.
17344         * target.def (force_at_comp_dir): New hook.
17345         * config/darwin.h (TARGET_FORCE_AT_COMP_DIR): Define.
17346         * dwarf2out.c (dwarf2out_finish): Check targetm.force_at_comp_dir.
17347
17348 2012-05-29  Jack Howarth  <howarth@bromo.med.uc.edu>
17349
17350         * config/darwin.h (STARTFILE_SPEC): Do not use -lbundle1.o when
17351         Darwin >= 10.
17352         (DARWIN_DYLIB1_SPEC): Do not use -ldylib1.10.5.o when Darwin >= 10.
17353         (DARWIN_CRT1_SPEC): Use -lcrt1.10.6.o when Darwin >= 10.
17354
17355 2012-05-29  Oleg Endo  <olegendo@gcc.gnu.org>
17356
17357         PR target/51340
17358         * config/sh/sh.c (sh_option_override): Set TARGET_FMAC if
17359         flag_unsafe_math_optimizations is set.
17360         * doc/invoke.texi (SH Options): Add -mno-fused-madd description.
17361         Update description of -mfused-madd.
17362
17363 2012-05-29  Oleg Endo  <olegendo@gcc.gnu.org>
17364
17365         PR target/52941
17366         * config/sh/predicates.md (atomic_arith_operand,
17367         atomic_logical_operand): New predicates.
17368         * config/sh/sh.c (sh_option_override): Check atomic options.
17369         * config/sh/sh.h (TARGET_ANY_ATOMIC, UNSUPPORTED_ATOMIC_OPTIONS,
17370         UNSUPPORTED_HARD_ATOMIC_CPU): New macros.
17371         (DRIVER_SELF_SPECS): Use UNSUPPORTED_ATOMIC_OPTIONS and
17372         UNSUPPORTED_HARD_ATOMIC_CPU.
17373         * config/sh/sync.md: Update description comments.
17374         (I12): New mode iterator.
17375         (fetchop_predicate, fetchop_constraint): New code attributes.
17376         (atomic_compare_and_swapsi_hard, atomic_compare_and_swap<mode>_hard,
17377         atomic_exchangesi_hard, atomic_exchange<mode>_hard,
17378         atomic_fetch_<fetchop_name>si_hard,
17379         atomic_fetch_<fetchop_name><mode>_hard,
17380         atomic_fetch_nandsi_hard, atomic_fetch_nand<mode>_hard,
17381         atomic_<fetchop_name>_fetchsi_hard,
17382         atomic_<fetchop_name>_fetch<mode>_hard,
17383         atomic_nand_fetchsi_hard, atomic_nand_fetch<mode>_hard,
17384         atomic_test_and_set_hard): New insns.
17385         (atomic_compare_and_swap<mode>_soft, atomic_exchange<mode>_soft,
17386         atomic_fetch_<fetchop_name><mode>_soft, atomic_fetch_nand<mode>_soft,
17387         atomic_<fetchop_name>_fetch<mode>_soft, atomic_nand_fetch<mode>_soft,
17388         atomic_test_and_set_soft): Use same formatting for the first line of
17389         the asm block as in new insns above.
17390         (atomic_compare_and_swap<mode>, atomic_exchange<mode>,
17391         atomic_fetch_<fetchop_name><mode>, atomic_<fetchop_name>_fetch<mode>,
17392         atomic_test_and_set): Integrate new *_hard insns into expanders.
17393         * config/sh/sh.opt (mhard-atomic): New option.
17394         * doc/invoke.texi (SH Options): Document it.
17395
17396 2012-05-29  Meador Inge  <meadori@codesourcery.com>
17397
17398         * c-decl.c (c_push_function_context): Always create a new language
17399         function.
17400         (c_pop_function_context): Clear the language function created in
17401         c_push_function_context.
17402
17403 2012-05-29  Matt Turner  <mattst88@gmail.com>
17404
17405         * config/alpha/ev6.md: (define_bypass "ev6_fmul,ev6_fadd"): New.
17406         (define_bypass "ev6_fcmov"): New.
17407
17408 2012-05-29  Steven Bosscher  <steven@gcc.gnu.org>
17409
17410         * integrate.c: Remove.
17411         * integrate.h: Remove.
17412         * Makefile.in: Remove make rules for integrate.c and INTEGRATE_H.
17413         * config/arm/t-arm: Remove INTEGRATE_H dependency for target files.
17414         * config/rs6000/t-rs6000: Likewise
17415         * config/spu/t-spu-elf: Likewise.
17416         * function.h (get_hard_reg_initial_val, has_hard_reg_initial_val,
17417         get_hard_reg_initial_reg, emit_initial_value_sets): Move prototypes
17418         from integrate.h to here.
17419         (initial_value_entry): New prototype.
17420         * reload.h (allocate_initial_values): Remove prototype.
17421         * tree.h (set_decl_abstract_flags, set_decl_origin_self): Likewise.
17422         * cse.c (fixed_base_plus_p): Don't handle virtual registers for
17423         integrate.c.
17424         * dwarf2out.c (set_decl_origin_self, set_block_origin_self,
17425         set_decl_abstract_flags, set_block_abstract_flags): Move from
17426         integrate.c to here, the only user.
17427         * expmed.c (extract_fixed_bit_field): Remove outdated comment
17428         about integrate.c.
17429         * function.c: Don't include integrate.h.
17430         (struct initial_value_pair, struct initial_value_struct,
17431         get_hard_reg_initial_val, has_hard_reg_initial_val,
17432         get_hard_reg_initial_reg, emit_initial_value_sets): Move from
17433         integrate.c to here.
17434         (initial_value_entry): New function.
17435         * genemit.c (main): Don't print integrate.h include line.
17436         * ira.c: Don't include integrate.h.
17437         (allocate_initial_values): Move from integrate.c to here.
17438         (ira): Update allocate_initial_values call.
17439         * tree-inline.c: Don't include integrate.h.
17440         (function_attribute_inlinable_p): Moved from integrate.c to here.
17441         * cfgexpand.c: Don't include integrate.h.
17442         * except.c: Likewise.
17443         * langhooks.c: Likewise.
17444         * passes.c: Likewise.
17445         * toplev.c: Likewise.
17446         * config/frv/frv.c: Likewise.
17447         * config/pa/pa.c: Likewise.
17448         * config/spu/spu.c: Likewise.
17449         * config/epiphany/epiphany.c: Likewise.
17450         * config/mep/mep.c: Likewise.
17451         * config/score/score.c: Likewise.
17452         * config/picochip/picochip.c: Likewise.
17453         * config/sh/sh.c: Likewise.
17454         * config/alpha/alpha.c: Likewise.
17455         * config/microblaze/microblaze.c: Likewise.
17456         * config/mips/mips.c: Likewise.
17457         * config/v850/v850.c: Likewise.
17458         * config/mmix/mmix.c: Likewise.
17459         * config/bfin/bfin.c: Likewise.
17460         * config/arm/arm.c: Likewise.
17461         * config/s390/s390.c: Likewise.
17462         * config/m32r/m32r.c: Likewise.
17463         * config/rs6000/rs6000.c: Likewise.
17464         * config/c6x/c6x.c: Include function.h instead of integrate.h.
17465         * config/tilegx/tilegx.c: Likewise.
17466         * config/tilepro/tilepro.c: Likewise.
17467
17468 2012-05-29  Georg-Johann Lay  <avr@gjlay.de>
17469
17470         * config/avr/t-avr (s-avr-mmcu-texi): Call
17471         gen-avr-mmcu-texi$(build_exeext) via ./ and don't assume . is in PATH.
17472
17473 2012-05-29  Michael Matz  <matz@suse.de>
17474
17475         * rtl.h (assign_stack_temp, assign_stack_temp_for_type,
17476         assign_temp): Remove 'keep' argument.
17477         (mark_temp_addr_taken): Remove prototype.
17478         * tree.h (expand_decl): Remove prototype.
17479         * function.c (struct temp_slot): Remove addr_taken and keep member.
17480         (assign_stack_temp_for_type) Don't initialize above, remove
17481         keep argument.
17482         (assign_stack_temp, assign_temp): Remove keep argument.
17483         (mark_temp_addr_taken): Remove.
17484         (preserve_temp_slots): Remove handling of addr_taken and keep members.
17485         (free_temp_slots): Ditto.
17486         * expr.c (expand_expr_real_1 <COMPOUND_LITERAL_EXPR>): Remove
17487         dead code.
17488         * stmt.c (expand_asm_operands): Remove dead code.
17489         (expand_decl): Remove.
17490         * c-decl.c (finish_struct): Don't call expand_decl.
17491         * builtins.c (expand_builtin_cexpi): Adjust calls to assign_temp
17492         and assign_stack_temp.
17493         * calls.c (save_fixed_argument_area, initialize_argument_information,
17494         expand_call, emit_library_call_value_1, store_one_arg): Ditto.
17495         * expmed.c (extract_bit_field_1): Ditto.
17496         * expr.c (emit_group_load_1, emit_group_store,
17497         copy_blkmode_from_reg, emit_push_insn, expand_assignment,
17498         store_field, expand_constructor, expand_cond_expr_using_cmove,
17499         expand_expr_real_2, expand_expr_real_1): Ditto.
17500         * stmt.c (expand_asm_operands, expand_return): Ditto.
17501
17502         * function.c (pop_temp_slots): Call free_temp_slots.
17503         * calls.c (store_one_arg): Don't call preserve_temp_slots or
17504         free_temp_slots.
17505         * expr.c (expand_assignment): Don't call free_temp_slots.
17506
17507         * config/arm/arm.c (neon_expand_vector_init): Ditto.
17508         * config/i386/i386.c (ix86_expand_vector_set): Ditto.
17509         (ix86_expand_vector_extract): Ditto.
17510         * config/ia64/ia64.c (spill_xfmode_rfmode_operand,
17511         ia64_expand_movxf_movrf): Ditto.
17512         * config/mips/mips.c (mips_expand_vi_general): Ditto.
17513         * config/mmix/mmix.md (floatdisf2, floatunsdisf2, truncdfsf2,
17514         extendsfdf2): Ditto.
17515         * config/rs6000/rs6000.c (rs6000_expand_vector_init,
17516         rs6000_expand_vector_set, rs6000_expand_vector_extract,
17517         rs6000_allocate_stack_temp): Ditto.
17518         * config/rs6000/rs6000.md (fix_trunctfsi2_fprs): Ditto.
17519         * config/sparc/sparc.c (emit_soft_tfmode_libcall,
17520         sparc_emit_float_lib_cmp, sparc_emit_float_lib_cmp,
17521         sparc_expand_vector_init): Ditto.
17522
17523 2012-05-29  Michael Matz  <matz@suse.de>
17524
17525         * c-tree.h (c_expand_decl): Remove prototype.
17526
17527         * expr.c (expand_expr_real_1 <normal_inner_ref>): Don't allocate
17528         a kept temp.
17529         (expand_expr_real_1 <COMPOUND_LITERAL_EXPR>): Make unreachable.
17530         * gimple-fold.c (canonicalize_constructor_val): Canonicalize
17531         COMPOUND_LITERAL_EXPR.
17532         * function.c (expand_function_start): Don't call expand_decl,
17533         instead assert that we have RTL assigned.
17534         * tree-ssa-live.c (remove_unused_locals): Clear
17535         nonlocal_goto_save_area if its backing variable is removed.
17536         * stmt.c (expand_asm_operands): Remove handling of non-lvalues
17537         as mem inputs.
17538         (expand_decl): Assert that this does nothing.
17539         * calls.c (expand_call): Don't call mark_temp_addr_taken.
17540
17541 2012-05-29  Richard Guenther  <rguenther@suse.de>
17542
17543         PR tree-optimization/53516
17544         * tree-data-ref.c (stmt_with_adjacent_zero_store_dr_p): Reject
17545         bitfield accesses.
17546         * tree-vect-data-refs.c (vect_analyze_data_refs): Likewise.
17547
17548 2012-05-29  Joseph Myers  <joseph@codesourcery.com>
17549
17550         * LANGUAGES: Fix typos.
17551         * Makefile.in: Fix typos.
17552         * alias.c: Fix typos.
17553         * auto-inc-dec.c: Fix typos.
17554         * bb-reorder.c: Fix typos.
17555         * cfgcleanup.c: Fix typos.
17556         * cgraph.c: Fix typos.
17557         * cgraph.h: Fix typos.
17558         * cgraphunit.c: Fix typos.
17559         * collect2-aix.h: Fix typos.
17560         * collect2.c: Fix typos.
17561         * compare-elim.c: Fix typos.
17562         * config/alpha/vms.h: Fix typos.
17563         * config/arm/README-interworking: Fix typos.
17564         * config/arm/arm.c: Fix typos.
17565         * config/arm/iterators.md: Fix typos.
17566         * config/arm/vxworks.h: Fix typos.
17567         * config/avr/avr.c: Fix typos.
17568         * config/avr/avr.h: Fix typos.
17569         * config/avr/avr.md: Fix typos.
17570         * config/avr/builtins.def: Fix typos.
17571         * config/c6x/c6x.c: Fix typos.
17572         * config/cr16/cr16.c: Fix typos.
17573         * config/cr16/cr16.md: Fix typos.
17574         * config/cris/cris.md: Fix typos.
17575         * config/darwin.c: Fix typos.
17576         * config/darwin.opt: Fix typos.
17577         * config/i386/i386-c.c: Fix typos.
17578         * config/i386/i386.c: Fix typos.
17579         * config/ia64/ia64.c: Fix typos.
17580         * config/m68k/cf.md: Fix typos.
17581         * config/mep/mep.c: Fix typos.
17582         * config/microblaze/microblaze.c: Fix typos.
17583         * config/microblaze/microblaze.h: Fix typos.
17584         * config/mn10300/mn10300.c: Fix typos.
17585         * config/mn10300/mn10300.md: Fix typos.
17586         * config/pa/pa.c: Fix typos.
17587         * config/picochip/picochip.h: Fix typos.
17588         * config/rs6000/a2.md: Fix typos.
17589         * config/rs6000/rs6000.c: Fix typos.
17590         * config/rs6000/vector.md: Fix typos.
17591         * config/rx/rx.md: Fix typos.
17592         * config/rx/rx.opt: Fix typos.
17593         * config/s390/2097.md: Fix typos.
17594         * config/s390/s390.c: Fix typos.
17595         * config/s390/s390.h: Fix typos.
17596         * config/sh/sh.c: Fix typos.
17597         * config/sh/sh.md: Fix typos.
17598         * config/sparc/sync.md: Fix typos.
17599         * config/spu/spu.c: Fix typos.
17600         * config/spu/spu.md: Fix typos.
17601         * config/vms/vms.c: Fix typos.
17602         * config/vxworks-dummy.h: Fix typos.
17603         * config/vxworks.h: Fix typos.
17604         * cselib.c: Fix typos.
17605         * df-scan.c: Fix typos.
17606         * df.h: Fix typos.
17607         * doc/extend.texi: Fix typos.
17608         * doc/install.texi: Fix typos.
17609         * doc/invoke.texi: Fix typos.
17610         * doc/md.texi: Fix typos.
17611         * doc/plugins.texi: Fix typos.
17612         * doc/rtl.texi: Fix typos.
17613         * dse.c: Fix typos.
17614         * dwarf2asm.c: Fix typos.
17615         * dwarf2out.c: Fix typos.
17616         * except.h: Fix typos.
17617         * expr.c: Fix typos.
17618         * fold-const.c: Fix typos.
17619         * gcc.c: Fix typos.
17620         * gcse.c: Fix typos.
17621         * genautomata.c: Fix typos.
17622         * gengtype-state.c: Fix typos.
17623         * gengtype.c: Fix typos.
17624         * genhooks.c: Fix typos.
17625         * gimple-fold.c: Fix typos.
17626         * gimple-pretty-print.c: Fix typos.
17627         * gimple.c: Fix typos.
17628         * gimple.h: Fix typos.
17629         * gimplify.c: Fix typos.
17630         * graphite-interchange.c: Fix typos.
17631         * graphite-sese-to-poly.c: Fix typos.
17632         * ifcvt.c: Fix typos.
17633         * input.c: Fix typos.
17634         * ipa-cp.c: Fix typos.
17635         * ipa-inline-analysis.c: Fix typos.
17636         * ipa-inline-transform.c: Fix typos.
17637         * ipa-inline.c: Fix typos.
17638         * ipa-pure-const.c: Fix typos.
17639         * ipa-ref.h: Fix typos.
17640         * ipa-reference.c: Fix typos.
17641         * ipa-utils.c: Fix typos.
17642         * ipa.c: Fix typos.
17643         * ira-emit.c: Fix typos.
17644         * ira-lives.c: Fix typos.
17645         * lto-streamer.c: Fix typos.
17646         * lto-streamer.h: Fix typos.
17647         * lto-wrapper.c: Fix typos.
17648         * mcf.c: Fix typos.
17649         * mode-switching.c: Fix typos.
17650         * modulo-sched.c: Fix typos.
17651         * plugin.c: Fix typos.
17652         * postreload.c: Fix typos.
17653         * sched-deps.c: Fix typos.
17654         * sel-sched-ir.c: Fix typos.
17655         * sel-sched-ir.h: Fix typos.
17656         * sel-sched.c: Fix typos.
17657         * sese.c: Fix typos.
17658         * stor-layout.c: Fix typos.
17659         * target-hooks-macros.h: Fix typos.
17660         * target.def: Fix typos.
17661         * trans-mem.c: Fix typos.
17662         * tree-eh.c: Fix typos.
17663         * tree-predcom.c: Fix typos.
17664         * tree-sra.c: Fix typos.
17665         * tree-ssa-address.c: Fix typos.
17666         * tree-ssa-loop-ivopts.c: Fix typos.
17667         * tree-ssa-loop-niter.c: Fix typos.
17668         * tree-ssa-math-opts.c: Fix typos.
17669         * tree-ssa-pre.c: Fix typos.
17670         * tree-ssa-propagate.c: Fix typos.
17671         * tree-ssa-reassoc.c: Fix typos.
17672         * tree-ssa-sccvn.c: Fix typos.
17673         * tree-ssa-ter.c: Fix typos.
17674         * tree-ssa-uninit.c: Fix typos.
17675         * tree-ssanames.c: Fix typos.
17676         * tree-vect-generic.c: Fix typos.
17677         * tree-vect-slp.c: Fix typos.
17678         * tree.c: Fix typos.
17679         * tree.h: Fix typos.
17680         * varasm.c: Fix typos.
17681         * varpool.c: Fix typos.
17682
17683 2012-05-29  Joseph Myers  <joseph@codesourcery.com>
17684
17685         * doc/include/texinfo.tex: Update to version 2012-05-16.16.
17686
17687 2012-05-29  Richard Guenther  <rguenther@suse.de>
17688
17689         * tree-dfa.c (find_vars_r): Do not call add_referenced_vars
17690         for globals.
17691         (add_referenced_var_1): Re-organize.  Assert we are not
17692         called for globals.
17693         (remove_referenced_var): Likewise.
17694         * varpool.c (add_new_static_var): Use create_tmp_var_raw.
17695         * tree-mudflap.c (execute_mudflap_function_ops): Do not
17696         call add_referenced_var on globals.
17697         * matrix-reorg.c (transform_access_sites): Likewise.
17698
17699 2012-05-29  Steven Bosscher  <steven@gcc.gnu.org>
17700
17701         * alias.c (reg_known_value): Make this a VEC.
17702         (reg_known_equiv_p): Make this an sbitmap.
17703         (reg_known_value_size): Remove.
17704         (get_reg_known_value, set_reg_known_value, get_reg_known_equiv_p,
17705         set_reg_known_equiv_p): Update for reg_known_value and
17706         reg_known_value_size data structure change.
17707         (init_alias_analysis, end_alias_analysis): Likewise.
17708
17709 2012-05-29  Jakub Jelinek  <jakub@redhat.com>
17710
17711         PR middle-end/53510
17712         * input.c (read_line): Use XRESIZEVEC instead of XNEWVEC
17713         to avoid leaking memory.  No need to handle memory allocation
17714         failure.  Double string_len on each reallocation instead of adding 2.
17715         * gcov.c (read_line): Likewise.
17716
17717 2012-05-29  Hans-Peter Nilsson  <hp@axis.com>
17718
17719         * config/cris/cris.h (TARGET_HAS_BREAK, TARGET_TRAP_USING_BREAK8):
17720         New macros.
17721         * config/cris/cris.md ("trap"): Define, enabled for
17722         TARGET_TRAP_USING_BREAK8.
17723         * config/cris/cris.opt (mtrap-using-break8): New option.
17724
17725 2012-05-28  Paolo Carlini  <paolo.carlini@oracle.com>
17726
17727         PR c++/25137
17728         * doc/invoke.texi: Document -Wmissing-braces not enabled by -Wall
17729         for C++.
17730
17731 2012-05-28  Hans-Peter Nilsson  <hp@axis.com>
17732
17733         * doc/md.texi (stack_protect_test): Remove negation of branch to label.
17734         (Standard Names): Fix typos in documentation of atomic patterns.
17735
17736 2012-05-27  Nathan Sidwell  <nathan@acm.org>
17737
17738         * tree.c (build_constructor): Propagate TREE_SIDE_EFFECTS.
17739
17740 2012-05-26  Jason Merrill  <jason@redhat.com>
17741
17742         PR c++/53220
17743         * c-typeck.c (array_to_pointer_conversion): Give -Wc++-compat warning
17744         about array compound literals.
17745
17746 2012-05-26  Eric Botcazou  <ebotcazou@adacore.com>
17747
17748         * cfgcleanup.c (try_optimize_cfg): Do not delete forwarder blocks
17749         if CLEANUP_NO_INSN_DEL.
17750         * cfgrtl.c (unique_locus_on_edge_between_p): New function extracted
17751         from cfg_layout_merge_blocks.
17752         (emit_nop_for_unique_locus_between): New function.
17753         (rtl_merge_blocks): Invoke emit_nop_for_unique_locus_between.
17754         (cfg_layout_merge_blocks): Likewise.
17755
17756 2012-05-26  Dimitrios Apostolou  <jimis@gmx.net>
17757             Paolo Bonzini  <bonzini@gnu.org>
17758
17759         * df-scan.c (df_def_record_1): Assert a parallel must contain an
17760         EXPR_LIST at this point.  Receive the LOC and move its extraction...
17761         (df_defs_record): ... here. Change if-else to a switch statement.
17762         (df_find_hard_reg_defs, df_find_hard_reg_defs_1): New.
17763         (df_get_call_refs): Changed defs_generated from bitmap to HARD_REG_SET
17764         and compute it from df_find_hard_reg_defs(). Record DF_REF_BASE
17765         DEFs in REGNO order. Use HARD_REG_SET instead of bitmap for
17766         regs_invalidated_by_call.
17767         (df_insn_refs_collect): Record DF_REF_REGULAR DEFs after
17768         df_get_call_refs().
17769
17770 2012-05-25  Eric Botcazou  <ebotcazou@adacore.com>
17771
17772         PR lto/52178
17773         * tree-inline.c (remap_gimple_op_r): Fix handling of FIELD_DECL.
17774         * tree.c (RETURN_TRUE_IF_VAR): Do not return true for PLACEHOLDER_EXPR.
17775
17776 2012-05-25  Michael Meissner  <meissner@linux.vnet.ibm.com>
17777
17778         * config/rs6000/t-linux64: Delete the 32-bit multilib that uses
17779         software floating point emulation.  No longer build the multilibs
17780         with -mstrict-align.
17781
17782 2012-05-25  Aldy Hernandez  <aldyh@redhat.com>
17783
17784         PR middle-end/53008
17785         * trans-mem.c (ipa_tm_create_version_alias): Output new_node if
17786         accessed indirectly.
17787         (ipa_tm_create_version): Same.
17788
17789 2012-05-25  Uros Bizjak  <ubizjak@gmail.com>
17790
17791         PR target/53474
17792         * config/i386/i386.c (ix86_print_operand) <case 'O'>: Print '.' here.
17793         <case 'C', case 'c', case 'F', case 'f'>: Print '.' only for C and c.
17794
17795 2012-05-25  Alexander Ivchenko  <alexander.ivchenko@intel.com>
17796
17797         PR target/53435
17798         * config/i386/i386.c (ix86_expand_vec_perm): Use correct op.
17799         (ix86_expand_vec_perm): Use int mode instead of float.
17800         (expand_vec_perm_pshufb): Remove handling of useseless type
17801         conversion.
17802
17803 2012-05-25  Eric Botcazou  <ebotcazou@adacore.com>
17804
17805         PR ada/52362
17806         * config.gcc (i[34567]86-*-mingw* | x86_64-*-mingw*): Set gas and
17807         gnu_ld variables to yes.
17808         * configure.ac (HAVE_GNU_LD): Move to after config.gcc inclusion.
17809         (HAVE_GNU_AS): Likewise.
17810         * config.in: Regenerate.
17811         * configure: Likewise.
17812
17813 2012-05-25  Tristan Gingold  <gingold@adacore.com>
17814
17815         * config/i386/i386.c (struct ix86_frame): Remove unused frame field.
17816         (ix86_compute_frame_layout): Fix type of stack_alignment_needed
17817         and preferred_alignment.
17818
17819 2012-05-25  Tristan Gingold  <gingold@adacore.com>
17820
17821         * common/config/ia64/ia64-common.c (ia64_except_unwind_info): Fix typo.
17822
17823 2012-05-25  Thomas Schwinge  <thomas@codesourcery.com>
17824
17825         * fold-const.c (optimize_bit_field_compare): Abort early in the strict
17826         volatile bitfields case.
17827
17828 2012-05-24  Pat Haugen  <pthaugen@us.ibm.com>
17829
17830         * config/rs6000/rs6000.c (rs6000_option_override_internal): Change
17831         rs6000_sched_costly_dep default to true_store_to_load_dep_costly.
17832         (adjacent_mem_locations): Move some code to and call...
17833         (get_memref_parts): ...new function.
17834         (mem_locations_overlap): New function.
17835         (rs6000_adjust_priority): Adjust calls to is_load_insn/is_store_insn.
17836         (is_mem_ref): Rename to...
17837         (find_mem_ref): ...this. Return MEM rtx.
17838         (get_store_dest): Remove function.
17839         (is_load_insn1, is_load_insn, is_store_insn1, is_store_insn): Add
17840         new parameter and adjust calls.
17841         (rs6000_is_costly_dependence): Update calls for extra arg. Make sure
17842         mem refs overlap for true_store_to_load_dep_costly.
17843         (rs6000_sched_reorder2): Update calls for extra arg. Adjust args
17844         passed to adjacent_mem_locations.
17845         (is_costly_group): Walk resolved dependency list.
17846         (force_new_group): Emit group ending nop for Power6/Power7.
17847         * config/rs6000/rs6000.md (UNSPEC_GRP_END_NOP): New enum value.
17848         (group_ending_nop): New define_insn.
17849
17850 2012-05-24  Dodji Seketeli  <dodji@redhat.com>
17851
17852         Make unwound macro expansion trace less redundant
17853         * tree-diagnostic.c (maybe_unwind_expanded_macro_loc): Don't print
17854         context of macro definition in the trace, when it's redundant.
17855         Update comments.
17856
17857 2012-05-24  Richard Guenther  <rguenther@suse.de>
17858
17859         PR middle-end/53460
17860         * tree-profile.c (tree_profiling): Cleanup the CFG if
17861         execute_fixup_cfg requests it.
17862
17863 2012-05-24  Richard Guenther  <rguenther@suse.de>
17864
17865         * tree-flow.h (create_var_ann): Remove.
17866         * tree-dfa.c (create_var_ann): Remove and inline into its
17867         single caller ...
17868         (add_referenced_var_1): ... here.
17869         * varpool.c (add_new_static_var): Do not call add_referenced_var
17870         for global vars.
17871         * gimple-fold.c (canonicalize_constructor_val): Likewise.
17872         * tree-switch-conversion.c (build_one_array): Likewise.
17873         * tree-profile.c (gimple_gen_ic_profiler): Likewise.
17874         * tree-flow-inline.h (gimple_referenced_vars): Guard against
17875         NULL fn argument.
17876         * tree-inline.c (remap_gimple_op_r): Likewise.  Check
17877         gimple_referenced_vars instead of gimple_in_ssa_p.
17878         (copy_tree_body_r): Likewise.
17879         (setup_one_parameter): Likewise.
17880         (declare_return_variable): Likewise.
17881         (tree_function_versioning): Likewise.
17882
17883 2012-05-24  Jakub Jelinek  <jakub@redhat.com>
17884
17885         PR tree-optimization/53465
17886         * tree-vrp.c (extract_range_from_cond_expr): First copy_value_range
17887         vr0 into *vr, then vrp_meet that.
17888         (vrp_meet): If one vr type is VR_UNDEFINED, ensure the result doesn't
17889         have any equivalences.
17890         (vrp_visit_phi_node): Call copy_value_range instead of vrp_meet the
17891         first time.
17892
17893 2012-05-24  Jim MacArthur  <jim.macarthur@arm.com>
17894
17895         * recog.c (reg_fits_class_p): Check both regno and regno + offset are
17896         hard registers.
17897         * regs.h (in_hard_reg_set_p): Assert that regno is a hard register and
17898         check end_regno - 1 is a hard register.
17899
17900 2012-05-24  Richard Guenther  <rguenther@suse.de>
17901
17902         * varpool.c (add_new_static_var): Remove call to create_var_ann.
17903         * tree-ssa-operands.c (create_vop_var): Likewise.
17904
17905 2012-05-24  Richard Guenther  <rguenther@suse.de>
17906
17907         PR bootstrap/53466
17908         * tree-ssa-live.c (remove_unused_scope_block_p): Properly
17909         handle globals.
17910         (remove_unused_locals): Pass global_unused_vars to
17911         remove_unused_scope_block_p.  Restore code walking all
17912         referenced vars and pruning them.
17913
17914 2012-05-23  Jan Hubicka  <jh@suse.cz>
17915
17916         * tree.h (alias_diag_flags): Remove.
17917         (alias_pair): Remove emitted_diags.
17918         (finish_aliases_1, finish_aliases_2, remove_unreachable_alias_pairs,
17919         symbol_alias_set_t, symbol_alias_set_destroy,
17920         symbol_alias_set_contains, propagate_aliases_backward): Remove.
17921         * toplev.c (compile_file): Do not call finish_aliases_2
17922         * cgraphunit.c (cgraph_process_new_functions): Do not call
17923         finish_aliases_1.
17924         (handle_alias_pairs): Output diagnostics about aliases to externals.
17925         (assemble_thunks_and_aliases): Use do_assemble_alias.
17926         (output_weakrefs): Likewise.
17927         (finalize_compilation_unit): Do not call finish_aliases_1.
17928         * ipa.c (symtab_remove_unreachable_nodes): De not call
17929         remove_unreachable_alias_pairs.
17930         * varasm.c (do_assemble_alias): Export.
17931         (symbol_alias_set_create, symbol_alias_set_destroy,
17932         symbol_alias_set_contains, symbol_alias_set_insert,
17933         propagate_aliases_forward, propagate_aliases_backward,
17934         propagate_aliases_backward, trivially_visible_alias,
17935         trivially_defined_alias, remove_unreachable_alias_pairs,
17936         finish_aliases_1, finish_aliases_2, assemble_alias): Remove.
17937         * output.h (do_assemble_alias): Declare.
17938         * varpool.c (varpool_remove_unreferenced_decls): Do not call
17939         finish_aliases_1.
17940
17941 2012-05-23  Martin Jambor  <mjambor@suse.cz>
17942
17943         * ipa-inline-analysis.c (inline_merge_summary): Free operand_map.
17944
17945 2012-05-23  Eric Botcazou  <ebotcazou@adacore.com>
17946
17947         * gimple.c (gimple_types_compatible_p_1) <ARRAY_TYPE>: Remove bogus
17948         size handling.
17949         (gimple_canonical_types_compatible_p) <ARRAY_TYPE>: Likewise.
17950         (iterative_hash_gimple_type): Adjust comment.
17951         (iterative_hash_canonical_type): Likewise.  Hash the bounds of the
17952         domain for an array type instead of the domain type itself.
17953
17954 2012-05-23  Richard Guenther  <rguenther@suse.de>
17955
17956         PR tree-optimization/53438
17957         * tree-sra.c (analyze_access_subtree): Correct bitfield exclusion.
17958
17959 2012-05-23  Georg-Johann Lay  <avr@gjlay.de>
17960
17961         PR target/53448
17962         * config/avr/avr.h (ASM_OUTPUT_ALIGN): Don't inhibit .p2align 1.
17963         * config/avr/elf.h (ASM_OUTPUT_BEFORE_CASE_LABEL): Use
17964         ASM_OUTPUT_ALIGN.
17965
17966 2012-05-23  Richard Guenther  <rguenther@suse.de>
17967
17968         * tree-dfa.c (add_referenced_var_1): Do not add global vars.
17969         * tree-ssa-live.c (mark_all_vars_used_1): Handle global vars
17970         via the global_unused_vars bitmap.
17971         (remove_unused_locals): Handle global vars in local-decls via
17972         a global_unused_vars bitmap instead of the used flag in the
17973         var annotation.  Simplify global variable handling and removal.
17974
17975 2012-05-22  Jan Hubicka  <jh@suse.cz>
17976
17977         PR middle-end/53426
17978         * tree-ssa-structalias.c (create_variable_info_for): Skip constructors
17979         from other partitions.
17980
17981 2012-05-22  Jan Hubicka  <jh@suse.cz>
17982
17983         PR middle-end/53161
17984         * symtab.c (symtab_register_node): Fix ordering issue.
17985
17986 2012-05-22  Steven Drake <sbd@NetBSD.org>
17987
17988         * gcc.c (do_spec_1): Add %M spec token to output multilib_os_dir.
17989
17990 2012-05-22  David Edelsohn  <dje.gcc@gmail.com>
17991
17992         * config/rs6000/rs6000.c (rs6000_aix_asm_output_dwarf_table_ref):
17993         Use strip_name_encoding target hook.
17994
17995 2012-05-22  Richard Guenther  <rguenther@suse.de>
17996
17997         * tree.h (VAR_DECL_IS_VIRTUAL_OPERAND): New.
17998         (init_function_for_compilation): Remove.
17999         * tree-dfa.c (find_vars_r): Take struct function argument.
18000         (find_referenced_vars_in): Adjust.
18001         * tree-ssa-operands.c (clobber_stats): Remove.
18002         (create_vop_var): Take struct function argument.  Mark
18003         virtual operand with VAR_DECL_IS_VIRTUAL_OPERAND.
18004         (init_ssa_operands): Take struct function argument.
18005         (fini_ssa_operands): Do not dump dead stats.
18006         * tree-ssa-operands.h (init_ssa_operands): Take struct function
18007         argument.
18008         * cgraphunit.c (init_lowered_empty_function): Adjust.
18009         * lto-streamer-in.c (input_cfg): Likewise.
18010         * tree-inline.c (initialize_cfun): Likewise.
18011         * tree-into-ssa.c (rewrite_into_ssa): Likewise.
18012         * omp-low.c (expand_omp_taskreg): Likewise.  Avoid switching cfun.
18013         * gimple.c (is_gimple_reg): Optimize the SSA_NAME case,
18014         virtual operands are not registers.
18015
18016 2012-05-22  Richard Guenther  <rguenther@suse.de>
18017
18018         * tree-cfg.c (verify_gimple_assign_unary): Fix typo in previous commit.
18019
18020 2012-05-22  Richard Guenther  <rguenther@suse.de>
18021
18022         PR middle-end/53437
18023         * tree-inline.c (setup_one_parameter): Create a dummy init
18024         statement for unused parameters when not optimizing.
18025
18026 2012-05-22  Richard Guenther  <rguenther@suse.de>
18027
18028         * tree-flow.h (add_referenced_var_1): Declare.
18029         (add_referenced_var): Define.
18030         * tree-dfa.c (referenced_var_check_and_insert): Avoid one hash lookup.
18031         (add_referenced_var): Rename to ...
18032         (add_referenced_var_1): ... this.  Take struct function argument.
18033
18034 2012-05-22  Ramana Radhakrishnan  <ramana.radhakrishnan@linaro.org>
18035
18036         PR target/53334
18037         * config/arm/arm-protos.h (arm_validize_comparison): Declare.
18038         * config/arm/arm.c (arm_validize_comparison): Define.
18039         * config/arm/arm.md ("cbranchsi4"): Cleanup expansion and use
18040         arm_validize_comparison.
18041         ("cbranchdi4"): Likewise.
18042         ("cstoredi4"): Likewise.
18043         ("movsicc"): Likewise.
18044         ("movsfcc"): Likewise.
18045         ("movdfcc"): Likewise.
18046
18047 2012-05-22  Dimitrios Apostolou  <jimis@gmx.net>
18048
18049         * df-scan.c (df_scan_alloc): Round up allocation pools size, reduce
18050         the mw_reg_pool size.
18051
18052 2012-05-22  Paolo Bonzini  <bonzini@gnu.org>
18053
18054         PR tree-optimization/53336
18055         * tree-cfg.c (verify_gimple_assign_unary): Allow conversion from
18056         non-integer integral types to offset type and vice versa.
18057
18058 2012-05-22  Alan Modra  <amodra@gmail.com>
18059
18060         * config/rs6000/aix.h (FP_SAVE_INLINE, GP_SAVE_INLINE): Delete.
18061         * config/rs6000/darwin.h (FP_SAVE_INLINE, GP_SAVE_INLINE): Delete.
18062         * config/rs6000/sysv4.h (FP_SAVE_INLINE, GP_SAVE_INLINE,
18063         V_SAVE_INLINE): Delete.
18064         * config/rs6000/rs6000.c (V_SAVE_INLINE): Delete.
18065         (rs6000_savres_strategy): Reimplement GP/FP/V_SAVE_INLINE logic.
18066         For ELF targets, use out-of-line restores for -Os and any number
18067         of regs if the restore exits, and out-of-line gp save for two or
18068         more regs.  Use save_reg_p to test for holes in reg restore set.
18069         Replace "#if" with "if".
18070
18071 2012-05-22  Alan Modra  <amodra@gmail.com>
18072
18073         * config/rs6000/rs6000.c (save_reg_p): New function.
18074         (first_reg_to_save, first_fp_reg_to_save): Use it here.
18075         (first_altivec_reg_to_save, restore_saved_cr): Likewise.
18076         (emit_frame_save): Use gen_frame_store.
18077         (gen_frame_mem_offset): Correct SPE condition requiring reg+reg.
18078         (rs6000_emit_prologue): Use save_reg_p.  Use gen_frame_store for
18079         vrsave and toc.
18080         (rs6000_emit_epilogue): Use save_reg_p.  Use gen_frame_load for
18081         vrsave, toc, gp and fp restores.
18082
18083 2012-05-22  Alan Modra  <amodra@gmail.com>
18084
18085         * config/rs6000/rs6000.c: Delete unnecessary forward declarations.
18086         Move those with ATTRIBUTE_UNUSED to immediately before definitions.
18087         Move function pointer variables after forward declarations.
18088         (rs6000_builtin_support_vector_misalignment): Make static.
18089         (rs6000_legitimate_address_p, rs6000_gimplify_va_arg): Likewise.
18090         (rs6000_function_value, rs6000_can_eliminate): Likewise.
18091
18092 2012-05-21  Bernd Schmidt  <bernds@codesourcery.com>
18093
18094         PR rtl-optimization/53373
18095         * caller-save.c (save_call_clobbered_regs): Look into a possible
18096         PARALLEL manually rather than using single_set on a call insn.
18097
18098 2012-05-21  Jakub Jelinek  <jakub@redhat.com>
18099
18100         PR tree-optimization/53436
18101         * omp-low.c (omp_build_component_ref): New function.
18102         (build_receiver_ref, build_sender_ref, create_task_copyfn): Use it.
18103
18104 2012-05-21  Uros Bizjak  <ubizjak@gmail.com>
18105
18106         * config/i386/i386.c (put_condition_code): Change "reverse" and "fp"
18107         arguments to bool.
18108         (ix86_print_operand) <case 'O'>: Look at mode size of the operand.
18109         Do not print '.' here.  Output operand lossage error for unhandled
18110         sizes.  Move.
18111         <case '*'>: Move.
18112         <case '&'>: Ditto.
18113         <case 'Y'>: Ditto.
18114         <case 'z'>: Hardcode "code" argument into error strings.
18115         <case 'Z'>: Ditto.
18116         <case 'D'>: Merge AVX and non-AVX codes.
18117         <case 'C', case 'c', case 'F', case 'f'>: Merge.  Fix error string.
18118         Update call to put_condition_code.
18119
18120 2012-05-21  Andreas Schwab  <schwab@linux-m68k.org>
18121
18122         * config/m68k/m68k.md (*clzsi2_cf): Renamed from clzsi2.  Call
18123         CC_STATUS_INIT.
18124         (clzsi2): New expander.
18125         (*clzsi2_68k): New insn.
18126         * config/m68k/m68k.h: Update comment about CLZ_DEFINED_VALUE_AT_ZERO.
18127
18128 2012-05-21  Aldy Hernandez  <aldyh@redhat.com>
18129
18130         * gimple.h (gimple_set_in_transaction): Remove.
18131         (gimple_in_transaction): Look in BB instead.
18132         (gimple_statement_base): Remove in_transaction field.
18133         * basic-block.h (enum bb_flags): Add BB_IN_TRANSACTION.
18134         * trans-mem.c (compute_transaction_bits): Place transaction bit
18135         information into basic blocks.
18136
18137 2012-05-21  Andreas Schwab  <schwab@linux-m68k.org>
18138
18139         * expr.c (get_def_for_expr_class): Define only if
18140         HAVE_conditional_move.
18141         (convert_tree_comp_to_rtx): Likewise.
18142
18143 2012-05-21  Uros Bizjak  <ubizjak@gmail.com>
18144
18145         PR target/53399
18146         * config/i386/i386.md (ffs<mode>2): Generate CCCmode compare
18147         for TARGET_BMI.
18148         (ffssi2_no_cmove): Ditto.
18149         (*ffs<mode>_1): Remove insn pattern.
18150         (*tzcnt<mode>_1): New insn pattern.
18151         (*bsf<mode>1): Ditto.
18152
18153 2012-05-21  Richard Guenther  <rguenther@suse.de>
18154
18155         * tree-dfa.c (add_referenced_var): Do not walk DECL_INITIAL for
18156         more referenced vars.
18157         * tree-ssa-live.c (mark_all_vars_used_1): Only set the used
18158         flag on variables that have a var-annotation.
18159
18160 2012-05-21  Joseph Myers  <joseph@codesourcery.com>
18161
18162         PR c/53418
18163         * c-typeck.c (build_conditional_expr): Remove C_MAYBE_CONST_EXPR
18164         from folded operands before wrapping another around the
18165         conditional expression.
18166
18167 2012-05-21  Jakub Jelinek  <jakub@redhat.com>
18168
18169         PR tree-optimization/53366
18170         * tree-vect-slp.c (vect_supported_load_permutation_p): Don't shortcut
18171         tests if complex_numbers == 2, but there are non-complex number loads
18172         too.
18173
18174         PR tree-optimization/53409
18175         * tree-vect-loop.c (vect_analyze_loop_operations): Don't check
18176         vinfo_for_stmt (op_def_stmt) if op_def_stmt isn't inside loop.
18177
18178         PR tree-optimization/53410
18179         * fold-const.c (fold_binary_loc): Use build_zero_cst (type)
18180         instead of build_int_cst (type, 0) where vector types might be
18181         involved. Instead of build_int_cst (type, 1) convert the original
18182         integer_onep argument to the desired type.
18183
18184 2012-05-21  Michael Matz  <matz@suse.de>
18185
18186         * genattrtab.c (attr_rtx_cost): Move earlier, start with cost being 1.
18187         (simplify_test_exp): Handle one more case of distributive law,
18188         decrease cost threshold.
18189         (tests_attr_p, get_attr_order): New functions.
18190         (optimize_attrs): Use topological order, inline only cheap values.
18191         (write_attr_set): Reset our_known_true after some time.
18192
18193 2012-05-21  H.J. Lu  <hongjiu.lu@intel.com>
18194
18195         PR target/53425
18196         * config/i386/i386.c (type_natural_mode): Warn passing SSE
18197         vector argument without SSE enabled changes the ABI.
18198
18199 2012-05-21  Richard Guenther  <rguenther@suse.de>
18200
18201         PR tree-optimization/53408
18202         * tree-vect-loop.c (vectorizable_induction): Properly check
18203         the restriction that we cannot handle induction results from
18204         the inner loop outside of the outer loop.
18205
18206 2012-05-21  H.J. Lu  <hongjiu.lu@intel.com>
18207
18208         PR target/53416
18209         * config/i386/i386.md (UNSPEC_RDRAND): Renamed to ...
18210         (UNSPECV_RDRAND): This.
18211         (rdrand<mode>_1): Updated.
18212
18213 2012-05-21  Richard Guenther  <rguenther@suse.de>
18214
18215         * tree-loop-distribution.c (can_generate_builtin): Reject
18216         volatile stmts.
18217
18218 2012-05-21  Chung-Lin Tang  <cltang@codesourcery.com>
18219
18220         * Makefile.in (options.c): Add options.h to included header
18221         files, before tm.h.
18222
18223 2012-05-21  Razya Ladelsky  <razya@il.ibm.com>
18224
18225         * tree-parloops.c : Add myself to contributors, update
18226         TODO list, add link to wiki.
18227
18228 2012-05-21  Alan Modra  <amodra@gmail.com>
18229
18230         * config/rs6000/predicates.md (input_operand): Don't match
18231         constant pool addresses.  Remove label_ref, high and plus from
18232         match_code list.  Remove redundant CONSTANT_P test.
18233         (splat_input_operand): Similarly update match_code list.
18234         (small_toc_ref): New predicate.
18235         * config/rs6000/rs6000-protos.h (toc_relative_expr_p): Update prototype.
18236         * config/rs6000/rs6000.c (tocrel_base, tocrel_offset): Make const.
18237         (legitimate_constant_pool_address_p): Move TARGET_TOC test and
18238         register checks to..
18239         (toc_relative_expr_p): ..here.  Add "strict" param.  Match new rtl
18240         generated by create_TOC_reference.
18241         (rs6000_legitimize_address): Update cerate_TOC_reference call.
18242         (rs6000_delegitimize_address): Handle new rtl for toc refs.
18243         (rs6000_cannot_force_const_mem, rs6000_find_base_term): Likewise.
18244         (use_toc_relative_ref): New function, split out from..
18245         (rs6000_emit_move): ..here.  Remove redundant tests.  Update
18246         create_TOC_reference calls.
18247         (rs6000_legitimize_reload_address): Formatting.  Handle splitting
18248         of medium/large model toc addresses.  Use use_toc_relative_ref.
18249         (print_operand): Formatting, style.  Adjust for toc changes.
18250         (print_operand_address): Likewise.
18251         (rs6000_output_addr_const_extra): Likewise.
18252         (create_TOC_reference): Put TOC_REGISTER in UNSPEC_TOCREL rather
18253         than a PLUS.  Use this formulation for both high and low part
18254         of -mcmodel=medium/large toc reference too.  Before reload,
18255         always use the small model formulation.
18256         * config/rs6000/rs6000.md (tls_gd, tls_gd_high): Similarly avoid
18257         a PLUS in high part of addresses here.
18258         (tls_ld, tls_ld_high, tls_got_dtprel, tls_got_dtprel_high): Likewise.
18259         (tls_got_tprel, tls_got_tprel_high, largetoc_high): Likewise.
18260         (largetoc_high, largetoc_low): Move earlier.  Cope when no
18261         base reg available.
18262         (largetoc_high_plus): New insn.
18263         (movsi_internal1, movsi_internal1_single, movsf_softfloat,
18264         movdi_mfpgpr, movdi_internal64): Don't handle 'R' constraint here..
18265         (tocref): ..instead do so here, new insn and split.
18266
18267 2012-05-20  H.J. Lu  <hongjiu.lu@intel.com>
18268
18269         * config/i386/driver-i386.c (host_detect_local_cpu): Support
18270         RDRND, F16C and FSGSBASE.
18271
18272 2012-05-20  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
18273
18274         PR rtl-optimzation/53373
18275         * config/pa/pa.md (call_symref_pic): Don't expose PIC register save in
18276         call pattern.  Update split patterns.
18277         (call_symref_64bit, call_reg_pic, call_reg_64bit, call_val_symref_pic,
18278         call_val_symref_64bit, call_val_reg_pic, call_val_reg_64bit): Likewise.
18279
18280 2012-05-20  Razya Ladelsky  <razya@il.ibm.com>
18281
18282         * tree-parloops.c (gen_parallel_loop): Change many_iterations_cond
18283         for outer loops.
18284
18285 2012-05-18  Jan Hubicka  <jh@suse.cz>
18286
18287         * cgraphunit.c (handle_alias_pairs): Declare; free alias_pairs
18288         (cgraph_process_new_functions): Process also aliases.
18289         * lto-streamer-out.c (struct sets): Remove.
18290         (trivally_defined_alias): Remove.
18291         (output_alias_pair_p): Remove.
18292         (output_unreferenced_globals): Remove.
18293         (produce_symtab); Do not handle alias pairs.
18294         (produce_asm_for_decls): Likewise.
18295         * lto-streamer-in.c (input_alias_pairs): Remove.
18296         (lto_read_body): Do not input alias pairs.
18297         (lto_input_constructors_and_inits): Remove.
18298
18299 2012-05-18  Jan Hubicka  <jh@suse.cz>
18300
18301         * cgraphunit.c (handle_alias_pairs): Cleanup; handle all types of
18302         aliases.
18303
18304 2012-05-18  Jan Hubicka  <jh@suse.cz>
18305
18306         * cgraphbuild.c (record_reference): Update.
18307         * lto-cgraph.c (lto_output_varpool_node): External vars
18308         are not in other partition even if they are not output
18309         in current partition.
18310         * gimple-fold.c (can_refer_decl_in_current_unit_p): Take FROM_DECL
18311         argument; fix.
18312         (canonicalize_constructor_val): Take FROM_DECL argument.
18313         (fold_ctor_reference, fold_string_cst_ctor_reference,
18314         fold_array_ctor_reference, fold_nonarray_ctor_reference,
18315         fold_ctor_reference): Likewise.
18316         (fold_const_aggregate_ref_1, gimple_get_virt_method_for_binfo): Update.
18317         * gimple.h (gimple_fold_builtin): Likewise.
18318
18319 2012-05-18  Olivier Hainque  <hainque@adacore.com>
18320
18321         * Makefile.in (FLAGS_TO_PASS): Pass $(libexecsubdir) instead of
18322         $(libsubdir) as libexecsubdir.
18323
18324 2012-05-18  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
18325
18326         * config/rs6000/rs6000.c (print_operand): Revise code that unsafely
18327         relied on signed overflow behavior.
18328
18329 2012-05-18  Richard Guenther  <rguenther@suse.de>
18330
18331         PR tree-optimization/53346
18332         * tree-loop-distribution.c (ldist_gen): Make sure to apply
18333         builtin transform even when only a single partition with
18334         all reads/writes exists.
18335
18336 2012-05-18  Richard Guenther  <rguenther@suse.de>
18337
18338         PR tree-optimization/53390
18339         * tree-vect-data-refs.c (vect_compute_data_ref_alignment): Ignore
18340         strided loads.
18341
18342 2012-05-18  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
18343
18344         * tree-ssa-reassoc.c (bip_map): Remove decl.
18345         (completely_remove_stmt): Remove function.
18346         (remove_def_if_absorbed_call): Remove function.
18347         (remove_visited_stmt_chain): Remove __builtin_powi handling.
18348         (possibly_move_powi): Remove function.
18349         (rewrite_expr_tree): Remove calls to possibly_move_powi.
18350         (rewrite_expr_tree_parallel): Likewise.
18351         (attempt_builtin_powi): Build multiplies explicitly rather than
18352         relying on the ops vector and rank system.
18353         (transform_stmt_to_copy): New function.
18354         (transform_stmt_to_multiply): Likewise.
18355         (reassociate_bb): Handle leftover operations after __builtin_powi
18356         optimization; build a final multiply if necessary.
18357
18358 2012-05-18  Jan Hubicka  <jh@suse.cz>
18359
18360         * cgraphunit.c (varpool_finalize_decl): Allow external decls.
18361         (mark_functions_to_output): Fix sanity check.
18362         * ipa.c (function_and_variable_visibility): Remove TREE_STATIC check.
18363
18364 2012-05-18  Richard Guenther  <rguenther@suse.de>
18365
18366         * tree-flow.h (mark_symbols_for_renaming): Remove.
18367         * tree-dfa.c (mark_symbols_for_renaming): Likewise.
18368         * tree-inline.c (copy_edges_for_bb): Do not mark symbols for renaming.
18369         (copy_debug_stmt): Likewise.
18370         (expand_call_inline): Likewise.
18371         (declare_return_variable): Mark the return variable for renaming
18372         if necessary.
18373
18374 2012-05-18  Andrew Stubbs  <ams@codesourcery.com>
18375
18376         * config/arm/arm-protos.h (arm_emit_coreregs_64bit_shift): New
18377         prototype.
18378         * config/arm/arm.c (arm_emit_coreregs_64bit_shift): New function.
18379         * config/arm/arm.md (ashldi3): Use arm_emit_coreregs_64bit_shift.
18380         (ashrdi3,lshrdi3): Likewise.
18381         (arm_cond_branch): Remove '*' to enable gen_arm_cond_branch.
18382
18383 2012-05-18  Meador Inge  <meadori@codesourcery.com>
18384
18385         PR rtl-optimization/53352
18386         * cse.c (equiv_constant): Ignore paradoxical subregs.
18387
18388 2012-05-17  Steven Bosscher  <steven@gcc.gnu.org>
18389
18390         PR rtl-optimization/53125
18391         * regstat.c (regstat_bb_compute_ri): Take new local_live_last_luid
18392         argument.  Simplify calculation of REG_LIVE_LENGTH for regnos that
18393         die in the basic block.  Correctly top off REG_FREQ and
18394         REG_FREQ_CALLS_CROSSED.
18395         Remove do_not_gen.
18396         (regstat_compute_ri): Allocate and free local_live_last_luid.
18397         Remove do_not_gen.
18398         (regstat_bb_compute_calls_crossed): Correctly top off
18399         REG_FREQ_CALLS_CROSSED.
18400
18401 2012-05-17  Jan Hubicka  <jh@suse.cz>
18402
18403         * lto-symtab.c (lto_symtab_resolve_symbols): Preffer decl with
18404         constructor over decl without.
18405         * cgraph.c (cgraph_remove_node): Clear also body of unanalyzed nodes.
18406         * cgraph.h (varpool_can_remove_if_no_refs): Handle external correctly.
18407         * cgraphunit.c (process_function_and_variable_attributes): Finalize
18408         extrnal decls.
18409         (mark_functions_to_output): Also accept bodies for functions with
18410         clones.
18411         (output_in_order): Skip external vars.
18412         * lto-cgraph.c (lto_output_node): External functions are never in other
18413         partition.
18414         (lto_output_varpool_node): Likewise.
18415         * lto-streamer-out.c (lto_write_tree): Always use error_mark_nodes for
18416         forgotten initializers.
18417         * ipa.c (process_references): Handle external vars.
18418         (symtab_remove_unreachable_nodes): Update to handle external vars.
18419         (varpool_externally_visible_p): External vars are externally visible.
18420         * gimple-fold.c (can_refer_decl_in_current_unit_p): Update.
18421         * varpool.c (varpool_remove_node): Remove constructor.
18422         (decide_is_variable_needed): Handle externals.
18423         (varpool_remove_unreferenced_decls): Likewise.
18424
18425 2012-05-17  Manuel López-Ibáñez  <manu@gcc.gnu.org>
18426
18427         * opts.c (common_handle_option): -pedantic-errors enables -Wpedantic.
18428         (enable_warning_as_error): Do not special case Wuninitialized.
18429         * optc-gen.awk: Add sanity checks.
18430
18431 2012-05-17  Jan Hubicka  <jh@suse.cz>
18432
18433         * ipa-reference.c (is_proper_for_analysis): Do not check flags
18434         that might change as result of global optimization.
18435         (analyze_function): Do not check analyzed and externally_visible
18436         flags; be happy about address dereferences.
18437         (propagate): Prune all_module_statics so it really contains just
18438         statics; prune all the local summaries.
18439         (ipa_reference_write_optimization_summary): Simplify.
18440
18441 2012-05-17  Kwok Cheung Yeung  <kcy@codesourcery.com>
18442
18443         * config/m68k/m68k-devices.def: Add 51ag, 51je, 51jf, 51jg, 51mm, 51qm.
18444         * config/m68k/m68k-tables.opt: Regenerated.
18445         * doc/invoke.texi (M680x0 Options): Document.
18446
18447 2012-05-16  Dave Boutcher  <daveboutcher@gmail.com>
18448             Patrick Marlier  <patrick.marlier@gmail.com>
18449
18450         * trans-mem.c (ipa_tm_transform_clone): Transform functions with
18451         indirect calls.
18452
18453 2012-05-16  H.J. Lu  <hongjiu.lu@intel.com>
18454
18455         * configure: Regenerated.
18456
18457 2012-05-16  Andrew Pinski  <apinski@cavium.com>
18458
18459         * gimple-fold.c (get_maxval_strlen): Move COND_EXPR handling under
18460         GIMPLE_ASSIGN.
18461
18462 2012-05-16  David S. Miller  <davem@davemloft.net>
18463
18464         * jump.c (delete_related_insns): If we remove a CALL, make sure
18465         we delete it's NOTE_INSN_CALL_ARG_LOCATION note too.
18466
18467 2012-05-16  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
18468
18469         PR tree-optimization/53217
18470         * tree-ssa-reassoc.c (bip_map): New static variable.
18471         (possibly_move_powi): Move feeding multiplies with __builtin_powi call.
18472         (attempt_builtin_powi): Save feeding multiplies on a stack.
18473         (reassociate_bb): Create and destroy bip_map.
18474
18475 2012-05-16  Olivier Hainque  <hainque@adacore.com>
18476
18477         * Makefile.in (install-no-fixedincludes): New target, former toplevel
18478         gcc-no-fixedincludes. Stash "include-fixed" in addition to "include".
18479         Add comments and improve stamp preservation across the whole sequence.
18480         (stmp-int-hdrs): Use move-if-change + cp -p to setup fix_dir/limits.h.
18481
18482 2012-05-16  Richard Guenther  <rguenther@suse.de>
18483
18484         * tree-inline.c (insert_init_stmt): Do not call
18485         mark_symbols_for_renaming.
18486         (setup_one_parameter): Avoid initializing unused parameters.
18487         (declare_return_variable): Properly handle DECL_BY_REFERENCE
18488         return vars in SSA form.
18489
18490 2012-05-16  Richard Guenther  <rguenther@suse.de>
18491
18492         * tree-flow.h (get_virtual_var): Remove.
18493         * tree-dfa.c (get_virtual_var): Likewise.
18494
18495 2012-05-16  Richard Guenther  <rguenther@suse.de>
18496
18497         * tree-vect-loop-manip.c (slpeel_update_phi_nodes_for_guard1):
18498         Remove set-only bitmap of new names.
18499         (slpeel_tree_peel_loop_to_edge): Likewise.  Do not set
18500         CFG hooks.
18501         * tree-flow.h (ssa_names_to_replace): Remove.
18502         * tree-into-ssa.c (ssa_names_to_replace): Likewise.
18503
18504 2012-05-16  Richard Guenther  <rguenther@suse.de>
18505
18506         PR tree-optimization/53364
18507         * tree-ssa-alias.c (indirect_ref_may_alias_decl_p): Properly
18508         detect a view-conversion of the decl.
18509
18510 2012-05-16  Dodji Seketeli  <dodji@redhat.com>
18511
18512         PR preprocessor/7263
18513         * c-tree.h (enum c_declspec_word): Declare new enum.
18514         (struct c_declspecs::locations): New member.
18515         (declspecs_add_qual, declspecs_add_scspec)
18516         (declspecs_add_addrspace, declspecs_add_alignas): Take a new
18517         location parameter.
18518         * c-decl.c (build_null_declspecs): Initialize the new struct
18519         c_declspecs::locations member.
18520         (declspecs_add_addrspace): Take a location parameter for the
18521         address space.  Store it onto declaration specifiers.
18522         (declspecs_add_qual): Likewise, take a location parameter for the
18523         qualifier.
18524         (declspecs_add_type): Likewise, take a location parameter for the
18525         type specifier.
18526         (declspecs_add_scspec): Likewise, take a location parameter for
18527         the storage class specifier.
18528         (declspecs_add_attrs): Likewise, take a location parameter for the
18529         first attribute.
18530         (declspecs_add_alignas): Likewise, take a location parameter for
18531         the alignas token.
18532         (finish_declspecs): For diagnostics, use the location of the
18533         relevant declspec, instead of the global input_location.
18534         * c-parser.c (c_parser_parameter_declaration): Pass the precise
18535         virtual location of the declspec to the declspecs-setters.
18536         (c_parser_declspecs): Likewise.  Avoid calling c_parser_peek_token
18537         repeatedly.
18538
18539 2012-05-16  Igor Zamyatin  <igor.zamyatin@intel.com>
18540
18541         * configure.ac: Stack protector enabling for Android targets.
18542         * configure: Regenerate.
18543
18544 2012-05-16  Richard Sandiford  <r.sandiford@uk.ibm.com>
18545
18546         * ira.c (pseudo_move_insn): Delete.
18547         (find_moveable_pseudos): Don't set it.
18548         (move_unallocated_pseudos): Use DF_REG_DEF_CHAIN to find
18549         the definitions of the original pseudo.  Delete all of them.
18550
18551 2012-05-16  Olivier Hainque  <hainque@adacore.com>
18552
18553         * config/rs6000/rs6000-opts.h (enum processor_type): Add
18554         PROCESSOR_PPC8548.
18555         * config/rs6000/rs6000-cpus.def: Reference it for cpu="8548".
18556         * config/rs6000/rs6000.md (cpu attribute definition): Add ppc8548.
18557         * config/rs6000/8540.md: indicate that the units/patterns apply to
18558         ppc8548 as well.
18559
18560         * config/rs6000/rs6000.c (rs6000_option_override_internal): Rename
18561         default_cpu into implicit_cpu, conveying what --with-cpu was passed at
18562         configure time. Treat implicit_cpu as have_CPU. Pick defaults for SPE
18563         related flags,  check that what is queried is supported by the selected
18564         configuration. Rework the single/double_float and MASK_STRING resets to
18565         hit for all the E500 cores (854x + E500MC variants). Select the ppc8540
18566         costs for PROCESSOR_PPC8548 as well.
18567         (rs6000_issue_rate): case CPU_PPC8548 together with CPU_PPC8540.
18568         (rs6000_use_sched_lookahead): Likewise, rewriting function as a case
18569         statement instead of a sequence of ifs.
18570
18571         * config/rs6000/rs6000.h (TARGET_E500): Remove.
18572         (TARGET_NO_LWSYNC): Adjust accordingly.
18573         * config/rs6000/e500.h (TARGET_E500): Remove.
18574         (CHECK_E500_OPTIONS): Adjust accordingly.
18575         * config/rs6000/eabispe.h (SUBSUBTARGET_OVERRIDE_OPTIONS): Remove.
18576         (TARGET_DEFAULT): Reformat definition to match the one in linuxspe.h.
18577         * config/rs6000/linuxspe.h: Likewise.
18578         * config/rs6000/vxworks.h: Remove bogus TARGET_E500 overrides and
18579         superfluous comments.
18580         * config/rs6000/e500-double.h: Remove.
18581
18582         * config.gcc (pick a default with_cpu): For powerpc*-*-*spe*,
18583         default to with_cpu=8548 if --enable-e500-double, and to 8540
18584         otherwise.
18585         (set misc flags section): For powerpc*|rs6000*, remove inclusion
18586         of e500-double.h for --enable-e500-double.
18587
18588 2012-05-16  Olivier Hainque  <hainque@adacore.com>
18589
18590         * Makefile.in (s-header-vars): Resort to -n instead of trailing
18591         -e d in sed invocation.
18592
18593 2012-05-16  Hans-Peter Nilsson  <hp@axis.com>
18594
18595         * doc/tm.texi.in (Type Layout) <SIZE_TYPE>: Update reference to
18596         source-code.
18597         * doc/tm.texi: Regenerate.
18598
18599 2012-05-15  Paolo Carlini  <paolo.carlini@oracle.com>
18600
18601         * tree.h (EXPR_LOCATION): Use CAN_HAVE_LOCATION_P.
18602
18603 2012-05-15  Jakub Jelinek  <jakub@redhat.com>
18604
18605         PR target/53358
18606         * config/i386/i386.md (*addqi_2 peephole with QImode addition): Check
18607         that operands[2] is either immediate, or q_regs_operand.
18608
18609 2012-05-15  Richard Guenther  <rguenther@suse.de>
18610
18611         * cgraphunit.c (thunk_adjust): Use make_rename_temp.
18612         (assemble_thunk): Likewise.  Manually rename and register
18613         function arguments.
18614
18615 2012-05-15  Richard Guenther  <rguenther@suse.de>
18616
18617         PR tree-optimization/53355
18618         * tree-vrp.c (extract_range_from_binary_expr_1): Handle LSHIFT_EXPRs
18619         by constants.
18620
18621 2012-05-15  Tristan Gingold  <gingold@adacore.com>
18622
18623         * tree-ssa-strlen.c (get_string_length): Convert lhs if needed.
18624
18625 2012-05-15  Richard Guenther  <rguenther@suse.de>
18626
18627         * gimple.c (gimple_set_modified): Move ...
18628         * gimple.h (gimple_set_modified): ... here.
18629
18630 2012-05-15  Tristan Gingold  <gingold@adacore.com>
18631
18632         * ira-color.c (move_spill_restore): Add a guard.
18633
18634 2012-05-15  Tristan Gingold  <gingold@adacore.com>
18635
18636         * config/ia64/ia64.c (ia64_emit_probe_stack_range): Adjust calls to
18637         plus_constant.
18638
18639 2012-05-15  Eric Botcazou  <ebotcazou@adacore.com>
18640
18641         * gimplify.c (gimplify_init_constructor): Do a block move for very
18642         small objects as well.
18643
18644 2012-05-15  Bernd Schmidt  <bernds@codesourcery.com>
18645
18646         * ira.c (find_moveable_pseudos): Skip registers whose
18647         DF_REG_EQ_USE_COUNT is nonzero.
18648
18649 2012-05-15  Kenneth Zadeck  <zadeck@naturalbridge.com>
18650
18651         * doc/md.texi (fma): Define to only be applicable for single rounding.
18652
18653 2012-05-14  Uros Bizjak  <ubizjak@gmail.com>
18654
18655         PR target/46098
18656         * config/i386/i386.c (ix86_expand_special_args_builtin): Always
18657         generate target register for "load" class builtins.
18658
18659         Revert:
18660         2010-10-22  Uros Bizjak  <ubizjak@gmail.com>
18661
18662         PR target/46098
18663         * config/i386/sse.md (*avx_movu<ssemodesuffix><avxmodesuffix>):
18664         Rename from avx_movu<ssemodesuffix><avxmodesuffix>.
18665         (avx_movu<ssemodesuffix><avxmodesuffix>): New expander.
18666         (*<sse>_movu<ssemodesuffix>): Rename from <sse>_movu<ssemodesuffix>.
18667         (<sse>_movu<ssemodesuffix>): New expander.
18668         (*avx_movdqu<avxmodesuffix>): Rename from avx_movdqu<avxmodesuffix>.
18669         (avx_movdqu<avxmodesuffix>): New expander.
18670         (*sse2_movdqu): Rename from sse2_movdqu.
18671         (sse2_movdqu): New expander.
18672
18673 2012-05-14  Marc Glisse  <marc.glisse@inria.fr>
18674
18675         PR target/52607
18676         * config/i386/i386.c (ix86_expand_vec_perm_const): Move code to ...
18677         (canonicalize_perm): ... new function.
18678         (expand_vec_perm_2vperm2f128_vshuf): New function.
18679         (ix86_expand_vec_perm_const_1): Call it.
18680
18681 2012-05-14  Andrew Pinski  <apinski@cavium.com>
18682             H.J. Lu  <hongjiu.lu@intel.com>
18683             Jakub Jelinek  <jakub@redhat.com>
18684
18685         PR target/53315
18686         * config/i386/i386.md (xbegin_1): Use + in constraint and match_dup.
18687         (xbegin): Updated.
18688
18689 2012-05-14  Jakub Jelinek  <jakub@redhat.com>
18690
18691         * dwarf2out.c (dwarf2out_define, dwarf2out_undef): Treat
18692         lineno 1 the same as lineno 0 before first start file directive.
18693         (optimize_macinfo_range): Likewise.
18694
18695         * dwarf2out.c (have_macinfo): Define.
18696         (dwarf2out_finish): Don't emit DW_AT_GNU_macros or DW_AT_macro_info
18697         attribute, don't force empty compilation unit and don't emit any
18698         .debug_macinfo/.debug_macro section if macinfo_table is empty.
18699
18700 2012-05-14  Georg-Johann Lay  <avr@gjlay.de>
18701
18702         PR target/53344
18703         * config/avr/avr.c (avr_const_address_lo16): Remove.
18704         (avr_assemble_integer):  Print ".byte lo8(x)",
18705         ".byte hi8(x)", ".byte hh8(x)" instead of emit an assembler
18706         .warning if 3-byte address is assembled.
18707         * doc/extend.texi (AVR Named Address Spaces): Document that
18708         binutils 2.23 is needed to assemble 3-byte addresses.
18709
18710 2012-05-14  Richard Guenther  <rguenther@suse.de>
18711
18712         * tree-vect-data-refs.c (vect_setup_realignment): Remove
18713         call to mark_symbols_for_renaming.
18714         (vect_permute_load_chain): Likewise.
18715         * tree-vect-loop.c (vect_is_slp_reduction): Update stmt
18716         instead of calling mark_symbols_for_renaming.
18717         * tree-vect-stmts.c (read_vector_array): Remove call to
18718         mark_symbols_for_renaming.
18719         (write_vector_array): Likewise.
18720         (vectorizable_call): Likewise.
18721         (vectorizable_store): Likewise.
18722         (vectorizable_load): Likewise.
18723         * matrix-reorg.c (transform_allocation_sites): Likewise.
18724         * tree-ssa-pre.c (create_expression_by_pieces): Likewise.
18725         (create_expression_by_pieces): Likewise.
18726
18727 2012-05-14  Richard Guenther  <rguenther@suse.de>
18728
18729         * gimplify.c (gimple_regimplify_operands): Only mark the LHS
18730         of statements for renaming.
18731         (force_gimple_operand_1): Likewise, consistently for both
18732         calls to force_gimple_operand and force_gimple_operand_gsi.
18733
18734 2012-05-14  Richard Guenther  <rguenther@suse.de>
18735
18736         * tree-dfa.c (make_rename_temp): Be forgiving if not in SSA form.
18737         * omp-low.c (expand_omp_taskreg): Properly conditionalize call
18738         to update_ssa.
18739         (expand_omp_for): Likewise.
18740         (expand_omp_for_generic): Adjust conditional add to referenced vars.
18741         Use make_rename_temp for temporaries that should be rewritten into
18742         SSA form.
18743         (expand_omp_for_static_nochunk): Likewise.
18744         (expand_omp_atomic_pipeline): Likewise.
18745
18746 2012-05-14  Richard Guenther  <rguenther@suse.de>
18747
18748         PR tree-optimization/53331
18749         * tree-vect-data-refs.c (vect_verify_datarefs_alignment): Ignore
18750         strided loads.
18751         * tree-vect-stmts.c (vect_model_load_cost): Handle strided loads.
18752
18753 2012-05-14  Manuel López-Ibáñez  <manu@gcc.gnu.org>
18754
18755         PR 53063
18756         * doc/options.texi: (LangEnabledBy): Document it.
18757         * optc-gen.awk: Handle LangEnabledBy.
18758         * opth-gen.awk: Generate declaration for lang-specific functions.
18759         * opt-read.awk: Record lang numbers.
18760         * opt-functions.awk (flag_set_p): Ignore the arguments of flags.
18761         (lang_sanitized_name): New.
18762
18763 2012-05-14  Bernd Schmidt  <bernds@codesourcery.com>
18764
18765         * attribs.c (decl_attributes): Avoid emitting a warning if
18766         ATTR_FLAG_BUILT_IN.
18767         * doc/rtl.texi (CALL_INSN_FUNCTION_USAGE): Use lowercase for rtx
18768         codes.  Document meaning of sets inside CALL_INSN_FUNCTION_USAGE.
18769         * builtin-attrs.def (DEF_ATTR_FOR_STRING): Define.  Use it to
18770         define a string "1".
18771         (ATTR_RET1_NOTHROW_NONNULL_LEAF): New attr definition.
18772         * builtins.def (BUILT_IN_MEMCPY, BUILT_IN_MEMMOVE, BUILT_IN_MEMSET,
18773         BUILT_IN_STRCPY): Use it for these functions.
18774         * postreload.c (reload_combine): Deal with SETs inside
18775         CALL_INSN_FUNCTION_USAGE.
18776         * caller-save.c (setup_save_areas, save_call_clobbered_regs):
18777         Look for REG_RETURNED notes and use a cheap restore if possible.
18778         * ira-int.h (struct ira_allocno): New member cheap_calls_crossed_num.
18779         (ALLOCNO_CHEAP_CALLS_CROSSED_NUM): New macro.
18780         * ira-build.c (ira_create_allocno, create_cap_allocno,
18781         propagate_allocno_info, propagate_some_info_from_allocno,
18782         copy_info_to_removed_store_destination, ira_flattening): Handle it.
18783         * ira-lives.c (pseudo_regno_single_word_and_live_p,
18784         find_call_crossed_cheap_reg): New static functions.
18785         (process_bb_node_lives): Look for SETs in CALL_INSN_FUNCTION_USAGE,
18786         and set ALLOCNO_CHEAP_CALLS_CROSSED_NUM if possible.  Also make
18787         a REG_RETURNED note in that case.
18788         * ira.c (setup_reg_renumber): Change assert to allow cases where
18789         allocnos only cross calls for which they are cheap to restore.
18790         * ira-costs.c (ira_tune_allocno_costs): Compare
18791         ALLOCNO_CALLS_CROSSED_NUM to ALLOCNO_CHEAP_CALLS_CROSSED_NUM rather
18792         than 0.
18793         * reg-notes.def (REG_RETURNED): New note.
18794         * cse.c (cse_insn): Likewise.
18795         * sched-deps.c (sched_analyze_insn): Likewise.
18796         * expr.c (init_block_move_fn): Set a "fn spec" attribute.
18797         * calls.c (decl_return_flags): New static function.
18798         (expand_call): Generate a SET in CALL_INSN_FUNCTION_USAGE for
18799         functions that return one of their arguments.
18800         * regcprop.c (struct kill_set_value_data): New.
18801         (kill_set_value): Interpret data as a pointer to such a struct.
18802         Do nothing if the caller wants the register to be ignored.
18803         (copyprop_hardreg_forward_1): Handle SETs in CALL_INSN_FUNCTION_USAGE.
18804
18805 2012-05-14  Richard Guenther  <rguenther@suse.de>
18806
18807         PR tree-optimization/53340
18808         * tree-ssa-pre.c (op_valid_in_sets): Fix error in last commit.
18809
18810 2012-05-14  Richard Guenther  <rguenther@suse.de>
18811
18812         * gimplify.c (gimplify_expr): Remove odd code.
18813
18814 2012-05-14  Eric Botcazou  <ebotcazou@adacore.com>
18815
18816         * stor-layout.c (bit_from_pos): Distribute conversion to bitsizetype
18817         into a PLUS_EXPR byte offset.
18818
18819         * tree-ssa-pre.c (can_value_number_call): Delete.
18820         (compute_avail): Skip all statements with side effects.
18821         <GIMPLE_CALL>: Skip calls to internal functions.
18822
18823 2012-05-13  Steven Bosscher  <steven@gcc.gnu.org>
18824
18825         * config/pa/pa.md: Use define_c_enum for "unspec" and "unspecv".
18826
18827 2012-05-13  Manuel López-Ibáñez  <manu@gcc.gnu.org>
18828
18829         * common.opt (Wtype-limits): Use EnabledBy.
18830
18831 2012-05-13  Uros Bizjak  <ubizjak@gmail.com>
18832
18833         * config/i386/i386.md (*pushtf): Enable for TARGET_SSE.
18834         (pushtf splitter): Ditto.
18835         (movtf): Ditto.
18836         (*movtf_internal): Ditto. Use V4SFmode for !TARGET_SSE2.
18837         (<code>tf2): Enable for TARGET_SSE.
18838         (*absnegtf2_sse): Ditto.
18839         (copysign<mode>3): Enable TFmode for TARGET_SSE.
18840         (copysign<mode>3_const): Ditto.
18841         (copysign<mode>3_var): Ditto.
18842         * config/i386/sse.md (<code>tf3): Enable for TARGET_SSE.
18843         (*andnottf3): Ditto.  Use V4SFmode for !TARGET_SSE2.
18844         (*<code>tf3): Ditto.
18845         * config/i386/i386.c (struct builtin_description bdesc_args)
18846         <IX86_BUILTIN_FABSQ>: Enable for TARGET_SSE.
18847         <IX86_BUILTIN_COPYSIGNQ>: Ditto.
18848         (ix86_expand_builtin) <IX86_BUILTIN_FABSQ, IX86_BUILTIN_COPYSIGNQ>:
18849         Emit a normal call if SSE isn't available.
18850
18851 2012-05-13  Uros Bizjak  <ubizjak@gmail.com>
18852
18853         * config/i386/sse.md (<sse>_andnot<mode>3): Handle
18854         TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL.
18855         (<code><mode>3): Ditto.
18856         (*andnot<mode>3): Ditto.
18857         (*andnottf3): Ditto.
18858         (*<code><mode>3): Ditto.
18859         (<code>tf3): Ditto.
18860
18861 2012-05-13  Manuel López-Ibáñez  <manu@gcc.gnu.org>
18862
18863         * optc-gen.awk: Error instead of warning for conflicting help.
18864
18865 2012-05-12  Jason Merrill  <jason@redhat.com>
18866
18867         PR debug/53235
18868         * dwarf2out.c (build_local_stub): Prefer DW_AT_signature for
18869         comdat types.
18870
18871 2012-05-12  Eric Botcazou  <ebotcazou@adacore.com>
18872
18873         * function.c (requires_stack_frame_p): If the function can throw
18874         non-call exceptions, return true if the insn can throw internally.
18875
18876 2012-05-12  Paolo Carlini  <paolo.carlini@oracle.com>
18877
18878         * doc/generic.texi: Rename TYPE_PTRMEM_P to TYPE_PTRDATAMEM_P.
18879
18880 2012-05-12  Uros Bizjak  <ubizjak@gmail.com>
18881
18882         * config/alpha/alpha.c (alpha_emit_conditional_branch): Handle
18883         ORDERED and UNORDERED conditions.
18884
18885 2012-05-11  Richard Guenther  <rguenther@suse.de>
18886
18887         * tree-flow.h (referenced_var_check_and_insert): Remove.
18888         (find_new_referenced_vars): Likewise.
18889         * tree-dfa.c (referenced_var_check_and_insert): Make static.
18890         (find_new_referenced_vars_1, find_new_referenced_vars): Remove.
18891         * tree-inline.c (copy_bb): Use find_referenced_vars_in
18892         instead of find_new_referenced_vars.
18893         * gimple-fold.c (gimplify_and_update_call_from_tree): Likewise.
18894
18895 2012-05-11  Richard Guenther  <rguenther@suse.de>
18896
18897         * tree-pass.h (pass_rest_of_compilation,
18898         pass_all_optimizations, pass_postreload, pass_all_early_optimizations):
18899         Remove.
18900         * passes.c (pass_all_optimizations, pass_postreload,
18901         pass_all_early_optimizations): Make static.
18902         (pass_rest_of_compilation): Likewise.  Make it an RTL_PASS.
18903         * tree-phinodes.c (init_phinodes, fini_phinodes): Remove.
18904         * tree-ssa.c (init_tree_ssa): Do not call init_phinodes.
18905         (delete_tree_ssa): Do not call fini_phinodes.
18906         * tree-flow.h (init_phinodes, fini_phinodes): Remove.
18907
18908 2012-05-11  Manuel López-Ibáñez  <manu@gcc.gnu.org>
18909
18910         PR 53063
18911         * doc/options.texi (EnabledBy): Document
18912         * opts.c: Include opts.h and options.h before tm.h.
18913         (finish_options): Do not handle some sub-options here...
18914         (common_handle_option): ... instead call common_handle_option_auto
18915         here.
18916         * optc-gen.awk: Handle EnabledBy.
18917         * opth-gen.awk: Declare common_handle_option_auto.
18918         * common.opt (Wuninitialized): Use EnabledBy. Delete Init.
18919         (Wmaybe-uninitialized): Likewise.
18920         (Wunused-but-set-variable): Likewise.
18921         (Wunused-function): Likewise.
18922         (Wunused-label): Likewise.
18923         (Wunused-value): Likewise.
18924         (Wunused-variable): Likewise.
18925         * opt-read.awk: Create opt_numbers array.
18926
18927 2012-05-11  Richard Guenther  <rguenther@suse.de>
18928
18929         PR tree-optimization/53295
18930         * tree-data-ref.h (stride_of_unit_type_p): Handle non-constant
18931         strides.
18932         * tree-data-ref.c (dr_analyze_innermost): Allow non-constant
18933         strides when analyzing data-references in a loop context.
18934         * tree-vect-data-refs.c (vect_mark_for_runtime_alias_test): Reject
18935         non-constant strides for now.
18936         (vect_enhance_data_refs_alignment): Ignore data references
18937         that are strided loads.
18938         (vect_analyze_data_ref_access): Handle non-constant strides.
18939         (vect_check_strided_load): Verify the data-reference is a load.
18940         (vect_analyze_data_refs): Restructure to make strided load
18941         support not dependent on gather support.
18942         * tree-vect-stmts.c (vectorizable_load): Avoid useless work
18943         when doing strided or gather loads.
18944         * tree-vect-loop-manip.c (vect_vfa_segment_size): Use
18945         integer_zerop to compare stride with zero.
18946
18947 2012-05-11  H.J. Lu  <hongjiu.lu@intel.com>
18948
18949         * config/i386/driver-i386.c (host_detect_local_cpu): Support RTM.
18950
18951 2012-05-11  Jan Hubicka  <jh@suse.cz>
18952
18953         PR bootstrap/53300
18954         * varpool.c (varpool_assemble_decl): Also output constat pool entries
18955         that output_constant_pool missed.
18956
18957 2012-05-11  Mingjie Xing  <mingjie.xing@gmail.com>
18958
18959         * config/mips/t-vxworks: Change MUTLILIB_EXTRA_OPTS to
18960         MULTILIB_EXTRA_OPTS.
18961
18962 2012-05-11  Uros Bizjak  <ubizjak@gmail.com>
18963
18964         PR target/53291
18965         * config/i386/i386.md (xtest): Use NE condition in ix86_expand_setcc.
18966
18967 2012-05-11  Uros Bizjak  <ubizjak@gmail.com>
18968
18969         * config/i386/i386.md (*movti_internal_rex64): Avoid MOVAPS size
18970         optimization for TARGET_AVX.
18971         (*movti_internal_sse): Ditto.
18972         (*movdi_internal_rex64): Handle TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL.
18973         (*movdi_internal): Ditto.
18974         (*movsi_internal): Ditto.
18975         (*movtf_internal): Avoid MOVAPS size optimization for TARGET_AVX.
18976         (*movdf_internal_rex64): Ditto.
18977         (*movfd_internal): Ditto.
18978         (*movsf_internal): Ditto.
18979         * config/i386/sse.md (mov<mode>): Handle TARGET_SSE_LOAD0_BY_PXOR.
18980
18981 2012-05-10  Eric Botcazou  <ebotcazou@adacore.com>
18982
18983         * dwarf2out.c (add_byte_size_attribute) <RECORD_TYPE>: Handle variable
18984         reference as size attribute.
18985
18986 2012-05-10  Eric Botcazou  <ebotcazou@adacore.com>
18987             Tristan Gingold  <gingold@adacore.com>
18988
18989         * doc/md.texi (Standard Names): Document probe_stack_address.
18990         * explow.c (emit_stack_probe): Handle probe_stack_address.
18991         * config/ia64/ia64.md (UNSPECV_PROBE_STACK_ADDRESS): New constant.
18992         (UNSPECV_PROBE_STACK_RANGE): Likewise.
18993         (probe_stack_address): New insn.
18994         (probe_stack_range): Likewise.
18995         * config/ia64/ia64.c: Include common/common-target.h.
18996         (ia64_compute_frame_size): Mark r2 and r3 as used if static stack
18997         checking is enabled.
18998         (ia64_emit_probe_stack_range): New function.
18999         (output_probe_stack_range): Likewise.
19000         (ia64_expand_prologue): Invoke ia64_emit_probe_stack_range if static
19001         builtin stack checking is enabled.
19002         (rtx_needs_barrier) <UNSPEC_VOLATILE>: Handle UNSPECV_PROBE_STACK_RANGE
19003         and UNSPECV_PROBE_STACK_ADDRESS.
19004         (unknown_for_bundling_p): New predicate.
19005         (group_barrier_needed): Use important_for_bundling_p.
19006         (ia64_dfa_new_cycle): Use unknown_for_bundling_p.
19007         (issue_nops_and_insn): Likewise.
19008         (bundling): Likewise.
19009         (final_emit_insn_group_barriers): Likewise.
19010         * config/ia64/ia64-protos.h (output_probe_stack_range): Declare.
19011         * config/ia64/hpux.h (STACK_CHECK_STATIC_BUILTIN): Define.
19012         (STACK_CHECK_PROTECT): Likewise.
19013         * config/ia64/linux.h (STACK_CHECK_STATIC_BUILTIN): Likewise.
19014
19015 2012-05-10  Jan Hubicka  <jh@suse.cz>
19016
19017         * ipa-inline.c (update_all_callee_keys): Remove.
19018         (inline_small_functions): Simplify priority updating.
19019
19020 2012-05-10  Jan Hubicka  <jh@suse.cz>
19021
19022         * ipa.c (symtab_remove_unreachable_nodes): Fix marking of clones.
19023
19024 2012-05-10  Jan Hubicka  <jh@suse.cz>
19025
19026         * cgraph.h (cgraph_remove_unreachable_nodes): Rename to ...
19027         (symtab_remove_unreachable_nodes): ... this one.
19028         * ipa-cp.c (ipcp_driver): Do not remove unreachable nodes.
19029         * cgraphunit.c (ipa_passes): Update.
19030         * cgraphclones.c (cgraph_materialize_all_clones): Update.
19031         * cgraph.c (cgraph_release_function_body): Only turn initial
19032         into error mark when initial was previously set.
19033         * ipa-inline.c (ipa_inline): Update.
19034         * ipa.c: Include ipa-inline.h
19035         (enqueue_cgraph_node, enqueue_varpool_node): Remove.
19036         (enqueue_node): New function.
19037         (process_references): Update.
19038         (symtab_remove_unreachable_nodes): Cleanup.
19039         * passes.c (execute_todo, execute_one_pass): Update.
19040
19041 2012-05-10  Vladimir Makarov  <vmakarov@redhat.com>
19042
19043         PR rtl-optimization/53125
19044         * ira.c (ira): Call find_moveable_pseudos and
19045         move_unallocated_pseudos if only ira_conflicts_p is true.
19046
19047 2012-05-10  Uros Bizjak  <ubizjak@gmail.com>
19048
19049         * config/i386/i386.md (*movoi_internal_avx): Handle
19050         TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL and TARGET_SSE_TYPELESS_STORES.
19051         (*movti_internal_rex64): Handle TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL.
19052         (*movti_internal_sse): Ditto.
19053         (*movtf_internal): Ditto.
19054         * config/i386/sse.md (ssePSmode): New mode attribute.
19055         (*move<mode>_internal): Use ssePSmode.
19056         (*<sse>_movu<ssemodesuffix><avxsizesuffix>): Ditto.
19057         (*<sse2>_movdqu<avxsizesuffix>): Ditto.
19058         * config/i386/i386.c (standard_sse_constant_opcode): Do not handle
19059         TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL here.
19060
19061 2012-05-10  Eric Botcazou  <ebotcazou@adacore.com>
19062
19063         * gimplify.c (gimplify_decl_expr): For a TYPE_DECL, also gimplify the
19064         DECL_ORIGINAL_TYPE if it is present.
19065
19066 2012-05-10  Nick Clifton  <nickc@redhat.com>
19067
19068         PR target/53120
19069         * config/m32c/bitops.md (bset_qi): Change operand 2 from having
19070         a "0" constraint to being a (match_dup 0).
19071
19072 2012-05-10  Richard Guenther  <rguenther@suse.de>
19073
19074         * stor-layout.c (byte_from_pos): Amend comment.
19075
19076 2012-05-10  Rainer Orth  <ro@CeBiTec.Uni-Bielefeld.DE>
19077
19078         * doc/extend.texi (X86 Built-in Functions, __builtin_cpu_init):
19079         Document requirement to call in constructors.
19080
19081         * config/i386/i386.c: Update comments for i386-cpuinfo.c name change.
19082
19083 2012-05-10  Richard Guenther  <rguenther@suse.de>
19084
19085         * tree.h (TYPE_IS_SIZETYPE): Remove.
19086         * fold-const.c (int_const_binop_1): Remove TYPE_IS_SIZETYPE use.
19087         (extract_muldiv_1): Likewise.
19088         * gimple.c (gtc_visit): Likewise.
19089         (gimple_types_compatible_p): Likewise.
19090         (iterative_hash_canonical_type): Likewise.
19091         (gimple_canonical_types_compatible_p): Likewise.
19092         * gimplify.c (gimplify_one_sizepos): Likewise.
19093         * print-tree.c (print_node): Likewise.
19094         * stor-layout.c (initialize_sizetypes): Do not set TYPE_IS_SIZETYPE.
19095
19096 2012-05-09  Uros Bizjak  <ubizjak@gmail.com>
19097
19098         PR target/52908
19099         * config/i386/sse.md (vec_widen_smult_hi_v4si): Expand using
19100         xop_pmacsdqh insn pattern instead of xop_mulv2div2di3_high.
19101         (vec_widen_smult_lo_v4si): Expand using xop_pmacsdql insn pattern
19102         instead of xop_mulv2div2di3_low.
19103         (xop_p<macs>dql): Fix vec_select selector.
19104         (xop_p<macs>dqh): Ditto.
19105         (xop_mulv2div2di3_low): Remove insn_and_split pattern.
19106         (xop_mulv2div2di3_high): Ditto.
19107
19108 2012-05-09  Manuel López-Ibáñez  <manu@gcc.gnu.org>
19109
19110         PR c++/53289
19111         * diagnostic.h (diagnostic_context): Add last_location.
19112         * diagnostic.c (diagnostic_initialize): Initialize it.
19113         (diagnostic_show_locus): Use it.
19114
19115 2012-05-09  Manuel López-Ibáñez  <manu@gcc.gnu.org>
19116
19117         * doc/extend.texi (Function Attributes): Point xref to section
19118         about Pragmas.
19119
19120 2012-05-09  Uros Bizjak  <ubizjak@gmail.com>
19121
19122         * config/i386/i386.c (*movdf_internal_rex64): Remove
19123         TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL handling from asm output code.
19124         Calculate "mode" attribute according to
19125         TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL flag.
19126         (*movdf_internal): Ditto.
19127
19128 2012-05-09  Uros Bizjak  <ubizjak@gmail.com>
19129
19130         PR target/44141
19131         * config/i386/i386.c (ix86_expand_vector_move_misalign): Do not handle
19132         128 bit vectors specially for TARGET_AVX.  Emit sse2_movupd and
19133         sse_movupd RTXes for TARGET_AVX, TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL
19134         or when optimizing for size.
19135         * config/i386/sse.md (*mov<mode>_internal): Remove
19136         TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL handling from asm output code.
19137         Calculate "mode" attribute according to optimize_function_for_size_p
19138         and TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL flag.
19139         (*<sse>_movu<ssemodesuffix><avxsizesuffix>): Choose asm template
19140         depending on the mode of the instruction.  Calculate "mode" attribute
19141         according to optimize_function_for_size_p, TARGET_SSE_TYPELESS_STORES
19142         and TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL flags.
19143         (*<sse2>_movdqu<avxsizesuffix>): Ditto.
19144
19145 2012-05-09  Georg-Johann Lay  <avr@gjlay.de>
19146
19147         PR target/53256
19148         * config/avr/elf.h (ASM_DECLARE_FUNCTION_NAME): Remove.
19149         * config/avr/avr-protos.h (avr_asm_declare_function_name): Remove.
19150         * config/avr/avr.h (struct machine_function): Add attributes_checked_p.
19151         * config/avr/avr.c (avr_asm_declare_function_name): Remove.
19152         (expand_prologue): Move initialization of cfun->machine->is_naked,
19153         is_interrupt, is_signal, is_OS_task, is_OS_main from here to...
19154         (avr_set_current_function): ...this new static function.
19155         (TARGET_SET_CURRENT_FUNCTION): New define.
19156         (avr_function_ok_for_sibcall): Use cfun->machine->is_* instead of
19157         checking attributes of current_function_decl.
19158         (avr_regs_to_save): Ditto.
19159         (signal_function_p): Rename to avr_signal_function_p.
19160         (interrupt_function_p): Rename to avr_interrupt_function_p.
19161
19162         * doc/extend.texi (Function Attributes): Better explanation of
19163         'interrupt' and 'signal' for AVR. Move 'ifunc' down to establish
19164         alphabetical order.
19165
19166 2012-05-09  Michael Matz  <matz@suse.de>
19167
19168         PR tree-optimization/53185
19169         * tree-vect-data-refs.c (vect_enhance_data_refs_alignment): Disable
19170         peeling when we see strided loads.
19171
19172 2012-05-09  Matthias Klose  <doko@ubuntu.com>
19173
19174         * gcc-ar.c (main): Don't check for execute bits for the plugin.
19175
19176 2012-05-09  Ramana Radhakrishnan  <ramana.radhakrishnan@linaro.org>
19177
19178         * tree-ssa-loop-ivopts.c (add_autoinc_candidates, get_address_cost):
19179         Replace use of HAVE_{POST/PRE}_{INCREMENT/DECREMENT} with
19180         USE_{LOAD/STORE}_{PRE/POST}_{INCREMENT/DECREMENT} appropriately.
19181         * config/arm/arm.h (ARM_AUTOINC_VALID_FOR_MODE_P): New.
19182         (USE_LOAD_POST_INCREMENT): Define.
19183         (USE_LOAD_PRE_INCREMENT): Define.
19184         (USE_LOAD_POST_DECREMENT): Define.
19185         (USE_LOAD_PRE_DECREMENT): Define.
19186         (USE_STORE_PRE_DECREMENT): Define.
19187         (USE_STORE_PRE_INCREMENT): Define.
19188         (USE_STORE_POST_DECREMENT): Define.
19189         (USE_STORE_POST_INCREMENT): Define.
19190         (arm_auto_incmodes): Add enumeration.
19191         * config/arm/arm-protos.h (arm_autoinc_modes_ok_p): Declare.
19192         * config/arm/arm.c (arm_autoinc_modes_ok_p): Define.
19193
19194 2012-05-09  Jakub Jelinek  <jakub@redhat.com>
19195
19196         PR tree-optimization/53226
19197         * tree-ssa-forwprop.c (ssa_forward_propagate_and_combine): Remove
19198         prev and prev_initialized vars, gimple_set_plf (stmt, GF_PLF_1, false)
19199         before processing it and gimple_set_plf (stmt, GF_PLF_1, true) if it
19200         doesn't need to be revisited, look for earliest stmt with
19201         !gimple_plf (stmt, GF_PLF_1) if something changed.
19202
19203 2012-05-09  Terry Guo  <terry.guo@arm.com>
19204
19205         * genmultilib: Update copyright dates.
19206         * doc/fragments.texi: Ditto.
19207
19208 2012-05-09  Terry Guo  <terry.guo@arm.com>
19209
19210         * Makefile.in (s-mlib): Add new argument MULTILIB_REQUIRED.
19211         * genmultilib (MULTILIB_REQUIRED): New.
19212         * doc/fragments.texi: Document the MULTILIB_REQUIRED.
19213
19214 2012-05-09  Richard Guenther  <rguenther@suse.de>
19215
19216         * tree-vectorizer.h (vect_loop_versioning): Adjust prototype.
19217         (vect_do_peeling_for_loop_bound): Likewise.
19218         (vect_do_peeling_for_alignment): Likewise.
19219         * tree-vect-loop-manip.c (conservative_cost_threshold): Remove.
19220         (vect_do_peeling_for_loop_bound): Get check_profitability and
19221         threshold as parameters.
19222         (vect_do_peeling_for_alignment): Likewise.
19223         (vect_loop_versioning): Likewise.
19224         * tree-vect-loop.c (vect_transform_loop): Compute check_profitability
19225         and threshold here.  Control where to put the check here.
19226
19227 2012-05-09  Richard Sandiford  <rdsandiford@googlemail.com>
19228
19229         PR middle-end/53249
19230         * dwarf2out.h (get_address_mode): Move declaration to...
19231         * rtl.h: ...here.
19232         * dwarf2out.c (get_address_mode): Move definition to...
19233         * rtlanal.c: ...here.
19234         * var-tracking.c (get_address_mode): Delete.
19235         * combine.c (find_split_point): Use get_address_mode instead of
19236         targetm.addr_space.address_mode.
19237         * cselib.c (cselib_record_sets): Likewise.
19238         * dse.c (canon_address, record_store): Likewise.
19239         * emit-rtl.c (adjust_address_1, offset_address): Likewise.
19240         * expr.c (move_by_pieces, emit_block_move_via_loop, store_by_pieces)
19241         (store_by_pieces_1, expand_assignment, store_expr, store_constructor)
19242         (expand_expr_real_1): Likewise.
19243         * ifcvt.c (noce_try_cmove_arith): Likewise.
19244         * optabs.c (maybe_legitimize_operand_same_code): Likewise.
19245         * reload.c (find_reloads): Likewise.
19246         * sched-deps.c (sched_analyze_1, sched_analyze_2): Likewise.
19247         * sel-sched-dump.c (debug_mem_addr_value): Likewise.
19248
19249 2012-05-09  Maciej W. Rozycki  <macro@codesourcery.com>
19250
19251         * config/mips/mips.c (mips16_gp_pseudo_reg): Remove line
19252         information from the instruction produced.
19253
19254 2012-05-09  Richard Guenther  <rguenther@suse.de>
19255
19256         * stor-layout.c (bit_from_pos): Document.
19257         (byte_from_pos): Likewise.  Optimize.
19258         (pos_from_bit): Likewise.
19259         (normalize_offset): Use pos_from_bit instead of replicating it.
19260
19261 2012-05-09  Alan Modra  <amodra@gmail.com>
19262
19263         PR target/53271
19264         * config/rs6000/rs6000.c (gen_frame_set): New function.
19265         (gen_frame_load, gen_frame_store): New functions.
19266         (rs6000_savres_rtx): Use the above.
19267         (rs6000_emit_epilogue, rs6000_emit_prologue): Here too.
19268         Correct mode used for CR2 in save/restore_world patterns.
19269         Don't emit instructions for eh_return frame unwind reg info.
19270
19271 2012-05-08  Jan Hubicka  <jh@suse.cz>
19272
19273         * cgraphbuild.c (build_cgraph_edges): Do not finalize vars
19274         with VALUE_EXPR.
19275         * cgraph.h (varpool_can_remove_if_no_refs): Vars with VALUE_EXPR
19276         are removable.
19277         * toplev.c (wrapup_global_declaration_2): Vars with VALUE_EXPR
19278         need to wrapup.
19279         (compile_file): Do not output variables.
19280         * cgraphbuild.c (varpool_finalize_decl): When var is finalized late,
19281         output it.
19282         * langhooks.c: Include timevar.h
19283         (write_global_declarations): Finalize compilation unit after wrapup;
19284         set timevars correctly.
19285         * passes.c (rest_of_decl_compilation): Decls with VALUE_EXPR needs
19286         not to be added to varpool.
19287         * varpool.c (varpool_assemble_decl): Sanity check that we are called
19288         only on cases where it makes sense; skip constant pool and value expr
19289         vars.
19290
19291 2012-05-08  David S. Miller  <davem@davemloft.net>
19292
19293         * config/sparc/linux.h (LINK_SPEC): Don't pass "-Y" option.
19294         * config/sparc/linux64.h (LINK_ARCH32_SPEC): Likewise.
19295         * config/sparc/linux64.h (LINK_ARCH64_SPEC): Likewise.
19296
19297 2012-05-08  Richard Sandiford  <rdsandiford@googlemail.com>
19298
19299         PR rtl-optimization/53278
19300         * lower-subreg.c (decompose_multiword_subregs): Remove left-over
19301         speed_p code from earlier patch.
19302
19303 2012-05-08  Oleg Endo  <olegendo@gcc.gnu.org>
19304
19305         PR target/51244
19306         * config/sh/sh.md (*branch_true, *branch_false): New insns.
19307
19308 2012-05-08  Teresa Johnson  <tejohnson@google.com>
19309
19310         * gcov-io.h (__gcov_reset, __gcov_dump): Declare.
19311         * doc/gcov.texi: Add note on using __gcov_reset and __gcov_dump.
19312
19313 2012-05-08  Jan Hubicka  <jh@suse.cz>
19314
19315         * cgraph.c (cgraph_call_edge_duplication_hooks): Export.
19316         (cgraph_create_node_1): Rename to ...
19317         (cgraph_create_empty_node): ... this one; export.
19318         (cgraph_create_node): Update.
19319         (cgraph_set_call_stmt_including_clones): Move to cgraphclones.c
19320         (cgraph_create_edge_including_clones): Likewise.
19321         (cgraph_find_replacement_node): Likewise.
19322         (cgraph_clone_edge): Likewise.
19323         (cgraph_clone_node): Likewise.
19324         (clone_function_name): Likewise.
19325         (cgraph_create_virtual_clone): Likewise.
19326         (cgraph_remove_node_and_inline_clones): Likewise.
19327         (cgraph_redirect_edge_call_stmt_to_callee): Move here from cgraphunit.c
19328         * cgraph.h: Reorder declarations so they match file of origin.
19329         (cgraph_create_empty_node): Declare.
19330         * cgraphunit.c (update_call_expr): Move to cgraphclones.c
19331         (cgraph_copy_node_for_versioning): Likewise.
19332         (cgraph_function_versioning): Likewise.
19333         (cgraph_materialize_clone): Likewise.
19334         (cgraph_redirect_edge_call_stmt_to_callee): Likewise.
19335         (cgraph_materialize_all_clones): Likewise.
19336         * cgraphclones.c: New file.
19337         * Makefile.in: Update for cgraphclones.
19338
19339 2012-05-08  Uros Bizjak  <ubizjak@gmail.com>
19340
19341         PR target/53176
19342         * config/i386/i386.c (ix86_set_reg_reg_cost): New function.
19343         (ix86_rtx_costs): Handle SET.
19344
19345 2012-05-08  Michael Matz  <matz@suse.de>
19346
19347         * basic-block.h (struct rtl_bb_info): Remove visited member and
19348         move head_ member to ...
19349         (struct basic_block_def.basic_block_il_dependent): ... the new
19350         member x, replacing but containing old member rtl.
19351         (enum bb_flags): New BB_VISITED flag.
19352         (BB_HEADER, BB_FOOTER): New macros.
19353
19354         * jump.c (mark_all_labels): Adjust.
19355         * cfgcleanup.c (try_optimize_cfg): Adjust.
19356         * cfglayout.c (record_effective_endpoints): Adjust.
19357         (relink_block_chain): Ditto (and don't fiddle with visited).
19358         (fixup_reorder_chain): Adjust.
19359         (fixup_fallthru_exit_predecessor): Ditto.
19360         (cfg_layout_duplicate_bb): Ditto.
19361         * combine.c (update_cfg_for_uncondjump): Adjust.
19362         * bb-reorder.c (struct bbro_basic_block_data_def): Add visited member.
19363         (bb_visited_trace): New accessor.
19364         (mark_bb_visited): Move in front.
19365         (rotate_loop): Use bb_visited_trace.
19366         (find_traces_1_round): Ditto.
19367         (emit_barrier_after): Ditto.
19368         (copy_bb): Ditto, and initialize visited on resize.
19369         (reorder_basic_blocks): Initize visited member.
19370         (duplicate_computed_gotos): Clear bb flags at start, use
19371         BB_VISITED flags.
19372
19373         * cfgrtl.c (try_redirect_by_replacing_jump): Adjust.
19374         (rtl_verify_flow_info_1): Ditto.
19375         (cfg_layout_split_block): Ditto.
19376         (cfg_layout_delete_block): Ditto.
19377         (cfg_layout_merge_blocks): Ditto.
19378         (init_rtl_bb_info): Adjust and initialize il.x.head_ member.
19379
19380 2012-05-08  Hans-Peter Nilsson  <hp@axis.com>
19381
19382         PR target/53272
19383         * config/cris/cris.c (cris_normal_notice_update_cc): For TARGET_V32,
19384         when a constant source operand matches an "I" constraint, the "no
19385         CC0 change" applies to a register-destination only, not a
19386         strict_low_part-destination.
19387
19388 2012-05-08  Richard Guenther  <rguenther@suse.de>
19389
19390         * fold-const.c (fold_binary_loc): Fold (X * CST1) & CST2
19391         to zero or to (X * CST1) & CST2' when CST1 has trailing zeros.
19392
19393 2012-05-08  Georg-Johann Lay  <avr@gjlay.de>
19394
19395         * Makefile.in (TEXI_GCC_FILES): Add avr-mmcu.texi.
19396
19397         * doc/avr-mmcu.texi: New auto-generated file.
19398         * doc/invoke.texi (AVR Options): Include avr-mmcu.texi in order
19399         to document all valid -mmcu= arguments.
19400
19401         * config/avr/avr.h (arch_info_s): New struct definition.
19402         * config/avr/avr-devices.c (avr_texinfo): New variable.
19403         * config/avr/gen-avr-mmcu-texi.c: New file.
19404         * config/avr/t-avr: New rules and dependencies to build avr-mmcu.texi.
19405
19406 2012-05-08  Dehao Chen  <dehao@google.com>
19407
19408         * predict.c (find_qualified_ssa_name): New.
19409         (find_ssa_name_in_expr): New.
19410         (find_ssa_name_in_assign_stmt): New.
19411         (is_comparison_with_loop_invariant_p): New.
19412         (is_bound_expr_similar): New.
19413         (predict_iv_comparison): New.
19414         (predict_loops): Add heuristic for loop-nested branches that compare an
19415         induction variable to a loop bound variable.
19416         * predict.def (PRED_LOOP_IV_COMPARE): New macro.
19417
19418 2012-05-08  Uros Bizjak  <ubizjak@gmail.com>
19419
19420         * config/i386/i386.c (has_dispatch): Use TARGET_BDVER1 and
19421         TARGET_BDVER2 defines where appropriate.
19422
19423 2012-05-07  Eric Botcazou  <ebotcazou@adacore.com>
19424
19425         * configure.ac (PLUGIN_LD): Rename into...
19426         (PLUGIN_LD_SUFFIX): ...this and strip the target_alias triplet.
19427         * config.in: Regenerate.
19428         * configure: Likewise.
19429         * collect2.c (main): Set plugin_ld_suffix to PLUGIN_LD_SUFFIX.
19430
19431 2012-05-07  Eric Botcazou  <ebotcazou@adacore.com>
19432
19433         * tree-dfa.c (get_ref_base_and_extent) <ARRAY_REF>: Do the offset
19434         computation using the precision of the index type.
19435         * gimple-fold.c (fold_const_aggregate_ref_1) <ARRAY_REF>: Likewise.
19436         (fold_array_ctor_reference): Do index computations in the index type.
19437
19438 2012-05-07  Georg-Johann Lay  <avr@gjlay.de>
19439
19440         * config/avr/avr.c (avr_prologue_setup_frame): Fix mode passed
19441         down to plus_constant.
19442         (expand_epilogue): Ditto.
19443
19444 2012-05-07  Steven Bosscher  <steven@gcc.gnu.org>
19445
19446         * postreload.c (reload_cse_regs): Make static.
19447         * reload.h (reload_cse_regs): Remove prototype.
19448
19449 2012-05-07  Richard Henderson  <rth@redhat.com>
19450
19451         * config/alpha/alpha.md (clear_cache): New pattern.
19452
19453 2012-05-07  Steven Bosscher  <steven@gcc.gnu.org>
19454
19455         PR middle-end/53245
19456         * gimplify.c (preprocess_case_label_vec_for_gimple): If low or high
19457         is folded to a type boundary value, verify that the resulting case
19458         label is still a care range.
19459
19460 2012-05-07  Uros Bizjak  <ubizjak@gmail.com>
19461
19462         * config/i386/i386.md (ctz<mode>2): Emit rep;bsf
19463         only for TARGET_GENERIC, when not optimizing for size.
19464         (*ffs<mode>_1): Ditto.
19465
19466 2012-05-07  Steven Bosscher  <steven@gcc.gnu.org>
19467
19468         * tree-cfg.c (verify_gimple_switch): Tighten checks.
19469
19470 2012-05-07  Jakub Jelinek  <jakub@redhat.com>
19471
19472         PR tree-optimization/53239
19473         * tree-vrp.c (get_value_range): Set VR of SSA_NAME_IS_DEFAULT_DEF
19474         of DECL_BY_REFERENCE RESULT_DECL to nonnull.
19475
19476 2012-05-07  Richard Guenther  <rguenther@suse.de>
19477
19478         PR tree-optimization/53195
19479         * tree-inline.c (setup_one_parameter): Properly add referenced
19480         vars from the parameters new known value.
19481
19482 2012-05-07  Steven Bosscher  <steven@gcc.gnu.org>
19483
19484         * config/m68k/m68k.c (m68k_sched_branch_type): Remove.
19485         (sched_branch_type): Remove.
19486         (m68k_sched_md_init_global): Don't allocate it.
19487         (m68k_sched_md_finish_global): Don't free it.
19488         * config/m68k/m68k.h (m68k_sched_branch_type): Remove prototype.
19489         * config/m68k/m68k.md: Set the type of insns using
19490         m68k_sched_branch_type to bcc directly.
19491
19492 2012-05-07  Rainer Orth  <ro@CeBiTec.Uni-Bielefeld.DE>
19493
19494         * config/sol2.c (solaris_override_options): New function.
19495         * config/sol2-protos.h (solaris_override_options): Declare.
19496         * config/sol2.h (SUBTARGET_OVERRIDE_OPTIONS): Define.
19497
19498 2012-05-07  Richard Guenther  <rguenther@suse.de>
19499
19500         * tree-ssa-loop-prefetch.c (determine_loop_nest_reuse): Return
19501         whether we failed to compute data dependences.
19502         (loop_prefetch_arrays): Fail if we failed.
19503
19504 2012-05-07  Uros Bizjak  <ubizjak@gmail.com>
19505             Paolo Bonzini  <bonzini@gnu.org>
19506
19507         * config/i386/i386.md (ctz<mode>2): Emit rep;bsf even for !TARGET_BMI.
19508         Emit bsf when optimizing for size.
19509         (*ffs<mode>_1): Ditto.
19510
19511 2012-05-07  Oleg Endo  <olegendo@gcc.gnu.org>
19512
19513         PR target/53250
19514         * config/sh/sh.c (sh_rtx_costs): Handle SET.
19515
19516 2012-05-06  Uros Bizjak  <ubizjak@gmail.com>
19517
19518         PR target/53227
19519         * config/i386/i386.md (swap<mode>): Rename from *swap<mode>.
19520         (bswapdi2): Split from bswap<mode>2.  Use nonnimediate_operand
19521         predicate for operand 1.  Force operand 1 to register for TARGET_BSWAP.
19522         (bswapsi2): Ditto.
19523         (*bswapdi2_doubleword): New insn pattern.
19524         (*bswap<mode>2): Rename from *bswap<mode>2_1.
19525
19526 2012-05-06  Richard Sandiford  <rdsandiford@googlemail.com>
19527
19528         * config/mips/mips.c (mips_set_reg_reg_piece_cost): New function.
19529         (mips_set_reg_reg_cost): Likewise.
19530         (mips_rtx_costs): Handle SET.
19531
19532 2012-05-06  Richard Sandiford  <rdsandiford@googlemail.com>
19533
19534         * lower-subreg.c (shift_cost): Use set_src_cost, avoiding the SET.
19535         (compute_costs): Likewise for the zero extension.  Use set_rtx_cost
19536         to compute the cost of moves.  Set the mode of the target register.
19537
19538 2012-05-05  Richard Sandiford  <rdsandiford@googlemail.com>
19539
19540         * rtl.h (plus_constant, plus_constant_mode): Merge into a single
19541         plus_constant function.
19542         * explow.c (plus_constant, plus_constant_mode): Likewise.  Assert
19543         that the mode is sensible.
19544         (use_anchored_address, round_push, allocate_dynamic_stack_space)
19545         (probe_stack_range, anti_adjust_stack_and_probe): Update calls to
19546         plus_constant.
19547
19548         * alias.c (canon_rtx): Likewise.
19549         (init_alias_analysis): Likewise.
19550         * builtins.c (expand_builtin_return_addr)
19551         (expand_builtin_setjmp_setup, expand_builtin_longjmp)
19552         (expand_builtin_nonlocal_goto, expand_builtin_update_setjmp_buf)
19553         (expand_builtin_apply_args_1, expand_builtin_apply, expand_movstr)
19554         (expand_builtin_stpcpy): Likewise.
19555         * calls.c (save_fixed_argument_area, restore_fixed_argument_area)
19556         (compute_argument_addresses, internal_arg_pointer_based_exp)
19557         (expand_call, emit_library_call_value_1): Likewise.
19558         * cfgexpand.c (expand_one_stack_var_at, expand_debug_expr): Likewise.
19559         * combine-stack-adj.c (try_apply_stack_adjustment): Likewise.
19560         * combine.c (combine_simplify_rtx, force_to_mode): Likewise.
19561         * cse.c (insert_const_anchor, find_reg_offset_for_const)
19562         (use_related_value, fold_rtx): Likewise.
19563         * cselib.c (cselib_subst_to_values): Likewise.
19564         * dse.c (record_store, check_mem_read_rtx): Likewise.
19565         * dwarf2out.c (rtl_for_decl_location, gen_variable_die): Likewise.
19566         * emit-rtl.c (adjust_address_1): Likewise.
19567         * except.c (sjlj_emit_function_enter)
19568         (expand_builtin_extract_return_addr)
19569         (expand_builtin_frob_return_addr): Likewise.
19570         * expmed.c (expand_divmod): Likewise.
19571         * expr.c (move_by_pieces, store_by_pieces, store_by_pieces_1)
19572         (emit_move_resolve_push, push_block, emit_push_insn, store_expr)
19573         (expand_expr_addr_expr_1, expand_expr_real_1): Likewise.
19574         * function.c (assign_stack_local_1)
19575         (instantiate_virtual_regs_in_rtx): Likewise.
19576         * optabs.c (prepare_cmp_insn): Likewise.
19577         * recog.c (offsettable_address_addr_space_p): Likewise.
19578         * reload.c (find_reloads_address, form_sum)
19579         (find_reloads_subreg_address): Likewise.
19580         * reload1.c (init_reload, eliminate_regs_1)
19581         (eliminate_regs_in_insn): Likewise.
19582         * simplify-rtx.c (simplify_unary_operation_1)
19583         (simplify_binary_operation_1, simplify_plus_minus): Likewise.
19584         * var-tracking.c (compute_cfa_pointer, prepare_call_arguments)
19585         (vt_add_function_parameter): Likewise.
19586
19587         * config/alpha/alpha.h (EH_RETURN_HANDLER_RTX): Likewise.
19588         * config/alpha/vms.h (EH_RETURN_HANDLER_RTX): Likewise.
19589         * config/alpha/alpha.c (alpha_legitimize_address_1)
19590         (get_unaligned_address, alpha_expand_unaligned_load)
19591         (alpha_expand_unaligned_store, alpha_expand_unaligned_load_words)
19592         (alpha_expand_unaligned_store_words, alpha_expand_block_clear)
19593         (alpha_expand_builtin_establish_vms_condition_handler)
19594         (alpha_setup_incoming_varargs, emit_frame_store_1)
19595         (alpha_expand_prologue, alpha_expand_epilogue)
19596         (alpha_use_linkage): Likewise.
19597         * config/alpha/alpha.md: Likewise.
19598
19599         * config/arm/arm.c (arm_trampoline_init, legitimize_pic_address)
19600         (arm_load_pic_register, arm_pic_static_addr, arm_legitimize_address)
19601         (thumb_legitimize_address, arm_gen_load_multiple_1)
19602         (arm_gen_store_multiple_1, arm_gen_multiple_op, gen_ldm_seq)
19603         (gen_stm_seq, gen_const_stm_seq, arm_block_move_unaligned_straight)
19604         (arm_block_move_unaligned_loop, arm_gen_movmemqi, arm_reload_in_hi)
19605         (arm_reload_out_hi, arm_reorg, vfp_emit_fstmd, emit_multi_reg_push)
19606         (emit_sfm, thumb_set_frame_pointer, arm_expand_prologue)
19607         (thumb1_emit_multi_reg_push, thumb1_expand_prologue)
19608         (thumb_expand_movmemqi, arm_set_return_address)
19609         (thumb_set_return_address): Likewise.
19610         * config/arm/arm.md: Likewise.
19611
19612         * config/avr/avr.c (avr_incoming_return_addr_rtx)
19613         (avr_prologue_setup_frame, expand_epilogue)
19614         (avr_const_address_lo16): Likewise.
19615
19616         * config/bfin/bfin.h (EH_RETURN_HANDLER_RTX): Likewise.
19617         * config/bfin/bfin.c (setup_incoming_varargs, bfin_load_pic_reg)
19618         (bfin_expand_prologue, bfin_trampoline_init, bfin_expand_call)
19619         (bfin_output_mi_thunk): Likewise.
19620
19621         * config/c6x/c6x.c (c6x_initialize_trampoline)
19622         (c6x_output_mi_thunk): Likewise.
19623
19624         * config/cr16/cr16.h (EH_RETURN_HANDLER_RTX): Likewise.
19625         * config/cr16/cr16.c (cr16_create_dwarf_for_multi_push): Likewise.
19626
19627         * config/cris/cris.c (cris_return_addr_rtx, cris_split_movdx)
19628         (cris_expand_prologue, cris_expand_epilogue, cris_gen_movem_load)
19629         (cris_emit_movem_store, cris_trampoline_init): Likewise.
19630         * config/cris/cris.md: Likewise.
19631
19632         * config/darwin.c (machopic_indirect_data_reference)
19633         (machopic_legitimize_pic_address): Likewise.
19634
19635         * config/epiphany/epiphany.c (epiphany_emit_save_restore)
19636         (epiphany_expand_prologue, epiphany_expand_epilogue)
19637         (epiphany_trampoline_init): Likewise.
19638         * config/epiphany/epiphany.md: Likewise.
19639
19640         * config/fr30/fr30.c (fr30_move_double): Likewise.
19641
19642         * config/frv/frv.c (frv_dwarf_store, frv_expand_prologue)
19643         (frv_expand_block_move, frv_expand_block_clear, frv_return_addr_rtx)
19644         (frv_index_memory, unspec_got_name, frv_find_base_term)
19645         (frv_output_dwarf_dtprel): Likewise.
19646
19647         * config/h8300/h8300.c (h8300_push_pop, h8300_return_addr_rtx)
19648         (h8300_swap_into_er6, h8300_swap_out_of_er6): Likewise.
19649
19650         * config/i386/i386.h (RETURN_ADDR_RTX): Likewise.
19651         * config/i386/i386.c (setup_incoming_varargs_64)
19652         (setup_incoming_varargs_ms_64, choose_baseaddr)
19653         (ix86_emit_save_reg_using_mov, ix86_adjust_stack_and_probe)
19654         (ix86_emit_probe_stack_range, ix86_expand_prologue)
19655         (ix86_emit_restore_reg_using_pop, ix86_emit_leave)
19656         (ix86_expand_epilogue, legitimize_pic_address, ix86_legitimize_address)
19657         (ix86_split_long_move, ix86_expand_movmem, ix86_expand_setmem)
19658         (ix86_static_chain, ix86_trampoline_init, x86_this_parameter)
19659         (x86_output_mi_thunk): Likewise.
19660         * config/i386/i386.md: Likewise.
19661
19662         * config/ia64/ia64.c (ia64_expand_load_address)
19663         (ia64_expand_tls_address, ia64_expand_move, ia64_split_tmode)
19664         (do_spill, ia64_trampoline_init): Likewise.
19665
19666         * config/iq2000/iq2000.c (iq2000_va_start)
19667         (iq2000_emit_frame_related_store, iq2000_expand_prologue)
19668         (iq2000_expand_eh_return, iq2000_setup_incoming_varargs)
19669         (iq2000_print_operand, iq2000_legitimize_address): Likewise.
19670
19671         * config/lm32/lm32.c (lm32_setup_incoming_varargs): Likewise.
19672
19673         * config/m32c/m32c.c (m32c_return_addr_rtx)
19674         (m32c_expand_insv): Likewise.
19675
19676         * config/m32r/m32r.c (m32r_setup_incoming_varargs)
19677         (m32r_legitimize_pic_address, m32r_print_operand)
19678         (m32r_print_operand_address): Likewise.
19679
19680         * config/m68k/linux.h (FINALIZE_TRAMPOLINE): Likewise.
19681         * config/m68k/m68k.h (RETURN_ADDR_RTX): Likewise.
19682         (EH_RETURN_HANDLER_RTX): Likewise.
19683         * config/m68k/m68k.c (m68k_emit_movem, m68k_expand_prologue)
19684         (m68k_expand_epilogue, legitimize_pic_address)
19685         (m68k_output_mi_thunk): Likewise.
19686         * config/m68k/m68k.md: Likewise.
19687
19688         * config/mcore/mcore.c (mcore_expand_prolog): Likewise.
19689         (mcore_expand_epilog): Likewise.
19690         * config/mcore/mcore.md: Likewise.
19691
19692         * config/mep/mep.c (mep_allocate_initial_value)
19693         (mep_expand_prologue, mep_expand_epilogue): Likewise.
19694
19695         * config/microblaze/microblaze.c (double_memory_operand)
19696         (microblaze_block_move_loop): Likewise.
19697
19698         * config/mips/mips.c (mips_strip_unspec_address, mips_add_offset)
19699         (mips_setup_incoming_varargs, mips_va_start, mips_block_move_loop)
19700         (mips_print_operand, mips16e_save_restore_reg, mips_save_restore_reg)
19701         (mips_expand_prologue, mips_epilogue_set_cfa)
19702         (mips_expand_epilogue): Likewise.
19703         * config/mips/mips.md: Likewise.
19704
19705         * config/mmix/mmix.c (mmix_dynamic_chain_address, mmix_return_addr_rtx)
19706         (mmix_expand_prologue, mmix_expand_epilogue): Likewise.
19707
19708         * config/mn10300/mn10300.c (mn10300_gen_multiple_store)
19709         (mn10300_builtin_saveregs, mn10300_trampoline_init): Likewise.
19710
19711         * config/moxie/moxie.h (INCOMING_RETURN_ADDR_RTX): Likewise.
19712         (EH_RETURN_HANDLER_RTX): Likewise.
19713         * config/moxie/moxie.c (moxie_static_chain): Likewise.
19714
19715         * config/pa/pa.c (legitimize_pic_address, hppa_legitimize_address)
19716         (store_reg, set_reg_plus_d, pa_expand_prologue, load_reg)
19717         (pa_return_addr_rtx, hppa_builtin_saveregs)
19718         (pa_trampoline_init): Likewise.
19719         * config/pa/pa.md: Likewise.
19720
19721         * config/pdp11/pdp11.c (pdp11_expand_epilogue): Likewise.
19722
19723         * config/picochip/picochip.c (picochip_static_chain): Likewise.
19724
19725         * config/rs6000/rs6000.h (RS6000_SAVE_TOC): Likewise.
19726         * config/rs6000/rs6000.c (rs6000_legitimize_address)
19727         (setup_incoming_varargs, print_operand, rs6000_return_addr)
19728         (rs6000_emit_eh_reg_restore, rs6000_emit_probe_stack_range)
19729         (rs6000_emit_epilogue)
19730         (rs6000_machopic_legitimize_pic_address): Likewise.
19731
19732         * config/rx/rx.c (gen_rx_rtsd_vector, gen_rx_popm_vector): Likewise.
19733
19734         * config/s390/s390.h (INITIAL_FRAME_ADDRESS_RTX): Likewise.
19735         (DYNAMIC_CHAIN_ADDRESS): Likewise.
19736         * config/s390/s390.c (s390_decompose_address, legitimize_pic_address)
19737         (s390_delegitimize_address, print_operand, annotate_constant_pool_refs)
19738         (replace_constant_pool_ref, s390_return_addr_rtx, s390_back_chain_rtx)
19739         (save_fpr, restore_fpr, save_gprs, restore_gprs, s390_emit_prologue)
19740         (s390_emit_epilogue, s390_function_profiler): Likewise.
19741         * config/s390/s390.md: Likewise.
19742
19743         * config/score/score.c (score_add_offset, score_prologue): Likewise.
19744
19745         * config/sh/sh.c (expand_block_move, push_regs, sh_builtin_saveregs)
19746         (sh_output_mi_thunk): Likewise.
19747         * config/sh/sh.md: Likewise.
19748
19749         * config/sparc/sparc.h (DYNAMIC_CHAIN_ADDRESS, FRAME_ADDR_RTX)
19750         (RETURN_ADDR_RTX, INCOMING_RETURN_ADDR_RTX): Likewise.
19751         * config/sparc/sparc.c (sparc_legitimize_pic_address)
19752         (sparc_emit_probe_stack_range, emit_save_or_restore_regs)
19753         (emit_window_save, sparc_flat_expand_prologue, sparc_struct_value_rtx)
19754         (emit_and_preserve): Likewise.
19755         * config/sparc/sparc.md: Likewise.
19756
19757         * config/spu/spu.h (DYNAMIC_CHAIN_ADDRESS): Likewise.
19758         * config/spu/spu.c (spu_expand_insv, spu_machine_dependent_reorg)
19759         (spu_setup_incoming_varargs, ea_load_store_inline)
19760         (spu_expand_load): Likewise.
19761
19762         * config/stormy16/stormy16.c (xstormy16_expand_prologue)
19763         (combine_bnp): Likewise.
19764
19765         * config/tilegx/tilegx.h (DYNAMIC_CHAIN_ADDRESS): Likewise.
19766         * config/tilegx/tilegx.c (tilegx_setup_incoming_varargs)
19767         (tilegx_expand_unaligned_load, tilegx_trampoline_init): Likewise.
19768
19769         * config/tilepro/tilepro.h (DYNAMIC_CHAIN_ADDRESS): Likewise.
19770         * config/tilepro/tilepro.c (tilepro_setup_incoming_varargs)
19771         (tilepro_expand_unaligned_load, tilepro_trampoline_init): Likewise.
19772
19773         * config/v850/v850.c (expand_prologue, expand_epilogue): Likewise.
19774         * config/v850/v850.md: Likewise.
19775
19776         * config/vax/elf.h (EH_RETURN_STACKADJ_RTX): Likewise.
19777         (EH_RETURN_HANDLER_RTX): Likewise.
19778         * config/vax/vax.h (DYNAMIC_CHAIN_ADDRESS, RETURN_ADDR_RTX): Likewise.
19779         * config/vax/vax.c (vax_add_reg_cfa_offset, vax_expand_prologue)
19780         (print_operand_address, vax_trampoline_init): Likewise.
19781
19782         * config/xtensa/xtensa.c (xtensa_expand_prologue, xtensa_return_addr)
19783         (xtensa_function_value_regno_p): Likewise.
19784
19785 2012-05-04  Andrew Pinski  <apinski@cavium.com>
19786
19787         * expr.c (get_def_for_expr_class): New function.
19788         (convert_tree_comp_to_rtx): New function.
19789         (expand_cond_expr_using_cmove): New function.
19790         (expand_expr_real_2 <case COND_EXPR>): Call
19791         expand_cond_expr_using_cmove first and return if it succeeds.
19792         Remove the check for HAVE_conditional_move since we should have
19793         already converted it to a conditional move.
19794         * config/i386/i386.c (ix86_expand_int_movcc): Disallow comparison
19795         modes of DImode for 32bits and TImode.
19796
19797 2012-05-04  Steven Bosscher  <steven@gcc.gnu.org>
19798
19799         PR other/29442
19800         * read-md.c (fprint_md_ptr_loc, fprint_c_condition): New functions.
19801         (print_md_ptr_loc, print_c_condition): Use them.
19802         * read-md.h (fprint_md_ptr_loc, fprint_c_condition): New prototypes.
19803         * genattrtab.c (attr_file_name, dfa_file_name, latency_file_name,
19804         attr_file, dfa_file, latency_file): New global variables.
19805         (write_attr_valueq, write_attr_set, write_attr_case, write_attr_value,
19806         write_upcase, write_indent, write_length_unit_log, write_test_expr,
19807         write_attr_get, write_insn_cases, write_eligible_delay,
19808         write_const_num_delay_slots): Accept FILE pointer and toss it around.
19809         Update all callers.
19810         (write_header, open_outfile, handle_arg): New funcions.
19811         (make_automaton_attrs): Write prototypes as extern to the output
19812         files.
19813         (main): Use init_rtx_reader_args_cb with handle_arg to take 3 file
19814         names from the command line.  Open the output files and write out
19815         internal functions for DFA functions to dfa_file_name, insn latency
19816         functions to latency_file_name, and everything else to attr_file.
19817         * Makefile.in (OBJS): Add insn-dfatab.o and insn-latencytab.o.
19818         (BACKEND): Build libbackend first.
19819         (MOSTLYCLEANFILES): Add insn-dfatab.c and insn-latencytab.c.
19820         (.PRECIOUS): Likewise.
19821         (insn-dfatab.o): New rule.
19822         (insn-latencytab.o): New rule.
19823         (simple_rtl_generated_c): Do not include insn-attrtab.c.
19824         (s-attrtab): New rule.
19825
19826 2012-05-04  Steven Bosscher  <steven@gcc.gnu.org>
19827
19828         * rtl.def (ATTR_FLAG): Remove probability indicating flags.
19829         * genattr.c (main): Remove ATTR_FLAG_likely, ATTR_FLAG_unlikely,
19830         ATTR_FLAG_very_likely, and ATTR_FLAG_very_unlikely.
19831         * reorg.c (get_jump_flags): Do not set the removed flags.
19832
19833         * doc/md.texi (attr_flag): Update for abovementioned changes.
19834
19835 2012-05-04  Uros Bizjak  <ubizjak@gmail.com>
19836
19837         PR target/53228
19838         * config/i386/i386.h (X86_ARCH_CMOV): Rename from X86_ARCH_CMOVE.
19839         (TARGET_CMOV): Rename from TARGET_CMOVE.
19840         (TARGET_CMOVE): New define.
19841         * config/i386/i386.c (ix86_option_override_internal): Use TARGET_CMOV.
19842         Do not set TARGET_CMOVE here.
19843
19844 2012-05-04  Dodji Seketeli  <dodji@redhat.com>
19845
19846         Enable -Wunused-local-typedefs when -Wall or -Wunused is on
19847         * opts.c (finish_options): Activate -Wunused-local-typedefs if
19848         -Wunused is activated.
19849         * doc/invoke.texi: Update blurb of -Wunused-local-typedefs.
19850
19851 2012-05-04  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
19852
19853         * config/s390/s390.md (*movmem_short, *clrmem_short)
19854         (*cmpmem_short): Move the mode check from the insn condition to
19855         the match_scratch.
19856
19857 2012-05-04  Ulrich Weigand  <ulrich.weigand@linaro.org>
19858
19859         PR tree-optimization/52633
19860         * tree-vect-patterns.c (vect_vect_recog_func_ptrs): Swap order of
19861         vect_recog_widen_shift_pattern and vect_recog_over_widening_pattern.
19862         (vect_recog_over_widening_pattern): Remove handling of code that was
19863         already detected as over-widening pattern.  Remove special handling
19864         of "unsigned" cases.  Instead, support general case of conversion
19865         of the shift result to another type.
19866
19867 2012-05-04  Ulrich Weigand  <ulrich.weigand@linaro.org>
19868
19869         * tree-vect-patterns.c (vect_single_imm_use): New function.
19870         (vect_recog_widen_mult_pattern): Use it instead of open-coding loop.
19871         (vect_recog_over_widening_pattern): Likewise.
19872         (vect_recog_widen_shift_pattern): Likewise.
19873
19874 2012-05-04  Ulrich Weigand  <ulrich.weigand@linaro.org>
19875
19876         * tree-vect-patterns.c (vect_same_loop_or_bb_p): New function.
19877         (vect_handle_widen_op_by_const): Use it instead of open-coding test.
19878         (vect_recog_widen_mult_pattern): Likewise.
19879         (vect_operation_fits_smaller_type): Likewise.
19880         (vect_recog_over_widening_pattern): Likewise.
19881         (vect_recog_widen_shift_pattern): Add to vect_same_loop_or_bb_p test.
19882
19883 2012-05-04  Richard Guenther  <rguenther@suse.de>
19884
19885         PR lto/50602
19886         * lto-wrapper.c (merge_and_complain): Complain about mismatches
19887         of -freg-struct-return and -fpcc-struct-return.
19888         (run_gcc): Pass through -freg-struct-return and -fpcc-struct-return
19889         from the input file options and ignore those from the link
19890         command line.
19891
19892 2012-05-04  Richard Guenther  <rguenther@suse.de>
19893
19894         PR tree-optimization/53168
19895         * tree-ssa-pre.c (phi_translate_1): Only handle type-punned
19896         memory reads when the result is a constant we can pun.
19897
19898 2012-05-04  Richard Guenther  <rguenther@suse.de>
19899
19900         * common.opt (flto-report): Do not mark as Optimization.
19901
19902 2012-05-04  Eric Botcazou  <ebotcazou@adacore.com>
19903
19904         PR target/48496
19905         * recog.c (constrain_operands): If extra constraints are present, also
19906         accept pseudo-registers with equivalent memory locations during reload.
19907
19908 2012-05-04  Olivier Hainque  <hainque@adacore.com>
19909
19910         * collect2.c (may_unlink_output_file): New global.
19911         (maybe_unlink): Honor it.
19912         * collect2.h: Add extern for it.
19913         * tlink.c (do_tlink): Set it to true if the link succeeded.
19914
19915 2012-05-04  Olivier Hainque  <hainque@adacore.com>
19916
19917         * gcc.c (eval_spec_function): Finalize/restore the current string
19918         obstack state as part of the context push/pop operations.
19919
19920 2012-05-04  Bin Cheng  <bin.cheng@arm.com>
19921
19922         PR rtl-optimization/52804
19923         * reload1.c (reload_reg_reaches_end_p): Check whether successor
19924         reload with type RELOAD_FOR_INPUT_ADDRESS kills reload register
19925         of current one with type RELOAD_FOR_INPADDR_ADDRESS.
19926         Same stands for reloads with type RELOAD_FOR_OUTPUT_ADDRESS and
19927         RELOAD_FOR_OUTADDR_ADDRESS.
19928
19929 2012-05-04  Manuel López-Ibáñez  <manu@gcc.gnu.org>
19930
19931         PR c++/24985
19932         * tree-diagnostic.c (maybe_unwind_expanded_macro_loc): Show caret
19933         for macro expansion.
19934
19935 2012-05-03  Manuel López-Ibáñez  <manu@gcc.gnu.org>
19936
19937         * flags.h (flag_permissive): Do not declare.
19938         * diagnostic.c (diagnostic_report_diagnostic): Handle fpermissive
19939         option specially.
19940         * toplev.c (flag_permissive): Do not define.
19941         * c-tree.h (system_header_p): Delete unused.
19942
19943 2012-05-03  David S. Miller  <davem@davemloft.net>
19944
19945         PR target/52684
19946         * config/sparc/sparc.c (emit_soft_tfmode_libcall): If we pass a
19947         MEM directly into a libcall, mark it's MEM_EXPR as addressable.
19948         (sparc_emit_float_lib_cmp): Likewise.
19949
19950 2012-05-03  Michael Meissner  <meissner@linux.vnet.ibm.com>
19951
19952         PR target/53199
19953         * config/rs6000/rs6000.md (bswapdi splitters): If
19954         -mavoid-indexed-addresses (or -mcpu=power6 which sets it by
19955         default) is used, generate an alternate sequence that does not
19956         depend on using indexed addressing.
19957
19958 2012-05-03  Jason Merrill  <jason@redhat.com>
19959
19960         * gengtype.c (write_types): Fix warning message.
19961         (write_local): Likewise.
19962
19963 2012-05-02  Jason Merrill  <jason@redhat.com>
19964
19965         * dwarf2out.c (struct external_ref, build_local_stub): New.
19966         (hash_external_ref, external_ref_eq, lookup_external_ref): New.
19967         (optimize_external_refs, optimize_external_refs_1): New.
19968         (change_AT_die_ref): New.
19969         (clone_as_declaration): Add DW_AT_signature when cloning a declaration.
19970         (build_abbrev_table): Take the external refs hashtable.
19971         (output_comp_unit): Get it from optimize_external_refs and pass it in.
19972
19973 2012-05-03  Jan Hubicka  <jh@suse.cz>
19974
19975         PR middle-end/53093
19976         * tree-emutls.c (new_emutls_decl): Fix handling of aliases.
19977
19978 2012-05-03  Jan Hubicka  <jh@suse.cz>
19979
19980         PR middle-end/53106
19981         * ipa.c (cgraph_remove_unreachable_nodes): Fix handling of clones.
19982
19983 2012-05-03  Jason Merrill  <jason@redhat.com>
19984
19985         * dwarf2out.c (die_struct): Add comdat_type_p flag.  Use it instead of
19986         use_debug_types to discriminate the die_id union.
19987         (print_die, assign_symbol_names, copy_decls_walk): Likewise.
19988         (build_abbrev_table, output_die): Likewise.
19989         (prune_unused_types_walk_attribs): Likewise.
19990         (generate_type_signature, copy_declaration_context): Set it.
19991         (remove_child_or_replace_with_skeleton): Set it.
19992         (dwarf2out_start_source_file, dwarf2out_end_source_file): Don't
19993         check use_debug_types.
19994         (dwarf2out_finish): Do break_out_includes after .debug_types.
19995
19996 2012-05-03  Jason Merrill  <jason@redhat.com>
19997
19998         * dwarf2out.c (modified_type_die): Use scope_die_for.
19999         (gen_type_die_with_usage, dwarf2out_finish): Likewise.
20000         (uses_local_type_r, uses_local_type): New.
20001         (scope_die_for): Keep a type that uses a local type in local scope.
20002         Use get_context_die for namespace and type scope.
20003
20004 2012-05-03  Jason Merrill  <jason@redhat.com>
20005
20006         * config/i386/i386.c (ix86_code_end): Set DECL_IGNORED_P on the
20007         pc thunk.
20008         * dwarf2out.c (output_aranges): Skip DECL_IGNORED_P functions.
20009         (dwarf2out_finish): Likewise.
20010
20011 2012-05-03  Martin Jambor  <mjambor@suse.cz>
20012
20013         * builtins.c (get_object_alignment_1): Return whether we can determine
20014         the alignment or conservatively assume byte alignment.  Return the
20015         alignment by reference.  Use get_pointer_alignment_1 for dereference
20016         alignment.
20017         (get_pointer_alignment_1): Return whether we can determine the
20018         alignment or conservatively assume byte alignment.  Return the
20019         alignment by reference.  Use get_ptr_info_alignment to get SSA name
20020         alignment.
20021         (get_object_alignment): Update call to get_object_alignment_1.
20022         (get_object_or_type_alignment): Likewise, fall back to type alignment
20023         only when it returned false.
20024         (get_pointer_alignment): Update call to get_pointer_alignment_1.
20025         * fold-const.c (get_pointer_modulus_and_residue): Update call to
20026         get_object_alignment_1.
20027         * ipa-prop.c (ipa_modify_call_arguments): Update call to
20028         get_pointer_alignment_1.
20029         * tree-sra.c (build_ref_for_offset): Likewise, fall back to the type
20030         of MEM_REF or TARGET_MEM_REF only when it returns false.
20031         * tree-ssa-ccp.c (get_value_from_alignment): Update call to
20032         get_object_alignment_1.
20033         (ccp_finalize): Use set_ptr_info_alignment.
20034         * tree.h (get_object_alignment_1): Update declaration.
20035         (get_pointer_alignment_1): Likewise.
20036         * gimple-pretty-print.c (dump_gimple_phi): Use get_ptr_info_alignment.
20037         (dump_gimple_stmt): Likewise.
20038         * tree-flow.h (ptr_info_def): Updated comments of fields align and
20039         misalign.
20040         (get_ptr_info_alignment): Declared.
20041         (mark_ptr_info_alignment_unknown): Likewise.
20042         (set_ptr_info_alignment): Likewise.
20043         (adjust_ptr_info_misalignment): Likewise.
20044         * tree-ssa-address.c (copy_ref_info): Use new access functions to get
20045         and set alignment of SSA names.
20046         * tree-ssa-loop-ivopts.c (rewrite_use_nonlinear_expr): Call
20047         mark_ptr_info_alignment_unknown.
20048         * tree-ssanames.c (get_ptr_info_alignment): New function.
20049         (mark_ptr_info_alignment_unknown): Likewise.
20050         (set_ptr_info_alignment): Likewise.
20051         (adjust_ptr_info_misalignment): Likewise.
20052         (get_ptr_info): Call mark_ptr_info_alignment_unknown.
20053         * tree-vect-data-refs.c (vect_create_addr_base_for_vector_ref):
20054         Likewise.
20055         (bump_vector_ptr): Likewise.
20056         * tree-vect-stmts.c (create_array_ref): Use set_ptr_info_alignment.
20057         (vectorizable_store): Likewise.
20058         (vectorizable_load): Likewise.
20059
20060 2012-05-03  Michael Matz  <matz@suse.de>
20061
20062         * basic-block.h (struct rtl_bb_info, struct gimple_bb_info): Move
20063         in front of basic_block_def.
20064         (struct basic_block_def): Make il.gimple the full struct, not a
20065         pointer.
20066         (__assert_gimple_bb_smaller_rtl_bb): Asserting typedef.
20067
20068         * cfgexpand.c (expand_gimple_basic_block): Clear all il.gimple members.
20069         * gimple-iterator.c (gimple_stmt_iterator): Don't special case
20070         NULL il.gimple, which can't happen anymore.
20071         * gimple.h (bb_seq): il.gimple can't be NULL.
20072         (bb_seq_add): Ditto.
20073         (set_bb_seq): Adjust.
20074         (gsi_start_bb, gsi_last_bb): Tidy.
20075         * lto-streamer-in.c (make_new_block): Don't zero members that
20076         are zeroed already, don't allocate a gimple_bb_info.
20077         * tree-cfg.c (create_bb): Don't allocate a gimple_bb_info.
20078         (remove_bb): Clear all il.gimple members.
20079         (gimple_verify_flow_info): Adjust for flat il.gimple.
20080         * tree-flow-inline.h (phi_nodes, phi_nodes_ptr, set_phi_nodes): Adjust.
20081
20082         * coretypes.h (const_gimple_seq): Remove typedef.
20083         * gimple.h (gimple_seq_first): Take gimple_seq.
20084         (gimple_seq_first_stmt): Ditto.
20085         (gimple_seq_last): Ditto.
20086         (gimple_seq_last_stmt): Ditto.
20087         (gimple_seq_empty_p): Ditto.
20088
20089 2012-05-03  Richard Guenther  <rguenther@suse.de>
20090
20091         * tree-ssa-pre.c (valid_in_sets): Remove checking of trapping
20092         operations.
20093         (prune_clobbered_mems): Do it here.  Do not uselessly sort expressions.
20094         (compute_avail): Do not add possibly trapping operations to
20095         EXP_GEN if they might not be executed in the block.
20096
20097 2012-05-03  Uros Bizjak  <ubizjak@gmail.com>
20098
20099         * config/alpha/elf.h (MAX_OFILE_ALIGNMENT): Remove.
20100
20101 2012-05-03  Steven Bosscher  <steven@gcc.gnu.org>
20102
20103         * tree-switch-conversion.c (gen_inbound_check): Free post-dominance
20104         information as early as possible.  Update dominance info instead of
20105         discarding it.
20106
20107 2012-05-03  Richard Guenther  <rguenther@suse.de>
20108
20109         * tree-ssa-pre.c (debug_bitmap_sets_for): New function.
20110         (union_contains_value): Remove.
20111         (vro_valid_in_sets): Likewise.
20112         (op_valid_in_sets): New function.
20113         (valid_in_sets): Use op_valid_in_sets.
20114         (insert_into_preds_of_block): Move dumping ...
20115         (do_regular_insertion): ... here.
20116         (do_partial_partial_insertion): ... and here.  Dump that
20117         we've found a partial partial redundancy.
20118         (insert): Dump the current insert iteration.
20119
20120 2012-05-03  Jakub Jelinek  <jakub@redhat.com>
20121
20122         PR plugins/53126
20123         * gcc-ar.c (main): If GCC_EXEC_PREFIX is set in env,
20124         append program name to it and pass that as first argument
20125         to make_relative_prefix.  Always pass standard_libexec_prefix
20126         as last argument to make_relative_prefix.  If
20127         make_relative_prefix returns NULL, fall back to
20128         standard_libexec_prefix.
20129
20130         PR debug/53174
20131         * tree-predcom.c (remove_stmt): Call reset_debug_uses on stmts being
20132         removed.
20133
20134         PR target/53187
20135         * config/arm/arm.c (arm_select_cc_mode): If x has MODE_CC class
20136         mode, return that mode.
20137
20138         PR target/53194
20139         * config/i386/i386-c.c (ix86_target_macros_internal): Don't
20140         define __ATOMIC_HLE_* macros here.
20141         (ix86_target_macros): But here, using cpp_define_formatted.
20142
20143 2012-05-03  Richard Guenther  <rguenther@suse.de>
20144
20145         PR tree-optimization/53144
20146         * tree-ssa-sccvn.c (vn_reference_lookup_or_insert_constant_for_pieces):
20147         Rename to ...
20148         (vn_reference_lookup_or_insert_for_pieces): ... this.  Properly deal
20149         with SSA name values.
20150         (vn_reference_lookup_3): Adjust callers.
20151
20152 2012-05-03  Ganesh Gopalasubramanian  <Ganesh.Gopalasubramanian@amd.com>
20153
20154         * config/i386/driver-i386.c (host_detect_local_cpu): Reset
20155         has_fma4 for AMD processors with both fma3 and fma4 support.
20156
20157 2012-05-03  Kirill Yukhin  <kirill.yukhin@intel.com>
20158
20159         PR target/53201
20160         * config/i386/driver-i386.c (host_detect_local_cpu): Add space to
20161         "-mno-hle".
20162
20163 2012-05-03  Michael Matz  <matz@suse.de>
20164
20165         PR bootstrap/53197
20166         * tree-ssa-dse.c (dse_optimize_stmt): Take pointer to iterator.
20167         (dse_enter_block): Properly iterate the whole sequence even
20168         if the last statement was removed.
20169
20170 2012-05-02  Steven Bosscher  <steven@gcc.gnu.org>
20171
20172         * config/alpha/vms.h (SUBTARGET_OVERRIDE_OPTIONS): For pic code,
20173         unset flag_jump_tables.
20174         * stmt.c (expand_case): Remove special flag_pic case conditional
20175         on ASM_OUTPUT_ADDR_DIFF_ELT not being defined.
20176
20177 2012-05-02  Ulrich Weigand  <ulrich.weigand@linaro.org>
20178
20179         * common/config/s390/s390-common.c (s390_option_optimization_table):
20180         Enable -fsched-pressure using -fsched-pressure-algorithm=model by
20181         default when optimizing.
20182
20183 2012-05-02  Martin Jambor  <mjambor@suse.cz>
20184
20185         PR lto/52605
20186         * dwarf2out.c (dwarf2out_decl): Only lookup die representing context
20187         of a variable when the contect is a function.
20188
20189 2012-05-02  Michael Matz  <matz@suse.de>
20190
20191         * coretypes.h (gimple_seq, const_gimple_seq): Typedef as gimple.
20192         * gimple.h (struct gimple_seq_node_d, struct gimple_seq_d): Remove.
20193         (const_gimple_seq_node): Remove.
20194         (gimple_seq_node): Typedef as gimple.
20195         (struct gimple_statement_base): Add next and prev members,
20196         adjust all WORD markers in using structs.
20197         (union gimple_statement_d): Link via gsbase.next field for GC and PCH.
20198         (gimple_seq_first, gimple_seq_first_stmt, gimple_seq_last,
20199         gimple_seq_last_stmt): Adjust as gimple_seq, gimple_seq_node and
20200         gimple are the same.
20201         (gimple_seq_set_last, gimple_seq_set_first): Don't allocate
20202         gimple_seq, adjust.
20203         (gimple_init_singleton): New function.
20204         (gsi_start_1, gsi_last_1, gsi_end_p, gsi_one_before_end_p): Adjust.
20205         (gsi_next, gsi_prev): Adjust, handle prev cyclic list correctly.
20206         (gsi_stmt): Adjust.
20207         (gsi_stmt_ptr): Remove.
20208         (enum gimple_alloc_kind): Remove gimple_alloc_kind_seq member.
20209
20210         * gimple-iterator.c (update_bb_for_stmts): Take last parameter
20211         again, adjust for above changes.
20212         (update_call_edge_frequencies): Adjust for above changes.
20213         (gsi_insert_seq_nodes_before): Rewrite for new data structure.
20214         (gsi_insert_seq_nodes_after): Ditto.
20215         (gsi_split_seq_after): Ditto.
20216         (gsi_set_stmt): Ditto.
20217         (gsi_split_seq_before): Ditto.
20218         (gsi_remove): Ditto.
20219         (gsi_insert_seq_before_without_update): Don't free sequence.
20220         (gsi_insert_seq_after_without_update): Ditto.
20221         (gsi_replace): Assert some more invariants.
20222         (gsi_insert_before_without_update, gsi_insert_after_without_update):
20223         Tidy.
20224         (gsi_for_stmt): Don't search for stmt.
20225         (gsi_insert_on_edge_immediate): Tidy.
20226
20227         * gimple.c (gimple_alloc_k): Remove "sequences".
20228         (gimple_seq_cache): Remove.
20229         (gimple_alloc_stat): Make stmt a singleton sequence.
20230         (gimple_seq_alloc, gimple_seq_free): Remove.
20231         (gimple_assign_set_rhs_with_ops_1): Ensure new stmt is a singleton.
20232         (gimple_copy): Ditto.
20233         * gimplify.c (gimplify_cleanup_point_expr): Use gsi_set_stmt,
20234         create iterator from correct sequence.
20235         * tree-phinodes.c (make_phi_node): Make stmt a singleton.
20236
20237 2012-05-02  Michael Matz  <matz@suse.de>
20238
20239         * gimple.h (gimple_stmt_iterator <seq>): Make it be pointer to
20240         gimple_seq.
20241         (gimple_seq_set_last, gimple_seq_set_first): Take pointer to
20242         sequence, lazily allocate it.
20243         (bb_seq_addr): New function.
20244         (gsi_start_1): Rename from gsi_start, but take pointer to sequence.
20245         (gsi_start): Macro to wrap gsi_start_1 taking pointer of argument.
20246         (gsi_none): New function.
20247         (gsi_start_bb): Adjust.
20248         (gsi_last_1): Rename from gsi_last, but take pointer to sequence.
20249         (gsi_last): Macro to wrap gsi_last_1 taking pointer of argument.
20250         (gsi_last_bb): Adjust.
20251         (gsi_seq): Adjust.
20252         * tree-flow-inline.h (phi_nodes_ptr): New function.
20253
20254         * gimple-iterator.c (gsi_insert_seq_nodes_before): Adjust to
20255         datastructure and interface change.
20256         (gsi_insert_seq_before_without_update): Ditto.
20257         (gsi_insert_seq_nodes_after): Ditto.
20258         (gsi_insert_seq_after_without_update): Ditto.
20259         (gsi_split_seq_after): Ditto, don't use gimple_seq_alloc.
20260         (gsi_split_seq_before): Ditto.
20261         (gsi_start_phis): Adjust.
20262         * tree-vect-loop.c (vect_determine_vectorization_factor): Use gsi_none.
20263         (vect_transform_loop): Ditto.
20264         * gimple.c (gimple_seq_add_stmt, gimple_seq_add_seq,
20265         gimple_seq_copy): Don't use gimple_seq_alloc.
20266         * gimplify.c (gimple_seq_add_stmt_without_update): Ditto.
20267         (gimplify_seq_add_seq): Ditto.
20268         * lto-streamer-in.c (make_new_block): Ditto.
20269         * tree-cfg.c (create_bb): Ditto.
20270         * tree-sra.c (initialize_parameter_reductions): Ditto.
20271
20272 2012-05-02  Michael Matz  <matz@suse.de>
20273
20274         * gimple.h (gimple_seq_first, gimple_seq_first_stmt, gimple_seq_last,
20275         gimple_seq_last_stmt, gimple_seq_set_last, gimple_seq_set_first,
20276         gimple_seq_empty_p, gimple_seq_alloc_with_stmt, bb_seq,
20277         set_bb_seq): Move down to after gimple_statement_d definition.
20278
20279 2012-05-02  Michael Matz  <matz@suse.de>
20280
20281         * gimple-fold.c (gimplify_and_update_call_from_tree): Use
20282         gsi_replace_with_seq, instead of inserting itself.
20283         * gimple-iterator.c (gsi_replace_with_seq): New function.
20284         * tree-ssa-forwprop.c (forward_propagate_comparison): Take
20285         iterator instead of statement, advance it.
20286         (ssa_forward_propagate_and_combine): Adjust call to above.
20287
20288 2012-05-02  Michael Matz  <matz@suse.de>
20289
20290         * tree-phinodes.c (add_phi_node_to_bb): Tidy, don't use
20291         gimple_seq_alloc.
20292         * omp-low.c (finalize_task_copyfn): Don't use gimple_seq_alloc.
20293         * tree-nested.c (walk_gimple_omp_for): Ditto.
20294         * trans-mem.c (lower_transaction): Ditto.
20295         * tree-eh.c (do_return_redirection): Ditto.
20296         (do_goto_redirection): Ditto.
20297         (lower_try_finally_switch): Ditto.
20298         * gimplify.c (gimplify_stmt): Ditto.
20299         (gimplify_scan_omp_clauses): Ditto.
20300         (gimplify_omp_for): Ditto.
20301         (gimplify_function_tree): Ditto.
20302         * gimple-fold.c (gimplify_and_update_call_from_tree): Ditto.
20303         * tree-mudflap.c (mf_decl_cache_locals): Ditto.
20304         (mf_build_check_statement_for): Ditto.
20305         (mx_register_decls): Ditto.
20306         * graphite-sese-to-poly.c (remove_invariant_phi): Ditto,
20307         and don't use itertors to append.
20308         (insert_stmts): Ditto.
20309         (insert_out_of_ssa_copy): Ditto.
20310         (insert_out_of_ssa_copy_on_edge): Ditto.
20311
20312 2012-05-02  Michael Matz  <matz@suse.de>
20313
20314         * gimple.h (gimple_bind_body_ptr): New function.
20315         (gimple_bind_body): Use it.
20316         (gimple_catch_handler): Use gimple_catch_handler_ptr.
20317         (gimple_eh_filter_failure_ptr): New function.
20318         (gimple_eh_filter_failure): Use it.
20319         (gimple_eh_else_n_body_ptr): New function.
20320         (gimple_eh_else_n_body): Use it.
20321         (gimple_eh_else_e_body_ptr): New function.
20322         (gimple_eh_else_e_body): Use it.
20323         (gimple_try_eval_ptr): New function.
20324         (gimple_try_eval): Use it.
20325         (gimple_try_cleanup_ptr): New function.
20326         (gimple_try_cleanup): Use it.
20327         (gimple_wce_cleanup_ptr): New function.
20328         (gimple_wce_cleanup): Use it.
20329         (gimple_omp_body_ptr): New function.
20330         (gimple_omp_body): Use it.
20331         (gimple_omp_for_pre_body_ptr): New function.
20332         (gimple_omp_for_pre_body): Use it.
20333         (gimple_transaction_body_ptr): New function.
20334         (gimple_transaction_body): Use it.
20335         (gsi_split_seq_before): Adjust to return nothing and take pointer
20336         to sequence.
20337         (gsi_set_stmt): Declare.
20338         (gsi_replace_with_seq): Declare.
20339         (walk_gimple_seq_mod): Declare.
20340         * function.h (struct function <gimple_body>): Use typedef gimple_seq.
20341
20342         * gimple-iterator.c (gsi_set_stmt): New function.
20343         (gsi_split_seq_before): Return new sequence via pointer argument.
20344         (gsi_replace): Use gsi_set_stmt.
20345
20346         * tree-ssa-loop-im.c (move_computations_stmt): First remove
20347         then insert stmt.
20348         * tree-complex.c (update_complex_components_on_edge): Don't copy gsi.
20349         * tree-phinodes.c (resize_phi_node): Don't resize stmt in-place,
20350         return new stmt.
20351         (reserve_phi_args_for_new_edge): Change call to above,
20352         use gsi_set_stmt.
20353
20354         * omp-low.c (lower_omp): Change prototype to take pointer to sequence.
20355         (lower_rec_input_clauses): Use gimple_seq_add_seq instead of
20356         iterators.  Adjust call to lower_omp.
20357         (lower_lastprivate_clauses): Adjust call to lower_omp.
20358         (lower_reduction_clauses): Ditto.
20359         (expand_omp_taskreg): Nullify non-cfg body of child_fn.
20360         (lower_omp_sections): Don't explicitely count sequence length,
20361         nullify lowered bodies earlier, ensure stmts are part of only
20362         one sequence, adjust call to lower_omp.
20363         (lower_omp_single): Ensure stmts are part of only one sequence,
20364         adjust call to lower_omp.
20365         (lower_omp_master): Ditto.
20366         (lower_omp_ordered): Ditto.
20367         (lower_omp_critical): Ditto.
20368         (lower_omp_for): Ditto.
20369         (lower_omp_taskreg): Ditto, tidy.
20370         (lower_omp_1): Adjust calls to lower_omp.
20371         (execute_lower_omp): Ditto.
20372         (lower_omp): Adjust to take pointer to sequence.
20373         (diagnose_sb_2): Use walk_gimple_seq_mod.
20374         (diagnose_omp_structured_block_errors): Ditto and set possibly
20375         changed function body.
20376         * gimple-low.c (lower_function_body): Set function body after
20377         it stabilizes.
20378         (lower_sequence): Adjust to take pointer to sequence.
20379         (lower_omp_directive): Ensure stmt isn't put twice into the
20380         sequence, adjust call to lower_sequence.
20381         (lower_stmt): Adjust calls to lower_sequence.
20382         (lower_gimple_bind): Ditto.
20383         (gimple_try_catch_may_fallthru): Call gsi_start with lvalue.
20384         * tree-nested.c (walk_body): Take pointer to sequence, use
20385         walk_gimple_seq_mod.
20386         (walk_function): Adjust call to walk_body, set possibly changed body.
20387         (walk_gimple_omp_for): Adjust calls to walk_body.
20388         (convert_nonlocal_omp_clauses): Ditto.
20389         (convert_nonlocal_reference_stmt): Ditto.
20390         (convert_local_omp_clauses): Ditto.
20391         (convert_local_reference_stmt): Ditto.
20392         (convert_tramp_reference_stmt): Ditto.
20393         (convert_gimple_call): Ditto.
20394         (convert_nl_goto_reference): Use local iterator copy.
20395         * gimple.c (walk_gimple_seq_mod): Renamed from walk_gimple_seq,
20396         but taking pointer to sequence, ensure gsi_start is called with
20397         callers lvalue.
20398         (walk_gimple_seq): New wrapper around walk_gimple_seq_mod,
20399         asserting that the sequence head didn't change.
20400         (walk_gimple_stmt): Replace all calls to walk_gimple_seq with
20401         walk_gimple_seq_mod.
20402         * trans-mem.c (lower_transaction): Use walk_gimple_seq_mod.
20403         (execute_lower_tm): Ditto, and set possibly changed body.
20404         * tree-eh.c (lower_eh_constructs_1): Take pointer to sequence,
20405         call gsi_start with that lvalue.
20406         (replace_goto_queue_stmt_list): Ditto.
20407         (replace_goto_queue_1): Adjust calls to replace_goto_queue_stmt_list.
20408         (replace_goto_queue): Ditto.
20409         (lower_try_finally_nofallthru): Adjust calls to lower_eh_constructs_1.
20410         (lower_try_finally_onedest): Ditto.
20411         (lower_try_finally_copy): Ditto.
20412         (lower_try_finally_switch): Ditto.
20413         (lower_try_finally): Ditto.
20414         (lower_eh_filter): Ditto.
20415         (lower_eh_must_not_throw): Ditto.
20416         (lower_cleanup): Ditto.
20417         (lower_eh_constructs_2): Ditto.
20418         (lower_catch): Ditto, and ensure gsi_start is called with lvalue.
20419         (lower_eh_constructs): Adjust calls to lower_eh_constructs_1, and
20420         set possibly changed body.
20421         (optimize_double_finally): Call gsi_start with lvalue.
20422
20423         * tree-cfg.c (make_blocks): Adjust call to gsi_split_seq_before.
20424         (gimple_split_block): Ditto.
20425         (gimple_merge_blocks): Use gsi_start_phis.
20426         (move_stmt_r): Use walk_gimple_seq_mod.
20427         * tree-ssa-dse.c (dse_enter_block): Use gsi_last_bb.
20428         * cgraphbuild.c (build_cgraph_edges): Use gsi_start_phis.
20429         (rebuild_cgraph_edges): Ditto.
20430         (cgraph_rebuild_references): Ditto.
20431         * ipa-prop.c (ipa_analyze_params_uses): Ditto.
20432         * tree-inline.c (copy_phis_for_bb): Ditto.
20433         * tree-ssa-dce.c: Ditto.
20434
20435         * cgraphunit.c (cgraph_analyze_function): Use gimple_has_body_p.
20436
20437 2012-05-02  Kirill Yukhin  <kirill.yukhin@intel.com>
20438             Andi Kleen  <ak@linux.intel.com>
20439
20440         * coretypes.h (MEMMODEL_MASK): New.
20441         * builtins.c (get_memmodel): Add val. Call target.memmodel_check
20442         and return new variable.
20443         (expand_builtin_atomic_exchange):  Mask memmodel values.
20444         (expand_builtin_atomic_compare_exchange): Ditto.
20445         (expand_builtin_atomic_load): Ditto.
20446         (expand_builtin_atomic_store): Ditto.
20447         (expand_builtin_atomic_clear): Ditto.
20448         * doc/extend.texi: Mention port-dependent memory model flags.
20449         * config/i386/cpuid.h (bit_HLE): New.
20450         * config/i386/driver-i386.c (host_detect_local_cpu): Detect
20451         HLE support.
20452         * config/i386/i386-protos.h (ix86_generate_hle_prefix): New.
20453         * config/i386/i386-c.c (ix86_target_macros_internal): Set HLE defines.
20454         (ix86_target_string)<-mhle>: New.
20455         (ix86_valid_target_attribute_inner_p) <OPT_mhle>: Ditto.
20456         * config/i386/i386.c (ix86_target_string) <OPTION_MASK_ISA_HLE>: New.
20457         (ix86_valid_target_attribute_inner_p) <OPT_mhle>: Ditto.
20458         (ix86_option_override_internal) <PTA_HLE>: New switch, set it
20459         enabled for generic, generic64 and core-avx2.
20460         (ix86_print_operand): Generate HLE lock prefixes.
20461         (ix86_memmodel_check): New.
20462         (TARGET_MEMMODEL_CHECK): Ditto.
20463         * config/i386/i386.h (OPTION_ISA_HLE): Ditto.
20464         (IX86_HLE_ACQUIRE): Ditto.
20465         (IX86_HLE_RELEASE): Ditto.
20466         * config/i386/i386.h (ix86_generate_hle_prefix): Ditto.
20467         * config/i386/i386.opt (mhle): Ditto.
20468         * config/i386/sync.md(atomic_compare_and_swap<mode>): Pass
20469         success model to instruction emitter.
20470         (atomic_fetch_add<mode>): Ditto.
20471         (atomic_exchange<mode>): Ditto.
20472         (atomic_add<mode>): Ditto.
20473         (atomic_sub<mode>): Ditto.
20474         (atomic_<code><mode>): Ditto.
20475         (*atomic_compare_and_swap_doubledi_pic): Ditto.
20476         (atomic_compare_and_swap_single<mode>): Define and use argument
20477         for success model.
20478         (atomic_compare_and_swap_double<mode>): Ditto.
20479         * configure.ac: Check if assembler support HLE prefixes.
20480         * configure: Regenerate.
20481         * config.in: Ditto.
20482
20483 2012-05-02  Steven Bosscher  <steven@gcc.gnu.org>
20484
20485         PR middle-end/53153
20486         * gimplify.c (preprocess_case_label_vec_for_gimple): New function,
20487         split out from ...
20488         (gimplify_switch_expr): ... here.
20489         * gimple.h (preprocess_case_label_vec_for_gimple): Add prototype.
20490         * tree-ssa-forwprop.c (simplify_gimple_switch_label_vec): New function
20491         to clean up case labels with values outside the index type range.
20492         (simplify_gimple_switch): Call it if something changed.
20493         Remove strange and unnecessary assert.
20494
20495 2012-05-02  Richard Guenther  <rguenther@suse.de>
20496
20497         * fold-const.c (div_if_zero_remainder): sizetypes no longer
20498         sign-extend.
20499         (int_const_binop_1): New worker for int_const_binop with
20500         overflowable parameter.  Pass it through to force_fit_type_double.
20501         (int_const_binop): Wrap around int_const_binop_1 with overflowable
20502         equal to one.
20503         (size_binop_loc): Call int_const_binop_1 with overflowable equal
20504         to minus one, forcing overflow detection for even unsigned types.
20505         (extract_muldiv_1): Remove bogus TYPE_IS_SIZETYPE special-casing.
20506         (fold_binary_loc): Call try_move_mult_to_index with signed offset.
20507         * stor-layout.c (initialize_sizetypes): sizetypes no longer
20508         sign-extend.
20509         (layout_type): For zero-sized arrays ignore overflow on the
20510         size calculations.
20511         * tree-ssa-ccp.c (bit_value_unop_1): Likewise.
20512         (bit_value_binop_1): Likewise.
20513         * tree.c (double_int_to_tree): Likewise.
20514         (double_int_fits_to_tree_p): Likewise.
20515         (force_fit_type_double): Likewise.
20516         (host_integerp): Likewise.
20517         (int_fits_type_p): Likewise.
20518         * varasm.c (output_constructor_regular_field): Sign-extend the
20519         field-offset to cater for negative offsets produced by the Ada
20520         frontend.
20521         * omp-low.c (extract_omp_for_data): Convert the loop step to
20522         signed for pointer adjustments.
20523
20524 2012-05-02  Richard Guenther  <rguenther@suse.de>
20525
20526         * tree.c (valid_constant_size_p): New function.
20527         * tree.h (valid_constant_size_p): Declare.
20528         * cfgexpand.c (expand_one_var): Adjust check for too large
20529         variables by using valid_constant_size_p.
20530         * varasm.c (assemble_variable): Likewise.
20531
20532         * c-decl.c (grokdeclarator): Properly check for sizes that
20533         cover more than half of the address-space.
20534
20535 2012-05-02  Jakub Jelinek  <jakub@redhat.com>
20536
20537         PR tree-optimization/53163
20538         * tree-ssa-phiopt.c (cond_if_else_store_replacement): Don't ignore
20539         return value from compute_all_dependences.
20540
20541         PR rtl-optimization/53160
20542         * ree.c (combine_reaching_defs): Handle the case where cand->insn
20543         has been modified by ree pass already.
20544
20545 2012-05-01  Ian Lance Taylor  <iant@google.com>
20546
20547         PR c/37303
20548         * c-decl.c (build_compound_literal): Make the decl readonly if it
20549         an array of a readonly type.
20550         * gimplify.c (gimplify_compound_literal_expr): Add fallback
20551         parameter.  Change all callers.  If the decl is not addressable
20552         and is not an l-value, make it readonly.
20553
20554 2012-05-01  Bernd Schmidt  <bernds@codesourcery.com>
20555
20556         * ira.c (allocated_reg_info_size): New static variable.
20557         (expand_reg_info): Manage it. Call
20558         setup_preferred_alternate_classes_for_new_pseudos.
20559         (ira): Don't do it here.  Remove local allocated_reg_info_size,
20560         set the global before calling find_moveable_pseudos.
20561         (find_moveable_pseudos): Call expand_reg_info rather than
20562         resize_reg_info.
20563
20564 2012-05-01  Richard Henderson  <rth@redhat.com>
20565
20566         * common.opt (fsync-libcalls): New.
20567         * doc/invoke.texi: Document it.
20568         * optabs.c (init_sync_libfuncs): Honor it.
20569
20570 2012-05-01  Kenneth Zadeck  <zadeck@naturalbridge.com>
20571             Richard Sandiford  <r.sandiford@uk.ibm.com>
20572
20573         PR rtl-optimization/52543
20574         * Makefile.in (lower-subreg.o, target-globals.o): Depend on
20575         lower-subreg.h.
20576         * lower-subreg.h: New file.
20577         * target-globals.h (this_target_lower_subreg): Declare.
20578         (target_globals): Add lower_subreg;
20579         (restore_target_globals): Restore this_target_lower_subreg.
20580         * target-globals.c: Include it.
20581         (default_target_globals): Add default_target_lower_subreg.
20582         (save_target_globals): Initialize target_lower_subreg.
20583         * rtl.h (init_lower_subreg): Added declaration.
20584         * toplev.c (backend_init_target): Call initializer for lower-subreg
20585         pass.
20586         * lower-subreg.c (LOG_COSTS, FORCE_LOWERING): New macros.
20587         (default_target_lower_subreg): New variable.
20588         (this_target_lower_subreg): Likewise.
20589         (twice_word_mode, choices): New macros.
20590         (shift_cost, compute_splitting_shift, compute_costs)
20591         (init_lower_subreg): New functions.
20592         (resolve_simple_move): Add speed_p argument.  Check choices.
20593         (find_pseudo_copy): Don't check the mode size here.
20594         (resolve_simple_move): Assert the mode size.
20595         (find_decomposable_shift_zext): Add speed_p argument and return
20596         a bool.  Check choices.
20597         (resolve_shift_zext): Add comment.
20598         (dump_shift_choices, dump_choices): New functions.
20599         (decompose_multiword_subregs): Dump list of profitable
20600         transformations.  Add code to skip non profitable transformations.
20601         Update calls to simple_move and find_decomposable_shift_zext.
20602
20603 2012-05-01  Ian Bolton  <ian.bolton@arm.com>
20604             Sameera Deshpande  <sameera.deshpande@arm.com>
20605             Greta Yorsh  <greta.yorsh@arm.com>
20606
20607         * config/arm/arm-protos.h (thumb_unexpanded_epilogue): Rename to...
20608         (thumb1_unexpanded_epilogue): ...this.
20609         * config/arm/arm.c (thumb_unexpanded_epilogue): Rename to...
20610         (thumb1_unexpanded_epilogue): ...this.
20611         * config/arm/arm.md (thumb_unexpanded_epilogue): Rename to...
20612         (thumb1_unexpanded_epilogue): ...this.
20613
20614 2012-05-01  Richard Earnshaw  <rearnsha@arm.com>
20615
20616         * arm/linux-eabi.h (GLIBC_DYNAMIC_LINKER_DEFAULT): Avoid ifdef
20617         comparing enumeration values.  Update comments.
20618
20619 2012-05-01  Alan Modra  <amodra@gmail.com>
20620
20621         PR target/53038
20622         * config/rs6000/rs6000.c (load_lr_save, restore_saved_lr,
20623         load_cr_save, add_crlr_cfa_restore): New functions.
20624         (rs6000_restore_saved_cr): Rename to..
20625         (restore_saved_cr): ..this.  Add cfa_restore notes for cr.
20626         (rs6000_emit_epilogue): Use new functions.  Adjust condition
20627         for emitting lr and cr cfa_restore.  Emit cfa_restores for fp
20628         regs when using out-of-line restore only when shrink wrapping.
20629
20630 2012-04-30  Uros Bizjak  <ubizjak@gmail.com>
20631
20632         PR middle-end/53136
20633         * ipa-prop.c (ipa_print_node_jump_functions): Wrap multiple
20634         calls to cgraph_node_name in xstrdup.
20635         (ipa_make_edge_direct_to_target): Ditto.
20636         * cgraph.c (dump_cgraph_node): Ditto.
20637         * tree-sra.c (convert_callers_for_node): Ditto.
20638         * lto-symtab.c (lto_cgraph_replace_node): Ditto.
20639         * ipa-cp.c (perhaps_add_new_callers): Ditto.
20640         * cgraphunit.c (cgraph_redirect_edge_call_stmt_to_callee): Ditto.
20641         (cgraph_materialize_all_clones): Ditto.
20642         * ipa-inline.c (report_inline_failed_reason): Ditto.
20643         (want_early_inline_function_p): Ditto.
20644         (edge_badness): Ditto.
20645         (update_edge_key): Ditto.
20646         (flatten_function): Ditto.
20647         (ipa_inline): Ditto.
20648         (inline_always_inline_functions): Ditto.
20649         (early_inline_small_functions): Ditto.
20650
20651 2012-04-30  Uros Bizjak  <ubizjak@gmail.com>
20652
20653         PR target/53141
20654         * config/i386/i386.md (*umul<mode><dwi>3_1): Switch places of
20655         constraints 0 and 1.
20656
20657 012-04-30  Jan Hubicka  <jh@suse.cz>
20658
20659         * cgraph.c (ld_plugin_symbol_resolution_names): Move to symtab.c
20660         (cgraph_asm_nodes, cgraph_asm_last_node): Move to cgraphunit.c
20661         (cgraph_add_to_same_comdat_group): Remove.
20662         (cgraph_add_asm_node): Move to cgraphunit.c.
20663         (cgraph_make_decl_local): Move to symtab.c
20664         (cgraph_make_node_local_1): Update.
20665         (cgraph_can_remove_if_no_direct_calls_and): Update.
20666         (used_from_object_file_p): Update.
20667         (resolution_used_from_other_file_p): Move to symtab.c
20668         (cgraph_used_from_object_file_p): move to symtab.c
20669         (verify_cgraph_node): Verify same comdat groups.
20670         * cgraph.h (cgraph_asm_node): Rename to ...
20671         (asm_node): ... this one.
20672         (cgraph_asm_nodes): Rename to ...
20673         (asm_nodes): ... this one.
20674         (symtab_add_to_same_comdat_group): New function.
20675         (symtab_dissolve_same_comdat_group_list): New function.
20676         (symtab_used_from_object_file_p): Declare.
20677         (symtab_make_decl_local): Declare.
20678         (cgraph_add_to_same_comdat_group): Remove.
20679         (cgraph_add_asm_node): Remove.
20680         (cgraph_used_from_object_file_p, varpool_used_from_object_file_p):
20681         Remove.
20682         (cgraph_finalize_compilation_unit): Rename to ...
20683         (finalize_compilation_unit): ... this one.
20684         (cgraph_optimize): Rename to ....
20685         (compile): ... this one.
20686         (add_asm_node): Declare.
20687         (fixup_same_cpp_alias_visibility): Declare.
20688         (cgraph_make_decl_local): Remove.
20689         (varpool_assemble_pending_decls): Rename to ...
20690         (varpool_output_variables): ... this one.
20691         (varpool_remove_unreferenced_decls): Remove.
20692         * ipa-inline-transform.c (clone_inlined_nodes): Dissolve comdat groups.
20693         (preserve_function_body_p): Make static.
20694         * toplev.c (compile_file): Update comments; update.
20695         * cgraphunit.c: Update comments.
20696         (cgraph_expand_all_functions): Rename to ...
20697         (expand_all_functions): ... this one; update.
20698         (cgraph_mark_functions_to_output): Rename to ...
20699         (mark_functions_to_output): ... this one; cleanup.
20700         (cgraph_output_pending_asms): Remove prototype.
20701         (asm_nodes, asm_last_node): New static vars.
20702         (cgraph_process_new_functions): Update.
20703         (cgraph_reset_node): Cleanup; add comment.
20704         (cgraph_add_new_function): Update.
20705         (cgraph_output_pending_asms): Rename to ...
20706         (output_asm_statements): ... this one.
20707         (add_asm_node): New function.
20708         (fixup_same_cpp_alias_visibility): New function based on code
20709         in cgraph_analyze_function.
20710         (cgraph_analyze_function): Use it.
20711         (cgraph_order_sort): Update.
20712         (cgraph_output_in_order): Update.
20713         (cgraph_function_versioning): Update.
20714         (cgraph_optimize): Rename to ...
20715         (compile): ... this one; initialize streamer hooks here.
20716         (cgraph_finalize_compilation_unit): Rename to ...
20717         (finalize_compilation_unit): ... this one; do not initialize streamer
20718         hook here.
20719         * lto-streamer-out.c (lto_output_toplevel_asms): Update.
20720         * dwarf2out.c: Update ocmment.
20721         * optimize.c (maybe_clone_body): Use symtab_add_to_same_comdat_group.
20722         * method.c (use_thunk): Likewise.
20723         * semantics.c (maybe_add_lambda_conv_op): Likewise.
20724         * decl2.c (maybe_emit_vtables): Likewise.
20725         (cp_write_global_declarations): Use finalize_compilation_unit.
20726         * parser.c (cp_parser_asm_definition): Use add_asm_node.
20727         * lto-streamer-in.c (lto_input_toplevel_asms): Use add_asm_node
20728         * c-decl.c (c_write_global_declarations): Use
20729         finalize_compilation_unit.
20730         * langhooks.c (write_global_declarations): Update.
20731         * ipa.c (cgraph_externally_visible_p): Update.
20732         (dissolve_same_comdat_group_list): Remove.
20733         (function_and_variable_visibility): Update.
20734         * symtab.c: Inlcude lto-streamer.h and rtl.h
20735         (ld_plugin_symbol_resolution_names): New.
20736         (symtab_add_to_same_comdat_group): New.
20737         (symtab_dissolve_same_comdat_group_list): New.
20738         (resolution_used_from_other_file_p): Move here from cgraph.c
20739         (symtab_used_from_object_file_p): New.
20740         (symtab_make_decl_local): New.
20741         * passes.c (register_pass): Update comments.
20742         * c-parser.c (c_parser_asm_definition): Update.
20743         * varpool.c (varpool_analyze_node): Use
20744         fixup_same_cpp_alias_visibility.
20745         (varpool_remove_unreferenced_decls): Make static.
20746         (varpool_assemble_pending_decls): Rename to ...
20747         (varpool_output_variables): ... this one; call
20748         varpool_remove_unreferenced_decls.
20749         (varpool_used_from_object_file_p): Remove.
20750
20751 2012-04-30  Marc Glisse  <marc.glisse@inria.fr>
20752
20753         PR c++/51033
20754         * c-typeck.c (build_array_ref): Call
20755         convert_vector_to_pointer_for_subscript.
20756         * doc/extend.texi (Vector Extensions): Subscripting not just for C.
20757
20758 2012-04-30  Uros Bizjak  <ubizjak@gmail.com>
20759
20760         * config/i386/i386.md (and<mode>3): Change runtime operand mode checks
20761         to compile-time "mode == <MODE>mode" checks.
20762         (and splitter): Ditto.
20763
20764 2012-04-30  Richard Henderson  <rth@redhat.com>
20765
20766         * config/arm/arm.md (UNSPEC_LL): New.
20767         * config/arm/sync.md (atomic_loaddi, atomic_loaddi_1): New.
20768         (arm_load_exclusivedi): Use %H0.
20769
20770 2012-04-30  Jason Merrill  <jason@redhat.com>
20771
20772         * dwarf2out.c (comdat_symbol_id): Add const.
20773         (union die_symbol_or_type_node): Add const to die_symbol.
20774         (output_die_symbol, output_die, output_comp_unit): Adjust.
20775
20776 2012-04-30  Andrew Stubbs  <ams@codesourcery.com>
20777
20778         * config/arm/arm.md (negdi2): Use gen_negdi2_neon.
20779         * config/arm/neon.md (negdi2_neon): New insn.
20780         Also add splitters for core and NEON registers.
20781
20782 2012-04-30  Andrew Stubbs  <ams@codesourcery.com>
20783
20784         * config/arm/arm.c (neon_valid_immediate): Allow const_int.
20785         (arm_print_operand): Add 'x' format.
20786         * config/arm/constraints.md (Dn): Allow const_int.
20787         * config/arm/neon.md (neon_mov<mode>): Use VDX to allow DImode.
20788         Use 'x' format to print constants.
20789         * config/arm/predicates.md (imm_for_neon_mov_operand): Allow const_int.
20790         * config/arm/vfp.md (movdi_vfp): Disable for const_int when neon
20791         is enabled.
20792         (movdi_vfp_cortexa8): Likewise.
20793
20794 2012-04-30  Ian Bolton  <ian.bolton@arm.com>
20795             Sameera Deshpande  <sameera.deshpande@arm.com>
20796             Greta Yorsh  <greta.yorsh@arm.com>
20797
20798         * config/arm/arm-protos.h (ldm_stm_operation_p): New declaration.
20799         * config/arm/arm.c (ldm_stm_operation_p): New function.
20800         * config/arm/predicates.md (load_multiple_operation): Update predicate.
20801         (store_multiple_operation): Likewise.
20802
20803         * config/arm/arm-protos.h (ldm_stm_operation_p): New parameters.
20804         * config/arm/arm.c (ldm_stm_operation_p): New parameters.
20805         * config/arm/predicates.md (load_multiple_operation): Add arguments.
20806         (store_multiple_operation): Likewise.
20807
20808 2012-04-30  Uros Bizjak  <ubizjak@gmail.com>
20809
20810         * config/i386/i386.md (and<mode>3): Expand masking operations with
20811         0xff, 0xffff or 0xffffffff immediates to corresponding zero_extend RTX.
20812         (and splitter): Split to DImode zero_extend RTX for DImode operand[0].
20813
20814 2012-04-30  Dodji Seketeli  <dodji@redhat.com>
20815
20816         Add -Wvarargs option
20817         * builtins.c (fold_builtin_next_arg):  Use OPT_Wvarargs as an
20818         argument for the various warning_at calls.
20819         * docs/invoke.texi: Update the documentation.
20820
20821 2012-04-30  Dodji Seketeli  <dodji@redhat.com>
20822
20823         Switch -ftrack-macro-expansion=2 on by default.
20824         * docs/cppopts.texi: Adjust for enabling -ftrack-macro-expansion=2
20825         by default.
20826
20827         Fix va_start related location
20828         * builtins.c (fold_builtin_next_arg): Unwinds to the first
20829         location in real source code.
20830
20831         Make conversion warnings work on NULL with -ftrack-macro-expansion
20832         * input.h (expansion_point_location_if_in_system_header): Declare
20833         new function.
20834         * input.c (expansion_point_location_if_in_system_header): Define it.
20835
20836         Fix -Wuninitialized for -ftrack-macro-expansion
20837         * tree-ssa.c (warn_uninit): Use the spelling location of the variable
20838         declaration.  Use linemap_location_before_p for source locations.
20839
20840         Strip "<built-in>" loc from displayed expansion context
20841         * input.c (expand_location_1): When expanding to spelling location
20842         in a context of a macro expansion, skip reserved system header
20843         locations.  Update comments.  * tree-diagnostic.c
20844         (maybe_unwind_expanded_macro_loc): Likewise.
20845
20846         Make expand_location resolve to locus in main source file
20847         * input.c (expand_location_1): New.  Takes a parameter to choose
20848         whether to resolve the location to spelling or expansion point.
20849         Was factorized from ...
20850         (expand_location): ... here.
20851         (expand_location_to_spelling_point): New.  Implemented in terms of
20852         expand_location_1.
20853         * diagnostic.c (diagnostic_build_prefix): Use the new
20854         expand_location_to_spelling_point instead of expand_location.
20855
20856         Fix PCH crash on GTYed pointer-to-scalar field of a struct
20857         * gengtype.c (write_types_process_field): Force second argument of
20858         the call to the PCH object hierarchy walker to be 'x'.
20859
20860 2012-04-30  Eric Botcazou  <ebotcazou@adacore.com>
20861
20862         * config/i386/i386.c (ix86_handle_struct_attribute): Use the proper
20863         predicate to discriminate types.
20864
20865 2012-04-30  Manuel López-Ibáñez  <manu@gcc.gnu.org>
20866
20867         * doc/invoke.texi (Wmissing-format-attribute): Document as an
20868         alias of Wsuggest-attribute=format.
20869         * c-typeck.c (convert_for_assignment): Replace
20870         Wmissing-format-attribute with Wsuggest-attribute=format.
20871         (digest_init): Likewise.
20872
20873 2012-04-29  Manuel López-Ibáñez  <manu@gcc.gnu.org>
20874
20875         * opts.c (finish_options): Do not handle -Wmissing-noreturn here.
20876         * common.opt (Wmissing-noreturn): Alias of
20877         -Wsuggest-attribute=noreturn.
20878
20879 2012-04-29  Hans-Peter Nilsson  <hp@axis.com>
20880
20881         PR target/53156
20882         * config/cris/cris.md (andqu): New peephole2.
20883         (andu): Tweak head comment.
20884
20885 2012-04-28  Joern Rennecke  <joern.rennecke@embecosm.com>
20886             Steven Bosscher  <steven@gcc.gnu.org>
20887             Maxim Kuvyrkov  <maxim@codesourcery.com>
20888
20889         PR tree-optimization/38785
20890         * common.opt (ftree-partial-pre): New option.
20891         * doc/invoke.texi: Document it.
20892         * opts.c (default_options_table): Initialize flag_tree_partial_pre.
20893         * tree-ssa-pre.c (do_partial_partial_insertion): Insert only if it will
20894         benefit speed path.
20895         (execute_pre): Use flag_tree_partial_pre.
20896
20897 2012-04-27  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
20898
20899         PR target/52999
20900         * config/pa/pa.c (pa_legitimate_constant_p): Don't put function labels
20901         in constant pool.
20902
20903 2012-04-27  Ollie Wild  <aaw@google.com>
20904
20905         * doc/invoke.texi (Wliteral-suffix): Document new option.
20906
20907 2012-04-27  Tom Tromey  <tromey@redhat.com>
20908
20909         * dwarf2out.c (dwarf_stack_op_name): Use get_DW_OP_name.
20910         (dwarf_tag_name): Use get_DW_TAG_name.
20911         (dwarf_attr_name): Use get_DW_AT_name.
20912         (dwarf_form_name): Use get_DW_FORM_name.
20913         * dwarf2cfi.c (dwarf_cfi_name): Use get_DW_CFA_name.
20914
20915 2012-04-27  Paolo Bonzini  <bonzini@gnu.org>
20916
20917         * tree-ssa-phiopt.c (conditional_replacement): Replace PHIs whose
20918         arguments are -1 and 0, by negating the result of the conditional.
20919
20920 2012-04-27  Paolo Bonzini  <bonzini@gnu.org>
20921
20922         PR target/53138
20923         * config/i386/i386.md (x86_mov<mode>cc_0_m1_neg): Add clobber.
20924
20925 2012-04-27  Richard Guenther  <rguenther@suse.de>
20926
20927         * tree-flow.h (is_hidden_global_store): Remove.
20928         * tree-ssa-sink.c (is_hidden_global_store): Likewise.
20929         * tree-ssa-alias.h (ref_may_alias_global_p): Declare.
20930         (stmt_may_clobber_global_p): Likewise.
20931         * tree-ssa-alias.c (ref_may_alias_global_p): New function.
20932         (stmt_may_clobber_global_p): Likewise.
20933         * tree-ssa-dce.c (mark_stmt_if_obviously_necessary): Call
20934         stmt_may_clobber_global_p.
20935         * tree-ssa-dse.c (dse_possible_dead_store_p): Likewise.
20936
20937 2012-04-27  Steven Bosscher  <steven@gcc.gnu.org>
20938
20939         * cfg.c (disconnect_src): Do df_mark_solutions_dirty in the right
20940         place.
20941
20942         * tree-switch-conversion.c (struct switch_conv_info): Add range_max,
20943         reorganize some fields and update comments.  Rename bit_test_uniq
20944         and bit_test_count to uniq resp. count.  Remove bit_test_bb.
20945         (collect_switch_conv_info): New function, collects info about a
20946         GIMPLE_SWITCH into a struct switch_conv_info.
20947         (check_range): Simplify to use pre-recorded info.  Fix think-o in
20948         range-branch ratio check.
20949         (check_process_case): Remove function.
20950         (check_all_empty_except_final): New function, verifies that all
20951         non-final basic blocks are empty.
20952         (process_switch): Simplify to use pre-recorded info.  Call
20953         collect_switch_conv_info to do that.  Assert that degenerate switch
20954         statements have been cleaned up.
20955
20956 2012-04-27  Marc Glisse  <marc.glisse@inria.fr>
20957
20958         PR middle-end/27139
20959         * tree-ssa-forwprop.c (combine_conversions): Handle INT->FP->INT.
20960
20961 2012-04-25  Manuel López-Ibáñez  <manu@gcc.gnu.org>
20962
20963         PR c/53130
20964         * c-typeck.c (pop_init_level): Use %qD instead of %qT.
20965
20966 2012-04-27  Tom de Vries  <tom@codesourcery.com>
20967
20968         PR tree-optimization/51879
20969         * tree-ssa-sccvn.h (struct vn_reference_s): Add result_vdef field.
20970         * tree-ssa-sccvn.c (mark_use_processed): New function, factored out
20971         of ...
20972         (defs_to_varying): ... here.  Don't set use_processed.
20973         (visit_reference_op_call): Handle gimple_vdef.
20974         Handle case that lhs is NULL_TREE.
20975         (visit_use): Use mark_use_processed.  Handle calls with side-effect
20976         using visit_reference_op_call.
20977
20978 2012-04-26  Richard Sandiford  <richard.sandiford@linaro.org>
20979
20980         * sched-deps.c (fixup_sched_groups): Rename to...
20981         (chain_to_prev_insn): ...this.
20982         (chain_to_prev_insn_p): New function.
20983         (deps_analyze_insn): Use it instead of SCHED_GROUP_P.
20984
20985 2012-04-26  Richard Sandiford  <richard.sandiford@linaro.org>
20986
20987         * sched-int.h (_haifa_insn_data): Move priority_status.
20988         Add model_index.
20989         (INSN_MODEL_INDEX): New macro.
20990         * haifa-sched.c (insn_delay): New function.
20991         (sched_regno_pressure_class): Update commentary.
20992         (mark_regno_birth_or_death): Pass the liveness bitmap and
20993         pressure array as arguments, instead of using curr_reg_live and
20994         curr_reg_pressure.  Only update the pressure if the bit in the
20995         liveness set has changed.
20996         (initiate_reg_pressure_info): Always trust the live-in set for
20997         SCHED_PRESSURE_MODEL.
20998         (initiate_bb_reg_pressure_info): Update call to
20999         mark_regno_birth_or_death.
21000         (dep_list_size): Take the list as argument.
21001         (calculate_reg_deaths): New function, extracted from...
21002         (setup_insn_reg_pressure_info): ...here.
21003         (MODEL_BAR): New macro.
21004         (model_pressure_data, model_insn_info, model_pressure_limit)
21005         (model_pressure_group): New structures.
21006         (model_schedule, model_worklist, model_insns, model_num_insns)
21007         (model_curr_point, model_before_pressure, model_next_priority):
21008         New variables.
21009         (MODEL_PRESSURE_DATA, MODEL_MAX_PRESSURE, MODEL_REF_PRESSURE)
21010         (MODEL_INSN_INFO, MODEL_INSN): New macros.
21011         (model_index, model_update_limit_points_in_group): New functions.
21012         (model_update_limit_points, model_last_use_except): Likewise.
21013         (model_start_update_pressure, model_update_pressure): Likewise.
21014         (model_recompute, model_spill_cost, model_excess_group_cost): Likewise.
21015         (model_excess_cost, model_dump_pressure_points): Likewise.
21016         (model_set_excess_costs): Likewise.
21017         (rank_for_schedule): Extend SCHED_PRIORITY_WEIGHTED ordering to
21018         SCHED_PRIORITY_MODEL.  Use insn_delay.  Use the order in the model
21019         schedule as an alternative tie-breaker.  Update the call to
21020         dep_list_size.
21021         (ready_sort): Call model_set_excess_costs.
21022         (update_register_pressure): Update call to mark_regno_birth_or_death.
21023         Rely on that function to check liveness rather than doing it here.
21024         (model_classify_pressure, model_order_p, model_add_to_worklist_at)
21025         (model_remove_from_worklist, model_add_to_worklist, model_promote_insn)
21026         (model_add_to_schedule, model_analyze_insns, model_init_pressure_group)
21027         (model_record_pressure, model_record_pressures): New functions.
21028         (model_record_final_pressures, model_add_successors_to_worklist)
21029         (model_promote_predecessors, model_choose_insn): Likewise.
21030         (model_reset_queue_indices, model_dump_pressure_summary): Likewise.
21031         (model_start_schedule, model_finalize_pressure_group): Likewise.
21032         (model_end_schedule): Likewise.
21033         (schedule_insn): Say when we're scheduling the next instruction
21034         in the model schedule.
21035         (schedule_insn): Handle SCHED_PRESSURE_MODEL.
21036         (queue_to_ready): Do not add instructions that are
21037         MAX_SCHED_READY_INSNS beyond the current point of the model schedule.
21038         Always allow the next instruction in the model schedule to be added.
21039         (debug_ready_list): Print the INSN_REG_PRESSURE_EXCESS_COST_CHANGE
21040         and delay for SCHED_PRESSURE_MODEL too.
21041         (prune_ready_list): Extend SCHED_PRIORITY_WEIGHTED handling to
21042         SCHED_PRIORITY_MODEL, but also take the DFA into account.
21043         (schedule_block): Call model_start_schedule and model_end_schedule.
21044         Extend SCHED_PRIORITY_WEIGHTED stall handling to SCHED_PRIORITY_MODEL.
21045         (sched_init): Extend INSN_REG_PRESSURE_EXCESS_COST_CHANGE handling
21046         to SCHED_PRESSURE_MODEL, but don't allocate saved_reg_live or
21047         region_ref_regs.
21048         (sched_finish): Update accordingly.
21049         (fix_tick_ready): Extend INSN_REG_PRESSURE_EXCESS_COST_CHANGE handling
21050         to SCHED_PRESSURE_MODEL.
21051         (add_jump_dependencies): Update call to dep_list_size.
21052         (haifa_finish_h_i_d): Fix leak of max_reg_pressure.
21053         (haifa_init_insn): Extend INSN_REG_PRESSURE_EXCESS_COST_CHANGE handling
21054         to SCHED_PRESSURE_MODEL.
21055         * sched-deps.c (init_insn_reg_pressure_info): Likewise, but don't
21056         allocate INSN_MAX_REG_PRESSURE for SCHED_PRESSURE_MODEL.
21057         (sched_analyze_insn): Extend INSN_REG_PRESSURE_EXCESS_COST_CHANGE
21058         handling to SCHED_PRESSURE_MODEL.
21059
21060 2012-04-26  Richard Sandiford  <richard.sandiford@linaro.org>
21061
21062         * common.opt (fsched-pressure-algorithm=): New option.
21063         * flag-types.h (sched_pressure_algorithm): New enum.
21064         * sched-int.h (sched_pressure_p): Replace with...
21065         (sched_pressure): ...this new variable.
21066         * haifa-sched.c (sched_pressure_p): Replace with...
21067         (sched_pressure): ...this new variable.
21068         (sched_regno_pressure_class, rank_for_schedule, ready_sort)
21069         (update_reg_and_insn_max_reg_pressure, schedule_insn)
21070         (debug_ready_list, prune_ready_list, schedule_block, sched_init)
21071         (sched_finish, fix_tick_ready, haifa_init_insn): Update accordingly.
21072         * sched-deps.c (init_insn_reg_pressure_info): Likewise.
21073         (sched_analyze_insn): Likewise.
21074         * sched-rgn.c (schedule_region): Likewise.
21075         * config/m68k/m68k.c (m68k_sched_variable_issue): Likewise.
21076
21077 2012-04-26  Bernd Schmidt  <bernds@codesourcery.com>
21078
21079         PR middle-end/52997
21080         * ira.c (find_moveable_pseudos): Call resize_reg_info.
21081
21082         PR middle-end/52940
21083         * machmode.h (CLASS_HAS_WIDER_MODES_P): True for MODE_PARTIAL_INT.
21084         * expr.c (convert_move): Honor unsignedp when extending partial int
21085         modes.
21086         * genmodes.c (complete_mode): Don't clear component field of partial
21087         int modes.
21088         (emit_mode_inner): Don't emit it however.
21089         (calc_wider_mode): Partial int modes widen to their component.
21090
21091 2012-04-26  David S. Miller  <davem@davemloft.net>
21092
21093         * config/sparc/niagara4.md: New file.
21094         * config/sparc/sparc.md: Include it.
21095         * config/sparc/sparc.c (niagara4_costs): New processor costs.
21096         (sparc_option_override): Use it.
21097         (sparc_use_sched_lookahead): Return 2 for niagara4.
21098         (sparc_issue_rate): Likewise.
21099
21100         * config/sparc/sparc.md (attr type): Delete 'fgm_cmp'.
21101         (fpack16_vis, fpackfix_vis, fpack32_vis): Set type to fgm_pack.
21102         (fmul8x16_vis, fmul8x16au_vis, fmul8x16al_vis, fmul8sux16_vis,
21103         fmul8ulx16_vis, fmuld8sux16_vis, fmuld8ulx16_vis): Set type to fgm_mul.
21104         (alignaddrsi_vis, alignaddrdi_vis, alignaddrlsi_vis,
21105         alignaddrldi_vis): Set type to gsr.
21106         (pdist_vis, pdistn<mode>_vis): Set type to fgm_pdsit.
21107         (fcmp<code><GCM:gcm_name><P:mode>_vis, cmask8<P:mode>_vis,
21108         cmask16<P:mode>_vis, cmask32<P:mode>_vis, fchksm16_vis,
21109         v<vis3_shift_patname><mode>3, fmean16_vis,
21110         fp<plusminus_insn>64_vis, <vis3_addsub_ss_patname><mode>3,
21111         fucmp<code>8<P:mode>_vis): Set type to fga.
21112         * config/sparc/ultra1_2.md: Remove refrences to fgm_cmp.
21113         * config/sparc/niagara.md: Likewise.
21114         * config/sparc/niagara2.md: Likewise.
21115         * config/sparc/ultra3.md: Likewise, and fix type matching for
21116         us3_ialuX reservation.
21117
21118 2012-04-26  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
21119
21120         * reload.c (find_reloads): Change the loop nesting when trying an
21121         alternative with swapped operands.
21122
21123 2012-04-26  Manuel López-Ibáñez  <manu@gcc.gnu.org>
21124
21125         * tree-diagnostic.c (maybe_unwind_expanded_macro_loc): Fix
21126         comment. Delete unused parameter first_exp_point_map.
21127         (virt_loc_aware_diagnostic_finalizer): Update call.
21128
21129 2012-04-26  Michael Hope  <michael.hope@linaro.org>
21130             Richard Earnshaw  <rearnsha@arm.com>
21131
21132         * config/arm/linux-eabi.h (GLIBC_DYNAMIC_LINKER_SOFT_FLOAT): Define.
21133         (GLIBC_DYNAMIC_LINKER_HARD_FLOAT): Define.
21134         (GLIBC_DYNAMIC_LINKER_DEFAULT): Define.
21135         (GLIBC_DYNAMIC_LINKER): Redefine to use the hard float path.
21136
21137 2012-04-25  Sriraman Tallam  <tmsriram@google.com>
21138
21139         * doc/extend.texi: Document avx2 support.
21140         * config/i386/i386.c (fold_builtin_cpu): Add avx2.
21141
21142 2012-04-26  Hans-Peter Nilsson  <hp@axis.com>
21143
21144         PR target/53120
21145         * config/cris/cris.md ("*andhi_lowpart_v32")
21146         ("*andqi_lowpart_v32"): Change first input-only operand from
21147         a (match_operand ...) to (match_dup 0).  Drop alternatives with
21148         const_int-matching constraints for redundancy.
21149         ("*andhi_lowpart_non_v32", "*andqi_lowpart_non_v32"): Ditto.  Drop
21150         three-operand alternative.
21151
21152 2012-04-25  Jakub Jelinek  <jakub@redhat.com>
21153
21154         PR target/53110
21155         * config/i386/i386.md (and<mode>3): For andq $0xffffffff, reg
21156         instead expand it as zero extension.
21157
21158 2012-04-25  H.J. Lu  <hongjiu.lu@intel.com>
21159
21160         PR debug/52857
21161         * dwarf2out.c (dbx_reg_number): Assert return value != INVALID_REGNUM.
21162
21163 2012-04-25  Jakub Jelinek  <jakub@redhat.com>
21164
21165         * common.opt (flag_debug_types_section): Default to 0.
21166         (dwarf_version): Default to 4.
21167         (dwarf_record_gcc_switches): Default to 1.
21168         (dwarf_strict): Default to 0.
21169         * toplev.c (process_options): Don't handle dwarf_strict
21170         or dwarf_version here.
21171         * config/vxworks.c (vxworks_override_options): Don't
21172         test whether dwarf_strict or dwarf_version are negative,
21173         instead test !global_options_set.x_dwarf_*.
21174         * config/darwin.c (darwin_override_options): Default to
21175         dwarf_version 2.
21176         * doc/invoke.texi: Note that -gdwarf-4, -grecord-gcc-switches
21177         and -fno-debug-types-section are now the default.
21178
21179 2012-04-25  Jan Hubicka  <jh@suse.cz>
21180
21181         * cgraphunit.c: Update toplevel comment.
21182         (tree_rest_of_compilation): Merge into cgraph_expand_function.
21183         (cgraph_analyze_function): Make static.
21184         (cgraph_decide_is_function_needed): Make static.
21185         (cgraph_add_new_function): Use expand_function instead of
21186         rest_of_compilation.
21187         (clone_of_p, verify_edge_count_and_frequency, cgraph_debug_gimple_stmt,
21188         verify_edge_corresponds_to_fndecl, verify_cgraph_node, verify_cgraph):
21189         Move to cgraph.c
21190         (cgraph_inline_p): Remove.
21191         (cgraph_preserve_function_body_p): Move to ipa-inline-transform.
21192         (init_cgraph): Add comment.
21193         * cgraphbuild.c (record_reference, mark_address, mark_load,
21194         mark_store): Do not call analyze_expr hook.
21195         * cgraph.c: Update toplevel comment.
21196         (clone_of_p, verify_edge_count_and_frequency, cgraph_debug_gimple_stmt,
21197         verify_edge_corresponds_to_fndecl, verify_cgraph_node, verify_cgraph):
21198         Move fere from cgraphunit.c
21199         (cgraph_mark_force_output_node): Move to cgraph.h
21200         * cgraph.h: Reorder so the comments match the function placement.
21201         (cgraph_analyze_function, cgraph_decide_is_function_needed): Remove.
21202         (cgraph_mark_force_output_node): Move here from cgraph.c
21203         * tree.c (free_lang_data): Do not clear analyze_expr hook.
21204         * ipa-inline-transform.c (preserve_function_body_p): New function.
21205         (inline_transform): Update.
21206         * langhooks.c (lhd_callgraph_analyze_expr): Remove.
21207         * langhooks.h (lang_hooks_for_callgraph): Remove.
21208         (lang_hooks): Remove callgraph.
21209         * tree-inline.c (expand_call_inline): Do not use cgraph_inline_p.
21210         * varpool.c: Remove out of date comment.
21211         * langhooks-def.h (lhd_callgraph_analyze_expr): Remove.
21212         (LANG_HOOKS_CALLGRAPH_ANALYZE_EXPR): Remove.
21213
21214 2012-04-25  Jan Hubicka  <jh@suse.cz>
21215
21216         PR middle-end/53089
21217         * cgraphunit.c (referred_to_p): Move ahead in file to avoid
21218         forward declaration.
21219         (cgraph_finalize_function): Finalize them here.
21220         * symtab.c (dump_symtab): Dump ctors and dtors.
21221
21222 2012-04-25  Jakub Jelinek  <jakub@redhat.com>
21223
21224         PR middle-end/52979
21225         * stor-layout.c (get_best_mode): Don't return mode with bitsize
21226         larger than maxbits.  Don't compute maxbits modulo align.
21227         Also check that unit bytes long store at bitpos / unit * unit
21228         doesn't affect bits beyond bitregion_end.
21229         * expmed.c (store_bit_field_1): Avoid trying insv if OP_MODE MEM
21230         would not fit into bitregion_start ... bitregion_end + 1 bit region.
21231         (store_split_bit_field): Decrease unit close to end of bitregion_end
21232         if access is restricted in order to avoid mutual recursion.
21233
21234         PR tree-optimization/53058
21235         * double-int.h (double_int_max_value, double_int_min_value): New
21236         prototypes.
21237         * double-int.c (double_int_max_value, double_int_min_value): New
21238         functions.
21239         * tree-vrp.c (register_edge_assert_for_2): Compare mask for LE_EXPR
21240         or GT_EXPR with double_int_max_value instead of double_int_mask.
21241
21242 2012-04-25  Richard Guenther  <rguenther@suse.de>
21243
21244         * tree-vectorizer.h (vect_loop_versioning): Adjust prototype.
21245         * tree-vect-loop.c (vect_transform_loop): Adjust.
21246         * tree-vect-loop-manip.c (vect_do_peeling_for_loop_bound): Record
21247         the maximum number of iterations for the epilogue loop.
21248         (vect_loop_versioning): Remove case re-using the peeled epilogue loop.
21249
21250 2012-04-25  Jakub Jelinek  <jakub@redhat.com>
21251
21252         PR c/52880
21253         * c-typeck.c (set_nonincremental_init,
21254         set_nonincremental_init_from_string): Pass true instead of false
21255         as IMPLICIT to add_pending_init.
21256
21257 2012-04-25  Manuel López-Ibáñez  <manu@gcc.gnu.org>
21258
21259         * c-typeck.c (pop_init_level): Improve diagnostics.
21260
21261 2012-04-25  Uros Bizjak  <ubizjak@gmail.com>
21262
21263         * compare-elim.c (try_eliminate_compare): Also handle operands with
21264         implicit extensions.
21265
21266 2012-04-25  Alan Modra  <amodra@gmail.com>
21267
21268         * config/rs6000/rs6000 (SAVE_INLINE_VRS, REST_INLINE_VRS,
21269         V_SAVE_INLINE, SAVRES_LR, SAVRES_SAVE, SAVRES_REG,
21270         SAVRES_GPR, SAVRES_FPR, SAVRES_VR): Define.
21271         (no_global_regs_above): Delete.
21272         (no_global_regs): New function.
21273         (rs6000_savres_strategy): Handle vector regs.  Use proper lr_save_p
21274         value for load multiple test.
21275         (savres_routine_syms): Increase size.
21276         (rs6000_savres_routine_name, rs6000_savres_routine_sym,
21277         ptr_regno_for_savres, rs6000_emit_savres_rtx): Pass in int selector
21278         rather than a number of boolean flags.  Update all callers.
21279         (rs6000_savres_routine_name): Generate vector save/restore names.
21280         (rs6000_savres_routine_sym): Handle vector regs.  Delete forward decl.
21281         (ptr_regno_for_savres, rs6000_emit_savres_rtx): Likewise.
21282         (rs6000_emit_prologue): Delete saving_FPRs_inline, saving_GPRs_inline
21283         and using_store_multiple.  Expand uses.  Don't always use r11 as
21284         frame reg when needed for out-of-line saves.  Set up initial offset
21285         for out-of-line vector saves when buying stack frame.  Handle pointer
21286         reg setup for out-of-line fp save.  Emit call to out-of-line vector
21287         save function.  Choose r11 or r12 for vrsave reg when available for
21288         better scheduling.
21289         (rs6000_output_function_prologue): Don't emit .extern for ELF.
21290         (rs6000_emit_epilogue): Choose a better frame reg when restoring
21291         from back-chain to suit out-of-line vector restore functions.  Emit
21292         call to out-of-line vector restore function.  Adjust register used
21293         for cr restore.  Tweak pointer register setup for gpr restore.
21294         * config/rs6000/rs6000.h (FIRST_SAVED_GP_REGNO): Take into account
21295         FIXED_R13.
21296         * config/rs6000/sysv4.h (FP_SAVE_INLINE, GP_SAVE_INLINE): Simplify.
21297         (V_SAVE_INLINE): Define.
21298         * config/rs6000/altivec.md (save_vregs_*, restore_vregs_*): New insns.
21299
21300 2012-04-25  Alan Modra  <amodra@gmail.com>
21301
21302         * config/rs6000/rs6000.c (rs6000_savres_strategy): Allow
21303         out-of-line save/restore for large frames.  Don't disable
21304         out-of-line saves on ABI_AIX when using static chain reg.
21305         (rs6000_emit_prologue): Adjust cr_save_regno on ABI_AIX to not
21306         clobber static chain reg, and tweak for out-of-line gpr saves
21307         that use r1.
21308
21309 2012-04-25  Alan Modra  <amodra@gmail.com>
21310
21311         * config/rs6000/rs6000.c (START_USE, END_USE, NOT_INUSE): Define.
21312         (rs6000_emit_prologue): Use the above to catch register overlap.
21313
21314 2012-04-25  Alan Modra  <amodra@gmail.com>
21315
21316         * config/rs6000/rs6000.c (rs6000_emit_stack_reset): Delete forward
21317         decl.  Move logic selecting update reg to callers.  Update all callers.
21318         (rs6000_emit_allocate_stack): Add copy_off param.
21319         (emit_frame_save): Don't handle reg+reg addressing.
21320         (ptr_regno_for_savres): New function, extracted from..
21321         (rs6000_emit_savres_rtx): ..here.  Add lr_offset param.
21322         (rs6000_emit_prologue): Generate frame_ptr_rtx as we need it.
21323         Set frame_reg_rtx to r11 whenever r11 is needed, and merge
21324         frame offset adjustment for out-of-line save with copy from sp.
21325         Simplify condition controlling whether cr is saved early or
21326         late.  Use ptr_regno_for_savres to verify correct reg is set
21327         up for out-of-line saves.  Pass the actual pointer reg used to
21328         rs6000_emit_savres_rtx so rtl matches insns in out-of-line
21329         function.  Rearrange spe vars so code is similar to that
21330         elsewhere in this function.  Don't update frame_off when spe
21331         save code will restore r11.  Use emit_frame_save for spe and
21332         gpr saves.  Consolidate darwin out-of-line gpr setup with that
21333         for other abis.  Don't assume frame_offset is zero and frame
21334         reg is sp when setting up altivec reg saves, and calculate
21335         exact offset requirement.
21336         (rs6000_emit_epilogue): Use HOST_WIDE_INT for frame_off.  Tidy
21337         spe restore code.  Consolidate darwin out-of-line gpr setup
21338         with that for other abis.
21339
21340 2012-04-25  Alan Modra  <amodra@gmail.com>
21341
21342         * config/rs6000/rs6000.c (rs6000_frame_related): Don't emit a
21343         REG_FRAME_RELATED_EXPR note when the instruction exactly matches
21344         the replacement.
21345         (emit_frame_save): Delete frame_ptr param.  Rename total_size to
21346         frame_reg_to_sp.
21347         (rs6000_emit_prologue): Add sp_off.  Update rs6000_frame_related
21348         and emit_frame_save calls.  Cope with possibly missing note.
21349
21350 2012-04-24  Sriraman Tallam  <tmsriram@google.com>
21351
21352         * config/i386/i386.c (build_processor_model_struct): New function.
21353         (make_var_decl): New function.
21354         (fold_builtin_cpu): New function.
21355         (ix86_fold_builtin): New function.
21356         (make_cpu_type_builtin): New function.
21357         (ix86_init_platform_type_builtins): New function.
21358         (ix86_expand_builtin): Expand new builtins by folding them.
21359         (ix86_init_builtins): Make new builtins to detect CPU type.
21360         (TARGET_FOLD_BUILTIN): New macro.
21361         (IX86_BUILTIN_CPU_INIT): New enum value.
21362         (IX86_BUILTIN_CPU_IS): New enum value.
21363         (IX86_BUILTIN_CPU_SUPPORTS): New enum value.
21364         * config/i386/i386-builtin-types.def: New function type.
21365         * doc/extend.texi: Document builtins.
21366
21367 2012-04-24  Olivier Hainque  <hainque@adacore.com>
21368
21369         * common.opt (gdwarf-): Initialize dwarf_version to -1 instead of 2.
21370         * toplev.c (process_options): Default to dwarf_version 2.
21371         * config/vxworks.c (vxworks_override_options): Default to strict-dwarf
21372         and dwarf_version 2.
21373
21374 2012-04-24  Manuel López-Ibáñez  <manu@gcc.gnu.org>
21375
21376         * tree-pretty-print.h (default_tree_printer): Do not declare.
21377         * tree-diagnostic.c: Include tree-pretty-print.h, tree-pass.h and
21378         intl.h.
21379         (default_tree_diagnostic_starter): Make static.
21380         (default_tree_printer): Move to here. Make static.
21381         (tree_diagnostics_defaults): New.
21382         * tree-diagnostic.h (default_tree_diagnostic_starter): Do not declare.
21383         * tree.c (free_lang_data): Use tree_diagnostics_defaults.
21384         * toplev.c: Do not include tree-pass.h.
21385         (default_tree_printer): Move from here.
21386         (general_init): Use tree_diagnostics_defaults.
21387
21388 2012-04-24  Chao-ying Fu  <fu@mips.com>
21389
21390         * config.gcc (mips64*-*-linux*): Append mips/linux-common.h to tm_file.
21391         (mips*-*-linux*): Append mips/linux-common.h to tm_file.
21392         * config/mips/gnu-user.h
21393         (SUBTARGET_CC1_SPEC): Use GNU_USER_TARGET_CC1_SPEC directly.
21394         (GNU_USER_TARGET_LINK_SPEC): New define.
21395         (LINK_SPEC): Use GNU_USER_TARGET_LINK_SPEC.
21396         (LIB_SPEC): Use GNU_USER_TARGET_LIB_SPEC directly.
21397         (GNU_USER_TARGET_MATHFILE_SPEC): New define.
21398         (ENDFILE_SPEC): Use GNU_USER_TARGET_MATHFILE_SPEC and
21399         GNU_USER_TARGET_ENDFILE_SPEC.
21400         * config/mips/gnu-user64.h (LIB_SPEC): Remove.
21401         (GNU_USER_TARGET_LINK_SPEC): New define.
21402         (LINK_SPEC): Use GNU_USER_TARGET_LINK_SPEC.
21403         * config/mips/linux-common.h: New file.
21404
21405 2012-04-24  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
21406
21407         PR target/47197
21408         * config/rs6000/rs6000-c.c (fully_fold_convert): New function.
21409         (altivec_build_resolved_builtin): Call fully_fold_convert.
21410
21411 2012-04-24  Georg-Johann Lay  <avr@gjlay.de>
21412
21413         PR target/53065
21414         * config/avr/avr.h (HARD_REGNO_CALL_PART_CLOBBERED): New hook define.
21415
21416 2012-04-24  Richard Guenther  <rguenther@suse.de>
21417
21418         PR tree-optimization/53085
21419         * tree-ssa-pre.c (eliminate): Do not eliminate volatile redundant
21420         stores.
21421
21422 2012-04-24  Richard Guenther  <rguenther@suse.de>
21423
21424         * tree-if-conv.c (main_tree_if_conversion): Move bb under
21425         ENABLE_CHECKING.
21426
21427 2012-04-24  Jim Meyering  <meyering@redhat.com>
21428
21429         * genattrtab.c (gen_attr): Avoid NULL-deref after diagnosing
21430         absence of an define_enum call.
21431
21432 2012-04-24  Richard Guenther  <rguenther@suse.de>
21433
21434         * tree-vect-loop-manip.c (vect_do_peeling_for_loop_bound): If
21435         the epilogue loop is not re-used as unvectorized version
21436         record the its maximum number of iterations.
21437
21438 2012-04-24  Andrew Pinski  <apinski@cavium.com>
21439
21440         * tree-ssa-forwprop.c (simplify_bitwise_binary):
21441         Don't directly use def1/def2.
21442
21443 2012-04-24  Richard Guenther  <rguenther@suse.de>
21444
21445         PR tree-optimization/53098
21446         * tree-vect-loop.c (vect_analyze_loop_operations): Fixup
21447         comparison sign.
21448
21449 2012-04-24  Andrew Pinski  <apinski@cavium.com>
21450
21451         PR tree-opt/33512
21452         * tree-ssa-forwprop.c (defcodefor_name): New function.
21453         (simplify_bitwise_binary): Use defcodefor_name instead of manually
21454         Simplify "( X | Y) & X" to X and "( X & Y) | X" to X.
21455         Simplify "(~X | Y) & X" to "X & Y" and
21456         "(~X & Y) | X" to "X | Y".
21457
21458 2012-04-24  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
21459
21460         * recog.c (insn_invalid_p): Add IN_GROUP parameter and use
21461         validate_change to add clobbers if IN_GROUP is nonzero.
21462         (verify_changes): Call insn_invalid_p with IN_GROUP set to true.
21463         * recog.h (insn_invalid_p): Add IN_GROUP parameter to function
21464         prototype.
21465         * gcse.c (process_insert_insn): Call insn_invalid_p with IN_GROUP
21466         set to false.
21467         * config/s390/s390.c (insn_invalid_p): Likewise.
21468
21469 2012-04-24  Jakub Jelinek  <jakub@redhat.com>
21470
21471         PR middle-end/53084
21472         * varasm.c (compute_reloc_for_constant): Handle ADDR_EXPR of MEM_REF.
21473         (output_addressed_constants): Likewise.
21474
21475         PR middle-end/52999
21476         * varasm.c (get_section): Don't ICE for section conflicts with
21477         built-in section kinds.
21478
21479 2012-04-23  DJ Delorie  <dj@redhat.com>
21480
21481         * config/s390/s390.h (LINK_SPEC): Remove, no longer needed.
21482         (LIBSTDCXX): Change to CPP2.
21483
21484 2012-04-23  H.J. Lu  <hongjiu.lu@intel.com>
21485
21486         PR bootstrap/52878
21487         * opth-gen.awk: Check if MASK_ and TARGET_ macros are defined for
21488         extra_masks.
21489
21490 2012-04-23  Uros Bizjak  <ubizjak@gmail.com>
21491
21492         * config/i386/i386.md (*add<mode>_2): Add r/r/0 alternative.
21493         (*addsi_2_zext): Ditto.
21494         (*add<mode>_3): Ditto.
21495         (*addsi_3_zext): Ditto.
21496         (*add<mode>_5): Ditto.
21497
21498 2012-04-23  Andrew Pinski  <apinski@cavium.com>
21499
21500         * tree-ssa-forwprop.c (simplify_bitwise_binary): Simplify (A & B) OP0
21501         (C & B) to (A OP0) & B.
21502
21503 2012-04-23  Martin Jambor  <mjambor@suse.cz>
21504
21505         * expr.c (expand_expr_real_1): Remove setting parent's alias set for
21506         temporaries created for a bitfield (reverting revision 122014).
21507
21508 2012-04-23  Richard Guenther  <rguenther@suse.de>
21509
21510         * tree-vect-loop-manip.c (slpeel_add_loop_guard): Gimplify
21511         the condition using is_gimple_condexpr and avoid the not necessary
21512         boolification.
21513         (set_prologue_iterations): Likewise.
21514         (vect_loop_versioning): Likewise.
21515
21516 2012-04-23  Richard Guenther  <rguenther@suse.de>
21517
21518         PR tree-optimization/53070
21519         * tree-if-conv.c (combine_blocks): Free predicates in all blocks.
21520         (main_tree_if_conversion): Verify we succeeded in that.
21521
21522 2012-04-23  Jan Hubicka  <jh@suse.cz>
21523
21524         * lto-symtab.c (lto_cgraph_replace_node): Do not call
21525         mark_reahcable_node.
21526         * cgraph.c (cgraph_remove_node): Do not clear reachable.
21527         (cgraph_mark_reachable_node): Remove.
21528         (cgraph_mark_force_output_node): Do not set reachable.
21529         (dump_cgraph_node): Do not dump reachable.
21530         (cgraph_create_virtual_clone): Do not set reachable.
21531         * cgraph.h (cgraph_node): Remove reachable flag.
21532         (varpool_node): Remove reachable flag.
21533         (cgraph_mark_if_needed): Remove.
21534         (cgraph_mark_reachable_node): Remove.
21535         * tree-emutls.c (ipa_lower_emutls): Do not check reachable.
21536         * cgraphunit.c (cgraph_finalize_function): Do not mark node as
21537         reachable.
21538         (cgraph_add_new_function): Likewise.
21539         (cgraph_mark_if_needed): Remove.
21540         (cgraph_analyze_function): Do not set target as reachable.
21541         (process_function_and_variable_attributes): Do not care about
21542         dllexport.
21543         (cgraph_analyze_functions): Do not set reachable flags.
21544         (cgraph_mark_functions_to_output): Do not check reachability.
21545         (cgraph_copy_node_for_versioning): Do not set reachable flag.
21546         (dbxout_expand_expr): Update.
21547         * c-decl.c (merge_decls): Do not track changed externs.
21548         * ipa.c: Include pointer-set.h
21549         (enqueue_cgraph_node): Use reachable pointer set.
21550         (process_references): Likewise.
21551         (cgraph_remove_unreachable_nodes): Likewise.
21552         (whole_program_function_and_variable_visibility): Do not recompute
21553         reachable.
21554         * trans-mem.c (ipa_tm_execute): Do not check reachable flag.
21555
21556 2012-04-23  Georg-Johann Lay  <avr@gjlay.de>
21557
21558         * doc/extend.texi (AVR Named Address Spaces): Fix typos.
21559
21560 2012-04-23  Richard Guenther  <rguenther@suse.de>
21561
21562         PR c/53060
21563         * c-typeck.c (build_binary_op): Fix typo.
21564
21565 2012-04-23  Jakub Jelinek  <jakub@redhat.com>
21566
21567         PR tree-optimizations/52891
21568         * tree-vect-patterns.c (adjust_bool_pattern): Use
21569         build_nonstandard_type even if rhs1 has unsigned INTEGER_TYPE,
21570         but with non-standard precision.
21571
21572 2012-04-22  Jan Hubicka  <jh@suse.cz>
21573
21574         * tree-ssa-loop-ivopts.c (expr_invariant_in_loop_p): Bail out at NULL
21575         tree refs.
21576
21577 2012-04-22  Jan Hubicka  <jh@suse.cz>
21578
21579         * lto-symtab.c (lto_varpool_replace_node): Do not merge needed flags.
21580         * cgraphbuild.c (record_reference, record_type_list, mark_address,
21581         mark_load, mark_store): Do not mark varpool nodes as needed.
21582         * cgraph.c (cgraph_new_nodes): Remove.
21583         (cgraph_create_function_alias): Do not mark nodes as reachable.
21584         (cgraph_add_thunk): Likewise.
21585         (cgraph_mark_reachable_node): Do not manage the queue.
21586         * cgraph.h (cgraph_node): Remove next_needed.
21587         (varpool_nodes_queue): Remove next_needed and prev_needed.
21588         (x_cgraph_nodes_queue, x_cgraph_nodes_queue, cgraph_new_nodes): Remove.
21589         (cgraph_new_nodes): Declare.
21590         (x_varpool_nodes_queue, varpool_nodes_queue); Remove.
21591         (varpool_analyze_pending_decls): Remove.
21592         (varpool_analyze_node): New.
21593         (varpool_mark_needed_node): Remove.
21594         (varpool_first_variable, varpool_next_variable): New inlines.
21595         (varpool_first_static_initializer, varpool_next_static_initializer):
21596         Update.
21597         (FOR_EACH_STATIC_VARIABLE): Remove unused walker.
21598         (varpool_first_defined_variable): New inline.
21599         (varpool_next_defined_variable): New inline
21600         (FOR_EACH_VARIABLE): Reimplement.
21601         (FOR_EACH_DEFINED_VARIABLE): Reimplement.
21602         * toplev.c (wrapup_global_declaration_2): Use analyzed instead of
21603         needed flag.
21604         * cgraphunit.c (cgraph_new_nodes): Declare here.
21605         (enqueue_node): New function.
21606         (cgraph_process_new_functions): update for new
21607         node set; when constructing cgraph enqueue node for processing.
21608         (cgraph_add_new_function): Use new node set.
21609         (process_function_and_variable_attributes): Do not set varpool needed
21610         flags.
21611         (referred_to_p): New function.
21612         (varpool_finalize_decl): Move here from varpool.c; enqueue needed node
21613         when varpool is in construction.
21614         (cgraph_analyze_functions): Rewrite.
21615         (cgraph_expand_all_functions): Update.
21616         (cgraph_output_in_order): Do not analyze pending decls; do not set
21617         needed flags.
21618         (cgraph_optimize): Do not analyze pending decls.
21619         * lto-cgraph.c (input_varpool_node): Clear analyzed flag for objects
21620         in other partition; do not mark node as needed.
21621         * dwarf2out.c (reference_to_unused): Use analyzed flag.
21622         (premark_types_used_by_global_vars_helper): Likewise.
21623         * ipa.c (process_references): Do not call varpool_mark_needed_node.
21624         (cgraph_remove_unreachable_nodes): Do not rely on varpool and
21625         cgrpah queues.
21626         (function_and_variable_visibility): Do not mark node as needed.
21627         (whole_program_function_and_variable_visibility): Likewise.
21628         * Makefile.in (gt-varpool.h): No longer needed.
21629         * passes.c (execute_one_pass, execute_ipa_pass_list): Update.
21630         (ipa_write_summaries): Do not use needed flag.
21631         * varpool.c: Do not include gt-varpool.h
21632         (x_varpool_nodes_queue, x_varpool_last_needed_node,
21633         x_varpool_last_needed_node, x_varpool_first_unanalyzed_node,
21634         x_varpool_first_unanalyzed_node, varpool_assembled_nodes_queue):
21635         Remove.
21636         (varpool_remove_node): Do not update the lists.
21637         (dump_varpool_node): Do not dump needed flag.
21638         (varpool_enqueue_needed_node): Remove.
21639         (varpool_mark_needed_node): Remove.
21640         (varpool_reset_queue): Remove.
21641         (varpool_finalize_decl): Move to cgraphunit.c
21642         (varpool_analyze_node): New functions based on former
21643         varpool_analyze_pending_decls.
21644         (varpool_analyze_pending_decls): Remove.
21645         (varpool_assemble_decl): Do not update the lists.
21646         (enqueue_node): New function.
21647         (varpool_remove_unreferenced_decls): Rewrite.
21648         (varpool_empty_needed_queue): Remove.
21649         (add_new_static_var): Do not mark node as needed.
21650         (varpool_create_variable_alias): Handle expansion state
21651         creation.
21652         * except.c (output_ttype): Do not mark node as needed.
21653         * varasm.c (mark_decl_referenced): Do not use mark_needed_node.
21654         * tree-profile.c (init_ic_make_global_vars, init_ic_make_global_vars):
21655         Likewise.
21656         * tree-switch-conversion.c (build_one_array): Likewise.
21657
21658 2012-04-22  Manuel López-Ibáñez  <manu@gcc.gnu.org>
21659
21660         PR c/44774
21661         * doc/invoke.texi (pedantic): Rename to Wpedantic.
21662         * common.opt (Wpedantic): New.
21663         (pedantic): Alias Wpedantic.
21664         * diagnostic.c (warning_at): Likewise.
21665         * c-decl.c (diagnose_mismatched_decls): Likewise.
21666         (build_array_declarator): Likewise.
21667         (mark_forward_parm_decls):
21668         (check_bitfield_type_and_width): Likewise.
21669         (grokdeclarator): Likewise.
21670         (grokfield): Likewise.
21671         (finish_struct): Likewise.
21672         (build_enumerator): Likewise.
21673         (store_parm_decls_oldstyle): Likewise.
21674         (declspecs_add_qual): Likewise.
21675         (declspecs_add_type): Likewise.
21676         (finish_declspecs): Likewise.
21677         * c-typeck.c (composite_type): Likewise.
21678         (comp_target_types): Likewise.
21679         (build_array_ref): Likewise.
21680         (pointer_diff): Likewise.
21681         (build_unary_op): Likewise.
21682         (build_conditional_expr): Likewise.
21683         (build_c_cast): Likewise.
21684         (convert_for_assignment): Likewise.
21685         (maybe_warn_string_init): Likewise.
21686         (digest_init): Likewise.
21687         (pop_init_level): Likewise.
21688         (set_init_index): Likewise.
21689         (c_finish_goto_label): Likewise.
21690         (c_finish_return): Likewise.
21691         (do_case): Likewise.
21692         (build_binary_op): Likewise.
21693         * c-parser.c (static): Likewise.
21694         (c_parser_external_declaration): Likewise.
21695         (c_parser_declaration_or_fndef): Likewise.
21696         (c_parser_static_assert_declaration_no_se): Likewise.
21697         (c_parser_enum_specifier): Likewise.
21698         (c_parser_struct_or_union_specifier): Likewise.
21699         (c_parser_struct_declaration): Likewise.
21700         (c_parser_alignas_specifier): Likewise.
21701         (c_parser_braced_init): Likewise.
21702         (c_parser_initelt): Likewise.
21703         (c_parser_compound_statement_nostart): Likewise.
21704         (c_parser_conditional_expression): Likewise.
21705         (c_parser_alignof_expression): Likewise.
21706         (c_parser_postfix_expression): Likewise.
21707         (c_parser_postfix_expression_after_paren_): Likewise.
21708         (c_parser_objc_class_instance_variables): Likewise.
21709         (c_parser_objc_method_definition): Likewise.
21710         (c_parser_objc_methodprotolist): Likewise.
21711
21712 2012-04-22  Ian Lance Taylor  <iant@google.com>
21713
21714         * godump.c (go_output_typedef): Dump size of structs.
21715
21716 2012-04-22  Razya Ladelsky  <razya@il.ibm.com>
21717
21718         Correcting transform_to_exit_first_loop + fix to PR46886
21719         * tree-parloops.c (transform_to_exit_first_loop): Remove
21720         setting of number of iterations according to the loop pattern.
21721         Duplicate from entry to exit->src instead of loop->latch.
21722         (pallelize_loops): Remove the condition preventing do-while loops.
21723         * tree-cfg.c (bool bb_in_region_p): New.
21724         (gimple_duplicate_sese_tail): Adjust duplication of the the subloops.
21725         Adjust redirection of the duplicated iteration.
21726
21727 2012-04-21  Richard Sandiford  <rdsandiford@googlemail.com>
21728
21729         PR bootstrap/53021
21730         * rtl.def (ADDRESS): Use "i" rather than "w".
21731         * rtl.h (find_base_term): Delete.
21732         (may_be_sp_based_p): Declare.
21733         * rtl.c (rtx_code_size): Remove ADDRESS special case.
21734         * alias.h (UNIQUE_BASE_VALUE_SP, UNIQUE_BASE_VALUE_ARGP)
21735         (UNIQUE_BASE_VALUE_FP, UNIQUE_BASE_VALUE_HFP): Move to...
21736         * alias.c: ...here.
21737         (find_base_term): Make static.
21738         (may_be_sp_based_p): New function.
21739         * dse.c (record_store): Use it.
21740         * store-motion.c (store_killed_in_insn): Likewise.
21741
21742 2012-04-21  Richard Sandiford  <rdsandiford@googlemail.com>
21743
21744         * fold-const.c (fold_checksum_tree): Fix VECTOR_CST case.
21745
21746 2012-04-21  Manuel López-Ibáñez  <manu@gcc.gnu.org>
21747
21748         PR 35441
21749         * c-typeck.c (inform_declaration): New.
21750         (build_function_call_vec):  Do not pretty-print
21751         expressions when caret is enabled.
21752         (convert_arguments): Use inform_declaration.
21753
21754 2012-04-20  Jim Meyering  <meyering@redhat.com>
21755
21756         * genmodes.c (make_complex_modes): Don't truncate a mode name of
21757         length 7 or more when prepending a "C".  Suggested by Richard Guenther.
21758
21759 2012-04-20  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
21760
21761         PR rtl-optimization/44214
21762         * fold-const.c (exact_inverse): New function.
21763         (fold_binary_loc): Fold vector and complex division by constant into
21764         multiply by recripocal with flag_reciprocal_math; fold vector division
21765         by constant into multiply by reciprocal with exact inverse.
21766
21767 2012-04-20  Jan Hubicka  <jh@suse.cz>
21768
21769         * lto-symtab.c (lto_cgraph_replace_node): Merge needed instead of
21770         force flags.
21771         * cgraph.c (cgraph_add_thunk): Use mark_reachable_node.
21772         (cgraph_remove_node): Update.
21773         (cgraph_mark_needed_node): Remove.
21774         (cgraph_mark_force_output_node): New.
21775         (dump_cgraph_node): Do not dump needed flag.
21776         (cgraph_node_cannot_be_local_p_1): Update.
21777         (cgraph_can_remove_if_no_direct_calls_and_refs): Update.
21778         * cgraph.h (symtab_node_base): Add force_output flag.
21779         (cgraph_node): Remove needed flag.
21780         (varpool_node): Remove force_output flag.
21781         (cgraph_mark_needed_node): Remove.
21782         (cgraph_mark_force_output_node): New.
21783         (cgraph_only_called_directly_or_aliased_p,
21784         varpool_can_remove_if_no_refs, varpool_all_refs_explicit_p): Update.
21785         * ipa-cp.c (ipcp_generate_summary): Remove out of date assert.
21786         * cgraphunit.c (cgraph_decide_is_function_needed): rewrite.
21787         (cgraph_add_new_function): Update.
21788         (cgraph_mark_if_needed): Update.
21789         (verify_cgraph_node): Update.
21790         (cgraph_analyze_function): Alias target is reachable.
21791         (process_function_and_variable_attributes): Update: externally_visible
21792         flag makes function reachable.
21793         (cgraph_analyze_functions): Update dumping.
21794         * lto-cgraph.c (lto_output_node, lto_output_varpool_node,
21795         input_overwrite_node, input_varpool_node): Update streaming.
21796         * lto-streamer-out.c (produce_symtab): Use force_output.
21797         * ipa.c (process_references): Weakrefs must be processed.
21798         (cgraph_remove_unreachable_nodes): Likewise; update for new
21799         force_output flag.
21800         (varpool_externally_visible_p): Weakrefs are externally visible
21801         even if they are not.
21802         (function_and_variable_visibility): Update; when processing alias
21803         pair force the targets to be output.
21804         (whole_program_function_and_variable_visility): Use
21805         mark_reachable_node.
21806         * trans-mem.c (ipa_tm_mark_needed_node): Remove
21807         (ipa_tm_mark_force_output_node): New function.
21808         (ipa_tm_create_version_alias, ipa_tm_create_version): Update.
21809         * gimple-fold.c (can_refer_decl_in_current_unit_p): Be lax about
21810         aliases.
21811         * varasm.c (mark_decl_referenced): Update.
21812         (find_decl_and_mark_needed): Remove.
21813         (find_decl): New function.
21814         (weak_finish, finish_aliases_1, assemble_alias): Update; do not mark
21815         alias targets as needed.
21816         (dump_tm_clone_pairs): Update.
21817         * tree-inline.c (copy_bb): Update check.
21818         * symtab.c (dump_symtab_base): Dump force_output.
21819         * tree-ssa-structalias.c (ipa_pta_execute): Use force_output.
21820         * passes.c (execute_todo): Fix dumping.
21821         * varpool.c (decide_is_variable_needed, varpool_finalize_decl): Update.
21822         (varpool_analyze_pending_decls): Alias target is reachable.
21823         (varpool_create_variable_alias): Finalize weakrefs.
21824
21825 2012-04-20  Jakub Jelinek  <jakub@redhat.com>
21826
21827         PR bootstrap/53021
21828         * alias.h (UNIQUE_BASE_VALUE_SP, UNIQUE_BASE_VALUE_ARGP,
21829         UNIQUE_BASE_VALUE_FP, UNIQUE_BASE_VALUE_HFP): Define.
21830         * alias.c (init_alias_targets): Use UNIQUE_BASE_VALUE_*
21831         macros instead of constants.
21832         * dse.c (record_store): Check for SP ADDRESS by comparing
21833         XWINT to UNIQUE_BASE_VALUE_SP instead of expecting
21834         XEXP to be stack_pointer_rtx.
21835
21836 2012-04-20  Richard Guenther  <rguenther@suse.de>
21837
21838         * tree-ssa-copy.c (propagate_tree_value_into_stmt): Use
21839         update_call_from_tree when propagating into a call.
21840
21841 2012-04-20  Alan Modra  <amodra@gmail.com>
21842
21843         * config/rs6000/rs6000.c (rs6000_emit_savres_rtx): Formatting.
21844         (rs6000_emit_prologue, rs6000_emit_epilogue): Likewise.  Rename
21845         sp_offset to frame_off.  Move world save code earlier.
21846
21847 2012-04-20  Richard Guenther  <rguenther@suse.de>
21848
21849         PR tree-optimization/53050
21850         * tree-ssa-forwprop.c (ssa_forward_propagate_and_combine):
21851         Do only one transform on COND_EXPRs at the same time.
21852
21853 2012-04-19  Jan Hubicka  <jh@suse.cz>
21854
21855         * symtab.c (dump_symtab_base): Revert accidental checkin.
21856
21857 2012-04-20  Alan Modra  <amodra@gmail.com>
21858
21859         PR target/53040
21860         * config/rs6000/rs6000.c (rs6000_savres_strategy): When using
21861         static chain, set REST_INLINE_FPRS too.
21862
21863 2012-04-20  Thomas Schwinge  <thomas@codesourcery.com>
21864
21865         * tree-dump.c (dequeue_and_dump) <BIT_FIELD_REF>: Dump the three child
21866         nodes.
21867
21868 2012-04-20  Richard Guenther  <rguenther@suse.de>
21869
21870         * tree-vect-loop.c (vect_analyze_loop_operations): Do not vectorize
21871         loops that can never run more often than the vectorization factor.
21872
21873 2012-04-19  Jan Hubicka  <jh@suse.cz>
21874
21875         * symtab.c (dump_symtab_base): Fix dumping of asm lists.
21876
21877 2012-04-19  David Edelsohn  <dje.gcc@gmail.com>
21878
21879         * config/rs6000/sync.md (fetchop_name): Change ior attribute to "or".
21880
21881 2012-04-19  Jim Meyering  <meyering@redhat.com>
21882
21883         * genmodes.c (make_complex_modes): Avoid unnecessary use of strncpy.
21884         We verified above that the string(including trailing NUL) fits in buf,
21885         so just use memcpy.
21886
21887 2012-04-19  Richard Guenther  <rguenther@suse.de>
21888
21889         * symtab.c (dump_symtab_base): Use TREE_STRING_POINTER
21890         for dumping DECL_SECTION_NAME.
21891
21892 2012-04-19  Michael Matz  <matz@suse.de>
21893
21894         PR middle-end/52977
21895         * tree.h (VECTOR_CST_NELTS): Use part number of types again.
21896         (struct tree_vector): Adjust GTY length.
21897         * tree.c (make_vector_stat): Don't set VECTOR_CST_NELTS.
21898
21899         * gengtype.c (struct walk_type_data): Add in_record_p and loopcounter
21900         members.
21901         (walk_type, <TYPE_POINTER, TYPE_ARRAY>): Handle case where our
21902         caller emitted the length calulation already.
21903         (walk_type, <TYPE_UNION, TYPE_STRUCT>): Emit length calculations
21904         before handling any of the fields for structs.
21905
21906 2012-04-19  Richard Guenther  <rguenther@suse.de>
21907
21908         PR tree-optimization/53031
21909         * tree-vrp.c (adjust_range_with_scev): Revert back to
21910         using max_loop_iterations.
21911
21912 2012-04-19  Michael Matz  <matz@suse.de>
21913
21914         * diagnostic.c (emit_diagnostic): Move va_end call after user
21915         of the va_list.
21916         (warning, warning_at, pedwarn, permerror): Ditto.
21917
21918 2012-04-19  Richard Guenther  <rguenther@suse.de>
21919
21920         * ira-int.h (ira_allocno_object_iter_cond): Avoid out-of-bound
21921         array access.
21922
21923 2012-04-19  Georg-Johann Lay  <avr@gjlay.de>
21924
21925         PR target/53033
21926         * config/avr/avr.c (avr_out_load_psi): Fix assembler template for
21927         the case *(X+const).
21928
21929 2012-04-19  Ramana Radhakrishnan  <ramana.radhakrishnan@linaro.org>
21930
21931         * config/arm/sync.md (sync_optab): Change ior attribute to "or".
21932
21933 2012-04-19  Manuel López-Ibáñez  <manu@gcc.gnu.org>
21934
21935         PR c/52283/37985
21936         * stmt.c (warn_if_unused_value): Skip NOP_EXPR.
21937         * convert.c (convert_to_integer): Don't set TREE_NO_WARNING.
21938
21939 2012-04-19  Richard Guenther  <rguenther@suse.de>
21940
21941         PR rtl-optimization/44688
21942         * loop-iv.c (determine_max_iter): Only return max_iter.
21943         (iv_number_of_iterations): Also use the recorded loop bound
21944         on the maximum number of iterations.
21945         * loop-unroll.c (decide_unroll_runtime_iterations): Use
21946         max_iter to avoid unrolling loops that do not roll.
21947         (decide_unroll_stupid): Likewise.
21948
21949 2012-04-18  Steven Bosscher  <steven@gcc.gnu.org>
21950
21951         * targhooks.c (default_case_values_threshold): Fix code style nit.
21952
21953         * stmt.c (add_case_node, expand_case): Move logic to remove/reduce
21954         case range and type folding from here...
21955         * gimplify.c (gimplify_switch_expr): ... to here.  Expect NULL_TREE
21956         type, as documented in tree.def.
21957
21958 2012-04-18  Jan Hubicka  <jh@suse.cz>
21959
21960         * cgraph.h (verify_symtab, verify_symtab_node, verify_symtab_base):
21961         Declare.
21962         * cgraphunit.c (verify_cgraph_node): Verify symtab base; do not verify
21963         cgraph hash and same comdat groups.
21964         (cgraph_optimize): Verify symbol table.
21965         * ipa.c (cgraph_remove_unreachable_nodes): Verify symbol table.
21966         (dissolve_same_comdat_group_list): Work on symtab nodes.
21967         (function_and_variable_visibility): Dissolve variable same comdat group
21968         lists, too.
21969         * symtab.c: Include timevar.h
21970         (verify_symtab_base, verify_symtab_node, verify_symtab): New functions.
21971
21972 2012-04-18  Steven Bosscher  <steven@gcc.gnu.org>
21973
21974         * tree-switch-conversion.c (info): Remove global pass info.
21975         (check_range, check_process_case, check_final_bb, create_temp_arrays,
21976         free_temp_arrays, gather_default_values, build_constructors,
21977         array_value_type, build_one_array, build_arrays, gen_def_assigns,
21978         fix_phi_nodes, gen_inbound_check): Pass info around from ...
21979         (process_switch): ... here.  Unify message format.  Return a const
21980         char pointer to the failure reason message.
21981         (do_switchconv): Unify message format.  Update process_switch usage.
21982
21983         * tree.def (CASE_LABEL_EXPR): Fix documentation, mention all operands.
21984         * tree-cfg.c (edge_to_cases): Fix documentation.
21985
21986 2012-04-18  Uros Bizjak  <ubizjak@gmail.com>
21987
21988         * config/alpha/sync.md (fetchop_name): Change ior attribute to "or".
21989
21990 2012-04-18  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
21991
21992         PR tree-optimization/52976
21993         * tree-ssa-reassoc.c (add_to_ops_vec_max_rank): Delete.
21994         (possibly_move_powi): New function.
21995         (rewrite_expr_tree): Call possibly_move_powi.
21996         (rewrite_expr_tree_parallel): Likewise.
21997         (attempt_builtin_powi): Change call of add_to_ops_vec_max_rank to
21998         call add_to_ops_vec instead.
21999
22000 2012-04-18  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
22001
22002         PR tree-optimization/52976
22003         * tree-ssa-reassoc.c (stmt_is_power_of_op): New function.
22004         (decrement_power): Likewise.
22005         (propagate_op_to_single_use): Likewise.
22006         (zero_one_operation): Handle __builtin_pow* calls in linearized
22007         expression trees; factor logic into propagate_op_to_single_use.
22008         (undistribute_ops_list): Allow operands with repeat counts > 1.
22009
22010 2012-04-18  Richard Guenther  <rguenther@suse.de>
22011
22012         PR tree-optimization/44688
22013         * cfgloop.h (record_niter_bound): Declare.
22014         * tree-ssa-loop-niter.c (record_niter_bound): Export.
22015         Update the estimation with the upper bound here...
22016         (estimate_numbers_of_iterations_loop): ... instead of here.
22017         Do not forcefully reset a recorded upper bound.
22018         * tree-vect-loop-manip.c (vect_do_peeling_for_alignment):
22019         Record the maximum number of loop iterations of the prologue loop.
22020
22021 2012-04-18  Jan Hubicka  <jh@suse.cz>
22022
22023         * lto-symtab.c (lto_cgraph_replace_node): Update.
22024         * cgraphbuild.c (record_reference, record_type_list,
22025         record_eh_tables, mark_address, mark_load, mark_store): Update.
22026         * cgraph.c (cgraph_same_body_alias, dump_cgraph_node,
22027         cgraph_create_virtual_clone, cgraph_for_node_thunks_and_aliases):
22028         Update.
22029         * cgraph.h (symtab_node_def, symtab_node, const_symtab_node): Remove.
22030         (cgraph_alias_aliased_node, varpool_alias_aliased_node): Update.
22031         * reload.c: Fix typo in comment.
22032         * rtlanal.c: Likewise.
22033         * tree-emultls.c (gen_emutls_addr): Update.
22034         * ipa-reference.c (analyze_function): Update.
22035         * cgraphunit.c (cgraph_analyze_function,
22036         cgraph_process_same_body_aliases, assemble_thunks_and_aliases):
22037         Update.
22038         * ipa-ref.c (ipa_record_reference): Reorg to avoid reference types.
22039         (ipa_remove_reference): Likewise.
22040         (ipa_remove_all_refering): Rename to ...
22041         (ipa_remove_all_referring): ... this one; update.
22042         (ipa_dump_references): Update.
22043         (ipa_dump_referring): Update.
22044         (ipa_clone_references): Update.
22045         (ipa_clone_refering): Rename to ...
22046         (ipa_clone_referring): ... this one; update.
22047         (ipa_ref_cannot_lead_to_return): Update.
22048         (ipa_ref_has_aliases_p): Update.
22049         * ipa-ref.h (symtab_node_def, symtab_node, const_symtab_node): New
22050         forward typedefs.
22051         (ipa_ref_type): Remove.
22052         (ipa_ref_ptr_u): Remove.
22053         (ipa_ref): Remove referencing, refered, refered_index, refering_type
22054         and refered_type; add referring, referred and referred_index.
22055         (ipa_ref_list): Rename refering to referring.
22056         (ipa_record_reference, ipa_remove_all_referring, ipa_dump_referring,
22057         ipa_clone_references, ipa_clone_referring): Update prototypes.
22058         * lto-cgraph.c (referenced_from_other_partition_p): Update.
22059         (lto_output_ref): Update.
22060         (add_references): Update.
22061         (input_varpool_node): Update.
22062         (input_refs): Update.
22063         * ipa-ref-inline.h (ipa_ref_node): Update.
22064         (ipa_ref_varpool_node): Update.
22065         (ipa_ref_referring_node): Update.
22066         (ipa_ref_referring_varpool_node): Update.
22067         (ipa_ref_referring_ref_list): Update.
22068         (ipa_ref_referred_ref_list): Update.
22069         (ipa_ref_list_first_referring): Update.
22070         (ipa_empty_ref_list): Update.
22071         (ipa_ref_list_refering_iterate): Rename to ...
22072         (ipa_ref_list_referring_iterate): ... this one.
22073         * cse.c: Update comment.
22074         * ipa-utils.c (ipa_reverse_postorder): Update.
22075         * tree-ssa-alias.c: Update.
22076         * ipa-inline.c (reset_edge_caches): Update.
22077         (update_caller_keys): Update.
22078         * ipa-inline.h: Update comments.
22079         * jump.c: Update comment.
22080         * alias.c: Likewise.
22081         * ipa.c (process_references): Update.
22082         (cgraph_remove_unreachable_nodes): Likewise.
22083         (ipa_discover_readonly_nonaddressable_var): Likewise.
22084         (cgraph_address_taken_from_non_vtable_p): Likewise.
22085         * trans-mem.c (ipa_tm_execute): Update.
22086         * simplify-rtx.c: Fix comment.
22087         * rtl.c: Fix comment.
22088         * symtab.c (symtab_unregister_node): Update.
22089         * varpool.c (dump_varpool_node): Update.
22090         (varpool_analyze_pending_decls): Update.
22091         (assemble_aliases): Update.
22092         (varpool_for_node_and_aliases): Update.
22093
22094 2012-04-18  Richard Guenther  <rguenther@suse.de>
22095
22096         * cfgloop.h (estimate_numbers_of_iterations_loop): Remove
22097         use_undefined_p parameter.
22098         * tree-flow.h (estimate_numbers_of_iterations): Likewise.
22099         * tree-ssa-loop-niter.c (estimate_numbers_of_iterations_loop):
22100         Likewise.
22101         (estimate_numbers_of_iterations): Likewise.
22102         (estimated_loop_iterations): Adjust.
22103         (max_loop_iterations): Likewise.
22104         (scev_probably_wraps_p): Likewise.
22105         * tree-ssa-loop.c (tree_ssa_loop_bounds): Likewise.
22106         * tree-vrp.c (adjust_range_with_scev): Use max_stmt_executions,
22107         not max_loop_iterations.
22108         (execute_vrp): Remove explicit number of iterations estimation.
22109
22110 2012-04-18  Enkovich Ilya  <ilya.enkovich@intel.com>
22111
22112         * config/i386/linux-common.h: New.
22113
22114         * config.gcc: Add i386/linux-common.h before
22115         all i386/linux.h and i386/linux64.h usages.
22116
22117         * config/i386/gnu-user.h (GNU_USER_TARGET_LINK_SPEC): New.
22118         (LINK_SPEC): Use GNU_USER_TARGET_LINK_SPEC.
22119         * config/i386/gnu-user64.h: Likewise.
22120
22121         * config/i386/gnu-user.common.h (GNU_USER_TARGET_CC1_SPEC): New.
22122         (CC1_SPEC): Use GNU_USER_TARGET_CC1_SPEC.
22123         (GNU_USER_TARGET_MATHFILE_SPEC): New.
22124         (ENDFILE_SPEC): Use GNU_USER_TARGET_MATHFILE_SPEC.
22125
22126 2012-04-18  Jan Hubicka  <jh@suse.cz>
22127
22128         * cgraph.c (cgraph_node_name): Remove.
22129         (dump_cgraph_node): Use dump_symtab_base; reformat.
22130         * cgraph.h (symtab_node_asm_name, symtab_node_name, dump_symtab,
22131         debug_symtab, dump_symtab_node, debug_symtab_node, dump_symtab_base):
22132         Declare.
22133         (cgraph_node_name, varpool_node_name): Remove.
22134         (cgraph_node_asm_name, varpool_node_asm_name,
22135         cgraph_node_name, varpool_node_name): New.
22136         * tree-pass.h (TODO_dump_cgraph): Rename to ...
22137         (TODO_dump_symtab): ... this one.
22138         * ipa-cp (pass_ipa_cp): Update.
22139         * ia-reference.c (generate_summary, read_write_all_from_decl,
22140         propagate, ipa_reference_read_optimization_summary): Update.
22141         * cgraphunit.c (cgraph_analyze_functions): Update.
22142         (cgraph_optimize): Update.
22143         * ipa-ref.c (ipa_dump_references): Update.
22144         (ipa_dump_refering): Update.
22145         * ipa-inline.c (pass_ipa_inline): Update.
22146         * matrix-reorg.c (pass_ipa_matrix_reorg): Update.
22147         * ipa.c (pass_ipa_function_visibility,
22148         pass_ipa_whole_program_visibility): Update.
22149         * tree-sra.c (pass_early_ipa_sra): Update.
22150         * symtab.c: Include langhooks.h
22151         (symtab_node_asm_name): New.
22152         (symtab_node_name): New.
22153         (symtab_type_names): New static var.
22154         (dump_symtab_base): New.
22155         (dump_symtab_node, dump_symtab): New.
22156         (debug_symtab_node,  debug_symtab): New.
22157         * tree-ssa-structalias.c: Dump symbol table.
22158         * pases.c (execute_todo): Handle TODO_dump_symtab instead
22159         of TODO_dump_cgraph.
22160         * varpoo.c (varpool_node_name): Remove.
22161         (dump_varpool_node): Use dump_symtab_base; reformat.
22162
22163 2012-04-18  Manuel López-Ibáñez  <manu@gcc.gnu.org>
22164
22165         * doc/invoke.texi (Language Independent Options): @item should be
22166         before @opindex.
22167
22168 2012-04-17  Richard Sandiford  <rdsandiford@googlemail.com>
22169
22170         PR bootstrap/53021
22171         * rtl.c (rtx_code_size): Handle ADDRESS.
22172
22173 2012-04-17  Tom de Vries  <tom@codesourcery.com>
22174
22175         * tree-iterator.c (append_to_statement_list_1): Handle case that *list_p
22176         is not a STMT_LIST.
22177
22178 2012-04-17  Uros Bizjak  <ubizjak@gmail.com>
22179
22180         PR target/53020
22181         * config/i386/sync.md (atomic_<code><mode>): Rename to
22182         atomic_<logic><mode>.
22183
22184 2012-04-17  Richard Sandiford  <rdsandiford@googlemail.com>
22185
22186         * rtl.def (ADDRESS): Turn operand into a HOST_WIDE_INT.
22187         * alias.c (reg_base_value): Expand and update comment.
22188         (arg_base_value): New variable.
22189         (unique_id): Move up file.
22190         (unique_base_value, unique_base_value_p, known_base_value_p): New.
22191         (find_base_value): Use arg_base_value and known_base_value_p.
22192         (record_set): Document REG_NOALIAS handling.  Use unique_base_value.
22193         (find_base_term): Use known_base_value_p.
22194         (base_alias_check): Use unique_base_value_p.
22195         (init_alias_target): Initialize arg_base_value.  Use unique_base_value.
22196         (init_alias_analysis): Use 1 as the first id for REG_NOALIAS bases.
22197
22198 2012-04-17  Pat Haugen <pthaugen@us.ibm.com>
22199
22200         * config/rs6000/rs6000.h (SLOW_UNALIGNED_ACCESS): Remove DImode.
22201
22202 2012-04-17  Michael Matz  <matz@suse.de>
22203
22204         PR tree-optimization/18437
22205         * tree-vectorizer.h (_stmt_vec_info.stride_load_p): New member.
22206         (STMT_VINFO_STRIDE_LOAD_P): New accessor.
22207         (vect_check_strided_load): Declare.
22208         * tree-vect-data-refs.c (vect_check_strided_load): New function.
22209         (vect_analyze_data_refs): Use it to accept strided loads.
22210         * tree-vect-stmts.c (vectorizable_load): Ditto and handle them.
22211
22212 2012-04-17  Richard Guenther  <rguenther@suse.de>
22213
22214         PR middle-end/53011
22215         * tree-eh.c (cleanup_empty_eh_merge_phis): Properly discard
22216         loops when redirecting an entry or latch edge.
22217
22218 2012-04-17  Bernd Schmidt  <bernds@codesourcery.com>
22219
22220         * sel-sched.c (sel_global_init): Revert previous change.
22221
22222 2012-04-17  Richard Guenther  <rguenther@suse.de>
22223
22224         * tree-flow.h (array_at_struct_end_p): Move declaration ...
22225         * tree.h (array_at_struct_end_p): ... here.
22226         * tree-ssa-loop-niter.c (array_at_struct_end_p): Move ...
22227         * expr.c (array_at_struct_end_p): ... here.  Rewrite.
22228
22229 2012-04-17  Steven Bosscher  <steven@gcc.gnu.org>
22230
22231         * stmt.c (cost_table_, use_cost_table, cost_table_initialize,
22232         COST_TABLE): Remove.
22233         (estimate_case_costs): Remove.
22234         (expand_case): Do not call estimate_case_costs
22235         to set use_cost_table.
22236         (balance_case_nodes): Do not use use_cost_table.
22237
22238 2012-04-16  Jan Hubicka  <jh@suse.cz>
22239
22240         * cgraph.c (cgraph_hash, assembler_name_hash): Remove.
22241         (hash_node, eq_node): Remove.
22242         (cgraph_create_node): Do not handle hashtable.
22243         (cgraph_get_node): Remove.
22244         (cgraph_insert_node_to_hashtable): Remove.
22245         (hash_node_by_assembler_name): Remove.
22246         (eq_assembler_name): Remove.
22247         (cgraph_node_for_asm): Rewrite.
22248         (cgraph_find_replacement_node): Break out from ...
22249         (cgraph_remove_node): ... here; do not maintain hashtables.
22250         (change_decl_assembler_name): Remove.
22251         (cgraph_clone_node): Do not maintain hashtables.
22252         * cgraph.h (const_symtab_node): New typedef.
22253         (cgraph_insert_node_to_hashtable): Remove.
22254         (symtab_get_node, symtab_node_for_asm,
22255         symtab_insert_node_to_hashtable): Declare.
22256         (cgraph_find_replacement_node): Declare.
22257         (cgraph_get_node, varpool_get_node): Turn into inlines.
22258         (cgraph, varpool): Work sanely on NULL pointers.
22259         (FOR_EACH_SYMBOL): New walker.
22260         * ipa-inline-transform.c (save_inline_function_body): Use
22261         symtab_insert_node_to_hashtable.
22262         * symtab.c: Include ggc.h and diagnostics.h
22263         (symtab_hash, assembler_name_hash): New static vars;
22264         (hash_node, eq_node, hash_node_by_assembler_name,
22265         eq_assembler_name, insert_to_assembler_name_hash,
22266         unlink_from_assembler_name_hash): New.
22267         (symtab_register_node): Update hashtables.
22268         (symtab_insert_node_to_hashtable): New.
22269         (symtab_unregister_node): Update hashtables.
22270         (symtab_get_node): New.
22271         (symtab_node_for_asm): New.
22272         (change_decl_assembler_name): New.
22273         * Makefile.in (symtab.o): Needs GTY.
22274         * varpool.c (varpool_hash): Remove.
22275         (hash_varpool_node, eq_varpool_node, varpool_get_node): Remove.
22276         (varpool_node): Rewrite using varpool_get_node.
22277         (varpool_remove_node): DO not maintain hashtables.
22278         (varpool_node_for_asm): Rewrite.
22279
22280 2012-04-16  Sandra Loosemore  <sandra@codesourcery.com>
22281
22282         * doc/invoke.texi:  Copy-edit to put verbs in the present tense
22283         when describing the current behavior of GCC.
22284
22285 2012-04-16  Richard Sandiford  <rdsandiford@googlemail.com>
22286
22287         * genemit.c (gen_exp): Remove ADDRESS handling.
22288         * genoutput.c (scan_operands): Likewise.
22289         * genpeep.c (match_rtx): Likewise.
22290         * genrecog.c (add_to_sequence): Likewise.
22291
22292 2012-04-16  David Edelsohn  <dje.gcc@gmail.com>
22293
22294         * doc/install.texi (Specific, *-ibm-aix*): Update assembler bug status.
22295
22296 2012-04-16  Martin Jambor  <mjambor@suse.cz>
22297
22298         * tree-sra.c (build_ref_for_model): Create COMPONENT_REFs only for
22299         bit-fields.
22300
22301 2012-04-16  Ulrich Weigand  <ulrich.weigand@linaro.org>
22302
22303         PR target/51819
22304         * config/arm/arm.c (arm_print_operand): Fix invalid alignment
22305         hints for 'A' operand types.
22306
22307 2012-04-16  Jan Hubicka  <jh@suse.cz>
22308
22309         * cgraph.h (symtab_node_base): Add next and previous pointers.
22310         (cgraph_node): Remove next and preivous pointers.
22311         (varpool_node): Likewise; remove next/previous GTY marker;
22312         it is not type safe.
22313         (symtab_node_def): Update GTY marker
22314         (x_cgraph_nodes, cgraph_nodes): Remove.
22315         (symtab_nodes): New function.
22316         (cgraph_order): Rename to ...
22317         (symtab_order): ... this one.
22318         (symtab_register_node, symtab_unregister_node, symtab_remove_node):
22319         Declare.
22320         (x_varpool_nodes, varpool_nodes): Remove.
22321         (FOR_EACH_STATIC_VARIABLE): Update.
22322         (symtab_function_p, symtab_variable_p): New function.
22323         (FOR_EACH_VARIABLE): Update.
22324         (varpool_first_variable, varpool_next_variable): New functions.
22325         (FOR_EACH_VARIABLE): Update.
22326         (cgraph_first_defined_function): Update.
22327         (cgraph_next_defined_function, cgraph_next_defined_function): Update.
22328         (FOR_EACH_DEFINED_FUNCTION, FOR_EACH_FUNCTION): Update.
22329         (cgraph_first_function, cgraph_next_function): New.
22330         (FOR_EACH_FUNCTION): Update.
22331         (cgraph_first_function_with_gimple_body,
22332         cgraph_next_function_with_gimple_body): Update.
22333         * symtab.c: New file.
22334         * cgraph.c: Update copyright dates.
22335         (x_cgraph_nodes, cgraph_order): Remove.
22336         (NEXT_FREE_NODE): Update.
22337         (SET_NEXT_FREE_NODE): New.
22338         (cgraph_create_node_1): Remove common code.
22339         (cgraph_create_node): Remove common code; call symtab_register_node.
22340         (cgraph_remove_node): Remove common code; call symtab_unregister-node.
22341         (cgraph_add_asm_node): Update.
22342         (cgraph_clone_node): Register new node.
22343         * cgraphunit.c (process_function_and_variable_attributes): Update.
22344         (cgraph_analyze_functions): Update.
22345         (cgraph_analyze_functions): Update.
22346         (cgraph_output_in_order): Update.
22347         * lto-cgraph.c (input_node, input_varpool_node, input_cgraph_1):
22348         Update.
22349         * ipa-inline.c (recursive_inlining): Update.
22350         * lto-streamer-in.c (lto_input_toplevel_asms): Update.
22351         * ipa.c (cgraph_remove_unreachable_nodes): Update.
22352         * Makefile.in: Add symtab.o
22353         * varpool.c (x_varpool_nodes): Remove
22354         (varpool_node): Remove common code; call symtab_register_node.
22355         (varpool_remove_node): Remove common code; call symtab_unregister_node.
22356
22357 2012-04-16  Richard Guenther  <rguenther@suse.de>
22358
22359         PR middle-end/52977
22360         * tree.h (VECTOR_CST_NELTS): Adjust.
22361         (struct tree_vector): Add explicit length field.
22362         (make_vector_stat): Declare.
22363         (make_vector): Define.
22364         * tree.c (make_vector_stat): New function.
22365         (build_vector_stat): Use it.
22366         * tree-streamer-in.c (streamer_alloc_tree): Likewise.
22367
22368 2012-04-16  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
22369
22370         PR tree-optimization/52976
22371         * tree-ssa-reassoc.c (add_to_ops_vec_max_rank): New function.
22372         (undistribute_ops_list): Ops with repeat counts aren't eligible for
22373         undistribution.
22374         (attempt_builtin_powi): Call add_to_ops_vec_max_rank.
22375
22376 2012-04-16  Jan Hubicka  <jh@suse.cz>
22377
22378         * cgraph.h (FOR_EACH_VARIABLE, FOR_EACH_VARIABLE, FOR_EACH_FUNCTION):
22379         New macros.
22380         * lto-symtab.c (lto_symtab_merge_cgraph_nodes): Use FOR_EACH
22381         walkers to walk cgraph and varpool.
22382         * cgraph.c (cgraph_node_for_asm): Likewise.
22383         (dump_cgraph): Likewise.
22384         * value-prof.c (init_node_map): Likewise.
22385         * tree.c (free_lang_data_in_cgraph): Likewise.
22386         * tree-emutls.c: (ipa_lower_emutls): Likewise.
22387         * ipa-reference.c (generate_summary, propagate): Likewise.
22388         * cgraphunit.c (verify_cgraph, cgraph_process_same_body_aliases,
22389         cgraph_mark_functions_to_output, cgraph_output_in_order,
22390         output_weakrefs, cgraph_materialize_all_clones,
22391         cgraph_optimize): Likewise.
22392         * lto-cgraph.c (merge_profile_summaries): Likewise.
22393         (input_cgraph): Likewise.
22394         * ipa-pure-const.c (generate_summary): Likewise.
22395         (propagate): Likwise.
22396         * ipa-utils.c (ipa_reduced_postorder): Likewise.
22397         (ipa_free_postorder_info): Likewise.
22398         (ipa_reverse_postorder): Likewise.
22399         * ipa-inline.c (ipa_inline): Likewise.
22400         * matrix-reorg.c (find_matrices_decl): Likewise.
22401         (matrix_reorg): Likewise.
22402         * tree-vectorizer.c (increase_alignment): Likewise.
22403         * ipa.c (cgraph_remove_unreachable_nodes): Likewise.
22404         (function_and_variable_visibility): Likewise.
22405         (whole_program_function_and_variable_visibility): Likewise.
22406         (ipa_cdtor_merge): Likewise.
22407         * trans-mem.c (ipa_tm_execute): Likewise.
22408         * ipa-inline-analysis.c (dump_inline_summaries): Likewise.
22409         * ipa-prop.c (ipa_print_all_jump_functions): Likewise.
22410         (ipa_print_all_params): Likewise.
22411         (ipa_update_after_lto_read): Likewise.
22412         * tree-profie.c (tree_profiling): Likewise.
22413         * tree-ssa-structalias.c (ipa_pta_execute): Likewise.
22414         * passes.c (dump_passes): Likewise.
22415         (do_per_function): Likewise.
22416         (ipa_write_summaries): Likewise.
22417         * varpool.c (dump_varpool): Likewise.
22418         (varpool_node_for_asm): Likewise.
22419         (varpool_assemble_pending_decls): Likewise.
22420
22421 2012-04-16  Richard Guenther  <rguenther@suse.de>
22422
22423         PR tree-optimization/52975
22424         * tree-if-conv.c (predicate_bbs): Do not simplify inverted
22425         condition but always mark it with TRUTH_NOT_EXPR.
22426
22427 2012-04-16  Richard Guenther  <rguenther@suse.de>
22428
22429         PR tree-optimization/52975
22430         * tree-ssa-forwprop.c (combine_cond_exprs): New function.
22431         (ssa_forward_propagate_and_combine): Call it for COND_EXPRs
22432         and VEC_COND_EXPRs.  Also combine into VEC_COND_EXPRs condition.
22433         * fold-const.c (operand_equal_p): Handle TARGET_MEM_REF.
22434
22435 2012-04-14  Uros Bizjak  <ubizjak@gmail.com>
22436
22437         * config/i386/sse.md (ssse3_plusminus): New code iterator.
22438         (avx2_ph<plusminus_mnemonic>wv16hi3): Macroize insn from
22439         avx2_ph{add,adds,sub,subs}wv16hi3 using ssse3_plusminus code iterator.
22440         (ssse3_ph<plusminus_mnemonic>wv8hi3): Macroize insn from
22441         ssse3_ph{add,adds,sub,subs}wv8hi3 using ssse3_plusminus code iterator.
22442         (ssse3_ph<plusminus_mnemonic>wv4hi3): Macroize insn from
22443         ssse3_ph{add,adds,sub,subs}wv4hi3 using ssse3_plusminus code iterator.
22444
22445         (avx2_ph<plusminus_mnemonic>dv8si3): Macroize insn from
22446         avx2_ph{add,adds,sub,subs}dv8si3 using plusminus code iterator.
22447         (ssse3_ph<plusminus_mnemonic>dv4si3): Macroize insn from
22448         ssse3_ph{add,adds,sub,subs}dv4si3 using plusminus code iterator.
22449         (ssse3_ph<plusminus_mnemonic>dv2si3): Macroize insn from
22450         ssse3_ph{add,adds,sub,subs}dv2si3 using plusminus code iterator.
22451
22452         (xop_plus): New code iterator.
22453         (macs): New code attribute.
22454         (macds): Ditto.
22455         (xop_p<macs><ssemodesuffix><ssemodesuffix>): Macroize insn from
22456         xop_pmacs{,s}{ww,dd} using xop_plus code iterator and VI24_128 mode
22457         iterator.
22458         (xop_p<macs>dql): Macroize insn from xop_pmacs{,s}dql using
22459         xop_plus code iterator.
22460         (xop_p<macs>dqh): Macroize insn from xop_pmacs{,s}dqh using
22461         xop_plus code iterator.
22462         (xop_p<macs>wd): Macroize insn from xop_pmacs{,s}wd using
22463         xop_plus code iterator.
22464         (xop_p<madcs>wd): Macroize insn from xop_pmadcs{,s}wd using
22465         xop_plus code iterator.
22466
22467         (xop_phadd<u>bw): Macroize insn from xop_phadd{,u}bw usign
22468         any_extend code iterator.
22469         (xop_phadd<u>bd): Macroize insn from xop_phadd{,u}bd usign
22470         any_extend code iterator.
22471         (xop_phadd<u>bq): Macroize insn from xop_phadd{,u}bq usign
22472         any_extend code iterator.
22473         (xop_phadd<u>wd): Macroize insn from xop_phadd{,u}wd usign
22474         any_extend code iterator.
22475         (xop_phadd<u>wq): Macroize insn from xop_phadd{,u}wq usign
22476         any_extend code iterator.
22477         (xop_phadd<u>dq): Macroize insn from xop_phadd{,u}dq usign
22478         any_extend code iterator.
22479
22480 2012-04-14  Tom de Vries  <tom@codesourcery.com>
22481
22482         * cfgcleanup.c (try_optimize_cfg): Replace call to delete_insn_chain by
22483         call to delete_insn.  Remove code to reorder BASIC_BLOCK note and
22484         DELETED_LABEL note, and move it to ...
22485         * cfgrtl.c (delete_insn): ... here.  Change return type to void.
22486         (delete_insn_and_edges): Likewise.
22487         (delete_insn_chain): Handle new return type of delete_insn.  Delete
22488         chain backwards rather than forwards.
22489         * rtl.h (delete_insn, delete_insn_and_edges): Change return type to
22490         void.
22491         * cfglayout.c (fixup_reorder_chain): Delete unused label.
22492
22493 2012-04-14  Jan Hubicka  <jh@suse.cz>
22494
22495         * cgraph.h: Update copyrights;
22496         (symtab_node): Turn to union typedef.
22497         (symtab_node_base): New structure.
22498         (symtab_type): Add SYMTAB_SYMBOL tag.
22499         (cgraph_node): Annotate some pinters with nested_ptr.
22500         (varpool_node): Likewise.
22501         (cgraph_local_info): Remove lto_file_data
22502         and externally_visible.
22503         (cgraph_node): Remove decl; same_comdat_group list;
22504         aux; ref_list; order; address_taken; reachable_from_other_parittion,
22505         in_other_partition; resolution.
22506         (varpool_node): Remove decl; same_comdat_group;
22507         ref_list; lto_file_data; aux; order; resolution; externally_visible;
22508         used_from_other_partition; in_other_partition.
22509         (symtab_node_def): New union.
22510         (cgraph, varpool): Update.
22511         (varpool_first_static_initializer, varpool_next_static_initializer,
22512         cgraph_only_called_directly_or_aliased_p,
22513         varpool_can_remove_if_no_refs, varpool_can_remove_if_no_refs,
22514         varpool_all_refs_explicit_p, cgraph_alias_aliased_node,
22515         varpool_alias_aliased_node, cgraph_edge_recursive_p): Update
22516         field references.
22517         * cgraph.c: Likewise.
22518         (cgraph_hash, assembler_name_hash): Turn into symtab_node.
22519         * cgraphbuild.c: Likewise.
22520         * lto-symtab.c: Likewise.
22521         * c-gimplify.c: Likewise.
22522         * value-prof.c: Likewise.
22523         * tree.c: Likewise.
22524         * ipa-cp.c: Likewise.
22525         * tree-emutls.c: Likewise.
22526         * ipa-inline-transform.c: Likwise.
22527         * ipa-reference.c: Likewise.
22528         * cgraphunit.c: Likewise.
22529         * ipa-ref.c: Likewise.
22530         * lto-cgraph.c: Likewise.
22531         * ipa-ref-inline.h: Likewise.
22532         * ipa-pure-const.c: Likewise.
22533         * lto-streamer-out.c: Likewise.
22534         * ipa-utils.c: Likewise.
22535         * ipa-inline.c: Likewise.
22536         * matrix-reorg.c: Likewise.
22537         * tree-eh.c: Likewise.
22538         * tree-vectorizer.c: Likewise.
22539         * ipa-split.c: Likewise.
22540         * ipa.c: Likewise.
22541         * trans-mem.c: Likewise.
22542         * ipa-inline-analysis.c: Likewise.
22543         * gimplify.c: Likewise.
22544         * cfgexpand.c: Likewise.
22545         * tree-sra.c: Likewise.
22546         * ipa-prop.c: Likewise.
22547         * varasm.c: Likewise.
22548         * tree-nested.c: Likewise.
22549         * tree-inline.c: Likewise.
22550         * tree-profile.c: Likewise.
22551         * tree-ssa-structalias.c: Likewise.
22552         * passes.c: Likewise.
22553         * varpool.c: Likewise.
22554
22555 2012-04-14  Tom de Vries  <tom@codesourcery.com>
22556
22557         * tree-ssa-tail-merge.c (stmt_local_def): New function, factored out of
22558         same_succ_hash, with local_def inlined.  Use SINGLE_SSA_DEF_OPERAND.
22559         Use FOR_EACH_IMM_USE_FAST instead of FOR_EACH_IMM_USE_STMT.  Remove use
22560         of find_edge.
22561         (gsi_advance_fw_nondebug_nonlocal): New function.
22562         (local_def): Removed function.
22563         (same_succ_hash): Use stmt_local_def.
22564         (same_succ_equal): Use gsi_advance_fw_nondebug_nonlocal.
22565         (gsi_advance_bw_nondebug_nonlocal): Use stmt_local_def.
22566
22567 2012-04-13  H.J. Lu  <hongjiu.lu@intel.com>
22568
22569         * config/i386/i386-c.c (ix86_target_macros): Define _ILP32
22570         and __ILP32__ for x32.
22571
22572 2012-04-13  Martin Jambor  <mjambor@suse.cz>
22573
22574         PR middle-end/52939
22575         * gimple-fold.c (gimple_get_virt_method_for_binfo): Bail out if
22576         fold_ctor_reference returns a zero constant.
22577
22578 2012-04-13  Enkovich Ilya  <ilya.enkovich@intel.com>
22579
22580         * config.gcc: Add i386/gnu-user-common.h before all
22581         i386/gnu-user.h and i386/gnu-user64.h usages.
22582
22583         * config/i386/gnu-user-common.h: New.
22584
22585         * config/i386/gnu-user.h (CPP_SPEC): Moved to gnu-user-common.h.
22586         (CC1_SPEC): Likewise.
22587         (ENDFILE_SPEC): Likewise.
22588         (DEFAULT_PCC_STRUCT_RETURN): Likewise.
22589         (TARGET_TLS_DIRECT_SEG_REFS_DEFAULT): Likewise.
22590         (TARGET_OS_CPP_BUILTINS): Likewise.
22591         (LIBGCC2_HAS_TF_MODE): Likewise.
22592         (LIBGCC2_TF_CEXT): Likewise.
22593         (TF_SIZE): Likewise.
22594         (TARGET_ASM_FILE_END): Likewise.
22595         (STACK_CHECK_MOVING_SP): Likewise.
22596         (STACK_CHECK_STATIC_BUILTIN): Likewise.
22597         * config/i386/gnu-user64.h: Likewise.
22598
22599 2012-04-13  Martin Jambor  <mjambor@suse.cz>
22600
22601         * expr.c (expand_expr_real_1): Pass type, not the expression, to
22602         set_mem_attributes for a memory temporary. Do not call the function
22603         for the memory temporary created for a bitfield.
22604
22605 2012-04-13  Alexandre Oliva  <aoliva@redhat.com>
22606
22607         PR debug/48866
22608         * df.h (enum debug_temp_where): New.
22609         (dead_debug_init, dead_debug_finish) Declare.
22610         (dead_debug_add, dead_debug_insert_temp): Declare.
22611         (struct dead_debug_use, struct dead_debug): Moved from...
22612         * df-problems.c: ... here.
22613         (df_set_unused_notes_for_mw): Bind debug uses of unused regno
22614         to a debug temp.
22615         (df_create_unused_note): Likewise.
22616         (df_set_dead_notes_for_mw): Move comment where it belongs.
22617         (dead_debug_init): Export.
22618         (dead_debug_reset_uses): New, factored out of...
22619         (dead_debug_finish): ...this.  Export.
22620         (dead_debug_reset): Remove.
22621         (dead_debug_add): Export.
22622         (dead_debug_insert_before): Rename to...
22623         (dead_debug_insert_temp): ... this.  Add where argument.  Export.
22624         Locate stored value for BEFORE_WITH_VALUE.  Avoid repeat inserts.
22625         Return insertion count.
22626         (df_note_bb_compute): Adjust.
22627         * dce.c (word_dce_process_block): Adjust dead debug uses.
22628         (dce_process_block): Likewise.
22629
22630 2012-04-13  Alexandre Oliva  <aoliva@redhat.com>
22631
22632         * df-problems.c (df_note_bb_compute): Do not take note of
22633         debug uses for whose REGs we won't emit DEAD or UNUSED notes.
22634
22635 2012-04-13  Alexandre Oliva  <aoliva@redhat.com>
22636
22637         PR debug/51570
22638         * var-tracking.c (expand_depth): New type.
22639         (onepart_aux, expand_loc_callback_data): Change depth type to it.
22640         (loc_exp_dep_alloc): Adjust initializer.
22641         (update_depth): Use new type.  Add entryvals.
22642         (vt_expand_var_loc_chain): Take note of expansions with
22643         ENTRY_VALUEs, but don't accept them right away.  Run an optional
22644         second pass accepting the minimum ENTRY_VALUE count found in the
22645         first pass.
22646         (vt_expand_loc_callback, INIT_ELCD): Adjust.
22647
22648 2012-04-13  Tom de Vries  <tom@codesourcery.com>
22649
22650         * tree-ssa-tail-merge.c (gsi_advance_bw_nondebug_nonlocal): Add
22651         parameters vuse and vuse_escaped.
22652         (find_duplicate): Init vuse1, vuse2 and vuse_escaped.  Pass to
22653         gsi_advance_bw_nondebug_nonlocal.  Return if vuse_escaped and
22654         vuse1 != vuse2.
22655
22656 2012-04-13  Richard Guenther  <rguenther@suse.de>
22657
22658         PR tree-optimization/52969
22659         * tree-if-conv.c (predicate_mem_writes): Properly gimplify
22660         the condition for the COND_EXPR and handle predicate negation
22661         by swapping the COND_EXPR arms.
22662
22663 2012-04-13  Nick Clifton  <nickc@redhat.com>
22664
22665         * config/rl78/rl78.c (rl78_devirt_pass): Remove use of
22666         TODO_dump_func flag.
22667
22668 2012-04-13  Andrey Belevantsev  <abel@ispras.ru>
22669
22670         PR rtl-optimization/52203
22671         PR rtl-optimization/52715
22672
22673         Revert the 2012-03-07 fix for PR 52203.
22674         * sel-sched.c (reset_sched_cycles_in_current_ebb): Check that
22675         the insn does not modify DFA right before issuing, adjust
22676         issue_rate accordingly.
22677
22678 2012-04-13  Richard Guenther  <rguenther@suse.de>
22679
22680         PR c/52549
22681         * c-typeck.c (pointer_diff): Remove bogus assert.
22682
22683 2012-04-13  Richard Guenther  <rguenther@suse.de>
22684
22685         PR c/52862
22686         * convert.c (convert_to_pointer): Remove special-casing of zero.
22687
22688 2012-04-13  Joey Ye  <joey.ye@arm.com>
22689
22690         * config/arm/constraints.md (Pe): New constraint.
22691         * config/arm/arm.md: New split for imm 256-510.
22692
22693 2012-04-13  Terry Guo  <terry.guo@arm.com>
22694
22695         * config/arm/arm-cores.def: Added core cortex-m0plus.
22696         * config/arm/arm-tune.md: Regenerated.
22697         * config/arm/arm-tables.opt: Regenerated.
22698         * doc/invoke.texi: Added entry for cpu ARM cortex-m0plus.
22699
22700 2012-04-13  Alan Modra  <amodra@gmail.com>
22701
22702         PR target/52828
22703         * config/rs6000/rs6000.c (rs6000_emit_stack_tie): Rewrite with
22704         tie regs on destination of sets.  Delete forward declaration.
22705         (rs6000_emit_stack_reset): Update rs6000_emit_stack_tie calls.
22706         (rs6000_emit_prologue): Likewise.
22707         (rs6000_emit_epilogue): Likewise.  Use in place of gen_frame_tie
22708         and gen_stack_tie.
22709         (is_mem_ref): Use tie_operand to recognise stack ties.
22710         * config/rs6000/predicates.md (tie_operand): New.
22711         * config/rs6000/rs6000.md (restore_stack_block): Generate new
22712         stack tie rtl.
22713         (restore_stack_nonlocal): Likewise.
22714         (stack_tie): Update.
22715         (frame_tie): Delete.
22716
22717 2012-04-12  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
22718
22719         * tree-ssa-reassoc.c (attempt_builtin_powi_stats): Change %ld to
22720         HOST_WIDE_INT_PRINT_DEC in format strings.
22721
22722 2012-04-12  Uros Bizjak  <ubizjak@gmail.com>
22723
22724         PR target/52932
22725         * config/i386/avx2intrin.h (_mm256_permutevar8x32_ps): Change second
22726         argument type to __m256i.  Update call to __builtin_ia32_permvarsf256.
22727         * config/i386/sse.md (UNSPEC_VPERMVAR): New.
22728         (UNSPEC_VPERMSI, UNSPEC_VPERMSF): Remove.
22729         (avx2_permvarv8sf, avx2_permvarv8si): Switch operands 1 and 2.
22730         (avx2_permvar<mode>): Macroize insn from avx2_permvarv8sf and
22731         avx2_permvarv8si using VI4F_256 mode iterator.
22732         * config/i386/i386.c (bdesc_args) <__builtin_ia32_permvarsf256>:
22733         Update builtin type to V8SF_FTYPE_V8SF_V8SI.
22734         (ix86_expand_vec_perm): Update calls to gen_avx2_permvarv8si and
22735         gen_avx2_permvarv8sf.
22736         (expand_vec_perm_pshufb): Ditto.
22737
22738 2012-04-12  Michael Meissner  <meissner@linux.vnet.ibm.com>
22739
22740         PR target/52775
22741         * config/rs6000/rs6000.h (TARGET_FCFID): Add TARGET_PPC_GPOPT to
22742         the list of options to enable the FCFID instruction.
22743         (TARGET_EXTRA_BUILTINS): Adjust comment.
22744
22745 2012-04-12  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
22746
22747         PR tree-optimization/18589
22748         * tree-ssa-reassoc.c (reassociate_stats): Add two fields.
22749         (operand_entry): Add count field.
22750         (add_repeat_to_ops_vec): New function.
22751         (completely_remove_stmt): Likewise.
22752         (remove_def_if_absorbed_call): Likewise.
22753         (remove_visited_stmt_chain): Remove feeding builtin pow/powi calls.
22754         (acceptable_pow_call): New function.
22755         (linearize_expr_tree): Look for builtin pow/powi calls and add operand
22756         entries with repeat counts when found.
22757         (repeat_factor_d): New struct and associated typedefs.
22758         (repeat_factor_vec): New static vector variable.
22759         (compare_repeat_factors): New function.
22760         (get_reassoc_pow_ssa_name): Likewise.
22761         (attempt_builtin_powi): Likewise.
22762         (reassociate_bb): Call attempt_builtin_powi.
22763         (fini_reassoc): Two new calls to statistics_counter_event.
22764
22765 2012-04-12  Richard Guenther  <rguenther@suse.de>
22766
22767         * Makefile.in (cgraphunit.o): Add $(EXCEPT_H) dependency.
22768         * cgraph.h (tree_rest_of_compilation): Remove.
22769         * cgraph.c (cgraph_add_new_function): Move ...
22770         * cgraphunit.c (cgraph_add_new_function): ... here.
22771         (tree_rest_of_compilation): Make static.
22772         (cgraph_expand_function): Do not set cgraph_function_flags_ready.
22773         * tree-optimize.c (gate_all_optimizations, pass_all_optimizations,
22774         gate_all_early_local_passes, execute_all_early_local_passes,
22775         pass_early_local_passes, gate_all_early_optimizations,
22776         pass_all_early_optimizations): Move ...
22777         * passes.c (gate_all_optimizations, pass_all_optimizations,
22778         gate_all_early_local_passes, execute_all_early_local_passes,
22779         pass_early_local_passes, gate_all_early_optimizations,
22780         pass_all_early_optimizations): ... here.
22781         * tree-optimize.c (execute_free_datastructures): Remove.
22782         * tree-flow.h (execute_free_datastructures): Remove.
22783         * tree-optimize.c (execute_init_datastructures,
22784         pass_init_datastructures): Move ...
22785         * tree-ssa.c (execute_init_datastructures,
22786         pass_init_datastructures): ... here.
22787         * cfgexpand.c (gimple_expand_cfg): Inline-expand call to
22788         execute_free_datastructures.
22789
22790 2012-04-12  Bernd Schmidt  <bernds@codesourcery.com>
22791
22792         * dbgcnt.def (ira_move): New counter.
22793         * ira-int.h (ira_create_new_reg): Declare function.
22794         (first_moveable_pseudo, last_moveable_pseudo): Declare variables.
22795         * ira-emit.c (ira_create_new_reg): Renamed from craete_new_reg and
22796         no longer static.  All callers changed.
22797         * ira.c: Include "dbgcnt.h".
22798         (rtx_moveable_p, insn_dominated_by_p, find_moveable_pseudos,
22799         move_unallocated_pseudos): New static functions.
22800         (first_moveable_pseudo, last_moveable_pseudo): New global variables.
22801         (pseudo_replaced_reg, pseudo_move_insn): New static variables.
22802         (ira): Call find_moveable_pseudos and move_unallocated_pseudos.
22803         * ira-costs.c (find_costs_and_classes): Assign a memory cost of zero
22804         to the pseudos generated in find_moveable_pseudos.
22805         * Makefile.in (ira.o): Add $(DBGCNT_H).
22806
22807 2012-04-12  Richard Guenther  <rguenther@suse.de>
22808
22809         PR tree-optimization/52943
22810         * tree-chrec.h (chrec_is_positive): Remove.
22811         * tree-scalar-evolution.c (chrec_is_positive): Move ...
22812         * tree-data-ref.c (chrec_is_positive): ... here.  Make static.
22813         Return false for a constant zero instead of negative.
22814         (analyze_siv_subscript_cst_affine): Handle zero difference
22815         in the initial condition explicitely.
22816
22817 2012-04-12  Richard Guenther  <rguenther@suse.de>
22818
22819         * tree-parloops.c (parallelize_loops): Also consult the upper
22820         bound for the number of iterations.
22821         * tree-ssa-loop-prefetch.c (determine_loop_nest_reuse): Likewise.
22822         (loop_prefetch_arrays): Likewise.
22823
22824 2012-04-12  Richard Guenther  <rguenther@suse.de>
22825
22826         * cfgloop.h (estimated_loop_iterations_int): Ditch
22827         'conservative' parameter.
22828         (max_stmt_executions_int): Likewise.
22829         (estimated_loop_iterations): Likewise.
22830         (max_stmt_executions): Likewise.
22831         (max_loop_iterations): Declare.
22832         (max_loop_iterations_int): Likewise.
22833         (estimated_stmt_executions): Likewise.
22834         (estimated_stmt_executions_int): Likewise.
22835         * tree-ssa-loop-niter.c (estimated_loop_iterations):
22836         Split parts to ...
22837         (max_loop_iterations): ... this.
22838         (estimated_loop_iterations_int): Split parts to ...
22839         (max_loop_iterations_int): ... this.
22840         (max_stmt_executions_int): Split parts to ...
22841         (estimated_stmt_executions_int): ... this.
22842         (max_stmt_executions): Split parts to ...
22843         (estimated_stmt_executions): ... this.
22844         * graphite-sese-to-poly.c (build_loop_iteration_domains): Adjust.
22845         * predict.c (predict_loops): Likewise.
22846         * tree-data-ref.c (max_stmt_executions_tree): Likewise.
22847         (analyze_siv_subscript_cst_affine): Likewise.
22848         (compute_overlap_steps_for_affine_1_2): Likewise.
22849         (analyze_subscript_affine_affine): Likewise.
22850         (init_omega_for_ddr_1): Likewise.
22851         * tree-parloops.c (parallelize_loops): Likewise.
22852         * tree-ssa-loop-ivopts.c (avg_loop_niter): Likewise.
22853         (may_eliminate_iv): Likewise.
22854         * tree-ssa-loop-prefetch.c (determine_loop_nest_reuse): Likewise.
22855         (loop_prefetch_arrays): Likewise.
22856         * tree-vrp.c (adjust_range_with_scev): Likewise.
22857
22858 2012-04-12  Oleg Endo  <olegendo@gcc.gnu.org>
22859
22860         * config/sh/sh.h (RETURN_ADDR_RTX): Use NULL_RTX instead of 0.
22861         * config/sh/sh.c (INSN_REGMODE_WEIGHT, CURR_REGMODE_PRESSURE):
22862         Fix line width.
22863         (dump_table): Use bool type for need_align and have_df variables.
22864         (find_barrier, sfunc_uses_reg): Use NULL_RTX instead of 0.
22865         (regs_used): Remove register modifier.
22866         (barrier_align): Move variables slot, credit, jump_to_next
22867         into if block above for loop.  Use bool type for jump_to_next.
22868         (sh_function_arg): Use NULL_RTX instead of 0.
22869
22870 2012-04-11  Andreas Schwab  <schwab@linux-m68k.org>
22871
22872         * config/m68k/m68k.md (rotrhi3+1): Name it rotrhi_lowpart.
22873         (bswapsi2): New expander.
22874
22875 2012-04-11  H.J. Lu  <hongjiu.lu@intel.com>
22876
22877         * config/host-linux.c (TRY_EMPTY_VM_SPACE): Defined to
22878         0x60000000 if __x86_64 is defined and __LP64__ isn't defined.
22879
22880 2012-04-11  H.J. Lu  <hongjiu.lu@intel.com>
22881
22882         PR rtl-optimization/52876
22883         * emit-rtl.c (set_reg_attrs_from_value): Handle arbitrary value.
22884         Don't call mark_reg_pointer for incompatible pointer sign extension.
22885
22886         * reginfo.c (reg_scan_mark_refs): Call set_reg_attrs_from_value
22887         directly.
22888
22889 2012-04-11  Bernd Schmidt  <bernds@codesourcery.com>
22890
22891         * fold-const.c (fold_unary_loc): Use GET_MODE_PRECISION for
22892         comparisons against TYPE_PRECISION.
22893         * tree-ssa-forwprop.c (combine_conversions): Likewise.
22894
22895 2012-04-11  Xinliang David Li  <davidxl@google.com>
22896
22897         * tree-passes.h: Remove TODO_dump_func.
22898         * tree-ssa-tail-merge.c (tail_merge_optimize): Remove TODO_dump_func.
22899         * trans-mem.c: Remove TODO_dump_func.
22900         * ira.c: Remove TODO_dump_func.
22901
22902 2012-04-11  H.J. Lu  <hongjiu.lu@intel.com>
22903
22904         * config/i386/i386.c (ix86_option_override_internal): Check
22905         SUBTARGET_OVERRIDE_OPTIONS and SUBSUBTARGET_OVERRIDE_OPTIONS
22906         after TARGET_64BIT is updated.
22907
22908 2012-04-11  Oleg Endo  <olegendo@gcc.gnu.org>
22909
22910         * config/sh/sh.h: Remove old secondary reload code.
22911
22912 2012-04-11  Oleg Endo  <olegendo@gcc.gnu.org>
22913
22914         * config/sh/sh.c (SCHED_REORDER): Merge macro into ...
22915         (ready_reorder): ... this function.
22916
22917 2012-04-11  Bernd Schmidt  <bernds@codesourcery.com>
22918
22919         * sel-sched.c (sel_global_init): Swap order of sched_rgn_init and
22920         sched_init calls.
22921
22922         * haifa-sched.c (prune_ready_list): Rework handling of SCHED_GROUP_P
22923         insns so that no other insn is queued for a time before them.
22924
22925         * config/c6x/c6x.md (load_got_gotoff): Set op_pattern attribute to
22926         unknown.
22927
22928 2012-04-11  Richard Guenther  <rguenther@suse.de>
22929
22930         PR middle-end/52621
22931         * tree-chrec.c (evolution_function_is_invariant_rec_p): Properly
22932         consider loop nesting.
22933         (evolution_function_is_univariate_p): Properly check the remainder
22934         for chrecs.
22935
22936 2012-04-11  Richard Guenther  <rguenther@suse.de>
22937
22938         PR middle-end/52918
22939         * except.c (sjlj_emit_dispatch_table): Properly update loop structure.
22940
22941 2012-04-11  Nick Clifton  <nickc@redhat.com>
22942
22943         * config/rl78/rl78.c (rl78_expand_prologue): Set stack use
22944         information, if requested.
22945
22946         * config/rx/rx.c (rx_expand_prologue): Likewise.
22947
22948 2012-04-11  Peter Bergner  <bergner@vnet.ibm.com>
22949             Michael Matz  <matz@suse.de>
22950
22951         PR target/16458
22952         * rtlanal.c (unsigned_reg_p): New function.
22953         Update copyright notice dates.
22954         * rtl.h (unsigned_reg_p): Prototype it.
22955         Update copyright notice dates.
22956         * config/rs6000/rs6000.c (rs6000_generate_compare): Use it.
22957         Update comment.
22958         * expr.c (expand_expr_real_1): Set register attributes.
22959         * stmt.c (expand_case): Likewise.
22960
22961 2012-04-11  Oleg Endo  <olegendo@gcc.gnu.org>
22962
22963         PR target/50751
22964         * config/sh/sh-protos.h (sh_legitimate_index_p): Add new arguments
22965         consider_sh2a and allow_zero.
22966         * config/sh/sh.c (sh_legitimate_index_p): Likewise.
22967         (disp_addr_displacement): New function.
22968         (sh_address_cost): Use disp_addr_displacement function instead
22969         of DISP_ADDR_OFFSET.
22970         (sh_legitimate_address_p): Adapt to changed
22971         sh_legitimate_index_p declaration.
22972         (sh_find_mov_disp_adjust): Remove HImode check.
22973         (sh_secondary_reload): Add HImode case.  Use satisfies_constraint_Sdd,
22974         disp_addr_displacement and max_mov_insn_displacement.
22975         (max_mov_insn_displacement): Remove HImode check.
22976         * config/sh/sh.h (CONST_OK_FOR_K04, CONST_OK_FOR_K12,
22977         DISP_ADDR_P, DISP_ADDR_OFFSET): Remove.
22978         * config/sh/constraints.md (K05, K13): New constraints.
22979         (K12): Correct comment.
22980         (Sdd): Do not use DISP_ADDR_P macro.
22981         (Snd, Sbw): Use satisfies_constraint_Sdd.
22982         * config/sh/sh.md (extendhisi2): Remove constraints from expander.
22983         (*extendhisi2_compact, movhi_i): Remove.
22984         (*extendhisi2_compact_reg, *extendhisi2_compact_mem_disp,
22985         *extendhisi2_compact_mem_disp, *extendhisi2_compact_snd,
22986         *movhi_reg_reg, *movhi_store_mem_disp05, *movhi_store_mem_disp13,
22987         *movhi_load_mem_disp, *movhi_load_mem_disp, *movhi): New insns.
22988         (*extendqisi2_compact_mem_disp, *extendqisi2_compact_mem_disp,
22989         *movqi_store_mem_disp04, *movqi_store_mem_disp12, *movqi_load_mem_disp,
22990         *movqi_load_mem_disp): Use sh_legitimate_index_p instead of
22991         CONST_OK_FOR_Kxx.
22992         Add new peepholes for HImode displacement addressing.
22993
22994 2012-04-11  Oleg Endo  <olegendo@gcc.gnu.org>
22995
22996         * config/sh/sh.h (SIDI_OFF): Remove.
22997         * config/sh/sh.md: Use gen_highpart and gen_lowpart to access
22998         DImode subregs instead of gen_rtx_REG or simplifly_gen_subreg
22999         or operand_subword.
23000
23001 2012-04-11  Eric Botcazou  <ebotcazou@adacore.com>
23002
23003         PR target/52624
23004         * doc/extend.texi (Other Builtins): Document __builtin_bswap16.
23005         (PowerPC AltiVec/VSX Built-in Functions): Remove it.
23006         * doc/md.texi (Standard Names): Add bswap.
23007         * builtin-types.def (BT_UINT16): New primitive type.
23008         (BT_FN_UINT16_UINT16): New function type.
23009         * builtins.def (BUILT_IN_BSWAP16): New.
23010         * builtins.c (expand_builtin_bswap): Add TARGET_MODE argument.
23011         (expand_builtin) <BUILT_IN_BSWAP16>: New case.  Pass TARGET_MODE to
23012         expand_builtin_bswap.
23013         (fold_builtin_bswap): Add BUILT_IN_BSWAP16 case.
23014         (fold_builtin_1): Likewise.
23015         (is_inexpensive_builtin): Likewise.
23016         * optabs.c (expand_unop): Deal with bswap in HImode specially.  Add
23017         missing bits for bswap to libcall code.
23018         * tree.c (build_common_tree_nodes): Build uint16_type_node.
23019         * tree.h (enum tree_index): Add TI_UINT16_TYPE.
23020         (uint16_type_node): New define.
23021         * config/rs6000/rs6000-builtin.def (RS6000_BUILTIN_BSWAP_HI): Delete.
23022         * config/rs6000/rs6000.c (rs6000_expand_builtin): Remove handling of
23023         above builtin.
23024         (rs6000_init_builtins): Likewise.
23025         * config/rs6000/rs6000.md (bswaphi2): Add TARGET_POWERPC predicate.
23026
23027 2012-04-11  Tristan Gingold  <gingold@adacore.com>
23028
23029         * doc/extend.texi (Type Attributes): Move paragraph.
23030
23031 2012-04-11  Manuel López-Ibáñez  <manu@gcc.gnu.org>
23032
23033         PR 24985
23034         * diagnostic.h (show_caret): Declare.
23035         (caret_max_width): Declare.
23036         (diagnostic_show_locus): Declare.
23037         * diagnostic.c (diagnostic_initialize): Initialize to false.
23038         (diagnostic_show_locus): New.
23039         (diagnostic_report_diagnostic): Call it.
23040         (getenv_columns): New.
23041         (adjust_line): New.
23042         (diagnostic_set_caret_max_width): New.
23043         * input.c (read_line): New.
23044         (location_get_source_line): New.
23045         * input.h (location_get_source_line): Declare.
23046         * toplev.c (general_init): Initialize show_caret from options.
23047         * dwarf2out.c (gen_producer_string): Handle fdiagnostics-show-caret.
23048         * opts.c (common_handle_option): Likewise.
23049         * pretty-print.h (pp_get_prefix): New.
23050         (pp_base_get_prefix): New.
23051         * common.opt (fdiagnostics-show-caret): New option.
23052         * doc/invoke.texi (fdiagnostics-show-caret): Document it.
23053
23054 2012-04-11  Richard Guenther  <rguenther@suse.de>
23055
23056         PR rtl-optimization/52881
23057         * ifcvt.c (find_if_case_2): Avoid speculating loop latches.
23058
23059 2012-04-11  Richard Guenther  <rguenther@suse.de>
23060
23061         PR tree-optimization/52912
23062         * tree-ssa-threadupdate.c (thread_block): Tell the cfg
23063         manipulation code we are threading through a loop header
23064         to an exit destination.
23065
23066 2012-04-10  Manuel López-Ibáñez  <manu@gcc.gnu.org>
23067
23068         * tree.h (warn_if_unused_value): Move declaration from here.
23069         * stmt.c (warn_if_unused_value): Move definition from here.
23070
23071 2012-04-10  Michael Matz  <matz@suse.de>
23072
23073         * tree-vectorizer.h (_loop_vec_info.strided_stores): Rename to
23074         grouped_stores.
23075         (LOOP_VINFO_STRIDED_STORES): Rename to LOOP_VINFO_GROUPED_STORES.
23076         (struce _bb_vec_info.strided_stores): Rename to grouped_stores.
23077         (BB_VINFO_STRIDED_STORES): Rename to BB_VINFO_GROUPED_STORES.
23078         (STMT_VINFO_STRIDED_ACCESS): Rename to STMT_VINFO_GROUPED_ACCESS.
23079         (vect_strided_store_supported): Rename to vect_grouped_store_supported.
23080         (vect_strided_load_supported): Rename to vect_grouped_load_supported.
23081         (vect_transform_strided_load): Rename to vect_transform_grouped_load.
23082         (vect_record_strided_load_vectors): Rename to
23083         vect_record_grouped_load_vectors.
23084         * tree-vect-data-refs.c (vect_update_misalignment_for_peel):
23085         Rename use of above macros.
23086         (vect_verify_datarefs_alignment): Ditto.
23087         (vector_alignment_reachable_p): Ditto.
23088         (vect_peeling_hash_get_lowest_cost): Ditto.
23089         (vect_enhance_data_refs_alignment): Ditto.
23090         (vect_analyze_group_access): Ditto and rename stride to groupsize.
23091         (vect_analyze_data_ref_access): Rename "strided" to "grouped".
23092         (vect_strided_store_supported): Rename to vect_grouped_store_supported.
23093         (vect_strided_load_supported): Rename to vect_grouped_load_supported.
23094         (vect_transform_strided_load): Rename to vect_transform_grouped_load.
23095         (vect_record_strided_load_vectors): Rename to
23096         vect_record_grouped_load_vectors.
23097         * tree-vect-loop.c (new_loop_vec_info): Rename use of above macros.
23098         (destroy_loop_vec_info): Ditto.
23099         (vect_transform_loop): Ditto and rename strided_store to grouped_store.
23100         * tree-vect-slp.c (vect_build_slp_tree): Rename use of above macros.
23101         (vect_analyze_slp): Ditto.
23102         (new_bb_vec_info): Ditto.
23103         (destroy_bb_vec_info): Ditto.
23104         (vect_schedule_slp_instance): Ditto and rename strided_store to
23105         grouped_store.
23106         * tree-vect-stmts.c (vect_cost_strided_group_size): Rename to
23107         vect_cost_group_size.
23108         (vect_model_store_cost): Rename use of above macros and call
23109         to vect_cost_strided_group_size.
23110         (vect_model_load_cost): Ditto.
23111         (vectorizable_store): Ditto, rename strided_store to grouped_store
23112         and calls to renamed tree-vectorizer.h functions.
23113         (vectorizable_load): Ditto.
23114         (vect_transform_stmt): Rename use of above macros and strided_store
23115         to grouped_store.
23116
23117 2012-04-10  Jan Hubicka  <jh@suse.cz>
23118
23119         * cgraph.h: Remove misledaing comment on ipa-ref.h.
23120         (symtab_type): New enum.
23121         (symtab_node): New structure.
23122         (cgraph_node, varpool_node): Add symbol base type.
23123         (cgraph, varpool): New accestor functions.
23124         * cgraph.c (cgraph_create_node_1): Set symbol type.
23125         * varpool.c (varpool_node): Set symbol type.
23126
23127 2012-04-10  Ulrich Weigand  <ulrich.weigand@linaro.org>
23128             Richard Sandiford  <rdsandiford@googlemail.com>
23129
23130         * fwprop.c (propagate_rtx): Also set PR_CAN_APPEAR for subregs.
23131
23132 2012-04-10  Richard Guenther  <rguenther@suse.de>
23133
23134         PR middle-end/52888
23135         * gimple-low.c (gimple_check_call_args): Properly account for
23136         compatible aggregate types.
23137
23138 2012-04-10  Richard Guenther  <rguenther@suse.de>
23139
23140         * toplev.h (tree_rest_of_compilation): Remove.
23141         * tree-optimize.c (tree_rest_of_compilation): Likewise.
23142         * cgraph.h (tree_rest_of_compilation): Declare.
23143         * tree-optimize.c (tree_rest_of_compilation): Move ...
23144         * cgraphunit.c (tree_rest_of_compilation): ... here.
23145         * cgraph.c (cgraph_add_new_function): Adjust.
23146         * Makefile.in (tree-optimize.o): Adjust.
23147         (cgraphunit.o): Likewise.
23148
23149 2012-04-10  Ulrich Weigand  <ulrich.weigand@linaro.org>
23150
23151         PR tree-optimization/52870
23152         * tree-vect-patterns.c (vect_recog_widen_mult_pattern): Verify that
23153         presumed pattern statement is within the same loop or basic block.
23154
23155 2012-04-10  Tristan Gingold  <gingold@adacore.com>
23156
23157         * gengtype.c (main): Make uintptr_t a known type.
23158
23159 2012-04-10  Richard Guenther  <rguenther@suse.de>
23160
23161         * tree-pass.h (tree_lowering_passes): Remove.
23162         * tree-optimize.c (tree_lowering_passes): Remove.
23163         * cgraph.c (cgraph_add_new_function): Inline relevant parts
23164         of tree_lowering_passes, avoid redundant call of early local passes.
23165         * cgraphunit.c (cgraph_lower_function): Fold into ...
23166         (cgraph_analyze_function): ... its single caller.  Inline
23167         relevant parts of tree_lowering_passes.
23168
23169 2012-04-09  H.J. Lu  <hongjiu.lu@intel.com>
23170
23171         PR other/52777
23172         * config/pa/pa.opt: Remove SIO and GNU_LD.
23173
23174 2012-04-09  Jan Hubicka  <jh@suse.cz>
23175
23176         PR lto/52722
23177         PR lto/51765
23178         PR lto/52634
23179         * lto-cgraph.c (compute_ltrans_boundary): When alias is in the
23180         boundary, add its target too.
23181         * lto.c (add_references_to_partition): Add also aliased nodes.
23182         (add_cgraph_node_to_partition,
23183         add_varpool_node_to_partition): Work on nodes, not functions/variables;
23184         when adding alias, add also the aliased object.
23185
23186 2012-04-09  Uros Bizjak  <ubizjak@gmail.com>
23187
23188         PR target/52883
23189         * config/i386/predicates.md (x86_64_zext_general_operand): Prevent
23190         VOIDmode immediate operands.
23191         * config/i386/constraints.md (Wz): New constraint.
23192         * config/i386/i386.md (*zero_extendsidi2_rex64): Use Wz instead of Z.
23193
23194 2012-04-09  Eric Botcazou  <ebotcazou@adacore.com>
23195
23196         PR target/52717
23197         * config/sparc/sparc.c (sparc_file_end): Set TREE_PUBLIC explicitly on
23198         the DECL generated for the special GOT helper.
23199
23200 2012-04-09  Oleg Endo  <olegendo@gcc.gnu.org>
23201
23202         * config/sh/constraints.md: Update list of constraints in
23203         comment block.
23204         (Sr0): Remove unused memory constraint.
23205
23206 2012-04-08  Manuel López-Ibáñez  <manu@gcc.gnu.org>
23207
23208         * tree-pretty-print.h: Update comment.
23209
23210 2012-04-08  Oleg Endo  <olegendo@gcc.gnu.org>
23211
23212         * config/sh/sh.md: Use braced string notation where applicable.
23213         (*prefetch_i4, prefetch_m2a): Merge into ...
23214         (*prefetch): ... this new insn.
23215
23216 2012-04-07  Oleg Endo  <olegendo@gcc.gnu.org>
23217
23218         * config/sh/sh.h (high_life_started): Remove
23219         * config/sh/predicates.md (general_movdst_operand): Use
23220         'reload_in_progress' instead of 'high_life_started'.
23221         * config/sh/sh.md (divsi_inv_call, *divsi_inv_call_combine,
23222         divsi_inv_fp): Likewise.
23223
23224 2012-04-07  Oleg Endo  <olegendo@gcc.gnu.org>
23225
23226         * config/sh/sh-protos.h (prepare_move_operands): Return void
23227         instead of int.
23228         * config/sh/sh.c (prepare_move_operands): Likewise.
23229         * config/sh/sh.md: Remove return value checks of prepare_move_operands.
23230
23231 2012-04-07  Oleg Endo  <olegendo@gcc.gnu.org>
23232
23233         * config/sh/sh-protos.h (fp_int_operand, symbol_ref_operand,
23234         general_movsrc_operand, general_movdst_operand, arith_reg_operand,
23235         fp_arith_reg_operand, arith_operand, arith_reg_or_0_operand,
23236         logical_operand, fpscr_operand, fpul_operand, expand_fp_branch,
23237         commutative_float_operator, noncommutative_float_operator,
23238         sh_handle_pragma): Remove.
23239
23240 2012-04-06  Sandra Loosemore  <sandra@codesourcery.com>
23241
23242         * doc/invoke.texi:  Clean up Texinfo markup throughout the file.
23243         Use @option markup on command-line options.  Use @samp markup on
23244         literal keywords to options.  Use @code markup on code fragments.
23245         Use other markup in preference to quotation marks in the text.
23246         Add markup to some passages without any.
23247
23248 2012-04-06  Mike Stump  <mikestump@comcast.net>
23249
23250         * gimple-fold.c (gimple_fold_stmt_to_constant_1): Avoid warning.
23251
23252 2012-04-06  Oleg Endo  <olegendo@gcc.gnu.org>
23253
23254         * config/sh/sh.c (hi_const): Remove.
23255         (find_barrier, sh_reorg): Use satisfies_constraint_I16 instead
23256         of hi_const.
23257
23258 2012-04-06  Oleg Endo  <olegendo@gcc.gnu.org>
23259
23260         * config/sh/sh-protos.h (sh_expand_t_scc): Change return type from int
23261         to bool.
23262         * config/sh/sh.c (sh_expand_t_scc): Likewise.
23263         * config/sh/sh.md (cstoresi4, cstoredi4): Remove GET_CODE checks before
23264         calling sh_expand_t_scc.
23265
23266 2012-04-06  Oleg Endo  <olegendo@gcc.gnu.org>
23267
23268         * config/sh/sh-protos.h (fp_zero_operand, fp_one_operand,
23269         nonpic_symbol_mentioned_p, expand_block_move, expand_ashiftrt,
23270         sh_dynamicalize_shift_p, gen_shl_and, gen_shl_sext, system_reg_operand,
23271         reg_unused_after, sh_can_redirect_branch, sh_need_epilogue, fldi_ok,
23272         sh_hard_regno_rename_ok, sh_cfun_interrupt_handler_p,
23273         sh_cfun_resbank_handler_p, sh_attr_renesas_p, sh_cfun_attr_renesas_p,
23274         check_use_sfunc_addr, sh_contains_memref_p, sh_loads_bankedreg_p,
23275         sh2a_is_function_vector_call): Use bool as return type.
23276         (sh_pass_in_reg_p): Remove.
23277         * config/sh/sh.c (broken_move, mova_p, noncall_uses_reg, high_pressure,
23278         flow_dependent_p, sh2a_function_vector_p, expand_block_move,
23279         expand_ashiftrt, sh_dynamicalize_shift_p, gen_shl_and, gen_shl_sext,
23280         sh_need_epilogue, sh2a_is_function_vector_call, sh_attr_renesas_p,
23281         sh_cfun_attr_renesas_p, sh_cfun_interrupt_handler_p,
23282         sh_cfun_resbank_handler_p, system_reg_operand, fp_zero_operand,
23283         fp_one_operand, fldi_ok, reg_unused_after, sh_can_redirect_branch,
23284         sh_hard_regno_rename_ok, check_use_sfunc_addr, sh_contains_memref_p,
23285         sh_loads_bankedreg_p): Use bool as return type.
23286         (nonpic_symbol_mentioned_p): Use bool as return type.  Remove
23287         'register' modifier.
23288
23289 2012-04-06  Matt Turner  <mattst88@gmail.com>
23290
23291         * doc/install.texi: Correct typo "-mno-lsc" -> "-mno-llsc".
23292
23293 2012-04-06  Eric Botcazou  <ebotcazou@adacore.com>
23294
23295         * config/ia64/ia64.c (ia64_load_pair_ok): Return 0 if the second member
23296         of the destination isn't also a FP_REGS register.
23297
23298 2012-04-05  Teresa Johnson  <tejohnson@google.com>
23299             H.J. Lu  <hongjiu.lu@intel.com>
23300
23301         * config/i386/i386.h (ix86_tune_indices): Add X86_TUNE_LCP_STALL.
23302         * config/i386/i386.md (move immediate to memory peephole2):
23303         Add cases for HImode move when LCP stall avoidance is needed.
23304         * config/i386/i386.c (initial_ix86_tune_features): Initialize
23305         X86_TUNE_LCP_STALL entry.
23306
23307 2012-04-05  Uros Bizjak  <ubizjak@gmail.com>
23308
23309         PR target/52882
23310         * config/i386/i386.c (ix86_decompose_address): Allow VOIDmode
23311         CONST_INT operands, zero-extended with AND.
23312
23313 2012-04-05  Oleg Endo  <olegendo@gcc.gnu.org>
23314
23315         PR target/50751
23316         * config/sh/sh.c (sh_find_mov_disp_adjust): Take machine_mode as the
23317         first argument instead of mode size.  Move displacement calculations
23318         to ...
23319         (mov_insn_size, max_mov_insn_displacement, mov_insn_alignment_mask):
23320         ... these new functions.
23321         (disp_adjust): Remove max_mov_disp field.
23322         (sh_legitimate_index_p): Use max_mov_insn_displacement and
23323         mov_insn_alignment_mask.
23324         (sh_address_cost): Use max_mov_insn_displacement.
23325
23326 2012-04-05  Andrew Stubbs  <ams@codesourcery.com>
23327
23328         * config/arm/arm.md (arch): Add neon_onlya8 and neon_nota8.
23329         (arch_enabled): Handle new arch types.
23330         (one_cmpldi2): Add NEON support.
23331
23332 2012-04-05  Richard Guenther  <rguenther@suse.de>
23333
23334         * gimple.c (walk_gimple_op): Compute val_only for the LHS
23335         of an assigment in the canonical way, avoiding is_gimple_mem_rhs.
23336         (is_gimple_mem_rhs, is_gimple_reg_rhs, is_gimple_stmt): Move ...
23337         * gimplify.c (is_gimple_mem_rhs, is_gimple_reg_rhs, is_gimple_stmt):
23338         ... here and make static.
23339         * gimple.h (is_gimple_mem_rhs, is_gimple_reg_rhs, is_gimple_stmt):
23340         Remove.
23341
23342 2012-04-05  Richard Guenther  <rguenther@suse.de>
23343
23344         * tree-ssa-dse.c (dse_optimize_stmt): Remember the stmt
23345         basic-block before removing it.
23346
23347 2012-04-05  Richard Guenther  <rguenther@suse.de>
23348
23349         * tree-ssanames.c (release_dead_ssa_names): Compact the SSA
23350         version namespace as we release the freelist.
23351
23352 2012-04-05  Richard Guenther  <rguenther@suse.de>
23353
23354         * tree-nrv.c (tree_nrv): Release VDEFs.
23355         * tree-sra.c (sra_modify_constructor_assign): Likewise.
23356         (sra_modify_assign): Likewise.
23357         * tree-vect-stmts.c (vect_remove_stores): Likewise.
23358         * tree-vect-loop.c (vect_transform_loop): Likewise.
23359         * tree-ssa-dom.c (optimize_stmt): Likewise.
23360         * tree-vect-slp.c (vect_schedule_slp): Likewise.
23361         * tree-ssa-math-opts.c (execute_cse_sincos): Likewise.
23362
23363 2012-04-05  Richard Guenther  <rguenther@suse.de>
23364
23365         * gimple-iterator.c (gsi_remove): Return whether EH edges need to be
23366         cleanup.
23367         * gimple.h (gsi_remove): Adjust.
23368         * tree-ssa-operands.c (unlink_stmt_vdef): Optimize.
23369         * tree-ssa-dom.c (optimize_stmt): Use gsi_remove result.
23370         * tree-ssa-dse.c (dse_optimize_stmt): Likewise.
23371         * tree-ssa-forwprop.c (remove_prop_source_from_use): Likewise.
23372         * tree-ssa-math-opts.c (execute_optimize_widening_mul): Likewise.
23373         * tree-ssa-pre.c (eliminate): Likewise.
23374
23375 2012-04-04  Mike Stump  <mikestump@comcast.net>
23376
23377         * doc/rtl.texi (const_double): Document as sign-extending.
23378         * expmed.c (expand_mult): Ensure we don't use shift incorrectly.
23379         * emit-rtl.c (immed_double_int_const): Refine to state the
23380         value is signed.
23381         * simplify-rtx.c (mode_signbit_p): Add a fixme for wider than
23382         CONST_DOUBLE integers.
23383         (simplify_const_unary_operation, UNSIGNED_FLOAT): Ensure no
23384         negative values are converted.  Fix conversions bigger than
23385         HOST_BITS_PER_WIDE_INT.
23386         (simplify_binary_operation_1): Ensure we don't use shift incorrectly.
23387         (simplify_immed_subreg): Sign-extend CONST_DOUBLEs.
23388         * explow.c (plus_constant_mode): Add.
23389         (plus_constant): Implement with plus_constant_mode.
23390         * rtl.h (plus_constant_mode): Add.
23391
23392 2012-04-04  Richard Guenther  <rguenther@suse.de>
23393
23394         PR tree-optimization/52808
23395         * tracer.c (tail_duplicate): Do not tail-duplicate loop header blocks.
23396         * Makefile.in (tracer.o): Depend on $(CFGLOOP_H).
23397
23398 2012-04-04  Tristan Gingold  <gingold@adacore.com>
23399
23400         * expr.c (expand_expr_real_2): Handle larger sizetype in
23401         POINTER_PLUS_EXPR.
23402
23403 2012-04-03  Kaz Kojima  <kkojima@gcc.gnu.org>
23404
23405         * config/sh/t-sh (MULTILIB_MATCHES): Match m2a-single-only
23406         to m2a-single instead of m2e.
23407
23408 2012-04-03  Eric Botcazou  <ebotcazou@adacore.com>
23409
23410         * expr.c (get_bit_range): Add OFFSET parameter and adjust BITPOS.
23411         Change type of BITOFFSET to signed.  Make sure the lower bound of
23412         the computed range is non-negative by adjusting OFFSET and BITPOS.
23413         (expand_assignment): Adjust call to get_bit_range.
23414
23415 2012-04-03  Sandeep Kumar Singh  <Sandeep.Singh2@kpitcummins.com>
23416
23417         * h8300/h8300.c (h8300_current_function_monitor_function_p):
23418         New function. Added to check monitor functions.
23419         (h8300_option_override): Modified to generate error/warning
23420         messages for invalid combinations of different command line
23421         options.
23422         * h8300/h8300.md: Generate 'rte' for monitor functions. Do not
23423         save EXR on stack for monitor function in case of H8S target
23424         when "-mno-exr" is passed.
23425         * h8300/h8300-protos.h (h8300_current_function_monitor_function_p):
23426         Add prototype.
23427         * doc/invoke.texi: Document H8S options.
23428
23429 2012-04-03  Tristan Gingold  <gingold@adacore.com>
23430
23431         * configure.ac: Use GCC_AC_FUNC_MMAP_BLACKLIST instead
23432         of gcc_AC_FUNC_MMAP_BLACKLIST.
23433         * acinclude.m4 (gcc_AC_FUNC_MMAP_BLACKLIST): Remove.
23434         * Makefile.in (aclocal_deps): Add mmap.m4.
23435         * configure: Regenerate.
23436         * aclocal.m4: Regenerate.
23437
23438 2012-04-03  Richard Guenther  <rguenther@suse.de>
23439
23440         PR tree-optimization/52808
23441         * tracer.c (tail_duplicate): Return whether we have duplicated
23442         any block.
23443         (tracer): If we have duplicated any block, cleanup the CFG.
23444         * cfghooks.c (duplicate_block): If we duplicated a loop
23445         header but not its loop, destroy the loop because it now has
23446         multiple entries.
23447         * tree-ssa-threadupdate.c (thread_through_loop_header): Tell
23448         the cfg manipulation routines we are not creating a multiple
23449         entry loop.
23450
23451 2012-04-03  Tristan Gingold  <gingold@adacore.com>
23452
23453         * config/vms/vms-c.c (vms_pragma_nomember_alignment): Handle
23454         'byte' alignment.
23455         (vms_c_common_override_options): Allow parameterless variadic
23456         functions.
23457
23458 2012-04-03  Jakub Jelinek  <jakub@redhat.com>
23459
23460         PR tree-optimization/52835
23461         * tree-data-ref.c (build_rdg): Return NULL if
23462         compute_data_dependences_for_loop failed.
23463
23464 2012-04-03  Eric Botcazou  <ebotcazou@adacore.com>
23465
23466         * varasm.c (initializer_constant_valid_for_bitfield_p): Return true
23467         for REAL_CST as well.
23468         (output_constructor): Use RECORD_OR_UNION_TYPE_P predicate.
23469         In the bitfield case, if the value is a REAL_CST, convert it first to
23470         an INTEGER_CST.
23471
23472 2012-04-02  H.J. Lu  <hongjiu.lu@intel.com>
23473
23474         * config.gcc: Use i386/biarchx32.h instead of i386/biarch64.h
23475         for --with-abi={x32|mx32} or --with-multilib-list=mx32.
23476         (supported_defaults): Add abi for i[34567]86-*-* and x86_64-*-*.
23477
23478         * config/i386/biarchx32.h: New.
23479
23480 2012-04-02  Anatoly Sokolov  <aesok@post.ru>
23481
23482         * config/arm/arm.h (PREFERRED_RELOAD_CLASS): Remove.
23483         * config/arm/arm.c (TARGET_PREFERRED_RELOAD_CLASS): Define.
23484         (arm_preferred_reload_class): New function.
23485
23486 2012-04-02  Richard Guenther  <rguenther@suse.de>
23487
23488         PR tree-optimization/52756
23489         * tree-ssa-threadupdate.c (def_split_header_continue_p): New function.
23490         (thread_through_loop_header): After threading through the loop latch
23491         remove the split part from the loop and clear further threading
23492         opportunities that would create a multiple entry loop.
23493
23494 2012-04-02  Richard Guenther  <rguenther@suse.de>
23495
23496         PR rtl-optimization/52800
23497         * cprop.c (execute_rtl_cprop): Call cleanup_cfg with
23498         CLEANUP_CFG_CHANGED.
23499
23500 2012-04-02  Richard Guenther  <rguenther@suse.de>
23501
23502         PR middle-end/52803
23503         * loop-init.c (gate_handle_loop2): Destroy loops here if
23504         we don't enter RTL loop optimizers.
23505
23506 2012-04-02  Uros Bizjak  <ubizjak@gmail.com>
23507
23508         Partially revert:
23509         2012-03-29  Richard Guenther  <rguenther@suse.de>
23510
23511         * rtl.h (extended_count): Remove.
23512         * combine.c (extended_count): Remove.
23513
23514 2012-04-02  Dodji Seketeli  <dodji@redhat.com>
23515
23516         PR c++/40942
23517         * pt.c (more_specialized_fn):  Don't apply decay conversion to
23518         types of function parameters.
23519
23520 2012-04-02  Tristan Gingold  <gingold@adacore.com>
23521
23522         * ggc-page.c (PAGE_L1_SIZE, PAGE_L2_SIZE, LOOKUP_L1, LOOKUP_L2)
23523         (ggc_allocated_p, lookup_page_table_entry, set_page_table_entry)
23524         (alloc_page, init_ggc, clear_marks, struct ggc_pch_data)
23525         (ggc_pch_this_base): Use uintptr_t instead of size_t.
23526
23527 2012-03-31  H.J. Lu  <hongjiu.lu@intel.com>
23528
23529         PR bootstrap/52784
23530         * config/i386/i386.c (ix86_option_override_internal): Don't
23531         check TARGET_64BIT if TARGET_64BIT_DEFAULT is false.
23532
23533 2012-03-31  Eric Botcazou  <ebotcazou@adacore.com>
23534
23535         * tree-cfg.c (call_can_make_abnormal_goto): New predicate.
23536         (stmt_can_make_abnormal_goto): Use it.
23537         (is_ctrl_altering_stmt): Likewise.
23538
23539 2012-03-30  Naveen H.S  <naveen.S@kpitcummins.com>
23540             Kaz Kojima  <kkojima@gcc.gnu.org>
23541
23542         * config/sh/sh.c (push_regs): Skip banked registers when
23543         resbank attribute is specified.
23544         (sh_expand_epilogue): Likewise.
23545
23546 2012-03-30  Richard Henderson  <rth@redhat.com>
23547
23548         PR debug/52727
23549         * combine-stack-adj.c (prev_active_insn_bb): New.
23550         (next_active_insn_bb): New.
23551         (force_move_args_size_note): New.
23552         (combine_stack_adjustments_for_block): Use it.
23553
23554 2012-03-30  Richard Henderson  <rth@redhat.com>
23555
23556         * config/i386/i386.c (struct expand_vec_perm_d): Add one_operand_p.
23557         (ix86_expand_vector_init_duplicate): Initialize it.
23558         (expand_vec_perm_palignr): Likewise.
23559         (ix86_expand_vec_perm_const): Likewise.
23560         (ix86_vectorize_vec_perm_const_ok): Likewise.
23561         (expand_vec_perm_blend): Use it.
23562         (expand_vec_perm_vpermil): Likewise.
23563         (expand_vec_perm_pshufb): Likewise.
23564         (expand_vec_perm_1): Likewise.
23565         (expand_vec_perm_pshuflw_pshufhw): Likewise.
23566         (expand_vec_perm_interleave2): Likewise.
23567         (expand_vec_perm_vpermq_perm_1): Likewise.
23568         (expand_vec_perm_vperm2f128): Likewise.
23569         (expand_vec_perm_interleave3): Likewise.
23570         (expand_vec_perm_vperm2f128_vblend): Likewise.
23571         (expand_vec_perm_vpshufb2_vpermq): Likewise.
23572         (expand_vec_perm_vpshufb2_vpermq_even_odd): Likewise,.
23573         (expand_vec_perm_broadcast): Likewise.
23574         (expand_vec_perm_vpshufb4_vpermq2): Likewise.
23575
23576 2012-03-30  Richard Henderson  <rth@redhat.com>
23577
23578         * dwarf2out.c (gen_variable_die): Initialize off.
23579
23580 2012-03-30  Tristan Gingold  <gingold@adacore.com>
23581
23582         * config/vms/vms-f.c: New file.
23583         * config/vms/t-vms (vms-f.o): New rule.
23584         * config.gcc (*-*-*vms*): Define fortran_target_objs.
23585
23586 2012-03-30  Richard Guenther  <rguenther@suse.de>
23587
23588         PR tree-optimization/52754
23589         * tree-ssa-forwprop.c (forward_propagate_addr_expr_1): Only
23590         propagate arbitrary addresses into really plain dereferences.
23591
23592 2012-03-30  Richard Guenther <rguenther@suse.de>
23593
23594         PR middle-end/52772
23595         * except.c (emit_to_new_bb_before): Move loop updating ...
23596         (dw2_build_landing_pads): ... here.  Use a proper block for
23597         querying the loop father.
23598
23599 2012-03-30  Tristan Gingold  <gingold@adacore.com>
23600
23601         * config/ia64/ia64.c (ia64_section_type_flags): Remove
23602         common_object attribute handling.
23603         (SECTION_VMS_OVERLAY): Remove
23604         (ia64_vms_common_object_attribute): Replace abort with an assert.
23605         Do not set DECL_SECTION_NAME.
23606         (ia64_vms_output_aligned_decl_common): Handle common_object
23607         attribute.
23608         (ia64_vms_elf_asm_named_section): Remove.
23609         * config/ia64/vms.h (TARGET_ASM_NAMED_SECTION): Remove.
23610
23611 2012-03-30  Richard Guenther  <rguenther@suse.de>
23612
23613         PR middle-end/52786
23614         * double-int.c (rshift_double): Remove not needed cast.
23615
23616 2012-03-30  Richard Guenther  <rguenther@suse.de>
23617
23618         * tree-affine.h (print_aff): Remove.
23619         * tree-affine.c (print_aff): Make static.
23620         * tree-data-ref.h (access_matrix_get_index_for_parameter): Remove.
23621         (get_references_in_stmt): Likewise.
23622         (print_direction_vector): Likewise.
23623         (print_dir_vectors): Likewise.
23624         (print_dist_vectors): Likewise.
23625         (dump_subscript): Likewise.
23626         (dump_ddrs): Likewise.
23627         (dump_dist_dir_vectors): Likewise.
23628         (dump_data_references): Likewise.
23629         (dump_data_dependence_relation): Likewise.
23630         (dump_data_dependence_direction): Likewise.
23631         (dump_rdg_vertex): Likewise.
23632         (dump_rdg_component): Likewise.
23633         (debug_ddrs): Declare.
23634         (struct data_ref_loc_d): Move ...
23635         * tree-data-ref.c (struct data_ref_loc_d): ... here.
23636         (get_references_in_stmt): Make static.
23637         (dump_data_references): Likewise.
23638         (dump_subscript): Likewise.
23639         (print_direction_vector): Likewise.
23640         (print_dir_vectors): Likewise.
23641         (print_dist_vectors): Likewise.
23642         (dump_data_dependence_relation): Likewise.
23643         (dump_dist_dir_vectors): Likewise.
23644         (dump_ddrs): Likewise.
23645         (dump_rdg_vertex): Likewise.
23646         (dump_rdg_component): Likewise.
23647         (debug_ddrs): New function.
23648         (access_matrix_get_index_for_parameter): Remove.
23649
23650 2012-03-30  Tristan Gingold  <gingold@adacore.com>
23651
23652         * config/vms/vms.c (VMS_CRTL_FLOAT32): Rename.
23653         (VMS_CRTL_FLOAT64, VMS_CRTL_FLOAT64_VAXD): New.
23654         (VMS_CRTL_FLOAT128, VMS_CRTL_DPML, VMS_CRTL_NODMPL)
23655         (VMS_CRTL_32ONLY, VMS_CRTL_G_MASK, VMS_CRTL_G_NONE)
23656         (VMS_CRTL_GA, VMS_CRTL_GL, VMS_CRTL_FLOATV2): New.
23657         (vms_patch_builtins): Handle new flags
23658         * config/vms/vms-crtlmap.map: Completed using nm on
23659         c and math system libraries.
23660         * config/vms/make-crtlmap.awk: Handle any number of flags.
23661
23662 2012-03-30  Martin Jambor  <mjambor@suse.cz>
23663
23664         * tree-ssa-ccp.c (insert_clobbers_for_var): Do not assert that there
23665         is a builtin_stack_save in a dominating BB.
23666
23667 2012-03-29  Uros Bizjak  <ubizjak@gmail.com>
23668
23669         * config/i386/sse.md (avx_h<plusminus_insn>v4df3): Fix results
23670         crossing 128bit lane boundary.
23671
23672 2012-03-29  Vladimir Makarov  <vmakarov@redhat.com>
23673
23674         * ira-color.c (setup_left_conflict_sizes_p): Process all
23675         conflicting objects.
23676
23677 2012-03-29  Jakub Jelinek  <jakub@redhat.com>
23678
23679         PR tree-optimization/52760
23680         * tree-vect-slp.c (vect_get_constant_vectors): Convert constant_p
23681         shift count for {L,R}{SHIFT,ROTATE}_EXPR to TREE_TYPE (vector_type).
23682
23683 2012-03-29  Richard Guenther  <rguenther@suse.de>
23684
23685         * cgraph.h (cgraph_materialize_all_clones): Remove.
23686         (reset_inline_failed): Likewise.
23687         * cgraphunit.c (cgraph_materialize_all_clones): Make static.
23688         * cgraphbuild.c (reset_inline_failed): Remove.
23689         * rtl.h (cse_main): Remove.
23690         (extended_count): Likewise.
23691         * cse.c (dump_class): Mark as DEBUG_FUNCTION.
23692         (cse_main): Make static.
23693         * combine.c (extended_count): Remove.
23694         (dump_combine_stats): Mark as DEBUG_FUNCTION.
23695         * basic-block.h (reorder_basic_blocks): Remove.
23696         * bb-reorder.c (reorder_basic_blocks): Make static.
23697         * Makefile.in (dse.o): Remove dse.h dependency.
23698         * dse.h: Remove.
23699         * dse.c (gate_dse): Remove.
23700         (clear_alias_mode_eq): Likewise.
23701         (clear_alias_mode_hash): Likewise.
23702         (dse_record_singleton_alias_set): Likewise.
23703         (dse_invalidate_singleton_alias_set): Likewise.
23704
23705 2012-03-29  H.J. Lu  <hongjiu.lu@intel.com>
23706
23707         * config/linux-android.h (ANDROID_STARTFILE_SPEC): Use
23708         crtbegin_so%O%s for -shared.
23709         (ANDROID_ENDFILE_SPEC): Use crtend_so%O%s for -shared.
23710
23711 2012-03-29  Richard Guenther  <rguenther@suse.de>
23712
23713         * tree-flow.h (struct pre_expr_d): Remove forward declaration.
23714         (add_to_value): Remove.
23715         (print_value_expressions): Likewise.
23716         * tree-ssa-pre.c (add_to_value): Make static.
23717         (print_value_expressions): Likewise.
23718         * gimple.h (gimple_adjust_this_by_delta): Remove.
23719         * gimple-fold.c (gimple_adjust_this_by_delta): Likewise.
23720
23721 2012-03-29  Richard Guenther  <rguenther@suse.de>
23722
23723         PR middle-end/50708
23724         * double-int.h (rshift_double): Remove.
23725         * double-int.c (lshift_double): Use absu_hwi to make count positive.
23726         (rshift_double): Make static, take unsigned count argument,
23727         remove handling of negative count argument.
23728         (double_int_rshift): Dispatch to lshift_double.
23729
23730 2012-03-28  H.J. Lu  <hongjiu.lu@intel.com>
23731
23732         * config/i386/biarch64.h (TARGET_64BIT_DEFAULT): Add
23733         OPTION_MASK_ABI_64.
23734
23735         * config/i386/gnu-user64.h (SPEC_64): Support TARGET_BI_ARCH == 2.
23736         (SPEC_X32): Likewise.
23737         (MULTILIB_DEFAULTS): Likewise.
23738
23739         * config/i386/i386.c (isa_opts): Remove -m64.
23740         (ix86_target_string): Properly handle -m32/-m64/-mx32.
23741         (ix86_option_override_internal): Properly
23742         set OPTION_MASK_ISA_64BIT and OPTION_MASK_ISA_X32 as well as
23743         handle -m32, -m64 and -mx32.
23744
23745         * config/i386/i386.h (TARGET_X32): Replace OPTION_ISA_X32
23746         with OPTION_ABI_X32.  Moved after TARGET_LP64.
23747         (TARGET_LP64): Changed to OPTION_ABI_64.
23748
23749         * config/i386/i386.opt (m64): Replace ISA_64BIT with ABI_64.
23750         (mx32): Replace ISA_X32 with ABI_X32.
23751
23752 2012-03-28  Eric Botcazou  <ebotcazou@adacore.com>
23753
23754         * tree.c (tree_size) <VECTOR_CST>: New case.
23755
23756 2012-03-28  Uros Bizjak  <ubizjak@gmail.com>
23757
23758         * config/i386/i386.c (ix86_modes_tieable_p): Handle 32bit AVX modes.
23759         (ix86_expand_vector_move_misalign): Remove un-needed gen_lowpart calls.
23760
23761 2012-03-28  Jakub Jelinek  <jakub@redhat.com>
23762
23763         PR middle-end/52691
23764         * tree-ssa-ccp.c (optimize_stdarg_builtin): Optimize
23765         __builtin_va_start to __builtin_next_arg if the latter is
23766         builtin_decl_explicit_p rather than when it is not.
23767
23768         PR middle-end/52750
23769         * tree-vect-generic.c (vector_element): Perform multiplication
23770         for pos in bitsizetype type instead of idx type.
23771
23772 2012-03-28  Richard Guenther  <rguenther@suse.de>
23773
23774         * loop-init.c (loop_optimizer_init): If loops are preserved
23775         perform incremental initialization of required loop features.
23776         (loop_optimizer_finalize): If loops are to be preserved only
23777         clean up optional loop features.
23778         (rtl_loop_done): Forcefully free loops here.
23779         * cgraph.c (cgraph_release_function_body): Forcefully free loops.
23780         * cfgexpand.c (expand_gimple_cond): Properly add new basic-blocks
23781         to existing loops.
23782         (construct_init_block): Likewise.
23783         (construct_exit_block): Likewise.
23784         (gimple_expand_cfg): Clear LOOP_CLOSED_SSA loop state.  Cleanup
23785         the CFG after expanding.
23786         * cfgloop.c (verify_loop_structure): Calculate or verify dominators.
23787         If we needed to calculate them, free them afterwards.
23788         * tree-pass.h (PROP_loops): New define.
23789         * tree-ssa-loop.c (pass_tree_loop_init): Provide PROP_loops.
23790         * basic-block.h (CLEANUP_CFG_CHANGED): New.
23791         * cfgcleanup.c (merge_blocks_move): Protect loop latches.
23792         (cleanup_cfg): If we did something and have loops around, fix them up.
23793         * cse.c (rest_of_handle_cse_after_global_opts): Call cleanup_cfg
23794         with CLEANUP_CFG_CHANGED.
23795         * cfghooks.c (merge_blocks): If we merge a loop header into
23796         its predecessor, update the loop structure.
23797         (duplicate_block): If we copy a loop latch, adjust loop state
23798         to note we may have multiple latches.
23799         (delete_basic_block): Mark loops for fixup if we remove a loop.
23800         * cfganal.c (forwarder_block_p): Protect loop latches, headers
23801         and preheaders.
23802         * cfgrtl.c (rtl_can_merge_blocks): Protect loop latches.
23803         (cfg_layout_can_merge_blocks_p): Likewise.
23804         * cprop.c (bypass_block): If we create a loop with multiple
23805         entries, mark it for removal.
23806         * except.c (emit_to_new_bb_before): Add the new basic-block
23807         to existing loops.
23808         * tree-eh.c (lower_resx): Likewise.
23809         * omp-low.c (finalize_task_copyfn): Do not copy PROP_loops.
23810         (expand_omp_taskreg): Likewise.
23811         * tree-inline.c (initialize_cfun): Likewise.
23812         * tree-mudflap.c (add_bb_to_loop): Prototype.
23813         (mf_build_check_statement_for): Properly add new basic-blocks
23814         to existing loops.
23815         * tree-ssa-threadupdate.c (thread_block): Mark loops for fixup
23816         if we remove a loop.
23817         (thread_through_loop_header): Likewise.
23818         * trans-mem.c (tm_log_emit_save_or_restores): Properly add
23819         new basic-blocks to existing loops.
23820         (expand_transaction): Likewise.
23821         * Makefile.in (except.o): Add $(CFGLOOP_H).
23822         (expr.o): Likewise.
23823         (cgraph.o): Likewise.
23824         (cprop.o): Likewise.
23825         (cfgexpand.o): Likewise.
23826         (cfganal.o): Likewise.
23827         (trans-mem.o): Likewise.
23828         (tree-eh.o): Likewise.
23829
23830 2012-03-28  Georg-Johann Lay  <avr@gjlay.de>
23831
23832         PR target/52692
23833         * config/avr/avr.c (TARGET_BUILTIN_DECL): New define.
23834         (avr_builtin_decl): New static function.
23835         (struct avr_builtin_description, avr_bdesc): Move up.
23836         Add GTY marker. Add field fndecl. Remove redundant field id.
23837         (avr_init_builtins): Initialize avr_bdesc[ID].fndecl.
23838         (avr_expand_builtin): Code cleanup because .id is removed.
23839
23840 2012-03-28  Georg-Johann Lay  <avr@gjlay.de>
23841
23842         PR target/52737
23843         * config.gcc (tm_file): Remove avr/multilib.h.
23844
23845         * doc/invoke.texi (AVR Options): Adjust documentation of -mtiny-stack.
23846
23847         * config/avr/genmultilib.awk: Remove code to generate multilib.h.
23848         (BEGIN): Use -msp8 as multilib option instead of -mtiny-stack.
23849         * config/avr/t-avr: Remove generation of multilib.h.
23850         * config/avr/t-multilib: Regenerate.
23851         * config/avr/multilib.h: Remove.
23852         * config/avr/avr.opt (-msp8): New option.
23853         (avr_sp8): New variable.
23854         * config/avr/driver-avr.c (avr_device_to_sp8): New function.
23855         * config/avr/avr.h (AVR_HAVE_SPH): New define.
23856         (AVR_HAVE_8BIT_SP): Also set by avr_sp8 i.e. -msp8.
23857         (avr_device_to_sp8): New prototype.
23858         (EXTRA_SPEC_FUNCTIONS): Add { "device_to_sp8", avr_device_to_sp8 }
23859         (DRIVER_SELF_SPECS): New define.
23860         * config/avr/avr-c.c (avr_cpu_cpp_builtins): New built-in defines:
23861         __AVR_SP8__, __AVR_HAVE_SPH__.
23862         * config/avr/avr.c (output_movhi): Use AVR_HAVE_SPH instead of
23863         AVR_HAVE_8BIT_SP to decide if SP_H is present.
23864         (avr_file_start): Ditto.
23865
23866 2012-03-28  Jakub Jelinek  <jakub@redhat.com>
23867
23868         PR target/52736
23869         * config/i386/sse.md (sse2_loadlpd splitter): Use offset 0
23870         instead of 8 in adjust_address.
23871
23872 2012-03-27  Aurelien Buhrig  <aurelien.buhrig.gcc@gmail.com>
23873
23874         PR middle-end/51893
23875         * expmed.c (store_bit_field_1): Fix wordnum value for big-endian
23876         targets.
23877
23878 2012-03-27  Oleg Endo  <olegendo@gcc.gnu.org>
23879
23880         PR target/50751
23881         * config/sh/sh.c (sh_legitimize_address, sh_legitimize_reload_address):
23882         Rearrange conditional logic.  Move displacement address calculations
23883         to ...
23884         (sh_find_mov_disp_adjust): ... this new function.
23885
23886 2012-03-27  H.J. Lu  <hongjiu.lu@intel.com>
23887
23888         * config/arm/arm.opt (mapcs): Remove MaskExists.
23889         * config/cris/linux.opt (mno-gotplt): Likewise.
23890         * config/i386/i386.opt (mhard-float): Likewise.
23891         (msse4): Likewise.
23892         (mno-sse4): Likewise.
23893         * config/m68k/m68k.opt (mhard-float): Likewise.
23894         * config/mep/mep.op (mcop32): Likewise.
23895         * config/pa/pa-hpux.opt (msio): Likewise.
23896         * config/pa/pa64-hpux.opt (mgnu-ld): Likewise.
23897         * config/picochip/picochip.opt (mlittle): Likewise.
23898         * config/sh/sh.opt (mrenesas): Likewise.
23899         * config/sparc/long-double-switch.opt (mlong-double-128): Likewise.
23900         * config/sparc/sparc.opt (mhard-float): Likewise.
23901         * config/v850/v850.opt (mv850es): Likewise.
23902         * config/vax/vax.opt (mg-float): Likewise.
23903
23904 2012-03-27  Martin Jambor  <mjambor@suse.cz>
23905
23906         PR middle-end/52693
23907         * tree-sra.c (sra_modify_assign): Do not call
23908         load_assign_lhs_subreplacements when working with an unscalarizable
23909         region.
23910
23911 2012-03-27  Uros Bizjak  <ubizjak@gmail.com>
23912
23913         PR target/52698
23914         * config/i386/i386-protos.h (ix86_legitimize_reload_address):
23915         New prototype.
23916         * config/i386/i386.h (LEGITIMIZE_RELOAD_ADDRESS): New define.
23917         * config/i386/i386.c: Include reload.h.
23918         (ix86_legitimize_reload_address): New function.
23919
23920 2012-03-27  H.J. Lu  <hongjiu.lu@intel.com>
23921
23922         * opth-gen.awk: Allocated a bit for Mask and InverseMask if it
23923         hasn't been allocated.  Define a target macro for Mask and
23924         InverseMask if it hasn't been defined.  Remove MaskExists handling.
23925
23926         * doc/options.texi: Remove MaskExists.
23927
23928 2012-03-27  Chung-Lin Tang  <cltang@codesourcery.com>
23929
23930         PR target/52667
23931         * config/sh/sh.c (find_barrier): Add equality check of last_got
23932         to avoid going above orig insn. Update comments.
23933
23934 2012-03-27  Richard Guenther  <rguenther@suse.de>
23935
23936         PR middle-end/52720
23937         * fold-const.c (try_move_mult_to_index): Handle &x.array more
23938         explicitely.
23939
23940 2012-03-27  Eric Botcazou  <ebotcazou@adacore.com>
23941
23942         * expmed.c (store_bit_field): Assert that BITREGION_START is a multiple
23943         of a unit before computing the offset in units.
23944         * expr.c (get_bit_range): Return the null range if the enclosing record
23945         is part of a larger bit field.
23946
23947 2012-03-27  Tristan Gingold  <gingold@adacore.com>
23948
23949         * config/ia64/vms.h (CASE_VECTOR_MODE): Define.
23950         * config/ia64/ia64.md: Remove mode in template.
23951         Sign extend operand in expand_simple_binop.
23952         * config/ia64/ia64.h (ASM_OUTPUT_ADDR_DIFF_ELT): Use
23953         CASE_VECTOR_MODE instead of TARGET_ILP32.
23954         (ADDR_VEC_ALIGN): Make it depends on CASE_VECTOR_MODE.
23955
23956 2012-03-26  Steven Bosscher  <steven@gcc.gnu.org>
23957
23958         * varasm.c (assemble_external): #if 0 out the new assert from the
23959         previous commit, it breaks the Java and Go front ends.
23960
23961 2012-03-26  Steven Bosscher  <steven@gcc.gnu.org>
23962
23963         * toplev.c (check_global_declaration_1): Do not call assemble_external.
23964         * expr.c (emit_block_move_libcall_fn): Likewise.
23965         (clear_storage_libcall_fn): Likewise.
23966         (expand_expr_addr_expr_1): Likewise.
23967         (expand_expr_real_1): Likewise.
23968         * calls.c (rtx_for_function_call): Likewise.
23969
23970         * varasm.c (assemble_external): Assert this function is only called
23971         during or after expanding to RTL.
23972
23973 2012-03-26  Martin Jambor  <mjambor@suse.cz>
23974
23975         PR tree-optimization/50052
23976         * tree-sra.c (tree_non_aligned_mem_p): Removed.
23977         (tree_non_aligned_mem_for_access_p): Likewise.
23978         (build_accesses_from_assign): Removed strict alignment requirements
23979         checks.
23980         (access_precludes_ipa_sra_p): Likewise.
23981
23982 2012-03-26  Richard Guenther  <rguenther@suse.de>
23983
23984         PR tree-optimization/52701
23985         * tree-vect-loop.c (vect_analyze_scalar_cycles_1): Always
23986         compute and set the evolution part of PHI nodes.
23987
23988 2012-03-26  Richard Guenther  <rguenther@suse.de>
23989
23990         PR tree-optimization/52721
23991         * tree-vect-stmts.c (vect_init_vector): Handle scalars.
23992
23993 2012-03-26  Ulrich Weigand  <ulrich.weigand@linaro.org>
23994
23995         PR tree-optimization/52686
23996         * tree-vect-data-refs.c (vect_get_smallest_scalar_type): Handle
23997         WIDEN_LSHIFT_EXPR.
23998
23999 2012-03-26  Tristan Gingold  <gingold@adacore.com>
24000
24001         * config/alpha/vms.h (LINK_SPEC): Simplify.
24002         (STARTFILE_SPEC): Remove -mvms-return-codes handling.
24003         (NAME__MAIN, SYMBOL__MAIN): Remove.
24004         (VMS_DEBUG_MAIN_POINTER): Remove.
24005         * config/ia64/vms.h: Likewise.
24006         * config/alpha/alpha.c (alpha_start_function): Move vms_debug_main
24007         code to vms.c.  Call vms_start_function.
24008         * config/ia64/ia64.c (ia64_start_function): Likewise.
24009         * config/vms/vms-protos.h (vms_start_function): Declare.
24010         * config/vms/vms.c (vms_start_function): New function.
24011         * config/vms/vms.h (MATH_LIBRARY): Define.
24012         (VMS_DEBUG_MAIN_POINTER): Define.
24013
24014 2012-03-26  Eric Botcazou  <ebotcazou@adacore.com>
24015
24016         PR rtl-optimization/52629
24017         * reload1.c (count_pseudo): Short-circuit common case.
24018         (count_spilled_pseudo): Return early for pseudos without hard regs.
24019         Assert that the pseudo has got a hard reg before manipulating it.
24020
24021 2012-03-24  Jan Hubicka  <jh@suse.cz>
24022
24023         PR lto/51663
24024         * varpool.c (varpool_finalize_decl): Handle toplevel_reorder here.
24025         (decide_is_variable_needed): Do not handle toplevel reorder here.
24026         * cgraph.h (varpool_can_remove_if_no_refs): Likewise.
24027         * ipa.c (cgraph_remove_unreachable_nodes): Remove unreachable vars
24028         even at -O0.
24029
24030 2012-03-24  Eric Botcazou  <ebotcazou@adacore.com>
24031
24032         * expr.c (optimize_bitfield_assignment_op) <BIT_IOR_EXPR>: Use str_mode
24033         and str_bitsize instead of more convoluted expressions.
24034
24035 2012-03-24  Eric Botcazou  <ebotcazou@adacore.com>
24036
24037         PR target/52610
24038         * config/sparc/sparc.h (ASM_CPU_SPEC): Pass -Av8 if -mcpu=leon.
24039
24040 2012-03-24  Eric Botcazou  <ebotcazou@adacore.com>
24041
24042         PR target/52656
24043         * config/sparc/sparc.c (sparc_handle_vis_mul8x16): Fix pasto.
24044
24045 2012-03-23  Martin Jambor  <mjambor@suse.cz>
24046
24047         * tree-sra.c (build_accesses_from_assign): Remove FIXME comment.
24048
24049 2012-03-23  Richard Guenther  <rguenther@suse.de>
24050
24051         PR tree-optimization/52678
24052         * tree-vectorizer.h (struct _stmt_vec_info): Add
24053         loop_phi_evolution_part member.
24054         (STMT_VINFO_LOOP_PHI_EVOLUTION_PART): New define.
24055         * tree-vect-loop.c (vect_analyze_scalar_cycles_1): Initialize
24056         STMT_VINFO_LOOP_PHI_EVOLUTION_PART.
24057         * tree-vect-loop-manip.c (vect_update_ivs_after_vectorizer):
24058         Use the cached evolution part and the PHI nodes value from
24059         the loop preheader edge instead of re-analyzing the evolution.
24060
24061 2012-03-22  Maxim Kuvyrkov  <maxim@codesourcery.com>
24062
24063         * config/mips/mips-tables.opt: Update.
24064         * config/mips/mips.md (processor): Add xlp.
24065         * config/mips/mips-cpus.def: Add xlp.
24066         * config/mips/mips.c (mips_rtx_cost_data): Add costs for XLP, copy from
24067         5KF for now.
24068         * config/mips/mips.h (MIPS_ISA_LEVEL_SPEC): Handle xlp.
24069         * doc/invoke.texi: Mention XLP.
24070
24071 2012-03-22  Jakub Jelinek  <jakub@redhat.com>
24072
24073         PR middle-end/52547
24074         * tree-nested.c (convert_tramp_reference_stmt): Call declare_vars
24075         on any new_local_var_chain vars declared during recursing on
24076         GIMPLE_OMP_PARALLEL or GIMPLE_OMP_TASK body.
24077
24078 2012-03-22  Uros Bizjak  <ubizjak@gmail.com>
24079
24080         * config/alpha/alpha.h (ASM_OUTPUT_ALIGN): Move to config/alpha/elf.h
24081         (ASM_OUTPUT_SKIP): Move to config/alpha/vms.h
24082         (ASM_OUTPUT_LOCAL): Ditto.
24083         (ASM_OUTPUT_COMMON): Remove.
24084         * config/alpha/elf.h (ASM_OUTPUT_DEF_FROM_DECLS): Use ASM_OUTPUT_DEF.
24085         * config/alpha/vms.h (ASM_OUTPUT_ALIGN): Do not undefine before define.
24086
24087 2012-03-22  Jan Hubicka  <jh@suse.cz>
24088
24089         PR middle-end/51737
24090         * cgraph.c (cgraph_remove_node_and_inline_clones): Add FORBIDDEN_NODE
24091         parameter.
24092         * cgraph.h (cgraph_remove_node_and_inline_clones): Update prototype.
24093         * ipa-inline-transform.c (save_inline_function_body): Remove
24094         copied clone if needed.
24095         * tree-inline.c (delete_unreachable_blocks_update_callgraph): Update.
24096
24097 2012-03-22  Richard Guenther  <rguenther@suse.de>
24098
24099         PR middle-end/52666
24100         * fold-const.c (fold_ternary_loc): Fix typo.
24101
24102 2012-03-22  Georg-Johann Lay  <avr@gjlay.de>
24103
24104         PR target/52496
24105         * config/avr/avr.md (unspec): Remove UNSPEC_MEMORY_BARRIER.
24106         (unspecv): Add UNSPECV_MEMORY_BARRIER.
24107         (cli_sei): Use unspec_volatile instead of unspec for memory barrier.
24108         (delay_cycles_1, delay_cycles_2): Ditto.
24109         (delay_cycles_3, delay_cycles_4): Ditto.
24110         (nopv, *nopv): Ditto.
24111         (sleep, *sleep): Ditto.
24112         (wdr, *wdr): Ditto.
24113
24114 2012-03-22  Richard Guenther  <rguenther@suse.de>
24115
24116         PR tree-optimization/52548
24117         * tree-ssa-pre.c (valid_in_sets): Remove handling of invalidation
24118         because of clobbers.
24119         (prune_clobbered_mems): New function.
24120         (compute_antic_aux): Use it to prune ANTIC_OUT.
24121         (compute_partial_antic_aux): Use it to prune PA_IN.
24122         (compute_avail): Only insert expressions into EXP_GEN that are not
24123         invalidated when translated up to the beginning of the block.
24124
24125 2012-03-22  Richard Guenther  <rguenther@suse.de>
24126
24127         PR tree-optimization/52638
24128         * tree-vect-stmts.c (vect_init_vector_1): New function, split
24129         out from ...
24130         (vect_init_vector): ... here.  Handle scalar vector inits.
24131         (vect_get_vec_def_for_operand): Adjust.
24132         (vectorizable_load): Likewise.
24133
24134 2012-03-22  Uros Bizjak  <ubizjak@gmail.com>
24135
24136         * config.gcc (alpha*-*-linux*): Add elfos.h to tm_file.
24137         (alpha*-*-freebsd*): Ditto.
24138         (alpha*-*-netbsd*): Ditto.
24139         (alpha*-*-openbsd*): Ditto.
24140         * config/alpha/elf.h (OBJECT_FORMAT_ELF): Remove.
24141         (DWARF2_DEBUGGING_INFO): Remove.
24142         (PREFERRED_DEBUGGING_TYPE): Remove.
24143         (ASM_FINAL_SPEC): Remove.
24144         (IDENT_ASM_OP): Remove.
24145         (ASM_OUTPUT_IDENT): Remove.
24146         (SKIP_ASM_OP): Remove.
24147         (ASM_OUTPUT_SKIP): Remove.
24148         (ALIGN_ASM_OP): Remove.
24149         (ASM_OUTPUT_BEFORE_CASE_LABEL): Remove.
24150         (ASM_OUTPUT_CASE_LABEL): Remove.
24151         (ASM_OUTPUT_EXTERNAL_LIBCALL): Remove.
24152         (COMMON_ASM_OP): Remove.
24153         (ASM_OUTPUT_ALIGNED_COMMON): Remove.
24154         (ASCII_DATA_ASM_OP): Remove.
24155         (READONLY_DATA_SECTION_ASM_OP): Remove.
24156         (INIT_SECTION_ASM_OP): Remove.
24157         (FINI_SECTION_ASM_OP): Remove.
24158         (ASM_SECTION_START_OP): Remove.
24159         (ASM_OUTPUT_SECTION_START_FILE): Remove.
24160         (TARGET_ASM_NAMED_SECTION): Remove.
24161         (TARGET_ASM_SELECT_SECTION): Remove.
24162         (MAKE_DECL_ONE_ONLY): Remove.
24163         (TYPE_ASM_OP): Remove.
24164         (SIZE_ASM_OP): Remove.
24165         (ASM_WEAKEN_LABEL): Remove.
24166         (TYPE_OPERAND_FMT): Remove.
24167         (ASM_DECLARE_RESULT): Remove.
24168         (ASM_DECLARE_OBJECT_NAME): Remove.
24169         (ASM_FINISH_DECLARE_OBJECT): Remove.
24170         (ELF_ASCII_ESCAPES): Remove.
24171         (ELF_STRING_LIMIT): Remove.
24172         (STRING_ASM_OP): Remove.
24173         (ASM_OUTPUT_EXTERNAL): Remove.
24174         (TARGET_ASM_FILE_START_FILE_DIRECTIVE): Redefine to false.
24175         * config/alpha/alpha.h (PCC_BITFIELD_TYPE_MATTERS): Undefine
24176         before define.
24177         (ASM_DECLARE_FUNCTION_NAME): Ditto.
24178         (ASM_DECLARE_FUNCTION_SIZE): Ditto.
24179         (ASM_GENERATE_INTERNAL_LABEL): Ditto.
24180         (ASM_OUTPUT_SKIP): Ditto.
24181         (READONLY_DATA_SECTION_ASM_OP): Remove.
24182         (USER_LABEL_PREFIX): Remove.
24183         (ASM_OUTPUT_ASCII): Remove.
24184         (ASM_OUTPUT_CASE_LABEL): Remove.
24185         (NO_DOLLAR_IN_LABEL): Undefine.
24186
24187 2012-03-22  Richard Guenther  <rguenther@suse.de>
24188
24189         PR tree-optimization/52459
24190         * tree-ssa-pre.c (inhibit_phi_insertion): Do not inhibit
24191         PHI insertion for calls.
24192
24193 2012-03-21  Steven Bosscher  <steven@gcc.gnu.org>
24194
24195         * cse.c (invalidate_from_sets_and_clobbers, try_back_substitute_reg,
24196         find_sets_in_insn, canonicalize_insn): Split out from ...
24197         (cse_insn): ... here.
24198         (invalidate_from_clobbers): Take an insn instead of the pattern.
24199
24200 2012-03-21  Oleg Endo  <olegendo@gcc.gnu.org>
24201
24202         PR target/52479
24203         * config/sh/sh-protos.h (sh_fsca_df2int): Remove.
24204         * config/sh/sh.c (sh_fsca_df2int_rtx, sh_fsca_df2int): Remove.
24205         * config/sh/sh.md (sindf2, cosdf2): Remove.
24206
24207 2012-03-21  Kaz Kojima  <kkojima@gcc.gnu.org>
24208
24209         PR target/52642
24210         * config/sh/sh.c (sh_expand_prologue): Emit blockage at the end of
24211         prologue for unwinder and profiler.
24212
24213 2012-03-21  Andreas Tobler  <andreast@fgznet.ch>
24214
24215         * configure.ac (HAVE_LD_NO_DOT_SYMBOLS): Add powerpc64-*-freebsd*.
24216         Introduce emul_name to select the right linker emulation for
24217         powerpc64-*-freebsd*.
24218         * configure: Regenerate.
24219         * config.gcc: Add bits to support powerpc64-*-freebsd*.
24220         * config/rs6000/freebsd.h (POWERPC_FREEBSD): Define.
24221         * config/rs6000/freebsd64.h: New file.
24222         * config/rs6000/rs6000.c (rs6000_option_override_internal): Use
24223         POWERPC_FREEBSD.
24224         (rs6000_savres_strategy): Likewise.
24225         (rs6000_savres_routine_name): Likewise.
24226         (rs6000_elf_file_end): Likewise.
24227         * config/rs6000/t-freebsd64: New file.
24228         * config/rs6000/sysv4.h (SUBTARGET_OVERRIDE_OPTIONS): Set the
24229         rs6000_current_abi for 64-bit FreeBSD to ABI_AIX.
24230
24231         * config/rs6000/freebsd64.h: Remove duplicated entries from last
24232         commit.
24233         * config/rs6000/t-freebsd64: Likewise.
24234
24235 2012-03-21  Georg-Johann Lay  <avr@gjlay.de>
24236
24237         PR rtl-optimization/52543
24238         PR target/52461
24239         * config/avr/avr-protos.h (avr_load_lpm): New prototype.
24240         * config/avr/avr.c (avr_mode_dependent_address_p): New function.
24241         (TARGET_MODE_DEPENDENT_ADDRESS_P): New define.
24242         (avr_load_libgcc_p): Restrict to __flash loads.
24243         (avr_out_lpm): Only handle 1-byte loads from __flash.
24244         (avr_load_lpm): New function.
24245         (avr_find_unused_d_reg): Remove.
24246         (avr_out_lpm_no_lpmx): Remove.
24247         (adjust_insn_length): Handle ADJUST_LEN_LOAD_LPM.
24248         * config/avr/avr.md (unspec): Add UNSPEC_LPM.
24249         (load_<mode>_libgcc): Use UNSPEC_LPM instead of MEM.
24250         (load_<mode>, load_<mode>_clobber): New insns.
24251         (mov<mode>): For multi-byte move from non-generic
24252         16-bit address spaces: Expand to load_<mode> resp.
24253         load_<mode>_clobber.
24254         (load<mode>_libgcc): Remove expander.
24255         (split-lpmx): Remove split.
24256
24257 2012-03-21  Richard Earnshaw  <rearnsha@arm.com>
24258
24259         * neon.md (neon_vget_lanev2di): Use gen_lowpart and gen_highpart.
24260         * config/arm/neon.ml (Fixed_return_reg): Renamed to fixed_vector_reg.
24261         All callers changed.
24262         (Fixed_core_reg): New feature.
24263         (Vget_lane [sizes S64 and U64]): Add Fixed_core_reg.  Allow fmrrd in
24264         disassembly.
24265         * neon-testgen.ml: Handle Fixed_core_reg.
24266
24267 2012-03-21  Andrew Stubbs  <ams@codesourcery.com>
24268
24269         * config/arm/arm.c (thumb2_reorg): Add complete support
24270         for 16-bit instructions.
24271         * config/arm/thumb2.md: Delete obsolete flag-clobbering peepholes.
24272
24273 2012-03-21  Richard Guenther  <rguenther@suse.de>
24274
24275         PR tree-optimizer/52636
24276         * tree-vect-slp.c (vect_get_constant_vectors): Convert constants
24277         to the appropriate type.
24278
24279 2012-03-21  Richard Guenther  <rguenther@suse.de>
24280
24281         * Makefile.in (cfgexpand.o): Add $(REGS_H) and $(INTEGRATE_H)
24282         dependencies.
24283         * cfgexpand.c (gimple_expand_cfg): Fold in pass_init_function,
24284         pass_jump, pass_initial_value_sets and pass_unshare_all_rtl.
24285         * passes.c (init_optimization_passes): Remove pass_init_function,
24286         pass_jump, pass_initial_value_sets and pass_unshare_all_rtl.
24287         * tree-pass.h (pass_init_function): Remove.
24288         (pass_jump): Remove.
24289         (pass_initial_value_sets): Remove.
24290         (pass_unshare_all_rtl): Remove.
24291         * integrate.c (pass_initial_value_sets): Remove.
24292         * emit-rtl.c (pass_unshare_all_rtl): Remove.
24293         * tree.h (init_function_for_compilation): Remove.
24294         * function.c (init_function_for_compilation): Remove.
24295         (pass_init_function): Remove.
24296         * cfgcleanup.c (rest_of_handle_jump): Remove.
24297         (pass_jump): Remove.
24298
24299 2012-03-20  Jason Merrill  <jason@redhat.com>
24300
24301         * tree-streamer-in.c (streamer_alloc_tree): Call
24302         ggc_alloc_zone_cleared_tree_node instead of
24303         ggc_alloc_zone_cleared_tree_node_stat.
24304
24305 2012-03-20  Jonathan Wakely  <jwakely.gcc@gmail.com>
24306
24307         * doc/extend.texi (Template Instantiation): Remove anachronisms.
24308
24309 2012-03-20  Jakub Jelinek  <jakub@redhat.com>
24310
24311         PR target/52607
24312         * config/i386/i386.c (expand_vec_perm_vperm2f128): New function.
24313         (ix86_expand_vec_perm_const_1): Call it.
24314
24315         * config/i386/i386.c (vselect_insn): New variable.
24316         (init_vselect_insn): New function.
24317         (expand_vselect, expand_vselect_insn): Add testing_p argument.
24318         Call init_vselect_insn if vselect_insn is NULL.  Adjust
24319         PATTERN (vselect_insn), instead of creating a new insn each time,
24320         only emit a copy of it if not testing and recog has been successful.
24321         (expand_vec_perm_pshufb, expand_vec_perm_1,
24322         expand_vec_perm_pshuflw_pshufhw, expand_vec_perm_broadcast_1): Adjust
24323         callers.
24324
24325         PR target/52607
24326         * config/i386/i386.md ("isa" attribute): Add avx2 and noavx2.
24327         ("enabled" attribute): Handle avx2 and noavx2 isas.
24328         * config/i386/sse.md (avx2_vec_dupv8sf_1, avx2_pbroadcast<mode>_1):
24329         New insns.
24330         (vec_dup<mode>): Add avx2 =x,x alternative.
24331         (vec_dup<mode> splitter): Don't split if TARGET_AVX2.
24332         (*avx_vperm_broadcast_<mode>): Don't split V4DFmode if TARGET_AVX2.
24333         For TARGET_AVX2, V8SFmode and elt == 0 split into vbroadcastss.
24334         * config/i386/i386.c (expand_vec_perm_pshufb): Emit also vpermps
24335         for V8SFmode.
24336         (expand_vec_perm_1): For broadcasts, use avx2_pbroadcast<mode>_1
24337         if possible, handle also V8SFmode.
24338
24339 2012-03-20  Richard Earnshaw  <rearnsha@arm.com>
24340
24341         * arm/predicates.md (zero_operand, reg_or_zero_operand): New predicates.
24342         * arm/neon.md (neon_vceq<mode>, neon_vcge<mode>): Use
24343         reg_or_zero_operand predicate.
24344         (neon_vcle<mode>, neon_vclt<mode>): Use zero_operand predicate.
24345
24346 2012-03-20  Jakub Jelinek  <jakub@redhat.com>
24347
24348         * config/i386/i386.c (ix86_decompose_address) <case ZERO_EXTEND>:
24349         If operand isn't UNSPEC, return 0.
24350
24351 2012-03-20  Richard Guenther  <rguenther@suse.de>
24352
24353         * tree-pass.h (pass_rtl_eh): Remove.
24354         * except.c (gate_handle_eh): Likewise.
24355         (rest_of_handle_eh): Likewise.
24356         (pass_rtl_eh): Likewise.
24357         (finish_eh_generation): Export.
24358         * except.h (finish_eh_generation): Declare.
24359         * passes.c (init_optimization_passes): Remove pass_rtl_eh.
24360         * cfgexpand.c (gimple_expand_cfg): Call finish_eh_generation
24361         after expanding stack alignment.  Instead of compacting blocks
24362         call cleanup_cfg.
24363
24364 2012-03-20  Richard Guenther  <rguenther@suse.de>
24365
24366         * stor-layout.c (finish_bitfield_representative): Fallback
24367         to conservative maximum size if the padding up to the next
24368         field cannot be computed as a constant.
24369         (finish_bitfield_layout): If we cannot compute the distance
24370         between the start of the bitfield representative and the
24371         bitfield member start a new representative.
24372         * expr.c (get_bit_range): The distance between the start of
24373         the bitfield representative and the bitfield member is zero
24374         if the field offsets are not constants.
24375
24376 2012-03-20  Tristan Gingold  <gingold@adacore.com>
24377
24378         * tree.h (enum size_type_kind): Add stk_ prefix to constants,
24379         convert in lowercase.
24380         (sizetype_tab, sizetype, bitsizetype, ssizetype, sbitsizetype)
24381         (size_int, ssize_int, bitsize_int, sbitsize_int): Adjust.
24382         * stor-layout.c (sizetype_tab): Adjust.
24383         (initialize_sizetypes): Use SIZETYPE instead of SIZE_TYPE.
24384         * tree-streamer.c (preload_common_nodes): Use stk_type_kind_last
24385         instead of type_kind_last.
24386         * tree-scalar-evolution.c (interpret_rhs_expr): Use size_int
24387         instead of size_int_kind.
24388         * doc/tm.texi.in (Type Layout): Document SIZETYPE.
24389         * doc/tm.texi: Regenerate.
24390         * defaults.h (SIZETYPE): Provide a default value.
24391         * config/vms/vms.h (SIZE_TYPE): Define as "unsigned int".
24392         (SIZETYPE): Define.
24393
24394 2012-03-20  Oleg Endo  <olegendo@gcc.gnu.org>
24395
24396         * config/sh/sh.md: Use braced string notation where applicable.
24397
24398 2012-03-19  Uros Bizjak  <ubizjak@gmail.com>
24399
24400         * config/i386/i386.md (allocate_stack): Simplify.
24401
24402 2012-03-19  Uros Bizjak  <ubizjak@gmail.com>
24403
24404         * builtins.c (expand_builtin_cexpi): Use copy_addr_to_reg instead of
24405         copy_to_mode_reg (Pmode, ...).
24406         (expand_builtin_frame_address): Ditto.
24407         * expr.c (emit_block_move_via_libcall): Ditto.
24408         (set_storage_via_libcall): Ditto.
24409
24410         * config/i386/i386.c (ix86_expand_movmem): Ditto.
24411         (ix86_expand_setmem): Ditto.
24412         (ix86_trampoline_init): DItto.
24413         * config/i386/i386.md (cmpstrnsi): Ditto.
24414
24415 2012-03-19  Sandra Loosemore  <sandra@codesourcery.com>
24416
24417         * config/sh/sh.opt (madjust-unroll): Mark as ignored/obsolete.
24418         * config/sh/sh.h (TARGET_OPT_DEFAULT): Don't use MASK_ADJUST_UNROLL.
24419         * doc/invoke.texi (Option Summary): Remove -madjust-unroll.
24420         (SH Options): Likewise.
24421
24422 2012-03-19  Uros Bizjak  <ubizjak@gmail.com>
24423
24424         * config/i386/i386.c (get_thread_pointer): Add tp_mode argument.
24425         Generate ZERO_EXTEND in place if GET_MODE (tp) != tp_mode.
24426         (legitimize_tls_address) <TLS_MODEL_INITIAL_EXEC>: Always generate
24427         DImode UNSPEC_GOTNTPOFF references on TARGET_64BIT.
24428         (ix86_decompose_address): Allow zero extended UNSPEC_TP references.
24429
24430         Revert:
24431         2012-03-13  Uros Bizjak  <ubizjak@gmail.com>
24432
24433         * config/i386/i386.h (TARGET_TLS_INDIRECT_SEG_REFS): New.
24434         * config/i386/i386.c (ix86_decompose_address): Use
24435         TARGET_TLS_INDIRECT_SEG_REFS to prevent %fs:(%reg) addresses.
24436         (legitimize_tls_address): Use TARGET_TLS_INDIRECT_SEG_REFS to load
24437         thread pointer to a register.
24438
24439         Revert:
24440         2012-03-10  H.J. Lu  <hongjiu.lu@intel.com>
24441
24442         * config/i386/i386.c (ix86_decompose_address): Disallow fs:(reg)
24443         if Pmode != word_mode.
24444         (legitimize_tls_address): Call gen_tls_initial_exec_x32 if
24445         Pmode == SImode for TARGET_X32.
24446
24447         * config/i386/i386.md (UNSPEC_TLS_IE_X32): New.
24448         (tls_initial_exec_x32): Likewise.
24449
24450 2012-03-19  Oleg Endo  <olegendo@gcc.gnu.org>
24451
24452         PR target/50751
24453         * config/sh/sh.h (CONST_OK_FOR_K04, CONST_OK_FOR_K12, DISP_ADDR_P,
24454         DISP_ADDR_OFFSET): New macros.
24455         * config/sh/sh.c (sh_address_cost): Add SH2A special case.
24456         (sh_legitimate_index_p): Allow QImode displacements for non-SH2A.
24457         (sh_legitimize_address): Add QImode displacement handling.
24458         (sh_cannot_change_mode_class): Disallow GENERAL_REGS for SFmode
24459         vector subregs.
24460         (sh_secondary_reload): Add QImode displacement handling.
24461         * config/sh/predicates.md (movsrc_no_disp_mem_operand): New predicate.
24462         * config/sh/constraints.md (K04, Snd, Sdd): New constraints.
24463         * config/sh/sh.md (extendqisi2): Remove constraints from expander.
24464         (*extendqisi2_compact): Rename to *extendqisi2_compact_reg, restrict
24465         to register operands only.
24466         (*extendqisi2_compact_mem_disp, *extendqisi2_compact_snd): New insns.
24467         (extendqihi2): Change insn to expander.
24468         (*extendqihi2_compact_reg): New insn.
24469         (movqi_i, movqi): Replace with ...
24470         (movqi, *movqi_reg_reg, *movqi_store_mem_disp12,
24471         *movqi_load_mem_disp, *movqi_load_mem_disp): ... these.
24472         Add new peepholes for QImode displacement addressing.
24473
24474 2012-03-19  Paolo Carlini  <paolo.carlini@oracle.com>
24475
24476         PR c++/14710
24477         * doc/invoke.texi: Document -Wuseless-cast.
24478
24479 2012-03-19  Eric Botcazou  <ebotcazou@adacore.com>
24480
24481         * tree.def (REALPART_EXPR, IMAGPART_EXPR, VIEW_CONVERT_EXPR): Move.
24482         * tree.h (handled_component_p): Reorder cases.
24483         * dwarf2out.c (loc_list_for_address_of_addr_expr_of_indirect_ref): Do
24484         not initialize unsignedp.
24485         (loc_list_from_tree): Likewise.
24486         (fortran_common): Likewise.
24487         * simplify-rtx.c (delegitimize_mem_from_attrs): Likewise.
24488
24489 2012-03-19  Uros Bizjak  <ubizjak@gmail.com>
24490
24491         * config/i386/i386.c (ix86_expand_prologue) <CM_LARGE_PIC>: Use Pmode
24492         mode consistently.  Use ix86_gen_add3.  Assert that Pmode == DImode.
24493         (ix86_expand_split_stack_prologue): Use ix86_gen_add3.
24494         (ix86_split_long_move): Ditto.
24495         (legitimize_tls_address): Use ix86_gen_sub3.
24496         (construct_plt_address): Assert that Pmode == DImode.
24497
24498 2012-03-18  Uros Bizjak  <ubizjak@gmail.com>
24499
24500         * config/i386/i386.md: Remove empty predicates and/or constraints.
24501         * config/i386/sync.md: Ditto.
24502         * config/i386/sse.md: Ditto.
24503         * config/i386/mmx.md: Ditto.
24504         * config/i386/pentium.md: Ditto.
24505         * config/i386/athlon.md: Ditto.
24506
24507 2012-03-16  Richard Guenther  <rguenther@suse.de>
24508
24509         PR tree-optimization/52603
24510         * tree-vect-data-refs.c (vect_can_force_dr_alignment_p): Clarify
24511         comment.
24512
24513         Revert
24514         2012-03-14  Richard Guenther  <rguenther@suse.de>
24515
24516         PR tree-optimization/52571
24517         * tree-vect-data-refs.c (vect_compute_data_ref_alignment): Move
24518         flag_section_anchors check ...
24519         (vect_can_force_dr_alignment_p): ... here.
24520
24521 2012-03-16  Martin Jambor  <mjambor@suse.cz>
24522
24523         * expr.c (expand_expr_real_1): Handle misaligned scalar reads from
24524         memory through MEM_REFs by calling extract_bit_field.
24525
24526 2012-03-16  Richard Guenther  <rguenther@suse.de>
24527
24528         * fold-const.c (native_interpret_expr): Also support POINTER_TYPE
24529         and REFERENCE_TYPE interpretations.
24530         (can_native_interpret_type_p): New function.
24531         (fold_ternary_loc): Use native encode/interpret to fold
24532         BIT_FIELD_REFs of constants.
24533
24534 2012-03-16  Richard Guenther  <rguenther@suse.de>
24535
24536         PR middle-end/52584
24537         * fold-const.c (fold_ternary_loc): Fold vector typed BIT_FIELD_REFs
24538         of vector constants and constructors.
24539
24540 2012-03-16  Richard Guenther  <rguenther@suse.de>
24541
24542         * tree-vect-stmts.c (vect_get_vec_def_for_operand): Use
24543         VIEW_CONVERT_EXPR to convert constants.
24544         (vect_is_simple_use): Treat all constants as vec_constant_def.
24545
24546 2012-03-16  Richard Guenther  <rguenther@suse.de>
24547             Kai Tietz  <ktietz@redhat.com>
24548
24549         PR middle-end/48814
24550         * gimplify.c (gimplify_self_mod_expr): Evaluate postfix
24551         side-effects completely in the pre-queue and use a temporary
24552         for the result.
24553
24554 2012-03-16  Richard Guenther  <rguenther@suse.de>
24555
24556         * stor-layout.c (finish_bitfield_representative): Fall back
24557         to the conservative maximum size if we cannot compute the
24558         size of the tail padding.
24559
24560 2012-03-16  Tristan Gingold  <gingold@adacore.com>
24561
24562         * config/vms/vms.h (TARGET_OS_CPP_BUILTINS): Define
24563         __CRTL_VER and __VMS_VER.
24564         * config/vms/vms-protos.h: Declare vms_c_get_crtl_ver
24565         and vms_c_get_vms_ver.
24566         * config/vms/vms-c.c (vms_c_get_crtl_ver, vms_c_get_vms_ver): New
24567         functions.
24568         * config/alpha/vms.h (VMS_DEFAULT_CRTL_VER)
24569         (VMS_DEFAULT_VMS_VER): Define.
24570         * config/ia64/vms.h (VMS_DEFAULT_CRTL_VER)
24571         (VMS_DEFAULT_VMS_VER): Define.
24572
24573 2012-03-16  Richard Guenther  <rguenther@suse.de>
24574
24575         * tree-vect-loop.c (get_initial_def_for_induction): Use
24576         build_constructor directly.
24577         * tree-vect-stmts.c (vect_get_vec_def_for_operand): Use
24578         build_vector_from_val.
24579         * tree.c (build_vector_from_val): Avoid creating a constructor
24580         first when we want a constant vector.
24581
24582 2012-03-16  Rainer Orth  <ro@CeBiTec.Uni-Bielefeld.DE>
24583
24584         * doc/install.texi (Specific, *-*-solaris2*): Improve wording.
24585
24586 2012-03-16  Richard Guenther  <rguenther@suse.de>
24587
24588         * tree.h (TREE_VECTOR_CST_ELTS): Remove.
24589         (VECTOR_CST_NELTS, VECTOR_CST_ELTS, VECTOR_CST_ELT): New defines.
24590         (struct tree_vector): Remove elements member, add variable size
24591         elts array member.
24592         (build_vector_stat): Declare.
24593         (build_vector): Define in terms of build_vector_stat.
24594         * tree.c (build_vector): Rename to ...
24595         (build_vector_stat): ... this.  Take array of trees as parameter.
24596         (build_vector_from_ctor): Adjust.
24597         (integer_zerop, integer_onep, integer_all_onesp, iterative_hash_expr,
24598         initializer_zerop): Adjust.
24599         * cfgexpand.c (expand_debug_expr): Likewise.
24600         * expr.c (categorize_ctor_elements_1, expand_expr_real_1,
24601         const_vector_from_tree): Likewise.
24602         * fold-const.c (const_binop, operand_equal_p, native_encode_vector,
24603         native_interpret_vector, fold_unary_loc, vec_cst_ctor_to_array,
24604         fold_vec_perm, fold_binary_loc, fold_ternary_loc): Likewise.
24605         * tree-streamer-in.c (streamer_alloc_tree): Handle TS_VECTOR.
24606         (lto_input_ts_vector_tree_pointers): Adjust.
24607         * tree-streamer-out.c (streamer_write_tree_header): Handle TS_VECTOR.
24608         (write_ts_vector_tree_pointers): Adjust.
24609         * varasm.c (const_hash_1, compare_constant, copy_constant,
24610         output_constant): Adjust.
24611         * gimple-fold.c (gimple_fold_stmt_to_constant_1): Adjust.
24612         * print-tree.c (print_node): Adjust.
24613         * tree-pretty-print.c (dump_generic_node): Adjust.
24614         * tree-vect-generic.c (uniform_vector_p, vector_element,
24615         lower_vec_perm): Adjust.
24616         * tree-vect-loop.c (get_initial_def_for_reduction): Adjust.
24617         * tree-vect-slp.c (vect_get_constant_vectors,
24618         vect_transform_slp_perm_load): Adjust.
24619         * tree-vect-stmts.c (vect_gen_perm_mask): Adjust.
24620         * expmed.c (make_tree): Adjust.
24621         * config/i386/i386.c (ix86_expand_builtin): Adjust.
24622         * config/sparc/sparc.c (sparc_handle_vis_mul8x16): Adjust interface
24623         and implementation.
24624         (sparc_fold_builtin): Adjust.
24625
24626 2012-03-16  Tristan Gingold  <gingold@adacore.com>
24627
24628         * config.gcc (*-*-*vms*): Define use_gcc_stdint and tm_file.
24629         * config/vms/vms-stdint.h: New file.
24630
24631 2012-03-16  Tristan Gingold  <gingold@adacore.com>
24632
24633         * config.host (alpha64-dec-*vms*, alpha*-dec-*vms*)
24634         (ia64-hp-*vms*): Replaced by ...
24635         (*-*-*vms*): ... This new entry.
24636
24637 2012-03-15  Jakub Jelinek  <jakub@redhat.com>
24638
24639         PR target/52568
24640         * config/i386/i386.c (expand_vec_perm_vperm2f128_vblend): New function.
24641         (ix86_expand_vec_perm_const_1): Use it.
24642
24643         PR target/52568
24644         * config/i386/sse.md (UNSPEC_VPERMDF): Remove.
24645         (avx2_permv4df): Remove.
24646         (avx2_permv4di): Macroize into...
24647         (avx2_perm<mode>): ... this using VI8F_256 iterator.
24648         (avx2_permv4di_1): Macroize into...
24649         (avx2_perm<mode>_1): ... this using VI8F_256 iterator.
24650
24651 2012-03-15  Ulrich Weigand  <ulrich.weigand@linaro.org>
24652
24653         * combine.c (apply_distributive_law): Do not distribute SUBREG.
24654
24655 2012-03-15  Ira Rosen  <irar@il.ibm.com>
24656             Ulrich Weigand  <ulrich.weigand@linaro.org>
24657
24658         * tree-vect-patterns.c (widened_name_p): Rename to ...
24659         (type_conversion_p): ... this.  Add new argument to determine
24660         if it's a promotion or demotion operation.  Check for
24661         CONVERT_EXPR_CODE_P instead of NOP_EXPR.
24662         (vect_recog_dot_prod_pattern): Call type_conversion_p instead
24663         widened_name_p.
24664         (vect_recog_widen_mult_pattern, vect_recog_widen_sum_pattern,
24665         vect_operation_fits_smaller_type, vect_recog_widen_shift_pattern):
24666         Likewise.
24667         (vect_recog_mixed_size_cond_pattern): Likewise and allow
24668         non-constant then and else clauses.
24669
24670 2012-03-15  Ira Rosen  <irar@il.ibm.com>
24671             Ulrich Weigand  <ulrich.weigand@linaro.org>
24672
24673         * tree-vectorizer.h (vect_pattern_recog): Add new argument.
24674         * tree-vect-loop.c (vect_analyze_loop_2): Update call to
24675         vect_pattern_recog.
24676         * tree-vect-patterns.c (widened_name_p): Pass basic block
24677         info to vect_is_simple_use.
24678         (vect_recog_dot_prod_pattern): Fail for basic blocks.
24679         (vect_recog_widen_sum_pattern): Likewise.
24680         (vect_handle_widen_op_by_const): Support basic blocks.
24681         (vect_operation_fits_smaller_type,
24682         vect_recog_over_widening_pattern): Likewise.
24683         (vect_recog_vector_vector_shift_pattern): Support basic blocks.
24684         Update call to vect_is_simple_use.
24685         (vect_recog_mixed_size_cond_pattern): Support basic blocks.
24686         Add printing.
24687         (check_bool_pattern): Add an argument, update call to
24688         vect_is_simple_use and the recursive calls.
24689         (vect_recog_bool_pattern): Update relevant function calls.
24690         Add printing.
24691         (vect_mark_pattern_stmts): Update calls to new_stmt_vec_info.
24692         (vect_pattern_recog_1): Check for reduction only in loops.
24693         (vect_pattern_recog): Add new argument.  Support basic blocks.
24694         * tree-vect-stmts.c (vectorizable_conversion): Pass basic block
24695         info to vect_is_simple_use_1.
24696         * tree-vect-slp.c (vect_get_and_check_slp_defs): Support basic blocks.
24697         (vect_slp_analyze_bb_1): Call vect_pattern_recog.
24698
24699 2012-03-15  Jakub Jelinek  <jakub@redhat.com>
24700             Andrew Pinski  <apinski@cavium.com>
24701
24702         PR middle-end/52592
24703         * builtins.c (expand_builtin_int_roundingfn_2): If expanding
24704         BUILT_IN_IR{INT,OUND}* using optab fails, emit lr{int,ound}*
24705         calls instead of __builtin_ir{int,ound}*.
24706
24707 2012-03-15  Bernhard Reutner-Fischer  <aldot@gcc.gnu.org>
24708
24709         * doc/sourcebuild.texi (cleanup-modules, keep-modules): Update
24710         documentation.
24711
24712 2012-03-15  Ramana Radhakrishnan  <ramana.radhakrishnan@linaro.org>
24713
24714         * config.gcc (target_type_format_char): New. Document it. Set it for
24715         arm*-*-* .
24716         * configure.ac (gnu_unique_option): Use target_type_format_char
24717         in test.  Comment rationale.
24718         * configure: Regenerate .
24719
24720 2012-03-15  Jakub Jelinek  <jakub@redhat.com>
24721
24722         PR tree-optimization/52267
24723         * tree-vrp.c (masked_increment): New function.
24724         (register_edge_assert_for_2): Derive ASSERT_EXPRs
24725         from (X & CST1) cmp CST2 tests.
24726
24727 2012-03-15  Richard Guenther  <rguenther@suse.de>
24728
24729         PR middle-end/52580
24730         * tree-data-ref.c (subscript_dependence_tester_1): Check
24731         all dimensions for non-conflicting access functions.
24732
24733 2012-03-15  Manuel López-Ibáñez  <manu@gcc.gnu.org>
24734
24735         PR c++/44783
24736         * doc/invoke.texi [C++ Language Options]: Document
24737         -ftemplate-backtrace-limit.
24738
24739 2012-03-15  Tristan Gingold  <gingold@adacore.com>
24740
24741         * c-parser.c (c_parser_parameter_declaration): Handle #pragma
24742         before a parameter.
24743
24744 2012-03-15  Tristan Gingold  <gingold@adacore.com>
24745
24746         * dwarf2out.c (gen_subprogram_die): Require dwarf unwinding to
24747         use DW_OP_call_frame_cfa.
24748
24749 2012-03-14  H.J. Lu  <hongjiu.lu@intel.com>
24750
24751         PR target/50797
24752         * config/i386/i386-opts.h (pmode): New.
24753
24754         * config/i386/i386.c (ix86_option_override_internal): Properly
24755         check and set ix86_pmode.
24756
24757         * config/i386/i386.h (Pmode): Check ix86_pmode instead of TARGET_64BIT.
24758
24759         * config/i386/i386.opt (maddress-mode=): New.
24760
24761         * doc/invoke.texi: Document -maddress-mode=short|long for x86.
24762
24763 2012-03-14  Rainer Orth  <ro@CeBiTec.Uni-Bielefeld.DE>
24764
24765         * dwarf2cfi.c (def_cfa_0): Remove MIPS_DEBUGGING_INFO handling.
24766         (dwarf2out_do_cfi_asm): Likewise.
24767         * dwarf2out.c (output_call_frame_info): Remove MIPS_DEBUGGING_INFO
24768         handling.
24769         (add_data_member_location_attribute): Likewise.
24770         (gen_array_type_die): Likewise.
24771         (gen_subprogram_die): Likewise.
24772         (gen_producer_string): Likewise.
24773         * sdbout.c (sdbout_begin_prologue): Declare unconditionally.
24774         Remove MIPS_DEBUGGING_INFO handling.
24775         (sdb_debug_hooks): Likewise.
24776         (sdbout_begin_block): Likewise.
24777         (sdbout_end_block): Likewise.
24778         (sdbout_begin_prologue): Likewise.
24779         (sdbout_start_source_file): Likewise.
24780         (sdbout_end_source_file): Likewise.
24781         (sdbout_init): Likewise.
24782         * system.h (MIPS_DEBUGGING_INFO): Poison.
24783
24784 2012-03-14  Rainer Orth  <ro@CeBiTec.Uni-Bielefeld.DE>
24785
24786         * config/alpha/alpha.c [HAVE_STAMP_H]: Remove.
24787         (alpha_file_start) [MS_STAMP]: Remove.
24788
24789         * config/alpha/elf.h (TARGET_GAS): Remove.
24790         * config/alpha/freebsd.h (TARGET_DEFAULT): Remove.
24791         * config/alpha/linux.h (TARGET_DEFAULT): Remove.
24792         * config/alpha/netbsd.h (TARGET_DEFAULT): Remove.
24793         * config/alpha/vms.h (TARGET_DEFAULT): Remove.
24794         * config.gcc (alpha*-*-linux*): Remove target_cpu_default.
24795         (alpha*-*-freebsd*): Likewise.
24796         (alpha*-*-netbsd*): Likewise.
24797         (alpha*-*-openbsd*): Likewise.
24798         (alpha*-*-*): Remove target_cpu_default2.
24799         * config/alpha/alpha.c (alpha_output_filename): Remove !TARGET_GAS
24800         handling.
24801         * config/alpha/alpha.h (TARGET_AS_CAN_SUBTRACT_LABELS): Remove.
24802         (TARGET_AS_SLASH_BEFORE_SUFFIX): Remove.
24803         * config/alpha/alpha.c (print_operand): Always assume
24804         TARGET_AS_SLASH_BEFORE_SUFFIX.
24805         * config/alpha/alpha.md ("*builtin_setjmp_receiver_er_sl_1"):
24806         Remove TARGET_AS_CAN_SUBTRACT_LABELS.
24807         ("*builtin_setjmp_receiver_er_1"): Remove.
24808         * config/alpha/alpha.opt (malpha-as): Remove.
24809         (mgas): Ignore.
24810         * doc/invoke.texi (Option Summary, DEC Alpha Options): Remove
24811         -malpha-as, -mgas.
24812         Remove DEC Unix reference.
24813
24814         * config/alpha/alpha.h (OBJECT_FORMAT_COFF): Remove.
24815         (EXTENDED_COFF): Remove.
24816         * config/alpha/elf.h (OBJECT_FORMAT_COFF): Don't undef.
24817         (EXTENDED_COFF): Don't undef.
24818         * config/alpha/alpha.c (alpha_file_start): Always assume
24819         OBJECT_FORMAT_ELF.
24820         Don't set targetm.asm_file_start_file_directive.
24821         [!OBJECT_FORMAT_ELF]: Remove.
24822         (TARGET_ASM_FILE_START_FILE_DIRECTIVE): Remove.
24823
24824         * config/alpha/alpha.h (SDB_DEBUGGING_INFO): Remove.
24825         (DBX_DEBUGGING_INFO): Remove.
24826         (MIPS_DEBUGGING_INFO): Remove.
24827         (PREFERRED_DEBUGGING_TYPE): Remove.
24828         (DBX_OUTPUT_SOURCE_LINE): Remove.
24829         (SDB_OUTPUT_SOURCE_LINE): Remove.
24830         (DBX_CONTIN_LENGTH): Remove.
24831         (NO_DBX_FUNCTION_END): Remove.
24832         (ASM_STABS_OP): Remove.
24833         (ASM_STABN_OP): Remove.
24834         (ASM_STABD_OP): Remove.
24835         (SDB_ALLOW_FORWARD_REFERENCES): Remove.
24836         (SDB_ALLOW_UNKNOWN_REFERENCES): Remove.
24837         (PUT_SDB_DEF): Remove.
24838         (PUT_SDB_PLAIN_DEF): Remove.
24839         (PUT_SDB_TYPE): Remove.
24840         (sdb_label_count): Remove.
24841         (PUT_SDB_BLOCK_START): Remove.
24842         (PUT_SDB_BLOCK_END): Remove.
24843         (PUT_SDB_FUNCTION_START): Remove.
24844         (PUT_SDB_FUNCTION_END): Remove.
24845         (PUT_SDB_EPILOGUE_END): Remove.
24846         * config/alpha/elf.h (SDB_DEBUGGING_INFO): Don't undef.
24847         (MIPS_DEBUGGING_INFO): Don't undef.
24848         (DBX_DEBUGGING_INFO): Don't undef.
24849         * config/alpha/vms.h (SDB_DEBUGGING_INFO): Don't undef.
24850         (MIPS_DEBUGGING_INFO): Don't undef.
24851         (DBX_DEBUGGING_INFO): Don't undef.
24852         * config/alpha/freebsd.h (DBX_CONTIN_CHAR): Remove.
24853         * config/alpha/alpha.c (alpha_option_override): Remove SDB_DEBUG
24854         handling.
24855         (alpha_start_function): Likewise.
24856         (sdb_label_count): Remove.
24857         (alpha_output_filename): Remove DBX_DEBUG handling.
24858         (alpha_file_start): Likewise.
24859
24860 2012-03-14  Rainer Orth  <ro@CeBiTec.Uni-Bielefeld.DE>
24861
24862         * config.gcc (enable_obsolete): Remove *-*-solaris2.8*.
24863         (*-*-solaris2.[0-8], *-*-solaris2.[0-8].*): Mark unsupported.
24864         (i[34567]86-*-solaris2*, x86_64-*-solaris2.1[0-9]*): Remove
24865         Solaris 8 support.
24866         * configure.ac (gcc_cv_ld_hidden): Remove *-*-solaris2.8*.
24867         (ld_tls_support): Remove Solaris 8 references.
24868         (lwp_dir, lwp_spec): Remove support for alternate thread library.
24869         * acinclude.m4 (gcc_cv_initfini_array): Remove *-*-solaris2.* tests.
24870         * configure: Regenerate.
24871         * config.in: Regenerate.
24872
24873         * config/sol2.h (LINK_SPEC): Remove LIB_THREAD_LDFLAGS_SPEC.
24874         * config/i386/sol2.h: Remove Solaris 8 references.
24875
24876         * doc/install.texi (Specific, i?86-*-solaris2.[89]): Rename to ...
24877         (i?86-*-solaris2.9): ... this.
24878         Remove Solaris 8 references.
24879         (Specific, *-*-solaris2*): Document Solaris 8 removal.
24880         Remove Solaris 8 references.
24881
24882 2012-03-14  Rainer Orth  <ro@CeBiTec.Uni-Bielefeld.DE>
24883
24884         * config.gcc (enable_obsolete): Remove mips-sgi-irix6.5.
24885         (mips-sgi-irix6.5*): Remove.
24886         * config.host (mips-sgi-irix*): Remove.
24887         * configure.ac (enable_fixed_point): Remove mips*-sgi-irix*.
24888         (set_have_as_tls): Remove *-*-irix6*.
24889         (gcc_cv_ld_static_dynamic): Remove mips-sgi-irix6*.
24890         * configure: Regenerate.
24891
24892         * config/mips/iris6.h: Remove.
24893         * config/mips/iris6.opt: Remove.
24894         * config/mips/t-irix6: Remove.
24895
24896         * config/mips/mips.h (TARGET_GPWORD): Remove IRIX 6 N64 handling.
24897         (TARGET_IRIX6): Remove.
24898         (TARGET_CPU_CPP_BUILTINS): Remove IRIX 6 handling.
24899         Don't define LANGUAGE_C, _LANGUAGE_C for Objective-C.
24900         * config/mips/mips.c (mips_build_builtin_va_list): Remove IRIX 6
24901         handling.
24902         (mips_file_start): Likewise.
24903         * config/mips/mips-protos.h (irix_asm_output_align): Remove.
24904
24905         * config/mips/driver-native.c [__sgi__]: Remove.
24906         (host_detect_local_cpu) [__sgi__]: Remove.
24907
24908         * config/mips/gnu-user.h: Remove iris5.h reference.
24909
24910         * config/mips/mips-modes.def: Remove IRIX 6 reference.
24911         * config/mips/gnu-user64.h (MIPS_TFMODE_FORMAT): Remove.
24912         * config/mips/mips.c (mips_option_override) [MIPS_TFMODE_FORMAT]:
24913         Remove.
24914
24915         * gcc.c (main): Move asm_debug initialization ...
24916         (asm_debug): ... here.
24917
24918         * ginclude/stddef.h (__STDDEF_H__): Don't define.
24919
24920         * defaults.h (LINK_ELIMINATE_DUPLICATE_LDIRECTORIES): Remove.
24921         * system.h (LINK_ELIMINATE_DUPLICATE_LDIRECTORIES): Poison.
24922         * collect2.c [LINK_ELIMINATE_DUPLICATE_LDIRECTORIES]: Remove.
24923         (main) [LINK_ELIMINATE_DUPLICATE_LDIRECTORIES]: Remove.
24924         [LINK_ELIMINATE_DUPLICATE_LDIRECTORIES] (is_in_args): Remove.
24925         * doc/tm.texi.in (Driver, LINK_ELIMINATE_DUPLICATE_LDIRECTORIES):
24926         Remove.
24927         * doc/tm.texi: Regenerate.
24928
24929         * doc/invoke.texi (Debugging Options, -gdwarf-<version>): Remove
24930         IRIX 6 reference.
24931         (MIPS Options, -march): Remove IRIX reference.
24932         * doc/install.texi (Binaries, SGI IRIX): Remove.
24933         (Specific, mips-sgi-irix6): Document IRIX 6.5 removal, remove rest
24934         of section.
24935         * doc/trouble.texi (Interoperation): Remove -lgl_s handling.
24936
24937 2012-03-14  Martin Jambor  <mjambor@suse.cz>
24938
24939         * expr.c (expand_assignment): Use expand_expr with EXPAND_WRITE
24940         when expanding MEM_REFs, MEM_TARGET_REFs and handled_component bases.
24941         (expand_expr_real_1): Do not handle misalignment if modifier is
24942         EXPAND_WRITE.
24943
24944 2012-03-14  Richard Guenther  <rguenther@suse.de>
24945
24946         PR middle-end/52584
24947         * tree-vect-generic.c (type_for_widest_vector_mode): Take
24948         element type instead of mode, use build_vector_type_for_mode
24949         instead of the langhook, build a vector of proper signedness.
24950         (expand_vector_operations_1): Adjust.
24951
24952 2012-03-14  Richard Guenther  <rguenther@suse.de>
24953
24954         PR middle-end/52582
24955         * gimple-fold.c (canonicalize_constructor_val): Make sure we have
24956         a cgraph node for a FUNCTION_DECL that comes from a constructor.
24957         (gimple_get_virt_method_for_binfo): Likewise.
24958
24959 2012-03-14  Richard Guenther  <rguenther@suse.de>
24960
24961         PR tree-optimization/52571
24962         * tree-vect-data-refs.c (vect_compute_data_ref_alignment): Move
24963         flag_section_anchors check ...
24964         (vect_can_force_dr_alignment_p): ... here.  Do not re-align
24965         DECL_COMMON variables.
24966
24967 2012-03-14  Richard Guenther  <rguenther@suse.de>
24968
24969         * tree.h (DECL_BIT_FIELD_REPRESENTATIVE): New define.
24970         * stor-layout.c (start_bitfield_representative): New function.
24971         (finish_bitfield_representative): Likewise.
24972         (finish_bitfield_layout): Likewise.
24973         (finish_record_layout): Call finish_bitfield_layout.
24974         * tree.c (free_lang_data_in_decl): Only free DECL_QUALIFIER
24975         for QUAL_UNION_TYPE fields.
24976         * tree-streamer-in.c (lto_input_ts_field_decl_tree_pointers):
24977         Stream DECL_BIT_FIELD_REPRESENTATIVE.
24978         * tree-streamer-out.c (write_ts_field_decl_tree_pointers): Likewise.
24979
24980         PR middle-end/52080
24981         PR middle-end/52097
24982         PR middle-end/48124
24983         * expr.c (get_bit_range): Unconditionally extract bitrange
24984         from DECL_BIT_FIELD_REPRESENTATIVE.
24985         (expand_assignment): Adjust call to get_bit_range.
24986
24987 2012-03-14  Richard Guenther  <rguenther@suse.de>
24988
24989         PR middle-end/52578
24990         * fold-const.c (fold_unary_loc): Fold (T1)(T2)x to (T1)x if
24991         the outermost conversion is a sign-change only.
24992         (fold_binary_loc): Disregard widening and sign-changing
24993         conversions when we determine if two variables are equal
24994         for reassociation.
24995         * tree-ssa-forwprop.c (combine_conversions): Fold (T1)(T2)x to
24996         (T1)x if the outermost conversion is a sign-change only.
24997
24998 2012-03-14  Uros Bizjak  <ubizjak@gmail.com>
24999
25000         Revert:
25001         2012-03-14  Uros Bizjak  <ubizjak@gmail.com>
25002
25003         * config/i386/predicates.md (constant_call_address_operand): Declare
25004         as special predicate.  Update all uses.
25005
25006 2012-03-13  Jakub Jelinek  <jakub@redhat.com>
25007
25008         PR c/52577
25009         * c-parser.c (c_parser_postfix_expression)
25010         <case RID_BUILTIN_SHUFFLE>: Call mark_exp_read on argument values.
25011
25012         * config/i386/smmintrin.h: Avoid /* within a comment.
25013         * config/i386/nmmintrin.h: Likewise.
25014
25015 2012-03-13  Uros Bizjak  <ubizjak@gmail.com>
25016
25017         * config/i386/i386.md (xbegin): Remove constraint from expander.
25018
25019 2012-03-13  Uros Bizjak  <ubizjak@gmail.com>
25020
25021         * config/i386/predicates.md (constant_call_address_operand): Declare
25022         as special predicate.  Update all uses.
25023         * config/i386/i386.md: Remove mode from constant_call_address_operand
25024         predicates.
25025         * config/i386/i386.c (ix86_output_call_insn): Call
25026         constant_call_address_operand with VOIDmode.
25027
25028 2012-03-13  Uros Bizjak  <ubizjak@gmail.com>
25029
25030         * config/i386/i386.c (ix86_decompose_address): Handle subregs of
25031         AND zero extended address correctly.
25032
25033 2012-03-13  Uros Bizjak  <ubizjak@gmail.com>
25034
25035         * config/i386/predicates.md (tls_symbolic_operand): Declare as
25036         special predicate.
25037         (tls_modbase_operand): Ditto.
25038         * config/i386/i386.md: Remove mode from tls_symbolic_operand and
25039         tls_modbase_operand predicates.
25040
25041 2012-03-13  Martin Jambor  <mjambor@suse.cz>
25042
25043         * expr.c (expand_assignment): Handle misaligned scalar writes to
25044         memory through top-level MEM_REFs by calling store_bit_field.
25045
25046 2012-03-13  Richard Guenther  <rguenther@suse.de>
25047
25048         PR middle-end/52134
25049         * fold-const.c (fold_binary_loc): Fold (X * Y) & -(1 << CST) to X * Y
25050         if Y is a constant multiple of 1 << CST.
25051
25052 2012-03-13  Georg-Johann Lay  <avr@gjlay.de>
25053
25054         PR target/52488
25055         * config/avr/avr.c (avr_prologue_setup_frame): Cut down stack
25056         offset (size) to a value the insns can deal with.
25057         (expand_epilogue): Ditto.
25058
25059 2012-03-13  Matthew Gretton-Dann  <matthew.gretton-dann@arm.com>
25060
25061         * config/arm/neon.ml (ops): Fixup expected instructions for
25062         unsigned vector compares.
25063
25064 2012-03-13  Uros Bizjak  <ubizjak@gmail.com>
25065
25066         * config/i386/i386.c (ix86_decompose_address): Prevent %fs:(%reg)
25067         addresses only when %reg is not in word mode.
25068
25069 2012-03-13  Rainer Orth  <ro@CeBiTec.Uni-Bielefeld.DE>
25070
25071         * config/microblaze/microblaze.md: Fix typo.
25072         * tree-if-conv.c: Likewise.
25073         * tree-vect-patterns.c: Likewise.
25074
25075 2012-03-13  Rainer Orth  <ro@CeBiTec.Uni-Bielefeld.DE>
25076
25077         * config.gcc (extra_passes): Remove.
25078         * configure.ac (extra_passes): Don't substitute.
25079         * configure: Regenerate.
25080         * Makefile.in (EXTRA_PASSES): Remove.
25081         (GCC_PASSES): Remove $(EXTRA_PASSES).
25082         (MOSTLYCLEANFILES): Likewise.
25083         (native): Likewise.
25084         (install-common): Likewise.
25085
25086 2012-03-13  Uros Bizjak  <ubizjak@gmail.com>
25087
25088         * config/i386/i386.h (TARGET_TLS_INDIRECT_SEG_REFS): New.
25089         * config/i386/i386.c (ix86_decompose_address): Use
25090         TARGET_TLS_INDIRECT_SEG_REFS to prevent %fs:(%reg) addresses.
25091         (legitimize_tls_address): Use TARGET_TLS_INDIRECT_SEG_REFS to load
25092         thread pointer to a register.
25093
25094 2012-03-12  H.J. Lu  <hongjiu.lu@intel.com>
25095
25096         * config/i386/i386.md (*tls_global_dynamic_64_<mode>): Remove :P
25097         on tls_symbolic_operand.
25098         (tls_global_dynamic_64_<mode>): Likewise.
25099
25100 2012-03-12  Georg-Johann Lay  <avr@gjlay.de>
25101
25102         PR other/52545
25103         * output.h (SECTION_EXCLUDE, SECTION_MACH_DEP): Don't use
25104         SECTION_MACH_DEP reserved bits for SECTION_EXCLUDE.
25105
25106 2012-03-12  Georg-Johann Lay  <avr@gjlay.de>
25107
25108         PR target/52499
25109         * config/avr/avr.c (avr_mode_code_base_reg_class): Change return
25110         type from reg_class_t to enum reg_class.
25111         * config/avr/avr-protos.h (avr_mode_code_base_reg_class): Ditto.
25112
25113 2012-03-12  Andrew Pinski  <apinski@cavium.com>
25114
25115         * tree-ssa-phiopt.c (single_non_singleton_phi_for_edges): New function.
25116         (tree_ssa_phiopt_worker): Use single_non_singleton_phi_for_edges.
25117         (value_replacement): Likewise.
25118         (empty_block_p): Check also if the PHIs for the block are empty.
25119
25120 2012-03-12  Georg-Johann Lay  <avr@gjlay.de>
25121
25122         PR target/52148
25123         * config/avr/avr.c (avr_out_movmem): Fix typo in output template
25124         for the case ADDR_SPACE_FLASH and AVR_HAVE_LPMX introduced in
25125         r184615 from 2012-02-28.
25126
25127 2012-03-12  H.J. Lu  <hongjiu.lu@intel.com>
25128
25129         * config/i386/i386.c (ix86_gen_tls_global_dynamic_64): New.
25130         (ix86_gen_tls_local_dynamic_base_64): Likewise.
25131         (ix86_option_override_internal): Set ix86_gen_tls_global_dynamic_64
25132         and ix86_gen_tls_local_dynamic_base_64.
25133         (legitimize_tls_address): Use ix86_gen_tls_global_dynamic_64 and
25134         ix86_gen_tls_local_dynamic_base_64.
25135
25136         * config/i386/i386.md (*tls_global_dynamic_64): Renamed to ...
25137         (*tls_global_dynamic_64_<mode>): This.
25138         (tls_global_dynamic_64): Renamed to ...
25139         (tls_global_dynamic_64_<mode>): This.
25140         (*tls_local_dynamic_base_64): Renamed to ...
25141         (*tls_local_dynamic_base_64_<mode>): This.
25142         (tls_local_dynamic_base_64): Renamed to ...
25143         (tls_local_dynamic_base_64_<mode>): This.
25144
25145 2012-03-12  H.J. Lu  <hongjiu.lu@intel.com>
25146
25147         * config/i386/i386.c (ix86_option_override_internal): Properly
25148         set ix86_gen_leave and ix86_gen_monitor.  Check Pmode == DImode,
25149         instead of TARGET_64BIT, to set ix86_gen_add3, ix86_gen_sub3,
25150         ix86_gen_one_cmpl2, ix86_gen_andsp, ix86_gen_allocate_stack_worker,
25151         ix86_gen_adjust_stack_and_probe and ix86_gen_probe_stack_range.
25152
25153         * config/i386/sse.md (sse3_monitor64): Renamed to ...
25154         (sse3_monitor64_<mode>): This.
25155
25156 2012-03-12  Tristan Gingold  <gingold@adacore.com>
25157
25158         * config/ia64/ia64.c (ia64_function_arg_1): Move code around.
25159         (ia64_function_arg_advance): Ditto.
25160
25161 2012-03-12  Rainer Orth  <ro@CeBiTec.Uni-Bielefeld.DE>
25162
25163         * config.gcc (mips*-*-openbsd*): Remove.
25164         * config/mips/openbsd.h: Remove.
25165         * config/mips/sdb.h: Remove.
25166
25167         * config/mips/mips.h (SDB_OUTPUT_SOURCE_LINE): Remove.
25168         * config/mips/mips.c (sdb_label_count): Remove.
25169         (mips_debugger_offset): Remove #if 0 code.
25170         (mips_output_function_prologue) [SDB_DEBUGGING_INFO]: Remove.
25171         * config/mips/sde.h (SDB_DEBUGGING_INFO): Don't undef.
25172
25173 2012-03-12  Rainer Orth  <ro@CeBiTec.Uni-Bielefeld.DE>
25174
25175         * doc/install.texi (Specific, i?86-*-solaris2.[89]): Update
25176         binutils reference.
25177         (Specific, i?86-*-solaris2.10): Remove GCC 4.0 reference.
25178         Update binutils references.
25179         (Specific, *-*-solaris2*): Mention bundled GCC in Solaris 10 and 11.
25180         Update binutils reference.
25181         Update Sun as/GNU ld caveat.
25182         Document binutils largefile requirement for LTO plugin.
25183         Remove reference to alternate libpthread.
25184
25185 2012-03-12  Rainer Orth  <ro@CeBiTec.Uni-Bielefeld.DE>
25186
25187         * config.gcc (alpha*-dec-osf5.1*): Remove.
25188         * config.host (alpha*-dec-osf*): Remove.
25189         * configure.ac (*-*-osf*): Remove.
25190         (alpha*-dec-osf*): Remove.
25191         * configure: Regenerate.
25192
25193         * config/alpha/host-osf.c, config/alpha/osf5.h, config/alpha/osf5.opt,
25194         config/alpha/va_list.h, config/alpha/x-osf: Remove.
25195
25196         * config/alpha/alpha.h (TARGET_LD_BUGGY_LDGP): Remove.
25197         * config/alpha/alpha.c (struct machine_function): Update comment.
25198         (alpha_start_function): Remove Tru64 UNIX as handling for
25199         max_frame_size.
25200         * config/alpha/alpha.md ("exception_receiver"): Remove
25201         TARGET_LD_BUGGY_LDGP.
25202         ("*exception_receiver_2"): Likewise.
25203         * except.c (finish_eh_generation): Remove Tru64 reference.
25204         * ginclude/stdarg.h [_HIDDEN_VA_LIST]: Don't undef _VA_LIST.
25205         * system.h (TARGET_HANDLE_PRAGMA_EXTERN_PREFIX): Poison.
25206         * target.def (handle_pragma_extern_prefix): Remove.
25207
25208         * Makefile.in (mips-tfile.o-warn): Remove.
25209         (ALL_HOST_BACKEND_OBJS): Remove mips-tfile.o, mips-tdump.o.
25210         (mips-tfile, mips-tfile.o, mips-tdump, mips-tdump.o): Remove.
25211         * mips-tdump.c, mips-tfile.c: Remove.
25212
25213         * doc/extend.texi (Symbol-Renaming Pragmas): Remove #pragma
25214         extern_prefix.
25215         * doc/install.texi (Binaries): Remove Tru64 UNIX reference.
25216         (Specific, alpha*-dec-osf5.1): Note removal.
25217         * doc/tm.texi.in (Misc, TARGET_HANDLE_PRAGMA_EXTERN_PREFIX):
25218         Remove.
25219         * doc/tm.texi: Regenerate.
25220         * doc/trouble.texi (Cross-Compiler Problems): Remove.
25221
25222 2012-03-12  Richard Guenther  <rguenther@suse.de>
25223
25224         * config/arm/arm.c (neon_dereference_pointer): Do not call
25225         covert during RTL expansion.
25226
25227 2012-03-12  Tristan Gingold  <gingold@adacore.com>
25228
25229         * doc/invoke.texi (VMS Options): Merge Alpha/VMS and IA-64/VMS
25230         Options.  Mention -mpointer-size.
25231
25232 2012-03-12  Richard Guenther  <rguenther@suse.de>
25233
25234         * config/alpha/alpha.c (alpha_gimplify_va_arg): Use
25235         build_nonstandard_integer_type.
25236
25237 2012-03-12  Richard Guenther  <rguenther@suse.de>
25238
25239         * tree.c (signed_or_unsigned_type_for): Use
25240         build_nonstandard_integer_type.
25241         (signed_type_for): Adjust documentation.
25242         (unsigned_type_for): Likewise.
25243         * tree-pretty-print.c (dump_generic_node): Use standard names
25244         for non-standard integer types if available.
25245
25246 2012-03-12  Tristan Gingold  <gingold@adacore.com>
25247
25248         * config/vms/vms.opt: Add vms-opts.h header.
25249         (mmalloc64): Use flag_vms_malloc64 flag instead of MALLOC64
25250         target mask.
25251         (-mvms-return-codes): Document.
25252         (-mpointer-size): New option.
25253         (vms_pointer_size): Add enumeration.
25254         * config/vms/vms-opts.h: New file.
25255         * config/vms/vms.h (TARGET_OS_CPP_BUILTINS): Define
25256         __INITIAL_POINTER_SIZE.
25257         (POINTER_SIZE, SIZE_TYPE, PTRDIFF_TYPE): Adjust definition.
25258         (C_COMMON_OVERRIDE_OPTIONS): Define.
25259         (DWARF2_ADDR_SIZE): Define.
25260         * config/vms/vms.c (vms_patch_builtins): Adjust condition.
25261         * config/vms/vms-protos.h (vms_c_common_override_options):
25262         New prototype.
25263         * config/vms/vms-c.c (vms_pragma_pointer_size): Ignore pragma
25264         if -mno-pointer-size.
25265         (vms_c_common_override_options): New function.
25266         * config/ia64/vms.h (TARGET_DEFAULT): Remove MASK_MALLOC64.
25267         * config/alpha/vms.h (TARGET_DEFAULT): Remove MASK_MALLOC64.
25268         (MALLOC_ABI_ALIGNMENT): Use flag_vms_malloc64
25269         and flag_vms_pointer_size.
25270         (MASK_RETURN_ADDR): Set according to flag_vms_pointer_size.
25271         * config.gcc (*-*-*vms*): Define xm_file.
25272         (alpha*-dec-*vms*): Do not define xm_file.
25273         (alpha64-dec-*vms*): Remove.
25274         (ia64-hp-*vms*): Do not define xm_file.  Simplify tm_file
25275         and tmake_file.
25276
25277 2012-03-12  Jakub Jelinek  <jakub@redhat.com>
25278
25279         PR tree-optimization/51721
25280         * tree-vrp.c (register_edge_assert_for_2): Add asserts for unsvar
25281         if (int) unsvar cmp CST.
25282
25283 2012-03-12  Richard Guenther  <rguenther@suse.de>
25284
25285         * tree-sra.c (create_access_replacement): Only rename the replacement
25286         if we can rewrite it into SSA form.  Properly mark register typed
25287         replacements that we cannot rewrite with TREE_ADDRESSABLE.
25288         * tree-cfg.c (verify_expr): Fix BIT_FIELD_REF verification
25289         for aggregate or BLKmode results.
25290
25291 2012-03-12  Jakub Jelinek  <jakub@redhat.com>
25292
25293         PR tree-optimization/52533
25294         * tree-vrp.c (register_edge_assert_for_2): Use double_int
25295         type for mask, only handle shifts by non-zero in-range
25296         shift count, for LE_EXPR and GT_EXPR if new_val is
25297         maximum, don't add the assertion.
25298
25299 2012-02-12  Kirill Yukhin  <kirill.yukhin@intel.com>
25300
25301         * doc/invoke.texi: Document -mrtm option.
25302         * common/config/i386/i386-common.c (OPTION_MASK_ISA_RTM_SET): New.
25303         (OPTION_MASK_ISA_RTM_UNSET): Ditto.
25304         (ix86_handle_option): Handle OPT_mrtm.
25305         * config.gcc (i[34567]86-*-*): Add rtmintrin.h and
25306         xtestintrin.h.
25307         (x86_64-*-*): Ditto.
25308         * i386-builtin-types.def (INT_FTYPE_VOID): New.
25309         * config/i386/i386-c.c (ix86_target_macros_internal): Define
25310         __RTM__ if needed.
25311         (ix86_target_string): Define -mrtm option.
25312         (PTA_RTM): New.
25313         (ix86_option_override_internal): Extend "corei7-avx" with RTM option.
25314         Handle new option.
25315         (ix86_valid_target_attribute_inner_p): Add OPT_mrtm.
25316         (ix86_builtins): Add IX86_BUILTIN_XBEGIN, IX86_BUILTIN_XEND,
25317         IX86_BUILTIN_XTEST.
25318         (bdesc_special_args): Ditto.
25319         (ix86_init_mmx_sse_builtins): Add IX86_BUILTIN_XABORT.
25320         (ix86_expand_special_args_builtin): Handle new built-in type.
25321         (ix86_expand_builtin): Handle XABORT instruction.
25322         * config/i386/i386.h (TARGET_RTM): New.
25323         * config/i386/i386.md (UNSPECV_XBEGIN): New.
25324         (UNSPECV_XEND): Ditto.
25325         (UNSPECV_XABORT): Ditto.
25326         (UNSPECV_XTEST): Ditto.
25327         (xbegin): Ditto.
25328         (xbegin_1): Ditto.
25329         (xend): Ditto.
25330         (xabort): Ditto
25331         (xtest): Ditto.
25332         (xtest_1): Ditto.
25333         * config/i386/i386.opt (mrtm): New.
25334         * config/i386/immintrin.h: Include rtmintrin.h and xtestintrin.h.
25335         * config/i386/rtmintrin.h: New header.
25336         * config/i386/xtestintrin.h: Ditto.
25337
25338 2012-03-12  Tristan Gingold  <gingold@adacore.com>
25339
25340         * ginclude/stddef.h: Adjust previous patch.
25341         Use __VMS__ instead of VMS.
25342
25343 2012-03-12  Uros Bizjak  <ubizjak@gmail.com>
25344
25345         * config/i386/i386.md (setcc + movzbl to xor + setcc peephole2):
25346         Also convert sequences with CC setting arithmetic instruction.
25347
25348 2012-03-11  Sandra Loosemore  <sandra@codesourcery.com>
25349
25350         * doc/invoke.texi (Option Summary): Move -no-integrated-cpp
25351         from C Language Options to Preprocessor Options.
25352         (C Dialect Options): Move -no-integrated-cpp documentation
25353         from here...
25354         (Preprocessor Options): ...to here.  Rewrite the description
25355         so it makes more sense, and remove discussion of merging front ends.
25356
25357 2012-03-11  H.J. Lu  <hongjiu.lu@intel.com>
25358
25359         * config/i386/i386.c (ix86_expand_movmem): Use word_mode for size
25360         needed for loop.
25361         (ix86_expand_setmem): Likewise.
25362
25363 2012-03-11  Uros Bizjak  <ubizjak@gmail.com>
25364
25365         * config/i386/i386.c (ix86_zero_extend_to_Pmode): Rewrite using
25366         convert_to_mode.
25367
25368 2012-03-11  H.J. Lu  <hongjiu.lu@intel.com>
25369
25370         * config/i386/i386.c (ix86_trampoline_init): Use movl for 64bit if
25371         ptr_mode == SImode.  Replace DImode with Pmode or ptr_mode.
25372
25373 2012-03-11  H.J. Lu  <hongjiu.lu@intel.com>
25374
25375         * config/i386/i386.c (x86_this_parameter): Replace DImode with Pmode.
25376
25377 2012-03-11  H.J. Lu  <hongjiu.lu@intel.com>
25378
25379         * config/i386/i386.md (lwp_slwpcb): Check Pmode instead of
25380         TARGET_64BIT.
25381
25382 2012-03-11  H.J. Lu  <hongjiu.lu@intel.com>
25383             Uros Bizjak  <ubizjak@gmail.com>
25384
25385         * config/i386/predicates.md (call_insn_operand): Allow
25386         constant_call_address_operand in Pmode only.
25387         (sibcall_insn_operand): Ditto.
25388         * config/i386/i386.md (*call): Use W mode iterator instead of P mode.
25389         (*call_vzeroupper): Ditto.
25390         (*sibcall): Ditto.
25391         (*sibcall_vzeroupper): Ditto.
25392         (*call_value): Ditto.
25393         (*call_value_vzeroupper): Ditto.
25394         (*sibcall_value): Ditto.
25395         (*sibcall_value_vzeroupper): Ditto.
25396         (*indirect_jump): Ditto.
25397         (*tablejump_1): Ditto.
25398         (indirect_jump): Convert memory address to word mode for TARGET_X32.
25399         (tablejump): Ditto.
25400         * config/i386/i386.c (ix86_expand_call): Convert indirect operands
25401         to word mode.
25402
25403 2012-03-11  Oleg Endo  <olegendo@gcc.gnu.org>
25404
25405         PR target/51244
25406         * config/sh/sh.md (movnegt): Expand into respective insns immediately.
25407         Use movrt_negc instead of negc pattern for non-SH2A.
25408         (*movnegt): Remove.
25409         (*movrt_negc, *negnegt, *movtt, *movt_qi): New insns and splits.
25410
25411 2012-03-10  H.J. Lu  <hongjiu.lu@intel.com>
25412
25413         * config/i386/i386.c (ix86_decompose_address): Disallow fs:(reg)
25414         if Pmode != word_mode.
25415         (legitimize_tls_address): Call gen_tls_initial_exec_x32 if
25416         Pmode == SImode for TARGET_X32.
25417
25418         * config/i386/i386.md (UNSPEC_TLS_IE_X32): New.
25419         (tls_initial_exec_x32): Likewise.
25420
25421 2012-03-10  Chung-Lin Tang  <cltang@codesourcery.com>
25422
25423         PR rtl-optimization/52528
25424         * combine.c (can_combine_p): Add setting of subst_low_luid
25425         before call to expand_field_assignment().
25426
25427 2012-03-09  Sandra Loosemore  <sandra@codesourcery.com>
25428
25429         * doc/invoke.texi: Use correct names/markup for "GCC", "GDB", "ld",
25430         and related program names.
25431
25432 2012-03-09  Sandra Loosemore  <sandra@codesourcery.com>
25433
25434         * doc/invoke.texi: Use correct names for "DWARF", "stabs", and "ELF".
25435
25436 2012-03-09  Uros Bizjak  <ubizjak@gmail.com>
25437
25438         PR target/52530
25439         * config/i386/i386.c (ix86_print_operand): Handle 'E' operand modifier.
25440         (ix86_print_operand_address): Handle UNSPEC_LEA_ADDR. Do not fallback
25441         to set code to 'q'.
25442         * config/i386/i386.md (UNSPEC_LEA_ADDR): New unspec.
25443         (*movdi_internal_rex64): Use %E operand modifier for lea.
25444         (*movsi_internal): Ditto.
25445         (*lea_1): Ditto.
25446         (*lea<mode>_2): Ditto.
25447         (*lea_{3,4,5,6}_zext): Ditto.
25448         (*tls_global_dynamic_32_gnu): Ditto.
25449         (*tls_global_dynamic_64): Ditto.
25450         (*tls_dynamic_gnu2_lea_32): Ditto.
25451         (*tls_dynamic_gnu2_lea_64): Ditto.
25452         (pro_epilogue_adjust_stack_<mode>_add): Ditto.
25453
25454 2012-03-09  Michael Meissner  <meissner@linux.vnet.ibm.com>
25455
25456         * config/rs6000/linux64.h (OPTION_TARGET_CPU_DEFAULT): Do not
25457         redefine to be NULL if the current bit-size is different from the
25458         configured bit-size.
25459
25460         * config/rs6000/rs6000.c (rs6000_option_override_internal): If the
25461         cpu is defaulted, use PROCESSOR_DEFAULT and PROCESSOR_DEFAULT64 to
25462         set the default tuning.  Add asserts to make sure the cpu and tune
25463         indexes are defined.  Fix tests for cpu/tune index to use >= 0 to
25464         test whether the index is set, instead of > 0.
25465         (rs6000_file_start): Do not reset the default cpu if the current
25466         bit-size is different from the configured bit-size.
25467
25468 2012-03-09  Tristan Gingold  <gingold@adacore.com>
25469
25470         * config/vms/vms-crtlmap.map: Add comments.
25471         Add entries needed to build Ada RTS.
25472
25473 2012-03-09  Tristan Gingold  <gingold@adacore.com>
25474
25475         * ginclude/stddef.h: Do not define __size_t on VMS.
25476
25477 2012-03-09  Tristan Gingold  <gingold@adacore.com>
25478
25479         * c-tree.h (c_default_pointer_mode): New variable.
25480         * c-decl.c (c_default_pointer_mode): New variable.
25481         (c_build_pointer_type): New function.
25482         (grokdeclarator): Call c_build_pointer_type instead
25483         of build_pointer_type.
25484
25485         * config/vms/vms-c.c: Include c-tree.h
25486         (saved_pointer_mode): New variable.
25487         (handle_pragma_pointer_size): New function.
25488         (vms_pragma_pointer_size, vms_pragma_required_pointer_size): Likewise.
25489         (vms_c_register_pragma): Register __pointer_size and
25490         __required_pointer_size pragmas.
25491
25492 2012-03-09  Tristan Gingold  <gingold@adacore.com>
25493
25494         * config/vms/vms-c.c (vms_construct_include_filename): New function.
25495         (vms_c_register_includes): Reference it.
25496
25497 2012-03-09  Andrew Pinski  <apinski@cavium.com>
25498
25499         PR middle-end/51988
25500         * tree-ssa-phiopt.c: Include tree-pretty-print.h for
25501         print_generic_expr.
25502         (tree_ssa_phiopt_worker): Go through all the PHIs for
25503         value_replacement instead of just the singleton one.
25504         (value_replacement): Change return type to int.  Return 0 instead of
25505         false.
25506         Allow the middle basic block to contain more than just the defining
25507         statement.
25508         Handle non empty middle basic blocks.
25509         * Makefile.in (tree-ssa-phiopt.o): Add tree-pretty-print.h.
25510
25511 2012-03-09  Jiangning Liu  <jiangning.liu@arm.com>
25512
25513         * tree-scalar-evolution (interpret_rhs_expr): generate chrec for
25514         array reference and component reference.
25515         (analyze_scalar_evolution_for_address_of): New.
25516
25517 2012-03-08  Jie Zhang  <jzhang918@gmail.com>
25518
25519         PR target/49862
25520         * config/bfin/bfin.c (hwloop_optimize): Fix unused variable warnings.
25521         (hwloop_pattern_reg): Fix set but not used warning.
25522         (bfin_reorg_loops): Remove unused parameter.
25523         (bfin_reorg): Update use of bfin_reorg_loops.
25524
25525 2012-03-08  H.J. Lu  <hongjiu.lu@intel.com>
25526
25527         * config/i386/i386.c (setup_incoming_varargs_64): Use word_mode
25528         with integer parameters in registers.
25529         (gen_push): Push register in word_mode instead of Pmode.
25530         (ix86_emit_save_regs): Likewise.
25531         (ix86_emit_save_regs_using_mov): Save integer registers in word_mode.
25532         (gen_pop): Pop register in word_mode instead of Pmode.
25533         (ix86_emit_restore_regs_using_pop): Likewise.
25534         (ix86_expand_prologue): Replace Pmode with word_mode for push
25535         immediate.  Use ix86_gen_pro_epilogue_adjust_stack.  Save and
25536         restore RAX and R10 in word_mode.
25537         (ix86_emit_restore_regs_using_mov): Restore integer registers
25538         in word_mode.
25539         (ix86_expand_split_stack_prologue): Save R10_REG and restore in
25540         word_mode.
25541         (ix86_split_to_parts): Use word_mode with PUT_MODE for push.
25542         (ix86_split_long_move): Likewise.
25543
25544         * config/i386/i386.md (W): New.
25545         (*push<mode>2_prologue): Replace :P with :W.
25546         (*pop<mode>1): Likewise.
25547         (*pop<mode>1_epilogue): Likewise.
25548         (push/pop peephole2): Use word_mode scratch registers.
25549
25550 2012-03-08  Uros Bizjak  <ubizjak@gmail.com>
25551
25552         * config/i386/predicates.md (indirect_branch_operand): Simplify.
25553
25554 2012-03-08  Georg-Johann Lay  <avr@gjlay.de>
25555
25556         * config/avr/avr.md (*addhi3, addhi3_clobber): Add "w" alternative
25557         for constants in [-63,63].
25558
25559 2012-03-08  Uros Bizjak  <ubizjak@gmail.com>
25560
25561         PR target/52530
25562         Revert:
25563         2012-03-04  H.J. Lu  <hongjiu.lu@intel.com>
25564
25565         * config/i386/i386.c (ix86_print_operand_address): Only handle
25566         zero-extended DImode addresses.
25567
25568 2012-03-08  Rainer Orth  <ro@CeBiTec.Uni-Bielefeld.DE>
25569
25570         * configure.ac (gcc_cv_as_ix86_tlsldmplt): Add label.
25571         * configure: Regenerate.
25572
25573 2012-03-08  Georg-Johann Lay  <avr@gjlay.de>
25574
25575         PR target/52496
25576         * config/avr/avr.c (avr_mem_clobber): New static function.
25577         (avr_expand_delay_cycles): Add memory clobber operand to
25578         delay_cycles_1, delay_cycles_2, delay_cycles_3, delay_cycles_4.
25579         * config/avr/avr.md (unspec): Add UNSPEC_MEMORY_BARRIER.
25580         (enable_interrupt, disable_interrupt): New expander.
25581         (nopv, sleep, wdr): New expanders.
25582         (delay_cycles_1): Add memory clobber.
25583         (delay_cycles_2): Add memory clobber.
25584         (delay_cycles_3): Add memory clobber.
25585         (delay_cycles_4): Add memory clobber.
25586         (cli_sei): New insn from former "enable_interrupt",
25587         "disable_interrupt" with memory clobber.
25588         (*wdt): New insn from former "wdt" with memory clobber.
25589         (*nopv): Similar, but for "nopv".
25590         (*sleep): Similar, but for "sleep".
25591
25592 2012-03-07  Oleg Endo  <olegendo@gcc.gnu.org>
25593             Kaz Kojima  <kkojima@gcc.gnu.org>
25594
25595         PR target/52503
25596         * config/sh/sh.opt (msoft-atomic): Use Var instead of Mask.
25597         * config/sh/linux.h (TARGET_DEFAULT): Remove MASK_SOFT_ATOMIC.
25598         (SUBTARGET_OVERRIDE_OPTIONS): Define.
25599
25600 2012-03-07  Uros Bizjak  <ubizjak@gmail.com>
25601
25602         * config/i386/predicates.md (x86_64_zext_general_operand): New.
25603         * config/i386/i386.md (*zero_extendsidi2_rex64): Change operand 1
25604         predicate to x86_64_zext_general_operand.  Accept "Z" constraint.
25605
25606 2012-03-07  Walter Lee  <walt@tilera.com>
25607
25608         * config/tilegx/tilegx.c (tilegx_expand_prologue): Don't generate
25609         REG_CFA_* notes for the stack pointer.
25610         (tilegx_expand_epilogue): Restore stack pointer by adjusting it by
25611         EH_RETURN_STACKADJ_RTX.
25612         * config/tilepro/tilepro.c (tilepro_expand_prologue): Don't
25613         generate REG_CFA_* notes for the stack pointer.
25614         (tilepro_expand_epilogue): Restore stack pointer by adjusting it
25615         by EH_RETURN_STACKADJ_RTX.
25616
25617 2012-03-07  Georg-Johann Lay  <avr@gjlay.de>
25618
25619         * doc/invoke.texi (AVR Built-in Macros): Correct condition for
25620         when __AVR_3_BYTE_PC__ is defined.
25621
25622 2012-03-07  Uros Bizjak  <ubizjak@gmail.com>
25623
25624         * config/i386/i386.c (ix86_print_operand_punct_valid_p): Add '^'.
25625         (ix86_print_operand): Handle '^'.
25626         * config/i386/i386.md (*strmovdi_rex_1): Macroize memory operands
25627         using P mode iterator.  Add %^ to asm template to conditionally emit
25628         addr32 prefix.
25629         (*rep_movdi_rex64): Ditto.
25630         (*strsetdi_rex_1): Ditto.
25631         (*rep_stosdi_rex64): Ditto.
25632         (*strmov{si,hi,qi}_1): Add %^ to asm template to
25633         conditionally emit addr32 prefix.
25634         (*rep_mov{si,qi}): Ditto.
25635         (*strset{si,hi,qi}): Ditto.
25636         (*rep_stos{si,qi}): Ditto.
25637         (*cmpstrnqi_nz_1): Ditto.
25638         (*cmpstrnqi_1): Ditto.
25639         (*strlenqi_1): Ditto.
25640
25641 2012-03-07  H.J. Lu  <hongjiu.lu@intel.com>
25642
25643         * config/i386/i386.c (function_value_64): Return pointers in
25644         word_mode instead of Pmode.
25645         (ix86_promote_function_mode): Likewise.
25646
25647 2012-03-07  Richard Guenther  <rguenther@suse.de>
25648
25649         * coverage.c (get_gcov_type): Use type_for_mode.
25650         (get_gcov_unsigned_t): Likewise.
25651         * expr.c (store_constructor): Use type_for_mode.
25652         (try_casesi): Likewise.
25653         * tree-ssa-loop-ivopts.c (add_standard_iv_candidates_for_size): Remove.
25654         (add_standard_iv_candidates): Use standard type trees.
25655         * dojump.c (do_jump): Remove dead code.
25656
25657 2012-03-07  Richard Guenther  <rguenther@suse.de>
25658
25659         * c-typeck.c (pointer_diff): Use c_common_type_for_size.
25660
25661 2012-03-07  Richard Guenther  <rguenther@suse.de>
25662
25663         * convert.c (strip_float_extensions): Move ...
25664         * tree.c (strip_float_extensions): ... here.
25665
25666 2012-03-07  Georg-Johann Lay  <avr@gjlay.de>
25667
25668         PR target/52484
25669         * config/avr/avr.md (xload<mode>_A): Add R22... to register footprint.
25670
25671 2012-03-07  Richard Guenther  <rguenther@suse.de>
25672
25673         * omp-low.c (extract_omp_for_data): Use signed_type_for.
25674         (expand_omp_for_generic): Likewise.
25675         (expand_omp_for_static_nochunk): Likewise.
25676         (expand_omp_for_static_chunk): Likewise.
25677         * tree-vect-stmts.c (vect_gen_perm_mask): Use type_for_mode.
25678         * tree-vect-slp.c (vect_transform_slp_perm_load): Likewise.
25679         * tree-vect-loop-manip.c (vect_gen_niters_for_prolog_loop):
25680         Use unsigned_type_for.
25681         (vect_create_cond_for_align_checks): Use signed_type_for.
25682
25683 2012-03-07  Andrey Belevantsev  <abel@ispras.ru>
25684
25685         PR rtl-optimization/52203
25686         * sel-sched.c (estimate_insn_cost): New parameter pempty.  Adjust
25687         all callers to pass NULL except ...
25688         (reset_sched_cycles_in_current_ebb): ... here, save the value
25689         in new variable 'empty'.  Increase issue_rate only for
25690         non-empty insns.
25691
25692 2012-03-07  Ralf Corsépius  <ralf.corsepius@rtems.org>
25693
25694         PR target/51417
25695         * Makefile.in: Let install-gcc-ar depend on installdirs,
25696         gcc-ar$(exeext), gcc-nm$(exeext), gcc-ranlib$(exeext).
25697         Don't double canonicalize if cross-compiling.
25698
25699 2012-03-07  Georg-Johann Lay  <avr@gjlay.de>
25700
25701         PR target/52506
25702         * gcc/config/avr/avr.c (expand_epilogue): Fix order of restoration
25703         to: RAMPZ, RAMPY, RAMPX, RAMPD.
25704         (expand_prologue): Only clear RAMPZ if it has effect on RAM-read.
25705
25706 2012-03-07  Georg-Johann Lay  <avr@gjlay.de>
25707
25708         PR target/52505
25709         * config/avr/avr.c (avr_out_xload): Don't read unintentionally
25710         from RAM.
25711         * config/avr/avr.md (xload_8): Adjust insn length.
25712
25713 2012-03-07  Georg-Johann Lay  <avr@gjlay.de>
25714
25715         PR target/52461
25716         * gcc/config/avr/avr.c (avr_out_lpm): Clear RAMPZ after usage
25717         if RAMPZ affects reading from RAM.
25718
25719 2012-03-07  Richard Guenther  <rguenther@suse.de>
25720
25721         PR pch/52518
25722         PR pch/38987
25723         * doc/invoke.texi (Precompiled Headers): Remove sentence that
25724         suggests you can include PCHs from inside another header.
25725
25726 2012-03-07  Richard Sandiford  <rdsandiford@googlemail.com>
25727
25728         PR middle-end/52515
25729         * rtl.h (pc_rtx, cc0_rtx, ret_rtx, simple_return_rtx): Add GTY markers.
25730
25731 2012-03-07  Kai Tietz  <ktietz@redhat.com>
25732
25733         * doc/invoke.texi (fwritable-relocated-rdata): Document
25734         new Cygwin/MinGW target option.
25735         * config/i386/winnt.c (i386_pe_unique_section): Ignore
25736         reloc if flag -fwritable-relocated-rdata is not set.
25737         (i386_pe_section_type_flags): Likewise.
25738         * config/i386/cygming.opt (fwritable-relocated-rdata):
25739         Add new flag variable flag_writable_rel_rdata.
25740
25741 2012-03-07  Richard Guenther  <rguenther@suse.de>
25742
25743         * tree-ssa-math-opts.c (convert_mult_to_widen): Check actual
25744         precision against gimple constraints.
25745
25746 2012-03-06  Richard Sandiford  <rdsandiford@googlemail.com>
25747
25748         PR middle-end/52372
25749         * rtl.h (pc_rtx, ret_rtx, simple_return_rtx, cc0_rtx): Redefine as
25750         variables.
25751         (GR_PC, GR_CC0, GR_RETURN, GR_SIMPLE_RETURN): Delete.
25752         * emit-rtl.c (pc_rtx, ret_rtx, simple_return_rtx, cc0_rtx): New
25753         variables.
25754         (init_emit_regs): Move associated initialization to...
25755         (init_emit_once): ...here.
25756
25757 2012-03-06  Richard Henderson  <rth@redhat.com>
25758
25759         * config/m68k/m68k.h (ISA_HAS_TAS): New.
25760         * config/m68k/sync.md (atomic_test_and_set): Use it.
25761         (atomic_test_and_set_1): Likewise.
25762
25763 2012-03-06  Michael Meissner  <meissner@linux.vnet.ibm.com>
25764
25765         PR target/50310
25766         * config/rs6000/vector.md (vector_uneq<mode>): Add support for
25767         UNEQ, LTGT, ORDERED, and UNORDERED IEEE vector comparisons.
25768         (vector_ltgt<mode>): Likewise.
25769         (vector_ordered<mode>): Likewise.
25770         (vector_unordered<mode>): Likewise.
25771         * config/rs6000/rs6000.c (rs6000_emit_vector_compare_inner): Likewise.
25772
25773 2012-03-06  Aldy Hernandez  <aldyh@redhat.com>
25774
25775         * trans-mem.c: New typedef for tm_region_p.
25776         Define vector types for tm_region_p.
25777         (tm_region_init): Replace region_worklist to a vector called
25778         bb_regions.
25779
25780 2012-03-06  Richard Guenther  <rguenther@suse.de>
25781
25782         * fold-const.c (build_fold_addr_expr_with_type_loc): Fold
25783         MEM_REF with constant pointer operand.
25784
25785 2012-03-06  Richard Guenther  <rguenther@suse.de>
25786
25787         PR middle-end/52493
25788         * tree-ssa-alias.c (ptr_derefs_may_alias_p): Robustify.
25789
25790 2012-03-06  Tristan Gingold  <gingold@adacore.com>
25791
25792         * config/vms/vms-c.c (vms_pragma_nomember_alignment): Handle octaword.
25793         (external_model_kind): Improve documentation.
25794         (vms_pragma_extern_model): Handle relaxed_redef.
25795         (vms_c_register_pragma): Allow expansion for nomember_alignment.
25796
25797 2012-03-06  Georg-Johann Lay  <avr@gjlay.de>
25798
25799         * doc/invoke.texi (AVR Options): -mmcu=: Document the XMEGA cores.
25800         Explain RAMPD, RAMPX, RAMPDY, RAMPZ usage by avr-gcc.
25801         Some more notes on EIND usage and reorder EIND subsection.
25802
25803 2012-03-06  Tristan Gingold  <gingold@adacore.com>
25804
25805         * config/vms/vms.c (VMS_CRTL_LDBL): Rename from VMS_CRTL_PRNTF.
25806         * config/vms/vms-crtlmap.map: Rename PRNTF to LDBL.
25807
25808 2012-03-06  Tristan Gingold  <gingold@adacore.com>
25809
25810         * config/vms/t-vmsnative (version): Define.
25811         * config/vms/t-vms (STMP_FIXPROTO, STMP_FIXINC, version): Remove.
25812
25813 2012-03-06  Andrey Belevantsev  <abel@ispras.ru>
25814
25815         PR rtl-optimization/52250
25816         * sel-sched-ir.c (maybe_tidy_empty_bb): Try harder to find a bb
25817         to put note list into.  Unconditionally call move_bb_info.
25818         (move_bb_info): Do not assert the blocks being in the same region,
25819         just drop the note list if they are not.
25820
25821 2012-03-06  Oleg Endo  <olegendo@gcc.gnu.org>
25822
25823         PR target/51244
25824         * config/sh/sh.c (sh_expand_t_scc): Remove SH2A special case
25825         and use unified expansion logic.
25826         * config/sh/sh.md (xorsi3_movrt): Rename to movrt.  Move
25827         closer to the existing movt insn.
25828         (negc): Rename insn to *negc.  Add new expander.
25829         (movnegt): Use xor pattern for T bit negation.  Reserve helper
25830         constant for negc pattern.
25831         (*movnegt): New insn and splitter.
25832
25833 2012-03-05  Bernd Schmidt  <bernds@codesourcery.com>
25834
25835         * c-typeck.c (pointer_diff): Check for POINTER_PLUS_EXPR, not
25836         PLUS_EXPR.
25837
25838 2012-03-05  Richard Henderson  <rth@redhat.com>
25839
25840         * genemit.c (main): Include "target.h" in insn-emit.c.
25841         * Makefile.in (insn-emit.o): Depend on TARGET_H.
25842         * config/sh/sync.md (atomic_test_and_set): Reference
25843         targetm.atomic_test_and_set_trueval instead of
25844         TARGET_ATOMIC_TEST_AND_SET_TRUEVAL.
25845
25846 2012-03-05  Joern Rennecke  <joern.rennecke@embecosm.com>
25847
25848         * config/epiphany/epiphany.c (epiphany_function_value_regno_p):
25849         Make static.
25850
25851 2012-03-05  Steven Bosscher  <steven@gcc.gnu.org>
25852
25853         * langhooks.c (add_builtin_type): New function.
25854         * langhooks.h (add_builtin_type): Export it.
25855         * config/mep/mep.c (mep_init_builtins): Use it.
25856         * config/rs6000/rs6000.c (rs6000_init_builtins): Use it.
25857
25858 2012-03-05  Jakub Jelinek  <jakub@redhat.com>
25859
25860         PR debug/51902
25861         * tree.h (BLOCK_SAME_RANGE): Define.
25862         * function.c (block_fragments_nreverse): Clear BLOCK_SAME_RANGE
25863         if BLOCK_FRAGMENT_CHAIN is non-NULL, but has it cleared.
25864         Also clear BLOCK_SAME_RANGE if fragment chain's supercontext fragment
25865         isn't equal to supercontext fragment's fragment chain.
25866         Adjust BLOCK_SUPERCONTEXT to point to supercontext fragment's
25867         fragment origin.
25868         (blocks_nreverse_all): Likewise.
25869         (reorder_blocks_1): Compute BLOCK_SAME_RANGE bits.  Set
25870         BLOCK_SUPERCONTEXT to supercontext fragment instead of
25871         supercontext fragment's fragment origin.
25872         * dwarf2out.c (add_high_low_attributes): If stmt has the same
25873         range as its parent (or parents thereof etc.), use the parent's
25874         DW_AT_ranges value instead of creating a new .debug_ranges range.
25875
25876 2012-03-05  Richard Henderson  <rth@redhat.com>
25877
25878         PR tree-opt/52242
25879         Revert: 2011-11-26  Richard Henderson  <rth@redhat.com>
25880         * omp-low.c (expand_omp_atomic): Assume anything aligned to
25881         BIGGEST_ALIGNMENT is aligned.
25882
25883 2012-03-05  Richard Henderson  <rth@redhat.com>
25884
25885         * config/sh/sh.h (TARGET_ATOMIC_TEST_AND_SET_TRUEVAL): Move...
25886         * config/sh/sh.c: ... here.
25887
25888 2012-03-05  Richard Henderson  <rth@redhat.com>
25889
25890         PR target/52481
25891         * config/m68k/sync.md (atomic_test_and_set): Use expand_simple_unop
25892         instead of calling negqi2 directly.
25893
25894 2012-03-05  Aldy Hernandez  <aldyh@redhat.com>
25895
25896         PR middle-end/52463
25897         * trans-mem.c (tm_region_init): Use last_basic_block.
25898
25899 2012-03-05  Oleg Endo  <olegendo@gcc.gnu.org>
25900
25901         * config/sh/sh.h (TARGET_ATOMIC_TEST_AND_SET_TRUEVAL): New hook.
25902         * config/sh/sync.md (atomic_test_and_set): New expander.
25903         (tasb, atomic_test_and_set_soft): New insns.
25904         * config/sh/sh.opt (menable-tas): New option.
25905         * doc/invoke.texi (SH Options): Document it.
25906
25907 2012-03-05  Richard Guenther  <rguenther@suse.de>
25908
25909         * cfgloop.c (verify_loop_structure): Verify dominators before
25910         using them.
25911         * graphite-clast-to-gimple.c (graphite_verify): Do not verify
25912         dominators from here.
25913         * graphite-scop-detection.c (create_sese_edges): Likewise.
25914         * loop-doloop.c (doloop_optimize_loops): Likewise.
25915         * loop-init.c (loop_optimizer_init): Likewise.
25916         * loop-unroll.c (unroll_and_peel_loops): Likewise.
25917         * loop-unswitch.c (unswitch_loops): Likewise.
25918         * tree-ssa-loop-manip.c (tree_transform_and_unroll_loop): Likewise.
25919         * tree-parloops.c (parallelize_loops): Likewise.  Verify
25920         only when checking is enabled.
25921         * tree-loop-distribution.c (tree_loop_distribution): Likewise.
25922
25923 2012-03-05  Bernd Schmidt  <bernds@codesourcery.com>
25924
25925         * genautomata.c (parse_automata_opt): New static function.
25926         (initiate_automaton_gen): Remove all option handling code.  Remove
25927         argc argument.  All callers changed.
25928         (main): Call init_rtx_reader_args_cb with the new function as argument.
25929
25930 2012-03-05  Richard Guenther  <rguenther@suse.de>
25931
25932         * cfgexpand.c (gimple_expand_cfg): Free dominator info.
25933         * tree-if-conv.c (combine_blocks): Free post-dominator info
25934         after breaking it.
25935         * tree-parloops.c (create_parallel_loop): Free and re-compute
25936         dominator info after breaking it.
25937
25938 2012-03-05  Richard Guenther  <rguenther@suse.de>
25939
25940         PR middle-end/52353
25941         * optabs.h (trapv_unoptab_p): New function.
25942         (trapv_binoptab_p): Likewise.
25943         * optabs.c (expand_binop): Use emit_libcall_block_1 with
25944         a proper equiv_may_trap argument.
25945         (expand_unop): Likewise.
25946         (emit_libcall_block_1): Take extra argument whether the
25947         instruction may trap.  Renamed from ...
25948         (emit_libcall_block): ... this.  New wrapper.
25949
25950 2012-03-05  Jakub Jelinek  <jakub@redhat.com>
25951
25952         PR tree-optimization/51721
25953         * tree-vrp.c (register_edge_assert_for_2): If comparing
25954         lhs of right shift by constant with an integer constant,
25955         add ASSERT_EXPRs for the rhs1 of the right shift.
25956
25957         * cfgrtl.c (cfg_layout_merge_blocks): Cleanup.
25958
25959 2012-03-05  Richard Guenther  <rguenther@suse.de>
25960
25961         * tree.c (integer_zerop): Handle VECTOR_CSTs.
25962         (integer_onep): Likewise.
25963         (integer_all_onesp): Likewise.
25964
25965 2012-03-05  Georg-Johann Lay  <avr@gjlay.de>
25966
25967         * config/avr/avr.md (*umaddqihi4.2): New insn-and-split.
25968
25969 2012-03-04  H.J. Lu  <hongjiu.lu@intel.com>
25970
25971         * config/i386/i386.c (pro_epilogue_adjust_stack): Check Pmode
25972         instead of TARGET_64BIT.
25973
25974 2012-03-04  H.J. Lu  <hongjiu.lu@intel.com>
25975
25976         * config/i386/i386.c (ix86_expand_prologue): Check Pmode to set
25977         adjust_stack_insn.
25978
25979 2012-03-04  H.J. Lu  <hongjiu.lu@intel.com>
25980
25981         * config/i386/i386.c (ix86_print_operand_address): Only handle
25982         zero-extended DImode addresses.
25983
25984 2012-03-04  Uros Bizjak  <ubizjak@gmail.com>
25985
25986         * config/i386/i386.c (ix86_print_operand) <case '+'>: Declare
25987         taken and cputaken as bool.
25988
25989 2012-03-04  Uros Bizjak  <ubizjak@gmail.com>
25990
25991         * config/i386/constraints.md (Ya): New internal constraint.
25992         * config/i386/i386.md (zero_extendsidi2): Remove expansion.
25993         (*zero_extendsidi2_rex64): Add x,x alternative.
25994         (*zero_extendsidi2): Ditto.  Add o,0 alternative.
25995         Remove flags reg clobber.  Adjust corresponding splits.
25996         (zero_extend<mode>si2): Macroize expander from zero_extendhisi2 and
25997         zero_extendqisi2 expanders using SWI12 mode iterator.
25998         (zero_extend<mode>si2_and): Macroize insn from
25999         zero_extendhisi2_and and zero_extendqisi2_and.  Merge corresponding
26000         splitters.
26001         (*zero_extend<mode>si2):  Macroize insn from
26002         *zero_extendhisi2_movzbl and *zero_extendqisi2_movzbl.
26003         (*zero_extend*2_movzbl_and): Remove insn patterns.
26004         (zero_extendqihi2_and): Merge corresponding splitter.
26005         (*zero_extendqihi2): Rename from *zero_extendqihi2_movzbl.
26006         (*zero_extend*2_movzbl_and): Remove insn patterns.
26007         (*anddi_1): Split TYPE_IMOVX instructions.
26008         (*andsi_1): Use Ya for alternative 2.  Split TYPE_IMOVX instructions.
26009         (*andhi_1): Ditto.
26010         (and->zext splitter): Add splitter pattern.
26011         (zero extend with andsi3 splitter): Adjust zero_extend pattern.
26012
26013 2012-03-04  Sandra Loosemore  <sandra@codesourcery.com>
26014
26015         * doc/invoke.texi (C++ Dialect Options): Minor copy-edits to
26016         x86-specific text.
26017         (Debugging Options): Likewise.
26018         (Optimize Options): Likewise.
26019         (i386 and x86-64 Options): Discuss -march before -mtune, consistently
26020         with other architectures.  Use official processor names with correct
26021         spelling/capitalization.  Fix formatting and grammar issues.
26022         (i386 and x86-64 Windows Options): Similar cleanup here.
26023
26024 2012-03-03  Kaz Kojima  <kkojima@gcc.gnu.org>
26025
26026         * config/sh/sh.md (abssi2): Add TARGET_SH1 condition.
26027
26028 2012-03-03  Kaz Kojima  <kkojima@gcc.gnu.org>
26029
26030         * config/sh/sh.c (sh_dwarf_register_span): Don't apply
26031         DBX_REGISTER_NUMBER.
26032
26033 2012-03-03  Kaz Kojima  <kkojima@gcc.gnu.org>
26034
26035         * config/sh/sh.c (shiftcosts): Return MAX_COST when the first
26036         operand is CONST_INT.  Take COSTS_N_INSNS into account.
26037         (sh_rtx_costs): Don't apply COSTS_N_INSNS to the return value
26038         of shiftcosts.
26039
26040 2012-03-02  Richard Henderson  <rth@redhat.com>
26041
26042         * optabs.c (expand_atomic_test_and_set): Honor
26043         atomic_test_and_set_trueval even when atomic_test_and_set
26044         optab is not in use.
26045
26046 2012-03-02  Kaz Kojima  <kkojima@gcc.gnu.org>
26047
26048         PR target/48596
26049         PR target/48806
26050         * config/sh/sh.c (sh_register_move_cost): Increase cost between
26051         GENERAL_REGS and FP_REGS for SImode.
26052
26053 2012-03-02  Oleg Endo  <olegendo@gcc.gnu.org>
26054
26055         PR target/49486
26056         * config/sh/sh.md (negdi2): Add TARGET_SH1 condition.
26057         (absdi2): New expander.
26058         (*absdi2, *negabsdi2, negdi_cond): New insns and splits.
26059
26060 2012-03-02  Oleg Endo  <olegendo@gcc.gnu.org>
26061
26062         * config/sh/sync.md (atomic_exchange<mode>): New expander.
26063         (atomic_exchange<mode>_soft): New insn.
26064
26065 2012-03-02  Oleg Endo  <olegendo@gcc.gnu.org>
26066
26067         * config/sh/sync.md: Update copyright notice dates.
26068         (atomic_compare_and_swap<mode>): Use SImode for return value instead
26069         of QImode.
26070         (atomic_compare_and_swap<mode>_soft): Likewise.
26071
26072 2012-03-02  Oleg Endo  <olegendo@gcc.gnu.org>
26073
26074         PR target/31640
26075         * config/sh/sh.h (LOOP_ALIGN): Move logic to sh_loop_align.
26076         * config/sh/sh.c: Update copyright notice dates.
26077         (sh_loop_align): Add logic from LOOP_ALIGN.  Don't disable loop
26078         alignment for TARGET_HARD_SH4.
26079         (sh_option_override): Reduce default function alignment.  Set
26080         loop alignment to 4 bytes when not optimizing for size.
26081
26082 2012-03-02  Maxim Kuvyrkov  <maxim@codesourcery.com>
26083
26084         PR middle-end/50335
26085         * doc/invoke.texi (floop-flatten): Remove.
26086         * toplev.c (process_options): Remove references to flag_loop_flatten.
26087         * tree-ssa-loop.c (gate_graphite_transform): Same.
26088         * common.opt (floop-flatten): Obsolete.
26089         * graphite-poly.c (apply_poly_transforms): Remove reference to
26090         flag_loop_flatten.
26091         * Makefile.in (graphite-flattening.o): Remove.
26092         * graphite-flattening.c: Remove.
26093
26094 2012-03-02  Uros Bizjak  <ubizjak@gmail.com>
26095
26096         * compare-elim.c (find_comparisons_in_bb): Eliminate only compares
26097         having mode compatible with the mode of previous compare.  Substitute
26098         compare mode of previous compare with the mode, compatible
26099         with eliminated and previous compare.
26100
26101 2012-03-02  Peter Bergner  <bergner@vnet.ibm.com>
26102
26103         * config/rs6000/dfp.md (floatdidd2): New define_insn.
26104
26105 2012-03-02  Uros Bizjak  <ubizjak@gmail.com>
26106
26107         * config/i386/i386.c (ix86_cc_modes_compatible): Declare CCZmode
26108         compatible with CCGOCmode and CCGCmode.
26109
26110 2012-03-02  Peter Bergner  <bergner@vnet.ibm.com>
26111
26112         * config/rs6000/vsx.md (vsx_set_<mode>): Reorder operands.
26113
26114 2012-03-02  Ulrich Weigand  <ulrich.weigand@linaro.org>
26115
26116         * config/arm/arm.c (arm_sat_operator_match): New function.
26117         * config/arm/arm-protos.h (arm_sat_operator_match): Add prototype.
26118         * config/arm/arm.md ("insn" attribute): Add "sat" value.
26119         ("SAT", "SATrev"): New code iterators.
26120         ("SATlo", "SAThi"): New code iterator attributes.
26121         ("*satsi_<SAT:code>"): New pattern.
26122         ("*satsi_<SAT:code>_shift"): Likewise.
26123         * config/arm/arm-fixed.md ("arm_ssatsihi_shift"): Add "insn"
26124         and "shift" attributes.
26125         ("arm_usatsihi"): Add "insn" attribute.
26126         * config/arm/predicates.md (sat_shift_operator): Allow multiplication
26127         by powers of two.  Do not allow shift by 32.
26128
26129 2012-03-02  Uros Bizjak  <ubizjak@gmail.com>
26130
26131         PR target/46716
26132         * config/i386/i386.c (construct_container): Use gen_reg_or_parallel
26133         to pass the argument in the register of "natural" mode.
26134
26135 2012-03-02  Richard Guenther  <rguenther@suse.de>
26136
26137         PR tree-optimization/52406
26138         * tree-data-ref.h: Update documentation about DR_BASE_OBJECT.
26139         (struct indices): Add unconstrained_base member.
26140         (struct dr_alias): Remove unused vops member.
26141         (DR_UNCONSTRAINED_BASE): New define.
26142         * tree-data-ref.c (dr_analyze_indices): For COMPONENT_REFs
26143         add indices to allow their disambiguation.  Make DR_BASE_OBJECT
26144         be an artificial access that covers the whole indexed object,
26145         or mark it with DR_UNCONSTRAINED_BASE if we cannot do so.  Canonicalize
26146         plain decl base-objects to their MEM_REF variant.
26147         (dr_may_alias_p): When the base-object of either data reference
26148         has unknown size use only points-to information.
26149         (compute_affine_dependence): Make dumps easier to read and
26150         more verbose.
26151         * tree-vect-data-ref.c (vector_alignment_reachable_p): Use
26152         DR_REF when looking for packed references.
26153         (vect_supportable_dr_alignment): Likewise.
26154
26155 2012-03-02  Greta Yorsh  <Greta.Yorsh@arm.com>
26156
26157         * config/arm/arm-ldmstm.ml (write_ldm_commutative_peephole):
26158         Improve conditions for peepholes of loads followed by commutative
26159         operators.
26160         * config/arm/ldmstm.md: Regenerated.
26161
26162 2012-03-02  Richard Guenther  <rguenther@suse.de>
26163
26164         * BASE-VER: Set to 4.8.0.
26165
26166 2012-03-01  Richard Earnshaw  <rearnsha@arm.com>
26167
26168         * config.gcc (obsolete): Add all ARM targets using the FPA.
26169         (with_fpu): Obsolete selection of the FPA or Maverick on ARM.
26170         * doc/install.texi: Avoid references to obsolete ARM ports.
26171
26172 2012-03-01  Joern Rennecke  <joern.rennecke@embecosm.com>
26173
26174         * config/epiphany/epiphany.md (movmisalign<mode>): New patterns.
26175
26176 2012-03-01  Jeremy Bennett  <jeremy.bennett@embecosm.com>
26177             Joern Rennecke  <joern.rennecke@embecosm.com>
26178
26179         * doc/extend.texi: Expand and update information on interrupt
26180         attribute for Epiphany.
26181
26182 2012-03-01  Oleg Endo  <olegendo@gcc.gnu.org>
26183
26184         * config/sh/sh-protos.h: Update copyright notice dates.
26185         * config/sh/sh.h: Likewise.
26186         * config/sh/sh.md: Likewise.
26187         * config/sh/constraints.md: Likewise.
26188         * config/sh/predicates.md: Likewise.
26189
26190 2012-03-01  Oleg Endo  <olegendo@gcc.gnu.org>
26191
26192         * config/sh/sh-protos.h (tertiary_reload_operand): Remove dead function.
26193         * config/sh/sh.c (tertiary_reload_operand): Likewise.
26194
26195 2012-03-01  Oleg Endo  <olegendo@gcc.gnu.org>
26196
26197         * config/sh/constraints.md: Fix comment typo.
26198
26199 2012-03-01  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
26200
26201         PR target/52408
26202         * config/pa/pa.md (zvdep_imm32): Change type of variable x from int to
26203         unsigned HOST_WIDE_INT.
26204         (zvdep_imm64): Likewise.
26205         (vdepi_ior): Change type of variable x from int to HOST_WIDE_INT.
26206         (vdepi_and): Likewise.
26207         Likewise for unamed 64-bit patterns.
26208         * config/pa/predicates.md (lhs_lshift_cint_operand): Update comment.
26209
26210 2012-03-01  Alexandre Oliva  <aoliva@redhat.com>
26211
26212         PR debug/52001
26213         PR rtl-optimization/52417
26214         * cselib.c (cselib_any_perm_equivs): New variable.
26215         (cselib_reset_table): Check that it's not set when not
26216         preserving constants.
26217         (cselib_add_permanent_equiv): Set it.
26218         (cselib_have_permanent_equivalences): New.
26219         (cselib_init, cselib_finish): Reset it.
26220         * cselib.h (cselib_have_permanent_equivalences): Declare.
26221         * alias.c (get_addr): Restore earlier behavior when there
26222         aren't permanent equivalences.
26223
26224 2012-03-01  Steven Bosscher  <steven@gcc.gnu.org>
26225
26226         * config/mn10300/mn10300-modes.def: Fix copyright notice.
26227         * config/v850/v850-modes.def: Fix copyright notice.
26228
26229 2012-03-01  Georg-Johann Lay  <avr@gjlay.de>
26230
26231         * doc/extend.texi (AVR Built-in Functions): Document
26232         __builtin_avr_flash_segment.
26233
26234         * config/avr/builtins.def (__builtin_avr_flash_segment): New entry.
26235         * config/avr/avr.md (flash_segment, flash_segment1): New expanders.
26236         (*split.flash_segment): New insn-and-split.
26237         * config/avr/avr.c (avr_init_builtins): Add local variables:
26238         const_memx_void_node, const_memx_ptr_type_node,
26239         char_ftype_const_memx_ptr.
26240
26241 2012-03-01  Jakub Jelinek  <jakub@redhat.com>
26242
26243         PR tree-optimization/52445
26244         * tree-ssa-phiopt.c (struct name_to_bb): Remove ssa_name field,
26245         add ssa_name_ver, offset and size fields and change store field
26246         to bool.
26247         (name_to_bb_hash, name_to_bb_eq): Adjust for the above changes.
26248         (add_or_mark_expr): Likewise.  Only consider previous stores
26249         with the same size and offset.
26250         (nt_init_block): Only look at gimple_assign_single_p stmts,
26251         doesn't look at rhs2.
26252
26253 2012-03-01  Richard Guenther  <rguenther@suse.de>
26254
26255         PR middle-end/52443
26256         * tree-cfg.c (verify_gimple_assign_unary): Allow any
26257         conversions from integral types to pointer types.
26258
26259 2012-03-01  Georg-Johann Lay  <avr@gjlay.de>
26260
26261         * config/avr/avr-c.c (avr_cpu_cpp_builtins): Restore built-in
26262         defines for __UINT24_MAX__, __INT24_MAX__, __INT24_MIN__
26263         unintentionally removed in r184616.
26264
26265 2012-03-01  Venkataramanan Kumar  <venkataramanan.kumar@amd.com>
26266
26267         * doc/invoke.texi: Document AMD bdver2 and remove mentioning
26268         3DNow from bdver1.
26269
26270 2012-02-29  Jakub Jelinek  <jakub@redhat.com>
26271             Uros Bizjak  <ubizjak@gmail.com>
26272
26273         PR target/52437
26274         * config/i386/sse.md (vec_set<mode>_0): Swap "*r" and "fF"
26275         alternatives, add "e" constraint to the new last alternative
26276         and ! to last 3 alternatives.
26277
26278 2012-02-29  Eric Botcazou  <ebotcazou@adacore.com>
26279
26280         * dwarf2out.c (modified_type_die): Set DW_AT_GNAT_descriptive_type and
26281         DW_AT_artificial attributes at the end of the processing.
26282         (gen_array_type_die): Likewise.
26283         (gen_enumeration_type_die): Likewise.
26284         (gen_struct_or_union_type_die): Likewise.
26285         (add_gnat_descriptive_type_attribute): Do not suppress debug info for
26286         the parent type.
26287
26288 2012-02-29  Jakub Jelinek  <jakub@redhat.com>
26289
26290         PR middle-end/52419
26291         * expr.c (expand_assignment): If doing misaligned store that doesn't
26292         cover all mode bits, perform a RMW cycle.
26293
26294         PR tree-optimization/52429
26295         * tree-parloops.c (separate_decls_in_region_debug): Return early
26296         if var is LABEL_DECL.
26297
26298 2012-02-29  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
26299
26300         PR tree-optimization/52424
26301         * tree-ssa-dom.c (dom_opt_leave_block): Push a marker before
26302         calling dom_thread_across_edge.
26303
26304 2012-02-29  Georg-Johann Lay  <avr@gjlay.de>
26305
26306         * config/avr/avr.c: Move definition of TARGET macros to end of file.
26307
26308 2012-02-29  Georg-Johann Lay  <avr@gjlay.de>
26309
26310         * config/avr/avr-protos.h (avr_output_bld): Remove unused prototype.
26311         * config/avr/avr.c (avr_output_bld): Remove unused function.
26312         (avr_out_sbxx_branch): Use "%T" to print bit position.
26313
26314 2012-02-29  Georg-Johann Lay  <avr@gjlay.de>
26315
26316         * config/avr/avr.md: Untabify.
26317
26318 2012-02-29  Georg-Johann Lay  <avr@gjlay.de>
26319
26320         * config/avr/avr.md (eqne): New code iterator.
26321         (*dec-and-branchsi): Use it in text peephole's condition.
26322         (*dec-and-branchhi): Ditto.
26323         (*dec-and-branchqi): Ditto.
26324
26325 2012-02-29  Georg-Johann Lay  <avr@gjlay.de>
26326
26327         PR target/49939
26328         * config/avr/avr.h (ASM_SPEC): Add -mno-skip-bug if we know that
26329         the device does not have the skip-bug.
26330
26331 2012-02-29  Oleg Endo  <olegendo@gcc.gnu.org>
26332
26333         * doc/invoke.texi (-msoft-atomic): Add more detailed description.
26334         (-mbranch-cost, -mcbranchdi -mcmpeqdi -mfused-madd
26335         -mpretend-cmove): New.
26336
26337 2012-02-29  Jakub Jelinek  <jakub@redhat.com>
26338
26339         PR bootstrap/52397
26340         * df.h (struct df_d): Adjust comment that hard_regs_live_count
26341         doesn't count DEBUG_INSN refs.
26342         * df-scan.c (df_ref_create_structure): Don't set DF_HARD_REG_LIVE
26343         for DEBUG_INSN refs.
26344
26345 2012-02-28  Ulrich Weigand  <Ulrich.Weigand@de.ibm.com>
26346
26347         Partially revert:
26348
26349         2012-02-20  Richard Guenther  <rguenther@suse.de>
26350         PR tree-optimization/52298
26351         * tree-vect-stmts.c (vectorizable_load): Properly use
26352         STMT_VINFO_DR_STEP instead of DR_STEP when vectorizing outer loops.
26353
26354 2012-02-28  Aldy Hernandez  <aldyh@redhat.com>
26355
26356         PR middle-end/51752
26357         * gimple.h (gimple_in_transaction): New.
26358         (gimple_set_in_transaction): New.
26359         (struct gimple_statement_base): Add in_transaction field.
26360         * tree-ssa-loop-im.c: (movement_possibility): Restrict movement of
26361         transaction loads.
26362         (tree_ssa_lim_initialize): Compute transaction bits.
26363         * tree.h (compute_transaction_bits): Protoize.
26364         * trans-mem.c (tm_region_init): Use the heap to store BB
26365         auxilliary data.
26366         (compute_transaction_bits): New.
26367
26368 2012-02-28  Bernhard Reutner-Fischer  <aldot@gcc.gnu.org>
26369
26370         * gcc.c (display_help): Document --help=common and sort entries
26371         alphabetically.
26372
26373 2012-02-28  Bernhard Reutner-Fischer  <aldot@gcc.gnu.org>
26374
26375         * doc/install.texi: Document check-$LANG specific shortcuts
26376
26377 2012-02-28  Matthew Gretton-Dann  <matthew.gretton-dann@arm.com>
26378
26379         PR target/51534
26380         * config/arm/arm.c (neon_builtin_data): Add entries for vcgeu
26381         and vcgtu.
26382         * config/arm/arm_neon.h: Regenerate.
26383         * config/arm/neon.md (unspec): Add UNSPEC_VCGEU, and UNSPEC_VCGTU.
26384         (neon_vcgeu): New insn.
26385         (neon_vcgtu): Likewise.
26386         * config/arm/neon.ml (s_8_32, u_8_32): New lists.
26387         (ops): Unsigned comparison intrinsics call a different builtin.
26388
26389 2012-02-28  Richard Guenther  <rguenther@suse.de>
26390
26391         PR target/52407
26392         * config/i386/i386.c (ix86_expand_vector_set): Fix element
26393         ordering for the VEC_CONCAT for two element vectors for
26394         V2SFmode, V2SImode and V2DImode.
26395
26396 2012-02-28  Richard Earnshaw  <rearnsha@arm.com>
26397
26398         PR target/49448
26399         * config.gcc (arm*-*-linux*): Use an unambiguous pattern for
26400         detecting big-endian triplets.
26401
26402 2012-02-28  Richard Earnshaw  <rearnsha@arm.com>
26403
26404         * arm.c (aapcs_vfp_is_call_or_return_candidate): Only use the machine
26405         mode if there is no type information available.
26406
26407 2012-02-28  Thomas Koenig  <tkoenig@gcc.gnu.org>
26408
26409         PR tree-optimization/53207
26410         * doc/invoke.texi: Document as experimental and relying on graphite.
26411
26412 2012-02-28  Georg-Johann Lay  <avr@gjlay.de>
26413
26414         * config/avr/avr-devices.c (avr_mcu_type): Adjust NULL part
26415         of initializer to changes from r184614.
26416
26417 2012-02-28  Richard Guenther  <rguenther@suse.de>
26418
26419         PR tree-optimization/52395
26420         * tree-sra.c (build_ref_for_offset): Also look at the base
26421         TYPE_ALIGN when figuring out the alignment of the replacement.
26422
26423 2012-02-28  Richard Guenther  <rguenther@suse.de>
26424
26425         PR tree-optimization/52402
26426         * ipa-prop.c (ipa_modify_call_arguments): Properly use
26427         mis-aligned types when creating the accesses at the call site.
26428
26429 2012-02-28  Georg-Johann Lay  <avr@gjlay.de>
26430
26431         * config/avr/builtins.def: New file.
26432         * config/avr/t-avr (avr.o, avr-c.o): Depend on it.
26433         * config/avr/avr.c (enum avr_builtin_id): Use it.
26434         (avr_init_builtins): Use it. And use avr_bdesc.
26435         (bdesc_1arg): Remove.
26436         (bdesc_2arg): Remove.
26437         (bdesc_3arg): Remove.
26438         (struct avr_builtin_description): Add field n_args.
26439         (avr_bdesc): New static variable using builtins.def.
26440         (avr_expand_builtin): Use it.
26441         Don't call avr_expand_delay_cycles if op0 is not CONST_INT.
26442         (avr_fold_builtin): Fold AVR_BUILTIN_SWAP.
26443         Don't fold AVR_BUILTIN_INSERT_BITS if arg0 is not INTEGER_CST.
26444
26445 2012-02-28  Georg-Johann Lay  <avr@gjlay.de>
26446
26447         PR target/52148
26448         * config/avr/avr.md (movmem_<mode>): Replace match_operand that
26449         match only one single hard register with respective hard reg rtx.
26450         (movmemx_<mode>): Ditto.
26451         * config/avr/avr.c (avr_emit_movmemhi): Adapt expanding to new
26452         insn anatomy of movmem[x]_<mode>.
26453         (avr_out_movmem): Same for printing assembler and operand usage.
26454
26455 2012-02-28  Georg-Johann Lay  <avr@gjlay.de>
26456
26457         PR target/49868
26458         PR target/52261
26459         * doc/extend.texi (AVR Named Address Spaces): No more try to fix
26460         address spaces located outside of device flash.
26461
26462         * config/avr/avr.h (base_arch_s): Remove field n_segments.
26463         (mcu_type_s): Add field n_flash.
26464         * config/avr/avr-devices.c (avr_arch_types): Remove .n_segments.
26465         Set .have_elpm and .have_elpmx to 1 for avrxmega4 and avrxmega5.
26466         (AVR_MCU): Add N_FLASH argument.
26467         * config/avr/avr-mcus.def (AVR_MCU): Add initializer for .n_flash.
26468         * config/avr/avr-c.c (avr_cpu_cpp_builtins): Only define built-in
26469         macro __FLASH<n> if that address space makes sense for the device.
26470         * config/avr/avr.c (avr_out_lpm): Don't try to fix address spaces
26471         outside of target flash.
26472         (avr_asm_named_section): Ditto.
26473         (avr_asm_select_section): Ditto.
26474         (avr_addr_space_convert): Ditto.
26475         (avr_emit_movmemhi): Ditto.
26476         (avr_nonconst_pointer_addrspace, avr_pgm_check_var_decl): Error if
26477         address space is outside of device flash.
26478         (avr_insert_attributes): Ditto.
26479         (avr_xload_libgcc_p): Use avr_current_device->n_flash instead of
26480         avr_current_arch->n_segments.
26481
26482 2012-02-27  H.J. Lu  <hongjiu.lu@intel.com>
26483
26484         PR target/52352
26485         * config/i386/i386.md (*movabs<mode>_1): Enable only for TARGET_LP64.
26486         (*movabs<mode>_2): Likewise.
26487
26488 2012-02-27  Jakub Jelinek  <jakub@redhat.com>
26489
26490         PR target/52375
26491         * config/arm/neon.md (vashr<mode>3, vlshr<mode>3): Use
26492         s_register_operand in the test instead of REG_P.  Don't call
26493         gen_reg_rtx if it won't be used.
26494
26495         PR tree-optimization/52376
26496         * ipa-split.c (split_function): Ignore CLOBBER stmts.
26497
26498 2012-02-27  Stuart Henderson  <shenders@gcc.gnu.org>
26499
26500         * ifcvt.c (noce_get_condition): Check condition variable is not
26501         small_register_classes_for_mode_p before accepting.
26502
26503 2012-02-27  Uros Bizjak  <ubizjak@gmail.com>
26504
26505         * config/i386/i386.md (*movabs<mode>_1): Fix operand 1 constraints.
26506
26507 2012-02-27  Matthew Gretton-Dann  <matthew.gretton-dann@arm.com>
26508
26509         Revert:
26510         2012-01-09  Matthew Gretton-Dann  <matthew.gretton-dann@arm.com>
26511         * config/arm/arm-cores.def (cortex-a15): Use cortex_a15_tune for
26512         tuning parameters.
26513         * config/arm/arm.c (arm_cortex_a15_tune): New static variable.
26514
26515 2012-02-27  Oleg Endo  <olegendo@gcc.gnu.org>
26516
26517         * config/sh/sh.h: Delete dead GO_IF_LEGITIMATE_INDEX macro.
26518
26519 2012-02-26  Oleg Endo  <olegendo@gcc.gnu.org>
26520
26521         * config/sh/predicates.md: Remove blank lines.
26522         * config/sh/sh.c: Fix typos in comments.
26523         * config/sh/constraints.md: Likewise.
26524         * config/sh/sh.md: Remove blank lines.
26525         Fix typos in comments.  Use ;; as comment characters.
26526
26527 2012-02-26  Walter Lee  <walt@tilera.com>
26528
26529         * config/tilegx/tilegx.c (match_pcrel_step2): Fix instruction pattern.
26530         (replace_mov_pcrel_step2): Ditto.
26531
26532 2012-02-25  Alexandre Oliva  <aoliva@redhat.com>
26533
26534         PR debug/52001
26535         * alias.c (refs_newer_value_cb, refs_newer_value_p): New.
26536         (get_addr): Walk canonical value's locs.  Avoid returning VALUEs
26537         and locs that reference values newer than the non-canonical value
26538         at hand.  Return the canonical value as a worst case.
26539         (memrefs_conflict_p): Walk canonical value's locs.
26540
26541         PR debug/52001
26542         * cselib.c (preserve_only_constants): Rename to...
26543         (preserve_constants_and_equivs): ... this.  Split out...
26544         (invariant_or_equiv_p): ... this.  Preserve plus expressions
26545         of other preserved expressions too.
26546         (cselib_reset_table): Adjust.
26547         * var-tracking.c (reverse_op): Use canonical value to build
26548         reverse operation.
26549
26550 2012-02-23  Kai Tietz  <ktietz@redhat.com>
26551
26552         * config/i386/i386.c (ix86_delegitimize_address): Handle
26553         UNSPEC_PCREL plus displacement.
26554
26555 2012-02-24  Georg-Johann Lay  <avr@gjlay.de>
26556
26557         PR target/52261
26558         * config/avr/avr.c (avr_out_movhi_mr_r_xmega): Use base
26559         to test for unusedness in st X addressing.
26560
26561 2012-02-24  Richard Guenther  <rguenther@suse.de>
26562
26563         PR middle-end/52361
26564         * gimple.c (walk_gimple_op): Use predicates with less redundant tests.
26565         (is_gimple_reg_type): Move inline ...
26566         * gimple.h (is_gimple_reg_type): ... here.
26567
26568 2012-02-24  Richard Guenther  <rguenther@suse.de>
26569
26570         PR middle-end/52361
26571         * passes.c (execute_function_todo): When verifying SSA form
26572         verify gimple form first.
26573         * tree-ssa.c (verify_ssa): Do not verify gimple form here.
26574
26575 2012-02-24  Richard Guenther  <rguenther@suse.de>
26576
26577         PR middle-end/52355
26578         * fold-const.c (fold_addr_of_array_ref_difference): New function.
26579         (fold_binary_loc): Use it to extend the existing &a[i] - &a[j] folding.
26580
26581 2012-02-13  Bernhard Reutner-Fischer  <aldot@gcc.gnu.org>
26582
26583         * tree-if-conv (predicate_scalar_phi): Commentary typo fix.
26584
26585 2012-02-23  Bernhard Reutner-Fischer  <aldot@gcc.gnu.org>
26586
26587         * tree-phinodes.c (make_phi_node): Mark static.
26588         * tree-flow.h (make_phi_node): Remove extern decl.
26589         * doc/gimple.texi (make_phi_node): Remove documentation.
26590
26591 2012-02-23  Bernhard Reutner-Fischer  <aldot@gcc.gnu.org>
26592
26593         * tree-into-ssa (update_ssa): Avoid trailing whitespace in dump_file.
26594         * tree-ssa-sccvn.c (print_scc): Ditto.
26595
26596 2012-02-23  Bernhard Reutner-Fischer  <aldot@gcc.gnu.org>
26597
26598         * doc/passes.texi (Full redundancy elimination): Fix typo.
26599
26600 2012-02-23  Bernhard Reutner-Fischer  <aldot@gcc.gnu.org>
26601
26602         * doc/invoke.texi (-fdse, -fdce): Remove duplicate entries.
26603
26604 2012-02-23  Eric Botcazou  <ebotcazou@adacore.com>
26605
26606         PR bootstrap/52287
26607         * haifa-sched.c (rank_for_schedule): Stabilize sort for debug insns.
26608
26609 2012-02-23  Uros Bizjak  <ubizjak@gmail.com>
26610
26611         PR c/52290
26612         * c-decl.c (start_function): Exit early if decl1 is not FUNTION_DECL.
26613
26614 2012-02-23  Georg-Johann Lay  <avr@gjlay.de>
26615
26616         * config/avr/avr.md (code_stdname): Add ior, xor.
26617         (xior): New code iterator.
26618         (*<code_stdname><mode>qi.byte0): Use xior instead of ior.
26619         (*<code_stdname><mode>qi.byte1-3): Ditto.
26620
26621 2012-02-23  Jakub Jelinek  <jakub@redhat.com>
26622
26623         PR tree-optimization/52019
26624         * ipa-split.c (find_return_bb, find_retval, visit_bb): Ignore
26625         CLOBBER stmts.
26626
26627 2012-02-23  Ulrich Weigand  <Ulrich.Weigand@de.ibm.com>
26628
26629         * acinclude.m4: Use HAVE_INITFINI_ARRAY_SUPPORT instead of
26630         HAVE_INITFINI_ARRAY to work around namespace pollution in
26631         certain versions of newlib system headers.
26632         * config.in: Regenerate.
26633         * configure: Regenerate.
26634         * config/initfini-array.h: Use HAVE_INITFINI_ARRAY_SUPPORT
26635         instead of HAVE_INITFINI_ARRAY.
26636
26637 2012-02-22  Uros Bizjak  <ubizjak@gmail.com>
26638
26639         PR target/52330
26640         * config/i386/i386.c (ix86_print_operand) <case 'H'>: Error out if x
26641         is not offsettable memory reference.
26642
26643 2012-02-22  Georg-Johann Lay  <avr@gjlay.de>
26644
26645         PR target/18145
26646         * config/avr/avr.c (avr_asm_output_aligned_decl_common): Skip
26647         setting avr_need_clear_bss_p for __gnu_lto* symbols.
26648
26649 2012-02-22  Georg-Johann Lay  <avr@gjlay.de>
26650
26651         * config/avr/avr.h (avr_accumulate_outgoing_args): Return int.
26652         * config/avr/avr.c (avr_accumulate_outgoing_args): Return int.
26653
26654 2012-02-22  Rainer Orth  <ro@CeBiTec.Uni-Bielefeld.DE>
26655
26656         * configure.ac (LIB_TLS_SPEC): Enforce use of alternate thread
26657         library on Solaris 8 even without TLS support.
26658         * configure: Regenerate.
26659
26660 2012-02-22  Richard Guenther  <rguenther@suse.de>
26661
26662         PR middle-end/52329
26663         * gimple-fold.c (fold_stmt_1): Also canonicalize ADDR_EXPRs
26664         for GIMPLE_DEBUG stmts.
26665
26666 2012-02-22  Martin Jambor  <mjambor@suse.cz>
26667
26668         PR middle-end/51782
26669         * emit-rtl.c (set_mem_attributes_minus_bitpos): Set address space
26670         according to the base object.
26671
26672 2012-02-22  Georg-Johann Lay  <avr@gjlay.de>
26673
26674         PR rtl-optimization/50063
26675         * config/avr/avr.md (movhi_sp_r): Handle -1 (unknown IRQ state)
26676         and 2 (8-bit SP) in operand 2.
26677         * config/avr/avr.c (avr_prologue_setup_frame): Adjust prologue
26678         setup to use movhi_sp_r instead of vanilla move to write SP.
26679         Adjust REG_CFA notes to superseed unspec.
26680         (expand_epilogue): Adjust epilogue setup to use movhi_sp_r instead
26681         of vanilla move.
26682         As function body might contain CLI or SEI: Use irq_state 0 (IRQ
26683         known to be off) only with TARGET_NO_INTERRUPTS. Never use
26684         irq_state 1 (IRQ known to be on) here.
26685
26686 2012-02-21  Bernd Schmidt  <bernds@codesourcery.com>
26687
26688         * ira.c (check_allocation): Use REG_WORDS_BIG_ENDIAN, not
26689         WORDS_BIG_ENDIAN.
26690         * ira-color.c (setup_profitable_hard_regs, check_hard_reg_p,
26691         assign_hard_reg): Likewise.
26692
26693 2012-02-21  Georg-Johann Lay  <avr@gjlay.de>
26694
26695         * config/avr/avr.md (neghi2): Remove "!d,0" alternative. Tweak "r,0".
26696
26697 2012-02-21  Georg-Johann Lay  <avr@gjlay.de>
26698
26699         * config/avr/avr.md
26700         (*dec-and-branchhi!=-1.d.clobber): New text peephole.
26701         (*dec-and-branchhi!=-1.l.clobber): New text peephole.
26702
26703 2012-02-21  Georg-Johann Lay  <avr@gjlay.de>
26704
26705         * config/avr/avr-protos.h (avr_accumulate_outgoing_args): Move
26706         prototype from here to...
26707         * config/avr/avr.h: ...here.
26708
26709 2012-02-21  Richard Earnshaw  <rearnsha@arm.com>
26710
26711         PR target/52294
26712         * thumb2.md (thumb2_shiftsi3_short): Split register and
26713         immediate shifts.  For register shifts tie operands 0 and 1.
26714         (peephole2 for above): Check that register-controlled shifts
26715         have suitably tied operands.
26716
26717 2012-02-21  Quentin Neill  <quentin.neill@amd.com>
26718
26719         PR target/52137
26720         * config/i386/bdver1.md (bdver1_call, bdver1_push,
26721         bdver1_pop, bdver1_leave, bdver1_lea, bdver1_imul_DI, bdver1_imul,
26722         bdver1_imul_mem_DI, bdver1_imul_mem, bdver1_idiv, bdver1_idiv_mem,
26723         bdver1_str, bdver1_idirect, bdver1_ivector, bdver1_idirect_loadmov,
26724         bdver1_idirect_load, bdver1_ivector_load, bdver1_idirect_movstore,
26725         bdver1_idirect_both, bdver1_ivector_both, bdver1_idirect_store,
26726         bdver1_ivector_store, bdver1_fldxf, bdver1_fld, bdver1_fstxf,
26727         bdver1_fst, bdver1_fist, bdver1_fmov_bdver1, bdver1_fadd_load,
26728         bdver1_fadd, bdver1_fmul_load, bdver1_fmul, bdver1_fsgn,
26729         bdver1_fdiv_load, bdver1_fdiv, bdver1_fpspc_load, bdver1_fpspc,
26730         bdver1_fcmov_load, bdver1_fcmov, bdver1_fcomi_load,
26731         bdver1_fcomi, bdver1_fcom_load, bdver1_fcom,
26732         bdver1_fxch, bdver1_ssevector_avx128_unaligned_load,
26733         bdver1_ssevector_avx256_unaligned_load,
26734         bdver1_ssevector_sse128_unaligned_load,
26735         bdver1_ssevector_avx128_load, bdver1_ssevector_avx256_load,
26736         bdver1_ssevector_sse128_load, bdver1_ssescalar_movq_load,
26737         bdver1_ssescalar_vmovss_load, bdver1_ssescalar_sse128_load,
26738         bdver1_mmxsse_load, bdver1_sse_store_avx256, bdver1_sse_store,
26739         bdver1_mmxsse_store_short, bdver1_ssevector_avx256,
26740         bdver1_movss_movsd, bdver1_mmxssemov, bdver1_sselog_load_256,
26741         bdver1_sselog_256, bdver1_sselog_load, bdver1_sselog,
26742         bdver1_ssecmp_load, bdver1_ssecmp, bdver1_ssecomi_load,
26743         bdver1_ssecomi, bdver1_vcvtX2Y_avx256_load, bdver1_vcvtX2Y_avx256,
26744         bdver1_ssecvt_cvtss2sd_load, bdver1_ssecvt_cvtss2sd,
26745         bdver1_sseicvt_cvtsi2sd_load, bdver1_sseicvt_cvtsi2sd,
26746         bdver1_ssecvt_cvtpd2ps_load, bdver1_ssecvt_cvtpd2ps,
26747         bdver1_ssecvt_cvtdq2ps_load, bdver1_ssecvt_cvtdq2ps,
26748         bdver1_ssecvt_cvtdq2pd_load, bdver1_ssecvt_cvtdq2pd,
26749         bdver1_ssecvt_cvtps2pd_load, bdver1_ssecvt_cvtps2pd,
26750         bdver1_ssecvt_cvtsX2si_load, bdver1_ssecvt_cvtsX2si,
26751         bdver1_ssecvt_cvtpd2pi_load, bdver1_ssecvt_cvtpd2pi,
26752         bdver1_ssecvt_cvtpd2dq_load, bdver1_ssecvt_cvtpd2dq,
26753         bdver1_ssecvt_cvtps2pi_load, bdver1_ssecvt_cvtps2pi,
26754         bdver1_ssemuladd_load_256, bdver1_ssemuladd_256,
26755         bdver1_ssemuladd_load, bdver1_ssemuladd, bdver1_sseimul_load,
26756         bdver1_sseimul, bdver1_sseiadd_load, bdver1_sseiadd,
26757         bdver1_ssediv_double_load_256, bdver1_ssediv_double_256,
26758         bdver1_ssediv_single_load_256, bdver1_ssediv_single_256,
26759         bdver1_ssediv_double_load, bdver1_ssediv_double,
26760         bdver1_ssediv_single_load, bdver1_ssediv_single, bdver1_sseins):
26761         Add "bdver2" attribute.
26762
26763 2012-02-21  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
26764
26765         * config/s390/s390.c (s390_option_override): Make -mhard-dfp the
26766         default if possible and not specified otherwise.
26767
26768 2012-02-21  Richard Guenther  <rguenther@suse.de>
26769
26770         PR middle-end/52314
26771         * gimplify.c (create_tmp_from_val): Use the main variant type
26772         for the type of the temporary we create.
26773
26774 2012-02-21  Richard Guenther  <rguenther@suse.de>
26775
26776         PR tree-optimization/52324
26777         * gimplify.c (gimplify_expr): When re-gimplifying expressions
26778         do not gimplify a MEM_REF address operand if it is already
26779         in suitable form.
26780
26781 2012-02-21  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
26782
26783         * config/s390/s390.md ("fixuns_trunc<mode>si2"): Replace
26784         TARGET_HARD_FLOAT with TARGET_HARD_DFP.
26785
26786 2012-02-21  Richard Guenther  <rguenther@suse.de>
26787
26788         * tree-vect-stmts.c (vectorizable_load): Use pre-computed
26789         nested_in_vect_loop.
26790
26791 2012-02-21  Jakub Jelinek  <jakub@redhat.com>
26792
26793         PR tree-optimization/52318
26794         * gimple-fold.c (gimplify_and_update_call_from_tree): Add
26795         vdef also to non-pure/const call stmts in the sequence.
26796
26797 2012-02-21  Tristan Gingold  <gingold@adacore.com>
26798
26799         * config/vms/vms-ld.c (main): Fix IDENTIFICATION padding.
26800
26801 2012-02-20  David S. Miller  <davem@davemloft.net>
26802
26803         * config/sparc/sparc.md (load_pcrel_sym<P:mode>): Explain why we
26804         don't use the "rd %pc" instruction on v9 for PIC register loads.
26805
26806 2012-02-20  Aldy Hernandez  <aldyh@redhat.com>
26807
26808         PR middle-end/52141
26809         * trans-mem.c (ipa_tm_scan_irr_block): Error out on GIMPLE_ASM's
26810         in a transaction safe function.
26811
26812 2012-02-20  Kai Tietz  <ktietz@redhat.com>
26813
26814         PR target/52238
26815         * stor-layout.c (place_field): Handle desired_align for
26816         ms-bitfields, too.
26817
26818 2012-02-20  Richard Guenther  <rguenther@suse.de>
26819
26820         PR tree-optimization/52298
26821         * tree-vect-stmts.c (vectorizable_store): Properly use
26822         STMT_VINFO_DR_STEP instead of DR_STEP when vectorizing
26823         outer loops.
26824         (vectorizable_load): Likewise.
26825         * tree-vect-data-refs.c (vect_analyze_data_ref_access):
26826         Access DR_STEP after ensuring it is not NULL.
26827
26828 2012-02-20  Jakub Jelinek  <jakub@redhat.com>
26829
26830         PR tree-optimization/52286
26831         * fold-const.c (fold_binary_loc): For (X & C1) | C2
26832         optimization use double_int_to_tree instead of build_int_cst_wide,
26833         rewrite to use double_int vars.
26834
26835 2012-02-20  Rainer Orth  <ro@CeBiTec.Uni-Bielefeld.DE>
26836
26837         PR target/50166
26838         * acinclude.m4 (gcc_AC_INITFINI_ARRAY): Require gcc_SUN_LD_VERSION.
26839         Define _start.
26840         Remove -e 0 from $gcc_cv_ld invocation.
26841         Only use __GLIBC_PREREQ if defined.
26842         Enable on Solaris since Solaris 8 patch.
26843         (gcc_SUN_LD_VERSION): New macro.
26844         * configure.ac (ld_ver) <*-*-solaris2*>: Refer to
26845         gcc_SUN_LD_VERSION for version number format.
26846         * configure: Regenerate.
26847         * varasm.c (get_elf_initfini_array_priority_section): Set
26848         SECTION_NOTYPE for non-default priority.
26849         Use get_section instead of get_unnamed_section to emit
26850         .init_array/.fini_array with default priority.
26851
26852 2012-02-19  Richard Sandiford  <rdsandiford@googlemail.com>
26853
26854         * config/mips/mips.c (mips_need_mips16_rdhwr_p): New variable.
26855         (mips_get_tp): Set it.  Record that __mips16_rdhwr binds locally.
26856         (mips_start_unique_function, mips_output_mips16_rdhwr)
26857         (mips_code_end): New functions.
26858         (TARGET_ASM_CODE_END): Define.
26859
26860 2012-02-19  Richard Sandiford  <rdsandiford@googlemail.com>
26861
26862         * config/mips/mips.c (mips16_build_call_stub): Add CFI information
26863         to stubs with non-sibling calls.
26864
26865 2012-02-18  Sandra Loosemore  <sandra@codesourcery.com>
26866
26867         * doc/invoke.texi (-fira-* options): Copy-edit.
26868         (ira-* parameters): Copy-edit.
26869
26870 2012-02-17  Sandra Loosemore  <sandra@codesourcery.com>
26871
26872         * doc/invoke.texi: Minor copy-edits to bring into conformance with
26873         GCC coding conventions.
26874
26875 2012-02-17  Sandra Loosemore  <sandra@codesourcery.com>
26876
26877         * doc/invoke.texi: Consistently hyphenate "big-endian"/"little-endian"
26878         when used as adjectives.
26879
26880 2012-02-16  Sandra Loosemore  <sandra@codesourcery.com>
26881
26882         * doc/invoke.texi: Clean up "that"/"which" confusion.
26883
26884 2012-02-17  Steven Bosscher  <steven@gcc.gnu.org>
26885
26886         * system.h: Poison SMALL_REGISTER_CLASSES
26887         * config/rl78/rl78.h: Replace SMALL_REGISTER_CLASSES with hook.
26888         * config/rx/rx.h: Remove SMALL_REGISTER_CLASSES.
26889
26890 2012-02-16  Jakub Jelinek  <jakub@redhat.com>
26891
26892         PR tree-optimization/52285
26893         * tree-tailcall.c (find_tail_calls): Ignore gimple_clobber_p stmts
26894         when deciding if a call is a tail call or tail recursion.
26895
26896 2012-02-16  Kai Tietz  <ktietz@redhat.com>
26897
26898         * config/i386/i386.c (legitimate_pic_address_disp_p): Allow
26899         interger-constant displacement for UNSPEC_PCREL.
26900
26901 2012-02-16  Jakub Jelinek  <jakub@redhat.com>
26902
26903         PR rtl-optimization/52208
26904         * ira-costs.c (scan_one_insn): Don't decrease mem_cost
26905         for MEMs with REG_EQUIV, if the MEM isn't general_operand.
26906
26907         PR tree-optimization/52255
26908         * tree-vect-loop-manip.c (slpeel_tree_peel_loop_to_edge): If
26909         loop->header has virtual PHI, but exit_e->dest doesn't, add
26910         virtual PHI to exit_e->dest and adjust all uses after the loop.
26911
26912         PR debug/52260
26913         * dwarf2out.c (copy_decls_walk): Fill in *slot before traversing
26914         children with clone_tree_hash, not after it.
26915
26916 2012-02-16  Iain Sandoe  <iains@gcc.gnu.org>
26917
26918         * config/darwin.h (ASM_OUTPUT_LABELREF): Add user label prefix for
26919         extended identifiers.
26920
26921 2012-02-16  Jakub Jelinek  <jakub@redhat.com>
26922
26923         PR middle-end/51929
26924         * cgraphunit.c (verify_edge_corresponds_to_fndecl): If node is
26925         a same_body_alias, also test whether e->callee isn't a former
26926         or current clone of the decl this is a same body alias of.
26927
26928         PR translation/52264
26929         * cgraphunit.c (verify_cgraph_node): Fix a typo.
26930
26931 2012-02-15  Sandra Loosemore  <sandra@codesourcery.com>
26932
26933         * doc/invoke.texi: Clean up "n-bit/byte/word" modifiers.
26934
26935 2012-02-15  Michael Meissner  <meissner@linux.vnet.ibm.com>
26936
26937         PR target/52199
26938         * config/rs6000/rs6000.c (rs6000_expand_vector_init): Use
26939         force_reg instead of copy_to_reg for better optimization.  Force
26940         non-register or memory operands into a register.
26941
26942 2012-02-15  Andrew MacLeod  <amacleod@redhat.com>
26943
26944         * extend.texi: Reserve upper bits of memory model for future use.
26945
26946 2012-01-15  Georg-Johann Lay  <avr@gjlay.de>
26947             Anatoly Sokolov <aesok@post.ru>
26948             Eric Weddington <eric.weddington@atmel.com>
26949
26950         PR target/52261
26951         * config/avr/avr-devices.c (avr_arch_types): Add avrxmega2,
26952         avrxmega4, avrxmega5, avrxmega6, avrxmega7.
26953         Rewrite initializers for .macro.
26954         * config/avr/avr-mcus.def (AVR_MCU): Add known MCUs:
26955         avrxmega2: atxmega16a4, atxmega16d4, atxmega16x1, atxmega32a4
26956         atxmega32d4, atxmega32x1.
26957         avrxmega4: atxmega64a3, atxmega64d3.
26958         avrxmega5: atxmega64a1, atxmega64a1u.
26959         avrxmega6: atxmega128a3, atxmega128d3, atxmega192a3, atxmega192d3,
26960         atxmega256a3, atxmega256a3b, atxmega256a3bu, atxmega256d3.
26961         avrxmega7: atxmega128a1, atxmega128a1u.
26962         * config/avr/avr.h (enum avr_arch): Add: ARCH_AVRXMEGA2,
26963         ARCH_AVRXMEGA4, ARCH_AVRXMEGA5, ARCH_AVRXMEGA6, ARCH_AVRXMEGA7.
26964         (struct base_arch_s): Rename reserved to xmega_p.
26965         Rename reserved2 to have_rampd.
26966         (AVR_XMEGA): New define.
26967         (AVR_HAVE_RAMPD, AVR_HAVE_RAMPX, AVR_HAVE_RAMPY): New defines.
26968         (AVR_HAVE_RAMPZ): Change definition to fit xmega.
26969         * config/avr/predicates.md (io_address_operand): Take into
26970         account SFR offset.
26971         (low_io_address_operand): Ditto.
26972         (high_io_address_operand): Ditto.
26973         * config/avr/avr.md (isa): Add alternatives no_xmega, xmega.
26974         (enabled, movhi_sp_r): Use them.
26975         * config/avr/avr-c.c (avr_cpu_cpp_builtins): Use
26976         cpp_define_formatted to built-in define __AVR_ARCH__.
26977         (__AVR_XMEGA__): New built-in define.
26978         (__AVR_HAVE_RAMPD__): New built-in define.
26979         (__AVR_HAVE_RAMPX__): New built-in define.
26980         (__AVR_HAVE_RAMPY__): New built-in define.
26981         (__AVR_HAVE_RAMPZ__): Change condition when to built-in define it.
26982
26983         * config/avr/avr.c (avr_addr_t): Add ccp, rampd, rampx, rampy.
26984         (avr_option_override): Initialize them.
26985         (sreg_rtx, rampd_rtx, rampx_rtx, rampy_rtx): New GTY rtx.
26986         (avr_init_expanders): Initialize them. No more block several calls.
26987         (emit_push_sfr): New static function.
26988         (avr_prologue_setup_frame): Use it to push SREG, RAMPD/X/Y/Z as needed.
26989         Handle AVR_XMEGA.
26990         (expand_epilogue): Handle AVR_XMEGA. Pop RAMPD/X/Y/Z as needed.
26991         (avr_print_operand): Print addreeses as symbols for
26992         RAMPX, RAMPY, RAMPD, CCP.
26993         (output_movhi): Handle AVR_XMEGA when writing to SP.
26994         (avr_out_movhi_mr_r_xmega): New static function.
26995         (out_movhi_mr_r): Forward to avr_out_movhi_mr_r_xmega for AVR_XMEGA.
26996         (avr_file_start): Print symbol defines for __RAMPX__,  __RAMPY__,
26997         __RAMPD__,  __CCP__ as needed.
26998
26999         * config/avr/multilib.h: Regenerate.
27000         * config/avr/t-multilib: Regenerate.
27001         * config/avr/avr-tables.opt: Regenerate.
27002
27003 2012-02-15  Tobias Grosser <grosser@fim.uni-passau.de>
27004
27005         PR tree-optimization/50561
27006         * graphite-flattening.c (lst_project_loop): Do not
27007         remove old scattering dimensions after flattening.
27008         (lst_do_flatten): Likewise.
27009
27010 2012-02-15  Georg-Johann Lay  <avr@gjlay.de>
27011
27012         * doc/extend.texi (AVR Built-in Functions): Remove doc for
27013         __builtin_avr_map8, __builtin_avr_map16.
27014         Document __builtin_avr_insert_bits.
27015
27016         * config/avr/avr.md (map_bitsqi, map_bitshi): Remove.
27017         (insert_bits): New insn.
27018         (adjust_len.map_bits): Rename to insert_bits.
27019         (UNSPEC_MAP_BITS): Rename to UNSPEC_INSERT_BITS.
27020         * avr-protos.h (avr_out_map_bits): Remove.
27021         (avr_out_insert_bits, avr_has_nibble_0xf): New.
27022         * config/avr/constraints.md (Cxf,C0f): New.
27023         * config/avr/avr.c (avr_cpu_cpp_builtins): Remove built-in
27024         defines __BUILTIN_AVR_MAP8, __BUILTIN_AVR_MAP16.
27025         New built-in define __BUILTIN_AVR_INSERT_BITS.
27026         * config/avr/avr.c (TARGET_FOLD_BUILTIN): New define.
27027         (enum avr_builtin_id): Add AVR_BUILTIN_INSERT_BITS.
27028         (avr_move_bits): Rewrite.
27029         (avr_fold_builtin, avr_map_metric, avr_map_decompose): New static
27030         functions.
27031         (avr_map_op_t): New typedef.
27032         (avr_map_op): New static variable.
27033         (avr_out_insert_bits, avr_has_nibble_0xf): New functions.
27034         (adjust_insn_length): Handle ADJUST_LEN_INSERT_BITS.
27035         (avr_init_builtins): Add definition for __builtin_avr_insert_bits.
27036         (bdesc_3arg, avr_expand_triop_builtin): New.
27037         (avr_expand_builtin): Use them. And handle AVR_BUILTIN_INSERT_BITS.
27038         (avr_revert_map, avr_swap_map, avr_id_map, avr_sig_map): Remove.
27039         (avr_map_hamming_byte, avr_map_hamming_nonstrict): Remove.
27040         (avr_map_equal_p, avr_map_sig_p): Remove.
27041         (avr_out_swap_bits, avr_out_revert_bits, avr_out_map_bits): Remove.
27042         (bdesc_2arg): Remove AVR_BUILTIN_MAP8, AVR_BUILTIN_MAP16.
27043         (adjust_insn_length): Remove handling for ADJUST_LEN_MAP_BITS.
27044         (enum avr_builtin_id): Remove AVR_BUILTIN_MAP8, AVR_BUILTIN_MAP16.
27045         (avr_init_builtins): Remove __builtin_avr_map8, __builtin_avr_map16.
27046         (avr_expand_builtin): Remove AVR_BUILTIN_MAP8, AVR_BUILTIN_MAP16.
27047
27048 2012-02-14  Bernd Schmidt  <bernds@codesourcery.com>
27049
27050         * config/c6x/c6x.md (reserve_cycles): New attribute.
27051         * config/c6x/c6x.c (c6x_sched_reorder_1): Ensure insns we predicate
27052         don't reserve functional units after the branch occurs.
27053
27054 2012-02-14  Aldy Hernandez  <aldyh@redhat.com>
27055
27056         PR middle-end/52142
27057         * ipa-inline.c (can_inline_edge_p): Do not inline tm_pure
27058         functions into non-tm_pure functions.
27059
27060 2012-02-14  Eric Botcazou  <ebotcazou@adacore.com>
27061
27062         PR lto/52178
27063         * gimple.c (iterative_hash_gimple_type): Use RECORD_OR_UNION_TYPE_P.
27064         (iterative_hash_canonical_type): Likewise.
27065         * tree-ssa-pre.c (fini_pre): Clean up the CFG only after purging all
27066         the dead edges.
27067
27068 2012-02-14  Bernd Schmidt  <bernds@codesourcery.com>
27069
27070         * haifa-sched.c (prune_ready_list): Ensure that if there is a
27071         sched-group insn, it either remains alone or the entire list is pruned.
27072
27073 2012-02-14  Jonathan Wakely  <jwakely.gcc@gmail.com>
27074
27075         * doc/install.texi (Prerequisites): Fix grammar.
27076         (Configuration): Likewise.
27077
27078 2012-02-14  Jonathan Wakely  <jwakely.gcc@gmail.com>
27079
27080         * doc/install.texi (Prerequisites): Suggest building GMP, MPFR and
27081         MPC as part of GCC before describing configuring with --with-gmp etc.
27082         (Installing GCC: Configuration): --with-gmp etc. aren't needed if
27083         sources are present.
27084
27085 2012-02-14  Jakub Jelinek  <jakub@redhat.com>
27086
27087         PR debug/51950
27088         * dwarf2out.c (clone_tree_hash): New function.
27089         (copy_decls_walk): Use it instead of clone_tree.
27090
27091 2012-02-14  Richard Guenther  <rguenther@suse.de>
27092
27093         PR tree-optimization/52244
27094         PR tree-optimization/51528
27095         * tree-sra.c (analyze_access_subtree): Only create INTEGER_TYPE
27096         replacements for integral types.
27097
27098 2012-02-14  Walter Lee  <walt@tilera.com>
27099
27100         * config.gcc: Handle tilegx and tilepro.
27101         * configure.ac (gcc_cv_as_dwarf2_debug_line): Enable test for
27102         tilegx and tilepro.
27103         Add HAVE_AS_TLS check for tilegx and tilepro.
27104         * configure: Regenerate.
27105         * doc/contrib.texi: Add Mat Hostetter and self.
27106         * doc/extend.texi (TILE-Gx Built-in Functions): New node.
27107         Document instruction intrinsics and network accessing intrinsics.
27108         (TILEPro Built-in Functions): New node.  Document instruction
27109         intrinsics and network accessing intrinsics.
27110         * doc/install.texi (Specific, tilegx-*-linux*): Document it.
27111         (Specific, tilepro-*-linux*): Likewise.
27112         * doc/invoke.texi (TILE-Gx Options): New section.
27113         (TILEPro Options): New section.
27114         * doc/md.texi (TILE-Gx): New section.
27115         (TILEPro): New section.
27116         * common/config/tilegx/tilegx-common.c: New file.
27117         * common/config/tilepro/tilepro-common.c: New file.
27118         * config/tilegx/constraints.md: New file.
27119         * config/tilegx/linux.h: New file.
27120         * config/tilegx/mul-tables.c: New file.
27121         * config/tilegx/predicates.md: New file.
27122         * config/tilegx/sync.md: New file.
27123         * config/tilegx/t-tilegx: New file.
27124         * config/tilegx/tilegx-builtins.h: New file.
27125         * config/tilegx/tilegx-c.c: New file.
27126         * config/tilegx/tilegx-generic.md: New file.
27127         * config/tilegx/tilegx-modes.def: New file.
27128         * config/tilegx/tilegx-multiply.h: New file.
27129         * config/tilegx/tilegx-protos.h: New file.
27130         * config/tilegx/tilegx.c: New file.
27131         * config/tilegx/tilegx.h: New file.
27132         * config/tilegx/tilegx.md: New file.
27133         * config/tilegx/tilegx.opt: New file.
27134         * config/tilepro/constraints.md: New file.
27135         * config/tilepro/gen-mul-tables.cc: New file.
27136         * config/tilepro/linux.h: New file.
27137         * config/tilepro/mul-tables.c: New file.
27138         * config/tilepro/predicates.md: New file.
27139         * config/tilepro/t-tilepro: New file.
27140         * config/tilepro/tilepro-builtins.h: New file.
27141         * config/tilepro/tilepro-c.c: New file.
27142         * config/tilepro/tilepro-generic.md: New file.
27143         * config/tilepro/tilepro-modes.def: New file.
27144         * config/tilepro/tilepro-multiply.h: New file.
27145         * config/tilepro/tilepro-protos.h: New file.
27146         * config/tilepro/tilepro.c: New file.
27147         * config/tilepro/tilepro.h: New file.
27148         * config/tilepro/tilepro.md: New file.
27149         * config/tilepro/tilepro.opt: New file.
27150
27151 2012-02-14  Jakub Jelinek  <jakub@redhat.com>
27152
27153         PR tree-optimization/52210
27154         * tree-vect-slp.c (vect_get_and_check_slp_defs): Call
27155         vect_model_simple_cost with two entry vect_def_type array instead
27156         of an address of dt.
27157
27158 2012-02-14  Richard Guenther  <rguenther@suse.de>
27159
27160         PR lto/52178
27161         * tree-streamer-in.c (lto_input_ts_field_decl_tree_pointers):
27162         Do not stream DECL_QUALIFIER.
27163         * tree-streamer-out.c (write_ts_field_decl_tree_pointers): Likewise.
27164         * tree.c (free_lang_data_in_decl): Free DECL_QUALIFIER.
27165         (find_decls_types_r): Do not walk DECL_QUALIFIER.
27166
27167 2012-02-14  Jakub Jelinek  <jakub@redhat.com>
27168
27169         PR c/52181
27170         * c-decl.c (merge_decls): Copy DECL_USER_ALIGN bit from olddecl to
27171         newdecl.
27172
27173 2012-02-13  Jakub Jelinek  <jakub@redhat.com>
27174
27175         PR bootstrap/52172
27176         * cselib.h (cselib_subst_to_values_from_insn): New prototype.
27177         * cselib.c (cselib_subst_to_values_from_insn): New function.
27178         * sched-deps.c (add_insn_mem_dependence,
27179         sched_analyze_1, sched_analyze_2): Use it.
27180
27181 2012-02-13  Jan Hubicka  <jh@suse.cz>
27182
27183         PR middle-end/52214
27184         * predict.c (predict_paths_for_bb): Fix thinko in prevoius patch.
27185
27186 2012-02-13  Eric Botcazou  <ebotcazou@adacore.com>
27187
27188         * gcc.c (LINK_COMMAND_SPEC): Deal with -fgnu-tm.
27189         (GTM_SELF_SPECS): Define if not already defined.
27190         (driver_self_specs): Add GTM_SELF_SPECS.
27191         * config/darwin.h (LINK_COMMAND_SPEC_A): Deal with -fgnu-tm.
27192         (GTM_SELF_SPECS): Define.
27193         * config/i386/cygwin.h (GTM_SELF_SPECS): Likewise.
27194         * config/i386/mingw32.h (GTM_SELF_SPECS): Likewise.
27195
27196 2012-02-13  Jakub Jelinek  <jakub@redhat.com>
27197
27198         * cselib.c (expand_loc): Return sp, fp, hfp or cfa base reg right
27199         away if seen.
27200
27201         * cselib.c (dump_cselib_val): Don't assume l->setting_insn is non-NULL.
27202
27203         PR middle-end/52230
27204         * omp-low.c (expand_omp_for): If a static schedule without chunk size
27205         has NULL region->cont, force fd.chunk_size to be integer_zero_node.
27206
27207 2012-02-13  Andrew MacLeod  <amacleod@redhat.com>
27208
27209         PR c/52190
27210         * doc/extend.texi : Fix another __atomic_compare_exchange typo.
27211
27212 2012-02-13  Richard Guenther  <rguenther@suse.de>
27213
27214         PR translation/52211
27215         * passes.c (enable_disable_pass): Fix typo.
27216
27217 2012-02-13  Jakub Jelinek  <jakub@redhat.com>
27218
27219         PR middle-end/52209
27220         * expr.c (expand_expr_real_2) <case BIT_NOT_EXPR>: Only expand using
27221         XOR for reduce_bit_field if type is unsigned.
27222
27223 2012-02-12  Eric Botcazou  <ebotcazou@adacore.com>
27224
27225         * config/sparc/sparc.h (CANNOT_CHANGE_MODE_CLASS): In 64-bit mode,
27226         disallow changes from SFmode to mode with different size in FP regs.
27227
27228 2012-02-12  Robert Millan  <rmh@gnu.org>
27229             Gerald Pfeifer <gerald@pfeifer.com>
27230
27231         * ginclude/stddef.h [__FreeBSD_kernel__] (__size_t): Do not define.
27232         Tweak comment.
27233
27234 2012-02-11  Richard Sandiford  <rdsandiford@googlemail.com>
27235
27236         PR rtl-optimization/52175
27237         * reorg.c (fill_slots_from_thread): Don't apply add/sub optimization
27238         to frame-related instructions.
27239
27240 2012-02-10  Jason Merrill  <jason@redhat.com>
27241
27242         PR c++/51910
27243         * tlink.c (demangled_hash_entry): Change mangled to a VEC.
27244         (demangle_new_symbols): Fill it.
27245         (scan_linker_output): Walk it.
27246         (start_tweaking): Split out from scan_linker_output.
27247         (maybe_tweak): Update sym->chosen.
27248         * Makefile.in (COLLECT2_OBJS): Add vec.o and gcc-none.o
27249
27250 2012-02-11  Jakub Jelinek  <jakub@redhat.com>
27251
27252         PR debug/52132
27253         * reg-stack.c (subst_stack_regs_in_debug_insn): Don't use get_true_reg.
27254
27255 2012-02-11  Uros Bizjak  <ubizjak@gmail.com>
27256
27257         * compare-elim.c (find_comparisons_in_bb): Eliminate only compares
27258         having the same mode as previous compare.
27259
27260 2012-02-10  Eric Botcazou  <ebotcazou@adacore.com>
27261
27262         * config/sparc/sparc.c (sparc_flat_expand_prologue): Use emit_use.
27263         * config/sparc/sparc.md (UNSPECV_GOTO): Delete.
27264         (nonlocal_goto_internal): Likewise.
27265         (nonlocal_goto): Emit a use and an indirect jump directly.
27266
27267 2012-02-10  Andrew MacLeod  <amacleod@redhat.com>
27268
27269         PR c/52190
27270         * doc/extend.texi : Update comments for __atomic_compare_exchange and
27271         __atomic_{is,always}_lock_free.
27272
27273 2012-02-10  Uros Bizjak  <ubizjak@gmail.com>
27274
27275         PR target/52146
27276         * config/i386/i386.c (ix86_legitimate_address_p): Disallow
27277         negative constant address for TARGET_X32.
27278
27279 2012-02-10  Richard Henderson  <rth@redhat.com>
27280
27281         * tree-ssa-dce.c (propagate_necessity): Handle GIMPLE_TRANSACTION.
27282         * tree-ssa-operands.c (parse_ssa_operands): Add virtual operands
27283         for GIMPLE_TRANSACTION.  Tidy if's into a switch.
27284
27285 2012-02-10  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
27286             Ira Rosen  <irar@il.ibm.com>
27287
27288         PR tree-optimization/50031
27289         * targhooks.c (default_builtin_vectorization_cost): Handle
27290         vec_promote_demote.
27291         * target.h (enum vect_cost_for_stmt): Add vec_promote_demote.
27292         * tree-vect-loop.c (vect_get_single_scalar_iteraion_cost): Handle
27293         all types of reduction and pattern statements.
27294         (vect_estimate_min_profitable_iters): Likewise.
27295         * tree-vect-stmts.c (vect_model_promotion_demotion_cost): New function.
27296         (vect_get_load_cost): Use vec_perm for permutations; add dump logic
27297         for explicit realigns.
27298         (vectorizable_conversion): Call vect_model_promotion_demotion_cost.
27299         * config/spu/spu.c (spu_builtin_vectorization_cost): Handle
27300         vec_promote_demote.
27301         * config/i386/i386.c (ix86_builtin_vectorization_cost): Likewise.
27302         * config/rs6000/rs6000.c (rs6000_builtin_vectorization_cost): Update
27303         vec_perm for VSX and handle vec_promote_demote.
27304
27305 2012-02-10  Jakub Jelinek  <jakub@redhat.com>
27306
27307         PR middle-end/52177
27308         * builtins.c (fold_builtin_atomic_always_lock_free,
27309         expand_builtin_atomic_always_lock_free,
27310         fold_builtin_atomic_is_lock_free, expand_builtin_atomic_is_lock_free):
27311         Return and/or test boolean_true_node/boolean_false_node instead of
27312         integer_one_node/integer_zero_node.
27313
27314 2012-02-10  Jan Hubicka  <jh@suse.cz>
27315
27316         PR middle-end/48600
27317         * predict.c (predict_paths_for_bb): Prevent looping.
27318         (predict_paths_leading_to_edge, predict_paths_leading_to): Update.
27319
27320 2012-02-10  Roman Zhuykov  <zhroma@ispras.ru>
27321
27322         * config/arm/arm.c (output_move_double): In one case properly
27323         count number of instructions that will be emitted.
27324
27325 2012-02-10  Richard Guenther  <rguenther@suse.de>
27326
27327         PR translation/52193
27328         * cgraphunit.c (cgraph_mark_functions_to_output): Fix typo.
27329
27330 2012-02-09  Peter Bergner  <bergner@vnet.ibm.com>
27331
27332         PR middle-end/52140
27333         * dojump.c (do_compare_rtx_and_jump): Use SCALAR_FLOAT_MODE_P.
27334
27335 2012-02-09  Jakub Jelinek  <jakub@redhat.com>
27336
27337         PR debug/52165
27338         * var-tracking.c (emit_note_insn_var_location): If
27339         EMIT_NOTE_BEFORE_INSN and insn is NOTE_INSN_CALL_ARG_LOCATION,
27340         emit it before next non-NOTE_INSN_CALL_ARG_LOCATION
27341         non-NOTE_DURING_CALL_P insn.
27342
27343 2012-02-09  Bin Cheng  <bin.cheng@arm.com>
27344
27345         PR middle-end/51867
27346         * builtins.c (expand_builtin): Don't check DECL_ASSEMBLER_NAME_SET_P.
27347
27348 2012-02-08  Magnus Granberg  <zorry@gentoo.org>
27349
27350         PR driver/48524
27351         * gcc.c (switch_matches) Support switches with separated form,
27352         -D and -U.
27353
27354 2012-02-08  Georg-Johann Lay  <avr@gjlay.de>
27355
27356         * config/avr/avr.md (SREG_ADDR): Remove constant definition.
27357         (SP_ADDR): Ditto.
27358         (RAMPZ_ADDR): Ditto.
27359         * config/avr/avr.c (avr_addr_t): New typedef.
27360         (avr_addr): New struct to hold RAM address of SPL, SPH, RAMPZ, SREG.
27361         (avr_init_expanders): Initialize it.
27362         (expand_prologue): Use avr_addr instead of RAMPZ_ADDR, SP_ADDR,
27363         SREG_ADDR.
27364         (expand_epilogue): Ditto.
27365         (avr_print_operand): Ditto.
27366         (avr_file_start): Ditto.
27367         (avr_emit_movmemhi): Ditto.
27368
27369 2012-02-08  Richard Guenther  <rguenther@suse.de>
27370
27371         PR tree-optimization/46886
27372         * tree-flow.h (do_while_loop_p): Declare.
27373         * tree-ssa-loop-ch.c (do_while_loop_p): Export.
27374         * tree-parloops.c (parallelize_loops): Only parallelize do-while loops.
27375
27376 2012-02-08  Andrew MacLeod  <amacleod@redhat.com>
27377
27378         * optabs.c (expand_atomic_load): Do not assume compare_and_swap will
27379         always succeed for integers larger than a native word.
27380
27381 2012-02-08  Richard Guenther  <rguenther@suse.de>
27382
27383         PR rtl-optimization/52170
27384         * simplify-rtx.c (simplify_plus_minus): Use CONSTM1_RTX to
27385         properly handle integer vector modes.
27386
27387 2012-02-08  Jakub Jelinek  <jakub@redhat.com>
27388
27389         PR gcov-profile/52150
27390         * coverage.c: Include target.h.
27391         (build_var): Call targetm.strip_name_encoding on the assembler name.
27392         Change one _ into . or $ if the target allows it.
27393         * Makefile.in (coverage.o): Depend on $(TARGET_H).
27394
27395         PR rtl-optimization/52139
27396         * cfgrtl.c (cfg_layout_merge_blocks): If BB_END
27397         is a BARRIER after emit_insn_after_noloc, move BB_END
27398         to the last non-BARRIER insn before it.
27399
27400 2012-02-07  Richard Sandiford  <rdsandiford@googlemail.com>
27401
27402         PR middle-end/24306
27403         * config/mips/mips.c (mips_std_gimplify_va_arg_expr): New function.
27404         (mips_gimplify_va_arg_expr): Call it instead of
27405         std_gimplify_va_arg_expr.
27406
27407 2012-02-07  Michael Meissner  <meissner@linux.vnet.ibm.com>
27408
27409         * config/rs6000/rs6000.c (rs6000_trampoline_init): Fix error
27410         message for -mno-pointers-to-nested-function.
27411
27412 2012-02-07  Eric Botcazou  <ebotcazou@adacore.com>
27413
27414         PR middle-end/51994
27415         * expr.c (get_inner_reference): If there is an offset, add a negative
27416         bit position to it (if any).
27417
27418 2012-02-07  Jakub Jelinek  <jakub@redhat.com>
27419
27420         PR rtl-optimization/52060
27421         * combine.c (try_combine): Add i0src_copy and i0src_copy2 variables,
27422         copy i1src to i1src_copy whenever added_sets_2 && i1_feeds_i2_n already
27423         before i1dest -> i1src substitution in newpat, copy i0src to i0src_copy
27424         and/or i0src_copy2 when needed.
27425
27426 2012-02-07  Jakub Jelinek  <jakub@redhat.com>
27427
27428         * gcc.c (main): Don't look for lto-wrapper or lto-wrapper
27429         or LTOPLUGINSONAME if have_c.
27430
27431         * config/freebsd-spec.h: Add comment about what macros can be defined
27432         in this header.
27433         (LINK_EH_SPEC, LINK_SSP_SPEC, USE_LD_AS_NEEDED): Don't define here.
27434         * config/freebsd.h (LINK_EH_SPEC, LINK_SSP_SPEC, USE_LD_AS_NEEDED): But
27435         here instead.
27436
27437 2012-02-07  Richard Guenther  <rguenther@suse.de>
27438
27439         * gimple-pretty-print.c (dump_gimple_phi): Avoid excessive
27440         newline in -alias dumps.
27441
27442 2012-02-07  Kai Tietz  <ktietz@redhat.com>
27443             Dave Korn  <dave.korn.cygwin@gmail.com>
27444
27445         PR target/40068
27446         * config/i386/winnt-cxx.c (i386_pe_adjust_class_at_definition):
27447         Take care that typinfo gets dllexport-attribute.
27448
27449 2012-02-07  Jakub Jelinek  <jakub@redhat.com>
27450
27451         PR middle-end/52074
27452         * expr.c (expand_expr_addr_expr_1): For CONSTANT_CLASS_P or CONST_DECL
27453         if modifier < EXPAND_SUM call force_operand on the result.
27454
27455 2012-02-07  Joern Rennecke  <joern.rennecke@embecosm.com>
27456
27457         * config/epiphany/epiphany.h (ASM_DECLARE_FUNCTION_SIZE): Redefine,
27458         adding __forwarder_dst__ prefix if a forwarder_section attribute is
27459         present.
27460         (epiphany_function_type): Replace types for specific interrupts with
27461         EPIPHANY_FUNCTION_INTERRUPT.
27462         (EPIPHANY_INTERRUPT_P): Update.
27463         * config/epiphany/epiphany.c (epiphany_handle_forwarder_attribute):
27464         New static function.
27465         (epiphany_attribute_table) <interrupt>: min_len is 0, max_len is 9.
27466         <disinterrupt>: Affects type identity.
27467         (epiphany_handle_interrupt_attribute): Handle variable number of
27468         arguments.
27469         (epiphany_compute_function_type): Update for new
27470         epiphany_function_type definition.
27471         (epiphany_expand_prologue): Don't save (reg:DI GPR_0) for interrupt
27472         handlers with a longcall forwarder.
27473         (epiphany_start_function): Handle multiple interrupt arguments and/or
27474         forwarder_section attribute.
27475
27476         * config/epiphany/epiphany.h (LIB_SPEC): Link libc again after
27477         libgloss.
27478
27479 2012-02-07  Alan Modra  <amodra@gmail.com>
27480
27481         PR target/52107
27482         * config/rs6000/rs6000.c (rs6000_emit_move): Don't create DImode
27483         subregs of TFmode.
27484
27485 2012-02-06  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
27486
27487         PR tree-optimization/50969
27488         * tree-vect-stmts.c (vect_model_store_cost): Correct statement cost to
27489         use vec_perm rather than vector_stmt.
27490         (vect_model_load_cost): Likewise.
27491         * config/i386/i386.c (ix86_builtin_vectorization_cost): Change cost of
27492         vec_perm to be the same as other vector statements.
27493         * config/rs6000/rs6000.c (rs6000_builtin_vectorization_cost): Revise
27494         cost of vec_perm for TARGET_VSX.
27495
27496 2012-02-06  Richard Guenther  <rguenther@suse.de>
27497
27498         PR tree-optimization/52115
27499         * tree-sra.c (access_has_replacements_p): New function.
27500         (sra_modify_assign): Use it to decide whether a use is uninitialized.
27501
27502 2012-02-06  Patrick Marlier  <patrick.marlier@gmail.com>
27503
27504         PR middle-end/52047
27505         * trans-mem.c (expand_call_tm): Add an assertion.
27506         * calls.c (flags_from_decl_or_type): Add ECF_TM_PURE to 'no vops'
27507         functions.
27508
27509 2012-02-06  Richard Guenther  <rguenther@suse.de>
27510
27511         PR tree-optimization/50955
27512         * tree-ssa-loop-ivopts.c (get_computation_cost_at): Artificially
27513         raise cost of expressions that replace an address with an
27514         expression based on a different pointer.
27515
27516 2012-02-06  Jakub Jelinek  <jakub@redhat.com>
27517
27518         PR target/52129
27519         * calls.c (mem_overlaps_already_clobbered_arg_p): If val is
27520         CONST_INT_P, subtract resp. add crtl->args.pretend_args_size to it.
27521
27522 2012-02-06  Jonathan Wakely  <jwakely.gcc@gmail.com>
27523
27524         PR c++/48680
27525         * doc/invoke.texi (C++ Dialect Options): Use @option markup for
27526         -Weffc++ and specify guidelines come from second edition.
27527
27528 2012-02-05  Richard Sandiford  <rdsandiford@googlemail.com>
27529
27530         * config/mips/mips.md (sibcall_internal, sibcall_value_internal)
27531         (sibcall_value_multiple_internal, call_split, call_internal_direct)
27532         (call_direct_split, call_value_split, call_value_internal_direct)
27533         (call_value_direct_split, call_value_multiple_split): Use jal and
27534         jal_macro attributes.
27535
27536 2012-02-05  Richard Sandiford  <rdsandiford@googlemail.com>
27537
27538         * reload1.c (reload_regs_reach_end_p): Replace with...
27539         (reload_reg_rtx_reaches_end_p): ...this function.
27540         (new_spill_reg_store): Update commentary.
27541         (emit_input_reload_insns): Don't clear new_spill_reg_store here.
27542         (emit_output_reload_insns): Check reload_reg_rtx_reaches_end_p
27543         before setting new_spill_reg_store.
27544         (emit_reload_insns): Use a separate loop to clear new_spill_reg_store.
27545         Use reload_reg_rtx_reaches_end_p instead of reload_regs_reach_end_p.
27546         Also use reload_reg_rtx_reaches_end_p when reading new_spill_reg_store
27547         for non-spill reload registers.
27548
27549 2012-02-05  Ira Rosen  <irar@il.ibm.com>
27550
27551         PR tree-optimization/52091
27552         * tree-vectorizer.h (vect_is_simple_use): Add an argument.
27553         (vect_is_simple_use_1): Likewise.
27554         * tree-vect-loop.c (vectorizable_reduction): Update calls
27555         to vect_is_simple_use_1 and vect_is_simple_use.
27556         (vectorizable_live_operation): Likewise.
27557         * tree-vect-patterns.c (widened_name_p,
27558         vect_recog_vector_vector_shift_pattern, check_bool_pattern): Likewise.
27559         * tree-vect-stmts.c (process_use, vect_get_vec_def_for_operand,
27560         vectorizable_call, vectorizable_conversion, vectorizable_assignment,
27561         vectorizable_shift,vectorizable_operation, vectorizable_store,
27562         vectorizable_load): Likewise.
27563         (vect_is_simple_cond): Add an argument, pass it to
27564         vect_is_simple_use_1.
27565         (vectorizable_condition): Update calls to vect_is_simple_cond,
27566         vect_is_simple_use.
27567         (vect_is_simple_use): Add an argument, the statement in which
27568         OPERAND is used.  Check that if OPERAND's def stmt is a double
27569         reduction phi node, the use is a phi node too.
27570         (vect_is_simple_use_1): Add an argument, pass it to
27571         vect_is_simple_use.
27572         * tree-vect-slp.c (vect_get_and_check_slp_defs): Update a call
27573         to vect_is_simple_use.
27574
27575 2012-02-04  Jakub Jelinek  <jakub@redhat.com>
27576
27577         PR rtl-optimization/52095
27578         * modulo-sched.c (dump_insn_locator): New function.
27579         (loop_canon_p, sms_schedule): Use it.
27580
27581         PR rtl-optimization/52113
27582         * lower-subreg.c (decompose_multiword_subregs): Call recog_memoized
27583         even for decomposable shift/zext insns.
27584
27585 2012-02-03  Jakub Jelinek  <jakub@redhat.com>
27586             Zdenek Dvorak  <ook@ucw.cz>
27587
27588         PR rtl-optimization/52092
27589         * loop-unswitch.c (unswitch_single_loop): Call copy_rtx_if_shared
27590         on get_iv_value result.
27591
27592 2012-02-02  Andrew Pinski  <apinski@cavium.com>
27593
27594         PR middle-end/47982
27595         PR middle-end/43967
27596         * doc/libgcc.texi (__udivmoddi4/__udivmodti4): Fix documentation typo.
27597
27598 2012-02-02  Jakub Jelinek  <jakub@redhat.com>
27599
27600         PR middle-end/48071
27601         * diagnostic.c (diagnostic_finish): Remove trailing newlines.
27602
27603 2012-02-02  Vladimir Makarov  <vmakarov@redhat.com>
27604
27605         PR rtl-optimization/49800
27606         * haifa-sched.c (sched_init): Call regstat_init_n_sets_and_refs.
27607         (sched_finish): Call regstat_free_n_sets_and_refs.
27608
27609 2012-02-02  Jia Liu  <proljc@gmail.com>
27610
27611         * config/mips/mips-dspr2.md (mips_prepend): Mask operand 3 rather
27612         than operand 2.
27613
27614 2012-02-02  Jan Hubicka  <jh@suse.cz>
27615             Tom de Vries  <tom@codesourcery.com>
27616
27617         PR middle-end/51998
27618         * cgraphunit.c (cgraph_analyze_function): Break cyclic aliases.
27619         * varpool.c (varpool_analyze_pending_decls): Likewise.
27620
27621 2012-02-02  Sumanth G <sumanth.gundapaneni@kpitcummins.com>
27622             Jayant R Sonar <jayant.sonar@kpitcummins.com>
27623
27624         * config.gcc: Add cr16-* support.
27625
27626         * doc/extend.texi: Document cr16 extensions.
27627         * doc/install.texi: Document cr16 install.
27628         * doc/invoke.texi: Document cr16 options.
27629         * doc/md.texi: Document cr16 constraints.
27630
27631         * common/config/cr16/cr16-common.c: New file.
27632         * config/cr16/cr16.c: New file.
27633         * config/cr16/cr16.h: New file.
27634         * config/cr16/cr16.md: New file.
27635         * config/cr16/cr16.opt: New file.
27636         * config/cr16/cr16-protos.h: New file.
27637         * config/cr16/predicates.md: New file.
27638         * config/cr16/constraints.md: New file.
27639         * config/cr16/t-cr16: New file.
27640
27641 2012-02-02  Jakub Jelinek  <jakub@redhat.com>
27642
27643         PR target/52086
27644         * config/i386/i386.md (*addqi_2 peephole with SImode addition): Check
27645         that operands[2] is either immediate, or q_regs_operand.
27646
27647         PR tree-optimization/52073
27648         * tree-vect-stmts.c (vect_mark_relevant): When checking uses of
27649         a pattern stmt for pattern uses, ignore uses outside of the loop.
27650
27651 2012-02-01  Georg-Johann Lay  <avr@gjlay.de>
27652
27653         * config/avr/avr.c: Resolve all AS1 and AS2 macros.
27654         * config/avr/avr.h (AS1, AS2, AS2C, AS3): Remove.
27655         (OUT_AS1, OUT_AS2): Remove.
27656
27657 2012-02-01  Georg-Johann Lay  <avr@gjlay.de>
27658
27659         PR rtl-optimization/51374
27660         * combine.c (can_combine_p): Don't allow volatile_refs_p insns
27661         to cross other volatile_refs_p insns.
27662
27663 2012-02-01  Richard Guenther  <rguenther@suse.de>
27664
27665         * doc/invoke.texi (fno-inline): Clarify documentation.
27666         (finline-small-functions): Likewise.
27667         (finline-functions): Likewise.
27668         * common.opt (finline): Adjust comment and documentation.
27669         (finline-small-functions): Clarify documentation.
27670         (finline-functions): Likewise.
27671         (finline-functions-called-once): Likewise.
27672
27673 2012-02-01  Tristan Gingold  <gingold@adacore.com>
27674
27675         * c-typeck.c (composite_type): Keep mode for pointers.
27676
27677 2012-01-31  Richard Sandiford  <rdsandiford@googlemail.com>
27678
27679         * function.h (regno_reg_rtx): Adjust comment.
27680         * reginfo.c (init_reg_modes_target): Only use the previous mode
27681         if it fits within one register.  Remove MIPS comment.
27682
27683 2012-01-31  Jakub Jelinek  <jakub@redhat.com>
27684
27685         PR bootstrap/52058
27686         * combine.c (do_SUBST_LINK, SUBST_LINK): Guard with #ifndef HAVE_cc0.
27687
27688 2012-01-31  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
27689
27690         * config/s390/s390.md ("*ashr<mode>3_and"): Add missing z196 flag
27691         to srak instruction.
27692
27693 2012-01-31  Matthew Gretton-Dann  <matthew.gretton-dann@arm.com>
27694
27695         * config/arm/thumb2.md (thumb2_mov_notscc): Use MVN for true condition.
27696
27697 2012-01-31  Jakub Jelinek  <jakub@redhat.com>
27698
27699         PR bootstrap/52041
27700         PR bootstrap/52039
27701         PR target/51974
27702         * ipa-prop.c (detect_type_change_1): Call ao_ref_init.
27703
27704 2012-01-31  Richard Guenther  <rguenther@suse.de>
27705
27706         PR tree-optimization/51528
27707         * tree-sra.c (sra_modify_assign): Avoid copy-in/out for aggregate
27708         assigns.
27709
27710 2012-01-31  Jakub Jelinek  <jakub@redhat.com>
27711
27712         PR bootstrap/52041
27713         PR bootstrap/52039
27714         PR target/51974
27715         * ree.c (add_removable_extension): Change def_map argument
27716         to unsigned *, store in def_map 1 + offset into *insn_list vector
27717         instead of pointers into the vector.
27718         (find_removable_extensions): Adjust caller.
27719
27720 2012-01-30  Georg-Johann Lay  <avr@gjlay.de>
27721
27722         * config/avr/avr.md: Resolve all AS1 and AS2 macros.
27723         Transform all "* quoted-c-code" to { c-code }.
27724         Remove redundant test for "optimize" in combine patterns.
27725         Move (include "avr-dimode.md") to end of file.
27726
27727 2012-01-30  Bin Cheng  <bin.cheng@arm.com>
27728
27729         PR target/51835
27730         * config/arm/arm.c (arm_libcall_uses_aapcs_base): Use correct ABI
27731         for __aeabi_d2iz/__aeabi_d2uiz with hard-float.
27732
27733 2012-01-30  Richard Guenther  <rguenther@suse.de>
27734
27735         PR tree-optimization/52028
27736         * tree-loop-distribution.c (ldist_gen): Properly update
27737         virtual SSA form.
27738
27739 2012-01-30  Jakub Jelinek  <jakub@redhat.com>
27740
27741         PR debug/52027
27742         * dwarf2out.c (dwarf2out_switch_text_section): Don't call
27743         set_cur_line_info_table if not emitting debug info.
27744
27745         PR tree-optimization/52046
27746         * tree-vect-patterns.c (check_bool_pattern): Give up if
27747         a comparison could throw.
27748
27749         PR debug/52048
27750         * tree-ssa-tail-merge.c (local_def): Ignore debug uses.
27751
27752 2012-01-30  Richard Guenther  <rguenther@suse.de>
27753
27754         PR tree-optimization/52045
27755         * tree-optimize.c (execute_cleanup_cfg_post_optimizing): Update
27756         SSA form if cfgcleanup did anything.
27757
27758 2012-01-30  Richard Guenther  <rguenther@suse.de>
27759
27760         PR tree-optimization/52045
27761         * ipa-inline-transform.c (inline_transform): Call execute_fixup_cfg
27762         before computing final todo.
27763
27764 2012-01-30  Richard Guenther  <rguenther@suse.de>
27765
27766         PR tree-optimization/51528
27767         * tree-sra.c (sra_modify_assign): Re-factor in preparation
27768         for PR51528 fix.
27769
27770 2012-01-30  Paolo Bonzini  <bonzini@gnu.org>
27771
27772         * df-problems.c (df_kill_notes): Check that the use refers
27773         to the note under examination.
27774
27775 2012-01-30  Eric Botcazou  <ebotcazou@adacore.com>
27776
27777         PR target/51920
27778         * config/sparc/sparc.c (vector_init_fpmerge): Remove INNER_MODE
27779         parameter and use short-lived pseudos.
27780         (vector_init_faligndata): Remove INNER_MODE parameter and use loop.
27781         (sparc_expand_vector_init): Const-ify local variables and adjust
27782         calls to above functions.
27783
27784 2012-01-30  Georg-Johann Lay  <avr@gjlay.de>
27785
27786         * config/avr/avr.c (out_movqi_mr_r): Fix length computation.
27787
27788 2012-01-29  Sandra Loosemore  <sandra@codesourcery.com>
27789
27790         * doc/invoke.texi: Make usage of "compile time" and
27791         "run time"/"runtime" consistent throughout the file.
27792
27793 2012-01-29  Uros Bizjak  <ubizjak@gmail.com>
27794
27795         * config/alpha/alpha.c (alpha_option_override): Default to
27796         full IEEE compliance mode for Go language.
27797
27798 2012-01-29  Tijl Coosemans  <tijl@coosemans.org>
27799
27800         * config/freebsd-spec.h [TARGET_LIBC_PROVIDES_SSP]
27801         (LINK_SSP_SPEC): Define.
27802
27803 2012-01-28  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
27804
27805         PR target/51871
27806         * config/pa/pa.c (pa_return_addr_rtx): Add support for PA2.0 export
27807         stubs.
27808
27809 2012-01-28  Sandra Loosemore  <sandra@codesourcery.com>
27810
27811         * doc/invoke.texi: Correct hyphenation of "floating point",
27812         "double precision", and related terminology throughout the file.
27813
27814 2012-01-28  Jakub Jelinek  <jakub@redhat.com>
27815
27816         PR target/52006
27817         * config/arm/arm.md (pic_add_dot_plus_eight peephole2): Use
27818         arm_general_register_operand predicate for operand 2 instead of
27819         register_operand.
27820
27821 2012-01-27  Ian Lance Taylor  <iant@google.com>
27822
27823         PR go/47656
27824         * builtins.def (BUILT_IN_INIT_HEAP_TRAMPOLINE): Define.
27825         * builtins.c (expand_builtin_init_trampoline): Add onstack
27826         parameter.  Change caller.
27827         (expand_builtin): Handle BUILT_IN_INIT_HEAP_TRAMPOLINE.
27828         * tree.c (build_common_builtin_nodes): Declare
27829         __builtin_init_heap_trampoline.
27830
27831 2012-01-27  Georg-Johann Lay  <avr@gjlay.de>
27832
27833         * config/avr/avr-protos.h (lpm_reg_rtx, lpm_addr_reg_rtx,
27834         tmp_reg_rtx, zero_reg_rtx, all_regs_rtx, rampz_rtx): Make global.
27835         * config/avr/avr.c: Ditto.
27836         (avr_regnames): Remove because unused.
27837         * config/avr/avr.md (*cpse.ne): New peephole.
27838         (*cpse.eq): New peephole from former cpse peepholes.
27839
27840 2012-01-27  Michael Eager  <eager@eagercon.com>
27841
27842         * config/microblaze.c (microblaze_emit_compare): Correct
27843         test after pcmp instruction.
27844
27845 2012-01-27  Richard Guenther  <rguenther@suse.de>
27846
27847         PR tree-optimization/52020
27848         * tree-sra.c (sra_modify_assign): Do not transform clobbers.
27849
27850 2012-01-27  Richard Guenther  <rguenther@suse.de>
27851
27852         * ipa-pure-const.c (check_stmt): Clobbers do not make a
27853         function non-const/pure.
27854
27855 2012-01-27  Richard Guenther  <rguenther@suse.de>
27856
27857         PR tree-optimization/50444
27858         * tree-sra.c (build_ref_for_offset): Properly adjust the
27859         MEM_REF type for unaligned accesses.
27860
27861 2012-01-27  Richard Guenther  <rguenther@suse.de>
27862
27863         PR tree-optimization/50444
27864         * expr.c (mem_ref_refers_to_non_mem_p): New function.
27865         (expand_assignment): Use it.  Properly handle misaligned
27866         bases when expanding stores to component references.
27867         (expand_expr_real_1): Use mem_ref_refers_to_non_mem_p and
27868         refactor that case.
27869
27870 2012-01-27  Andrey Belevantsev  <abel@ispras.ru>
27871
27872         PR middle-end/51389
27873         * Makefile.in (tree-data-ref.o): Depend on $(PARAMS_H).
27874         * tree-data-ref.h (find_data_references_in_loop): Remove declaration.
27875         * tree-data-ref.c (find_data_references_in_loop): Make static.
27876         (compute_all_dependences): Change return type to bool.  Bail out
27877         for too many datarefs in a loop.  Move the hunk resetting the data
27878         dependences vector from ...
27879         (compute_data_dependences_for_loop): ... here.  Account for
27880         compute_all_dependences returning false.
27881         (compute_data_dependences_for_bb): Likewise.
27882         * params.def (PARAM_LOOP_MAX_DATAREFS_FOR_DATADEPS): New param.
27883         * doc/invoke.texi (loop-max-datarefs-for-datadeps): Document it.
27884
27885 2012-01-27  Richard Guenther  <rguenther@suse.de>
27886
27887         PR middle-end/51959
27888         * expr.c (store_field): Use the alias-set of the scratch memory
27889         for storing to it.
27890
27891 2012-01-27  Tom de Vries  <tom@codesourcery.com>
27892
27893         PR tree-optimization/51990
27894         * tree-ssa-sccvn.c (copy_reference_ops_from_ref): Handle
27895         WITH_SIZE_EXPR.
27896         * tree-ssa-pre.c (create_component_ref_by_pieces_1): Same.
27897
27898 2012-01-27  Jakub Jelinek  <jakub@redhat.com>
27899
27900         PR debug/52001
27901         * var-tracking.c (reverse_op): Don't add any reverse operation
27902         if V already has any constant locations.
27903
27904 2012-01-27  Sandra Loosemore  <sandra@codesourcery.com>
27905
27906         * doc/invoke.texi: Correct usage of "command line" (noun)
27907         vs "command-line" (adjective) throughout.
27908
27909 2012-01-27  Sandra Loosemore  <sandra@codesourcery.com>
27910
27911         * doc/invoke.texi (Language Independent Options): Move
27912         -Wcoverage-mismatch blurb from here....
27913         (Warning Options): ...to here.
27914
27915 2012-01-27  Peter Bergner  <bergner@vnet.ibm.com>
27916
27917         * config/rs6000/rs6000.c (rs6000_option_override_internal):
27918         Set rs6000_always_hint to false for 476.
27919
27920 2012-01-27  Matthias Klose  <doko@ubuntu.com>
27921
27922         * gcc.c (add_sysrooted_prefix): Remove trailing dir separator from
27923           system root.
27924         * incpath.c (add_standard_paths): Likewise.
27925
27926 2012-01-27  Richard Henderson  <rth@redhat.com>
27927
27928         * config/m68k/m68k.c (TARGET_ATOMIC_TEST_AND_SET_TRUEVAL): New.
27929         * config/m68k/sync.md (atomic_test_and_set): Rename from
27930         sync_test_and_setqi and adjust the operands.
27931         (atomic_test_and_set_1): Rename from sync_test_and_setqi_1
27932         and unconditionally enable.
27933
27934 2012-01-27  Richard Henderson  <rth@redhat.com>
27935
27936         * config/sparc/sparc.c (TARGET_ATOMIC_TEST_AND_SET_TRUEVAL): New.
27937         * config/sparc/sync.md (atomic_test_and_set): Only handle QImode.
27938         (ldstub): Rename from ldstubqi.
27939         (ldstub<I24MODE>): Remove.
27940
27941 2012-01-27  Richard Henderson  <rth@redhat.com>
27942
27943         * target.def (TARGET_ATOMIC_TEST_AND_SET_TRUEVAL): New.
27944         * c-cppbuiltin.c (cpp_atomic_builtins): Define
27945         __GCC_ATOMIC_TEST_AND_SET_TRUEVAL.
27946         * doc/tm.texi.in (TARGET_ATOMIC_TEST_AND_SET_TRUEVAL): Add doc hook.
27947         * doc/tm.texi: Rebuild.
27948
27949 2012-01-27  Richard Henderson  <rth@redhat.com>
27950
27951         * optabs.c (gen_atomic_test_and_set): Remove default.
27952         (maybe_emit_atomic_test_and_set): Use maybe_expand_insn.
27953
27954 2012-01-26  Jakub Jelinek  <jakub@redhat.com>
27955
27956         PR rtl-optimization/51978
27957         * ree.c (make_defs_and_copies_lists): Change set_pat type to const_rtx.
27958         (combine_reaching_defs): Likewise.
27959         (struct re_info): Remove.
27960         (add_removable_extension): Remove x and data arguments,
27961         add insn, insn_list and def_map.  Use the arguments directly
27962         instead of using struct re_info.
27963         (find_removable_extensions): Don't call add_removable_extension
27964         through note_stores, instead just call it with single_set
27965         result if non-NULL.
27966         (find_and_remove_re): Pass curr_cand->expr instead of
27967         PATTERN (curr_cand->insn) as set_pat argument to combine_reaching_defs.
27968
27969 2012-01-26  Michael Matz  <matz@suse.de>
27970
27971         PR tree-optimization/46590
27972         * cfgexpand.c: Revert last change (r183305).
27973         * gimplify.c (gimplify_bind_expr): Add clobbers for all non-gimple
27974         regs.
27975         * tree-eh.c (cleanup_empty_eh): Try to optimize clobbers before
27976         checking for emptiness.
27977
27978 2012-01-26  Jakub Jelinek  <jakub@redhat.com>
27979
27980         PR middle-end/51895
27981         * expr.c (expand_expr_real_1): Handle BLKmode MEM_REF of
27982         non-addressable non-BLKmode base correctly.
27983
27984 2012-01-26  Michael Matz  <matz@suse.de>
27985
27986         PR tree-optimization/48794
27987         * tree-eh.c (remove_unreachable_handlers_no_lp): Don't remove
27988         regions referenced from RESX/EH_DISPATCH.
27989
27990 2012-01-26  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
27991
27992         * config/s390/s390.h: Make BRANCH_COST an option.
27993         * config/s390/s390.opt: New option -mbranch-cost.
27994
27995 2012-01-26  Richard Henderson  <rth@redhat.com>
27996
27997         Revert 2012-01-24 change:
27998         * trans-mem.c (requires_barrier): Do not instrument thread local
27999         variables and emit save/restore for them.
28000
28001 2012-01-25  Jakub Jelinek  <jakub@redhat.com>
28002
28003         PR middle-end/51986
28004         * sched-deps.c (sched_get_condition_with_rev_uncached): Don't test
28005         for pat == 0.
28006
28007 2012-01-25  Richard Sandiford  <rdsandiford@googlemail.com>
28008
28009         * config/mips/mips.c (mips_small_data_pattern_1): Don't process
28010         ASM_OPERANDS.
28011
28012 2012-01-25  Georg-Johann Lay  <avr@gjlay.de>
28013
28014         PR target/49868
28015         Rename __pgm to __flash.
28016         Rename __pgm1 to __flash1.
28017         Rename __pgm2 to __flash2.
28018         Rename __pgm3 to __flash3.
28019         Rename __pgm4 to __flash4.
28020         Rename __pgm5 to __flash5.
28021         Rename __pgmx to __memx.
28022         * doc/extend.texi (AVR Named Address Spaces)
28023         Rename address space names as indicated above.
28024         * config/avr/avr.c (avr_addrspace): Ditto.
28025
28026         * config/avr/avr-protos.h
28027         (avr_mem_pgmx_p): Rename to avr_mem_memx_p.
28028         (avr_mem_pgm_p): Rename to avr_mem_flash_p.
28029         * config/avr/predicates.md: Ditto.
28030         * config/avr/avr.c Ditto, and
28031         (avr_decl_pgmx_p): Rename to avr_decl_memx_p.
28032         (avr_decl_pgm_p): Rename to avr_decl_flash_p.
28033
28034         * config/avr/avr.h (ADDR_SPACE_PGM): Rename to ADDR_SPACE_FLASH.
28035         (ADDR_SPACE_PGM1): Rename to ADDR_SPACE_FLASH1.
28036         (ADDR_SPACE_PGM2): Rename to ADDR_SPACE_FLASH2.
28037         (ADDR_SPACE_PGM3): Rename to ADDR_SPACE_FLASH3.
28038         (ADDR_SPACE_PGM4): Rename to ADDR_SPACE_FLASH4.
28039         (ADDR_SPACE_PGM5): Rename to ADDR_SPACE_FLASH5.
28040         (ADDR_SPACE_PGMX): Rename to ADDR_SPACE_MEMX.
28041         * config/avr/avr.c: Ditto.
28042         * config/avr/avr.md: Ditto.
28043
28044 2012-01-25  Jason Merrill  <jason@redhat.com>
28045
28046         PR c++/51992
28047         * tree.c (find_decls_types_in_node): Walk gimple_call_fntype.
28048
28049 2012-01-25  Jakub Jelinek  <jakub@redhat.com>
28050
28051         PR tree-optimization/51987
28052         * tree-data-ref.c (get_references_in_stmt): Handle references in
28053         non-volatile GIMPLE_ASM.
28054
28055 2012-01-25  Richard Guenther  <rguenther@suse.de>
28056
28057         * tree-ssa-sccvn.c (vn_reference_eq): Also compare if both
28058         bases are dereferenced.
28059
28060 2012-01-25  Andrey Belevantsev  <abel@ispras.ru>
28061
28062         PR rtl-optimization/48374
28063         * sel-sched-ir.h (get_all_loop_exits): Check for zero successors.
28064
28065 2012-01-25  Andrey Belevantsev  <abel@ispras.ru>
28066
28067         * tree-predcom.c (tree_predictive_commoning_loop): Bail out when
28068         compute_data_dependences_for_loop returns false.
28069         * tree-parloops.c (loop_parallel_p): Likewise.
28070
28071 2012-01-25  Richard Guenther  <rguenther@suse.de>
28072
28073         * tree.h (get_pointer_alignment_1): Declare.
28074         * builtins.c (get_pointer_alignment_1): New function.
28075         (get_pointer_alignment): Use it.
28076
28077 2012-01-25  Ramana Radhakrishnan  <ramana.radhakrishnan@linaro.org>
28078
28079         PR rtl-optimization/48308
28080         * combine.c (enum undo_kind): Add UNDO_LINKS.
28081         (struct undo): Add member l to other_contents and where.
28082         (do_SUBST_LINK): New.
28083         (SUBST_LINK): New.
28084         (try_combine): Handle LOG_LINKS for the dummy i1 case.
28085         (undo_all): Handle UNDO_LINKS.
28086
28087 2012-01-25  Richard Henderson  <rth@redhat.com>
28088
28089         * optabs.c (maybe_emit_atomic_test_and_set): Allow non-QImode
28090         mem inputs.
28091
28092 2012-01-24  Richard Sandiford  <rdsandiford@googlemail.com>
28093
28094         * optabs.c (gen_atomic_test_and_set): Use each argument.
28095
28096 2012-01-24  Richard Sandiford  <rdsandiford@googlemail.com>
28097
28098         * config/mips/mips-ps-3d.md (mips_addr_ps, reduc_splus_v2sf)
28099         (mips_cvt_pw_ps, mips_cvt_ps_pw, mips_mulr_ps, mips_cabs_cond_<fmt>)
28100         (mips_cabs_cond_4s, mips_cabs_cond_ps, bc1any4t, bc1any4f, bc1any2t)
28101         (bc1any2f, mips_rsqrt1_<fmt>, mips_rsqrt2_<fmt>, mips_recip1_<fmt>)
28102         (mips_recip2_<fmt>): Require TARGET_MIPS3D rather than
28103         TARGET_PAIRED_SINGLE_FLOAT.
28104
28105 2012-01-24  Richard Sandiford  <rdsandiford@googlemail.com>
28106
28107         * doc/rtl.texi (MEM_IN_STRUCT_P, MEM_SCALAR_P): Delete.
28108         (in_struct, return_val): Remove MEM documentation.
28109         * rtl.h (rtx_def): Remove MEM meanings from in_struct and return_val.
28110         (MEM_IN_STRUCT_P, MEM_SCALAR_P): Delete.
28111         (MEM_COPY_ATTRIBUTES): Remove references to MEM_IN_STRUCT_P
28112         and MEM_SCALAR.
28113         * emit-rtl.c (set_mem_attributes_minus_bitpos): Likewise.
28114         * cfgexpand.c (add_alias_set_conflicts): Likewise.
28115         * expr.c (store_field): Likewise.
28116         * function.c (assign_stack_temp_for_type): Likewise.
28117         * ifcvt.c (noce_try_cmove_arith): Likewise.
28118         * reload1.c (reload): Likewise.
28119         * config/alpha/alpha.c (alpha_set_memflags_1): Likewise.
28120         (alpha_set_memflags): Likewise.
28121         * config/m32c/m32c.c (m32c_immd_dbl_mov): Nullify.
28122
28123 2012-01-24  Richard Sandiford  <rdsandiford@googlemail.com>
28124
28125         * rtl.h (true_dependence, canon_true_dependence): Remove varies
28126         parameter.
28127         * alias.c (fixed_scalar_and_varying_struct_p): Delete.
28128         (true_dependence_1, write_dependence_p, may_alias_p): Don't call it.
28129         (true_dependence_1, true_dependence, canon_true_dependence): Remove
28130         varies parameter.
28131         * cselib.c (cselib_rtx_varies_p): Delete.
28132         (cselib_invalidate_mem): Update call to canon_true_dependence.
28133         * dse.c (record_store, check_mem_read_rtx): Likewise.
28134         (scan_reads_nospill): Likewise.
28135         * cse.c (check_dependence): Likewise.
28136         (cse_rtx_varies_p): Delete.
28137         * expr.c (safe_from_p): Update call to true_dependence.
28138         * ira.c (validate_equiv_mem_from_store): Likewise.
28139         (memref_referenced_p): Likewise.
28140         * postreload-gcse.c (find_mem_conflicts): Likewise.
28141         * sched-deps.c (sched_analyze_2): Likewise.
28142         * store-motion.c (load_kills_store): Likewise.
28143         * config/frv/frv.c (frv_registers_conflict_p_1): Likewise.
28144         * gcse.c (mems_conflict_for_gcse_p): Likewise.
28145         (compute_transp): Update call to canon_true_dependence.
28146
28147 2012-01-25  Richard Henderson  <rth@redhat.com>
28148
28149         * optabs.c (CODE_FOR_atomic_test_and_set): Provide default.
28150         (maybe_emit_atomic_test_and_set): New.
28151         (expand_sync_lock_test_and_set): Use it.
28152         (expand_atomic_test_and_set): Likewise.
28153         * doc/extend.texi (__atomic_test_and_set): Adjust the docs to match
28154         the implementation; clarify implementation defined details.
28155         * doc/md.texi (atomic_test_and_set): Document.
28156
28157 2012-01-25  Richard Henderson  <rth@redhat.com>
28158
28159         * config/sparc/predicates.md (zero_or_v7_operand): Use match_code.
28160
28161 2012-01-25  Richard Henderson  <rth@redhat.com>
28162
28163         PR target/51968
28164         * config/arm/arm.c (neon_split_vcombine): Emit deleted note
28165         to effect no-op split.
28166
28167 2012-01-24  Aldy Hernandez  <aldyh@redhat.com>
28168
28169         PR lto/51698
28170         * builtin-types.def: (BT_CONST_DOUBLE_PTR): New.
28171         (BT_FN_VOID_PTR_CONST_PTR_SIZE): New.
28172         (BT_FN_VOID_PTR_INT_SIZE): New.
28173         (BT_FN_UINT_UINT_VAR): Remove.
28174         (BT_FN_UINT32_UINT32_VAR): New.
28175         (BT_FN_DOUBLE_VPTR): Remove.
28176         (BT_FN_DOUBLE_CONST_DOUBLE_PTR): New.
28177
28178         * gtm-builtins.def (_ITM_abortTransaction): Set return type to void.
28179         (_ITM_changeTransactionMode): Same.
28180         (_ITM_memmoveRtWt): Change return type to void.
28181         (_ITM_memcpyRtWt): Same.
28182         (_ITM_memsetW): Same.
28183         (_ITM_RaRD): Change types to double.
28184         (_ITM_RD): Same.
28185         (_ITM_RaWD): Same.
28186         (_ITM_RfWD): Same.
28187
28188         * builtins.def (DEF_TM_BUILTIN): Set BOTH_P to true.
28189
28190 2012-01-24  Aldy Hernandez  <aldyh@redhat.com>
28191             Patrick Marlier  <patrick.marlier@gmail.com>
28192
28193         * trans-mem.c (requires_barrier): Do not instrument thread local
28194         variables and emit save/restore for them.
28195
28196 2012-01-24  Jason Merrill  <jason@redhat.com>
28197
28198         PR c++/51812
28199         * cgraphunit.c (cgraph_decide_is_function_needed): Don't always
28200         output static aliases.
28201
28202 2012-01-24  Jakub Jelinek  <jakub@redhat.com>
28203
28204         PR driver/47249
28205         * common.opt (-pie, -shared, pie, shared): Change from Common to
28206         Driver.
28207         * gcc.c (display_help): Display help for -pie and -shared.
28208
28209 2012-01-24  Georg-Johann Lay  <avr@gjlay.de>
28210
28211         PR target/49868
28212         * doc/extend.texi (AVR Named Address Spaces): Move sample code up.
28213         Remove note on size/offset limitation.
28214         (AVR Variable Attributes): Add example how to read data located
28215         with progmem.  Refer to named address spaces.
28216         * doc/invoke.texi (AVR Options): Fix typo.
28217
28218 2012-01-24  Richard Guenther  <rguenther@suse.de>
28219
28220         Forward-port to trunk
28221         2010-09-21  Jakub Jelinek  <jakub@redhat.com>
28222
28223         PR middle-end/45678
28224         * expr.c (expand_expr_real_1) <case VIEW_CONVERT_EXPR>: If
28225         op0 isn't sufficiently aligned and there is movmisalignM
28226         insn for mode, use it to load op0 into a temporary register.
28227
28228 2012-01-24  Jakub Jelinek  <jakub@redhat.com>
28229
28230         PR target/51957
28231         * target.def (const_not_ok_for_debug_p): New hook.
28232         * doc/tm.texi.in (TARGET_CONST_NOT_OK_FOR_DEBUG_P): New hook
28233         documentation.
28234         * doc/tm.texi: Regenerated.
28235         * dwarf2out.c (const_ok_for_output_1): If
28236         targetm.const_not_ok_for_debug_p returns true, fail.
28237         * config/rs6000/rs6000.c (rs6000_const_not_ok_for_debug_p): New
28238         function.
28239         (TARGET_CONST_NOT_OK_FOR_DEBUG_P): Redefine.
28240
28241 2012-01-23  Kai Tietz  <ktietz@redhat.com>
28242
28243         PR target/51900
28244         * config/i386/predicates.md (symbolic_operand): Allow
28245         UNSPEC_PCREL as PIC expression for lea.
28246         * config/i386/winnt.c (i386_pe_binds_local_p): Reworked.
28247         * config/i386/i386.c (ix86_delegitimize_address): Handle
28248         UNSPEC_PCREL for none-MEM, too.
28249
28250 2012-01-23  Aldy Hernandez  <aldyh@redhat.com>
28251
28252         * trans-mem.c (ipa_tm_create_version): Set externally_visible.
28253         (ipa_tm_create_version_alias): Same.
28254
28255 2012-01-23  Uros Bizjak  <ubizjak@gmail.com>
28256
28257         PR libitm/51830
28258         * builtin-types.def (BT_FN_UINT_UINT_VAR): New.
28259         * gtm-builtins.def (BUILT_IN_TM_START): Declare as BT_FN_UINT_UINT_VAR.
28260
28261 2012-01-23  Aldy Hernandez  <aldyh@redhat.com>
28262             Patrick Marlier  <patrick.marlier@gmail.com>
28263             Iain Sandoe  <developer@sandoe-acoustics.co.uk>
28264
28265         PR lto/51916
28266         * lto-wrapper.c (run_gcc): Pass the LTO section name to
28267         simple_object_start_read.
28268
28269 2012-01-23  Richard Guenther  <rguenther@suse.de>
28270
28271
28272         PR tree-optimization/51895
28273         * tree-sra.c (decide_one_param_reduction): Avoid sub-optimal
28274         parameter decomposition into BLKmode components.
28275
28276 2012-01-23  Eric Botcazou  <ebotcazou@adacore.com>
28277
28278         * tree-ssa-structalias.c (intra_create_variable_infos): Do not create
28279         fake variables for restrict-qualified pointers whose pointed-to type
28280         contains a placeholder.
28281
28282 2012-01-23  Richard Guenther  <rguenther@suse.de>
28283
28284         PR tree-optimization/51949
28285         * ipa-split.c (execute_split_functions): Do not split malloc functions.
28286
28287 2012-01-23  Jakub Jelinek  <jakub@redhat.com>
28288
28289         PR rtl-optimization/51933
28290         * ree.c (transform_ifelse): Return true right away if dstreg is
28291         already wider or equal to cand->mode.
28292         (enum ext_modified_kind, struct ext_modified, ext_state): New types.
28293         (make_defs_and_copies_lists): Remove defs_list and copies_list
28294         arguments, add state argument, just truncate state->work_list
28295         instead of always allocating and freeing the vector.  Assert that
28296         get_defs succeeds instead of returning 2.  Changed return type to bool.
28297         (merge_def_and_ext): Add state argument.  If SET_DEST doesn't
28298         have ext_src_mode, see if it has been modified already with the
28299         right kind of extension and has been extended before from the
28300         ext_src_mode.  If SET_DEST is already wider or equal to cand->mode,
28301         just return true.  Remember the original mode in state->modified array.
28302         (combine_reaching_defs): Add state argument.  Don't allocate and
28303         free here def_list, copied_list and vec vectors, instead just
28304         VEC_truncate the vectors in *state.  Don't handle outcome == 2 here.
28305         (find_and_remove_re): Set DF_DEFER_INSN_RESCAN df flag.
28306         Add state variable, clear vectors in it, initialize state.modified
28307         if needed.  Free all the vectors at the end and state.modified too.
28308         Don't skip a candidate if the extension expression has been modified.
28309
28310 2012-01-22  Douglas B Rupp  <rupp@gnat.com>
28311
28312         PR target/47096
28313         * config.gcc: (i[34567]86-*-interix3*): Remove from obsolete
28314          configurations. Change triplet to i[34567]86-*-interix[3-9]*.
28315         (extra_options) interix.opt -> i386/interix.opt"
28316         (extra_objs):Add winnt-stubs.o
28317         * configure.ac: Add interix to target_os .comm on PE check.
28318         * configure: Regenerate.
28319         * config/interix3.h: Delete and move bits to..
28320         * config/interix.h: Delete and move bits to..
28321         * config/i386/i386-interix3.h: Delete and move bits to..
28322         * config/i386/i386-interix.h: ..here.
28323         (TARGET_CPU_DEFAULT): Remove redefinition.
28324         (TARGET_ASM_CONSTRUCTOR): Undefine.
28325         (SUBTARGET_SWITCHES): Define for ms-bitfields.
28326         (TARGET_OS_CPP_BUILTINS): Remove __OPENNT. Add __declspec.
28327         (PTRDIFF_TYPE): Define.
28328         (LONG_DOUBLE_TYPE_SIZE): Define.
28329         (LIBGCC2_LONG_DOUBLE_TYPE_SIZE): Define.
28330         (SUBTARGET_OVERRIDE_OPTIONS): Remove.
28331         (TARGET_SECTION_TYPE_FLAGS): Define.
28332         (ASM_DECLARE_FUNCTION_NAME): Define.
28333         (ASM_OUTPUT_EXTERNAL): Define.
28334         (ASM_OUTPUT_EXTERNAL_LIBCALL): Define.
28335         (ASM_OUTPUT_ALIGNED_BSS): Define.
28336         (PCC_BITFIELD_TYPE_MATTERS): Define.
28337         (USE_CONST_SECTION): Define.
28338         (SUBTARGET_ENCODE_SECTION_INFO): Remove.
28339         (TARGET_ASM_FUNCTION_RODATA_SECTION): Remove.
28340         (SUPPORTS_ONE_ONLY): Remove.
28341         (I386_PE_STRIP_ENCODING): Define.
28342         * config/interix.opt: Delete and move bits to..
28343         * config/i386/interix.opt: ..here. New.
28344         (mpe-aligned-commons): Add.
28345         * config/i386/t-interix: Add copyright header.
28346         (winnt-stubs.o): Add rule.
28347
28348 2012-01-22  Jason Merrill  <jason@redhat.com>
28349
28350         PR c++/51832
28351         * varpool.c (varpool_analyze_pending_decls): Copy DECL_EXTERNAL
28352         for extra name aliases.
28353
28354 2012-01-22  Eric Botcazou  <ebotcazou@adacore.com>
28355
28356         PR rtl-optimization/51924
28357         * ree.c (combine_set_extension): Improve debugging message.
28358         (combine_reaching_defs): Likewise.
28359         (get_defs): Rename confusingly named variable.
28360         (find_and_remove_re): Skip a candidate if the extension expression has
28361         been modified.
28362
28363 2012-01-21  Robert Millan  <rmh@gnu.org>
28364             Gerald Pfeifer  <gerald@pfeifer.com>
28365
28366         * config/kfreebsd-gnu.h (GNU_USER_DYNAMIC_LINKERX32): New macro.
28367         (GNU_USER_DYNAMIC_LINKER): Adjust indentation.
28368
28369 2012-01-20  Jakub Jelinek  <jakub@redhat.com>
28370
28371         PR tree-optimization/51914
28372         * tree-vect-stmts.c (vectorizable_conversion): For
28373         cvt_type && modifier == WIDEN, put temporary with cvt_type
28374         at the beginning of vec_dsts and set vec_dest to temporary
28375         with vectype_out.
28376
28377 2012-01-20  Eric Botcazou  <ebotcazou@adacore.com>
28378
28379         * cfgrtl.c (rtl_dump_bb): Do not dump insns for {ENTRY|EXIT}_BLOCK.
28380
28381 2012-01-20  Tijl Coosemans  <tijl@coosemans.org>
28382
28383         * config/i386/i386.c: Fix checks for !TARGET_MACHO.
28384         * config/rs6000/rs6000.c: Likewise.
28385
28386 2012-01-20  Jakub Jelinek  <jakub@redhat.com>
28387
28388         PR target/51915
28389         * config/arm/arm.c (arm_count_output_move_double_insns): Call
28390         output_move_double on a copy of operands array.
28391
28392 2012-01-20  Cary Coutant  <ccoutant@google.com>
28393             Dodji Seketeli  <dodji@redhat.com>
28394
28395         PR debug/45682
28396         * dwarf2out.c (copy_declaration_context): Return ref to parent
28397         of declaration DIE, if necessary.
28398         (remove_child_or_replace_with_skeleton): Add new parameter; update
28399         caller.  Place skeleton DIE under parent DIE of original declaration.
28400         Move call to copy_declaration_context to here ...
28401         (break_out_comdat_types): ... from here.
28402
28403 2012-01-20  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
28404
28405         PR rtl-optimization/51856
28406         * reload.c (find_reloads_subreg_address): Set the address_reloaded
28407         flag to reloaded.
28408
28409 2012-01-20  Ramana Radhakrishnan  <ramana.radhakrishnan@linaro.org>
28410
28411         PR target/51819
28412         * config/arm/arm.c (arm_print_operand): Correct output of alignment
28413         hints for neon loads and stores.
28414
28415 2012-01-20  Georg-Johann Lay  <avr@gjlay.de>
28416
28417         PR target/49868
28418         PR target/50887
28419         * doc/extend.texi (Named Address Spaces): Split into subsections.
28420         (AVR Named Address Spaces): New subsection.
28421         (M32C Named Address Spaces): New subsection.
28422         (RL78 Named Address Spaces): New subsection.
28423         (SPU Named Address Spaces): New subsection.
28424         (Variable Attributes): New anchor "AVR Variable Attributes".
28425         (AVR Variable Attributes): Rewrite and avoid wording
28426         "address space" in this context.
28427         * doc/invoke.texi (AVR Options): Rewrite and add documentation
28428         for -maccumulate-args, -mbranch-cost=, -mrelax, -mshort-calls.
28429         (AVR Built-in Macros): New subsubsection therein.
28430         * doc/md.texi (AVR constraints): Remove "C04", "R".
28431
28432 2012-01-20  Richard Guenther  <rguenther@suse.de>
28433
28434         PR tree-optimization/51903
28435         * tree-ssa-pre.c (eliminate): Properly purging of EH edges
28436         when removing stmts.
28437
28438 2012-01-20  Ramana Radhakrishnan  <ramana.radhakrishnan@linaro.org>
28439
28440         PR target/50313
28441         * config/arm/arm.c (arm_load_pic_register): Use
28442         gen_pic_load_addr_unified. Delete calls to gen_pic_load_addr_32bit
28443         , gen_pic_add_dot_plus_eight and gen_pic_add_dot_plus_four.
28444         (arm_pic_static_addr): Likewise.
28445         (arm_rtx_costs_1): Adjust cost for UNSPEC_PIC_UNIFIED.
28446         (arm_note_pic_base): Handle UNSPEC_PIC_UNIFIED.
28447         * config/arm/arm.md (UNSPEC_PIC_UNIFIED): Define.
28448         (pic_load_addr_unified): New.
28449
28450 2012-01-20  Andrey Belevantsev  <abel@ispras.ru>
28451
28452         PR target/51106
28453         * function.c (instantiate_virtual_regs_in_insn): Use
28454         delete_insn_and_edges when removing a wrong asm insn.
28455
28456 2012-01-19  Vladimir Makarov  <vmakarov@redhat.com>
28457
28458         PR rtl-optimization/40761
28459         * ira-int.h (struct ira_loop_tree_node): Add comment for member loop.
28460         Add new member loop_num.
28461         (IRA_LOOP_NODE_BY_INDEX): Modify the check.
28462         (ira_build): Remove the parameter.
28463
28464         * ira.c (ira_print_disposition): Use loop_num instead of loop->num.
28465         (ira.c): Do not build CFG loops for one region allocation.  Remove
28466         argument from ira_build call.
28467
28468         * ira-build.c (init_loop_tree_node): New function.
28469         (create_loop_tree_nodes): Use it.  Separate the case when CFG
28470         loops are not built.
28471         (more_one_region_p): Check current_loops.
28472         (finish_loop_tree_nodes): Separate the case when CFG loops are not
28473         built.
28474         (add_loop_to_tree): Process loop equal to NULL too.
28475         (form_loop_tree): Separate the case when CFG loops are not built.
28476         Use explicitly number for the root.
28477         (rebuild_regno_allocno_maps, create_loop_tree_node_allocnos): Add
28478         an assertion.
28479         (ira_print_expanded_allocno, loop_compare_func): Use loop_num
28480         instead of loop->num.
28481         (mark_loops_for_removal): Ditto.  Use loop_num instead of loop->num.
28482         (mark_all_loops_for_removal): Ditto.
28483         (remove_unnecessary_regions): Separate the case when CFG loops
28484         are not built.
28485         (ira_build): Remove the parameter.  Use explicit number of regions
28486         when CFG loops are not built.
28487
28488         * ira-color.c (print_loop_title): Separate the case for the root node.
28489         Use loop_num instead of loop->num.
28490         (move_spill_restore): Use loop_num instead of loop->num.
28491
28492         * ira-emit.c (setup_entered_from_non_parent_p): Add an assertion.
28493         (change_loop): Ditto.
28494         (change_loop): Use loop_num instead of loop->num.
28495
28496         * ira-lives.c (process_bb_node_lives): Ditto.
28497
28498         * ira-costs.c (print_allocno_costs, find_costs_and_classes): Ditto.
28499
28500         * ira-conflicts.c (print_allocno_conflicts): Ditto.
28501
28502 2012-01-19  Jakub Jelinek  <jakub@redhat.com>
28503
28504         PR libmudflap/40778
28505         * tree-mudflap.c (mf_artificial): New function.
28506         (execute_mudflap_function_ops, execute_mudflap_function_decls,
28507         mx_register_decls, mudflap_enqueue_decl): Use it.
28508
28509         PR target/51876
28510         * config/arm/neon.md (*neon_vswp<mode>): Fix up operand
28511         numbers in the insn pattern.
28512
28513 2012-01-19  Michael Matz  <matz@suse.de>
28514
28515         PR tree-optimization/46590
28516         * cfgexpand.c (add_scope_conflicts_1): New old_conflicts argument,
28517         use it in remembering which conflicts we already created.
28518         (add_scope_conflicts): Adjust call to above, (de)allocate helper
28519         bitmap.
28520
28521 2012-01-19  Aldy Hernandez  <aldyh@redhat.com>
28522
28523         PR lto/51280
28524         * lto-wrapper.c (run_gcc): Pass -fgnu_tm on.
28525         (merge_and_complain): Same.
28526
28527 2012-01-19  Jakub Jelinek  <jakub@redhat.com>
28528
28529         PR bootstrap/50237
28530         * config/initfini-array.h: Guard content of the header
28531         with #ifdef HAVE_INITFINI_ARRAY.
28532         * configure.ac: Move gcc_AC_INITFINI_ARRAY much later into the file.
28533         Add initfini-array.h to tm_file here.
28534         * acinclude.m4 (gcc_AC_INITFINI_ARRAY): For non-ia64 do a linker test.
28535         * config.gcc: Don't add initfini-array.h to tm_file here.
28536         * configure: Regenerated.
28537
28538 2012-01-19  Andrey Belevantsev  <abel@ispras.ru>
28539
28540         PR rtl-optimization/51505
28541         * df-problems.c (df_kill_notes): New parameter live. Update comment.
28542         Remove REG_EQUAL/REG_EQUIV notes referring to dead registers.
28543         (df_note_bb_compute): Update the call to df_kill_notes.
28544
28545 2012-01-18  Aldy Hernandez  <aldyh@redhat.com>
28546
28547         * trans-mem.c (requires_barrier): Remove call to is_global_var.
28548
28549 2012-01-18  Richard Guenther  <rguenther@suse.de>
28550
28551         * tree-ssa.c (useless_type_conversion_p): Remove special-casing
28552         of conversions to void *.
28553
28554 2012-01-17  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
28555             Richard Sandiford  <rdsandiford@googlemail.com>
28556
28557         PR middle-end/50325
28558         PR middle-end/51192
28559         * optabs.h (simplify_expand_binop): Declare.
28560         * optabs.c (simplify_expand_binop): Make global.
28561         * expmed.c (store_bit_field_1): Use simplify_expand_binop on big
28562         endian targets if the source cannot be exactly covered by word
28563         mode chunks.
28564
28565 2012-01-17  Jakub Jelinek  <jakub@redhat.com>
28566
28567         PR bootstrap/51872
28568         * hard-reg-set.h (struct hard_reg_set_container): New type.
28569         * target.h (struct hard_reg_set_container): Forward declare.
28570         * target.def (set_up_by_prologue): New target hook.
28571         * doc/tm.texi.in (TARGET_SET_UP_BY_PROLOGUE): Document it.
28572         * doc/tm.texi: Regenerated.
28573         * function.c (thread_prologue_and_epilogue_insns): Change
28574         set_up_by_prologue HARD_REG_SET into struct hard_reg_set_container.
28575         Call targetm.set_up_by_prologue on it.
28576         * config/rs6000/rs6000.c (rs6000_set_up_by_prologue): New function.
28577         (TARGET_SET_UP_BY_PROLOGUE): Redefine to it.
28578
28579 2012-01-17  Nick Clifton  <nickc@redhat.com>
28580
28581         * config/rx/rx.c (rx_can_use_simple_return): New function.
28582         * config/rx/rx-protos.h (rx_can_use_simple_return): Prototype.
28583         * config/rx/rx.md (return): Predicate on rx_can_use_simple_return.
28584
28585 2012-01-17  Richard Guenther  <rguenther@suse.de>
28586
28587         PR middle-end/51782
28588         * expr.c (expand_assignment): Take address-space information
28589         from the address operand of MEM_REF and TARGET_MEM_REF.
28590         (expand_expr_real_1): Likewise.
28591
28592 2012-01-17  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
28593
28594         * ira.c (do_reload): Make sure ira_dump_file is re-set if no
28595         reload dump is requested.
28596
28597 2012-01-17  Aldy Hernandez  <aldyh@redhat.com>
28598
28599         PR other/51165
28600         * trans-mem.c (requires_barrier): Call may_be_aliased.
28601
28602 2012-01-17  Jakub Jelinek  <jakub@redhat.com>
28603
28604         PR tree-optimization/51877
28605         * tree-ssa-tail-merge.c (gimple_equal_p): Don't return true whenever
28606         call arguments and fndecls compare equal, instead return false if they
28607         don't.  Return true only if lhs1 and lhs2 are either both NULL, or
28608         both SSA_NAMEs that are valueized the same, or they satisfy
28609         operand_equal_p.
28610
28611 2012-01-17  Rainer Orth  <ro@CeBiTec.Uni-Bielefeld.DE>
28612
28613         * configure.ac (gcc_cv_target_dl_iterate_phdr): Only check on
28614         Solaris 11+.
28615         * configure: Regenerate.
28616
28617 2012-01-16  Jan Hubicka  <jh@suse.cz>
28618
28619         PR c/12245
28620         PR c++/14179
28621         * convert.c (convert_to_integer): Use fold_convert for
28622         converting an INTEGER_CST to integer type.
28623
28624 2012-01-16  Jason Merrill  <jason@redhat.com>
28625
28626         PR c++/14179
28627         * vec.c (vec_gc_o_reserve_1): Use ggc_round_alloc_size.
28628
28629 2012-01-16  Jakub Jelinek  <jakub@redhat.com>
28630
28631         PR bootstrap/51860
28632         * config/s390/s390.c (s390_chunkify_start): Don't skip
28633         call insns followed by NOTE_INSN_CALL_ARG_LOCATION note.  Skip
28634         NOTE_INSN_VAR_LOCATION and NOTE_INSN_CALL_ARG_LOCATION notes.
28635         If insn is followed by NOTE_INSN_VAR_LOCATION or
28636         NOTE_INSN_CALL_ARG_LOCATION notes, insert jump after all those notes.
28637         Don't use location of note insns.
28638
28639         PR tree-optimization/51865
28640         * tree-inline.c (tree_function_versioning): Call remap_decl
28641         on DECL_RESULT whenever it has VOID_TYPE_P type.
28642
28643 2012-01-15  Richard Sandiford  <rdsandiford@googlemail.com>
28644
28645         * config/mips/mips.c (mips16_build_call_stub): Don't use a stub
28646         for calls to locally-binding MIPS16 functions if only the return
28647         type uses float regs.
28648
28649 2012-01-15  Chung-Lin Tang  <cltang@codesourcery.com>
28650             Richard Sandiford  <rdsandiford@googlemail.com>
28651
28652         * config/mips/mips-protos.h (SYMBOL_FORCE_TO_MEM): Delete.
28653         (SYMBOL_32_HIGH): Likewise.
28654         (mips_output_tls_reloc_directive): Declare.
28655         * config/mips/mips.h (PIC_FUNCTION_ADDR_REGNUM): Move to mips.md.
28656         (mips_use_pcrel_pool_p, mips_lo_relocs, mips_hi_relocs): Declare.
28657         * config/mips/mips.c (mips_use_pcrel_pool_p): New variable.
28658         (mips_lo_relocs, mips_hi_relocs): Make extern.
28659         (mips16_stub_function): Move up file.
28660         (mips_classify_symbol): Remove SYMBOL_FORCE_TO_MEM handling.
28661         (mips_symbolic_constant_p): Likewise.  Remove SYMBOL_32_HIGH too.
28662         (mips_symbol_insns_1): Likewise.  Check mips_use_pcrel_pool_p.
28663         (mips_cannot_force_const_mem): Use mips_use_pcrel_pool_p instead of
28664         SYMBOL_FORCE_TO_MEM.  Only check mips_tls_symbol_ref_1 if it's false.
28665         (mips_get_tp): Add MIPS16 support.
28666         (mips_legitimize_tls_address): Remove MIPS16 sorry().
28667         Generalize DTPREL and TPREL handling.
28668         (mips_init_relocs): Initialize mips_use_pcrel_pool_p.
28669         Add MIPS16 TLS support.
28670         (mips_output_tls_reloc_directive): New function.
28671         (mips16_rewrite_pool_refs): Ignore UNSPEC_TLS_GET_TPs.
28672         * config/mips/predicates.md (symbolic_operand_with_high)
28673         (tls_reloc_operand): New predicates.
28674         (force_to_mem_operand): Use mips_use_pcrel_pool_p.
28675         * config/mips/mips.md (UNSPEC_UNSHIFTED_HIGH): New unspec.
28676         (PIC_FUNCTION_ADDR_REGNUM): Moved from mips.h.
28677         (*unshifted_high): New instruction.  Use it for MIPS16 high splitter.
28678         (consttable_tls_reloc, tls_get_tp_mips16_<mode>): New patterns.
28679         (*tls_get_tp_mips16_call_<mode>): Likewise.
28680
28681 2012-01-15  Uros Bizjak  <ubizjak@gmail.com>
28682
28683         PR rtl-optimization/51821
28684         * recog.c (peep2_find_free_register): Determine clobbered registers
28685         from insn pattern.
28686
28687 2012-01-14  Denis Chertykov  <chertykov@gmail.com>
28688
28689         PR target/50925
28690         * config/avr/avr-protos.h: Revert change of 2012-01-09.
28691         * config/avr/avr.c: Likewise.
28692         * config/avr/avr.h: Likewise.
28693
28694 2012-01-13  Ian Lance Taylor  <iant@google.com>
28695
28696         PR c++/50012
28697         * tree.h (TYPE_QUALS): Add cast to int.
28698         (TYPE_QUALS_NO_ADDR_SPACE): Likewise.
28699
28700 2012-01-13  Ian Lance Taylor  <iant@google.com>
28701
28702         * ipa-cp.c (ipa_get_indirect_edge_target): Add typecasts when
28703         comparing param_index to VEC_length result.
28704
28705 2012-01-13  Steven Bosscher  <steven@gcc.gnu.org>
28706
28707         * c-decl.c: Do not include tree-mudflap.h
28708         * tree-optimize.c: Likewise.
28709         * Makefile.in: Update dependencies.
28710
28711 2012-01-13  Richard Guenther  <rguenther@suse.de>
28712
28713         PR middle-end/8081
28714         * gimplify.c (gimplify_modify_expr_rhs): For calls with a
28715         variable-sized result always use RSO.
28716
28717 2012-01-12  DJ Delorie  <dj@redhat.com>
28718
28719         * cfgexpand.c (convert_debug_memory_address): Allow any valid
28720         pointer type, not just the default pointer type.
28721
28722 2012-01-09  Richard Henderson  <rth@redhat.com>
28723             Denis Chertykov  <chertykov@gmail.com>
28724
28725         PR target/50925
28726         * config/avr/avr-protos.h (avr_hard_regno_nregs): Declare.
28727         * config/avr/avr.c (avr_can_eliminate): Simplify.
28728         (avr_initial_elimination_offset): Likewise.
28729         (avr_prologue_setup_frame): Use hard_frame_pointer_rtx.
28730         (expand_epilogue): Likewise.
28731         (avr_legitimize_address): Gut.
28732         (avr_legitimize_reload_address): Use hard_frame_pointer_rtx.
28733         (avr_hard_regno_nregs): New.
28734         (avr_hard_regno_ok): Allow only Pmode for arg and frame_pointers.
28735         (avr_regno_mode_code_ok_for_base_b): Handle arg and frame pointers.
28736         * config/avr/avr.h (FIXED_REGISTERS): Adjust arg pointer,
28737         add soft frame pointer.
28738         (CALL_USED_REGISTERS): Likewise.
28739         (REG_CLASS_CONTENTS): Likewise.
28740         (REGISTER_NAMES): Likewise.
28741         (HARD_REGNO_NREGS): Use avr_hard_regno_nregs.
28742         (HARD_FRAME_POINTER_REGNUM): New.
28743         (FRAME_POINTER_REGNUM): Use soft frame pointer.
28744         (ELIMINABLE_REGS): Eliminate from the soft frame pointer,
28745         remove the HARD_FRAME_POINTER self-elimination.
28746
28747 2012-01-12  Georg-Johann Lay  <avr@gjlay.de>
28748
28749         PR target/51756
28750         * config/avr/avr.c (avr_encode_section_info): Test for absence of
28751         DECL_EXTERNAL when checking for initializers of progmem variables.
28752
28753 2012-01-12  Ira Rosen  <irar@il.ibm.com>
28754
28755         PR tree-optimization/51799
28756         * tree-vect-patterns.c (vect_recog_over_widening_pattern): Check
28757         that the last operation is a type demotion.
28758
28759 2012-01-12  Uros Bizjak  <ubizjak@gmail.com>
28760
28761         * config/i386/i386.md (*zero_extendsidi2_rex64): Correct movl template.
28762         (x86_shift<mode>_adj_1): Remove operand constraint from operand 3.
28763
28764 2012-01-11  Jakub Jelinek  <jakub@redhat.com>
28765
28766         PR bootstrap/51796
28767         * combine.c (distribute_notes): If i3 is a noreturn call,
28768         allow old_size to be equal to args_size and make sure the
28769         noreturn call gets REG_ARGS_SIZE note.
28770         * expr.c (fixup_args_size_notes): Put REG_ARGS_SIZE notes
28771         on noreturn calls even when the delta is 0.
28772
28773 2012-01-11  Nathan Sidwell  <nathan@acm.org>
28774
28775         * gcov.c (STRING_SIZE): Remove.
28776         (generate_results): Erase annotations for source files with no
28777         coverage information.
28778         (read_line): New.
28779         (output_lines): Use it.
28780
28781 2012-01-11  Eric Botcazou  <ebotcazou@adacore.com>
28782
28783         * gimple.h (gimplify_body): Remove first argument.
28784         * gimplify.c (copy_if_shared): Add DATA argument.  Do not create the
28785         pointer set here, instead just pass DATA to walk_tree.
28786         (unshare_body): Remove BODY_P argument and adjust.  Create the pointer
28787         set here and invoke copy_if_shared on the size trees of DECL_RESULT.
28788         (unvisit_body): Likewise, but with unmark_visited.
28789         (gimplify_body): Remove BODY_P argument and adjust.
28790         (gimplify_function_tree): Adjust call to gimplify_body.
28791         * omp-low.c (finalize_task_copyfn): Likewise.
28792
28793 2012-01-11  Eric Botcazou  <ebotcazou@adacore.com>
28794
28795         * tree.h (build_function_decl_skip_args): Add boolean parameter.
28796         (build_function_type_skip_args): Delete.
28797         * tree.c (build_function_type_skip_args): Make static and add
28798         SKIP_RETURN parameter.  Fix thinko in the handling of variants.
28799         (build_function_decl_skip_args): Add SKIP_RETURN parameter and
28800         pass it to build_function_type_skip_args.
28801         * cgraph.h (cgraph_function_versioning): Add boolean parameter.
28802         (tree_function_versioning): Likewise.
28803         * cgraph.c (cgraph_create_virtual_clone): Adjust call to
28804         build_function_decl_skip_args.
28805         * cgraphunit.c (cgraph_function_versioning): Add SKIP_RETURN parameter
28806         and pass it to build_function_decl_skip_args/tree_function_versioning.
28807         (cgraph_materialize_clone): Adjust call to tree_function_versioning.
28808         * ipa-inline-transform.c (save_inline_function_body): Likewise.
28809         * trans-mem.c (ipa_tm_create_version): Likewise.
28810         * tree-sra.c (modify_function): Ditto for cgraph_function_versioning.
28811         * tree-inline.c (declare_return_variable): Remove always-true test.
28812         (tree_function_versioning): Add SKIP_RETURN parameter.  If the function
28813         returns non-void and SKIP_RETURN, create a void-typed RESULT_DECL.
28814         * ipa-split.c (split_function): Skip the return value for the split
28815         part if it doesn't return.
28816
28817 2012-01-11  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
28818
28819         PR tree-optimization/49642
28820         * ipa-split.c (forbidden_dominators): New variable.
28821         (check_forbidden_calls): New function.
28822         (dominated_by_forbidden): Likewise.
28823         (consider_split): Check for forbidden dominators.
28824         (execute_split_functions): Initialize and free forbidden
28825         dominators info; call check_forbidden_calls.
28826
28827 2012-01-11  Matthew Gretton-Dann  <matthew.gretton-dann@arm.com>
28828
28829         * config/arm/arm.md (mov_notscc): Use MVN for false condition.
28830
28831 2012-01-11  Nick Clifton  <nickc@redhat.com>
28832
28833         * config/rx/rx.md (return): Define pattern.
28834
28835 2012-01-11  Richard Guenther  <rguenther@suse.de>
28836
28837         * doc/extend.texi (malloc attribute): Adjust according to
28838         implementation.
28839
28840 2012-01-10  Aldy Hernandez  <aldyh@redhat.com>
28841             Patrick Marlier  <patrick.marlier@gmail.com>
28842
28843         PR middle-end/51516
28844         * trans-mem.c (get_cg_data): Traverse aliases if requested.
28845         (ipa_tm_scan_calls_block): Update parameters to get_cg_data.
28846         (ipa_tm_note_irrevocable): Same.
28847         (ipa_tm_scan_irr_block): Same.
28848         (ipa_tm_decrement_clone_counts): Same.
28849         (ipa_tm_scan_irr_function): Same.
28850         (ipa_tm_create_version_alias): Same.
28851         (ipa_tm_create_version): Same.
28852         (ipa_tm_transform_calls_redirect): Same.
28853         (ipa_tm_transform_calls): Same.
28854         (ipa_tm_transform_transaction): Same.
28855         (ipa_tm_execute): Same.
28856
28857 2012-01-10  Richard Guenther  <rguenther@suse.de>
28858
28859         PR middle-end/51806
28860         * opts.c (common_handle_option): Handle -Werror.
28861
28862 2012-01-10  Andreas Schwab  <schwab@linux-m68k.org>
28863
28864         * config/m68k/sync.md ("atomic_compare_and_swap<mode>_1"): Fix
28865         operand number.
28866
28867 2012-01-10  Jason Merrill  <jason@redhat.com>
28868
28869         * doc/invoke.texi (C++ Dialect Options): Update -fabi-version=6
28870         information.
28871
28872 2012-01-10  Rainer Orth  <ro@CeBiTec.Uni-Bielefeld.DE>
28873
28874         * configure.ac (gcc_cv_as_ix86_tlsgdplt): Check if linker
28875         supports R_386_TLS_GD_PLT reloc.
28876         (gcc_cv_as_ix86_tlsldmplt): Check if linker
28877         supports R_386_TLS_LDM_PLT reloc.
28878         * configure: Regenerate.
28879         * config.in: Regenerate.
28880
28881 2012-01-10  Georg-Johann Lay  <avr@gjlay.de>
28882
28883         PR target/49868
28884         Extend __pgmx semantics to linearize memory.
28885         * config/avr/avr.md (mov<mode>): Use avr_xload_libgcc_p to
28886         determine if code comes inline or from libgcc.
28887         (MOVMEM_r_d:HI): Add "w" to constraint for better preference.
28888         (movmem_qi, movmem_qi): Set constraint #2 to "n".
28889         (movmem_qi_elpm, movmem_hi_elpm): Remove insns.
28890         (movmemx_qi, movmemx_hi): New insns.
28891         (xload_<mode>_libgcc): Rewrite to new insn condition.
28892         (xload_<mode>): Remove insns.
28893         * config/avr/avr.c (avr_out_xload): Rewrite: Only need to handle
28894         cases that don't satisfy avr_xload_libgcc_p().
28895         (avr_addr_space_convert): Allow converting in any direction.
28896         (avr_addr_space_subset_p): Return always true.
28897         (avr_xload_libgcc_p): Rewrite to fit new __pgmx semantics.
28898         (avr_emit_movmemhi): Ditto.
28899         (avr_out_lpm): No need to handle ADDR_SPACE_PGMX any more.
28900         (avr_out_movmem): Ditto.
28901         (AVR_SYMBOL_FLAG_PROGMEM): New macro.
28902         (AVR_SYMBOL_SET_ADDR_SPACE): New macro.
28903         (AVR_SYMBOL_GET_ADDR_SPACE): New macro.
28904         (avr_encode_section_info): Encode 'progmem' in symbol flags.
28905         (output_reload_in_const): Don't zero-extend any 24-bit symbols.
28906
28907 2012-01-10  Richard Guenther  <rguenther@suse.de>
28908
28909         PR tree-optimization/50913
28910         * graphite-scop-detection.c (stmt_has_simple_data_refs_p):
28911         Require data-refs to be representable by Graphite with respect
28912         to any loop nest.
28913
28914 2012-01-10  Uros Bizjak  <ubizjak@gmail.com>
28915
28916         * config/i386/constraints.md ("L"): Return true for 0xffffffff.
28917         * config/i386/i386.c (*anddi_1): Emit AND with 0xffffffff as MOV.
28918
28919 2012-01-10  Tom de Vries  <tom@codesourcery.com>
28920
28921         PR rtl-optimization/51271
28922         * dwarf2cfi.c (scan_trace): Save and restore cur_row->reg_save when
28923         handling annulled branch.
28924
28925 2012-01-10  Richard Henderson  <rth@redhat.com>
28926
28927         * config/arm/arm.c (arm_vectorize_vec_perm_const_ok,
28928         TARGET_VECTORIZE_VEC_PERM_CONST_OK, neon_split_vcombine, MAX_VECT_LEN,
28929         struct expand_vec_perm_d, arm_expand_vec_perm_1, arm_expand_vec_perm,
28930         arm_evpc_neon_vuzp, arm_evpc_neon_vzip, arm_evpc_neon_vrev,
28931         arm_evpc_neon_vtrn, arm_evpc_neon_vtbl, arm_expand_vec_perm_const_1,
28932         arm_expand_vec_perm_const): New.
28933         * config/arm/arm-protos.h: Update.
28934         * config/arm/neon.md (UNSPEC_VCONCAT): New.
28935         (*neon_vswp<VDQX>): New.
28936         (neon_vcombine<VDX>): Use neon_split_vcombine.
28937         (neon_vtbl1v16qi, neon_vtbl2v16qi, neon_vcombinev16qi): New.
28938         * config/arm/vec-common.md (vec_perm_const<VALL>): New.
28939         (vec_perm<VE>): New.
28940
28941 2012-01-10  Richard Henderson  <rth@redhat.com>
28942
28943         * config/arm/arm.c (arm_gen_compare_reg): Add scratch argument;
28944         use it if reload_completed.
28945         (arm_legitimize_sync_memory, arm_emit, arm_insn_count, arm_count,
28946         arm_output_asm_insn, arm_process_output_memory_barrier,
28947         arm_output_memory_barrier, arm_ldrex_suffix, arm_output_ldrex,
28948         arm_output_strex, arm_output_it, arm_output_op2, arm_output_op3,
28949         arm_output_sync_loop, arm_get_sync_operand, FETCH_SYNC_OPERAND,
28950         arm_process_output_sync_insn, arm_output_sync_insn,
28951         arm_sync_loop_insns, arm_call_generator, arm_expand_sync): Remove.
28952         (arm_pre_atomic_barrier, arm_post_atomic_barrier): New.
28953         (arm_emit_load_exclusive, arm_emit_store_exclusive): New.
28954         (emit_unlikely_jump): New.
28955         (arm_expand_compare_and_swap, arm_split_compare_and_swap): New.
28956         (arm_split_atomic_op): New.
28957         * config/arm/arm-protos.h: Update.
28958         * config/arm/arm.h (enum arm_sync_generator_tag): Remove.
28959         (struct arm_sync_generator): Remove.
28960         * config/arm/arm.md (VUNSPEC_SYNC_COMPARE_AND_SWAP, VUNSPEC_SYNC_LOCK,
28961         VUNSPEC_SYNC_OP, VUNSPEC_SYNC_NEW_OP, VUNSPEC_SYNC_OLD_OP): Remove.
28962         (VUNSPEC_ATOMIC_CAS, VUNSPEC_ATOMIC_XCHG, VUNSPEC_ATOMIC_OP): New.
28963         (VUNSPEC_LL, VUNSPEC_SC): New.
28964         (sync_result, sync_memory, sync_required_value, sync_new_value,
28965         sync_t1, sync_t2, sync_release_barrier, sync_op): Remove.
28966         (attr length): Don't use arm_sync_loop_insns.
28967         (cbranch_cc, cstore_cc): Update call to arm_gen_compare_reg.
28968         (movsfcc, movdfcc): Likewise.
28969         * config/arm/constraints.md (Ua): New.
28970         * config/arm/prediates.md (mem_noofs_operand): New.
28971         (sync_compare_and_swap<QHSD>, sync_lock_test_and_set<QHSD>): Remove.
28972         (sync_clobber, sync_t2_reqd): Remove.
28973         (sync_<syncop><QHSD>, sync_nand<QHSD>): Remove.
28974         (sync_new_<syncop><QHSD>, sync_new_nand<QHSD>): Remove.
28975         (sync_old_<syncop><QHSD>, sync_old_nand<QHSD>): Remove.
28976         (arm_sync_compare_and_swap<SIDI>): Remove.
28977         (arm_sync_compare_and_swap<NARROW>): Remove.
28978         (arm_sync_lock_test_and_set<SIDI>): Remove.
28979         (arm_sync_lock_test_and_set<NARROW>): Remove.
28980         (arm_sync_new_<syncop><SIDI>): Remove.
28981         (arm_sync_new_<syncop><NARROW>): Remove.
28982         (arm_sync_new_nand<SIDI>): Remove.
28983         (arm_sync_new_nand<NARROW>): Remove.
28984         (arm_sync_old_<syncop><SIDI>): Remove.
28985         (arm_sync_old_<syncop><NARROW>): Remove.
28986         (arm_sync_old_nand<SIDI>): Remove.
28987         (arm_sync_old_nand<NARROW>): Remove.
28988         (*memory_barrier): Merge arm_output_memory_barrier.
28989         (atomic_compare_and_swap<QHSD>): New.
28990         (atomic_compare_and_swap<NARROW>_1): New.
28991         (atomic_compare_and_swap<SIDI>_1): New.
28992         (atomic_exchange<QHSD>): New.
28993         (cas_cmp_operand, cas_cmp_str): New.
28994         (atomic_op_operand, atomic_op_str): New.
28995         (atomic_<syncop><QHSD>, atomic_nand<QHSD>): New.
28996         (atomic_fetch_<syncop><QHSD>, atomic_fetch_nand<QHSD>): New.
28997         (atomic_<syncop>_fetch<QHSD>, atomic_nand_fetch<QHSD>): New.
28998         (arm_load_exclusive<NARROW>): New.
28999         (arm_load_exclusivesi, arm_load_exclusivedi): New.
29000         (arm_store_exclusive<QHSD>): New.
29001
29002 2012-01-09  Michael Meissner  <meissner@linux.vnet.ibm.com>
29003
29004         * config/rs6000/rs6000.c (rs6000_init_hard_regno_mode_ok): Add DF
29005         reload patterns if -mvsx-scalar-memory.
29006
29007         * config/rs6000/vsx.md (vsx_xscvspdp): Allow xscvspdp to be
29008         generated, even -mno-vsx-scalar-double was used.
29009         (vsx_xscvdpsp_scalar): Likewise.
29010         (vsx_xscvspdp_scalar2): Likewise.
29011
29012 2012-01-09  Tom de Vries  <tom@codesourcery.com>
29013             Andrew Pinski  <apinski@cavium.com>
29014
29015         PR debug/51471
29016         * reorg.c (fill_slots_from_thread): Don't speculate
29017         frame-related insns.
29018
29019 2012-01-09  Richard Sandiford  <rdsandiford@googlemail.com>
29020
29021         * sched-int.h (bb_note): Move to...
29022         * basic-block.h: ...here.
29023         * haifa-sched.c (bb_note): Move to...
29024         * cfgrtl.c: ...here.
29025         * function.c (next_block_for_reg): New function.
29026         (move_insn_for_shrink_wrap): Likewise.
29027         (prepare_shrink_wrap): Rewrite to use the above.
29028
29029 2012-01-09  Aldy Hernandez  <aldyh@redhat.com>
29030
29031         * gimple.c (is_gimple_non_addressable): Remove.
29032         * gimple.h: Remove is_gimple_non_addressable.
29033         * gimplify.c (gimplify_modify_expr_rhs): Use is_gimple_reg instead of
29034         is_gimple_non_addressable.
29035         * trans-mem.c (expand_assign_tm): Same.
29036
29037 2012-01-09  Richard Guenther  <rguenther@suse.de>
29038
29039         PR tree-optimization/51775
29040         * tree-ssa-sccvn.c (visit_use): Value-number throwing stmts.
29041         * tree-ssa-pre.c (eliminate): Properly fixup EH info.
29042
29043 2012-01-09  Matthew Gretton-Dann  <matthew.gretton-dann@arm.com>
29044
29045         * config/arm/arm-cores.def (cortex-a15): Use cortex_a15_tune for
29046         tuning parameters.
29047         * config/arm/arm.c (arm_cortex_a15_tune): New static variable.
29048
29049 2012-01-09  Richard Guenther  <rguenther@suse.de>
29050
29051         * tree-streamer-out.c (write_ts_optimization): Fix spelling.
29052
29053 2012-01-08  Jan Hubicka  <jh@suse.cz>
29054
29055         PR tree-optimize/51680
29056         * ipa-inline-analyss.c (evaluate_properties_for_edge): Fix condition
29057         on when known_vals needs to be computed; cleanup.
29058
29059 2012-01-08  Jan Hubicka  <jh@suse.cz>
29060
29061         PR tree-optimize/51694
29062         * ipa-cp.c (ipa_get_indirect_edge_target): Add bounds checks.
29063
29064 2012-01-08  Jonathan Wakely  <jwakely.gcc@gmail.com>
29065
29066         * doc/cpp.texi (Predefined Macros): __STRICT_ANSI__ is defined
29067         for -std=c++98 and -std=c++11 too.
29068
29069 2012-01-08  Chung-Lin Tang  <cltang@codesourcery.com>
29070
29071         * cfgloop.c (cancel_loop): Add free() of bbs array.
29072
29073 2012-01-07  Jan Hubicka  <jh@suse.cz>
29074
29075         PR tree-optimization/51600
29076         * ipa-inline-analysis.c (estimate_edge_devirt_benefit): Disable code
29077         that benefits small functions.
29078
29079 2012-01-07  Jan Hubicka  <jh@suse.cz>
29080
29081         * ipa-inline.c (want_inline_small_function_p): Fix formating.
29082
29083 2012-01-07  Jan Hubicka  <jh@suse.cz>
29084
29085         PR tree-optimization/51680
29086         * ipa-inline.c (want_inline_small_function_p): Be more lax on functions
29087         whose inlining reduce unit size.
29088
29089 2012-01-07  Alexandre Oliva  <aoliva@redhat.com>
29090
29091         PR bootstrap/51725
29092         * cselib.c (new_elt_loc_list): Promote addr_list to canonical node.
29093         Add canonical node to containing_mem chain after the non-canonical
29094         one, even if there weren't any locs to propagate.
29095         (remove_useless_values): Keep only canonical values.
29096         (add_mem_for_addr, cselib_lookup_mem): Canonicalize addr.
29097         (cselib_invalidate_mem): Likewise.  Ensure v is canonical, and
29098         canonicalize mem_chain elements that are not discarded.
29099
29100 2012-01-06  Jakub Jelinek  <jakub@redhat.com>
29101
29102         PR target/47333
29103         * cgraphunit.c (cgraph_optimize): Call output_weakrefs
29104         before emitting functions.
29105
29106         PR gcov-profile/50127
29107         * bb-reorder.c (partition_hot_cold_basic_blocks): Call
29108         clear_aux_for_blocks.
29109
29110 2012-01-06  Alexandre Oliva  <aoliva@redhat.com>
29111
29112         PR debug/51746
29113         * cselib.c (cselib_hash_rtx): Hash incoming VALUEs too.
29114
29115 2012-01-06  Arnaud Charlet  <charlet@adacore.com>
29116
29117         * c-decl.c (ext_block): Moved up.
29118         (collect_all_refs, for_each_global_decl): Take ext_block into account.
29119
29120 2012-01-06  Han Shen  <shenhan@google.com>
29121
29122         Translate built-in include paths for sysroot.
29123         * Makefile.in (gcc_gxx_include_dir_add_sysroot): New.
29124         (PREPROCESSOR_DEFINES): Define GPLUSPLUS_INCLUDE_DIR_ADD_SYSROOT.
29125
29126         * cppdefault.c (cpp_include_defaults): Replace hard coded "0" with
29127         GPLUSPLUS_INCLUDE_DIR_ADD_SYSROOT for "add_sysroot" field.
29128
29129         * configure.ac (AC_SUBST): Add gcc_gxx_include_dir_add_sysroot to
29130         control whether sysroot should be prepended to gxx include dir.
29131
29132         * configure: Regenerate.
29133
29134 2012-01-06  Torvald Riegel  <triegel@redhat.com>
29135
29136         PR rtl-optimization/51771
29137         * builtin-attrs.def (ATTR_RETURNS_TWICE, ATTR_TM_NOTHROW_RT_LIST): New.
29138         * gtm-builtins.def (BUILT_IN_TM_START): Add returns-twice attrib.
29139
29140 2012-01-05  Eric Botcazou  <ebotcazou@adacore.com>
29141
29142         PR tree-optimization/51315
29143         * tree-sra.c (tree_non_aligned_mem_for_access_p): New predicate.
29144         (build_accesses_from_assign): Use it instead of tree_non_aligned_mem_p.
29145
29146 2012-01-05  Uros Bizjak  <ubizjak@gmail.com>
29147
29148         PR target/51681
29149         * config/ia64/ia64.c (expand_vec_perm_shrp): Use correct operands
29150         for shrp pattern.  Correctly handle and fixup shift variable.
29151         Return false when shift > nelt for BYTES_BIG_ENDIAN target.
29152
29153 2012-01-05  Jakub Jelinek  <jakub@redhat.com>
29154
29155         PR debug/51762
29156         * calls.c (emit_call_1): For noreturn calls force a REG_ARGS_SIZE
29157         note when !ACCUMULATE_OUTGOING_ARGS.
29158
29159 2012-01-05  Eric Botcazou  <ebotcazou@adacore.com>
29160
29161         * tree-vrp.c (extract_range_from_binary_expr_1): Remove duplicated
29162         condition.
29163         (extract_range_from_unary_expr_1): Avoid useless computations.
29164
29165 2012-01-05  Jakub Jelinek  <jakub@redhat.com>
29166
29167         PR rtl-optimization/51767
29168         * cfgrtl.c (force_nonfallthru_and_redirect): Force addition
29169         of jump_block and add an extra edge for degenerated asm gotos.
29170
29171         PR middle-end/51768
29172         * stmt.c (check_unique_operand_names): Don't ICE during error
29173         reporting if i is from labels chain.
29174
29175         PR middle-end/44777
29176         * profile.c (branch_prob): Split bbs that have exit edge
29177         and need a fake entry edge too.
29178
29179 2012-01-05  Jan Hubicka  <jh@suse.cz>
29180
29181         PR middle-end/49710
29182         * cfgloopmanip.c (remove_path): Walk loop hiearchy upwards when
29183         unlooping loops.
29184
29185 2012-01-05  Richard Guenther  <rguenther@suse.de>
29186
29187         PR lto/50490
29188         * tree-streamer-out.c (write_ts_optimization): New function.
29189         (streamer_write_tree_body): Call it.
29190         * tree-streamer-in.c (lto_input_ts_optimization): New function.
29191         (streamer_read_tree_body): Call it.
29192         * lto-streamer-out.c (lto_is_streamable): Handle OPTIMIZATION_NODE.
29193
29194 2012-01-05  Jakub Jelinek  <jakub@redhat.com>
29195
29196         PR middle-end/51761
29197         * gimple.h (struct gimplify_ctx): Add in_cleanup_point_expr field.
29198         * gimplify.c (gimplify_cleanup_point_expr): Save and set
29199         in_cleanup_point_expr before gimplify_stmt call and restore it
29200         afterwards.
29201         (gimplify_target_expr): Don't add {CLOBBER} cleanup if
29202         in_cleanup_point_expr is false.
29203
29204 2012-01-05  Richard Guenther  <rguenther@suse.de>
29205
29206         PR middle-end/51764
29207         * common.opt (Wmudflap, fmudflap, fmudflapth, fmudflapir): Move
29208         to c.opt.
29209         * toplev.c (process_options): Reject combining mudflap and LTO.
29210         * tree-nomudflap.c (nogo): Use sorry instead of internal_error.
29211
29212 2012-01-05  Richard Guenther  <rguenther@suse.de>
29213
29214         PR tree-optimization/51760
29215         * tree-ssa-ccp.c (likely_value): Drop UNDEFINED to CONSTANT,
29216         not VARYING.
29217         (bit_value_unop): Handle UNDEFINED operands.
29218         (bit_value_binop): Likewise.
29219
29220 2012-01-05  Georg-Johann Lay  <avr@gjlay.de>
29221
29222         * config/avr/avr.c (avr_replace_prefix): Remove.
29223         (avr_asm_named_section): Use ACONCAT instead of avr_replace_prefix.
29224         (avr_asm_function_rodata_section): Ditto.
29225         (avr_asm_select_section): Ditto.
29226
29227 2012-01-05  Marcus Shawcroft  <marcus.shawcroft@arm.com>
29228
29229         * reload.c (find_reloads): Adjust LABEL_NUSES on REG_LABEL_OPERAND
29230         insertion.
29231
29232 2012-01-05  Jakub Jelinek  <jakub@redhat.com>
29233
29234         PR bootstrap/51648
29235         * tree-cfg.c (need_fake_edge_p): Return true also for noreturn
29236         calls that have any non-fake successor edges.
29237
29238         PR debug/51746
29239         * var-tracking.c (add_stores): For COND_EXEC allow oval to be NULL.
29240
29241 2012-01-04  Eric Botcazou  <ebotcazou@adacore.com>
29242
29243         PR tree-optimization/51624
29244         * tree-sra.c (build_ref_for_model): When replicating a chain of
29245         COMPONENT_REFs, stop as soon as the offset would become negative.
29246
29247 2012-01-04  Jakub Jelinek  <jakub@redhat.com>
29248
29249         PR debug/51695
29250         * dwarf2out.c (output_loc_list): For now drop >= 64KB expressions
29251         in .debug_loc on the floor.
29252
29253 2012-01-04  Andrew Pinski  <apinski@cavium.com>
29254
29255         * doc/invoke.texi (-march=@var{arch}): Add octeon+ and octeon2.
29256
29257 2012-01-04  Andrew Pinski  <apinski@cavium.com>
29258             Adam Nemet  <anemet@caviumnetworks.com>
29259
29260         * config/mips/mips.md (size): Add SI and DI.
29261         (SIZE): New mode attribute.
29262         (U): New code attribute.
29263         * config/mips/mips-dsp.md (mips_lbux): Use gen_mips_lbux_extsi.
29264         (mips_lbux_<mode>): Delete.
29265         (mips_l<SHORT:size><u>x_ext<GPR:mode>_<P:mode>): New pattern.
29266         (mips_lhx): Use gen_mips_lhx_extsi.
29267         (mips_lhx_<mode>): Delete.
29268         (mips_lwx): Delete.
29269         (mips_l<size>x): New expand.
29270         (mips_lwx_<mode>): Delete.
29271         (mips_l<GPR:size>x_<P:mode>): New pattern.
29272         (*mips_lw<u>x_<P:mode>_ext): Likewise.
29273         * config/mips/mips-ftypes.def: Add DI f(POINTER, SI) function type.
29274         * config/mips/mips.c (mips_lx_address_p): New function.
29275         (mips_rtx_costs <case MEM>): Call mips_lx_address_p.
29276         (dsp64): New availability predicate.
29277         (mips_builtins): Add an entry for __builtin_mips_ldx.
29278         * config/mips/mips.h (ISA_HAS_LBX): New define.
29279         (ISA_HAS_LBUX): Likewise.
29280         (ISA_HAS_LHX): Likewise.
29281         (ISA_HAS_LHUX): Likewise.
29282         (ISA_HAS_LWX): Likewise.
29283         (ISA_HAS_LWUX): Likewise.
29284         (ISA_HAS_LDX): Likewise.
29285         * doc/extend.texi (__builtin_mips_ldx): Document.
29286
29287 2012-01-04  Tristan Gingold  <gingold@adacore.com>
29288
29289         * config/vms/xm-vms.h (HOST_LONG_FORMAT, HOST_PTR_PRINTF): Define
29290         when long pointers are used.
29291         * config.build (*-*-*vms*): Handle all OpenVMS targets.
29292         (alpha64-dec-*vms*, alpha*-dec-*vms*)
29293         (ia64-hp-*vms*): Remove.
29294         * config/vms/xm-vms64.h: Delete.
29295
29296 2012-01-04  Aldy Hernandez  <aldyh@redhat.com>
29297
29298         PR middle-end/51472
29299         * trans-mem.c (expand_assign_tm): Handle TM_MEMMOVE loads correctly.
29300
29301 2012-01-04  Aldy Hernandez  <aldyh@redhat.com>
29302
29303         * opts.c (finish_options): Remove duplicate sorry.
29304
29305 2012-01-04  Aldy Hernandez  <aldyh@redhat.com>
29306
29307         PR middle-end/51696
29308         * trans-mem.c (diagnose_tm_1): Display indirect calls with no name
29309         correctly.
29310
29311 2012-01-04  Richard Guenther  <rguenther@suse.de>
29312
29313         PR middle-end/51750
29314         * tree.c (size_low_cst): New function.
29315         * tree.h (size_low_cst): Declare.
29316         * fold-const.c (fold_comparison): Use it to extract the low
29317         part of the POINTER_PLUS_EXPR offset.
29318
29319 2012-01-04  Georg-Johann Lay  <avr@gjlay.de>
29320
29321         Fix clearing ZERO_REG
29322         * config/avr/avr.md (cc): Add alternative "ldi".
29323         (movqi_insn): Use it in cc attribute.
29324         * config/avr/avr.c (notice_update_cc): Handle CC_LDI.
29325         (output_reload_in_const): Use CLR to move 0 to ZERO_REG.
29326         (output_reload_insisf): Use ZERO_REG to pre-clear register.
29327
29328 2012-01-04  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
29329
29330         * configure: Regenerate.
29331
29332 2012-01-04  Richard Guenther  <rguenther@suse.de>
29333
29334         PR tree-optimization/49651
29335         * tree-ssa-structalias.c (type_can_have_subvars): New function.
29336         (var_can_have_subvars): Use it.
29337         (get_constraint_for_1): Only consider subfields if there can be any.
29338
29339 2012-01-03  Jakub Jelinek  <jakub@redhat.com>
29340
29341         PR bootstrap/51725
29342         * cselib.c (new_elt_loc_list): When moving locs from one cselib_val
29343         to its new canonical_cselib_val and the cselib_val was in
29344         first_containing_mem chain, but the canonical_cselib_val was not,
29345         add the latter into the chain.
29346         (cselib_invalidate_mem): Compare canonical_cselib_val of
29347         addr_list chain elt with v.
29348
29349         PR pch/51722
29350         * dwarf2out.c (dwarf2out_start_source_file, dwarf2out_define,
29351         dwarf2out_undef): Allocate e.info using ggc_strdup instead
29352         of xstrdup.
29353         (output_macinfo_op): Don't ggc_strdup fd->filename.
29354         (optimize_macinfo_range): Allocate grp_name using XALLOCAVEC,
29355         then ggc_strdup it.  Don't free inc->info or cur->info.
29356         (output_macinfo): Don't free ref->info or file->info.
29357
29358 2012-01-03  Ira Rosen  <irar@il.ibm.com>
29359
29360         PR tree-optimization/51269
29361         * tree-vect-loop-manip.c (set_prologue_iterations): Make
29362         first_niters a pointer.
29363         (slpeel_tree_peel_loop_to_edge): Likewise.
29364         (vect_do_peeling_for_loop_bound): Update call to
29365         slpeel_tree_peel_loop_to_edge.
29366         (vect_gen_niters_for_prolog_loop): Don't compute wide_prolog_niters
29367         here.  Remove it from the parameters list.
29368         (vect_do_peeling_for_alignment): Update calls and compute
29369         wide_prolog_niters.
29370
29371 2012-01-03  Richard Guenther  <rguenther@suse.de>
29372
29373         PR tree-optimization/51070
29374         * tree-loop-distribution.c (stmt_has_scalar_dependences_outside_loop):
29375         Properly handle calls.
29376
29377 2012-01-03  Richard Guenther  <rguenther@suse.de>
29378
29379         PR tree-optimization/51692
29380         * tree-ssa-dce.c (eliminate_unnecessary_stmts): Do not remove
29381         the LHS of allocation stmts.
29382
29383 2012-01-03  Olivier Hainque  <hainque@adacore.com>
29384
29385         * system.h: Prior to #define, #undef fopen and freopen unconditionally.
29386
29387 2012-01-03  Olivier Hainque  <hainque@adacore.com>
29388
29389         * collect2.c (main): In AIX specific computations for vector
29390         insertions, use CONST_CAST2 to cast from char ** to const char **.
29391
29392 2012-01-03  Richard Guenther  <rguenther@suse.de>
29393
29394         PR debug/51650
29395         * dwarf2out.c (dwarf2out_finish): Always create a DIE for
29396         the context of a limbo DIE when it does not already exist.
29397
29398 2012-01-03  Jakub Jelinek  <jakub@redhat.com>
29399
29400         PR tree-optimization/51719
29401         * value-prof.c (gimple_ic): When indirect call isn't noreturn,
29402         but direct call is, clear direct call's lhs and don't add fallthrough
29403         edge from dcall_bb to join_bb and PHIs.
29404
29405 2012-01-03  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
29406
29407         * config/s390/s390.md ("*cmp<mode>_ccs"): Fix comment mentioning
29408         the instructions emitted by the pattern.
29409         ("*TDC_insn_<mode>"): Add comment.
29410
29411 2012-01-03  Richard Guenther  <rguenther@suse.de>
29412
29413         PR middle-end/51730
29414         * fold-const.c (fold_comparison): Properly canonicalize
29415         tree offset and HOST_WIDE_INT bit position.
29416
29417 2012-01-02  Uros Bizjak  <ubizjak@gmail.com>
29418
29419         * config/ia64/ia64.c (expand_vec_perm_broadcast): Use correct
29420         operands for extzv pattern.
29421
29422 2012-01-02  Jakub Jelinek  <jakub@redhat.com>
29423
29424         PR bootstrap/51725
29425         * cselib.c (add_mem_for_addr): Call canonical_cselib_val
29426         on mem_elt first.
29427
29428 2012-01-02  Sandra Loosemore  <sandra@codesourcery.com>
29429
29430         * doc/invoke.texi (-flto and related options): Copy-edit.
29431
29432 2012-01-02  Richard Sandiford  <rdsandiford@googlemail.com>
29433
29434         * config/mips/mips.md (loadgp_newabi_<mode>): Add missing earlyclobber.
29435
29436 2012-01-02  Jakub Jelinek  <jakub@redhat.com>
29437
29438         * config/i386/sse.md (*avx2_gatherdi<mode>_3, *avx2_gatherdi<mode>_4):
29439         New patterns.
29440
29441 2012-01-02  Richard Sandiford  <rdsandiford@googlemail.com>
29442
29443         * expr.h (move_by_pieces_ninsns): Declare.
29444         * expr.c (move_by_pieces_ninsns): Make external.
29445         * config/mips/mips-protos.h (mips_move_by_pieces_p): Declare.
29446         (mips_store_by_pieces_p): Likewise.
29447         * config/mips/mips.h (MOVE_BY_PIECES_P): Call mips_move_by_pieces_p.
29448         (STORE_BY_PIECES_P): Likewise mips_store_by_pieces_p.
29449         * config/mips/mips.c (mips_move_by_pieces_p): New function.
29450         (mips_store_by_pieces_p): Likewise.
29451
29452 2012-01-02  Jakub Jelinek  <jakub@redhat.com>
29453
29454         * passes.c (register_one_dump_file): Free full_name.
29455
29456         * reload1.c (reload): Don't allocate reg_max_ref_width here.
29457         (calculate_elim_costs_all_insns): Free offsets_at and
29458         offsets_known_at at the end and clear the pointers.
29459
29460 2012-01-02  Georg-Johann Lay  <avr@gjlay.de>
29461
29462         * config/avr/avr.opt (-mbranch-cost): Fix double definition of
29463         this option introduced in r180739.
29464
29465 2012-01-02  Georg-Johann Lay  <avr@gjlay.de>
29466
29467         PR target/51345
29468         * config.gcc (tm_file target=avr]): Add avr/avr-multilib.h
29469         (tmake_file target=avr): Add avr/t-multilib.
29470
29471         * config/avr/avr-c.c (avr_cpu_cpp_builtins): Use AVR_HAVE_8BIT_SP
29472         to built-in define __AVR_HAVE_8BIT_SP__, __AVR_HAVE_16BIT_SP__.
29473         * config/avr/genmultilib.awk: New file.
29474         * config/avr/t-multilib: New auto-generated file.
29475         * config/avr/multilib.h: New auto-generated file.
29476         * config/avr/t-avr (AVR_MCUS): New variable.
29477         (genopt.sh): Use it.
29478         (s-mlib): Depend on t-multilib.
29479         (t-multilib, multilib.h): New dependencies.
29480         (s-avr-mlib): New rule to build t-multilib, multilib.h from AVR_MCUS.
29481         (MULTILIB_OPTIONS): Remove.
29482         (MULTILIB_MATCHES): Remove.
29483         (MULTILIB_DIRNAMES): Remove.
29484         (MULTILIB_EXCEPTIONS): Remove:
29485         * config/avr/genopt.sh: Don't use hard coded file name;
29486         pass AVR_MCUS from t-avr instead.
29487
29488 2012-01-02  Georg-Johann Lay  <avr@gjlay.de>
29489
29490         * config/avr/avr.c (avr_out_ashrpsi3): Fix "case 31" to "case 23".
29491
29492 2012-01-02  Georg-Johann Lay  <avr@gjlay.de>
29493
29494         Implement light-weight DImode support.
29495         * config/avr/avr-dimode.md: New file.
29496         * config/avr/avr.md: Include it.
29497         (adjust_len): Add plus64, compare64.
29498         (HIDI): Remove code iterator.
29499         (code_stdname): New code attribute.
29500         (rotx, rotsmode): Remove DI.
29501         (rotl<mode>3, *rotw<mode>, *rotb<mode>): Use HISI instead of HIDI
29502         as code iterator.
29503         * config/avr/avr-protos.h (avr_have_dimode): New.
29504         (avr_out_plus64, avr_out_compare64): New.
29505         * config/avr/avr.c (avr_out_compare): Handle DImode.
29506         (avr_have_dimode): New variable definition and initialization.
29507         (avr_out_compare64, avr_out_plus64): New functions.
29508         (avr_out_plus_1): Use simplify_unary_operation to negate xval.
29509         (adjust_insn_length): Handle ADJUST_LEN_COMPARE64, ADJUST_LEN_PLUS64.
29510         (avr_compare_pattern): Skip DImode comparisons.
29511
29512 2012-01-02  Revital Eres  <revital.eres@linaro.org>
29513
29514         * ddg.c (def_has_ccmode_p): New function.
29515         (add_cross_iteration_register_deps,
29516         create_ddg_dep_from_intra_loop_link): Call it.
29517
29518 2012-01-02  Richard Guenther  <rguenther@suse.de>
29519
29520         PR other/51679
29521         * invoke.texi (fassociative-math): Remove spurious paranthesis.
29522
29523 2012-01-01  Jakub Jelinek  <jakub@redhat.com>
29524
29525         * gcc.c (process_command): Update copyright notice dates.
29526         * gcov.c (print_version): Likewise.
29527         * gcov-dump.c (print_version): Likewise.
29528         * mips-tfile.c (main): Likewise.
29529         * mips-tdump.c (main): Likewise.
29530
29531 2012-01-01  Ira Rosen  <irar@il.ibm.com>
29532
29533         PR tree-optimization/51704
29534         * tree-vect-slp.c (vect_detect_hybrid_slp_stmts): Check that
29535         a use is inside the basic block or loop before accessing its vect info.
29536
29537 2012-01-01  Jan Hubicka  <jhjh@suse.cz>
29538
29539         PR rtl-optimization/51069
29540         * cfgloopmanip.c (remove_path): Removing path making irreducible
29541         region unconditional makes BB part of the region.
29542
29543 2012-01-01  Jakub Jelinek  <jakub@redhat.com>
29544
29545         PR tree-optimization/51683
29546         * tree-ssa-propagate.c (substitute_and_fold): Don't optimize away
29547         calls with side-effects.
29548         * tree-ssa-ccp.c (ccp_fold_stmt): Likewise.
29549 \f
29550 Copyright (C) 2012 Free Software Foundation, Inc.
29551
29552 Copying and distribution of this file, with or without modification,
29553 are permitted in any medium without royalty provided the copyright
29554 notice and this notice are preserved.