rs6000.c (special_handling_values): Add SH_SPLAT.
[gcc.git] / gcc / ChangeLog
1 2014-09-08 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
2
3 * config/rs6000/rs6000.c (special_handling_values): Add SH_SPLAT.
4 (rtx_is_swappable_p): Convert UNSPEC cascading ||s to a switch
5 statement; allow optimization of UNSPEC_VSPLT_DIRECT with special
6 handling SH_SPLAT.
7 (adjust_extract): Fix test for VEC_DUPLICATE case; fix adjustment
8 of extracted lane.
9 (adjust_splat): New function.
10 (handle_special_swappables): Call adjust_splat for SH_SPLAT.
11 (dump_swap_insn_table): Add case for SH_SPLAT.
12
13 2014-09-08 Richard Biener <rguenther@suse.de>
14
15 PR ipa/63196
16 * tree-inline.c (copy_loops): The source loop header should
17 always be non-NULL.
18 (tree_function_versioning): If loops need fixup after removing
19 unreachable blocks fix them.
20 * omp-low.c (simd_clone_adjust): Do not add incr block to
21 loop under construction.
22
23 2014-09-08 Alan Lawrence <alan.lawrence@arm.com>
24
25 * config/aarch64/aarch64-builtins.c
26 (aarch64_types_cmtst_qualifiers, TYPES_TST): Remove as unused.
27
28 2014-09-08 Joseph Myers <joseph@codesourcery.com>
29
30 * config/i386/cygming.h (TF_SIZE): Remove.
31 * config/i386/darwin.h (TF_SIZE): Remove.
32 * config/i386/dragonfly.h (TF_SIZE): Remove.
33 * config/i386/freebsd.h (TF_SIZE): Remove.
34 * config/i386/gnu-user-common.h (TF_SIZE): Remove.
35 * config/i386/openbsdelf.h (TF_SIZE): Remove.
36 * config/i386/sol2.h (TF_SIZE): Remove.
37 * config/ia64/hpux.h (XF_SIZE, TF_SIZE): Remove.
38 * config/ia64/linux.h (TF_SIZE): Remove.
39 * doc/tm.texi.in (SF_SIZE, DF_SIZE, XF_SIZE, TF_SIZE): Remove.
40 * doc/tm.texi: Regenerate.
41 * system.h (SF_SIZE, DF_SIZE, XF_SIZE, TF_SIZE): Poison.
42
43 2014-09-08 Joseph Myers <joseph@codesourcery.com>
44
45 * defaults.h (LARGEST_EXPONENT_IS_NORMAL, ROUND_TOWARDS_ZERO):
46 Remove.
47 * doc/tm.texi.in (ROUND_TOWARDS_ZERO, LARGEST_EXPONENT_IS_NORMAL):
48 Remove.
49 * doc/tm.texi: Regenerate.
50 * system.h (LARGEST_EXPONENT_IS_NORMAL, ROUND_TOWARDS_ZERO):
51 Poison.
52 * config/arm/arm.h (LARGEST_EXPONENT_IS_NORMAL): Remove.
53 * config/cris/cris.h (__make_dp): Remove.
54
55 2014-09-08 Richard Biener <rguenther@suse.de>
56
57 PR bootstrap/63204
58 * cfgloop.c (mark_loop_for_removal): Track former header
59 unconditionally.
60 * cfgloop.h (struct loop): Add former_header member unconditionally.
61 * loop-init.c (fix_loop_structure): Enable bogus loop removal
62 diagnostic unconditionally.
63
64 2014-09-07 Venkataramanan Kumar <venkataramanan.kumar@linaro.org>
65
66 PR target/63190
67 * config/aarch64/aarch64.md (stack_protect_test_<mode>) Add register
68 constraint for operand0 and remove write only modifier from operand3.
69
70 2014-09-07 Richard Sandiford <rdsandiford@googlemail.com>
71
72 PR rtl-optimization/62208
73 * simplify-rtx.c (simplify_relational_operation_1): Use CONST0_RTX
74 rather than const0_rtx in eq/ne-xor simplifications.
75
76 2014-09-06 Joern Rennecke <joern.rennecke@embecosm.com>
77
78 * config/arc/arc.c (arc_print_operand): Fix format for HOST_WIDE_INT.
79 (arc_output_mi_thunk): Likewise.
80
81 * config/arc/arc.c (arc_predicate_delay_insns): Swap comparison
82 arguments to silence bogus warning.
83
84 2014-09-06 Richard Sandiford <rdsandiford@googlemail.com>
85
86 PR middle-end/63171
87 * rtlanal.c (tls_referenced_p): Don't skip constant subrtxes.
88
89 2014-09-06 Tom de Vries <tom@codesourcery.com>
90
91 * ira-costs.c (ira_tune_allocno_costs): Don't conditionalize
92 IRA_HARD_REGNO_ADD_COST_MULTIPLIER code on
93 ALLOCNO_CROSSED_CALLS_CLOBBERED_REGS.
94
95 2014-09-05 Dominique Dhumieres <dominiq@lps.ens.fr>
96
97 PR target/63188
98 * config/darwin.h (INIT_SECTION_ASM_OP): Define to "".
99 * config/pa/pa64-hpux.h (INIT_SECTION_ASM_OP): Likewise.
100
101 2014-09-05 Easwaran Raman <eraman@google.com>
102
103 PR rtl-optimization/62146
104 * ifcvt.c (dead_or_predicable): Make removal of REG_EQUAL note of
105 hoisted instruction unconditional.
106
107 2014-09-05 Segher Boessenkool <segher@kernel.crashing.org>
108
109 PR target/63187
110 * config/rs6000/rs6000.md (*and<mode>3_imm_dot, *and<mode>3_imm_dot2):
111 Do not allow any_mask_operand for operands[2].
112 (*and<mode>3_imm_mask_dot, *and<mode>3_imm_mask_dot2): New.
113
114 2014-09-05 David Malcolm <dmalcolm@redhat.com>
115
116 * config/arc/arc.c (arc_print_operand): Use insn method of
117 final_sequence for type-safety.
118 * config/bfin/bfin.c (bfin_hardware_loop): Strengthen param
119 "insn" from rtx to rtx_insn *.
120 * config/frv/frv.c (frv_print_operand_jump_hint): Likewise.
121 * config/mn10300/mn10300.c (mn10300_scan_for_setlb_lcc):
122 Likewise for locals "branch", "label".
123 * config/h8300/h8300.c (same_cmp_preceding_p): Likewise for
124 locals "i1", "i2". Use NULL rather than NULL_RTX in comparisons.
125 (same_cmp_following_p): Likewise for locals "i2", "i3".
126 * config/sh/sh_optimize_sett_clrt.cc
127 (sh_optimize_sett_clrt::sh_cbranch_ccreg_value): Likewise for
128 param "cbranch_insn".
129 * function.c (convert_jumps_to_returns): Likewis for local "jump".
130 * ifcvt.c (cond_exec_get_condition): Likewise for param "jump".
131 * jump.c (simplejump_p): Strengthen param "insn" from const_rtx to
132 const rtx_insn *.
133 (condjump_p): Likewise.
134 (condjump_in_parallel_p): Likewise.
135 (pc_set): Likewise.
136 (any_uncondjump_p): Likewise.
137 (any_condjump_p): Likewise.
138 (condjump_label): Likewise.
139 (returnjump_p): Strengthen param "insn" from rtx to
140 const rtx_insn *.
141 (onlyjump_p): Strengthen param "insn" from const_rtx to
142 const rtx_insn *.
143 (jump_to_label_p): Likewise.
144 (invert_jump_1): Strengthen param "jump" from rtx to rtx_insn *.
145 (invert_jump): Likewise.
146 * reorg.c (simplejump_or_return_p): Add checked cast when calling
147 simplejump_p.
148 (get_jump_flags): Strengthen param "insn" from rtx to
149 const rtx_insn *.
150 (get_branch_condition): Likewise.
151 (condition_dominates_p): Likewise.
152 (make_return_insns): Move declaration of local "pat" earlier, to
153 after we've handled NONJUMP_INSN_P and non-sequences, using its
154 methods to simplify the code and for type-safety.
155 * rtl.h (find_constant_src): Strengthen param from const_rtx to
156 const rtx_insn *.
157 (jump_to_label_p): Strengthen param from rtx to const rtx_insn *.
158 (condjump_p): Strengthen param from const_rtx to
159 const rtx_insn *.
160 (any_condjump_p): Likewise.
161 (any_uncondjump_p): Likewise.
162 (pc_set): Likewise.
163 (condjump_label): Likewise.
164 (simplejump_p): Likewise.
165 (returnjump_p): Likewise.
166 (onlyjump_p): Likewise.
167 (invert_jump_1): Strengthen param 1 from rtx to rtx_insn *.
168 (invert_jump): Likewise.
169 (condjump_in_parallel_p): Strengthen param from const_rtx to
170 const rtx_insn *.
171 * rtlanal.c (find_constant_src): Strengthen param from const_rtx
172 to const rtx_insn *.
173 * sel-sched-ir.c (fallthru_bb_of_jump): Strengthen param from rtx
174 to const rtx_insn *.
175 * sel-sched-ir.h (fallthru_bb_of_jump): Likewise.
176
177 2014-09-05 David Malcolm <dmalcolm@redhat.com>
178
179 * reorg.c (relax_delay_slots): Move declaration of "trial_seq"
180 above the conditional, and convert the check on GET_CODE to a
181 dyn_cast, so that "trial_seq" is available as an rtx_sequence * in
182 the conditional. Simplify the conditional by using methods of
183 "trial_seq".
184
185 2014-09-05 David Malcolm <dmalcolm@redhat.com>
186
187 * haifa-sched.c (check_clobbered_conditions): Strengthen local
188 "link" from rtx to rtx_insn_list *, and use its methods for
189 clarity and type-safety.
190 (toggle_cancelled_flags): Likewise.
191 (restore_last_backtrack_point): Likewise.
192 (queue_to_ready): Use insn method of "link" in one place.
193 (schedule_block): Strengthen local "link" from rtx to
194 rtx_insn_list *, and use its methods for clarity and type-safety.
195
196 2014-09-05 David Malcolm <dmalcolm@redhat.com>
197
198 * sched-deps.c (sched_get_condition_with_rev_uncached): Strengthen
199 param "insn" from const_rtx to const rtx_insn *.
200 (sched_get_reverse_condition_uncached): Likewise.
201 (sched_get_condition_with_rev): Likewise.
202 (sched_has_condition_p): Likewise.
203 (sched_insns_conditions_mutex_p): Likewise for both params.
204 (sched_insn_is_legitimate_for_speculation_p): Likewise for param
205 "insn"; conver use of CONST_CAST_RTX to CONST_CAST_RTX_INSN.
206 (setup_insn_reg_uses): Move local "list" to be more tightly
207 scoped, strengthening it from an rtx to an rtx_insn_list *. Use
208 its methods for clarity and type-safety.
209 (sched_analyze_1): Strengthen local "pending" from rtx to
210 rtx_insn_list *, and local "pending_mem" from rtx to
211 rtx_expr_list *. Use methods of each for clarity and type-safety.
212 (sched_analyze_2): Likewise.
213 (sched_analyze_insn): Likewise.
214
215 * sched-int.h (sched_get_reverse_condition_uncached): Strengthen
216 param from const_rtx to const rtx_insn *.
217 (sched_insns_conditions_mutex_p): Likewise for both params.
218 (sched_insn_is_legitimate_for_speculation_p): Likewise for first
219 param.
220
221 * system.h (CONST_CAST_RTX_INSN): New macro.
222
223 2014-09-05 David Malcolm <dmalcolm@redhat.com>
224
225 * recog.c (peep2_attempt): Strengthen return type from rtx to
226 rtx_insn *.
227 (peep2_update_life): Likewise for params "last", "prev", removing
228 a checked cast made redundant by this.
229 (peephole2_optimize): Likewise for local "last".
230
231 2014-09-05 David Malcolm <dmalcolm@redhat.com>
232
233 * basic-block.h (set_block_for_insn): Eliminate this macro in
234 favor of...
235 * rtl.h (set_block_for_insn): New inline function, imposing the
236 requirement that the "insn" param is an rtx_insn *.
237
238 2014-09-05 David Malcolm <dmalcolm@redhat.com>
239
240 * caller-save.c (setup_save_areas): Strengthen local "insn" from
241 rtx to rtx_insn *.
242 * final.c (get_call_reg_set_usage): Likewise for first param,
243 eliminating a checked cast.
244 * regs.h (get_call_reg_set_usage): Likewise for first param.
245 * resource.c (mark_set_resources): Introduce local rtx_call_insn *
246 "call_insn" for the case of a MARK_SRC_DEST_CALL via a checked
247 cast, replacing references to "x" with "call_insn" where
248 appropriate.
249 (mark_target_live_regs): Strengthen local "real_insn" from rtx to
250 rtx_insn *, adding a checked cast.
251
252 2014-09-05 David Malcolm <dmalcolm@redhat.com>
253
254 * output.h (final_scan_insn): Strengthen first param from rtx to
255 rtx_insn *.
256
257 * final.c (final_scan_insn): Likewise, renaming it back from
258 "uncast_insn" to "insn", eliminating the checked cast.
259
260 * config/h8300/h8300.md (define_insn "jump"): Replace local rtx
261 "vec" with an rtx_sequence * "seq", taking a copy of
262 "final_sequence", and using methods of "seq" for clarity, and for
263 type-safety in the calls to final_scan_insn.
264 * config/mips/mips.c (mips_output_conditional_branch): Use methods
265 of "final_sequence" for clarity, and for type-safety in the call to
266 final_scan_insn.
267 * config/sh/sh.c (print_slot): Strengthen param from rtx to
268 rtx_sequence * and rename from "insn" to "seq".
269
270 2014-09-05 David Malcolm <dmalcolm@redhat.com>
271
272 * jump.c (delete_related_insns): Introduce a new local "table" by
273 replacing JUMP_TABLE_DATA_P with a dyn_cast, then use the
274 get_labels method of "table" to simplify access to the labels in
275 the jump table.
276
277 2014-09-05 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
278
279 * config/arm/cortex-a53.md (cortex_a53_fpalu): Add f_rints, f_rintd,
280 f_minmaxs, f_minmaxd types.
281
282 2014-09-05 Richard Biener <rguenther@suse.de>
283
284 * cfgloop.c (mark_loop_for_removal): Record former header
285 when ENABLE_CHECKING.
286 * cfgloop.h (strut loop): Add former_header member when
287 ENABLE_CHECKING.
288 * loop-init.c (fix_loop_structure): Sanity check loops
289 marked for removal if they re-appeared.
290
291 2014-09-05 Alan Lawrence <alan.lawrence@arm.com>
292
293 * config/aarch64/arm_neon.h (int32x1_t, int16x1_t, int8x1_t,
294 uint32x1_t, uint16x1_t, uint8x1_t): Remove typedefs.
295
296 (vqabsb_s8, vqabsh_s16, vqabss_s32, vqaddb_s8, vqaddh_s16, vqadds_s32,
297 vqaddb_u8, vqaddh_u16, vqadds_u32, vqdmlalh_s16, vqdmlalh_lane_s16,
298 vqdmlals_s32, vqdmlslh_s16, vqdmlslh_lane_s16, vqdmlsls_s32,
299 vqdmulhh_s16, vqdmulhh_lane_s16, vqdmulhs_s32, vqdmulhs_lane_s32,
300 vqdmullh_s16, vqdmullh_lane_s16, vqdmulls_s32, vqdmulls_lane_s32,
301 vqmovnh_s16, vqmovns_s32, vqmovnd_s64, vqmovnh_u16, vqmovns_u32,
302 vqmovnd_u64, vqmovunh_s16, vqmovuns_s32, vqmovund_s64, vqnegb_s8,
303 vqnegh_s16, vqnegs_s32, vqrdmulhh_s16, vqrdmulhh_lane_s16,
304 vqrdmulhs_s32, vqrdmulhs_lane_s32, vqrshlb_s8, vqrshlh_s16,
305 vqrshls_s32, vqrshlb_u8, vqrshlh_u16, vqrshls_u32, vqrshrnh_n_s16,
306 vqrshrns_n_s32, vqrshrnd_n_s64, vqrshrnh_n_u16, vqrshrns_n_u32,
307 vqrshrnd_n_u64, vqrshrunh_n_s16, vqrshruns_n_s32, vqrshrund_n_s64,
308 vqshlb_s8, vqshlh_s16, vqshls_s32, vqshlb_u8, vqshlh_u16, vqshls_u32,
309 vqshlb_n_s8, vqshlh_n_s16, vqshls_n_s32, vqshlb_n_u8, vqshlh_n_u16,
310 vqshls_n_u32, vqshlub_n_s8, vqshluh_n_s16, vqshlus_n_s32,
311 vqshrnh_n_s16, vqshrns_n_s32, vqshrnd_n_s64, vqshrnh_n_u16,
312 vqshrns_n_u32, vqshrnd_n_u64, vqshrunh_n_s16, vqshruns_n_s32,
313 vqshrund_n_s64, vqsubb_s8, vqsubh_s16, vqsubs_s32, vqsubb_u8,
314 vqsubh_u16, vqsubs_u32, vsqaddb_u8, vsqaddh_u16, vsqadds_u32,
315 vuqaddb_s8, vuqaddh_s16, vuqadds_s32): Replace all int{32,16,8}x1_t
316 with int{32,16,8}_t.
317
318 2014-09-05 Alan Lawrence <alan.lawrence@arm.com>
319
320 * config/aarch64/arm_neon.h (__GET_HIGH): New macro.
321 (vget_high_f32, vget_high_f64, vget_high_p8, vget_high_p16,
322 vget_high_s8, vget_high_s16, vget_high_s32, vget_high_s64,
323 vget_high_u8, vget_high_u16, vget_high_u32, vget_high_u64):
324 Remove temporary __asm__ and reimplement.
325
326 2014-09-05 Alan Lawrence <alan.lawrence@arm.com>
327
328 * config/aarch64/aarch64-builtins.c (aarch64_fold_builtin): Remove code
329 handling cmge, cmgt, cmeq, cmtst.
330
331 * config/aarch64/aarch64-simd-builtins.def (cmeq, cmge, cmgt, cmle,
332 cmlt, cmgeu, cmgtu, cmtst): Remove.
333
334 * config/aarch64/arm_neon.h (vceq_*, vceqq_*, vceqz_*, vceqzq_*,
335 vcge_*, vcgeq_*, vcgez_*, vcgezq_*, vcgt_*, vcgtq_*, vcgtz_*,
336 vcgtzq_*, vcle_*, vcleq_*, vclez_*, vclezq_*, vclt_*, vcltq_*,
337 vcltz_*, vcltzq_*, vtst_*, vtstq_*): Use gcc vector extensions.
338
339 2014-09-05 Alan Lawrence <alan.lawrence@arm.com>
340
341 * config/aarch64/aarch64-builtins.c (aarch64_types_cmtst_qualifiers,
342 TYPES_TST): Define.
343 (aarch64_fold_builtin): Update pattern for cmtst.
344
345 * config/aarch64/aarch64-protos.h (aarch64_const_vec_all_same_int_p):
346 Declare.
347
348 * config/aarch64/aarch64-simd-builtins.def (cmtst): Update qualifiers.
349
350 * config/aarch64/aarch64-simd.md (aarch64_vcond_internal<mode><mode>):
351 Switch operands, separate out more cases, refactor.
352
353 (aarch64_cmtst<mode>): Rewrite pattern to match (plus ... -1).
354
355 * config/aarch64.c (aarch64_const_vec_all_same_int_p): Take single
356 argument; rename old version to...
357 (aarch64_const_vec_all_same_in_range_p): ...this.
358 (aarch64_print_operand, aarch64_simd_shift_imm_p): Follow renaming.
359
360 * config/aarch64/predicates.md (aarch64_simd_imm_minus_one): Define.
361
362 2014-09-05 Alan Lawrence <alan.lawrence@arm.com>
363
364 * config/aarch64/aarch64-builtins.c (enum aarch64_type_qualifiers):
365 Remove qualifier_const_pointer, update comment.
366
367 2014-09-05 Alan Lawrence <alan.lawrence@arm.com>
368
369 * config/aarch64/aarch64.md (adddi3_aarch64): set type to neon_add.
370
371 2014-09-05 Alan Lawrence <alan.lawrence@arm.com>
372
373 * config/aarch64/aarch64-builtins.c (aarch64_simd_expand_args): Replace
374 varargs with pointer parameter.
375 (aarch64_simd_expand_builtin): pass pointer into previous.
376
377 2014-09-05 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
378
379 * config/arm/cortex-a53.md (cortex_a53_alu_shift): Add alu_ext,
380 alus_ext.
381
382 2014-09-05 Alan Lawrence <alan.lawrence@arm.com>
383
384 * config/aarch64/aarch64-simd.md (aarch64_rbit<mode>): New pattern.
385 * config/aarch64/aarch64-simd-builtins.def (rbit): New builtin.
386 * config/aarch64/arm_neon.h (vrbit_s8, vrbit_u8, vrbitq_s8, vrbitq_u8):
387 Replace temporary asm with call to builtin.
388 (vrbit_p8, vrbitq_p8): New functions.
389
390 2014-09-05 Richard Biener <rguenther@suse.de>
391
392 * cfgloop.c (mark_loop_for_removal): New function.
393 * cfgloop.h (mark_loop_for_removal): Declare.
394 * cfghooks.c (delete_basic_block): Use mark_loop_for_removal.
395 (merge_blocks): Likewise.
396 (duplicate_block): Likewise.
397 * except.c (sjlj_emit_dispatch_table): Likewise.
398 * tree-eh.c (cleanup_empty_eh_merge_phis): Likewise.
399 * tree-ssa-threadupdate.c (ssa_redirect_edges): Likewise.
400 (thread_through_loop_header): Likewise.
401
402 2014-09-05 Richard Biener <rguenther@suse.de>
403
404 PR middle-end/63148
405 * fold-const.c (try_move_mult_to_index): Remove.
406 (fold_binary_loc): Do not call it.
407 * tree-data-ref.c (dr_analyze_indices): Strip conversions
408 from the base object again.
409
410 2014-09-05 James Greenhalgh <james.greenhalgh@arm.com>
411
412 * config/aarch64/aarch64.md (sibcall_value_insn): Give operand 1
413 DImode.
414
415 2014-09-05 Bin Cheng <bin.cheng@arm.com>
416
417 PR target/55701
418 * config/arm/arm.md (setmem): New pattern.
419 * config/arm/arm-protos.h (struct tune_params): New fields.
420 (arm_gen_setmem): New prototype.
421 * config/arm/arm.c (arm_slowmul_tune): Initialize new fields.
422 (arm_fastmul_tune, arm_strongarm_tune, arm_xscale_tune): Ditto.
423 (arm_9e_tune, arm_v6t2_tune, arm_cortex_tune): Ditto.
424 (arm_cortex_a8_tune, arm_cortex_a7_tune): Ditto.
425 (arm_cortex_a15_tune, arm_cortex_a53_tune): Ditto.
426 (arm_cortex_a57_tune, arm_cortex_a5_tune): Ditto.
427 (arm_cortex_a9_tune, arm_cortex_a12_tune): Ditto.
428 (arm_v7m_tune, arm_v6m_tune, arm_fa726te_tune): Ditto.
429 (arm_const_inline_cost): New function.
430 (arm_block_set_max_insns): New function.
431 (arm_block_set_non_vect_profit_p): New function.
432 (arm_block_set_vect_profit_p): New function.
433 (arm_block_set_unaligned_vect): New function.
434 (arm_block_set_aligned_vect): New function.
435 (arm_block_set_unaligned_non_vect): New function.
436 (arm_block_set_aligned_non_vect): New function.
437 (arm_block_set_vect, arm_gen_setmem): New functions.
438
439 2014-09-05 Bin Cheng <bin.cheng@arm.com>
440
441 * config/arm/arm.md (arm_movqi_insn): Use Uh instead of m constraint.
442
443 2014-09-05 Bin Cheng <bin.cheng@arm.com>
444
445 * config/arm/arm.c (output_move_neon): Handle REG explicitly.
446
447 2014-09-04 Trevor Saunders <tsaunders@mozilla.com>
448
449 * valtrack.c (dead_debug_insert_temp): Take an rtx_insn * instead of
450 an rtx.
451 * valtrack.h: Adjust.
452
453 2014-09-04 Trevor Saunders <tsaunders@mozilla.com>
454
455 * emit-rtl.c (emit_insn_before_noloc): Take an rtx_insn * instead of
456 an rtx.
457 (emit_jump_insn_before_noloc): Likewise.
458 (emit_call_insn_before_noloc): Likewise.
459 (emit_label_before): Likewise.
460 (emit_label_after): Likewise.
461 (emit_insn_before_setloc): Likewise.
462 (emit_jump_insn_before_setloc): Likewise.
463 (emit_call_insn_before_setloc): Likewise.
464 (emit_call_insn_before): Likewise.
465 * rtl.h: Adjust.
466
467 2014-09-05 David Malcolm <dmalcolm@redhat.com>
468
469 * cse.c (cse_insn): Strengthen local "new_rtx" from rtx to
470 rtx_insn *, eliminating a checked cast.
471
472 2014-09-05 David Malcolm <dmalcolm@redhat.com>
473
474 * rtl.h (modified_between_p): Strengthen params 2 and 3 from
475 const_rtx to const rtx_insn *.
476 * rtlanal.c (modified_between_p): Likewise, eliminating a checked
477 cast.
478
479 2014-09-05 David Malcolm <dmalcolm@redhat.com>
480
481 * emit-rtl.c (try_split): Update NULL_RTX to NULL in call to
482 fixup_args_size_notes.
483 * expr.c (fixup_args_size_notes): Strengthen first two params from
484 rtx to rtx_insn *, eliminating a checked cast.
485 * rtl.h (fixup_args_size_notes): Strengthen first two params from
486 rtx to rtx_insn *.
487
488 2014-09-05 David Malcolm <dmalcolm@redhat.com>
489
490 * haifa-sched.c (get_ready_element): Strengthen return type from
491 rtx to rtx_insn *.
492 * sched-int.h (get_ready_element): Likewise.
493
494 2014-09-04 Segher Boessenkool <segher@kernel.crashing.org>
495
496 PR target/63165
497 * config/rs6000/rs6000.md (floatsi<mode>2_lfiwax_mem): Use
498 indexed_or_indirect_operand instead of memory_operand.
499 (floatsi<mode>2_lfiwzx_mem): Ditto.
500
501 2014-09-04 Trevor Saunders <tsaunders@mozilla.com>
502
503 * config/bfin/bfin.c, config/c6x/c6x.c, config/m32c/m32c.c,
504 config/mn10300/mn10300.c, config/s390/s390.c, config/sh/sh.c,
505 ifcvt.c, reorg.c: Change types of variables from rtx to rtx_insn *.
506
507 2014-09-04 Trevor Saunders <tsaunders@mozilla.com>
508
509 * emit-rtl.c (get_first_nonnote_insn): Return rtx_insn * instead of
510 rtx.
511 (get_last_nonnote_insn): Likewise.
512 (next_nonnote_insn_bb): Take rtx_insn * instead of rtx.
513 * resource.c (find_basic_block): Likewise.
514 * rtl.h: Adjust.
515 * rtlanal.c (keep_with_call_p): Take const rtx_insn * instead of
516 const_rtx.
517
518 2014-09-04 David Malcolm <dmalcolm@redhat.com>
519
520 * genattr.c (main): Within the prototype of insn_latency written
521 out to insn-attr.h, strengthen both params from rtx to rtx_insn *.
522 * genautomata.c (output_internal_maximal_insn_latency_func):
523 Within the implementation of insn_latency written out to
524 insn-automata.c, strengthen both params from rtx to rtx_insn *,
525 eliminating a pair of checked casts.
526
527 2014-09-04 David Malcolm <dmalcolm@redhat.com>
528
529 * jump.c (eh_returnjump_p): Strengthen param "insn" from rtx to
530 rtx_insn *.
531
532 * rtl.h (eh_returnjump_p): Likewise.
533
534 2014-09-04 Aldy Hernandez <aldyh@redhat.com>
535
536 * Makefile.in (TAGS): Handle constructs in timevar.def.
537
538 2014-09-04 Guozhi Wei <carrot@google.com>
539
540 PR target/62040
541 * config/aarch64/iterators.md (VQ_NO2E, VQ_2E): New iterators.
542 * config/aarch64/aarch64-simd.md (move_lo_quad_internal_<mode>): Split
543 it into two patterns.
544 (move_lo_quad_internal_be_<mode>): Likewise.
545
546 2014-09-04 Manuel López-Ibáñez <manu@gcc.gnu.org>
547
548 * doc/options.texi: Document that Var and Init are required if CPP
549 is given.
550 * optc-gen.awk: Require Var and Init if CPP is given.
551 * common.opt (Wpedantic): Use Init.
552
553 2014-09-04 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
554
555 * config/rs6000/rs6000.c (special_handling_values): Add
556 SH_EXTRACT.
557 (rtx_is_swappable_p): Look for patterns with a VEC_SELECT, perhaps
558 wrapped in a VEC_DUPLICATE, representing an extract. Mark these
559 as swappable with special handling SH_EXTRACT. Remove
560 UNSPEC_VSX_XXSPLTW from the list of disallowed unspecs for the
561 optimization.
562 (adjust_extract): New function.
563 (handle_special_swappables): Add default to case statement; add
564 case for SH_EXTRACT that calls adjust_extract.
565 (dump_swap_insn_table): Handle SH_EXTRACT.
566
567 2014-09-04 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
568
569 * config/rs6000/vsx.md (*vsx_extract_<mode>_load): Always match
570 selection of 0th memory doubleword, regardless of endianness.
571
572 2014-09-04 Jan-Benedict Glaw <jbglaw@lug-owl.de>
573
574 * config/rx/rx.h (HARD_REGNO_MODE_OK): Add braces.
575
576 2014-09-04 Alan Modra <amodra@gmail.com>
577
578 PR debug/60655
579 * dwarf2out.c (mem_loc_descriptor <PLUS>): Return NULL if addend
580 can't be output.
581
582 2014-09-03 Matthew Fortune <matthew.fortune@imgtec.com>
583
584 * target.def (TARGET_DWARF_FRAME_REG_MODE): New target hook.
585 * targhooks.c (default_dwarf_frame_reg_mode): New function.
586 * targhooks.h (default_dwarf_frame_reg_mode): New prototype.
587 * doc/tm.texi.in (TARGET_DWARF_FRAME_REG_MODE): Document.
588 * doc/tm.texi: Regenerate.
589 * dwarf2cfi.c (expand_builtin_init_dwarf_reg_sizes): Abstract mode
590 selection logic to default_dwarf_frame_reg_mode.
591
592 2014-09-03 Marek Polacek <polacek@redhat.com>
593
594 * doc/invoke.texi: Document that -Wlogical-not-parentheses is enabled
595 by -Wall.
596
597 2014-09-03 Richard Sandiford <rdsandiford@googlemail.com>
598
599 * doc/rtl.texi (RTX_AUTOINC): Document that the first operand is
600 the automodified register.
601
602 2014-09-03 Richard Sandiford <rdsandiford@googlemail.com>
603
604 * output.h (get_some_local_dynamic_name): Declare.
605 * final.c (some_local_dynamic_name): New variable.
606 (get_some_local_dynamic_name): New function.
607 (final_end_function): Clear some_local_dynamic_name.
608 * config/alpha/alpha.c (machine_function): Remove some_ld_name.
609 (get_some_local_dynamic_name, get_some_local_dynamic_name_1): Delete.
610 (print_operand): Report an error if '%&' is used inappropriately.
611 * config/i386/i386.c (get_some_local_dynamic_name): Delete.
612 (get_some_local_dynamic_name_1): Delete.
613 * config/rs6000/rs6000.c (machine_function): Remove some_ld_name.
614 (rs6000_get_some_local_dynamic_name): Delete.
615 (rs6000_get_some_local_dynamic_name_1): Delete.
616 (print_operand): Report an error if '%&' is used inappropriately.
617 * config/s390/s390.c (machine_function): Remove some_ld_name.
618 (get_some_local_dynamic_name, get_some_local_dynamic_name_1): Delete.
619 (print_operand): Assert that get_some_local_dynamic_name is nonnull.
620 * config/sparc/sparc.c: Include rtl-iter.h.
621 (machine_function): Remove some_ld_name.
622 (sparc_print_operand): Report an error if '%&' is used inappropriately.
623 (get_some_local_dynamic_name, get_some_local_dynamic_name_1): Delete.
624
625 2014-09-03 Richard Henderson <rth@redhat.com>
626
627 * config/aarch64/aarch64.c (aarch64_popwb_single_reg): Remove.
628 (aarch64_popwb_pair_reg): Remove.
629 (aarch64_set_frame_expr): Remove.
630 (aarch64_restore_callee_saves): Add CFI_OPS argument; fill it with
631 the restore ops performed by the insns generated.
632 (aarch64_expand_epilogue): Attach CFI_OPS to the stack deallocation
633 insn. Perform the calls_eh_return addition later; do not attempt to
634 preserve the CFA in that case. Don't use aarch64_set_frame_expr.
635 (aarch64_expand_prologue): Use REG_CFA_ADJUST_CFA directly, or no
636 special markup at all. Load cfun->machine->frame.hard_fp_offset
637 into a local variable.
638 (aarch64_frame_pointer_required): Don't check calls_alloca.
639
640 2014-09-03 Richard Biener <rguenther@suse.de>
641
642 * opts.c (default_options_optimization): Adjust
643 max-combine-insns to 2 for -Og.
644
645 2014-09-03 Martin Jambor <mjambor@suse.cz>
646
647 PR ipa/62015
648 * ipa-cp.c (intersect_aggregates_with_edge): Handle impermissible
649 pass-trough jump functions correctly.
650
651 2014-09-03 Martin Jambor <mjambor@suse.cz>
652
653 PR ipa/61986
654 * ipa-cp.c (find_aggregate_values_for_callers_subset): Chain
655 created replacements in ascending order of offsets.
656 (known_aggs_to_agg_replacement_list): Likewise.
657
658 2014-09-03 Martin Liska <mliska@suse.cz>
659
660 * tree-ssa-sccvn.c (vn_reference_lookup_call): default (NULL) value
661 is set to set uninitialized value for vnresult.
662
663 2014-09-03 Chung-Ju Wu <jasonwucj@gmail.com>
664
665 * config/nds32/nds32.c (nds32_must_pass_in_stack): New implementation
666 for TARGET_MUST_PASS_IN_STACK.
667
668 2014-09-03 Chung-Ju Wu <jasonwucj@gmail.com>
669
670 * config/nds32/nds32.c (nds32_arg_partial_bytes): New implementation
671 for TARGET_ARG_PARTIAL_BYTES.
672
673 2014-09-03 Chung-Ju Wu <jasonwucj@gmail.com>
674
675 * config/nds32/nds32.c (nds32_expand_prologue): Emit stack push
676 instructions for varargs implementation.
677 (nds32_expand_epilogue): Emit stack adjustment instructions for
678 varargs implementation.
679
680 2014-09-03 Chung-Ju Wu <jasonwucj@gmail.com>
681
682 * config/nds32/nds32.c (nds32_expand_prologue): Suppress fp-as-gp
683 optimization detection.
684
685 2014-09-03 Chung-Ju Wu <jasonwucj@gmail.com>
686
687 * config/nds32/nds32.c (nds32_function_arg): Deal with nameless
688 arguments.
689 (nds32_function_arg_advance): Deal with nameless arguments.
690 * config/nds32/nds32.h (NDS32_ARG_PASS_IN_REG_P): Split it into ...
691 (NDS32_ARG_ENTIRE_IN_GPR_REG_P): ... this one and ...
692 (NDS32_ARG_PARTIAL_IN_GPR_REG_P): ... this one.
693
694 2014-09-03 Richard Biener <rguenther@suse.de>
695
696 * tree-ssa-pre.c (alloc_expression_id): Use quick_grow_cleared.
697 (struct bb_bitmap_sets): Remove deferred member.
698 (BB_DEFERRED): Remove.
699 (defer_or_phi_translate_block): Remove.
700 (compute_antic_aux): Remove deferring of blocks, assert
701 proper iteration order.
702 (compute_antic): Do not set BB_DEFERRED.
703 (eliminate): Allocate el_avail of proper size initially.
704
705 2014-09-03 Chung-Ju Wu <jasonwucj@gmail.com>
706
707 * config/nds32/nds32.h (FIRST_PARM_OFFSET): Set proper location
708 according to the value of crtl->args.pretend_args_size.
709
710 2014-09-03 Chung-Ju Wu <jasonwucj@gmail.com>
711
712 * config/nds32/nds32.c (nds32_compute_stack_frame): Prepare necessary
713 varargs information.
714
715 2014-09-03 Chung-Ju Wu <jasonwucj@gmail.com>
716
717 * config/nds32/nds32.c (nds32_setup_incoming_varargs): New
718 implementation for TARGET_SETUP_INCOMING_VARARGS.
719 (nds32_strict_argument_naming): Refine comment.
720 * config/nds32/nds32.h (TARGET_SOFT_FLOAT, TARGET_HARD_FLOAT):
721 Define for future implementation.
722
723 2014-09-03 Ilya Tocar <ilya.tocar@intel.com>
724
725 * config/i386/adxintrin.h (_subborrow_u32): New.
726 (_addcarry_u32): Ditto.
727 (_subborrow_u64): Ditto.
728 (_addcarry_u64): Ditto.
729 * config/i386/i386.c (ix86_builtins): Add IX86_BUILTIN_SBB32,
730 IX86_BUILTIN_SBB64.
731 (ix86_init_mmx_sse_builtins): Handle __builtin_ia32_sbb_u32,
732 __builtin_ia32_sbb_u64
733
734 2014-09-03 Chung-Ju Wu <jasonwucj@gmail.com>
735
736 * config/nds32/nds32.c (nds32_function_arg): Define and rename some
737 GPR-specific stuff.
738 (nds32_function_arg_advance): Likewise.
739 (nds32_init_cumulative_args): Likewise.
740 * config/nds32/nds32.h (NDS32_MAX_GPR_REGS_FOR_ARGS): Define.
741 (NDS32_FIRST_GPR_REGNUM): Define.
742 (NDS32_LAST_GPR_REGNUM): Define.
743 (NDS32_AVAILABLE_REGNUM_FOR_GPR_ARG): Define.
744 (NDS32_ARG_PASS_IN_REG_P): Use NDS32_MAX_GPR_REGS_FOR_ARGS.
745 (FUNCTION_ARG_REGNO_P): Use NDS32_MAX_GPR_REGS_FOR_ARGS.
746 (machine_function): Use GRP-specific stuff.
747
748 2014-09-03 Chung-Ju Wu <jasonwucj@gmail.com>
749
750 * config/nds32/nds32.c (nds32_expand_prologue): Remove unused variables.
751 (nds32_expand_epilogue): Likewise.
752 (nds32_expand_prologue_v3push): Likewise.
753 (nds32_expand_epilogue_v3pop): Likewise.
754
755 2014-09-03 Chung-Ju Wu <jasonwucj@gmail.com>
756
757 * config/nds32/nds32.c (nds32_compute_stack_frame): Do not use
758 v3push/v3pop for variadic function.
759 * config/nds32/nds32.md (prologue, epilogue): Likewise.
760
761 2014-09-03 Chung-Ju Wu <jasonwucj@gmail.com>
762
763 * config/nds32/nds32-md-auxiliary.c (nds32_output_stack_push):
764 Check rtx for varargs implementation.
765 (nds32_output_stack_pop): Likewise.
766 * config/nds32/nds32-protos.h: Have a rtx argument for
767 nds32_output_stack_push and nds32_output_stack_pop.
768 * config/nds32/nds32.md: Likewise.
769
770 2014-09-03 Chung-Ju Wu <jasonwucj@gmail.com>
771
772 * config/nds32/nds32-isr.c (nds32_isr_function_p): Define new function
773 to check if FUNC is an interrupt service routine.
774 * config/nds32/nds32-protos.h (nds32_isr_function_p): Declaration.
775
776 2014-09-03 Chung-Ju Wu <jasonwucj@gmail.com>
777
778 * config/nds32/nds32.h (machine_function): Add some fields for variadic
779 arguments implementation.
780
781 2014-09-03 Chung-Ju Wu <jasonwucj@gmail.com>
782
783 * config/nds32/nds32-predicates.c
784 (nds32_valid_stack_push_pop): Rename to ...
785 (nds32_valid_stack_push_pop_p): ... this.
786 * config/nds32/nds32-protos.h: Likewise.
787 * config/nds32/predicates.md: Likewise.
788
789 2014-09-03 Chung-Ju Wu <jasonwucj@gmail.com>
790
791 * config/nds32/nds32.c (nds32_gen_stack_v3push): Rename to ...
792 (nds32_emit_stack_v3push): ... this.
793 (nds32_gen_stack_v3pop): Rename to ...
794 (nds32_emit_stack_v3pop): ... this and consider CFA restore
795 information.
796
797 2014-09-03 Chung-Ju Wu <jasonwucj@gmail.com>
798
799 * config/nds32/nds32.c (nds32_gen_stack_push_multiple): Rename to ...
800 (nds32_emit_stack_push_multiple): ... this.
801 (nds32_gen_stack_pop_multiple): Rename to ...
802 (nds32_emit_stack_pop_multiple): ... this and consider CFA restore
803 information.
804
805 2014-09-03 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
806
807 PR target/61078
808 * config/s390/s390.md ("*negdi2_31"): Add s390_split_ok_p check
809 and add a second splitter to handle the remaining cases.
810
811 2014-09-03 Chung-Ju Wu <jasonwucj@gmail.com>
812
813 * config/nds32/nds32.h (PIC_OFFSET_TABLE_REGNUM): Define.
814
815 2014-09-02 Trevor Saunders <tsaunders@mozilla.com>
816
817 * cfgexpand.c (label_rtx_for_bb): Change type to
818 hash_map<basic_block, rtx_code_label *> *.
819 (expand_gimple_basic_block): Adjust.
820 (pass_expand::execute): Likewise.
821
822 2014-09-02 Trevor Saunders <tsaunders@mozilla.com>
823
824 * asan.c, cfgexpand.c, config/alpha/alpha.md, config/arm/arm.c,
825 config/epiphany/epiphany.md, config/h8300/h8300.c, config/i386/i386.md,
826 config/m32r/m32r.c, config/mcore/mcore.md, config/mips/mips.c,
827 config/mips/mips.md, config/nios2/nios2.c, config/pa/pa.c,
828 config/s390/s390.c, config/s390/s390.md, config/sh/sh-mem.cc,
829 config/sh/sh.c, config/sparc/sparc.c, dojump.c, function.c, optabs.c,
830 stmt.c: Assign the result of gen_label_rtx to rtx_code_label * instead
831 of rtx.
832
833 2014-09-02 Trevor Saunders <tsaunders@mozilla.com>
834
835 * alloc-pool.c: Include coretypes.h.
836 * cgraph.h, dbxout.c, dwarf2out.c, except.c, except.h, function.c,
837 function.h, symtab.c, tree-cfg.c, tree-eh.c: Use hash_map and
838 hash_set instead of htab.
839 * ggc-page.c (in_gc): New variable.
840 (ggc_free): Do nothing if a collection is taking place.
841 (ggc_collect): Set in_gc appropriately.
842 * ggc.h (gt_ggc_mx(const char *)): New function.
843 (gt_pch_nx(const char *)): Likewise.
844 (gt_ggc_mx(int)): Likewise.
845 (gt_pch_nx(int)): Likewise.
846 * hash-map.h (hash_map::hash_entry::ggc_mx): Likewise.
847 (hash_map::hash_entry::pch_nx): Likewise.
848 (hash_map::hash_entry::pch_nx_helper): Likewise.
849 (hash_map::hash_map): Adjust.
850 (hash_map::create_ggc): New function.
851 (gt_ggc_mx): Likewise.
852 (gt_pch_nx): Likewise.
853 * hash-set.h (default_hashset_traits::ggc_mx): Likewise.
854 (default_hashset_traits::pch_nx): Likewise.
855 (hash_set::hash_entry::ggc_mx): Likewise.
856 (hash_set::hash_entry::pch_nx): Likewise.
857 (hash_set::hash_entry::pch_nx_helper): Likewise.
858 (hash_set::hash_set): Adjust.
859 (hash_set::create_ggc): New function.
860 (hash_set::elements): Likewise.
861 (gt_ggc_mx): Likewise.
862 (gt_pch_nx): Likewise.
863 * hash-table.h (hash_table::hash_table): Adjust.
864 (hash_table::m_ggc): New member.
865 (hash_table::~hash_table): Adjust.
866 (hash_table::expand): Likewise.
867 (hash_table::empty): Likewise.
868 (gt_ggc_mx): New function.
869 (hashtab_entry_note_pointers): Likewise.
870 (gt_pch_nx): Likewise.
871
872 2014-09-02 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
873
874 * config/rs6000/rs6000-builtin.def (XVCVSXDDP_SCALE): New
875 built-in definition.
876 (XVCVUXDDP_SCALE): Likewise.
877 (XVCVDPSXDS_SCALE): Likewise.
878 (XVCVDPUXDS_SCALE): Likewise.
879 * config/rs6000/rs6000-c.c (altivec_overloaded_builtins): Add
880 entries for VSX_BUILTIN_XVCVSXDDP_SCALE,
881 VSX_BUILTIN_XVCVUXDDP_SCALE, VSX_BUILTIN_XVCVDPSXDS_SCALE, and
882 VSX_BUILTIN_XVCVDPUXDS_SCALE.
883 * config/rs6000/rs6000-protos.h (rs6000_scale_v2df): New
884 prototype.
885 * config/rs6000/rs6000.c (real.h): New include.
886 (rs6000_scale_v2df): New function.
887 * config/rs6000/vsx.md (UNSPEC_VSX_XVCVSXDDP): New unspec.
888 (UNSPEC_VSX_XVCVUXDDP): Likewise.
889 (UNSPEC_VSX_XVCVDPSXDS): Likewise.
890 (UNSPEC_VSX_XVCVDPUXDS): Likewise.
891 (vsx_xvcvsxddp_scale): New define_expand.
892 (vsx_xvcvsxddp): New define_insn.
893 (vsx_xvcvuxddp_scale): New define_expand.
894 (vsx_xvcvuxddp): New define_insn.
895 (vsx_xvcvdpsxds_scale): New define_expand.
896 (vsx_xvcvdpsxds): New define_insn.
897 (vsx_xvcvdpuxds_scale): New define_expand.
898 (vsx_xvcvdpuxds): New define_insn.
899 * doc/extend.texi (vec_ctf): Add new prototypes.
900 (vec_cts): Likewise.
901 (vec_ctu): Likewise.
902 (vec_splat): Likewise.
903 (vec_div): Likewise.
904 (vec_mul): Likewise.
905
906 2014-09-02 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
907
908 PR target/62275
909 * config/arm/neon.md
910 (neon_vcvt<NEON_VCVT:nvrint_variant><su_optab><VCVTF:mode>
911 <v_cmp_result>): New pattern.
912 * config/arm/iterators.md (NEON_VCVT): New int iterator.
913 * config/arm/arm_neon_builtins.def (vcvtav2sf, vcvtav4sf, vcvtauv2sf,
914 vcvtauv4sf, vcvtpv2sf, vcvtpv4sf, vcvtpuv2sf, vcvtpuv4sf, vcvtmv2sf,
915 vcvtmv4sf, vcvtmuv2sf, vcvtmuv4sf): New builtin definitions.
916 * config/arm/arm.c (arm_builtin_vectorized_function): Handle
917 BUILT_IN_LROUNDF, BUILT_IN_LFLOORF, BUILT_IN_LCEILF.
918
919 2014-09-02 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
920
921 PR target/62275
922 * config/arm/iterators.md (FIXUORS): New code iterator.
923 (VCVT): New int iterator.
924 (su_optab): New code attribute.
925 (su): Likewise.
926 * config/arm/vfp.md (l<vrint_pattern><su_optab><mode>si2): New pattern.
927
928 2014-09-02 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
929
930 * config/aarch64/predicates.md (aarch64_comparison_operation):
931 New special predicate.
932 * config/aarch64/aarch64.md (*csinc2<mode>_insn): Use
933 aarch64_comparison_operation instead of matching an operator.
934 Update operand numbers.
935 (csinc3<mode>_insn): Likewise.
936 (*csinv3<mode>_insn): Likewise.
937 (*csneg3<mode>_insn): Likewise.
938 (ffs<mode>2): Update gen_csinc3<mode>_insn callsite.
939 * config/aarch64/aarch64.c (aarch64_get_condition_code):
940 Return -1 instead of aborting on invalid condition codes.
941 (aarch64_print_operand): Update aarch64_get_condition_code callsites
942 to assert that the returned condition code is valid.
943 * config/aarch64/aarch64-protos.h (aarch64_get_condition_code): Export.
944
945 2014-09-02 Aldy Hernandez <aldyh@redhat.com>
946
947 * Makefile.in (TAGS): Handle constructs in common.opt, rtl.def,
948 tree.def, and gimple.def
949
950 2014-09-02 Jakub Jelinek <jakub@redhat.com>
951 Balaji V. Iyer <balaji.v.iyer@intel.com>
952 Igor Zamyatin <igor.zamyatin@intel.com>
953
954 * cilk-builtins.def (__cilkrts_cilk_for_32): New.
955 (__cilkrts_cilk_for_64): Likewise.
956 * cilk-common.c (declare_cilk_for_builtin): New function.
957 (cilk_init_builtins): Declare __cilkrts_cilk_for_32 and
958 __cilkrts_cilk_for_64 bultins.
959 * cilk.h (enum cilk_tree_index): Added CILK_TI_F_LOOP_32 and
960 CILK_TI_F_LOOP_64.
961 (cilk_for_32_fndecl): New define.
962 (cilk_for_64_fndecl): Likewise.
963 * gimple-pretty-print.c (dump_gimple_omp_for): Correct hadling of
964 GF_OMP_FOR_KIND_CILKFOR cases; Added NE_EXPR case.
965 * gimple.h (enum gf_mask): Added GF_OMP_FOR_KIND_CILKFOR; adjusted
966 GF_OMP_FOR_KIND_MASK, GF_OMP_FOR_SIMD, GF_OMP_FOR_COMBINED,
967 GF_OMP_FOR_COMBINED_INTO.
968 * gimplify.c (gimplify_scan_omp_clauses): Added
969 OMP_CLAUSE__CILK_FOR_COUNT_ case.
970 (gimplify_adjust_omp_clauses): Ditto.
971 (gimplify_omp_for): Added CILK_FOR case.
972 (gimplify_expr): Ditto.
973 * omp-low.c: Include cilk.h.
974 (extract_omp_for_data): Set appropriate kind for
975 GF_OMP_FOR_KIND_CILKFOR; added check for GF_OMP_FOR_KIND_CILKFOR.
976 (scan_sharing_clauses): Added OMP_CLAUSE__CILK_FOR_COUNT_ cases.
977 (create_omp_child_function_name): Added second argument to handle
978 cilk_for case.
979 (cilk_for_check_loop_diff_type): New function.
980 (expand_cilk_for_call): Likewise.
981 (expand_cilk_for): Likewise.
982 (create_omp_child_function): Set cilk_for_count; handle the cases when
983 it is true; call create_omp_child_function_name with second argument.
984 (expand_omp_taskreg): Set is_cilk_for and handle cases when it's true.
985 (expand_omp_for): Handle case of GF_OMP_FOR_KIND_CILKFOR.
986 * tree-core.h (omp_clause_code): Added OMP_CLAUSE__CILK_FOR_COUNT_.
987 * tree-nested.c (convert_nonlocal_omp_clauses): Added
988 OMP_CLAUSE__CILK_FOR_COUNT_ case.
989 (convert_local_omp_clauses): Ditto.
990 * tree-pretty-print.c (dump_omp_clause): Added
991 OMP_CLAUSE__CILK_FOR_COUNT_ and OMP_CLAUSE_SCHEDULE_CILKFOR cases.
992 (dump_generic_node): Added CILK_FOR case.
993 * tree.c (omp_clause_num_ops): New element
994 OMP_CLAUSE__CILK_FOR_COUNT_ (1).
995 (omp_clause_code_name): New element _Cilk_for_count_.
996 (walk_tree_1): Added OMP_CLAUSE__CILK_FOR_COUNT_ case.
997 * tree.def: Add tree code for CILK_FOR.
998
999 2014-09-02 Segher Boessenkool <segher@kernel.crashing.org>
1000
1001 * config/rs6000/40x.md (ppc403-integer): Move "exts" to "no dot".
1002 (ppc403-compare): Add "exts with dot" case.
1003 * config/rs6000/440.md (ppc440-integer, ppc440-compare): As above.
1004 * config/rs6000/476.md (ppc476-simple-integer, ppc476-compare): Ditto.
1005 * config/rs6000/601.md (ppc601-integer, ppc601-compare): Ditto.
1006 * config/rs6000/603.md (ppc603-integer, ppc603-compare): Ditto.
1007 * config/rs6000/6xx.md (ppc604-integer, ppc604-compare): Ditto.
1008 * config/rs6000/7450.md (ppc7450-integer, ppc7450-compare): Ditto.
1009 * config/rs6000/7xx.md (ppc750-integer, ppc750-compare): Ditto.
1010 * config/rs6000/cell.md (cell-integer, cell-fast-cmp,
1011 cell-cmp-microcoded): Similarly.
1012 * config/rs6000/e300c2c3.md (ppce300c3_iu, ppce300c3_cmp): As before.
1013 * config/rs6000/e500mc64.md (e500mc64_su, e500mc64_su2): Ditto.
1014 * config/rs6000/e5500.md (e5500_sfx, e5500_sfx2): Ditto.
1015 * config/rs6000/e6500.md (e6500_sfx, e6500_sfx2): Ditto.
1016 * config/rs6000/mpc.md (mpccore-integer, mpccore-compare): Ditto.
1017 * config/rs6000/power4.md (power4-integer, power4-compare): Ditto.
1018 * config/rs6000/power5.md (power5-integer, power5-compare): Ditto.
1019 * config/rs6000/power6.md (power6-exts): Add "no dot" condition.
1020 (power6-compare): Add "exts with dot" case.
1021 * config/rs6000/power7.md (power7-integer, power7-compare): As before.
1022 * config/rs6000/power8.md (power8-1cyc, power8-compare): Ditto.
1023 * config/rs6000/rs64.md (rs64a-integer, rs64a-compare): Ditto.
1024
1025 * config/rs6000/predicates.md (lwa_operand): Don't allow memory
1026 if avoiding Cell microcode.
1027 * config/rs6000/rs6000.c (rs6000_adjust_cost): Handle exts+dot case.
1028 (is_cracked_insn): Ditto.
1029 (insn_must_be_first_in_group): Ditto.
1030 * config/rs6000/rs6000.md (dot): Adjust comment.
1031 (cell_micro): Handle exts+dot.
1032 (extendqidi2, extendhidi2, extendsidi2, *extendsidi2_lfiwax,
1033 *extendsidi2_nocell, *extendsidi2_nocell, extendqisi2, extendqihi2,
1034 extendhisi2, 16 anonymous instructions, and 12 splitters): Delete.
1035 (extendqi<mode>2, *extendqi<mode>2_dot, *extendqi<mode>2_dot2,
1036 extendhi<mode>2, *extendhi<mode>2, *extendhi<mode>2_noload,
1037 *extendhi<mode>2_dot, *extendhi<mode>2_dot2, extendsi<mode>2,
1038 *extendsi<mode>2_dot, *extendsi<mode>2_dot2): New.
1039
1040 2014-09-02 Segher Boessenkool <segher@kernel.crashing.org>
1041
1042 * config/rs6000/rs6000.md (QHSI): Delete.
1043 (EXTQI, EXTHI, EXTSI): New mode iterators.
1044 (zero_extend<mode>di2, *zero_extend<mode>di2_internal1,
1045 *zero_extend<mode>di2_internal2, *zero_extend<mode>di2_internal3,
1046 *zero_extendsidi2_lfiwzx, zero_extendqisi2, zero_extendhisi2,
1047 9 anonymous instructions, and 8 splitters): Delete.
1048 (zero_extendqi<mode>2, *zero_extendqi<mode>2_dot,
1049 *zero_extendqi<mode>2_dot2, zero_extendhi<mode>2,
1050 *zero_extendhi<mode>2_dot, *zero_extendhi<mode>2_dot2,
1051 zero_extendsi<mode>2, *zero_extendsi<mode>2_dot,
1052 *zero_extendsi<mode>2_dot2): New.
1053
1054 2014-09-02 Segher Boessenkool <segher@kernel.crashing.org>
1055
1056 * config/rs6000/rs6000.md (any_extend): New code iterator.
1057 (u, su): New code attributes.
1058 (dmode, DMODE): New mode attributes.
1059 (<su>mul<mode>3_highpart): New.
1060 (*<su>mul<mode>3_highpart): New.
1061 (<su>mulsi3_highpart_le): New.
1062 (<su>muldi3_highpart_le): New.
1063 (<su>mulsi3_highpart_64): New.
1064 (<u>mul<mode><dmode>3): New.
1065 (mulsidi3, umulsidi3, smulsi3_highpart, umulsi3_highpart, and two
1066 splitters): Delete.
1067 (mulditi3, umulditi3, smuldi3_highpart, umuldi3_highpart, and two
1068 splitters): Delete.
1069
1070 2014-09-02 Segher Boessenkool <segher@kernel.crashing.org>
1071
1072 * config/rs6000/rs6000.md (mulsi3, *mulsi3_internal1,
1073 *mulsi3_internal2, and two splitters): Delete.
1074 (muldi3, *muldi3_internal1, *muldi3_internal2, and two splitters):
1075 Delete.
1076 (mul<mode>3, mul<mode>3_dot, mul<mode>3_dot2): New.
1077
1078 2014-09-02 Richard Biener <rguenther@suse.de>
1079
1080 PR tree-optimization/62695
1081 * tree-ssa-structalias.c (find_func_clobbers): Add missing
1082 vector truncate.
1083
1084 2014-09-01 Oleg Endo <olegendo@gcc.gnu.org>
1085
1086 PR target/62312
1087 * config/sh/sh.md (*cmp_div0s_0): Add missing constraints.
1088
1089 2014-09-01 Andi Kleen <ak@linux.intel.com>
1090
1091 * file-find.c (add_prefix_begin): Add.
1092 (do_add_prefix): Rename from add_prefix with first argument.
1093 (add_prefix): Add new wrapper.
1094 * file-find.h (add_prefix_begin): Add.
1095 * gcc-ar.c (main): Support -B option.
1096
1097 2014-09-01 Segher Boessenkool <segher@kernel.crashing.org>
1098
1099 * genemit.c: Include dumpfile.h.
1100 (gen_split): Print name of splitter function to dump file.
1101
1102 2014-09-01 Richard Biener <rguenther@suse.de>
1103
1104 * tree-ssa-struct-aliases.c (find_func_aliases_for_builtin_call):
1105 Use stack auto_vecs for constraint expressions.
1106 (find_func_aliases_for_call): Likewise.
1107 (find_func_aliases): Likewise.
1108 (find_func_clobbers): Likewise.
1109
1110 2014-09-01 Richard Biener <rguenther@suse.de>
1111
1112 * tree-ssa-pre.c (phi_translate_1): Avoid re-allocating the
1113 operands vector in most cases. Remove redundant code.
1114
1115 2014-09-01 Olivier Hainque <hainque@adacore.com>
1116
1117 * config/vxworksae.h (VXWORKSAE_TARGET_DIR): Rely on
1118 $WIND_BASE instead of designating a harcoded arbitrary home dir.
1119 (VXWORKS_ADDITIONAL_CPP_SPEC): Adjust callers.
1120
1121 2014-09-01 Richard Biener <rguenther@suse.de>
1122
1123 * tree-ssa-sccvn.h (copy_reference_ops_from_ref,
1124 copy_reference_ops_from_call, vn_nary_op_compute_hash,
1125 vn_reference_compute_hash, vn_reference_insert): Remove.
1126 (vn_reference_lookup_call): New function.
1127 * tree-ssa-sccvn.c (vn_reference_compute_hash,
1128 copy_reference_ops_from_ref, copy_reference_ops_from_call,
1129 vn_reference_insert, vn_nary_op_compute_hash): Make static.
1130 (create_reference_ops_from_call): Remove.
1131 (vn_reference_lookup_3): Properly update shared_lookup_references.
1132 (vn_reference_lookup_pieces): Assert that we updated
1133 shared_lookup_references properly.
1134 (vn_reference_lookup): Likewise.
1135 (vn_reference_lookup_call): New function.
1136 (visit_reference_op_call): Use it. Avoid re-building the
1137 reference ops.
1138 (visit_reference_op_load): Remove redundant lookup.
1139 (visit_reference_op_store): Perform special tail-merging work
1140 only when possibly doing tail-merging.
1141 (visit_use): Likewise.
1142 * tree-ssa-pre.c (compute_avail): Use vn_reference_lookup_call.
1143
1144 2014-09-01 Jakub Jelinek <jakub@redhat.com>
1145
1146 PR target/62025
1147 * sched-deps.c (add_or_update_dep_1): If ask_dependency_caches
1148 returned DEP_PRESENT, make sure to set DEP_MULTIPLE on present_dep.
1149 (find_inc): Revert 2014-08-13 change.
1150
1151 2014-09-01 Marek Polacek <polacek@redhat.com>
1152
1153 PR middle-end/61903
1154 * expmed.c (store_fixed_bit_field_1): Shift UHWI 1 instead of HWI 1.
1155 Change the type of V to unsigned HOST_WIDE_INT.
1156
1157 2014-09-01 Thomas Preud'homme <thomas.preudhomme@arm.com>
1158
1159 * tree-ssa-math-opts.c (struct symbolic_number): Clarify comment about
1160 the size of byte markers.
1161 (do_shift_rotate): Fix confusion between host, target and marker byte
1162 size.
1163 (verify_symbolic_number_p): Likewise.
1164 (find_bswap_or_nop_1): Likewise.
1165 (find_bswap_or_nop): Likewise.
1166
1167 2014-09-01 Olivier Hainque <hainque@adacore.com>
1168
1169 * Makefile.in (FLAGS_TO_PASS): Propagate INSTALL, INSTALL_DATA,
1170 INSTALL_SCRIPT and INSTALL_PROGRAM as well.
1171
1172 2014-09-01 Jakub Jelinek <jakub@redhat.com>
1173
1174 * config/gnu-user.h (LIBLSAN_EARLY_SPEC): Define.
1175 * gcc.c (LIBLSAN_SPEC, LIBLSAN_EARLY_SPEC): Follow LIBTSAN*_SPEC.
1176 (SANITIZER_EARLY_SPEC): Include LIBLSAN_EARLY_SPEC for -fsanitize=leak.
1177
1178 2014-09-01 Yury Gribov <y.gribov@samsung.com>
1179
1180 PR sanitizer/61897
1181 PR sanitizer/62140
1182 * asan.c (asan_mem_ref_get_end): Handle non-ptroff_t lengths.
1183 (build_check_stmt): Likewise.
1184 (instrument_strlen_call): Likewise.
1185 (asan_expand_check_ifn): Likewise and fix types.
1186 (maybe_cast_to_ptrmode): New function.
1187
1188 2014-09-01 Jan-Benedict Glaw <jbglaw@lug-owl.de>
1189
1190 * config/mcore/mcore.c (try_constant_tricks): Fix declaration.
1191
1192 2014-08-31 Gerald Pfeifer <gerald@pfeifer.com>
1193
1194 * doc/generic.texi (Deficiencies): Add note on exemplary mistakes.
1195
1196 2014-08-30 John David Anglin <danglin@gcc.gnu.org>
1197
1198 * config/pa/pa.c (pa_assemble_integer): Don't add PLABEL relocation
1199 prefix to function labels when generating fast indirect calls.
1200
1201 2014-08-30 David Malcolm <dmalcolm@redhat.com>
1202
1203 PR bootstrap/62304
1204
1205 * gcc/reorg.c (skip_consecutive_labels): Convert return type and
1206 param back from rtx_insn * to rtx. Rename param from "label" to
1207 "label_or_return", reintroducing "label" as an rtx_insn * after
1208 we've ensured it's not a RETURN.
1209 (first_active_target_insn): Likewise for return type and param;
1210 add a checked cast to rtx_insn * once we've ensured "insn" is not
1211 a RETURN.
1212 (steal_delay_list_from_target): Convert param "pnew_thread" back
1213 from rtx_insn ** to rtx *. Replace use of JUMP_LABEL_AS_INSN
1214 with JUMP_LABEL.
1215 (own_thread_p): Convert param "thread" back from an rtx_insn * to
1216 an rtx. Introduce local rtx_insn * "thread_insn" with a checked
1217 cast once we've established we're not dealing with a RETURN,
1218 renaming subsequent uses of "thread" to "thread_insn".
1219 (fill_simple_delay_slots): Convert uses of JUMP_LABEL_AS_INSN back
1220 to JUMP_LABEL.
1221 (follow_jumps): Convert return type and param "label" from
1222 rtx_insn * back to rtx. Move initialization of "value" to after
1223 the handling for ANY_RETURN_P, adding a checked cast there to
1224 rtx_insn *. Convert local rtx_insn * "this_label" to an rtx and
1225 rename to "this_label_or_return", reintroducing "this_label" as
1226 an rtx_insn * once we've handled the case where it could be an
1227 ANY_RETURN_P.
1228 (fill_slots_from_thread): Rename param "thread" to
1229 "thread_or_return", converting from an rtx_insn * back to an rtx.
1230 Reintroduce name "thread" as an rtx_insn * local with a checked
1231 cast once we've handled the case of it being an ANY_RETURN_P.
1232 Convert local "new_thread" from an rtx_insn * back to an rtx.
1233 Add a checked cast when assigning to "trial" from "new_thread".
1234 Convert use of JUMP_LABEL_AS_INSN back to JUMP_LABEL. Add a
1235 checked cast to rtx_insn * from "new_thread" when invoking
1236 get_label_before.
1237 (fill_eager_delay_slots): Convert locals "target_label",
1238 "insn_at_target" from rtx_insn * back to rtx.
1239 Convert uses of JUMP_LABEL_AS_INSN back to JUMP_LABEL.
1240 (relax_delay_slots): Convert locals "trial", "target_label" from
1241 rtx_insn * back to rtx. Convert uses of JUMP_LABEL_AS_INSN back
1242 to JUMP_LABEL. Add a checked cast to rtx_insn * on "trial" when
1243 invoking update_block.
1244 (dbr_schedule): Convert use of JUMP_LABEL_AS_INSN back to
1245 JUMP_LABEL; this removes all JUMP_LABEL_AS_INSN from reorg.c.
1246
1247 * resource.h (mark_target_live_regs): Undo erroneous conversion
1248 of second param of r214693, converting it back from rtx_insn * to
1249 rtx, since it could be a RETURN.
1250
1251 * resource.c (find_dead_or_set_registers): Similarly, convert
1252 param "jump_target" back from an rtx_insn ** to an rtx *, as we
1253 could be writing back a RETURN. Rename local rtx_insn * "next" to
1254 "next_insn", and introduce "lab_or_return" as a local rtx,
1255 handling the case where JUMP_LABEL (this_jump_insn) is a RETURN.
1256 (mark_target_live_regs): Undo erroneous conversion
1257 of second param of r214693, converting it back from rtx_insn * to
1258 rtx, since it could be a RETURN. Rename it from "target" to
1259 "target_maybe_return", reintroducing the name "target" as a local
1260 rtx_insn * with a checked cast, after we've handled the case of
1261 ANY_RETURN_P.
1262
1263 2014-08-29 DJ Delorie <dj@redhat.com>
1264
1265 * cppbuiltin.c (define_builtin_macros_for_type_sizes): Round
1266 pointer size up to a power of two.
1267 * defaults.h (DWARF2_ADDR_SIZE): Round up.
1268 (POINTER_SIZE_UNITS): New, rounded up value.
1269 * dwarf2asm.c (size_of_encoded_value): Use it.
1270 (dw2_output_indirect_constant_1): Likewise.
1271 * expmed.c (init_expmed_one_conv): We now know the sizes of
1272 partial int modes.
1273 * loop-iv.c (iv_number_of_iterations): Use precision, not size.
1274 * optabs.c (expand_float): Use precision, not size.
1275 (expand_fix): Likewise.
1276 * simplify-rtx (simplify_unary_operation_1): Likewise.
1277 * tree-dfa.c (get_ref_base_and_extent): Likewise.
1278 * varasm.c (assemble_addr_to_section): Round up pointer sizes.
1279 (default_assemble_integer) Likewise.
1280 (dump_tm_clone_pairs): Likewise.
1281 * dwarf2out.c (mem_loc_descriptor): Allow partial-int modes also.
1282 * var-tracking.c (adjust_mems): Allow partial-int modes also.
1283 (prepare_call_arguments): Likewise.
1284 * stor-layout.c (finalize_type_size): Preserve precision.
1285 (layout_type): Use precision, not size.
1286
1287 * expr.c (convert_move): If the target has an explicit converter,
1288 use it.
1289
1290 2014-08-29 David Malcolm <dmalcolm@redhat.com>
1291
1292 * gdbinit.in: Skip various inline functions in rtl.h when
1293 stepping.
1294
1295 2014-08-29 Richard Sandiford <richard.sandiford@arm.com>
1296
1297 PR bootstrap/62301
1298 * rtlanal.c (rtx_referenced_p): Fix typo in LABEL_P call.
1299
1300 2014-08-29 Richard Biener <rguenther@suse.de>
1301
1302 PR tree-optimization/62291
1303 * tree-ssa-pre.c (sorted_array_from_bitmap_set): Reserve
1304 exactly the vector size needed and use quick_push.
1305 (phi_translate_1): Adjust comment.
1306 (valid_in_sets): Remove block argument and remove pointless
1307 checking of NAMEs.
1308 (dependent_clean): Adjust for removal of block argument.
1309 (clean): Likewise.
1310 (compute_antic_aux): Likewise.
1311 (compute_partial_antic_aux): Likewise.
1312
1313 2014-08-29 Alexander Ivchenko <alexander.ivchenko@intel.com>
1314 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
1315 Anna Tikhonova <anna.tikhonova@intel.com>
1316 Ilya Tocar <ilya.tocar@intel.com>
1317 Andrey Turetskiy <andrey.turetskiy@intel.com>
1318 Ilya Verbin <ilya.verbin@intel.com>
1319 Kirill Yukhin <kirill.yukhin@intel.com>
1320 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
1321
1322 * config/i386/sse.md
1323 (define_insn "avx2_interleave_highv4di<mask_name>"): Add masking.
1324 (define_insn "vec_interleave_highv2di<mask_name>"): Ditto.
1325 (define_insn "avx2_interleave_lowv4di<mask_name>"): Ditto.
1326 (define_insn "vec_interleave_lowv2di<mask_name>"): Ditto.
1327
1328 2014-08-29 Alexander Ivchenko <alexander.ivchenko@intel.com>
1329 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
1330 Anna Tikhonova <anna.tikhonova@intel.com>
1331 Ilya Tocar <ilya.tocar@intel.com>
1332 Andrey Turetskiy <andrey.turetskiy@intel.com>
1333 Ilya Verbin <ilya.verbin@intel.com>
1334 Kirill Yukhin <kirill.yukhin@intel.com>
1335 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
1336
1337 * config/i386/i386-modes.def: Add V12QI, V14QI, V6HI modes.
1338 * config/i386/sse.md
1339 (define_mode_iterator VI4_128_8_256): New.
1340 (define_mode_iterator VI2_128_4_256): Ditto.
1341 (define_mode_iterator PMOV_DST_MODE): Rename into
1342 (define_mode_iterator PMOV_DST_MODE_1): this.
1343 (define_insn "*avx512f_<code><pmov_src_lower><mode>2"):
1344 Use PMOV_DST_MODE_1 mode iterator.
1345 (define_insn "avx512f_<code><pmov_src_lower><mode>2_mask"):
1346 Ditto.
1347 (define_insn "avx512f_<code><pmov_src_lower><mode>2_mask"):
1348 Ditto.
1349 (define_insn "*avx512bw_<code>v32hiv32qi2"): New.
1350 (define_insn "avx512bw_<code>v32hiv32qi2_mask"): Ditto.
1351 (define_expand "avx512bw_<code>v32hiv32qi2_store_mask"): Ditto.
1352 (define_mode_iterator PMOV_DST_MODE_2): New.
1353 (define_insn "*avx512vl_<code><ssedoublemodelower><mode>2"): Ditto.
1354 (define_insn "<avx512>_<code><ssedoublemodelower><mode>2_mask"): Ditto.
1355 (define_expand "<avx512>_<code><ssedoublemodelower><mode>2_store_mask"):
1356 Ditto.
1357 (define_mode_iterator PMOV_SRC_MODE_3): Ditto.
1358 (define_mode_attr pmov_dst_3): Ditto.
1359 (define_mode_attr pmov_dst_zeroed_3): Ditto.
1360 (define_mode_attr pmov_suff_3): Ditto.
1361 (define_insn "*avx512vl_<code><mode>v<ssescalarnum>qi2"): Ditto.
1362 (define_insn "*avx512vl_<code>v2div2qi2_store"): Ditto.
1363 (define_insn "avx512vl_<code>v2div2qi2_mask"): Ditto.
1364 (define_insn "avx512vl_<code>v2div2qi2_store_mask"): Ditto.
1365 (define_insn "*avx512vl_<code><mode>v4qi2_store"): Ditto.
1366 (define_insn "avx512vl_<code><mode>v4qi2_mask"): Ditto.
1367 (define_insn "avx512vl_<code><mode>v4qi2_store_mask"): Ditto.
1368 (define_insn "*avx512vl_<code><mode>v8qi2_store"): Ditto.
1369 (define_insn "avx512vl_<code><mode>v8qi2_mask"): Ditto.
1370 (define_insn "avx512vl_<code><mode>v8qi2_store_mask"): Ditto.
1371 (define_mode_iterator PMOV_SRC_MODE_4): Ditto.
1372 (define_mode_attr pmov_dst_4): Ditto.
1373 (define_mode_attr pmov_dst_zeroed_4): Ditto.
1374 (define_mode_attr pmov_suff_4): Ditto.
1375 (define_insn "*avx512vl_<code><mode>v<ssescalarnum>hi2"): Ditto.
1376 (define_insn "*avx512vl_<code><mode>v4hi2_store"): Ditto.
1377 (define_insn "avx512vl_<code><mode>v4hi2_mask"): Ditto.
1378 (define_insn "avx512vl_<code><mode>v4hi2_store_mask"): Ditto.
1379 (define_insn "*avx512vl_<code>v2div2hi2_store"): Ditto.
1380 (define_insn "avx512vl_<code>v2div2hi2_mask"): Ditto.
1381 (define_insn "avx512vl_<code>v2div2hi2_store_mask"): Ditto.
1382 (define_insn "*avx512vl_<code>v2div2si2"): Ditto.
1383 (define_insn "*avx512vl_<code>v2div2si2_store"): Ditto.
1384 (define_insn "avx512vl_<code>v2div2si2_mask"): Ditto.
1385 (define_insn "avx512vl_<code>v2div2si2_store_mask"): Ditto.
1386
1387 2014-08-29 Richard Biener <rguenther@suse.de>
1388
1389 * tree-cfg.c (verify_gimple_assign_unary): Do not allow
1390 NON_LVALUE_EXPR in gimple.
1391
1392 2014-08-29 Richard Biener <rguenther@suse.de>
1393
1394 PR middle-end/62292
1395 * gimple-fold.c (gimple_fold_builtin_strcpy): Fix error
1396 from previous refactoring.
1397 (gimple_fold_builtin_strncpy): Likewise.
1398
1399 2014-08-29 David Malcolm <dmalcolm@redhat.com>
1400
1401 PR bootstrap/62300
1402 * function.c (assign_parm_setup_reg): Remove erroneous checked
1403 cast to rtx_insn * on result of gen_extend_insn in favor of
1404 introducing a new local rtx "pat".
1405
1406 2014-08-29 Jan-Benedict Glaw <jbglaw@lug-owl.de>
1407
1408 * config/mep/mep-pragma.c (mep_pragma_coprocessor_subclass): Rework
1409 to silence warning.
1410 * config/mep/mep.c (VECTOR_TYPE_P): Remove duplicate definition.
1411
1412 2014-08-28 David Malcolm <dmalcolm@redhat.com>
1413
1414 * rtl.h (previous_insn): Strengthen param from rtx to rtx_insn *.
1415 (next_insn): Likewise.
1416 * emit-rtl.c (next_insn): Likewise.
1417 (previous_insn): Likewise.
1418 * config/pa/pa.c (remove_useless_addtr_insns): Strenghten locals
1419 "insn" and "next" from rtx to rtx_insn *.
1420 * config/picochip/picochip.c (picochip_reorg): Likewise for locals
1421 "insn", "insn1", "vliw_start", "prologue_end_note",
1422 "last_insn_in_packet".
1423
1424 2014-08-28 David Malcolm <dmalcolm@redhat.com>
1425
1426 * shrink-wrap.h (active_insn_between): Strengthen both params from
1427 rtx to rtx_insn *.
1428 * function.c (active_insn_between): Likewise.
1429
1430 2014-08-28 David Malcolm <dmalcolm@redhat.com>
1431
1432 * genattr.c (main): When writing out insn-attr.h, strengthen param
1433 of dfa_clear_single_insn_cache from rtx to rtx_insn *.
1434 * genautomata.c (output_dfa_clean_insn_cache_func): Likewise when
1435 writing out the definition of dfa_clear_single_insn_cache to the
1436 generated insn-automata.c
1437
1438 2014-08-28 David Malcolm <dmalcolm@redhat.com>
1439
1440 * resource.h (clear_hashed_info_for_insn): Strengthen param from
1441 rtx to rtx_insn *.
1442 (incr_ticks_for_insn): Likewise.
1443 (init_resource_info): Likewise.
1444
1445 * resource.c (init_resource_info): Likewise.
1446 (clear_hashed_info_for_insn): Likewise.
1447 (incr_ticks_for_insn): Likewise.
1448
1449 * reorg.c (delete_scheduled_jump): Strengthen param "insn" from
1450 rtx to rtx_insn *.
1451 (steal_delay_list_from_target): Use methods of "seq".
1452 (try_merge_delay_insns): Use methods of "merged_insns".
1453 (update_block): Strengthen param "insn" from rtx to rtx_insn *.
1454 (reorg_redirect_jump): Likewise for param "jump".
1455
1456 2014-08-28 David Malcolm <dmalcolm@redhat.com>
1457
1458 * insn-addr.h (insn_addresses_new): Strengthen param "insn" from
1459 rtx to rtx_insn *.
1460 * config/s390/s390.c (s390_split_branches): Eliminate top-level
1461 local rtx "tmp", in favor of new local rtx "mem" and rtx_insn *
1462 "set_insn".
1463 (s390_mainpool_finish): In three places, split out a local rtx
1464 "insn" into a local rtx - "set" or "pat" - and a rtx_insn *
1465 "insn". Strengthen local "pool_end" from rtx to rtx_code_label *
1466 and split another local rtx "insn" out into rtx "pat" and
1467 rtx_insn * "insn".
1468 * config/sh/sh.c (output_branchy_insn): Rather than working
1469 directly on operands[9], introduce local rtx_code_label *
1470 variables named "lab" in two places, working on them, and then
1471 assigning them to operands[9], so that the intervening operations
1472 are known by the type system to be on insns.
1473
1474 2014-08-28 David Malcolm <dmalcolm@redhat.com>
1475
1476 * rtl.h (INSN_HAS_LOCATION): Strengthen param from const_rtx to
1477 const rtx_insn *.
1478
1479 * print-rtl.c (print_rtx): Add checked cast to const rtx_insn *
1480 in invocation of INSN_HAS_LOCATION.
1481
1482 2014-08-28 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
1483
1484 * config/rs6000/altivec.h (vec_xl): New #define.
1485 (vec_xst): Likewise.
1486 * config/rs6000/rs6000-builtin.def (XXSPLTD_V2DF): New built-in.
1487 (XXSPLTD_V2DI): Likewise.
1488 (DIV_V2DI): Likewise.
1489 (UDIV_V2DI): Likewise.
1490 (MUL_V2DI): Likewise.
1491 * config/rs6000/rs6000-c.c (altivec_overloaded_builtins): Add
1492 entries for VSX_BUILTIN_XVRDPI, VSX_BUILTIN_DIV_V2DI,
1493 VSX_BUILTIN_UDIV_V2DI, VSX_BUILTIN_MUL_V2DI,
1494 VSX_BUILTIN_XXSPLTD_V2DF, and VSX_BUILTIN_XXSPLTD_V2DI).
1495 * config/rs6000/vsx.md (UNSPEC_VSX_XXSPLTD): New unspec.
1496 (UNSPEC_VSX_DIVSD): Likewise.
1497 (UNSPEC_VSX_DIVUD): Likewise.
1498 (UNSPEC_VSX_MULSD): Likewise.
1499 (vsx_mul_v2di): New insn-and-split.
1500 (vsx_div_v2di): Likewise.
1501 (vsx_udiv_v2di): Likewise.
1502 (vsx_xxspltd_<mode>): New insn.
1503
1504 2014-08-28 David Malcolm <dmalcolm@redhat.com>
1505
1506 * rtl.h (RTX_PREV): Added checked casts to uses of PREV_INSN and
1507 NEXT_INSN.
1508 (PREV_INSN): Strengthen param from const_rtx to const rtx_insn *.
1509 (NEXT_INSN): Likewise.
1510 (JUMP_LABEL_AS_INSN): Add a "const" modifier to param.
1511 (reg_used_between_p): Strengthen params 2 and 3 from const_rtx to
1512 const rtx_insn *.
1513 (no_labels_between_p): Likewise for both params.
1514
1515 * config/aarch64/aarch64.c (aarch64_output_casesi): Add a checked
1516 cast when using NEXT_INSN on operands[2].
1517 * config/alpha/alpha.c (alpha_set_memflags): Strengthen local
1518 "insn" from rtx to rtx_insn *, adding a checked cast.
1519 (alpha_handle_trap_shadows): Strengthen locals "i", "n" from rtx to
1520 rtx_insn *.
1521 * config/arc/arc-protos.h (arc_ccfsm_record_condition): Likewise
1522 for third param.
1523 (arc_text_label): Likewise for param "insn".
1524 * config/arc/arc.c (arc_expand_epilogue): Likewise for local
1525 "insn".
1526 (arc_ccfsm_record_condition): Likewise for param "jump".
1527 (arc_text_label): Likewise for local "label".
1528 * config/arc/arc.md (doloop_begin_i): Likewise for local "scan".
1529 Introduce a local "seq" via a dyn_cast to rtx_sequence *, and use
1530 a method for typesafety. Add a checked cast.
1531 * config/arc/constraints.md (Clb): Add a checked cast when getting
1532 the CODE_LABEL from a LABEL_REF.
1533 * config/arm/arm.c (require_pic_register): Strengthen locals
1534 "seq", "insn" from rtx to rtx_insn *.
1535 (create_fix_barrier): Likewise for locals "selected", "next".
1536 (thumb1_reorg): Likewise for locals "prev", "insn".
1537 (arm_expand_prologue): Likewise for local "last".
1538 (thumb1_output_casesi): Add a checked cast when using NEXT_INSN on
1539 operands[0].
1540 (thumb2_output_casesi): Likewise for operands[2].
1541 * config/avr/avr-log.c (avr_log_vadump): Within 'L' case,
1542 strengthen local "insn" from rtx to rtx_insn *.
1543 * config/bfin/bfin.c (find_next_insn_start): Likewise for return
1544 type and param "insn".
1545 (find_prev_insn_start): Likewise.
1546 (hwloop_optimize): Likewise for locals "insn", "last_insn",
1547 "prev".
1548 (gen_one_bundle): Likewise for loal "t".
1549 (find_load): Likewise for param "insn".
1550 (workaround_speculation): Likewise for locals "insn", "next",
1551 "target", "next_tgt".
1552 * config/c6x/c6x.c (assign_reservations): Likewise for both params
1553 and for locals "insn", "within", "last".
1554 (count_unit_reqs): Likewise for params "head", "tail" and local
1555 "insn".
1556 (try_rename_operands): Likewise for params "head", "tail".
1557 (reshuffle_units): Likewise for locals "head", "tail", "insn".
1558 (struct c6x_sched_context): Likewise for fields
1559 "last_scheduled_insn", "last_scheduled_iter0".
1560 (init_sched_state): Replace NULL_RTX with NULL.
1561 (reorg_split_calls): Strengthen local "new_cycle_first" from rtx
1562 to rtx_insn *.
1563 (undo_split_delayed_nonbranch): Likewise for param and for local
1564 "prev".
1565 (conditionalize_after_sched): Likewise for local "insn".
1566 (bb_earliest_end_cycle): Likewise.
1567 (filter_insns_above): Likewise for locals "insn", "next".
1568 (hwloop_optimize): Remove redundant checked cast.
1569 (hwloop_fail): Strengthen local "t" from rtx to rtx_insn *.
1570 * config/cris/cris.c (cris_initial_frame_pointer_offset): Replace
1571 NULL_RTX with NULL.
1572 (cris_simple_epilogue): Likewise.
1573 (cris_expand_prologue): Likewise.
1574 (cris_expand_epilogue): Likewise.
1575 * config/frv/frv.c (frv_function_contains_far_jump): Strengthen
1576 local "insn" from rtx to rtx_insn *.
1577 (frv_ifcvt_modify_tests): Likewise for locals "last_insn", "insn".
1578 (struct frv_packet_group): Likewise for the elements within array
1579 fields "insns", "sorted", and for field "nop".
1580 (frv_packet): Likewise for the elements within array field
1581 "insns".
1582 (frv_add_insn_to_packet): Likewise for param "insn".
1583 (frv_insert_nop_in_packet): Likewise for param "insn" and local
1584 "last".
1585 (frv_for_each_packet): Likewise for locals "insn", "next_insn".
1586 (frv_sort_insn_group_1): Likewise for local "insn".
1587 (frv_optimize_membar_local): Likewise.
1588 (frv_align_label): Likewise for locals "x", "last", "barrier",
1589 "label".
1590 * config/ia64/ia64.c (last_scheduled_insn): Likewise for this
1591 local.
1592 (ia64_sched_init): Likewise for local "insn".
1593 (scheduled_good_insn): Likewise for param "last".
1594 (struct _ia64_sched_context): Likewise for field
1595 "last_scheduled_insn".
1596 (ia64_init_sched_context): Replace NULL_RTX with NULL.
1597 (struct bundle_state): Likewise for field "insn".
1598 (issue_nops_and_insn): Likewise for param "insn".
1599 (get_next_important_insn): Likewise for return type and both
1600 params.
1601 (ia64_add_bundle_selector_before): Likewise for param "insn".
1602 (bundling): Likewise for params "prev_head_insn", "tail" and
1603 locals "insn", "next_insn", "b". Eliminate top-level local rtx
1604 "nop" in favor of new locals rtx "nop_pat" and rtx_insn *nop;
1605 * config/iq2000/iq2000-protos.h (iq2000_fill_delay_slot):
1606 Strengthen final param from rtx to rtx_insn *.
1607 (iq2000_move_1word): Likewise for second param.
1608 * config/iq2000/iq2000.c (iq2000_fill_delay_slot): Likewise for
1609 param "cur_insn" and local "next_insn".
1610 (iq2000_move_1word): Likewise for param "insn".
1611 * config/iq2000/iq2000.md (insn before ADDR_DIFF_VEC): Add checked
1612 casts when using NEXT_INSN on operands[1].
1613 * config/m32c/m32c.c (m32c_function_needs_enter): Strengthen local
1614 "insn" from rtx to rtx_insn *.
1615 * config/m68k/m68k.c (m68k_jump_table_ref_p): Split out uses of
1616 "x", introducing local rtx_insn * "insn" for when working with the
1617 CODE_LABEL of the LABEL_REF.
1618 (m68k_sched_md_init_global): Strengthen local "insn" from rtx to
1619 rtx_insn *.
1620 * config/mcore/mcore-protos.h (mcore_is_dead): Likewise for first
1621 param.
1622 * config/mcore/mcore.c (emit_new_cond_insn): Likewise for return
1623 type.
1624 (conditionalize_block): Likewise for return type and param.
1625 (mcore_is_dead): Likewise for param "first" and local "insn".
1626 (emit_new_cond_insn): Likewise for return type.
1627 (conditionalize_block): Likewise for return type, param, and
1628 locals "insn", "blk_1_br", "end_blk_2_insn", "start_blk_3_lab",
1629 "newinsn".
1630 (conditionalize_optimization): Likewise for local "insn".
1631 * config/mep/mep.c (mep_jmp_return_reorg): Add checked cast when
1632 using NEXT_INSN.
1633 * config/microblaze/microblaze.md: Add checked casts when using
1634 NEXT_INSN.
1635 * config/mips/mips.c (mips_expand_prologue): Eliminate top-level
1636 rtx "insn" in favor of various more tightly-scoped rtx "insn" and
1637 and rtx_insn * "insn".
1638 * config/mips/mips.md (casesi_internal_mips16_<mode>): Add a
1639 checked cast when using NEXT_INSN on operands[2].
1640 * config/mn10300/mn10300.c (mn10300_insert_setlb_lcc): Strengthen
1641 local "insn" from rtx to rtx_insn *.
1642 * config/nds32/nds32-fp-as-gp.c (nds32_fp_as_gp_check_available):
1643 Likewise.
1644 * config/nds32/nds32-md-auxiliary.c (nds32_output_casesi_pc_relative):
1645 Add a checked cast when using NEXT_INSN on operands[1].
1646 * config/pa/pa-protos.h (pa_following_call): Strengthen param from
1647 rtx to rtx_insn *.
1648 (pa_output_cbranch): Likewise for final param.
1649 (pa_output_lbranch): Likewise for second param.
1650 (pa_output_bb): Likewise for third param.
1651 (pa_output_bvb): Likewise.
1652 (pa_output_dbra): Likewise for second param.
1653 (pa_output_movb): Likewise.
1654 (pa_output_parallel_movb): Likewise.
1655 (pa_output_parallel_addb): Likewise.
1656 (pa_output_millicode_call): Likewise for first param.
1657 (pa_output_mul_insn): Likewise for second param.
1658 (pa_output_div_insn): Likewise for third param.
1659 (pa_output_mod_insn): Likewise for second param.
1660 (pa_jump_in_call_delay): Likewise for param.
1661 * config/pa/pa.c (pa_output_mul_insn): Likewise for param "insn".
1662 (pa_output_div_insn): Likewise.
1663 (pa_output_mod_insn): Likewise.
1664 (pa_output_cbranch): Likewise.
1665 (pa_output_lbranch): Likewise.
1666 (pa_output_bb): Likewise.
1667 (pa_output_bvb): Likewise.
1668 (pa_output_dbra): Likewise.
1669 (pa_output_movb): Likewise.
1670 (pa_output_millicode_call): Likewise; use method of rtx_sequence *
1671 to simplify and for typesafety.
1672 (pa_output_call): Use method of rtx_sequence *.
1673 (forward_branch_p): Strengthen param "insn" from rtx to rtx_insn *.
1674 (pa_jump_in_call_delay): Likewise.
1675 (pa_output_parallel_movb): Likewise.
1676 (pa_output_parallel_addb): Likewise.
1677 (pa_following_call): Likewise.
1678 (pa_combine_instructions): Likewise for locals "anchor",
1679 "floater".
1680 (pa_can_combine_p): Likewise for params "anchor", "floater" and
1681 locals "start", "end".
1682 * config/picochip/picochip.c (picochip_reset_vliw): Likewise for
1683 param "insn" and local "local_insn".
1684 (picochip_final_prescan_insn): Likewise for local "local_insn".
1685 * config/rs6000/rs6000.c (compute_save_world_info): Likewise for
1686 local "insn".
1687 (uses_TOC): Likewise.
1688 * config/s390/s390.c (get_some_local_dynamic_name): Likewise.
1689 (s390_mainpool_finish): Eliminate top-level local rtx "insn",
1690 splitting out to more tightly-scoped locals, 3 as rtx and one as
1691 rtx_insn *.
1692 (s390_optimize_nonescaping_tx): Strengthen local "tmp" from rtx
1693 to rtx_insn *.
1694 (s390_emit_prologue): Introduce a local "insn" to be an rtx_insn *
1695 where needed.
1696 * config/sh/sh-protos.h (barrier_align): Strenghten param from rtx
1697 to rtx_insn *.
1698 (fixup_addr_diff_vecs): Likewise.
1699 (reg_unused_after): Likewise for param 2.
1700 (sh_can_redirect_branch): Likewise for both params.
1701 (check_use_sfunc_addr): Likewise for param 1.
1702 * config/sh/sh.c (fixup_mova): Likewise for local "worker".
1703 (find_barrier): Likewise for local "last_got".
1704 (gen_block_redirect): Likewise for return type, param "jump" and
1705 locals "prev", "scan", "next", "insn".
1706 (struct far_branch): Likewise for fields "near_label",
1707 "insert_place", "far_label".
1708 (gen_far_branch): Likewise for local "jump".
1709 (fixup_addr_diff_vecs): Likewise for param "first" and locals
1710 "insn", "prev".
1711 (barrier_align): Likewise for param and for locals "prev", "x".
1712 Introduce local rtx_sequence * "prev_seq" and use insn method for
1713 typesafety and clarity.
1714 (sh_reorg): Strengthen local "scan" from rtx to rtx_insn *.
1715 (get_dest_uid): Likewise for local "dest".
1716 (split_branches): Likewise for locals "next", "beyond", "label",
1717 "block", "far_label". Add checked casts when assigning to
1718 bp->far_label and "far_label".
1719 (reg_unused_after): Strengthen param "scan" from rtx to rtx_insn *.
1720 (sequence_insn_p): Likewise.
1721 (mark_constant_pool_use): Likewise for locals "insn", "lab". Add a
1722 more loop-scoped rtx "insn" when walking LABEL_REFS.
1723 (sh_can_redirect_branch): Strengthen both params from rtx to
1724 rtx_insn *.
1725 (check_use_sfunc_addr): Likewise for param "insn". Introduce a
1726 new local rtx_sequence * "seq" via a dyn_cast, and use a method
1727 for clarity and typesafety.
1728 * config/sh/sh.md (define_expand "epilogue"): Strengthen local
1729 "insn" from rtx to rtx_insn *.
1730 (define_insn "casesi_worker_1"): Add a checked cast to rtx_insn *
1731 when using NEXT_INSN on the CODE_LABEL in operands[2].
1732 (define_insn "casesi_worker_2"): Likewise.
1733 (define_insn "casesi_shift_media"): Likewise.
1734 (define_insn "casesi_load_media"): Likewise for the CODE_LABEL in
1735 operands[3].
1736 * config/sh/sh_optimize_sett_clrt.cc (struct ccreg_value):
1737 Strengthen field "insn" from rtx to rtx_insn *.
1738 (sh_optimize_sett_clrt::execute): Likewise for locals "next_i", "i".
1739 (sh_optimize_sett_clrt::find_last_ccreg_values): Likewise for
1740 param "start_insn" and local "start_insn".
1741 * config/sh/sh_treg_combine.cc (struct set_of_reg): Likewise for
1742 field "insn".
1743 (find_set_of_reg_bb): Likewise for param "insn".
1744 (trace_reg_uses_1): Likewise for param "start_insn" and local "i".
1745 (trace_reg_uses): Likewise for param "start_insn".
1746 (sh_treg_combine::cbranch_trace): Likewise for field
1747 "cbranch_insn".
1748 (sh_treg_combine::cbranch_trace::cbranch_trace): Likewise for
1749 param "insn".
1750 (sh_treg_combine::record_set_of_reg): Likewise for param
1751 "start_insn" and local "i".
1752 (sh_treg_combine::can_remove_cstore): Likewise for local
1753 "prev_insn".
1754 (sh_treg_combine::try_optimize_cbranch): Likewise for param
1755 "insn".
1756 (sh_treg_combine::execute): Likewise for local "i".
1757 * config/sparc/sparc-protos.h (empty_delay_slot): Likewise for
1758 param.
1759 (sparc_check_64): Likewise for second param.
1760 * config/sparc/sparc.c (sparc_do_work_around_errata): Likewise for
1761 locals "insn", "next". Introduce local rtx_sequence * "seq" via a
1762 dyn_cast, using its insn method for typesafety and clarity.
1763 (empty_delay_slot): Strengthen param "insn" from rtx to
1764 rtx_insn *.
1765 (set_extends): Likewise.
1766 (sparc_check_64): Likewise.
1767 * config/stormy16/stormy16.c (xstormy16_split_cbranch): Likewise
1768 for locals "seq", "last_insn".
1769 (combine_bnp): Likewise for param "insn".
1770 (xstormy16_reorg): Likewise for local "insn".
1771 * config/v850/v850.c (substitute_ep_register): Likewise for params
1772 "first_insn", "last_insn" and local "insn".
1773 (v850_reorg): Likewise for fields "first_insn", "last_insn" within
1774 elements of "regs" array, and local "insn".
1775 * except.c (emit_note_eh_region_end): Likewise for param "insn".
1776 * final.c (final_sequence): Strengthen this global from rtx to
1777 rtx_sequence *.
1778 (shorten_branches): Strenthen locals "rel_lab", "prev" from rtx to
1779 rtx_insn *.
1780 (final_scan_insn): Update assignment to "final_sequence" to be
1781 from "seq", the cast version of "body", for type-safety.
1782 * function.c (assign_parm_setup_reg): Strengthen locals "insn",
1783 "insns" from rtx to rtx_insn *.
1784 (thread_prologue_and_epilogue_insns): Likewise for local "seq".
1785 * genattr.c (main): When writing out generated insn-attr.h,
1786 strengthen params 1 and 3 of eligible_for_delay,
1787 eligible_for_annul_true, eligible_for_annul_false from rtx to
1788 rtx_insn *.
1789 * genattrtab.c (write_eligible_delay): Likewise when writing out
1790 generated insn-attrtab.c; also local "insn" the generated
1791 functions.
1792 * hw-doloop.c (discover_loops): Strengthen local "insn" from rtx
1793 to rtx_insn *.
1794 * hw-doloop.h (struct GTY hwloop_info_d): Strengthen field
1795 "start_label" from rtx to rtx_insn *.
1796 * ira.c (decrease_live_ranges_number): Likewise for local "p".
1797 (ira_update_equiv_info_by_shuffle_insn): Likewise for param
1798 "insns" and local "insn".
1799 (validate_equiv_mem): Likewise for param "start" and local "insn".
1800 (memref_used_between_p): Likewise for params "start", "end" and
1801 local "insn".
1802 * ira.h (ira_update_equiv_info_by_shuffle_insn): Likewise for
1803 final param.
1804 * loop-doloop.c (doloop_optimize): Within region guarded by
1805 INSN_P (doloop_pat), introduce a new local rtx_insn *
1806 "doloop_insn" via a checked cast, and use it for typesafety,
1807 eventually writing the value back into doloop_pat.
1808 * output.h (final_sequence): Strengthen this global from rtx to
1809 rtx_sequence *.
1810 * recog.c (peep2_attempt): Rename param "insn" to "uncast_insn",
1811 reintroducing "insn" as an rtx_insn * via a checked cast.
1812 Strengthen param "attempt" and local "new_insn"from rtx to
1813 rtx_insn *.
1814 (peephole2_optimize): Strengthen locals "insn", "attempt" from rtx
1815 to rtx_insn *.
1816 * ree.c (emit_note_eh_region_end): Likewise for local "insn".
1817 * reload1.c (reload_as_needed): Eliminate top-level locals "x" and
1818 "p" in favor of more tightly-scoped replacements, sometimes rtx
1819 and sometimes rtx_insn *, as appropriate.
1820 (delete_output_reload): Eliminate top-level rtx "i1", splitting
1821 into two loop-scoped locals, one an rtx, the other an rtx_insn *.
1822 * reorg.c (delete_scheduled_jump): Add checked cast. Strengthen
1823 local "trial" from rtx to rtx_insn *.
1824 (redirect_with_delay_slots_safe_p): Strengthen param "jump" from
1825 rtx to rtx_insn *. Strenghten local "pat" from rtx to
1826 rtx_sequence * and use methods for clarity and typesafety.
1827 (redirect_with_delay_list_safe_p): Strengthen param "jump" from
1828 rtx to rtx_insn *. Strenghten local "li" from rtx to
1829 rtx_insn_list * and use its methods for clarity and typesafety.
1830 (steal_delay_list_from_target): Strengthen param "insn" from rtx
1831 to rtx_insn *.
1832 (steal_delay_list_from_fallthrough): Likewise.
1833 (try_merge_delay_insns): Likewise for param "thread" and locals
1834 "trial", "next_trial", "delay_insn".
1835 (redundant_insn): Likewise for param "target" and local "trial".
1836 (own_thread_p): Likewise for param "thread" and locals
1837 "active_insn", "insn".
1838 (get_label_before): Likewise for param "insn".
1839 (fill_simple_delay_slots): Likewise for local "new_label"; use
1840 JUMP_LABEL_AS_INSN as necessary when calling own_thread_p.
1841 (label_before_next_insn): Strengthen return type and local "insn"
1842 from rtx to rtx_insn *.
1843 (relax_delay_slots): Likewise for locals "other", "tmp".
1844 (make_return_insns): Likewise for param "first" and locals "insn",
1845 "jump_insn", "prev". Move declaration of "pat" to its assignment
1846 and strengthen from rtx to rtx_sequence *. Use its methods for
1847 clarity and typesafety.
1848 * rtlanal.c (no_labels_between_p): Strengthen params from
1849 const_rtx to const rtx_insn *. Strengthen local "p" from rtx to
1850 rtx_insn *.
1851 (reg_used_between_p): Strengthen params "from_insn", "to_insn"
1852 from const_rtx to const rtx_insn *.
1853 (reg_set_between_p): Rename param "from_insn" to
1854 "uncast_from_insn", and reintroduce "from_insn" as a
1855 const rtx_insn * via a checked cast.
1856 (modified_between_p): Likewise for param "start" as "uncast_start".
1857 (tablejump_p): Add a cast when invoking NEXT_INSN on "label".
1858 * sel-sched-ir.c (get_seqno_by_preds): Strengthen param and locals
1859 "tmp", head" from rtx to rtx_insn *.
1860 (recompute_rev_top_order): Likewise for local "insn".
1861 * sel-sched-ir.h (get_seqno_by_preds): Likewise for param.
1862 * store-motion.c (build_store_vectors): Likewise for local "insn".
1863 Strengthen local "st" from rtx to rtx_insn_list * and use methods
1864 for clarity and typesafety.
1865 * tree-ssa-loop-ivopts.c (seq_cost): Strengthen param "seq" from
1866 rtx to rtx_insn *.
1867 (computation_cost): Likewise for local "seq".
1868 (get_address_cost): Likewise.
1869
1870 2014-08-28 David Malcolm <dmalcolm@redhat.com>
1871
1872 * rtl.h (tablejump_p): Strengthen first param from const_rtx to
1873 const rtx_insn *.
1874 (label_is_jump_target_p): Likewise for second param.
1875
1876 * rtlanal.c (tablejump_p): Likewise for param "insn".
1877 (label_is_jump_target_p): Likewise for param "jump_insn".
1878
1879 2014-08-28 David Malcolm <dmalcolm@redhat.com>
1880
1881 * rtl.h (find_first_parameter_load): Strengthen return type and
1882 both params from rtx to rtx_insn *.
1883 * rtlanal.c (find_first_parameter_load): Strengthen return type,
1884 both params and locals "before", "first_set" from rtx to
1885 rtx_insn *. Remove now-redundant cast.
1886 * except.c (sjlj_mark_call_sites): Use NULL rather than NULL_RTX.
1887
1888 2014-08-28 David Malcolm <dmalcolm@redhat.com>
1889
1890 * rtl.h (find_last_value): Delete.
1891 * rtlanal.c (find_last_value): Delete.
1892
1893 2014-08-28 David Malcolm <dmalcolm@redhat.com>
1894
1895 * cfgexpand.c (pass_expand::execute): Strengthen local "after"
1896 from rtx to rtx_insn *.
1897 * cfgrtl.c (force_nonfallthru_and_redirect): Replace use of local
1898 rtx "note" with new local rtx_insn * "new_head" when calculating
1899 head insn of new basic block.
1900 * combine.c (combine_split_insns): Strengthen return type and local
1901 "ret" from rtx to rtx_insn *.
1902 (likely_spilled_retval_p): Likewise for locals "use" and "p".
1903 (try_combine): Eliminate local "m_split", splitting into new
1904 locals "m_split_insn" and "m_split_pat".
1905 (find_split_point): Strengthen local "seq" from rtx into
1906 rtx_insn *.
1907 * config/spu/spu.c (spu_machine_dependent_reorg): Likewise for
1908 locals "label", "branch".
1909 * config/spu/spu.md (define_expand "smulsi3_highpart"): Likewise
1910 for local "insn".
1911 (define_expand "umulsi3_highpart"): Likewise for local "insn".
1912 * dse.c (note_add_store_info): Likewise for fields "first",
1913 "current".
1914 (note_add_store): Likewise for local "insn".
1915 (emit_inc_dec_insn_before): Likewise for locals "insn",
1916 "new_insn", "cur".
1917 (find_shift_sequence): Likewise for locals "shift_seq", "insn".
1918 (replace_read): Likewise for locals "insns", "this_insn".
1919 * dwarf2cfi.c (dw_trace_info): Likewise for field "eh_head".
1920 (notice_eh_throw): Likewise for param "insn".
1921 (before_next_cfi_note): Likewise for return type, param, and local
1922 "prev".
1923 (connect_traces): Likewise for local "note".
1924 * emit-rtl.c (reset_all_used_flags): Likewise for local "p".
1925 (verify_rtl_sharing): Likewise.
1926 (unshare_all_rtl_in_chain): Likewise for param "insn".
1927 (get_first_nonnote_insn): Likewise for local "insn".
1928 (get_last_nonnote_insn): Likewise. Introduce local rtx_sequence *
1929 "seq" and use its methods to clarify things.
1930 (next_insn): Strengthen return type from rtx to rtx_insn *.
1931 Rename param "insn" to "uncast_insn" and reintroduce "insn" as a
1932 local rtx_insn * using a checked cast, dropping a checked cast
1933 made redundant by this change. Use a cast to and method of
1934 rtx_sequence to clarify the code.
1935 (previous_insn): Rename param "insn" to "uncast_insn" and
1936 reintroduce "insn" as a local rtx_insn * using a checked cast,
1937 dropping a checked cast made redundant by this change. Use a cast
1938 to and method of rtx_sequence to clarify the code.
1939 (next_nonnote_insn): Rename param "insn" to "uncast_insn" and
1940 reintroduce "insn" as a local rtx_insn * using a checked cast,
1941 dropping a checked cast made redundant by this change.
1942 (next_nonnote_insn_bb): Likewise.
1943 (prev_nonnote_insn): Likewise.
1944 (prev_nonnote_insn_bb): Likewise.
1945 (next_nondebug_insn): Likewise.
1946 (prev_nondebug_insn): Likewise.
1947 (next_nonnote_nondebug_insn): Likewise.
1948 (prev_nonnote_nondebug_insn): Likewise.
1949 (next_real_insn): Likewise.
1950 (prev_real_insn): Likewise.
1951 (next_active_insn): Likewise.
1952 (prev_active_insn): Likewise.
1953 (next_cc0_user): Likewise. Use rtx_sequence and a method for
1954 clarity.
1955 (prev_cc0_setter): Likewise.
1956 (try_split): Rename param "trial" to "uncast_trial" and
1957 reintroduce "insn" as a local rtx_insn * using a checked cast,
1958 dropping checked casts made redundant by this change.
1959 Strengthen locals "seq", "tem", "insn_last", "insn", "next" from
1960 rtx to rtx_insn *.
1961 (remove_insn): Rename param "insn" to "uncast_insn" and
1962 reintroduce "insn" as a local rtx_insn * using a checked cast.
1963 (emit_pattern_after_setloc): Likewise for param "after", as
1964 "uncast_after".
1965 (emit_pattern_after): Likewise. Strengthen local "prev" from
1966 rtx to rtx_insn *.
1967 (emit_pattern_before_setloc): Rename param "before" to
1968 "uncast_before" and reintroduce "before" as a local rtx_insn *
1969 using a checked cast. Strengthen locals "first", "last" from
1970 rtx to rtx_insn *.
1971 (emit_pattern_before): Likewise rename/cast param "before" to
1972 "uncast_before". Strengthen local "next" from rtx to rtx_insn *.
1973 * except.c (copy_reg_eh_region_note_forward): Strengthen param
1974 "first" and local "insn" from rtx to rtx_insn *.
1975 (copy_reg_eh_region_note_backward): Likewise for param "last"
1976 and local "insn".
1977 * expr.c (fixup_args_size_notes): Rename param "last" to
1978 "uncast_last" and reintroduce "last" as a local rtx_insn *
1979 using a checked cast. Strengthen local "insn" from rtx to
1980 rtx_insn *.
1981 * function.c (set_insn_locations): Strengthen param "insn" from
1982 rtx to rtx_insn *.
1983 (record_insns): Likewise for param "insns" and local "tmp".
1984 (active_insn_between): Rename param "tail" to
1985 "uncast_tail" and reintroduce "tail" as a local rtx_insn *
1986 using a checked cast.
1987 (thread_prologue_and_epilogue_insns): Split out top-level local
1988 rtx "seq" into three different rtx_insn * locals. Strengthen
1989 local "prologue_seq" from rtx to rtx_insn *.
1990 * gcse.c (insert_insn_end_basic_block): Strenghen local "insn"
1991 from rtx to rtx_insn *.
1992 * haifa-sched.c (initiate_bb_reg_pressure_info): Likewise.
1993 (priority): Likewise for locals "prev_first", "twin".
1994 (setup_insn_max_reg_pressure): Likewise for param "after".
1995 (sched_setup_bb_reg_pressure_info): Likewise.
1996 (no_real_insns_p): Strengthen params from const_rtx to
1997 const rtx_insn *.
1998 (schedule_block): Strengthen local "next_tail" from rtx to
1999 rtx_insn *.
2000 * ifcvt.c (find_active_insn_before): Strengthen return type and
2001 param "insn" from rtx to rtx_insn *.
2002 (find_active_insn_after): Likewise.
2003 (cond_exec_process_insns): Likewise for param "start" and local "insn".
2004 (cond_exec_process_if_block): Likewise for locals "then_start",
2005 "then_end", "else_start", "else_end", "insn", "start", "end", "from".
2006 (noce_process_if_block): Likewise for local "jump".
2007 (merge_if_block): Likewise for two locals named "end".
2008 (cond_exec_find_if_block): Likewise for local "last_insn".
2009 * jump.c (delete_related_insns): Rename param "insn" to
2010 "uncast_insn" and reintroduce "insn" as a local rtx_insn * using a
2011 checked cast. Strengthen local "p" from rtx to rtx_insn *.
2012 * lra-constraints.c (inherit_reload_reg): Replace NULL_RTX with
2013 NULL.
2014 (split_reg): Likewise.
2015 * lra.c (lra_process_new_insns): Likewise.
2016 * modulo-sched.c (permute_partial_schedule): Strengthen param
2017 "last" from rtx to rtx_insn *.
2018 * optabs.c (add_equal_note): Likewise for param "insns" and local
2019 "last_insn".
2020 (expand_binop_directly): Add checked casts to rtx_insn * within
2021 NEXT_INSN (pat) uses.
2022 (expand_unop_direct): Likewise.
2023 (maybe_emit_unop_insn): Likewise.
2024 * recog.c (peep2_attempt): Strengthen locals "last",
2025 "before_try", "x" from rtx to rtx_insn *.
2026 * reorg.c (optimize_skip): Strengthen return type and local
2027 "delay_list" from rtx to rtx_insn_list *. Strengthen param "insn"
2028 and locals "trial", "next_trial" from rtx to rtx_insn *.
2029 * resource.c (next_insn_no_annul): Strengthen return type and
2030 param "insn" from rtx to rtx_insn *. Use a cast to and method of
2031 rtx_sequence to clarify the code.
2032 (mark_referenced_resources): Add a checked cast to rtx_insn *
2033 within PREV_INSN (x).
2034 (find_dead_or_set_registers): Strengthen return type, param
2035 "target", locals "insn", "next", "jump_insn", "this_jump_insn"
2036 from rtx to rtx_insn *. Strengthen param "jump_target" from rtx *
2037 to rtx_insn **.
2038 (mark_target_live_regs): Strengthen params "insns" and "target",
2039 locals "insn", "jump_target", "start_insn", "stop_insn" from rtx
2040 to rtx_insn *. Use cast to and method of rtx_sequence to clarify
2041 the code.
2042 * resource.h (mark_target_live_regs): Strengthen params 1 and 2
2043 from rtx to rtx_insn *.
2044 * rtl.h (copy_reg_eh_region_note_forward): Strengthen second param
2045 from rtx to rtx_insn *.
2046 (copy_reg_eh_region_note_backward): Likewise.
2047 (unshare_all_rtl_in_chain): Likewise for sole param.
2048 (dump_rtl_slim): Strengthen second and third params from const_rtx
2049 to const rtx_insn *.
2050 * sched-deps.c (sched_free_deps): Strengthen params "head" and
2051 "tail" and locals "insn", "next_tail" from rtx to rtx_insn *.
2052 * sched-ebb.c (init_ready_list): Strengthen locals "prev_head",
2053 "next_tail" from rtx to rtx_insn *.
2054 (begin_move_insn): Likewise for local "next".
2055 * sched-int.h (sched_free_deps): Likewise for first and second
2056 params.
2057 (no_real_insns_p): Strengthen both params from const_rtx to
2058 const rtx_insn *.
2059 (sched_setup_bb_reg_pressure_info): Strengthen second params from
2060 rtx to rtx_insn *.
2061 * sched-rgn.c (init_ready_list): Likewise for locals "prev_head",
2062 "next_tail".
2063 * sched-vis.c (dump_rtl_slim): Strengthen params "first", "last"
2064 and locals "insn", "tail" from const_rtx to const rtx_insn *.
2065 (rtl_dump_bb_for_graph): Strengthen local "insn" from rtx to
2066 rtx_insn *.
2067 (debug_rtl_slim): Strengthen params "first" and "last" from
2068 const_rtx to const rtx_insn *.
2069 * shrink-wrap.c (try_shrink_wrapping): Strengthen param
2070 "prologue_seq" and locals "seq", "p_insn" from rtx to rtx_insn *.
2071 (convert_to_simple_return): Likewise for param "returnjump".
2072 * shrink-wrap.h (try_shrink_wrapping): Likewise for param
2073 "prologue_seq".
2074 (convert_to_simple_return): Likewise for param "returnjump".
2075 * valtrack.c (propagate_for_debug): Likewise for params
2076 "insn", "last".
2077 * valtrack.h (propagate_for_debug): Likewise for second param.
2078
2079 2014-08-28 David Malcolm <dmalcolm@redhat.com>
2080
2081 * output.h (insn_current_reference_address): Strengthen param
2082 from rtx to rtx_insn *.
2083 * final.c (insn_current_reference_address): Likewise.
2084
2085 2014-08-28 David Malcolm <dmalcolm@redhat.com>
2086
2087 * basic-block.h (inside_basic_block_p): Strengthen param from
2088 const_rtx to const rtx_insn *.
2089 * cfgbuild.c (inside_basic_block_p): Likewise.
2090
2091 2014-08-28 David Malcolm <dmalcolm@redhat.com>
2092
2093 * dwarf2cfi.c (dw_trace_info): Strengthen field "head" from rtx to
2094 rtx_insn *.
2095 (get_trace_info): Likewise for param "insn".
2096 (save_point_p): Likewise.
2097 (maybe_record_trace_start): Likewise for both params.
2098 (maybe_record_trace_start_abnormal): Likewise.
2099 (create_trace_edges): Likewise for sole param and for three of the
2100 locals named "lab".
2101 (scan_trace): Strengthen local "prev", "insn", "control" from rtx
2102 to rtx_insn *, and update a call to pat->element to pat->insn.
2103
2104 2014-08-28 David Malcolm <dmalcolm@redhat.com>
2105
2106 * function.h (struct expr_status): Convert field "x_forced_labels"
2107 from rtx_expr_list * to rtx_insn_list *.
2108
2109 * cfgbuild.c (make_edges): Convert local "x" from an
2110 rtx_expr_list * to an rtx_insn_list *, replacing use of
2111 "element" method with "insn" method.
2112 * dwarf2cfi.c (create_trace_edges): Likewise for local "lab".
2113 * except.c (sjlj_emit_dispatch_table): Replace use of
2114 gen_rtx_EXPR_LIST with gen_rtx_INSN_LIST when prepending to
2115 forced_labels.
2116 * jump.c (rebuild_jump_labels_1): Convert local "insn" from an
2117 rtx_expr_list * to an rtx_insn_list *, replacing use of
2118 "element" method with "insn" method.
2119 * reload1.c (set_initial_label_offsets): Likewise for local "x".
2120 * stmt.c (label_rtx): Strengthen local "ref" from rtx to
2121 rtx_insn *, adding a checked cast. Replace use of
2122 gen_rtx_EXPR_LIST with gen_rtx_INSN_LIST when prepending it to
2123 forced_labels.
2124 (expand_label): Likewise for local "label_r".
2125
2126 2014-08-28 David Malcolm <dmalcolm@redhat.com>
2127
2128 * function.h (struct rtl_data): Convert field
2129 "x_nonlocal_goto_handler_labels" from rtx_expr_list * to
2130 rtx_insn_list *.
2131 * rtl.h (remove_node_from_insn_list): New prototype.
2132
2133 * builtins.c (expand_builtin): When prepending to
2134 nonlocal_goto_handler_labels, use gen_rtx_INSN_LIST rather than
2135 gen_rtx_EXPR_LIST.
2136 * cfgbuild.c (make_edges): Convert local "x" from rtx_expr_list *
2137 to rtx_insn_list *, and use its "insn" method rather than
2138 "element" method.
2139 * cfgrtl.c (delete_insn): Use new function
2140 remove_node_from_insn_list rather than
2141 remove_node_from_expr_list.
2142 (cfg_layout_initialize): Convert local "x" from rtx_expr_list *
2143 to rtx_insn_list *, and use its "insn" method rather than
2144 "element" method.
2145 * dwarf2cfi.c (create_trace_edges): Likewise for local "lab".
2146 * reload1.c (set_initial_label_offsets): Likewise for local "x".
2147 * rtlanal.c (remove_node_from_insn_list): New function, adapted
2148 from remove_node_from_expr_list.
2149 * stmt.c (expand_label): When prepending to
2150 nonlocal_goto_handler_labels, use gen_rtx_INSN_LIST rather than
2151 gen_rtx_EXPR_LIST.
2152
2153 2014-08-28 David Malcolm <dmalcolm@redhat.com>
2154
2155 * function.h (struct rtl_data): Strengthen fields "x_return_label"
2156 and "x_naked_return_label" from rtx to rtx_code_label *.
2157
2158 2014-08-28 David Malcolm <dmalcolm@redhat.com>
2159
2160 * rtl.h (SET_PREV_INSN): Strengthen param from rtx to rtx_insn *.
2161 (SET_NEXT_INSN): Likewise.
2162 (gen_rtvec_v): Add an overload for param types (int, rtx_insn **).
2163
2164 * config/c6x/c6x.c (gen_one_bundle): Strengthen param "slot" from
2165 rtx * to rtx_insn **. Introduce a new local rtx "seq", using it
2166 to split out the SEQUENCE from local "bundle", strengthening the
2167 latter from rtx to rtx_insn * to hold the insn holding the SEQUENCE.
2168 Strengthen locals "t" and "insn" from rtx to rtx_insn *.
2169 (c6x_gen_bundles): Strengthen locals "insn", "next", "last_call"
2170 and the type of the elements of the "slot" array from rtx to
2171 rtx_insn *.
2172 (reorg_split_calls): Likewise for locals "insn" and "next", and
2173 the type of the elements of the "slot" array.
2174
2175 * config/frv/frv.c (frv_nops): Likewise for the elements of this
2176 array.
2177 (frv_function_prologue): Likewise for locals "insn", "next",
2178 "last_call".
2179 (frv_register_nop): Introduce a local "nop_insn" to be the
2180 rtx_insn * containing rtx "nop".
2181
2182 * config/mep/mep.c (mep_make_bundle): Param "core" is sometimes
2183 used as an insn and sometimes as a pattern, so rename it to
2184 "core_insn_or_pat", and introduce local rtx_insn * "core_insn",
2185 using it where dealing with the core insn.
2186
2187 * config/picochip/picochip.c (reorder_var_tracking_notes):
2188 Strengthen locals "insn", "next", "last_insn", "queue",
2189 "next_queue", "prev" from rtx to rtx_insn *.
2190
2191 * emit-rtl.c (gen_rtvec_v): Add overloaded implementation for when
2192 the second param is an rtx_insn ** rather than an rtx **.
2193 (link_insn_into_chain): Strengthen locals "seq" and "sequence"
2194 from rtx to rtx_sequence *, and introduce local named "sequence",
2195 using methods of rtx_sequence to clarify the code.
2196 (remove_insn): Introduce local rtx_sequence * named "sequence" and
2197 use its methods.
2198 (emit_insn_after_1): Strengthen return type from rtx to rtx_insn *.
2199 Rename param "after" to "uncast_after", reintroducing "after" as a
2200 local rtx_insn * with a checked cast.
2201 (emit_pattern_after_noloc): Rename param "after" to "uncast_after",
2202 reintroducing "after" as a local rtx_insn * with a checked cast.
2203 Strengthen local "last" from rtx to rtx_insn * and remove the
2204 now-redundant checked casts.
2205 (copy_delay_slot_insn): Strengthen return type and param from rtx
2206 to rtx_insn *.
2207
2208 * haifa-sched.c (reemit_notes): Strengthen params "insn" and
2209 "last" from rtx to rtx_insn *.
2210
2211 2014-08-28 David Malcolm <dmalcolm@redhat.com>
2212
2213 * emit-rtl.h (copy_delay_slot_insn): Strengthen return type and
2214 param from rtx to rtx_insn *.
2215
2216 * emit-rtl.c (copy_delay_slot_insn): Likewise.
2217
2218 * reorg.c (skip_consecutive_labels): Strengthen return type, param
2219 and local "insn" from rtx to rtx_insn *.
2220 (unfilled_slots_base): Strengthen type from rtx * to rtx_insn **.
2221 (unfilled_slots_next): Likewise.
2222 (function_return_label): Strengthen from rtx to rtx_code_label *.
2223 (function_simple_return_label): Likewise.
2224 (first_active_target_insn): Strengthen return type and param from
2225 rtx to rtx_insn *.
2226 (find_end_label): Strengthen return type from rtx to
2227 rtx_code_label *; strengthen locals as appropriate.
2228 (emit_delay_sequence): Strengthen return type, param "insn" and
2229 local "seq_insn" from rtx to rtx_insn *. Strengthen param "list"
2230 and local "li" from rtx to rtx_insn_list *, using methods of
2231 rtx_insn_list for clarity and typesafety.
2232 (add_to_delay_list): Strengthen return type and param "insn" from
2233 rtx to rtx_insn *. Strengthen param "delay_list" from rtx to
2234 rtx_insn_list * and use methods of rtx_insn_list.
2235 (delete_from_delay_slot): Strengthen return type, param "insn",
2236 locals "trial", "seq_insn", "prev" from rtx to rtx_insn *.
2237 Strengthen local "seq" from rtx to rtx_sequence *, and local
2238 "delay_list" from rtx to rtx_insn_list *, using methods of
2239 rtx_sequence for clarity and type-safety.
2240 (delete_scheduled_jump): Add checked cast when invoking
2241 delete_from_delay_slot. Strengthen local "trial" from rtx to
2242 rtx_insn *.
2243 (optimize_skip): Strengthen return type and local "delay_list"
2244 from rtx to rtx_insn_list *. Strengthen local "trial" from rtx to
2245 rtx_insn *.
2246 (steal_delay_list_from_target): Strengthen return type, param
2247 "delay_list" and local "new_delay_list" from rtx to
2248 rtx_insn_list *. Strengthen param "seq" from rtx to
2249 rtx_sequence *. Strengthen param "pnew_thread" from rtx * to
2250 rtx_insn **.
2251 Split out local "temp" into multiple more-tightly scoped locals:
2252 sometimes an rtx_insn_list *, and once a rtx_insn *. Use methods
2253 of rtx_insn_list and rtx_sequence for clarity and typesafety.
2254 Strengthen locals named "trial" from rtx to rtx_insn *.
2255 (steal_delay_list_from_fallthrough): Strengthen return type and
2256 param "delay_list" from rtx to rtx_insn_list *. Strengthen param
2257 "seq" from rtx to rtx_sequence *. Use methods of rtx_sequence.
2258 Strengthen local "trial" from rtx to rtx_insn *.
2259 (try_merge_delay_insns): Strength local "merged_insns" from rtx
2260 to rtx_insn_list * and use its methods. Strengthen local "pat"
2261 from rtx to rtx_sequence * and use its methods. Strengthen locals
2262 "dtrial" and "new_rtx" from rtx to rtx_insn *.
2263 (get_label_before): Strengthen return type and local "label" from
2264 rtx to rtx_insn *.
2265 (fill_simple_delay_slots): Likewise for locals "insn", "trial",
2266 "next_trial", "next", prev". Strengthen local "delay_list" from
2267 rtx to rtx_insn_list * Strengthen local "tmp" from rtx * to
2268 rtx_insn **.
2269 (follow_jumps): Strengthen return type, param "label" and locals
2270 "insn", "next", "value", "this_label" from rtx to rtx_insn *.
2271 (fill_slots_from_thread): Strengthen return type, param
2272 "delay_list" from rtx to rtx_insn_list *. Strengthen params
2273 "insn", "thread", "opposite_thread" and locals "new_thread",
2274 "trial", "temp", "ninsn" from rtx to rtx_insn *. Introduce local
2275 "sequence" from a checked cast to rtx_sequence so that we can call
2276 steal_delay_list_from_target and steal_delay_list_from_fallthrough
2277 with an rtx_sequence *.
2278 (fill_eager_delay_slots): Strengthen locals "insn", "target_label",
2279 "insn_at_target", "fallthrough_insn" from rtx to rtx_insn *.
2280 Strengthen local "delay_list" from rtx to rtx_insn_list *.
2281 (relax_delay_slots): Strengthen param "first" and locals "insn",
2282 "next", "trial", "delay_insn", "target_label" from rtx to
2283 rtx_insn *. Strengthen local "pat" from rtx to rtx_sequence *.
2284 Introduce a local "trial_seq" for PATTERN (trial) of type
2285 rtx_sequence *, in both cases using methods of rtx_sequence.
2286 (dbr_schedule): Strengthen param "first" and locals "insn",
2287 "next", "epilogue_insn" from rtx to rtx_insn *.
2288
2289 2014-08-28 Richard Biener <rguenther@suse.de>
2290
2291 PR tree-optimization/62283
2292 * tree-vect-data-refs.c (vect_enhance_data_refs_alignment):
2293 Do not peel loops for alignment where the vector loop likely
2294 doesn't run at least VF times.
2295
2296 2014-08-28 Bin Cheng <bin.cheng@arm.com>
2297
2298 * tree-ssa-loop-ivopts.c (iv_ca_add_use): Delete parameter
2299 important_candidates. Consider all important candidates if
2300 IVS doesn't give any result. Remove check on ivs->upto.
2301 (try_add_cand_for): Call iv_ca_add_use only once.
2302
2303 2014-08-28 Alexander Ivchenko <alexander.ivchenko@intel.com>
2304 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
2305 Anna Tikhonova <anna.tikhonova@intel.com>
2306 Ilya Tocar <ilya.tocar@intel.com>
2307 Andrey Turetskiy <andrey.turetskiy@intel.com>
2308 Ilya Verbin <ilya.verbin@intel.com>
2309 Kirill Yukhin <kirill.yukhin@intel.com>
2310 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
2311
2312 (define_mode_iterator VI12_AVX2): Add V64QI and V32HI modes.
2313 (define_expand "<sse2_avx2>_<plusminus_insn><mode>3<mask_name>"): Add
2314 masking.
2315 (define_insn "*<sse2_avx2>_<plusminus_insn><mode>3<mask_name>"): Ditto.
2316 (define_expand "<sse2_avx2>_uavg<mode>3<mask_name>"): Ditto.
2317 (define_insn "*<sse2_avx2>_uavg<mode>3<mask_name>"): Ditto.
2318 (define_insn "*mul<mode>3"): Add EVEX version.
2319
2320 2014-08-28 Alexander Ivchenko <alexander.ivchenko@intel.com>
2321 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
2322 Anna Tikhonova <anna.tikhonova@intel.com>
2323 Ilya Tocar <ilya.tocar@intel.com>
2324 Andrey Turetskiy <andrey.turetskiy@intel.com>
2325 Ilya Verbin <ilya.verbin@intel.com>
2326 Kirill Yukhin <kirill.yukhin@intel.com>
2327 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
2328
2329 * config/i386/sse.md
2330 (define_insn "avx512bw_interleave_highv64qi<mask_name>"): New.
2331 (define_insn "avx2_interleave_highv32qi<mask_name>"): Add masking.
2332 (define_insn "vec_interleave_highv16qi<mask_name>"): Ditto.
2333 (define_insn "avx2_interleave_lowv32qi<mask_name>"): Ditto.
2334 (define_insn "vec_interleave_lowv16qi<mask_name>"): Ditto.
2335 (define_insn "avx2_interleave_highv16hi<mask_name>"): Ditto.
2336 (define_insn "vec_interleave_highv8hi<mask_name>"): Ditto.
2337 (define_insn "avx2_interleave_lowv16hi<mask_name>"): Ditto.
2338 (define_insn "vec_interleave_lowv8hi<mask_name>"): Ditto.
2339 (define_insn "avx2_interleave_highv8si<mask_name>"): Ditto.
2340 (define_insn "vec_interleave_highv4si<mask_name>"): Ditto.
2341 (define_insn "avx2_interleave_lowv8si<mask_name>"): Ditto.
2342 (define_insn "vec_interleave_lowv4si<mask_name>"): Ditto.
2343 (define_insn "vec_interleave_highv16qi<mask_name>"): New.
2344 (define_insn "avx512bw_interleave_highv32hi<mask_name>"): Ditto.
2345 (define_insn "<mask_codefor>avx512bw_interleave_lowv32hi<mask_name>"): Ditto.
2346
2347 2014-08-28 Alexander Ivchenko <alexander.ivchenko@intel.com>
2348 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
2349 Anna Tikhonova <anna.tikhonova@intel.com>
2350 Ilya Tocar <ilya.tocar@intel.com>
2351 Andrey Turetskiy <andrey.turetskiy@intel.com>
2352 Ilya Verbin <ilya.verbin@intel.com>
2353 Kirill Yukhin <kirill.yukhin@intel.com>
2354 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
2355
2356 * config/i386/sse.md
2357 (define_mode_iterator VIMAX_AVX2): Add V4TI mode.
2358 (define_insn "<sse2_avx2>_ashl<mode>3"): Add EVEX version.
2359 (define_insn "<sse2_avx2>_lshr<mode>3"): Ditto.
2360
2361 2014-08-28 Alexander Ivchenko <alexander.ivchenko@intel.com>
2362 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
2363 Anna Tikhonova <anna.tikhonova@intel.com>
2364 Ilya Tocar <ilya.tocar@intel.com>
2365 Andrey Turetskiy <andrey.turetskiy@intel.com>
2366 Ilya Verbin <ilya.verbin@intel.com>
2367 Kirill Yukhin <kirill.yukhin@intel.com>
2368 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
2369
2370 * config/i386/sse.md
2371 (define_mode_iterator VI128_256): New.
2372 (define_insn "<mask_codefor><code><mode>3<mask_name>"): Ditto.
2373
2374 2014-08-28 Alexander Ivchenko <alexander.ivchenko@intel.com>
2375 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
2376 Anna Tikhonova <anna.tikhonova@intel.com>
2377 Ilya Tocar <ilya.tocar@intel.com>
2378 Andrey Turetskiy <andrey.turetskiy@intel.com>
2379 Ilya Verbin <ilya.verbin@intel.com>
2380 Kirill Yukhin <kirill.yukhin@intel.com>
2381 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
2382
2383 * config/i386/sse.md
2384 (define_mode_iterator VI8_256_512): New.
2385 (define_insn "<mask_codefor>avx512dq_cvtps2qq<mode><mask_name><round_name>"):
2386 Ditto.
2387 (define_insn "<mask_codefor>avx512dq_cvtps2qqv2di<mask_name>"): Ditto.
2388 (define_insn "<mask_codefor>avx512dq_cvtps2uqq<mode><mask_name><round_name>"):
2389 Ditto.
2390 (define_insn "<mask_codefor>avx512dq_cvtps2uqqv2di<mask_name>"): Ditto.
2391
2392 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2393
2394 * varasm.c (compute_reloc_for_rtx_1): Take a const_rtx. Remove the
2395 pointer to the cumulative reloc value and return the value for
2396 this reloc instead.
2397 (compute_reloc_for_rtx): Take a const_rtx. Call
2398 compute_reloc_for_rtx_1 directly for SYMBOL_REF and LABEL_REF,
2399 avoiding any recursion. Use FOR_EACH_SUBRTX rather than
2400 for_each_rtx for the CONST case.
2401
2402 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2403
2404 * varasm.c (mark_constant): Replace this for_each_rtx callback with...
2405 (mark_constants_in_pattern): ...this new function to iterate over
2406 all the subrtxes.
2407 (mark_constants): Update accordingly.
2408
2409 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2410
2411 * varasm.c: Include rtl-iter.h.
2412 (const_rtx_hash_1): Take a const_rtx rather than an rtx *.
2413 Remove the pointer to the cumulative hashval_t and just return
2414 the hash for this rtx instead. Remove recursive CONST_VECTOR case.
2415 (const_rtx_hash): Use FOR_EACH_SUBRTX instead of for_each_rtx.
2416 Accumulate the hashval_ts here instead of const_rtx_hash_1.
2417
2418 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2419
2420 * var-tracking.c (add_uses): Take an rtx rather than an rtx *.
2421 Give real type of data parameter. Remove return value.
2422 (add_uses_1): Use FOR_EACH_SUBRTX_VAR rather than for_each_rtx
2423 to iterate over subrtxes.
2424
2425 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2426
2427 * var-tracking.c (use_narrower_mode_test): Turn from being a
2428 for_each_rtx callback to being a function that examines each
2429 subrtx itself.
2430 (adjust_mems): Update accordingly.
2431
2432 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2433
2434 * var-tracking.c (non_suitable_const): Turn from being a for_each_rtx
2435 callback to being a function that examines each subrtx itself.
2436 Remove handling of null rtxes.
2437 (add_uses): Update accordingly.
2438
2439 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2440
2441 * var-tracking.c: Include rtl-iter.h.
2442 (rtx_debug_expr_p): Turn from being a for_each_rtx callback
2443 to being a function that examines each subrtx itself.
2444 (use_type): Update accordingly.
2445
2446 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2447
2448 * store-motion.c: Include rtl-iter.h.
2449 (extract_mentioned_regs_1): Delete.
2450 (extract_mentioned_regs): Use FOR_EACH_SUBRTX_VAR rather than
2451 for_each_rtx to iterate over subrtxes.
2452
2453 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2454
2455 * sel-sched.c: Include rtl-iter.h
2456 (count_occurrences_1): Delete.
2457 (count_occurrences_equiv): Turn rtxes into const_rtxes.
2458 Use FOR_EACH_SUBRTX rather than for_each_rtx.
2459
2460 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2461
2462 * rtl.h (tls_referenced_p): Take a const_rtx rather than an rtx.
2463 * rtlanal.c (tls_referenced_p_1): Delete.
2464 (tls_referenced_p): Take a const_rtx rather than an rtx.
2465 Use FOR_EACH_SUBRTX rather than for_each_rtx.
2466
2467 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2468
2469 * rtl.h (for_each_inc_dec_fn): Remove special case for -1.
2470 (for_each_inc_dec): Take an rtx rather than an rtx *.
2471 * cselib.c (cselib_record_autoinc_cb): Update accordingly.
2472 (cselib_record_sets): Likewise.
2473 * dse.c (emit_inc_dec_insn_before, check_for_inc_dec_1)
2474 (check_for_inc_dec): Likewise.
2475 * rtlanal.c (for_each_inc_dec_ops): Delete.
2476 (for_each_inc_dec_find_inc_dec): Take the MEM as argument,
2477 rather than a pointer to the memory address. Replace
2478 for_each_inc_dec_ops argument with separate function and data
2479 arguments. Abort on non-autoinc addresses.
2480 (for_each_inc_dec_find_mem): Delete.
2481 (for_each_inc_dec): Take an rtx rather than an rtx *. Use
2482 FOR_EACH_SUBRTX_VAR to visit every autoinc MEM.
2483
2484 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2485
2486 * rtl.h (find_all_hard_regs): Declare.
2487 * rtlanal.c (find_all_hard_regs): New function.
2488 (record_hard_reg_uses_1): Delete.
2489 (record_hard_reg_uses): Use find_all_hard_regs.
2490
2491 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2492
2493 * rtl.h (replace_label_data): Delete.
2494 (replace_label): Take the old label, new label and update-nuses flag
2495 as direct arguments. Return void.
2496 * cfgcleanup.c (outgoing_edges_match): Update accordingly.
2497 * rtlanal.c (replace_label): Update interface as above. Handle
2498 JUMP_TABLE_DATA as a special case. Handle JUMPs outside the
2499 iterator. Use FOR_EACH_SUBRTX_PTR.
2500
2501 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2502
2503 * rtl.h (get_pool_constant, rtx_referenced_p): Replace rtx parameters
2504 with const_rtx parameters.
2505 * varasm.c (get_pool_constant): Likewise.
2506 * rtlanal.c (rtx_referenced_p_1): Delete.
2507 (rtx_referenced_p): Use FOR_EACH_SUBRTX instead of for_each_rtx.
2508 Assert that the rtx we're looking for is nonnull. Allow searches
2509 for constant pool SYMBOL_REFs.
2510
2511 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2512
2513 * reload1.c: Include rtl-iter.h.
2514 (note_reg_elim_costly): Turn from being a for_each_rtx callback
2515 to being a function that examines each subrtx itself.
2516 (eliminate_regs_1, elimination_costs_in_insn): Update accordingly.
2517
2518 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2519
2520 * regcprop.c (cprop_find_used_regs_1): Delete.
2521 (cprop_find_used_regs): Use FOR_EACH_SUBRTX instead of for_each_rtx.
2522
2523 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2524
2525 * regcprop.c: Include rtl-iter.h.
2526 (kill_value): Take a const_rtx.
2527 (kill_autoinc_value): Turn from being a for_each_rtx callback
2528 to being a function that examines each subrtx itself.
2529 (copyprop_hardreg_forward_1): Update accordingly.
2530
2531 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2532
2533 * reg-stack.c: Include rtl-iter.h.
2534 (subst_stack_regs_in_debug_insn): Delete.
2535 (subst_all_stack_regs_in_debug_insn): Use FOR_EACH_SUBRTX_PTR
2536 instead of for_each_rtx.
2537
2538 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2539
2540 * lower-subreg.c (find_decomposable_subregs): Turn from being
2541 a for_each_rtx callback to being a function that examines each
2542 subrtx itself. Remove handling of null rtxes.
2543 (decompose_multiword_subregs): Update accordingly.
2544
2545 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2546
2547 * lower-subreg.c (adjust_decomposed_uses): Delete.
2548 (resolve_debug): Use FOR_EACH_SUBRTX_PTR rather than for_each_rtx.
2549 Remove handling of null rtxes.
2550
2551 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2552
2553 * lower-subreg.c: Include rtl-iter.h.
2554 (resolve_subreg_use): Turn from being a for_each_rtx callback
2555 to being a function that examines each subrtx itself. Remove
2556 handling of null rtxes.
2557 (resolve_reg_notes, resolve_simple_move): Update accordingly.
2558 (decompose_multiword_subregs): Likewise.
2559
2560 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2561
2562 * loop-iv.c (altered_reg_used): Turn from being a for_each_rtx callback
2563 to being a function that examines each subrtx itself.
2564 (simplify_using_condition, simplify_using_initial_values): Update
2565 accordingly.
2566
2567 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2568
2569 * loop-iv.c: Include rtl-iter.h.
2570 (find_single_def_src): New function.
2571 (replace_single_def_regs): Turn from being a for_each_rtx callback
2572 to being a function that examines each subrtx itself.
2573 (replace_in_expr, simplify_using_initial_values): Update accordingly.
2574
2575 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2576
2577 * jump.c (eh_returnjump_p_1): Delete.
2578 (eh_returnjump_p): Use FOR_EACH_SUBRTX rather than for_each_rtx.
2579 Remove handling of null rtxes.
2580
2581 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2582
2583 * jump.c: Include rtl-iter.h.
2584 (returnjump_p_1): Delete.
2585 (returnjump_p): Use FOR_EACH_SUBRTX rather than for_each_rtx.
2586 Remove handling of null rtxes.
2587
2588 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2589
2590 * ira.c: Include rtl-iter.h.
2591 (set_paradoxical_subreg): Turn from being a for_each_rtx callback
2592 to being a function that examines each subrtx itself. Remove
2593 handling of null rtxes.
2594 (update_equiv_regs): Update call accordingly.
2595
2596 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2597
2598 * fwprop.c: Include rtl-iter.h.
2599 (varying_mem_p): Turn from being a for_each_rtx callback to being
2600 a function that examines each subrtx itself.
2601 (propagate_rtx): Update accordingly.
2602
2603 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2604
2605 * function.c: Include rtl-iter.h
2606 (instantiate_virtual_regs_in_rtx): Turn from being a for_each_rtx
2607 callback to being a function that examines each subrtx itself.
2608 Return the changed flag.
2609 (instantiate_virtual_regs_in_insn, instantiate_decl_rtl)
2610 (instantiate_virtual_regs): Update calls accordingly.
2611
2612 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2613
2614 * final.c: Include rtl-iter.h.
2615 (mark_symbol_ref_as_used): Delete.
2616 (mark_symbol_refs_as_used): Use FOR_EACH_SUBRTX instead of
2617 for_each_rtx.
2618
2619 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2620
2621 * emit-rtl.c: Include rtl-iter.h.
2622 (find_auto_inc): Turn from being a for_each_rtx callback to being
2623 a function that examines each subrtx itself. Assume the first operand
2624 to an RTX_AUTOINC is the automodified register.
2625 (try_split): Update call accordingly.
2626
2627 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2628
2629 * dwarf2out.c (resolve_one_addr): Remove unused data parameter.
2630 Return a bool, inverting the result so that 0/false means "not ok".
2631 Use FOR_EACH_SUBRTX_PTR instead of for_each_rtx to iterate over
2632 subrtxes of a CONST.
2633 (mem_loc_descriptor, add_const_value_attribute)
2634 (resolve_addr_in_expr): Update calls accordingly.
2635
2636 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2637
2638 * dwarf2out.c: Include rtl-iter.h.
2639 (const_ok_for_output_1): Take the rtx instead of a pointer to it.
2640 Remove unused data parameter. Return a bool, inverting the result
2641 so that 0/false means "not ok".
2642 (const_ok_for_output): Update accordingly. Use FOR_EACH_SUBRTX_VAR
2643 instead of for_each_rtx.
2644
2645 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2646
2647 * dse.c: Include rtl-iter.h.
2648 (check_mem_read_rtx): Change void * parameter to real type.
2649 Remove return value.
2650 (check_mem_read_use): Fix comment. Use FOR_EACH_SUBRTX_PTR instead of
2651 for_each_rtx. Don't handle null rtxes.
2652
2653 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2654
2655 * df-problems.c: Include rtl-iter.h.
2656 (find_memory): Turn from being a for_each_rtx callback to being
2657 a function that examines each subrtx itself. Continue to look for
2658 volatile references even after a nonvolatile one has been found.
2659 (can_move_insns_across): Update calls accordingly.
2660
2661 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2662
2663 * ddg.c (walk_mems_2, walk_mems_1): Delete.
2664 (insns_may_alias_p): Use FOR_EACH_SUBRTX rather than for_each_rtx
2665 to iterate over subrtxes. Return a bool rather than an int.
2666
2667 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2668
2669 * ddg.c: Include rtl-iter.h.
2670 (mark_mem_use_1): Rename to...
2671 (mark_mem_use): ...deleting old mark_mem_use. Use FOR_EACH_SUBRTX
2672 instead of for_each_rtx.
2673 (mem_read_insn_p): Update accordingly.
2674
2675 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2676
2677 * cse.c (change_cc_mode_args): Delete.
2678 (cse_change_cc_mode): Turn from being a for_each_rtx callback to being
2679 a function that examines each subrtx itself. Take the fields of
2680 change_cc_mode_args as argument and return void.
2681 (cse_change_cc_mode_insn): Update calls accordingly.
2682
2683 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2684
2685 * cse.c (is_dead_reg): Change argument to const_rtx.
2686 (dead_debug_insn_data): Delete.
2687 (is_dead_debug_insn): Expand commentary. Turn from being a
2688 for_each_rtx callback to being a function that examines
2689 each subrtx itself. Take the fields of dead_debug_insn_data
2690 as argument.
2691 (delete_trivially_dead_insns): Update call accordingly.
2692
2693 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2694
2695 * cse.c (check_for_label_ref): Move earlier in file. Turn from
2696 being a for_each_rtx callback to being a function that examines
2697 each subrtx itself.
2698 (cse_extended_basic_block): Update call accordingly.
2699
2700 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2701
2702 * cse.c (check_dependence_data): Delete.
2703 (check_dependence): Change from being a for_each_rtx callback to being
2704 a function that examines all subrtxes itself. Don't handle null rtxes.
2705 (invalidate): Update call accordingly.
2706
2707 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2708
2709 * cse.c: Include rtl-iter.h.
2710 (approx_reg_cost_1): Delete.
2711 (approx_reg_cost): Use FOR_EACH_SUBRTX instead of for_each_rtx.
2712 Don't handle null rtxes.
2713
2714 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2715
2716 * cfgcleanup.c: Include rtl-iter.h.
2717 (mentions_nonequal_regs): Turn from being a for_each_rtx callback
2718 to being a function that examines each subrtx itself.
2719 (thread_jump): Update accordingly.
2720
2721 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2722
2723 * combine-stack-adj.c: Include rtl-iter.h.
2724 (record_stack_refs_data): Delete.
2725 (record_stack_refs): Turn from being a for_each_rtx callback
2726 to being a function that examines each subrtx itself.
2727 Take a pointer to the reflist. Invert sense of return value
2728 so that true means success and false means failure. Don't
2729 handle null rtxes.
2730 (combine_stack_adjustments_for_block): Update accordingly.
2731
2732 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2733
2734 * combine.c (record_truncated_value): Turn from being a for_each_rtx
2735 callback to a function that takes an rtx and returns a bool
2736 (record_truncated_values): Use FOR_EACH_SUBRTX_VAR instead of
2737 for_each_rtx.
2738
2739 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2740
2741 * combine.c: Include rtl-iter.h.
2742 (unmentioned_reg_p_1): Delete.
2743 (unmentioned_reg_p): Use FOR_EACH_SUBRTX rather than for_each_rtx.
2744 Don't handle null rtxes.
2745
2746 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2747
2748 * calls.c: Include rtl-iter.h.
2749 (internal_arg_pointer_based_exp_1): Delete.
2750 (internal_arg_pointer_based_exp): Take a const_rtx.
2751 Use FOR_EACH_SUBRTX to iterate over subrtxes.
2752
2753 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2754
2755 * caller-save.c: Include rtl-iter.h.
2756 (add_used_regs_1): Delete.
2757 (add_used_regs): Use FOR_EACH_SUBRTX rather than for_each_rtx
2758 to iterate over subrtxes. Assert that any remaining pseudos
2759 have been spilled.
2760
2761 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2762
2763 * bt-load.c: Include rtl-iter.h.
2764 (btr_reference_found, find_btr_reference, btr_referenced_p): Delete.
2765 (find_btr_use): Move further up file. Use FOR_EACH_SUBRTX_PTR
2766 to iterate over subrtxes.
2767 (insn_sets_btr_p, new_btr_user, compute_defs_uses_and_gen): Use
2768 find_btr_use rather than btr_referenced_p.
2769
2770 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2771
2772 * alias.c: Include rtl-iter.h.
2773 (refs_newer_value_cb): Delete.
2774 (refs_newer_value_p): Use FOR_EACH_SUBRTX instead of for_each_rtx.
2775
2776 2014-08-28 Richard Sandiford <rdsandiford@googlemail.com>
2777
2778 * rtl-iter.h: New file.
2779 * rtlanal.c: Include it.
2780 (rtx_all_subrtx_bounds, rtx_nonconst_subrtx_bounds): New variables.
2781 (generic_subrtx_iterator <T>::add_single_to_queue)
2782 (generic_subrtx_iterator <T>::add_subrtxes_to_queue)
2783 (generic_subrtx_iterator <T>::free_array): New functions.
2784 (generic_subrtx_iterator <T>::LOCAL_ELEMS): Define.
2785 (generic_subrtx_iterator <const_rtx_accessor>)
2786 (generic_subrtx_iterator <rtx_var_accessor>
2787 (generic_subrtx_iterator <rtx_ptr_accessor>): Instantiate.
2788 (setup_reg_subrtx_bounds): New function.
2789 (init_rtlanal): Call it.
2790
2791 2014-08-27 Kaz Kojima <kkojima@gcc.gnu.org>
2792
2793 PR target/62261
2794 * config/sh/sh.md (ashlsi3): Handle negative shift count for
2795 TARGET_SHMEDIA.
2796 (ashldi3, ashrsi3, ashrdi3, lshrsi3, lshrdi3): Likewise.
2797
2798 2014-08-27 Richard Sandiford <rdsandiford@googlemail.com>
2799
2800 * emit-rtl.c (set_unique_reg_note): Discard notes with side effects.
2801
2802 2014-08-27 David Malcolm <dmalcolm@redhat.com>
2803
2804 * rtl.h (JUMP_LABEL_AS_INSN): New.
2805
2806 2014-08-27 David Malcolm <dmalcolm@redhat.com>
2807
2808 * rtl.h (free_EXPR_LIST_list): Strengthen param from rtx * to
2809 rtx_expr_list **.
2810 (alloc_EXPR_LIST): Strengthen return type from rtx to
2811 rtx_expr_list *.
2812 (remove_free_EXPR_LIST_node): Likewise for param.
2813 * reload.h (struct reg_equivs_t): Strengthen field "alt_mem_list"
2814 from rtx to rtx_expr_list *.
2815 * sched-int.h (struct deps_desc): Strengthen fields
2816 "pending_read_mems" and "pending_write_mems" from rtx to
2817 rtx_expr_list *.
2818
2819 * dwarf2out.c (decl_piece_varloc_ptr): Strengthen return type from
2820 rtx to rtx_expr_list *.
2821 * lists.c (alloc_INSN_LIST): Likewise, also for local "r".
2822 (free_EXPR_LIST_list): Strengthen param "listp" from rtx * to
2823 rtx_expr_list **.
2824 (remove_free_EXPR_LIST_node): Likewise. Strengthen local "node"
2825 from rtx to rtx_expr_list *.
2826 * loop-iv.c (simplify_using_initial_values): Strengthen local
2827 "cond_list" from rtx to rtx_expr_list *, and locals "pnode",
2828 "pnote_next" from rtx * to rtx_expr_list **.
2829 * sched-deps.c (remove_from_both_dependence_lists): Strengthen
2830 param "exprp" from rtx * to rtx_expr_list **.
2831 (add_insn_mem_dependence): Strengthen local "mem_list" from
2832 rtx * to rtx_expr_list **. Strengthen local "mem_node" from rtx
2833 to rtx_expr_list *.
2834 * sched-rgn.c (concat_insn_mem_list): Strengthen param "copy_mems"
2835 and local "new_mems" from rtx to rtx_expr_list *. Strengthen
2836 param "old_mems_p" from rtx * to rtx_expr_list **.
2837 * var-tracking.c (struct adjust_mem_data): Strengthen field
2838 "side_effects" from rtx to rtx_expr_list *.
2839 (adjust_insn): Replace NULL_RTX with NULL when assigning to
2840 rtx_expr_list *.
2841 (prepare_call_arguments): Likewise.
2842
2843 2014-08-27 David Malcolm <dmalcolm@redhat.com>
2844
2845 * function.h (struct rtl_data): Strengthen field
2846 "x_stack_slot_list" from rtx to rtx_expr_list *.
2847
2848 * emit-rtl.c (unshare_all_rtl_1): Add a checked cast
2849 when assigning to stack_slot_list.
2850
2851 2014-08-27 David Malcolm <dmalcolm@redhat.com>
2852
2853 * function.h (struct rtl_data): Strengthen field
2854 x_nonlocal_goto_handler_labels from rtx to rtx_expr_list *.
2855 * rtl.h (remove_node_from_expr_list): Strengthen second param from
2856 rtx * to rtx_expr_list **.
2857
2858 * cfgbuild.c (make_edges): In loop over
2859 nonlocal_goto_handler_labels, strengthen local "x" from rtx to
2860 rtx_expr_list *, and use methods of the latter class to clarify
2861 the code.
2862 * cfgrtl.c (cfg_layout_initialize): Strengthen local "x" from rtx to
2863 rtx_expr_list *, and use methods of the latter class to clarify
2864 the code.
2865 * dwarf2cfi.c (create_trace_edges): Likewise for local "lab".
2866 * reload1.c (set_initial_label_offsets): Likewise for local "x".
2867 * rtlanal.c (remove_node_from_expr_list): Strengthen param "listp"
2868 from rtx * to rtx_expr_list **. Strengthen local "temp" from rtx
2869 to rtx_expr_list *. Use methods of the latter class to clarify
2870 the code.
2871
2872 2014-08-27 David Malcolm <dmalcolm@redhat.com>
2873
2874 * function.h (struct expr_status): Strengthen field
2875 "x_forced_labels" from rtx to rtx_expr_list *.
2876
2877 * cfgbuild.c (make_edges): Split local "x" into two locals,
2878 strengthening one from rtx to rtx_expr_list *, and using methods
2879 of said class.
2880 * dwarf2cfi.c (create_trace_edges): Split local "lab" out; within
2881 loop over forced_labels, introduce strengthen it from rtx to
2882 rtx_expr_list *, using methods to clarify the code.
2883 * jump.c (rebuild_jump_labels_1): Strengthen local "insn" from rtx
2884 to rtx_expr_list *, using methods of said class to clarify the
2885 code.
2886 * reload1.c (set_initial_label_offsets): Split local "x" into two
2887 per-loop variables, strengthening the first from rtx to
2888 rtx_expr_list * and using methods.
2889
2890 2014-08-27 David Malcolm <dmalcolm@redhat.com>
2891
2892 * coretypes.h (class rtx_expr_list): Add forward declaration.
2893 * emit-rtl.c (gen_rtx_EXPR_LIST): New.
2894 * gengenrtl.c (special_rtx): Add EXPR_LIST.
2895 * rtl.h (class rtx_expr_list): New subclass of rtx_def, adding
2896 invariant: GET_CODE (X) == EXPR_LIST.
2897 (is_a_helper <rtx_expr_list *>::test): New.
2898 (rtx_expr_list::next): New.
2899 (rtx_expr_list::element): New.
2900 (gen_rtx_EXPR_LIST): New.
2901
2902 2014-08-27 David Malcolm <dmalcolm@redhat.com>
2903
2904 * varasm.c (mark_constants): Convert a GET_CODE check into a
2905 dyn_cast, strengthening local "seq" from rtx to rtx_sequence *.
2906 Use methods of rtx_sequence to clarify the code.
2907
2908 2014-08-27 David Malcolm <dmalcolm@redhat.com>
2909
2910 * sched-vis.c (print_pattern): Within SEQUENCE case, introduce a
2911 local "seq" via a checked cast, and use methods of rtx_sequence
2912 to simplify the code.
2913
2914 2014-08-27 David Malcolm <dmalcolm@redhat.com>
2915
2916 * resource.c (mark_referenced_resources): Strengthen local
2917 "sequence" from rtx to rtx_sequence *, adding a checked cast, and
2918 using methods of rtx_sequence to clarify the code.
2919 (find_dead_or_set_registers): Within the switch statement, convert
2920 a GET_CODE check to a dyn_cast, introducing local "seq". Within
2921 the JUMP_P handling, introduce another local "seq", adding a
2922 checked cast to rtx_sequence *. In both cases, use methods of
2923 rtx_sequence to clarify the code.
2924 (mark_set_resources): Within SEQUENCE case, introduce local "seq"
2925 via a checked cast, and use methods of rtx_sequence to simplify
2926 the code.
2927
2928 2014-08-27 David Malcolm <dmalcolm@redhat.com>
2929
2930 * reorg.c (redundant_insn): In two places in the function, replace
2931 a check of GET_CODE with a dyn_cast, introducing local "seq", and
2932 usings methods of rtx_sequence to clarify the code.
2933
2934 2014-08-27 David Malcolm <dmalcolm@redhat.com>
2935
2936 * jump.c (mark_jump_label_1): Within the SEQUENCE case, introduce
2937 local "seq" with a checked cast, and use methods of rtx_sequence
2938 to clarify the code.
2939
2940 2014-08-27 David Malcolm <dmalcolm@redhat.com>
2941
2942 * function.c (contains): Introduce local "seq" for PATTERN (insn),
2943 with a checked cast, in the region for where we know it's a
2944 SEQUENCE. Use methods of rtx_sequence.
2945
2946 2014-08-27 David Malcolm <dmalcolm@redhat.com>
2947
2948 * final.c (get_attr_length_1): Replace GET_CODE check with a
2949 dyn_cast, introducing local "seq" and the use of methods of
2950 rtx_sequence.
2951 (shorten_branches): Likewise, introducing local "body_seq".
2952 Strengthen local "inner_insn" from rtx to rtx_insn *.
2953 (reemit_insn_block_notes): Replace GET_CODE check with a
2954 dyn_cast, strengthening local "body" from rtx to rtx_sequence *.
2955 Use methods of rtx_sequence.
2956 (final_scan_insn): Likewise, introducing local "seq" for when
2957 "body" is known to be a SEQUENCE, using its methods.
2958
2959 2014-08-27 David Malcolm <dmalcolm@redhat.com>
2960
2961 * except.c (can_throw_external): Strengthen local "seq" from rtx
2962 to rtx_sequence *. Use methods of rtx_sequence.
2963 (insn_nothrow_p): Likewise.
2964
2965 2014-08-27 David Malcolm <dmalcolm@redhat.com>
2966
2967 * dwarf2cfi.c (create_trace_edges): Convert GET_CODE check into a
2968 dyn_cast, strengthening local "seq" from rtx to rtx_sequence *.
2969 Use methods of rtx_sequence.
2970 (scan_trace): Likewise for local "pat".
2971
2972 2014-08-27 David Malcolm <dmalcolm@redhat.com>
2973
2974 * coretypes.h (class rtx_sequence): Add forward declaration.
2975 * rtl.h (class rtx_sequence): New subclass of rtx_def, adding
2976 invariant: GET_CODE (X) == SEQUENCE.
2977 (is_a_helper <rtx_sequence *>::test): New.
2978 (is_a_helper <const rtx_sequence *>::test): New.
2979 (rtx_sequence::len): New.
2980 (rtx_sequence::element): New.
2981 (rtx_sequence::insn): New.
2982
2983 2014-08-27 David Malcolm <dmalcolm@redhat.com>
2984
2985 * rtl.h (free_INSN_LIST_list): Strengthen param from rtx * to
2986 rtx_insn_list **.
2987 (alloc_INSN_LIST): Strengthen return type from rtx to
2988 rtx_insn_list *.
2989 (copy_INSN_LIST): Likewise for return type and param.
2990 (concat_INSN_LIST): Likewise for both params and return type.
2991 (remove_free_INSN_LIST_elem): Strenghten first param from rtx to
2992 rtx_insn *. Strengthen second param from rtx * to rtx_insn_list **.
2993 (remove_free_INSN_LIST_node): Strenghten return type from rtx to
2994 rtx_insn *. Strengthen param from rtx * to rtx_insn_list **.
2995
2996 * sched-int.h (struct deps_reg): Strengthen fields "uses", "sets",
2997 "implicit_sets", "control_uses", "clobbers" from rtx to
2998 rtx_insn_list *.
2999 (struct deps_desc): Likewise for fields "pending_read_insns",
3000 "pending_write_insns", "pending_jump_insns",
3001 "last_pending_memory_flush", "last_function_call",
3002 "last_function_call_may_noreturn", "sched_before_next_call",
3003 "sched_before_next_jump".
3004 (struct _haifa_deps_insn_data): Likewise for field "cond_deps".
3005 (remove_from_deps): Strengthen second param from rtx to rtx_insn *.
3006
3007 * gcse.c (struct ls_expr): Strengthen fields "loads" and "stores"
3008 from rtx to rtx_insn_list *.
3009 (ldst_entry): Replace use of NULL_RTX with NULL when dealing with
3010 rtx_insn_list *.
3011
3012 * haifa-sched.c (insn_queue): Strengthen this variable from rtx *
3013 to rtx_insn_list **.
3014 (dep_cost_1): Strengthen local "dep_cost_rtx_link" from rtx to
3015 rtx_insn_list *.
3016 (queue_insn): Likewise for local "link".
3017 (struct haifa_saved_data): Strengthen field "insn_queue" from
3018 rtx * to rtx_insn_list **.
3019 (save_backtrack_point): Update allocation of save->insn_queue to
3020 reflect the strengthening of elements from rtx to rtx_insn_list *.
3021 (queue_to_ready): Strengthen local "link" from rtx to
3022 rtx_insn_list *; use methods "next" and "insn" when traversing the
3023 list.
3024 (early_queue_to_ready): Likewise for locals "link", "next_link",
3025 "prev_link".
3026 (schedule_block): Update allocation of insn_queue to reflect the
3027 strengthening of elements from rtx to rtx_insn_list *. Strengthen
3028 local "link" from rtx to rtx_insn_list *, and use methods when
3029 working it.
3030 (add_to_speculative_block): Strengthen locals "twins" and
3031 "next_node" from rtx to rtx_insn_list *, and use methods when
3032 working with them. Strengthen local "twin" from rtx to
3033 rtx_insn *, eliminating a checked cast.
3034 (fix_recovery_deps): Strengthen locals "ready_list" and "link"
3035 from rtx to rtx_insn_list *, and use methods when working with
3036 them.
3037
3038 * lists.c (alloc_INSN_LIST): Strengthen return type and local "r"
3039 from rtx to rtx_insn_list *, adding a checked cast.
3040 (free_INSN_LIST_list): Strengthen param "listp" from rtx * to
3041 rtx_insn_list **.
3042 (copy_INSN_LIST): Strengthen return type and locals "new_queue",
3043 "newlink" from rtx to rtx_insn_list *. Strengthen local
3044 "pqueue" from rtx * to rtx_insn_list **. Strengthen local "x"
3045 from rtx to rtx_insn *.
3046 (concat_INSN_LIST): Strengthen return type and local "new_rtx",
3047 from rtx to rtx_insn_list *. Use methods of the latter class.
3048 (remove_free_INSN_LIST_elem): Strengthen param "elem" from rtx to
3049 rtx_insn *, and param "listp" from rtx * to rtx_insn_list **.
3050 (remove_free_INSN_LIST_node): Strengthen return type and local
3051 "elem" from rtx to rtx_insn *. Strenghten param "listp" from
3052 rtx * to rtx_insn_list **. Strengthen local "node" from rtx to
3053 rtx_insn_list *, using "insn" method.
3054
3055 * sched-deps.c (add_dependence_list): Strengthen param "list"
3056 from rtx to rtx_insn_list *, and use methods when working with it.
3057 (add_dependence_list_and_free): Strengthen param "listp" from
3058 rtx * to rtx_insn_list **.
3059 (remove_from_dependence_list): Strenghten param "listp" from rtx *
3060 to rtx_insn_list **, and use methods when working with *listp.
3061 (remove_from_both_dependence_lists): Strengthen param "listp" from
3062 rtx * to rtx_insn_list **
3063 (add_insn_mem_dependence): Strengthen local "insn_list" from rtx *
3064 to rtx_insn_list **. Eliminate local "link", in favor of two new
3065 locals "insn_node" and "mem_node", an rtx_insn_list * and an rtx
3066 respectively.
3067 (deps_analyze_insn): Split out uses 'f local "t" as an INSN_LIST
3068 by introducing local "cond_deps".
3069 (remove_from_deps): Strengthen param "insn" from rtx to
3070 rtx_insn *.
3071
3072 * sched-rgn.c (concat_insn_mem_list): Strengthen param
3073 "copy_insns" and local "new_insns" from rtx to rtx_insn_list *.
3074 Strengthen param "old_insns_p" from rtx * to rtx_insn_list **.
3075 Use methods of rtx_insn_list.
3076
3077 * store-motion.c (struct st_expr): Strengthen fields
3078 "antic_stores" and "avail_stores" from rtx to rtx_insn_list *.
3079 (st_expr_entry): Replace NULL_RTX with NULL when dealing with
3080 rtx_insn_list *.
3081 (find_moveable_store): Split out "tmp" into multiple more-tightly
3082 scoped locals. Use methods of rtx_insn_list *.
3083 (compute_store_table): Strengthen local "tmp" from rtx to
3084 rtx_insn *. Use methods of rtx_insn_list *.
3085
3086 2014-08-27 David Malcolm <dmalcolm@redhat.com>
3087
3088 * coretypes.h (class rtx_insn_list): Add forward declaration.
3089 * rtl.h (class rtx_insn_list): New subclass of rtx_def
3090 (is_a_helper <rtx_insn_list *>::test): New.
3091 (rtx_insn_list::next): New.
3092 (rtx_insn_list::insn): New.
3093 (gen_rtx_INSN_LIST): Add prototype.
3094 * emit-rtl.c (gen_rtx_INSN_LIST): New.
3095 * gengenrtl.c (special_rtx): Add INSN_LIST.
3096
3097 2014-08-27 David Malcolm <dmalcolm@redhat.com>
3098
3099 * ira-lives.c (find_call_crossed_cheap_reg): Strengthen local
3100 "prev" from rtx to rtx_insn *.
3101
3102 2014-08-27 David Malcolm <dmalcolm@redhat.com>
3103
3104 * rtl.h (INSN_UID): Convert from a macro to a pair of inline
3105 functions. Require merely an rtx for now, not an rtx_insn *.
3106 (BLOCK_FOR_INSN): Likewise.
3107 (INSN_LOCATION): Likewise.
3108 (INSN_HAS_LOCATION): Convert from a macro to an inline function.
3109
3110 2014-08-27 David Malcolm <dmalcolm@redhat.com>
3111
3112 * rtl.h (PATTERN): Convert this macro into a pair of inline
3113 functions, for now, requiring const_rtx and rtx.
3114
3115 2014-08-27 David Malcolm <dmalcolm@redhat.com>
3116
3117 * target.def (unwind_emit): Strengthen param "insn" from rtx to
3118 rtx_insn *.
3119 (final_postscan_insn): Likewise.
3120 (adjust_cost): Likewise.
3121 (adjust_priority): Likewise.
3122 (variable_issue): Likewise.
3123 (macro_fusion_pair_p): Likewise.
3124 (dfa_post_cycle_insn): Likewise.
3125 (first_cycle_multipass_dfa_lookahead_guard): Likewise.
3126 (first_cycle_multipass_issue): Likewise.
3127 (dfa_new_cycle): Likewise.
3128 (adjust_cost_2): Likewise for params "insn" and "dep_insn".
3129 (speculate_insn): Likewise for param "insn".
3130 (gen_spec_check): Likewise for params "insn" and "label".
3131 (get_insn_spec_ds): Likewise for param "insn".
3132 (get_insn_checked_ds): Likewise.
3133 (dispatch_do): Likewise.
3134 (dispatch): Likewise.
3135 (cannot_copy_insn_p): Likewise.
3136 (invalid_within_doloop): Likewise.
3137 (legitimate_combined_insn): Likewise.
3138 (needed): Likewise.
3139 (after): Likewise.
3140
3141 * doc/tm.texi: Automatically updated to reflect changes to
3142 target.def.
3143
3144 * haifa-sched.c (choose_ready): Convert NULL_RTX to NULL when
3145 working with insn.
3146 (schedule_block): Likewise.
3147 (sched_init): Likewise.
3148 (sched_speculate_insn): Strengthen param "insn" from rtx to
3149 rtx_insn *.
3150 (ready_remove_first_dispatch): Convert NULL_RTX to NULL when
3151 working with insn.
3152 * hooks.c (hook_bool_rtx_true): Rename to...
3153 hook_bool_rtx_insn_true): ...this, and strengthen first param from
3154 rtx to rtx_insn *.
3155 (hook_constcharptr_const_rtx_null): Rename to...
3156 (hook_constcharptr_const_rtx_insn_null): ...this, and strengthen
3157 first param from const_rtx to const rtx_insn *.
3158 (hook_bool_rtx_int_false): Rename to...
3159 (hook_bool_rtx_insn_int_false): ...this, and strengthen first
3160 param from rtx to rtx_insn *.
3161 (hook_void_rtx_int): Rename to...
3162 (hook_void_rtx_insn_int): ...this, and strengthen first param from
3163 rtx to rtx_insn *.
3164
3165 * hooks.h (hook_bool_rtx_true): Rename to...
3166 (hook_bool_rtx_insn_true): ...this, and strengthen first param from
3167 rtx to rtx_insn *.
3168 (hook_bool_rtx_int_false): Rename to...
3169 (hook_bool_rtx_insn_int_false): ...this, and strengthen first
3170 param from rtx to rtx_insn *.
3171 (hook_void_rtx_int): Rename to...
3172 (hook_void_rtx_insn_int): ...this, and strengthen first param from
3173 rtx to rtx_insn *.
3174 (hook_constcharptr_const_rtx_null): Rename to...
3175 (hook_constcharptr_const_rtx_insn_null): ...this, and strengthen
3176 first param from const_rtx to const rtx_insn *.
3177
3178 * sched-deps.c (sched_macro_fuse_insns): Strengthen param "insn"
3179 and local "prev" from rtx to rtx_insn *.
3180
3181 * sched-int.h (sched_speculate_insn): Strengthen first param from
3182 rtx to rtx_insn *.
3183
3184 * sel-sched.c (create_speculation_check): Likewise for local "label".
3185 * targhooks.c (default_invalid_within_doloop): Strengthen param
3186 "insn" from const_rtx to const rtx_insn *.
3187 * targhooks.h (default_invalid_within_doloop): Strengthen param
3188 from const_rtx to const rtx_insn *.
3189
3190 * config/alpha/alpha.c (alpha_cannot_copy_insn_p): Likewise.
3191 (alpha_adjust_cost): Likewise for params "insn", "dep_insn".
3192
3193 * config/arc/arc.c (arc_sched_adjust_priority): Likewise for param
3194 "insn".
3195 (arc_invalid_within_doloop): Likewise, with const.
3196
3197 * config/arm/arm.c (arm_adjust_cost): Likewise for params "insn", "dep".
3198 (arm_cannot_copy_insn_p): Likewise for param "insn".
3199 (arm_unwind_emit): Likewise.
3200
3201 * config/bfin/bfin.c (bfin_adjust_cost): Likewise for params "insn",
3202 "dep_insn".
3203
3204 * config/c6x/c6x.c (c6x_dfa_new_cycle): Likewise for param "insn".
3205 (c6x_variable_issue): Likewise. Removed now-redundant checked
3206 cast.
3207 (c6x_adjust_cost): Likewise for params "insn", "dep_insn".
3208
3209 * config/epiphany/epiphany-protos.h (epiphany_mode_needed):
3210 Likewise for param "insn".
3211 (epiphany_mode_after): Likewise.
3212 * config/epiphany/epiphany.c (epiphany_adjust_cost): Likewise for
3213 params "insn", "dep_insn".
3214 (epiphany_mode_needed): Likewise for param "insn".
3215 (epiphany_mode_after): Likewise.
3216
3217 * config/i386/i386-protos.h (i386_pe_seh_unwind_emit): Likewise.
3218 * config/i386/i386.c (ix86_legitimate_combined_insn): Likewise.
3219 (ix86_avx_u128_mode_needed): Likewise.
3220 (ix86_i387_mode_needed): Likewise.
3221 (ix86_mode_needed): Likewise.
3222 (ix86_avx_u128_mode_after): Likewise.
3223 (ix86_mode_after): Likewise.
3224 (ix86_adjust_cost): Likewise for params "insn", "dep_insn".
3225 (ix86_macro_fusion_pair_p): Likewise for params "condgen", "condjmp".
3226 (ix86_adjust_priority): Likewise for param "insn".
3227 (core2i7_first_cycle_multipass_issue): Likewise for param "insn".
3228 (do_dispatch): Likewise.
3229 (has_dispatch): Likewise.
3230 * config/i386/winnt.c (i386_pe_seh_unwind_emit): Likewise.
3231
3232 * config/ia64/ia64.c (TARGET_INVALID_WITHIN_DOLOOP): Update to
3233 reflect renaming of default hook implementation from
3234 hook_constcharptr_const_rtx_null to
3235 hook_constcharptr_const_rtx_insn_null.
3236 (ia64_adjust_cost_2): Strengthen params "insn", "dep_insn" from
3237 rtx to rtx_insn *.
3238 (ia64_variable_issue): Likewise for param "insn".
3239 (ia64_first_cycle_multipass_dfa_lookahead_guard): Likewise.
3240 (ia64_dfa_new_cycle): Likewise.
3241 (ia64_get_insn_spec_ds): Likewise.
3242 (ia64_get_insn_checked_ds): Likewise.
3243 (ia64_speculate_insn): Likewise.
3244 (ia64_gen_spec_check): Likewise for params "insn", "label".
3245 (ia64_asm_unwind_emit): Likewise for param "insn".
3246
3247 * config/m32r/m32r.c (m32r_adjust_priority): Likewise.
3248
3249 * config/m68k/m68k.c (m68k_sched_adjust_cost): Likewise for params
3250 "insn", "def_insn".
3251 (m68k_sched_variable_issue): Likewise for param "insn".
3252
3253 * config/mep/mep.c (mep_adjust_cost): Likewise for params "insn",
3254 "def_insn".
3255
3256 * config/microblaze/microblaze.c (microblaze_adjust_cost):
3257 Likewise for params "insn", "dep".
3258
3259 * config/mips/mips.c (mips_adjust_cost): Likewise.
3260 (mips_variable_issue): Likewise for param "insn".
3261 (mips_final_postscan_insn): Likewise.
3262
3263 * config/mn10300/mn10300.c (mn10300_adjust_sched_cost): Likewise
3264 for params "insn", "dep".
3265
3266 * config/pa/pa.c (pa_adjust_cost): Likewise for params "insn",
3267 "dep_insn".
3268 (pa_adjust_priority): Likewise for param "insn".
3269
3270 * config/picochip/picochip.c (picochip_sched_adjust_cost):
3271 Likewise for params "insn", "dep_insn".
3272
3273 * config/rs6000/rs6000.c (rs6000_variable_issue_1): Likewise for
3274 param "insn".
3275 (rs6000_variable_issue): Likewise.
3276 (rs6000_adjust_cost): Likewise for params "insn", "dep_insn".
3277 (rs6000_debug_adjust_cost): Likewise.
3278 (rs6000_adjust_priority): Likewise for param "insn".
3279 (rs6000_use_sched_lookahead_guard): Likewise.
3280 (get_next_active_insn): Likewise for return type and both params.
3281 (redefine_groups): Likewise for params "prev_head_insn", "tail"
3282 and locals "insn", "next_insn".
3283 (pad_groups): Likewise.
3284
3285 * config/s390/s390.c (s390_adjust_priority): Likewise for param
3286 "insn".
3287 (s390_cannot_copy_insn_p): Likewise.
3288 (s390_sched_variable_issue): Likewise for third param, eliminating
3289 checked cast.
3290 (TARGET_INVALID_WITHIN_DOLOOP): Update to reflect renaming of
3291 default hook implementation from hook_constcharptr_const_rtx_null
3292 to hook_constcharptr_const_rtx_insn_null.
3293
3294 * config/sh/sh.c (sh_cannot_copy_insn_p): Strengthen param "insn"
3295 from rtx to rtx_insn *.
3296 (sh_adjust_cost): Likewise for params "insn", "dep_insn".
3297 (sh_variable_issue): Likewise for param "insn".
3298 (sh_dfa_new_cycle): Likewise.
3299 (sh_mode_needed): Likewise.
3300 (sh_mode_after): Likewise.
3301
3302 * config/sparc/sparc.c (supersparc_adjust_cost): Likewise for
3303 params "insn", "dep_insn".
3304 (hypersparc_adjust_cost): Likewise.
3305 (sparc_adjust_cost): Likewise.
3306
3307 * config/spu/spu.c (spu_sched_variable_issue): Likewise for third
3308 param, eliminated checked cast.
3309 (spu_sched_adjust_cost): Likewise for first and third params.
3310
3311 * config/tilegx/tilegx.c (tilegx_sched_adjust_cost): Strengthen
3312 params "insn" and "dep_insn" from rtx to rtx_insn *.
3313
3314 * config/tilepro/tilepro.c (tilepro_sched_adjust_cost): Likewise.
3315
3316 2014-08-27 David Malcolm <dmalcolm@redhat.com>
3317
3318 * gcc/config/mn10300/mn10300.c (is_load_insn): Rename to...
3319 (set_is_load_p): ...this, updating to work on a SET pattern rather
3320 than an insn.
3321 (is_store_insn): Rename to...
3322 (set_is_store_p): ...this, updating to work on a SET pattern
3323 rather than an insn.
3324 (mn10300_adjust_sched_cost): Move call to get_attr_timings from
3325 top of function to where it is needed. Rewrite the bogus
3326 condition that checks for "insn" and "dep" being PARALLEL to
3327 instead use single_set, introducing locals "insn_set" and
3328 "dep_set". Given that we only ever returned "cost" for a non-pair
3329 of SETs, bail out early if we don't have a pair of SET.
3330 Rewrite all uses of PATTERN (dep) and PATTERN (insn) to instead
3331 use the new locals "insn_set" and "dep_set", and update calls to
3332 is_load_insn and is_store_insn to be calls to set_is_load_p and
3333 set_is_store_p.
3334
3335 2014-08-27 Guozhi Wei <carrot@google.com>
3336
3337 PR target/62262
3338 * config/aarch64/aarch64.md (*andim_ashift<mode>_bfiz): Check the shift
3339 amount before using it.
3340
3341 2014-08-27 Richard Biener <rguenther@suse.de>
3342
3343 * gimple-fold.c (get_maxval_strlen): Add overload wrapping
3344 get_maxval_strlen inside a more useful API.
3345 (gimple_fold_builtin_with_strlen): Remove and fold into ...
3346 (gimple_fold_builtin): ... caller.
3347 (gimple_fold_builtin_strlen, gimple_fold_builtin_strcpy,
3348 gimple_fold_builtin_strncpy, gimple_fold_builtin_strcat,
3349 gimple_fold_builtin_fputs, gimple_fold_builtin_memory_chk,
3350 gimple_fold_builtin_stxcpy_chk, gimple_fold_builtin_stxncpy_chk,
3351 gimple_fold_builtin_snprintf_chk, gimple_fold_builtin_snprintf,
3352 gimple_fold_builtin_sprintf): Adjust to compute maxval
3353 themselves.
3354
3355 2014-08-27 Yvan Roux <yvan.roux@linaro.org>
3356
3357 PR other/62248
3358 * config.gcc (arm*-*-*): Check --with-fpu against arm-fpus.def.
3359
3360 2014-08-27 Alexander Ivchenko <alexander.ivchenko@intel.com>
3361 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
3362 Anna Tikhonova <anna.tikhonova@intel.com>
3363 Ilya Tocar <ilya.tocar@intel.com>
3364 Andrey Turetskiy <andrey.turetskiy@intel.com>
3365 Ilya Verbin <ilya.verbin@intel.com>
3366 Kirill Yukhin <kirill.yukhin@intel.com>
3367 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
3368
3369 * config/i386/sse.md
3370 (define_insn "<mask_codefor>avx512dq_broadcast<mode><mask_name>_1"):
3371 Use `concat_tg_mode' attribute to determine asm register size.
3372
3373 2014-08-27 Alexander Ivchenko <alexander.ivchenko@intel.com>
3374 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
3375 Anna Tikhonova <anna.tikhonova@intel.com>
3376 Ilya Tocar <ilya.tocar@intel.com>
3377 Andrey Turetskiy <andrey.turetskiy@intel.com>
3378 Ilya Verbin <ilya.verbin@intel.com>
3379 Kirill Yukhin <kirill.yukhin@intel.com>
3380 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
3381
3382 * config/i386/sse.md
3383 (define_mode_iterator VI48_AVX512VL): New.
3384 (define_mode_iterator VI_UNALIGNED_LOADSTORE): Delete.
3385 (define_mode_iterator VI_ULOADSTORE_BW_AVX512VL): New.
3386 (define_mode_iterator VI_ULOADSTORE_F_AVX512VL): Ditto.
3387 (define_expand "<sse2_avx_avx512f>_loaddqu<mode><mask_name>"
3388 with VI1): Change mode iterator.
3389 (define_expand "<sse2_avx_avx512f>_loaddqu<mode><mask_name>"
3390 with VI_ULOADSTORE_BW_AVX512VL): New.
3391 (define_expand "<sse2_avx_avx512f>_loaddqu<mode><mask_name>"
3392 with VI_ULOADSTORE_F_AVX512VL): Ditto.
3393 (define_insn "*<sse2_avx_avx512f>_loaddqu<mode><mask_name>"
3394 with VI1): Change mode iterator.
3395 (define_insn "*<sse2_avx_avx512f>_loaddqu<mode><mask_name>"
3396 with VI_ULOADSTORE_BW_AVX512VL): New.
3397 (define_insn "*<sse2_avx_avx512f>_loaddqu<mode><mask_name>"
3398 with VI_ULOADSTORE_F_AVX512VL): Ditto.
3399 (define_insn "<sse2_avx_avx512f>_storedqu<mode>
3400 with VI1): Change mode iterator.
3401 (define_insn "<sse2_avx_avx512f>_storedqu<mode>
3402 with VI_ULOADSTORE_BW_AVX512VL): New.
3403 (define_insn "<sse2_avx_avx512f>_storedqu<mode>
3404 with VI_ULOADSTORE_BW_AVX512VL): Ditto.
3405 (define_insn "avx512f_storedqu<mode>_mask"): Delete.
3406 (define_insn "<avx512>_storedqu<mode>_mask" with
3407 VI48_AVX512VL): New.
3408 (define_insn "<avx512>_storedqu<mode>_mask" with
3409 VI12_AVX512VL): Ditto.
3410
3411 2014-08-27 Alexander Ivchenko <alexander.ivchenko@intel.com>
3412 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
3413 Anna Tikhonova <anna.tikhonova@intel.com>
3414 Ilya Tocar <ilya.tocar@intel.com>
3415 Andrey Turetskiy <andrey.turetskiy@intel.com>
3416 Ilya Verbin <ilya.verbin@intel.com>
3417 Kirill Yukhin <kirill.yukhin@intel.com>
3418 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
3419
3420 * config/i386/sse.md
3421 (define_mode_iterator VI48_AVX2_48_AVX512F): Delete.
3422 (define_mode_iterator VI48_AVX512BW): New.
3423 (define_insn "<avx2_avx512f>_<shift_insn>v<mode><mask_name>"): Delete.
3424 (define_insn "<avx2_avx512bw>_<shift_insn>v<mode><mask_name>"
3425 with VI48_AVX2_48_AVX512F): New.
3426 (define_insn "<avx2_avx512bw>_<shift_insn>v<mode><mask_name>"
3427 with VI2_AVX512VL): Ditto.
3428
3429 2014-08-27 Richard Biener <rguenther@suse.de>
3430
3431 PR middle-end/62239
3432 * builtins.c (fold_builtin_strcat_chk): Move to gimple-fold.c.
3433 (fold_builtin_3): Do not fold strcat_chk here.
3434 * gimple-fold.c (gimple_fold_builtin_strcat_chk): Move here
3435 from builtins.c.
3436 (gimple_fold_builtin): Fold strcat_chk here.
3437
3438 2014-08-26 Aldy Hernandez <aldyh@redhat.com>
3439
3440 * dwarf2out.h (dwarf2out_decl): Remove prototype.
3441 * dwarf2out.c (dwarf2out_decl): Make static.
3442
3443 2014-08-26 Joel Sherrill <joel.sherrill@oarcorp.com>
3444
3445 * doc/invoke.texi: -fno-cxa-atexit should be -fno-use-cxa-atexit.
3446
3447 2014-08-26 David Malcolm <dmalcolm@redhat.com>
3448
3449 * cselib.h (struct elt_loc_list): Strengthen field "setting_insn"
3450 from rtx to rtx_insn *.
3451 (cselib_lookup_from_insn): Likewise for final param.
3452 (cselib_subst_to_values_from_insn): Likewise.
3453 (cselib_add_permanent_equiv): Likewise.
3454
3455 * cselib.c (cselib_current_insn): Likewise for this variable.
3456 (cselib_subst_to_values_from_insn): Likewise for param "insn".
3457 (cselib_lookup_from_insn): Likewise.
3458 (cselib_add_permanent_equiv): Likewise for param "insn" and local
3459 "save_cselib_current_insn".
3460 (cselib_process_insn): Replace use of NULL_RTX with NULL.
3461
3462 * sched-deps.c (add_insn_mem_dependence): Strengthen param "insn"
3463 from rtx to rtx_insn *.
3464
3465 2014-08-26 David Malcolm <dmalcolm@redhat.com>
3466
3467 * dse.c (dse_step6): Strengthen local "rinsn" from rtx to
3468 rtx_insn *.
3469
3470 2014-08-26 David Malcolm <dmalcolm@redhat.com>
3471
3472 * df.h (df_dump_insn_problem_function): Strengthen first param of
3473 this callback from const_rtx to const rtx_insn *.
3474 (struct df_insn_info): Strengthen field "insn" from rtx to
3475 rtx_insn *.
3476 (DF_REF_INSN): Eliminate this function, reinstating the older
3477 macro definition.
3478 (df_find_def): Strengthen param 1 from rtx to rtx_insn *.
3479 (df_reg_defined): Likewise.
3480 (df_find_use): Likewise.
3481 (df_reg_used): Likewise.
3482 (df_dump_insn_top): Strengthen param 1 from const_rtx to
3483 const rtx_insn *.
3484 (df_dump_insn_bottom): Likewise.
3485 (df_insn_debug): Strengthen param 1 from rtx to rtx_insn *.
3486 (df_insn_debug_regno): Likewise.
3487 (debug_df_insn): Likewise.
3488 (df_rd_simulate_one_insn): Likewise for param 2.
3489 (df_word_lr_simulate_defs): Likewise for param 1.
3490 (df_word_lr_simulate_uses): Likewise.
3491 (df_md_simulate_one_insn): Likewise for param 2.
3492 (df_simulate_find_noclobber_defs): Likewise for param 1.
3493 (df_simulate_find_defs): Likewise.
3494 (df_simulate_defs): Likewise.
3495 (df_simulate_uses): Likewise.
3496 (df_simulate_one_insn_backwards): Likewise for param 2.
3497 (df_simulate_one_insn_forwards): Likewise.
3498 (df_uses_create): Likewise for param 2.
3499 (df_insn_create_insn_record): Likewise for param 1.
3500 (df_insn_delete): Likewise.
3501 (df_insn_rescan): Likewise.
3502 (df_insn_rescan_debug_internal): Likewise.
3503 (df_insn_change_bb): Likewise.
3504 (df_notes_rescan): Likewise.
3505 * rtl.h (remove_death): Likewise for param 2.
3506 (print_rtl_with_bb): Strengthen param 2 from const_rtx to
3507 const rtx_insn *.
3508 * sched-int.h (reemit_notes): Strengthen param from rtx to
3509 rtx_insn *.
3510 * valtrack.h (propagate_for_debug): Likewise for param 1.
3511
3512 * cfgrtl.c (print_rtl_with_bb): Strengthen param "rtx_first" and
3513 local "tmp_rtx" from const_rtx to const rtx_insn *.
3514 * combine.c (remove_death): Strengthen param "insn" from rtx to
3515 rtx_insn *.
3516 (move_deaths): Likewise for local "where_dead".
3517 * cse.c (delete_trivially_dead_insns): Introduce local
3518 "bind_var_loc" so that "bind" can be strengthened to an rtx_insn *.
3519 * df-core.c (df_find_def): Strengthen param "insn" from rtx to
3520 rtx_insn *.
3521 (df_reg_defined): Likewise.
3522 (df_find_use): Likewise.
3523 (df_reg_used): Likewise.
3524 (df_dump_insn_problem_data): Strengthen param "insn" from
3525 const_rtx to const rtx_insn *.
3526 (df_dump_insn_top): Likewise.
3527 (df_dump_insn_bottom): Likewise.
3528 (df_insn_debug): Strengthen param "insn" from rtx to rtx_insn *.
3529 (df_insn_debug_regno): Likewise.
3530 (debug_df_insn): Likewise.
3531 (DF_REF_INSN): Delete.
3532 * df-problems.c (df_rd_simulate_one_insn): Strengthen param "insn"
3533 from rtx to rtx_insn *.
3534 (df_chain_insn_top_dump): Strengthen param "insn" from
3535 const_rtx to const rtx_insn *.
3536 (df_chain_insn_bottom_dump): Likewise.
3537 (df_word_lr_simulate_defs): Strengthen param "insn" from rtx to
3538 rtx_insn *.
3539 (df_word_lr_simulate_uses): Likewise.
3540 (df_print_note): Likewise.
3541 (df_remove_dead_and_unused_notes): Likewise.
3542 (df_set_unused_notes_for_mw): Likewise.
3543 (df_set_dead_notes_for_mw): Likewise.
3544 (df_create_unused_note): Likewise.
3545 (df_simulate_find_defs): Likewise.
3546 (df_simulate_find_uses): Likewise.
3547 (df_simulate_find_noclobber_defs): Likewise.
3548 (df_simulate_defs): Likewise.
3549 (df_simulate_uses): Likewise.
3550 (df_simulate_one_insn_backwards): Likewise.
3551 (df_simulate_one_insn_forwards): Likewise.
3552 (df_md_simulate_one_insn): Likewise.
3553 * df-scan.c (df_uses_create): Likewise.
3554 (df_insn_create_insn_record): Likewise.
3555 (df_insn_delete): Likewise.
3556 (df_insn_rescan): Likewise.
3557 (df_insn_rescan_debug_internal): Likewise.
3558 (df_insn_change_bb): Likewise.
3559 (df_notes_rescan): Likewise.
3560 (df_refs_add_to_chains): Likewise.
3561 (df_insn_refs_verify): Likewise.
3562 * emit-rtl.c (set_insn_deleted): Add checked cast to rtx_insn *
3563 when invoking df_insn_delete.
3564 (reorder_insns): Strengthen local "x" from rtx to rtx_insn *.
3565 (set_unique_reg_note): Add checked cast.
3566 * final.c (cleanup_subreg_operands): Likewise.
3567 * gcse.c (update_ld_motion_stores): Likewise, strengthening local
3568 "insn" from rtx to rtx_insn *.
3569 * haifa-sched.c (reemit_notes): Strengthen param "insn" and local
3570 "last" from rtx to rtx_insn *.
3571 * ira-emit.c (change_regs_in_insn): New function.
3572 (change_loop): Strengthen local "insn" from rtx to rtx_insn *.
3573 Invoke change_regs_in_insn rather than change_regs.
3574 * ira.c (update_equiv_regs): Strengthen locals "insn",
3575 "init_insn", "new_insn" from rtx to rtx_insn *. Invoke
3576 for_each_rtx_in_insn rather than for_each_rtx.
3577 * recog.c (confirm_change_group): Add checked casts.
3578 (peep2_update_life): Strengthen local "x" from rtx to rtx_insn *.
3579 Add checked cast.
3580 (peep2_fill_buffer): Add checked cast.
3581 * rtlanal.c (remove_note): Likewise.
3582 * valtrack.c (propagate_for_debug): Strengthen param "insn" and
3583 locals "next" "end" from rtx to rtx_insn *.
3584
3585 2014-08-26 David Malcolm <dmalcolm@redhat.com>
3586
3587 * sched-int.h (sched_init_insn_luid): Strengthen param 1 from rtx
3588 to rtx_insn *.
3589 (struct reg_use_data): Likewise for field "insn".
3590 (insn_cost): Likewise for param.
3591 (real_insn_for_shadow): Likewise for return type and param.
3592 (increase_insn_priority): Likewise for param 1.
3593 (debug_dependencies): Likewise for both params.
3594
3595 * haifa-sched.c (insn_delay): Likewise for param "insn".
3596 (real_insn_for_shadow): Likewise for return type and param "insn".
3597 (update_insn_after_change): Likewise for param "insn".
3598 (recompute_todo_spec): Likewise for param "next" and locals "pro",
3599 "other".
3600 (insn_cost): Likewise for param "insn".
3601 (increase_insn_priority): Likewise.
3602 (calculate_reg_deaths): Likewise.
3603 (setup_insn_reg_pressure_info): Likewise.
3604 (model_schedule): Strengthen from vec<rtx> to vec<rtx_insn *>.
3605 (model_index): Strengthen param "insn" from rtx to rtx_insn *.
3606 (model_recompute): Likewise.
3607 (must_restore_pattern_p): Likewise for param "next".
3608 (model_excess_cost): Likewise for param "insn".
3609 (queue_remove): Likewise.
3610 (adjust_priority): Likewise for param "prev".
3611 (update_register_pressure): Likewise for param "insn".
3612 (setup_insn_max_reg_pressure): Likewise for local "insn".
3613 (update_reg_and_insn_max_reg_pressure): Likewise for param "insn".
3614 (model_add_to_schedule): Likewise.
3615 (model_reset_queue_indices): Likewise for local "insn".
3616 (unschedule_insns_until): Strengthen local "recompute_vec" from
3617 auto_vec<rtx> to auto_vec<rtx_insn *>. Strengthen locals "last",
3618 "con" from rtx to rtx_insn *.
3619 (restore_last_backtrack_point): Likewise for both locals "x". Add
3620 checked casts.
3621 (estimate_insn_tick): Likewise for param "insn".
3622 (commit_schedule): Likewise for params "prev_head", "tail" and
3623 local "x".
3624 (verify_shadows): Likewise for locals "i1", "i2".
3625 (dump_insn_stream): Likewise for params "head", "tail" and locals
3626 "next_tail", "insn".
3627 (schedule_block): Likewise for locals "insn", "x". Add a checked
3628 cast.
3629 (fix_inter_tick): Likewise for params "head", "tail".
3630 (create_check_block_twin): Likewise for local "jump".
3631 (haifa_change_pattern): Likewise for param "insn".
3632 (haifa_speculate_insn): Likewise.
3633 (dump_new_block_header): Likewise for params "head", "tail".
3634 (fix_jump_move): Likewise for param "jump".
3635 (move_block_after_check): Likewise.
3636 (sched_init_insn_luid): Likewise for param "insn".
3637 (sched_init_luids): Likewise for local "insn".
3638 (insn_luid): Likewise for param "insn".
3639 (init_h_i_d): Likewise.
3640 (haifa_init_h_i_d): Likewise for local "insn".
3641 (haifa_init_insn): Likewise for param "insn".
3642 * sched-deps.c (add_dependence): Likewise for local "real_pro",
3643 "other".
3644 (create_insn_reg_use): Likewise for param "insn".
3645 (setup_insn_reg_uses): Likewise. Add a checked cast.
3646 * sched-ebb.c (debug_ebb_dependencies): Strengthen params "head",
3647 "tail" from rtx to rtx_insn *.
3648 * sched-rgn.c (void debug_dependencies): Likewise, also for locals
3649 "insn", "next_tail".
3650
3651 2014-08-26 David Malcolm <dmalcolm@redhat.com>
3652
3653 * haifa-sched.c (struct model_insn_info): Strengthen field "insn"
3654 from rtx to rtx_insn *.
3655 (model_add_to_schedule): Likewise for locals "start", "end",
3656 "iter".
3657
3658 2014-08-26 David Malcolm <dmalcolm@redhat.com>
3659
3660 * rtl.h (duplicate_insn_chain): Strengthen both params from rtx to
3661 rtx_insn *.
3662 * cfgrtl.c (duplicate_insn_chain): Likewise for params "from",
3663 "to" and locals "insn", "next", "copy". Remove now-redundant
3664 checked cast.
3665
3666 2014-08-26 David Malcolm <dmalcolm@redhat.com>
3667
3668 * rtl.h (canonicalize_condition): Strengthen param 1 from rtx to
3669 rtx_insn * and param 4 from rtx * to rtx_insn **.
3670 (get_condition): Strengthen param 1 from rtx to rtx_insn * and
3671 param 2 from rtx * to rtx_insn **.
3672
3673 * df.h (can_move_insns_across): Strengthen params 1-4 from rtx to
3674 rtx_insn * and final param from rtx * to rtx_insn **.
3675
3676 * cfgcleanup.c (try_head_merge_bb): Strengthen local "move_before"
3677 from rtx to rtx_insn *.
3678 (try_head_merge_bb): Likewise for both locals named "move_upto".
3679 * df-problems.c (can_move_insns_across): Likewise for params
3680 "from", "to", "across_from", "across_to" and locals "insn",
3681 "next", "max_to". Strengthen param "pmove_upto" from rtx * to
3682 rtx_insn **.
3683 * ifcvt.c (struct noce_if_info): Strengthen field "cond_earliest"
3684 from rtx to rtx_insn *.
3685 (noce_get_alt_condition): Strengthen param "earliest" from rtx *
3686 to rtx_insn **. Strengthen local "insn" from rtx to rtx_insn *.
3687 (noce_try_minmax): Strengthen locals "earliest", "seq" from rtx to
3688 rtx_insn *.
3689 (noce_try_abs): Likewise.
3690 (noce_get_condition): Likewise for param "jump". Strengthen param
3691 "earliest" from rtx * to rtx_insn **.
3692 (noce_find_if_block): Strengthen local "cond_earliest" from rtx to
3693 rtx_insn *.
3694 (find_cond_trap): Likewise.
3695 (dead_or_predicable): Likewise for local "earliest".
3696 * loop-iv.c (check_simple_exit): Likewise for local "at". Add
3697 checked cast.
3698 * rtlanal.c (canonicalize_condition): Likewise for param "insn"
3699 and local "prev". Strengthen param "earliest" from rtx * to
3700 rtx_insn **.
3701 (get_condition): Strengthen param "jump" from rtx to rtx_insn *
3702 Strengthen param "earliest" from rtx * to rtx_insn **.
3703
3704 2014-08-26 David Malcolm <dmalcolm@redhat.com>
3705
3706 * fwprop.c (local_ref_killed_between_p): Strengthen params "from",
3707 "to" and local "insn" from rtx to rtx_insn *.
3708
3709 2014-08-26 David Malcolm <dmalcolm@redhat.com>
3710
3711 * sel-sched.c (find_place_for_bookkeeping): Strengthen local "insn"
3712 from rtx to rtx_insn *.
3713 (need_nop_to_preserve_insn_bb): Likewise for param "insn".
3714 (code_motion_path_driver): Likewise for local "last_insn".
3715 (simplify_changed_insns): Likewise for local "insn".
3716
3717 2014-08-26 David Malcolm <dmalcolm@redhat.com>
3718
3719 * rtl.h (push_to_sequence): Strengthen param from rtx to
3720 rtx_insn *.
3721 (push_to_sequence2): Likewise for both params.
3722 (delete_insns_since): Likewise for param.
3723 (reorder_insns_nobb): Likewise for all three params.
3724 (set_new_first_and_last_insn): Likewise for both params.
3725
3726 * emit-rtl.h (set_first_insn): Strengthen param "insn" from rtx to
3727 rtx_insn *. Remove now-redundant cast.
3728 (set_last_insn): Likewise.
3729
3730 * builtins.c (expand_builtin_return): Strengthen local
3731 "call_fusage" from rtx to rtx_insn *.
3732 * cfgrtl.c (create_basic_block_structure): Likewise for local
3733 "after".
3734 * emit-rtl.c (set_new_first_and_last_insn): Likewise for params
3735 "first", "last" and local "insn".
3736 (delete_insns_since): Likewise for param "from".
3737 (reorder_insns_nobb): Likewise for params "from", "to", "after"
3738 and local "x".
3739 (push_to_sequence): Likewise for param "first" and local "last".
3740 (push_to_sequence2): Likewise for params "first" and "last".
3741 * lra.c (emit_add3_insn): Likewise for local "last".
3742 (lra_emit_add): Likewise.
3743 * lra-constraints.c (base_to_reg): Likewise for locals "insn",
3744 "last_insn".
3745 (process_address_1): Likewise for locals "insn", last".
3746 * modulo-sched.c (ps_first_note): Likewise for return type.
3747 * optabs.c (expand_binop_directly): Likewise for param "last".
3748
3749 2014-08-26 David Malcolm <dmalcolm@redhat.com>
3750
3751 * rtl.h (get_last_insn_anywhere): Strengthen return type from rtx
3752 to rtx_insn*.
3753 * emit-rtl.c (get_last_insn_anywhere): Likewise.
3754
3755 2014-08-26 David Malcolm <dmalcolm@redhat.com>
3756
3757 * function.h (struct sequence_stack): Strengthen fields "first"
3758 and "last" from rtx to rtx_insn *.
3759 (struct emit_status): Likewise for fields "x_first_insn" and
3760 "x_last_insn".
3761
3762 * emit-rtl.h (get_insns): Remove now-redundant checked cast.
3763 (set_first_insn): Add checked cast.
3764 (get_last_insn): Remove now-redundant checked cast.
3765 (set_last_insn): Add checked cast.
3766
3767 * config/m32c/m32c.c (m32c_leaf_function_p): Strengthen locals
3768 "saved_first" and "saved_last" from rtx to rtx_insn *.
3769
3770 2014-08-26 David Malcolm <dmalcolm@redhat.com>
3771
3772 * rtl.h (add_insn): Strengthen param from rtx to rtx_insn *.
3773 (unlink_insn_chain): Strengthen both params from rtx to
3774 rtx_insn *.
3775
3776 * cfgrtl.c (cfg_layout_function_header): Likewise for this
3777 variable.
3778 (unlink_insn_chain): Likewise for params "first" and "last".
3779 Remove now-redundant checked cast.
3780 (record_effective_endpoints): Replace use of NULL_RTX with NULL.
3781 (fixup_reorder_chain): Strengthen local "insn" from rtx to
3782 rtx_insn *.
3783 * emit-rtl.c (link_insn_into_chain): Likewise for all three
3784 params.
3785 (add_insn): Likewise for param "insn" and local "prev".
3786 (add_insn_after_nobb): Likewise for both params and local "next".
3787 (add_insn_before_nobb): Likewise for both params and local "prev".
3788 (add_insn_after): Rename param "after" to "uncast_after",
3789 introducing local "after" with another checked cast.
3790 (add_insn_before): Rename params "insn" and "before", giving them
3791 "uncast_" prefixes, adding the old names back using checked casts.
3792 (emit_note_after): Likewise for param "after".
3793 (emit_note_before): Likewise for param "before".
3794 (emit_label): Add a checked cast.
3795
3796 2014-08-26 David Malcolm <dmalcolm@redhat.com>
3797
3798 * cselib.h (cselib_record_sets_hook): Strengthen initial param
3799 "insn" from rtx to rtx_insn *.
3800
3801 * cselib.c (cselib_record_sets_hook): Likewise.
3802
3803 * var-tracking.c (add_with_sets): Likewise, renaming back from
3804 "uncast_insn" to "insn" and eliminating the checked cast from rtx
3805 to rtx_insn *.
3806
3807 2014-08-26 David Malcolm <dmalcolm@redhat.com>
3808
3809 * basic-block.h (struct rtl_bb_info): Strengthen fields "end_"
3810 and "header_" from rtx to rtx_insn *.
3811 (struct basic_block_d): Likewise for field "head_" within "x"
3812 field of union basic_block_il_dependent.
3813 (BB_HEAD): Drop function...
3814 (SET_BB_HEAD): ...and this function in favor of...
3815 (BB_HEAD): ...reinstate macro.
3816 (BB_END): Drop function...
3817 (SET_BB_END): ...and this function in favor of...
3818 (BB_END): ...reinstate macro.
3819 (BB_HEADER): Drop function...
3820 (SET_BB_HEADER): ...and this function in favor of...
3821 (BB_HEADER): ...reinstate macro.
3822
3823 * bb-reorder.c (add_labels_and_missing_jumps): Drop use of BB_END.
3824 (fix_crossing_unconditional_branches): Likewise.
3825 * caller-save.c (save_call_clobbered_regs): Likewise.
3826 (insert_one_insn): Drop use of SET_BB_HEAD and SET_BB_END.
3827 * cfgbuild.c (find_bb_boundaries): Drop use of SET_BB_END.
3828 * cfgcleanup.c (merge_blocks_move_successor_nojumps): Likewise.
3829 (merge_blocks_move_successor_nojumps): Likewise.
3830 (outgoing_edges_match): Update use of for_each_rtx to
3831 for_each_rtx_in_insn.
3832 * cfgexpand.c (expand_gimple_cond): Drop use of SET_BB_END.
3833 (expand_gimple_cond): Likewise.
3834 (expand_gimple_tailcall): Likewise.
3835 (expand_gimple_basic_block): Drop use of SET_BB_HEAD and
3836 SET_BB_END.
3837 (construct_exit_block): Drop use of SET_BB_END.
3838 * cfgrtl.c (cfg_layout_function_footer): Strengthen from rtx to
3839 rtx_insn *.
3840 (delete_insn): Rename param "insn" to "uncast_insn", introducing
3841 a new local "insn" with a checked cast to rtx_insn *. Drop use of
3842 SET_BB_HEAD and SET_BB_END.
3843 (create_basic_block_structure): Drop use of SET_BB_HEAD and
3844 SET_BB_END.
3845 (rtl_delete_block): Drop use of SET_BB_HEAD.
3846 (rtl_split_block): Drop use of SET_BB_END.
3847 (emit_nop_for_unique_locus_between): Likewise.
3848 (rtl_merge_blocks): Drop use of SET_BB_END and SET_BB_HEAD.
3849 (block_label): Drop use of SET_BB_HEAD.
3850 (fixup_abnormal_edges): Drop use of SET_BB_END.
3851 (record_effective_endpoints): Drop use of SET_BB_HEADER.
3852 (relink_block_chain): Likewise.
3853 (fixup_reorder_chain): Drop use of SET_BB_END.
3854 (cfg_layout_duplicate_bb): Drop use of SET_BB_HEADER.
3855 (cfg_layout_delete_block): Strengthen local "to" from rtx * to
3856 rtx_insn **. Drop use of SET_BB_HEADER.
3857 (cfg_layout_merge_blocks): Drop use of SET_BB_HEADER, SET_BB_END,
3858 SET_BB_HEAD.
3859 (BB_HEAD): Delete this function.
3860 (SET_BB_HEAD): Likewise.
3861 (BB_END): Likewise.
3862 (SET_BB_END): Likewise.
3863 (BB_HEADER): Likewise.
3864 (SET_BB_HEADER): Likewise.
3865 * emit-rtl.c (add_insn_after): Rename param "insn" to
3866 "uncast_insn", adding a new local "insn" and a checked cast to
3867 rtx_insn *. Drop use of SET_BB_END.
3868 (remove_insn): Strengthen locals "next" and "prev" from rtx to
3869 rtx_insn *. Drop use of SET_BB_HEAD and SET_BB_END.
3870 (reorder_insns): Drop use of SET_BB_END.
3871 (emit_insn_after_1): Strengthen param "first" and locals "last",
3872 "after_after" from rtx to rtx_insn *. Drop use of SET_BB_END.
3873 (emit_pattern_after_noloc): Add checked cast.
3874 * haifa-sched.c (get_ebb_head_tail): Drop use of SET_BB_END.
3875 (restore_other_notes): Likewise.
3876 (move_insn): Likewise.
3877 (sched_extend_bb): Likewise.
3878 (fix_jump_move): Likewise.
3879 * ifcvt.c (noce_process_if_block): Likewise.
3880 (dead_or_predicable): Likewise.
3881 * ira.c (update_equiv_regs): Drop use of SET_BB_HEAD.
3882 * reg-stack.c (change_stack): Drop use of SET_BB_END.
3883 * sel-sched-ir.c (sel_move_insn): Likewise.
3884 * sel-sched.c (move_nop_to_previous_block): Likewise.
3885
3886 * config/c6x/c6x.c (hwloop_optimize): Drop use of SET_BB_HEAD and
3887 SET_BB_END.
3888 * config/ia64/ia64.c (emit_predicate_relation_info): Likewise.
3889
3890 2014-08-26 David Malcolm <dmalcolm@redhat.com>
3891
3892 * basic-block.h (create_basic_block_structure): Strengthen params
3893 1 "head" and 2 "end" from rtx to rtx_insn *.
3894 * cfgrtl.c (create_basic_block_structure): Likewise.
3895 (rtl_create_basic_block): Update casts from void * to rtx to
3896 rtx_insn *, so that we can pass them as rtx_insn * to
3897 create_basic_block_structure.
3898 * sel-sched-ir.c (sel_create_basic_block): Likewise.
3899
3900 2014-08-26 David Malcolm <dmalcolm@redhat.com>
3901
3902 * rtl.h (for_each_inc_dec): Strengthen param 1 from rtx * to
3903 rtx_insn **.
3904 (check_for_inc_dec): Strengthen param "insn" from rtx to
3905 rtx_insn *.
3906
3907 * cselib.h (cselib_process_insn): Likewise.
3908
3909 * cselib.c (cselib_record_sets): Likewise.
3910 (cselib_process_insn): Likewise.
3911
3912 * dse.c (struct insn_info): Likewise for field "insn".
3913 (check_for_inc_dec_1): Likewise for local "insn".
3914 (check_for_inc_dec): Likewise for param "insn".
3915 (scan_insn): Likewise.
3916 (dse_step1): Likewise for local "insn".
3917
3918 * rtlanal.c (for_each_inc_dec): Strengthen param 1 from rtx * to
3919 rtx_insn **. Use for_each_rtx_in_insn rather than for_each_rtx.
3920
3921 2014-08-26 David Malcolm <dmalcolm@redhat.com>
3922
3923 * sched-int.h (struct _dep): Strengthen fields "pro" and "con"
3924 from rtx to rtx_insn *.
3925 (DEP_PRO): Delete this function and...
3926 (SET_DEP_PRO): ...this function in favor of...
3927 (DEP_PRO): ...reinstate this macro.
3928 (DEP_CON): Delete this function and...
3929 (SET_DEP_CON): ...this function in favor of...
3930 (DEP_CON): ...reinstate this old macro.
3931 (init_dep_1): Strengthen params 2 and 3 from rtx to rtx_insn *.
3932 (init_dep): Likewise.
3933 (set_priorities): Likewise for both params.
3934 (sd_copy_back_deps): Likewise for params 1 and 2.
3935
3936 * haifa-sched.c (priority): Likewise for param "insn" and local
3937 "next".
3938 (set_priorities): Likewise for params "head" and "tail" and local
3939 "insn".
3940 (process_insn_forw_deps_be_in_spec): Likewise for param "twin" and
3941 local "consumer".
3942 (add_to_speculative_block): Add a checked cast.
3943 (create_check_block_twin): Drop use of SET_DEP_CON.
3944 (add_jump_dependencies): Strengthen params "insn" and "jump" from
3945 rtx to rtx_insn *.
3946
3947 * sched-deps.c (init_dep_1): Likewise for params "pro" and "con".
3948 Drop use of SET_DEP_PRO
3949 (init_dep): Strengthen params "pro" and "con" from rtx to
3950 rtx_insn *.
3951 (sd_copy_back_deps): Likewise for params "to" and "from". Drop
3952 use of SET_DEP_CON.
3953 (DEP_PRO): Delete.
3954 (DEP_CON): Delete.
3955 (SET_DEP_PRO): Delete.
3956 (SET_DEP_CON): Delete.
3957
3958 2014-08-26 David Malcolm <dmalcolm@redhat.com>
3959
3960 * sel-sched-ir.h (struct vinsn_def): Strengthen field "insn_rtx"
3961 from rtx to rtx_insn *.
3962 (VINSN_INSN_RTX): Eliminate rvalue function and...
3963 (SET_VINSN_INSN): ...lvalue function in favor of...
3964 (VINSN_INSN_RTX): reinstate this old macro.
3965
3966 * sel-sched-ir.c (vinsn_init): Eliminate use of SET_VINSN_INSN_RTX
3967 in favor of VINSN_INSN_RTX.
3968 (VINSN_INSN_RTX): Delete this function.
3969 (SET_VINSN_INSN_RTX): Likewise.
3970
3971 2014-08-26 David Malcolm <dmalcolm@redhat.com>
3972
3973 * sel-sched-ir.h (insn_t): Strengthen from rtx to rtx_insn *.
3974 (BND_TO): Delete this function and...
3975 (SET_BND_TO): ...this functions in favor of...
3976 (BND_TO): ...reinstating this macro.
3977 (struct _fence): Strengthen field "executing_insns" from
3978 vec<rtx, va_gc> * to vec<rtx_insn *, va_gc> *. Strengthen fields
3979 "last_scheduled_insn" and "sched_next" from rtx to rtx_insn *.
3980 (_succ_iter_cond): Update param "succp" from rtx * to insn_t *
3981 and param "insn" from rtx to insn_t.
3982 (create_vinsn_from_insn_rtx): Strengthen first param from rtx to
3983 rtx_insn *.
3984
3985 * sched-int.h (insn_vec_t): Strengthen from vec<rtx> to
3986 vec<rtx_insn *> .
3987 (rtx_vec_t): Likewise.
3988 (struct sched_deps_info_def): Strengthen param of "start_insn"
3989 callback from rtx to rtx_insn *. Likewise for param "insn2" of
3990 "note_mem_dep" callback and first param of "note_dep" callback.
3991
3992 * haifa-sched.c (add_to_speculative_block): Strengthen param
3993 "insn" from rtx to rtx_insn *.
3994 (clear_priorities): Likewise.
3995 (calc_priorities): Likewise for local "insn".
3996
3997 * sched-deps.c (haifa_start_insn): Likewise for param "insn".
3998 Remove redundant checked cast.
3999 (haifa_note_mem_dep): Likewise for param "pending_insn".
4000 (haifa_note_dep): Likewise for param "elem".
4001 (note_mem_dep): Likewise for param "e".
4002 (sched_analyze_1): Add checked casts.
4003 (sched_analyze_2): Likewise.
4004
4005 * sel-sched-dump.c (dump_insn_vector): Strengthen local "succ"
4006 from rtx to rtx_insn *.
4007 (debug): Update param from vec<rtx> & to vec<rtx_insn *>, and
4008 from vec<rtx> * to vec<rtx_insn *> *.
4009
4010 * sel-sched-ir.c (blist_add): Remove use of SET_BND_TO
4011 scaffolding.
4012 (flist_add): Strengthen param "executing_insns" from
4013 vec<rtx, va_gc> * to vec<rtx_insn *, va_gc> *.
4014 (advance_deps_context): Remove now-redundant checked cast.
4015 (init_fences): Replace uses of NULL_RTX with NULL.
4016 (merge_fences): Strengthen params "last_scheduled_insn" and
4017 "sched_next" from rtx to rtx_insn * and "executing_insns" from
4018 vec<rtx, va_gc> * to vec<rtx_insn *, va_gc> *.
4019 (add_clean_fence_to_fences): Replace uses of NULL_RTX with NULL.
4020 (get_nop_from_pool): Add local "nop_pat" so that "nop" can be
4021 an instruction, rather than doing double-duty as a pattern.
4022 (return_nop_to_pool): Update for change of insn_t.
4023 (deps_init_id): Remove now-redundant checked cast.
4024 (struct sched_scan_info_def): Strengthen param of "init_insn"
4025 callback from rtx to insn_t.
4026 (sched_scan): Strengthen local "insn" from rtx to rtx_insn *.
4027 (init_global_and_expr_for_insn): Replace uses of NULL_RTX with
4028 NULL.
4029 (get_seqno_by_succs): Strengthen param "insn" and locals "tmp",
4030 "end" from rtx to rtx_insn *.
4031 (create_vinsn_from_insn_rtx): Likewise for param "insn_rtx".
4032 (rtx insn_rtx, bool force_unique_p)
4033 (BND_TO): Delete function.
4034 (SET_BND_TO): Delete function.
4035
4036 * sel-sched.c (advance_one_cycle): Strengthen local "insn" from
4037 rtx to rtx_insn *.
4038 (extract_new_fences_from): Replace uses of NULL_RTX with NULL.
4039 (replace_dest_with_reg_in_expr): Strengthen local "insn_rtx" from
4040 rtx to rtx_insn *.
4041 (undo_transformations): Likewise for param "insn".
4042 (update_liveness_on_insn): Likewise.
4043 (compute_live_below_insn): Likewise for param "insn" and local
4044 "succ".
4045 (update_data_sets): Likewise for param "insn".
4046 (fill_vec_av_set): Replace uses of NULL_RTX with NULL.
4047 (convert_vec_av_set_to_ready): Drop now-redundant checked cast.
4048 (invoke_aftermath_hooks): Strengthen param "best_insn" from rtx to
4049 rtx_insn *.
4050 (move_cond_jump): Likewise for param "insn".
4051 (move_cond_jump): Drop use of SET_BND_TO.
4052 (compute_av_set_on_boundaries): Likewise.
4053 (update_fence_and_insn): Replace uses of NULL_RTX with NULL.
4054 (update_and_record_unavailable_insns): Strengthen local "bb_end"
4055 from rtx to rtx_insn *.
4056 (maybe_emit_renaming_copy): Likewise for param "insn".
4057 (maybe_emit_speculative_check): Likewise.
4058 (handle_emitting_transformations): Likewise.
4059 (remove_insn_from_stream): Likewise.
4060 (code_motion_process_successors): Strengthen local "succ" from rtx
4061 to insn_t.
4062
4063 2014-08-26 David Malcolm <dmalcolm@redhat.com>
4064
4065 * sel-sched-ir.h (ilist_t): Redefine this typedef in terms of
4066 ilist_t, not _xlist_t;
4067 (ILIST_INSN): Define in terms of new union field "insn".
4068 (ILIST_NEXT): Define in terms of _LIST_NEXT rather than
4069 _XLIST_NEXT.
4070 (struct _list_node): Add new field "insn" to the union, of type
4071 insn_t.
4072 (ilist_add): Replace macro with an inline function, requiring an
4073 insn_t.
4074 (ilist_remove): Define this macro directly in terms of
4075 _list_remove, rather than indirectly via _xlist_remove.
4076 (ilist_clear): Likewise, in terms of _list_clear rather than
4077 _xlist_clear.
4078 (ilist_is_in_p): Replace macro with an inline function, requiring
4079 an insn_t.
4080 (_list_iter_cond_insn): New function.
4081 (ilist_iter_remove): Define this macro directly in terms of
4082 _list_iter_remove, rather than indirectly via _xlist_iter_remove.
4083 (ilist_iterator): Define directly in terms of _list_iterator
4084 rather than indirectly through _xlist_iterator.
4085 (FOR_EACH_INSN): Define in terms of _list_iter_cond_insn rather
4086 than in terms of _FOR_EACH_X.
4087 (FOR_EACH_INSN_1): Likewise.
4088
4089 2014-08-26 Joseph Myers <joseph@codesourcery.com>
4090
4091 PR target/60606
4092 PR target/61330
4093 * varasm.c (make_decl_rtl): Clear DECL_ASSEMBLER_NAME and
4094 DECL_HARD_REGISTER and return for invalid register specifications.
4095 * cfgexpand.c (expand_one_var): If expand_one_hard_reg_var clears
4096 DECL_HARD_REGISTER, call expand_one_error_var.
4097 * config/arm/arm.c (arm_hard_regno_mode_ok): Do not allow
4098 CC_REGNUM with non-MODE_CC modes.
4099 (arm_regno_class): Return NO_REGS for PC_REGNUM.
4100
4101 2014-08-26 Marek Polacek <polacek@redhat.com>
4102
4103 PR c/61271
4104 * sel-sched-ir.c (make_regions_from_the_rest): Fix condition.
4105
4106 2014-08-26 Evandro Menezes <e.menezes@samsung.com>
4107
4108 * config/arm/aarch64/aarch64.c (generic_addrcost_table): Delete
4109 qi cost; add di cost.
4110 (cortexa57_addrcost_table): Likewise.
4111
4112 2014-08-26 Marek Polacek <polacek@redhat.com>
4113
4114 PR c/61271
4115 * expr.c (is_aligning_offset): Remove logical not.
4116
4117 2014-08-26 Marek Polacek <polacek@redhat.com>
4118
4119 PR c/61271
4120 * tree-vectorizer.h (LOOP_REQUIRES_VERSIONING_FOR_ALIGNMENT,
4121 LOOP_REQUIRES_VERSIONING_FOR_ALIAS): Wrap in parens.
4122
4123 2014-08-26 Richard Biener <rguenther@suse.de>
4124
4125 PR tree-optimization/62175
4126 * tree-ssa-loop-niter.c (expand_simple_operations): Do not
4127 expand possibly trapping operations.
4128
4129 2014-08-26 David Malcolm <dmalcolm@redhat.com>
4130
4131 * config/rs6000/rs6000.c (class swap_web_entry): Strengthen field
4132 "insn" from rtx to rtx_insn *.
4133 (permute_load): Likewise for param "insn".
4134 (permute_store): Likewise.
4135 (handle_special_swappables): Likewise for local "insn".
4136 (replace_swap_with_copy): Likewise for locals "insn" and
4137 "new_insn".
4138 (rs6000_analyze_swaps): Likewise for local "insn".
4139
4140 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4141
4142 * regrename.h (struct du_chain): Strengthen field "insn" from rtx
4143 to rtx_insn *.
4144
4145 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4146
4147 * sel-sched-ir.h (struct sel_region_bb_info_def): Strengthen field
4148 "note_list" from rtx to rtx_insn *.
4149 (BB_NOTE_LIST): Replace this function and...
4150 (SET_BB_NOTE_LIST): ...this function with...
4151 (BB_NOTE_LIST): ...the former macro implementation.
4152
4153 * sched-int.h (concat_note_lists): Strengthen param "from_end" and
4154 local "from_start" from rtx to rtx_insn *. Strengthen param
4155 "to_endp" from rtx * to rtx_insn **.
4156
4157 * haifa-sched.c (concat_note_lists): Likewise.
4158 * sel-sched-ir.c (init_bb): Eliminate SET_BB_NOTE_LIST in favor of
4159 BB_NOTE_LIST.
4160 (sel_restore_notes): Likewise.
4161 (move_bb_info): Likewise.
4162 (BB_NOTE_LIST): Delete this function.
4163 (SET_BB_NOTE_LIST): Delete this function.
4164 * sel-sched.c (create_block_for_bookkeeping): Eliminate
4165 SET_BB_NOTE_LIST in favor of BB_NOTE_LIST.
4166
4167 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4168
4169 * target.def (reorder): Strengthen param "ready" of this DEFHOOK
4170 from rtx * to rtx_insn **.
4171 (reorder2): Likewise.
4172 (dependencies_evaluation_hook): Strengthen params "head", "tail"
4173 from rtx to rtx_insn *.
4174
4175 * doc/tm.texi: Update mechanically for above change to target.def.
4176
4177 * sched-int.h (note_list): Strengthen this variable from rtx to
4178 rtx_insn *.
4179 (remove_notes): Likewise for both params.
4180 (restore_other_notes): Likewise for return type and first param.
4181 (struct ready_list): Strengthen field "vec" from rtx * to
4182 rtx_insn **.
4183 (struct dep_replacement): Strenghten field "insn" from rtx to
4184 rtx_insn *.
4185 (struct deps_desc): Likewise for fields "last_debug_insn",
4186 "last_args_size".
4187 (struct haifa_sched_info): Likewise for callback field
4188 "can_schedule_ready_p"'s param, for first param of "new_ready"
4189 callback field, for both params of "rank" callback field, for
4190 first field of "print_insn" callback field (with a const), for
4191 both params of "contributes_to_priority" callback, for param
4192 of "insn_finishes_block_p" callback, for fields "prev_head",
4193 "next_tail", "head", "tail", for first param of "add_remove_insn"
4194 callback, for first param of "begin_schedule_ready" callback, for
4195 both params of "begin_move_insn" callback, and for second param
4196 of "advance_target_bb" callback.
4197 (add_dependence): Likewise for params 1 and 2.
4198 (sched_analyze): Likewise for params 2 and 3.
4199 (deps_analyze_insn): Likewise for param 2.
4200 (ready_element): Likewise for return type.
4201 (ready_lastpos): Strengthen return type from rtx * to rtx_insn **.
4202 (try_ready): Strenghten param from rtx to rtx_insn *.
4203 (sched_emit_insn): Likewise for return type.
4204 (record_delay_slot_pair): Likewise for params 1 and 2.
4205 (add_delay_dependencies): Likewise for param.
4206 (contributes_to_priority): Likewise for both params.
4207 (find_modifiable_mems): Likewise.
4208
4209 * config/arm/arm.c (cortexa7_sched_reorder): Strengthen param
4210 "ready" from rtx * to rtx_insn **. Strengthen locals "insn",
4211 "first_older_only_insn" from rtx to rtx_insn *.
4212 (arm_sched_reorder): Strengthen param "ready" from rtx * to
4213 rtx_insn **.
4214
4215 * config/c6x/c6x.c (struct c6x_sched_context): Strengthen field
4216 "last_scheduled_iter0" from rtx to rtx_insn *.
4217 (init_sched_state): Replace use of NULL_RTX with NULL for insn.
4218 (c6x_sched_reorder_1): Strengthen param "ready" and locals
4219 "e_ready", "insnp" from rtx * to rtx_insn **. Strengthen local
4220 "insn" from rtx to rtx_insn *.
4221 (c6x_sched_reorder): Strengthen param "ready" from rtx * to
4222 rtx_insn **.
4223 (c6x_sched_reorder2): Strengthen param "ready" and locals
4224 "e_ready", "insnp" from rtx * to rtx_insn **. Strengthen local
4225 "insn" from rtx to rtx_insn *.
4226 (c6x_variable_issue): Add a checked cast when assigning from insn
4227 to ss.last_scheduled_iter0.
4228 (split_delayed_branch): Strengthen param "insn" and local "i1"
4229 from rtx to rtx_insn *.
4230 (split_delayed_nonbranch): Likewise.
4231 (undo_split_delayed_nonbranch): Likewise for local "insn".
4232 (hwloop_optimize): Likewise for locals "seq", "insn", "prev",
4233 "entry_after", "end_packet", "head_insn", "tail_insn",
4234 "new_insns", "last_insn", "this_iter", "prev_stage_insn".
4235 Strengthen locals "orig_vec", "copies", "insn_copies" from rtx *
4236 to rtx_insn **. Remove now-redundant checked cast on last_insn,
4237 but add a checked cast on loop->start_label. Consolidate calls to
4238 avoid assigning result of gen_spkernel to "insn", now an
4239 rtx_insn *.
4240
4241 * config/i386/i386.c (do_reorder_for_imul): Strengthen param
4242 "ready" from rtx * to rtx_insn **. Strengthen local "insn" from
4243 rtx to rtx_insn *.
4244 (swap_top_of_ready_list): Strengthen param "ready" from rtx * to
4245 rtx_insn **. Strengthen locals "top", "next" from rtx to
4246 rtx_insn *.
4247 (ix86_sched_reorder): Strengthen param "ready" from rtx * to
4248 rtx_insn **. Strengthen local "insn" from rtx to rtx_insn *.
4249 (add_parameter_dependencies): Strengthen params "call", "head" and
4250 locals "insn", "last", "first_arg" from rtx to rtx_insn *.
4251 (avoid_func_arg_motion): Likewise for params "first_arg", "insn".
4252 (add_dependee_for_func_arg): Likewise for param "arg" and local
4253 "insn".
4254 (ix86_dependencies_evaluation_hook): Likewise for params "head",
4255 "tail" and locals "insn", "first_arg".
4256
4257 * config/ia64/ia64.c (ia64_dependencies_evaluation_hook): Likewise
4258 for params "head", "tail" and locals "insn", "next", "next_tail".
4259 (ia64_dfa_sched_reorder): Strengthen param "ready" and locals
4260 "e_ready", "insnp" from rtx * to rtx_insn **. Strengthen locals
4261 "insn", "lowest", "highest" from rtx to rtx_insn *.
4262 (ia64_sched_reorder): Strengthen param "ready" from rtx * to
4263 rtx_insn **.
4264 (ia64_sched_reorder2): Likewise.
4265
4266 * config/mep/mep.c (mep_find_ready_insn): Strengthen return type
4267 and local "insn" from rtx to rtx_insn *. Strengthen param "ready"
4268 from rtx * to rtx_insn **.
4269 (mep_move_ready_insn): Strengthen param "ready" from rtx * to
4270 rtx_insn **.
4271 (mep_print_sched_insn): Strengthen param "insn" from rtx to
4272 rtx_insn *.
4273 (mep_sched_reorder): Strengthen param "ready" from rtx * to
4274 rtx_insn **. Strengthen locals "core_insn", "cop_insn" from rtx
4275 to rtx_insn *.
4276
4277 * config/mips/mips.c (mips_promote_ready): Strengthen param "ready"
4278 from rtx * to rtx_insn **. Strengthen local "new_head" from rtx
4279 to rtx_insn *.
4280 (mips_maybe_swap_ready): Strengthen param "ready" from rtx * to
4281 rtx_insn **. Strengthen local "temp" from rtx to rtx_insn *.
4282 (mips_macc_chains_reorder): Strengthen param "ready" from rtx * to
4283 rtx_insn **.
4284 (vr4130_reorder): Likewise.
4285 (mips_74k_agen_reorder): Likewise. Strengthen local "insn" from
4286 rtx to rtx_insn *.
4287 (mips_sched_reorder_1): Strengthen param "ready" from rtx * to
4288 rtx_insn **.
4289 (mips_sched_reorder): Likewise.
4290 (mips_sched_reorder2): Likewise.
4291
4292 * config/picochip/picochip.c (picochip_sched_reorder): Likewise.
4293
4294 * config/rs6000/rs6000.c (rs6000_sched_reorder): Likewise.
4295 Strengthen local "tmp" from rtx to rtx_insn *.
4296 (rs6000_sched_reorder2): Likewise.
4297
4298 * config/s390/s390.c (s390_z10_prevent_earlyload_conflicts):
4299 Likewise. Update sizeof(rtx) to sizeof(rtx_insn *) in memmove.
4300 (s390_sched_reorder): Strengthen param "ready" from rtx * to
4301 rtx_insn **. Strengthen local "tmp" from rtx to rtx_insn *.
4302
4303 * config/sh/sh.c (rank_for_reorder): Strengthen locals "tmp",
4304 "tmp2" from rtx to rtx_insn *.
4305 (swap_reorder): Strengthen param "a" from rtx * to rtx_insn **.
4306 Strengthen local "insn" from rtx to rtx_insn *.
4307 (ready_reorder): Strengthen param "ready" from rtx * to
4308 rtx_insn **. Update sizeof(rtx) to sizeof(rtx_insn *) in qsort.
4309 (sh_reorder): Strengthen param "ready" from rtx * to rtx_insn **.
4310 (sh_reorder2): Likewise.
4311
4312 * config/spu/spu.c (spu_sched_reorder): Likewise. Strengthen
4313 local "insn" from rtx to rtx_insn *.
4314
4315 * haifa-sched.c (note_list): Strengthen this variable from rtx to
4316 rtx_insn *.
4317 (scheduled_insns): Strengthen this variable from vec<rtx> to
4318 vec<rtx_insn *>.
4319 (set_modulo_params): Likewise for locals "i1", "i2".
4320 (record_delay_slot_pair): Likewise for params "i1", "i2".
4321 (add_delay_dependencies): Likewise for param "insn".
4322 (cond_clobbered_p): Likewise.
4323 (recompute_todo_spec): Likewise for local "prev".
4324 (last_scheduled_insn): Likewise for this variable.
4325 (nonscheduled_insns_begin): Likewise.
4326 (model_set_excess_costs): Strengthen param "insns" from rtx * to
4327 rtx_insn **.
4328 (rank_for_schedule): Strengthen locals "tmp", "tmp2" from rtx to
4329 rtx_insn *.
4330 (swap_sort): Strengthen param "a" from rtx * to rtx_insn **.
4331 Strengthen local "insn" from rtx to rtx_insn *.
4332 (queue_insn): Strengthen param "insn" from rtx to rtx_insn *.
4333 (ready_lastpos): Strengthen return type from rtx * to rtx_insn **.
4334 (ready_add): Strengthen param "insn" from rtx to rtx_insn *.
4335 (ready_remove_first): Likewise for return type and local "t".
4336 (ready_element): Likewise for return type.
4337 (ready_remove): Likewise for return type and local "t".
4338 (ready_sort): Strengthen local "first" from rtx * to rtx_insn **.
4339 (check_clobbered_conditions): Strengthen local "x" from rtx to
4340 rtx_insn *, adding a checked cast.
4341 (schedule_insn): Likewise for param "insn".
4342 (remove_notes): Likewise for params "head", "tail" and locals
4343 "next_tail", "insn", "next".
4344 (struct haifa_saved_data): Likewise for fields
4345 "last_scheduled_insn", "nonscheduled_insns_begin".
4346 (save_backtrack_point): Update for change to field "vec" of
4347 struct ready_list.
4348 (toggle_cancelled_flags): Strengthen local "first" from rtx * to
4349 rtx_insn **.
4350 (restore_last_backtrack_point): Likewise. Strengthen local "insn"
4351 from rtx to rtx_insn *
4352 (resolve_dependencies): Strengthen param "insn" from rtx to
4353 rtx_insn *
4354 (restore_other_notes): Likewise for return type, for param "head"
4355 and local "note_head".
4356 (undo_all_replacements): Likewise for local "insn".
4357 (first_nonscheduled_insn): Likewise for return type and local "insn".
4358 (queue_to_ready): Likewise for local "insn", adding checked casts.
4359 (early_queue_to_ready): Likewise for local "insn".
4360 (debug_ready_list_1): Strengthen local "p" from rtx * to
4361 rtx_insn **.
4362 (move_insn): Strengthen param "insn" and local "note" from rtx to
4363 rtx_insn *
4364 (insn_finishes_cycle_p): Likewise for param "insn".
4365 (max_issue): Likewise for local "insn".
4366 (choose_ready): Likewise. Strengthen param "insn_ptr" from rtx *
4367 to rtx_insn **.
4368 (commit_schedule): Strengthen param "prev_head" and local "insn"
4369 from rtx to rtx_insn *
4370 (prune_ready_list): Likewise for local "insn".
4371 (schedule_block): Likewise for locals "prev_head", "head", "tail",
4372 "skip_insn", "insn", "failed_insn", "x", adding a checked cast.
4373 (set_priorities): Likewise for local "prev_head".
4374 (try_ready): Likewise for param "next".
4375 (fix_tick_ready): Likewise.
4376 (change_queue_index): Likewise.
4377 (sched_extend_ready_list): Update for change to field "vec" of
4378 struct ready_list.
4379 (generate_recovery_code): Strengthen param "insn" from rtx to
4380 rtx_insn *.
4381 (begin_speculative_block): Likewise.
4382 (create_check_block_twin): Likewise for param "insn" and locals
4383 "label", "check", "twin". Introduce local "check_pat" to avoid
4384 "check" being used as a plain rtx before being used as an insn.
4385 (fix_recovery_deps): Add a checked cast to rtx_insn * when
4386 extracting elements from ready_list.
4387 (sched_remove_insn): Strengthen param "insn" from rtx to
4388 rtx_insn *.
4389 (sched_emit_insn): Likewise for return type.
4390 (ready_remove_first_dispatch): Likewise for return type and local
4391 "insn".
4392
4393 * hw-doloop.c (discover_loop): Add a checked cast to rtx_insn *.
4394
4395 * modulo-sched.c (sms_print_insn): Strengthen from const_rtx to
4396 const rtx_insn *.
4397
4398 * sched-deps.c (add_dependence): Strengthen params "con", "pro"
4399 from rtx to rtx_insn *.
4400 (add_dependence_list): Likewise for param "insn". Add a checked
4401 cast.
4402 (add_dependence_list_and_free): Strengthen param "insn" from rtx
4403 to rtx_insn *. Strengthen param "list_p" from rtx * to
4404 rtx_insn **.
4405 (chain_to_prev_insn): Strengthen param "insn" and locals
4406 "prec_nonnote", "i" from rtx to rtx_insn *.
4407 (flush_pending_lists): Likewise for param "insn".
4408 (cur_insn): Likewise for this variable.
4409 (haifa_start_insn): Add a checked cast.
4410 (note_dep): Strengthen param "e" from rtx to rtx_insn *.
4411 (sched_analyze_reg): Likewise for param "insn".
4412 (sched_analyze_1): Likewise.
4413 (sched_analyze_2): Likewise. Add checked casts.
4414 (sched_analyze_insn): Likewise. Also for local "prev".
4415 (deps_analyze_insn): Likewise for param "insn".
4416 (sched_analyze): Likewise for params "head", "tail" and local "insn".
4417 (add_dependence_1): Likewise for params "insn", "elem".
4418 (struct mem_inc_info): Likewise for fields "inc_insn", "mem_insn".
4419 (parse_add_or_inc): Likewise for param "insn".
4420 (find_inc): Likewise for local "inc_cand".
4421 (find_modifiable_mems): Likewise for params "head", "tail" and
4422 locals "insn", "next_tail".
4423
4424 * sched-ebb.c (init_ready_list): Likewise for local "insn".
4425 (begin_schedule_ready): Likewise for param "insn".
4426 (begin_move_insn): Likewise for params "insn" and "last".
4427 (ebb_print_insn): Strengthen param "insn" from const_rtx to
4428 const rtx_insn *.
4429 (rank): Strengthen params "insn1", "insn2" from rtx to rtx_insn *.
4430 (ebb_contributes_to_priority): Likewise for params "next", "insn".
4431 (ebb_add_remove_insn): Likewise for param "insn".
4432 (advance_target_bb): Likewise.
4433
4434 * sched-rgn.c (rgn_estimate_number_of_insns): Likewise for local
4435 "insn".
4436 (check_live): Likewise for param "insn".
4437 (init_ready_list): Likewise for local "insn".
4438 (can_schedule_ready_p): Likewise for param "insn".
4439 (begin_schedule_ready): Likewise.
4440 (new_ready): Likewise for param "next".
4441 (rgn_print_insn): Likewise for param "insn".
4442 (rgn_rank): Likewise for params "insn1", "insn2".
4443 (contributes_to_priority): Likewise for params "next", "insn".
4444 (rgn_insn_finishes_block_p): Likewise for param "insn".
4445 (add_branch_dependences): Likewise for params "head", "tail" and
4446 locals "insn", "last".
4447 (rgn_add_remove_insn): Likewise for param "insn".
4448 (advance_target_bb): Likewise.
4449
4450 * sel-sched-dump.c (sel_print_insn): Strengthen param "insn" from
4451 const_rtx to const rtx_insn *.
4452
4453 * sel-sched-dump.h (sel_print_insn): Likewise.
4454
4455 * sel-sched-ir.c (advance_deps_context): Add a checked cast.
4456 (deps_init_id): Likewise.
4457
4458 * sel-sched.c (convert_vec_av_set_to_ready): Likewise.
4459 (invoke_reorder_hooks): Strengthen local "arr" from rtx * to
4460 rtx_insn **.
4461
4462 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4463
4464 * output.h (final_start_function): Strengthen param 1 from rtx to
4465 rtx_insn *.
4466
4467 * final.c (final_start_function): Likewise, renaming back from
4468 "uncast_first" to "first", and dropping the checked cast from rtx
4469 to rtx_insn *.
4470
4471 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4472
4473 * output.h (final): Strengthen param 1 from rtx to rtx_insn *.
4474 * final.c (final): Likewise. Rename param back from
4475 "uncast_first" to "first" and eliminate the checked cast from rtx
4476 to rtx_insn *.
4477
4478 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4479
4480 * output.h (shorten_branches): Strengthen param from rtx to
4481 rtx_insn *.
4482
4483 * final.c (shorten_branches): Likewise, renaming param back from
4484 "uncast_first" to "first", and dropping the checked cast from rtx
4485 to rtx_insn *.
4486
4487 * genattr.c (gen_attr): Likewise when writing out the prototype of
4488 shorten_branches.
4489
4490 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4491
4492 * sched-int.h (struct haifa_sched_info): Strengthen fields
4493 "prev_head" and "next_tail" from rtx to rtx_insn *.
4494
4495 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4496
4497 * rtl.h (rtx_jump_table_data::get_labels): New method.
4498 * cfgbuild.c (make_edges): Replace hand-coded lookup of labels
4499 with use of the new rtx_jump_table_data::get_labels method.
4500 (purge_dead_tablejump_edges): Strengthen param "table" from rtx
4501 to rtx_jump_table_data *. Simplify by using get_labels method.
4502 * cfgrtl.c (delete_insn): Replace use of JUMP_TABLE_DATA_P with
4503 a dyn_cast, introducing local "table", using it to replace
4504 label-lookup logic with a get_labels method call.
4505 (patch_jump_insn): Simplify using get_labels method.
4506 * dwarf2cfi.c (create_trace_edges): Likewise.
4507 * rtlanal.c (label_is_jump_target_p): Likewise.
4508
4509 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4510
4511 * rtl.h (unshare_all_rtl_again): Strengthen param "insn" from rtx
4512 to rtx_insn *.
4513
4514 * emit-rtl.c (unshare_all_rtl_1): Likewise.
4515 (unshare_all_rtl_again): Likewise, also for local "p".
4516
4517 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4518
4519 * rtl.h (delete_insn_and_edges): Strengthen param "insn" from rtx
4520 to rtx_insn *.
4521 * cfgrtl.c (delete_insn_and_edges): Likewise.
4522
4523 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4524
4525 * rtl.h (reorder_insns): Strengthen params "from", "to", "after"
4526 from rtx to rtx_insn *.
4527
4528 * emit-rtl.c (reorder_insns): Likewise, also for local "insn".
4529
4530 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4531
4532 * function.c (thread_prologue_and_epilogue_insns): Likewise for
4533 locals "returnjump", "epilogue_end", "insn", "next".
4534
4535 * shrink-wrap.h (get_unconverted_simple_return): Strengthen param
4536 "returnjump" from rtx * to rtx_insn **.
4537 * shrink-wrap.c (get_unconverted_simple_return): Likewise.
4538
4539 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4540
4541 * basic-block.h (struct edge_def). Strengthen "r" within
4542 union edge_def_insns from rtx to rtx_insn *.
4543
4544 * cfgexpand.c (pass_expand::execute): Remove now-redundant cast
4545 from rtx to rtx_insn *. Strengthen local "insns" from rtx to
4546 rtx_insn *.
4547 * cfgrtl.c (commit_one_edge_insertion): Remove now-redundant cast
4548 from rtx to rtx_insn *.
4549 * cprop.c (find_bypass_set): Strengthen local "insn" from rtx to
4550 rtx_insn *.
4551 * postreload-gcse.c (reg_killed_on_edge): Likewise.
4552 (reg_used_on_edge): Likewise.
4553 * tree-cfg.c (gt_ggc_mx): New overload for rtx_insn *&.
4554 (gt_pch_nx): New overload for rtx_insn *&.
4555 * tree-outof-ssa.c (expand_phi_nodes): Strengthen local "insns"
4556 from rtx to rtx_insn *.
4557
4558 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4559
4560 * basic-block.h (struct rtl_bb_info): Strengthen field "footer_"
4561 from rtx to rtx_insn *.
4562 (BB_FOOTER): Replace function with access macro.
4563 (SET_BB_FOOTER): Delete.
4564
4565 * cfgcleanup.c (try_optimize_cfg): Replace uses of SET_BB_FOOTER
4566 with BB_FOOTER.
4567 * cfgrtl.c (try_redirect_by_replacing_jump): Likewise.
4568 (emit_barrier_after_bb): Likewise.
4569 (record_effective_endpoints): Likewise.
4570 (relink_block_chain): Likewise.
4571 (fixup_fallthru_exit_predecessor): Likewise.
4572 (cfg_layout_duplicate_bb): Likewise.
4573 (cfg_layout_split_block): Likewise.
4574 (cfg_layout_delete_block): Likewise.
4575 (cfg_layout_merge_blocks): Likewise.
4576 (BB_FOOTER): Delete function.
4577 (SET_BB_FOOTER): Delete function.
4578 * combine.c (update_cfg_for_uncondjump): Replace uses of
4579 SET_BB_FOOTER with BB_FOOTER.
4580
4581 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4582
4583 * except.h (struct eh_landing_pad_d): Strengthen field
4584 "landing_pad" from rtx to rtx_code_label *.
4585
4586 * except.c (sjlj_emit_dispatch_table): Likewise for param
4587 "dispatch_label"
4588 (sjlj_build_landing_pads): Likewise for local "dispatch_label".
4589
4590 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4591
4592 * config/xtensa/xtensa-protos.h (xtensa_emit_loop_end): Strengthen
4593 first param from rtx to rtx_insn *.
4594 * config/xtensa/xtensa.c (struct machine_function): Likewise for
4595 field "set_frame_ptr_insn".
4596 (xtensa_expand_compare_and_swap): Strengthen locals "csloop" and
4597 "csend" from rtx to rtx_code_label *.
4598 (xtensa_expand_atomic): Likewise for local "csloop".
4599 (xtensa_emit_loop_end): Strengthen param "insn" from rtx to
4600 rtx_insn *.
4601 (xtensa_call_tls_desc): Likewise for return type and locals
4602 "call_insn", "insns".
4603 (xtensa_legitimize_tls_address): Likewise for local "insns".
4604 (xtensa_expand_prologue): Likewise for locals "insn", "first".
4605
4606 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4607
4608 * config/v850/v850-protos.h (v850_adjust_insn_length): Strengthen
4609 first param from rtx to rtx_insn *.
4610 * config/v850/v850.c (v850_adjust_insn_length): Likewise for param
4611 "insn".
4612
4613 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4614
4615 * config/tilepro/tilepro-protos.h (tilepro_output_cbranch_with_opcode):
4616 Strengthen param 1 from rtx to rtx_insn *.
4617 (tilepro_output_cbranch): Likewise.
4618 (tilepro_adjust_insn_length): Likewise.
4619 (tilepro_final_prescan_insn): Likewise for sole param.
4620
4621 * config/tilepro/tilepro.c (tilepro_legitimize_tls_address):
4622 Likewise for local "last".
4623 (cbranch_predicted_p): Likewise for param "insn".
4624 (tilepro_output_simple_cbranch_with_opcode): Likewise.
4625 (tilepro_output_cbranch_with_opcode): Likewise.
4626 (tilepro_output_cbranch): Likewise.
4627 (frame_emit_load): Likewise for return type and locals "seq",
4628 "insn".
4629 (emit_sp_adjust): Likewise for return type and local "insn".
4630 (tilepro_expand_epilogue): Likewise for locals "last_insn",
4631 "insn".
4632 (tilepro_adjust_insn_length): Likewise for param "insn".
4633 (next_insn_to_bundle): Likewise for return type and params
4634 "r", "end".
4635 (tilepro_gen_bundles): Likewise for locals "insn", "next", "end".
4636 (replace_pc_relative_symbol_ref): Likewise for param "insn" and
4637 local "new_insns".
4638 (match_addli_pcrel): Likewise for param "insn".
4639 (replace_addli_pcrel): Likewise.
4640 (match_auli_pcrel): Likewise.
4641 (replace_auli_pcrel): Likewise.
4642 (tilepro_fixup_pcrel_references): Likewise for locals "insn",
4643 "next_insn".
4644 (reorder_var_tracking_notes): Likewise for locals "insn", "next",
4645 "queue", "next_queue", "prev".
4646 (tilepro_asm_output_mi_thunk): Likewise for local "insn".
4647 (tilepro_final_prescan_insn): Likewise for param "insn".
4648
4649 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4650
4651 * config/tilegx/tilegx-protos.h (tilegx_output_cbranch_with_opcode):
4652 Strengthen param 1 from rtx to rtx_insn *.
4653 (tilegx_output_cbranch): Likewise.
4654 (tilegx_adjust_insn_length): Likewise.
4655 (tilegx_final_prescan_insn): Likewise for sole param.
4656
4657 * config/tilegx/tilegx.c (tilegx_legitimize_tls_address): Likewise
4658 or local "last".
4659 (cbranch_predicted_p): Likewise for param "insn".
4660 (tilegx_output_simple_cbranch_with_opcode): Likewise.
4661 (tilegx_output_cbranch_with_opcode): Likewise.
4662 (tilegx_output_cbranch): Likewise.
4663 (frame_emit_load): Likewise for return type.
4664 (set_frame_related_p): Likewise for locals "seq", "insn".
4665 (emit_sp_adjust): Likewise for return type, and for local "insn".
4666 Introduce local "pat" for use in place of "insn" where the latter
4667 isn't an instruction.
4668 (tilegx_expand_epilogue): Strengthen locals "last_insn", "insn"
4669 from rtx to rtx_insn *.
4670 (tilegx_adjust_insn_length): Likewise for param "insn".
4671 (next_insn_to_bundle): Likewise for return type and params "r" and
4672 "end".
4673 (tilegx_gen_bundles): Likewise for locals "insn", "next", "prev",
4674 "end".
4675 (replace_insns): Likewise for params "old_insn", "new_insns".
4676 (replace_mov_pcrel_step1): Likewise for param "insn" and local
4677 "new_insns".
4678 (replace_mov_pcrel_step2): Likewise.
4679 (replace_mov_pcrel_step3): Likewise.
4680 (tilegx_fixup_pcrel_references): Likewise for locals "insn",
4681 "next_insn".
4682 (reorder_var_tracking_notes): Likewise for locals "insn", "next",
4683 "queue", "next_queue", "prev".
4684 (tilegx_output_mi_thunk): Likewise for local "insn".
4685 (tilegx_final_prescan_insn): Likewise for param "insn".
4686
4687 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4688
4689 * config/spu/spu.c (frame_emit_store): Strengthen return type from
4690 rtx to rtx_insn *.
4691 (frame_emit_load): Likewise.
4692 (frame_emit_add_imm): Likewise, also for local "insn".
4693 (spu_expand_prologue): Likewise for local "insn".
4694 (struct spu_bb_info): Likewise for field "prop_jump".
4695 (emit_nop_for_insn): Likewise for param "insn" and local
4696 "new_insn".
4697 (pad_bb): Likewise for locals "insn", "next_insn", "prev_insn",
4698 "hbr_insn".
4699 (spu_emit_branch_hint): Likewise for params "before", "branch" and
4700 locals "hint", "insn".
4701 (get_branch_target): Likewise for param "branch".
4702 (insn_clobbers_hbr): Likewise for param "insn".
4703 (insert_hbrp_for_ilb_runout): Likewise for param "first" and
4704 locals "insn", "before_4", "before_16".
4705 (insert_hbrp): Likewise for local "insn".
4706 (spu_machine_dependent_reorg): Likewise for locals "branch",
4707 "insn", "next", "bbend".
4708 (uses_ls_unit): Likewise for param "insn".
4709 (get_pipe): Likewise.
4710 (spu_sched_variable_issue): Rename param "insn" to "uncast_insn",
4711 introducing a checked cast.
4712 (spu_sched_adjust_cost): Likewise for params "insn" and
4713 "dep_insn".
4714 (ea_load_store_inline): Strengthen local "insn" from rtx to rtx_insn *.
4715 (spu_sms_res_mii): Likewise.
4716
4717 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4718
4719 * config/sparc/sparc-protos.h (output_ubranch): Strengthen param 2
4720 from rtx to rtx_insn *.
4721 (output_cbranch): Likewise for param 6.
4722 (output_return): Likewise for param 1.
4723 (output_sibcall): Likewise.
4724 (output_v8plus_shift): Likewise.
4725 (output_v8plus_mult): Likewise.
4726 (output_v9branch): Likewise for param 7.
4727 (output_cbcond): Likewise for param 3.
4728
4729 * config/sparc/sparc.c (sparc_legitimize_tls_address): Likewise
4730 for local "insn".
4731 (sparc_legitimize_pic_address): Likewise.
4732 (sparc_emit_call_insn): Likewise.
4733 (emit_save_or_restore_regs): Likewise.
4734 (emit_window_save): Likewise for return type and local "insn".
4735 (sparc_expand_prologue): Likewise for local "insn".
4736 (sparc_flat_expand_prologue): Likewise.
4737 (output_return): Likewise for param "insn".
4738 (output_sibcall): Likewise for param "insn" and local "delay".
4739 (output_ubranch): Likewise for param "insn".
4740 (output_cbranch): Likewise.
4741 (output_cbcond): Likewise.
4742 (output_v9branch): Likewise.
4743 (output_v8plus_shift): Likewise.
4744 (sparc_output_mi_thunk): Likewise for local "insn".
4745 (get_some_local_dynamic_name): Likewise.
4746 (output_v8plus_mult): Likewise for param "insn".
4747
4748 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4749
4750 * config/sh/sh-protos.h (output_ieee_ccmpeq): Strengthen param 1
4751 from rtx to rtx_insn *.
4752 (output_branchy_insn): Likewise for param 3.
4753 (output_far_jump): Likewise for param 1.
4754 (final_prescan_insn): Likewise.
4755 (sh_insn_length_adjustment): Likewise for sole param.
4756
4757 * config/sh/sh.c (expand_cbranchsi4): Likewise for local "jump".
4758 (expand_cbranchdi4): Strengthen local "skip_label" from rtx to
4759 rtx_code_label *.
4760 (sh_emit_compare_and_set): Likewise for local "lab".
4761 (output_far_jump): Strengthen param "insn" and local "prev" from
4762 rtx to rtx_insn *.
4763 (output_branchy_insn): Likewise for param "insn" and local
4764 "next_insn".
4765 (output_ieee_ccmpeq): Likewise for param "insn".
4766 (struct label_ref_list_d): Strengthen field "label" from rtx to
4767 rtx_code_label *.
4768 (pool_node): Likewise.
4769 (pool_window_label): Likewise for this global.
4770 (add_constant): Likewise for return type and locals "lab", "new_rtx".
4771 (dump_table): Strengthen params "start", "barrier" and local
4772 "scan" from rtx to rtx_insn *.
4773 (broken_move): Likewise for param "insn".
4774 (untangle_mova): Likewise for params "first_mova" and "new_mova".
4775 Strengthen param "first_mova" from rtx * to rtx_insn **.
4776 (mova_p): Likewise for param "insn".
4777 (fixup_mova): Likewise for param "mova".
4778 (find_barrier): Likewise for return type, params "mova" and
4779 "from", and locals "barrier_before_mova", "found_barrier",
4780 "good_barrier", "orig", "last_symoff", "next". Strengthen local
4781 "label" from rtx to rtx_code_label *.
4782 (sh_loop_align): Strengthen locals "first", "insn", "mova" from
4783 rtx to rtx_insn *.
4784 (sh_reorg): Likewise for locals "link", "scan", "barrier".
4785 (split_branches): Likewise for param "first" and local "insn".
4786 (final_prescan_insn): Likewise for param "insn".
4787 (sequence_insn_p): Likewise for locals "prev", "next".
4788 (sh_insn_length_adjustment): Likewise for param "insn".
4789 (sh_can_redirect_branch): Likewise for local "insn".
4790 (find_r0_life_regions): Likewise for locals "end", "insn".
4791 (sh_output_mi_thunk): Likewise for local "insns".
4792
4793 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4794
4795 * config/score/score.c (score_output_mi_thunk): Strengthen local
4796 "insn" from rtx to rtx_insn *.
4797 (score_prologue): Likewise.
4798
4799 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4800
4801 * config/s390/s390-protos.h (s390_match_ccmode): Strengthen param
4802 1 from rtx to rtx_insn *.
4803 (s390_emit_jump): Likewise for return type.
4804 (s390_emit_call): Likewise.
4805 (s390_load_got): Likewise.
4806
4807 * config/s390/s390.c (last_scheduled_insn): Likewise for this
4808 variable.
4809 (s390_match_ccmode): Likewise for param "insn".
4810 (s390_emit_jump): Likewise for return type.
4811 (s390_split_branches): Likewise for local "label".
4812 (struct constant): Strengthen field "label" from rtx to
4813 rtx_code_label *.
4814 (struct constant_pool): Likewise for field "label". Strengthen
4815 fields "first_insn", "pool_insn", "emit_pool_after" from rtx to
4816 rtx_insn *.
4817 (s390_alloc_pool): Replace NULL_RTX with NULL when dealing with
4818 insns.
4819 (s390_start_pool): Strengthen param "insn" from rtx to rtx_insn *.
4820 (s390_end_pool): Likewise.
4821 (s390_dump_pool): Likewise for local "insn".
4822 (s390_mainpool_start): Likewise.
4823 (s390_chunkify_start): Likewise.
4824 (s390_chunkify_start): Replace NULL_RTX with NULL when dealing
4825 with insns. Strengthen locals "label", "jump", "barrier", "next",
4826 "prev", "vec_insn", "insn" from rtx to rtx_insn *.
4827 (s390_chunkify_finish): Strengthen local "insn" from rtx to
4828 rtx_insn *.
4829 (s390_chunkify_cancel): Likewise for locals "insn", "barrier",
4830 "jump", "label", "next_insn".
4831 (s390_regs_ever_clobbered): Likewise for local "cur_insn".
4832 (s390_optimize_nonescaping_tx): Likewise for locals "insn",
4833 "tbegin_insn".
4834 (s390_load_got): Likewise for return type and local "insns".
4835 (s390_save_gprs_to_fprs): Likewise for local "insn".
4836 (s390_restore_gprs_from_fprs): Likewise.
4837 (pass_s390_early_mach::execute): Likewise.
4838 (s390_emit_prologue): Likewise for local "insns".
4839 (s390_expand_tbegin): Strengthen local "leave_label" from rtx to
4840 rtx_code_label *.
4841 (s390_emit_call): Strengthen return type and local "insn" from
4842 rtx to rtx_insn *.
4843 (s390_emit_tpf_eh_return): Likewise for local "insn".
4844 (s390_optimize_prologue): Likewise for locals "insn", "new_insn",
4845 "next_insn", introducing locals "s_pat", "rpat" to allow this.
4846 (s390_fix_long_loop_prediction): Likewise for param "insn" and
4847 local "cur_insn".
4848 (s390_non_addr_reg_read_p): Likewise for param "insn".
4849 (find_cond_jump): Likewise for return type and param "insn".
4850 (s390_swap_cmp): Likewise for param "insn".
4851 (s390_z10_optimize_cmp): Likewise for param "insn" and locals
4852 "prev_insn", "next_insn".
4853 (s390_reorg): Likewise for locals "insn", "target".
4854 (s390_z10_prevent_earlyload_conflicts): Likewise for local "insn".
4855 (s390_sched_variable_issue): For now, rename param "insn" to
4856 "uncast_insn", introducing a checked cast.
4857 (s390_sched_init): Replace NULL_RTX with NULL when dealing with
4858 insn.
4859 (s390_loop_unroll_adjust): Strengthen local "insn" from rtx to
4860 rtx_insn *. Use for_each_rtx_in_insn rather than for_each_rtx.
4861
4862 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4863
4864 * config/rx/rx-protos.h (rx_adjust_insn_length): Strengthen first
4865 param from rtx to rtx_insn *.
4866 * config/rx/rx.c (rx_adjust_insn_length): Likewise for param "insn".
4867
4868 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4869
4870 * config/rs6000/rs6000-protos.h (output_cbranch): Strengthen param
4871 4 from rtx to rtx_insn *.
4872 (rs6000_final_prescan_insn): Likewise for first param.
4873 * config/rs6000/rs6000.c (rs6000_emit_set_const): Likewise for
4874 local "insn".
4875 (rs6000_get_some_local_dynamic_name): Likewise.
4876 (output_cbranch): Likewise for param "insn".
4877 (spe_func_has_64bit_regs_p): Likewise for locals "insns", "insn".
4878 (rs6000_function_ok_for_sibcall): Likewise for locals "top", "insn".
4879 (rs6000_emit_allocate_stack): Likewise for local "insn".
4880 (load_cr_save): Likewise.
4881 (restore_saved_cr): Likewise.
4882 (restore_saved_lr): Likewise.
4883 (emit_cfa_restores): Likewise.
4884 (rs6000_output_function_epilogue): Likewise for locals "insn" and
4885 "deleted_debug_label".
4886 (rs6000_output_mi_thunk): Likewise for local "insn".
4887 (rs6000_final_prescan_insn): Likewise for param "insn".
4888
4889 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4890
4891 * config/picochip/picochip-protos.h (picochip_final_prescan_insn):
4892 Strengthen param "insn" from rtx to rtx_insn *.
4893 * config/picochip/picochip.c (picochip_current_prescan_insn):
4894 Likewise for this variable.
4895 (picochip_final_prescan_insn): Likewise for param "insn".
4896
4897 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4898
4899 * config/pa/pa-protos.h (pa_output_call): Strengthen first param
4900 from rtx to rtx_insn *.
4901 (pa_output_indirect_call): Likewise.
4902 (pa_adjust_insn_length): Likewise.
4903 (pa_attr_length_millicode_call): Likewise.
4904 (pa_attr_length_call): Likewise.
4905 (pa_attr_length_indirect_call): Likewise.
4906
4907 * config/pa/pa.c (pa_adjust_insn_length): Likewise for param
4908 "insn".
4909 (pa_attr_length_millicode_call): Likewise.
4910 (pa_attr_length_call): Likewise.
4911 (pa_output_call): Likewise.
4912 (pa_attr_length_indirect_call): Likewise.
4913 (pa_output_indirect_call): Likewise.
4914
4915 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4916
4917 * config/nds32/nds32-protos.h (nds32_adjust_insn_length):
4918 Strengthen first param from rtx to rtx_insn *.
4919 * config/nds32/nds32.c (nds32_adjust_insn_length): Likewise for
4920 param "insn".
4921
4922 2014-08-25 David Malcolm <dmalcolm@redhat.com>
4923
4924 * config/mips/mips-protos.h (mips_emit_move): Strengthen return
4925 type from rtx to rtx_insn *.
4926 (mips_expand_call): Likewise.
4927 (mips_adjust_insn_length): Likewise for first param.
4928 (mips_output_conditional_branch): Likewise.
4929 (mips_output_order_conditional_branch): Likewise.
4930 (mips_final_prescan_insn): Likewise.
4931
4932 * config/mips/mips.c (SEQ_BEGIN): For now, add checked cast to
4933 rtx_insn * for the SEQUENCE case.
4934 (SEQ_END): Likewise.
4935 (mips_emit_move): Strengthen return type from rtx to rtx_insn *.
4936 (mips_emit_call_insn): Likewise, also for local "insn".
4937 (mips16_gp_pseudo_reg): Likewise for local "scan".
4938 (mips16_build_call_stub): Likewise for return type and for local
4939 "insn". Introduce a new local "pattern" so that "insn" can indeed
4940 be an insn.
4941 (mips_expand_call): Strengthen return type and local "insn" from
4942 rtx to rtx_insn *.
4943 (mips_block_move_loop): Strengthen local "label" from rtx to
4944 rtx_code_label *.
4945 (mips_expand_synci_loop): Likewise for locals "label",
4946 "end_label".
4947 (mips_set_frame_expr): Strengthen local "insn" from rtx to
4948 rtx_insn *.
4949 (mips16e_collect_argument_saves): Likewise for locals "insn",
4950 "next".
4951 (mips_find_gp_ref): Likewise for param of callback for "pred"
4952 param, and for local "insn".
4953 (mips_insn_has_inflexible_gp_ref_p): Likewise for param "insn".
4954 (mips_insn_has_flexible_gp_ref_p): Likewise.
4955 (mips_epilogue_emit_cfa_restores): Likewise for return type and
4956 local "insn".
4957 (mips_epilogue_set_cfa): Likewise for local "insn".
4958 (mips_expand_epilogue): Likewise.
4959 (mips_adjust_insn_length): Likewise for param "insn".
4960 (mips_output_conditional_branch): Likewise.
4961 (mips_output_order_conditional_branch): Likewise.
4962 (struct mips_ls2): Likewise for fields "alu1_turn_enabled_insn",
4963 "alu2_turn_enabled_insn", "falu1_turn_enabled_insn",
4964 "falu2_turn_enabled_insn".
4965 (mips_builtin_branch_and_move): Strengthen locals "true_label",
4966 "done_label" from rtx to rtx_code_label *.
4967 (struct mips16_constant): Likewise for field "label".
4968 (mips16_add_constant): Likewise for return type.
4969 (mips16_emit_constants_1): Strengthen return type and param "insn"
4970 from rtx to rtx_insn *.
4971 (mips16_emit_constants): Likewise for param "insn".
4972 (mips16_insn_length): Likewise.
4973 (mips16_rewrite_pool_constant): Strengthen local "label" from rtx
4974 to rtx_code_label *.
4975 (struct mips16_rewrite_pool_refs_info): Strengthen field "insn"
4976 from rtx to rtx_insn *.
4977 (mips16_lay_out_constants): Likewise for locals "insn", "barrier",
4978 "jump". Strengthen local "label" from rtx to rtx_code_label *.
4979 (r10k_simplify_address): Strengthen param "insn" and local
4980 "def_insn" from rtx to rtx_insn *.
4981 (r10k_safe_address_p): Strengthen param "insn" from rtx to
4982 rtx_insn *.
4983 (r10k_needs_protection_p_1): Update target type of cast of data
4984 from to rtx to rtx_insn *.
4985 (r10k_needs_protection_p_store): Strengthen local "insn_ptr" from
4986 rtx * to rtx_insn **.
4987 (r10k_needs_protection_p): Strengthen param "insn" from rtx to
4988 rtx_insn *.
4989 (r10k_insert_cache_barriers): Likewise for locals "insn", "end".
4990 (mips_call_expr_from_insn): Likewise for param "insn".
4991 (mips_pic_call_symbol_from_set): Likewise for local "def_insn".
4992 (mips_find_pic_call_symbol): Likewise for param "insn".
4993 (mips_annotate_pic_calls): Likewise for local "insn".
4994 (mips_sim_insn): Likewise for this variable.
4995 (struct mips_sim): Likewise for field "insn" within elements of
4996 last_set array.
4997 (mips_sim_wait_reg): Likewise for param "insn".
4998 (mips_sim_wait_regs): Likewise.
4999 (mips_sim_wait_units): Likewise.
5000 (mips_sim_wait_insn): Likewise.
5001 (mips_sim_issue_insn): Likewise.
5002 (mips_sim_finish_insn): Likewise.
5003 (mips_seq_time): Likewise for param "seq" and local "insn".
5004 (vr4130_avoid_branch_rt_conflict): Likewise for param "insn" and
5005 locals "first", "second".
5006 (vr4130_align_insns): Likewise for locals "insn", "subinsn",
5007 "last", "last2", "next".
5008 (mips_avoid_hazard): Likewise for params "after", "insn".
5009 (mips_reorg_process_insns): Likewise for locals "insn",
5010 "last_insn", "subinsn", "next_insn".
5011 (mips_has_long_branch_p): Likewise for locals "insn", "subinsn".
5012 (mips16_split_long_branches): Likewise for locals "insn" "jump",
5013 "jump_sequence".
5014 (mips_output_mi_thunk): Likewise for local "insn".
5015 (mips_final_prescan_insn): Likewise for param "insn".
5016
5017 2014-08-25 David Malcolm <dmalcolm@redhat.com>
5018
5019 * config/microblaze/microblaze.c (microblaze_call_tls_get_addr):
5020 Strengthen return type and local "insns" from rtx to rtx_insn *.
5021 (microblaze_legitimize_tls_address): Likewise for local "insns".
5022 (microblaze_block_move_loop): Strengthen local "label" from rtx
5023 to rtx_code_label *.
5024 (microblaze_expand_prologue): Strengthen two locals named "insn"
5025 from rtx to rtx_insn *.
5026 (microblaze_asm_output_mi_thunk): Likewise for local "insn".
5027 (microblaze_expand_divide): Likewise for locals "jump", "cjump",
5028 "insn". Strengthen locals "div_label", "div_end_label" from rtx
5029 to rtx_code_label *.
5030
5031 2014-08-25 David Malcolm <dmalcolm@redhat.com>
5032
5033 * config/mep/mep-protos.h (mep_mulr_source): Strengthen first
5034 param from rtx to rtx_insn *.
5035 (mep_reuse_lo): Likewise for third param.
5036 (mep_use_post_modify_p): Likewise for first param.
5037 (mep_core_address_length): Likewise.
5038 (mep_cop_address_length): Likewise.
5039 (mep_final_prescan_insn): Likewise.
5040 (mep_store_data_bypass_p): Likewise for both params.
5041 (mep_mul_hilo_bypass_p): Likewise.
5042 (mep_ipipe_ldc_p): Likewise for param.
5043
5044 * config/mep/mep.c (mep_mulr_source): Likewise for param "insn".
5045 (mep_rewrite_mult): Likewise.
5046 (mep_rewrite_mulsi3): Likewise.
5047 (mep_rewrite_maddsi3): Likewise.
5048 (mep_reuse_lo_p_1): Likewise.
5049 (mep_reuse_lo_p): Likewise.
5050 (mep_frame_expr): Likewise.
5051 (mep_make_parallel): Likewise for both params.
5052 (mep_use_post_modify_p_1): Likewise for param "set_insn" and
5053 local "insn".
5054 (mep_use_post_modify_p): Likewise for param "insn".
5055 (mep_core_address_length): Likewise.
5056 (mep_cop_address_length): Likewise.
5057 (mep_reg_set_in_function): Likewise for local "insn".
5058 (mep_asm_without_operands_p): Likewise.
5059 (F): Likewise for return type and param "x".
5060 (add_constant): Likewise for local "insn".
5061 (maybe_dead_move): Likewise for return type and local "insn".
5062 (mep_expand_prologue): Likewise for local "insn".
5063 (mep_final_prescan_insn): Likewise for param "insn".
5064 (mep_reorg_regmove): Likewise for param "insns" and locals "insn",
5065 "next", "follow", "x".
5066 (mep_insert_repeat_label_last): Likewise for return type, param
5067 "last_insn", and locals "next", "prev". Strengthen param "label"
5068 from rtx to rtx_code_label *.
5069 (struct mep_doloop_begin): Strengthen field "insn" from rtx to
5070 rtx_insn *.
5071 (struct mep_doloop_end): Likewise for fields "insn" and
5072 "fallthrough".
5073 (mep_reorg_repeat): Likewise for param "insns" and local "insn".
5074 Strengthen local "repeat_label" from rtx to rtx_code_label *.
5075 (mep_invertable_branch_p): Strengthen param "insn" from rtx to
5076 rtx_insn *.
5077 (mep_invert_branch): Likewise for params "insn" and "after".
5078 (mep_reorg_erepeat): Likewise for param "insns" and locals
5079 "insn", "prev", "new_last", "barrier", "user". Strengthen local
5080 "l" from rtx to rtx_code_label *.
5081 (mep_jmp_return_reorg): Strengthen param "insns" and local "insn"
5082 from rtx to rtx_insn *.
5083 (mep_reorg_addcombine): Likewise for param "insns" and locals
5084 "i", "n".
5085 (add_sp_insn_p): Likewise for param "insn".
5086 (mep_reorg_noframe): Likewise for param "insns" and locals
5087 "start_frame_insn", "end_frame_insn", "next".
5088 (mep_reorg): Likewise for local "insns".
5089 (mep_store_data_bypass_1): Likewise for param "prev". Add checked
5090 cast.
5091 (mep_store_data_bypass_p): Likewise for params "prev", "insn".
5092 (mep_mul_hilo_bypass_p): Likewise.
5093 (mep_ipipe_ldc_p): Likewise for param "insn".
5094 (mep_make_bundle): Likewise for return type, param "cop" and local
5095 "insn", splitting out the latter into a new local "seq" for when it
5096 is a SEQUENCE rather than an insn.
5097 (core_insn_p): Likewise for param "insn".
5098 (mep_bundle_insns): Likewise for param "insns" and locals "insn",
5099 "last", "first", "note", "prev", "core_insn".
5100
5101 2014-08-25 David Malcolm <dmalcolm@redhat.com>
5102
5103 * config/m68k/m68k-protos.h (output_btst): Strengthen param 4 from
5104 rtx to rtx_insn *.
5105 (strict_low_part_peephole_ok): Likewise for param 2 "first_insn".
5106 (m68k_final_prescan_insn): Likewise for first param.
5107
5108 * config/m68k/m68k.c (m68k_emit_movem): Likewise for return type.
5109 (m68k_set_frame_related): Likewise for param "insn".
5110 (output_btst): Likewise for param "insn".
5111 (m68k_final_prescan_insn): Likewise.
5112 (m68k_move_to_reg): Likewise for local "insn".
5113 (m68k_call_tls_get_addr): Likewise for local "insns".
5114 (m68k_call_m68k_read_tp): Likewise.
5115 (strict_low_part_peephole_ok): Likewise for param "first_insn".
5116 (m68k_output_mi_thunk): Likewise for local "insn".
5117
5118 2014-08-25 David Malcolm <dmalcolm@redhat.com>
5119
5120 * config/iq2000/iq2000-protos.h (final_prescan_insn): Strengthen
5121 first param from rtx to rtx_insn *.
5122 (iq2000_adjust_insn_length): Likewise.
5123 (iq2000_output_conditional_branch): Likewise.
5124 * config/iq2000/iq2000.c (final_prescan_insn): Likewise for param
5125 "insn" and local "nop_insn".
5126 (iq2000_annotate_frame_insn): Likewise for param "insn".
5127 (iq2000_expand_prologue): Likewise for both locals "insn".
5128 (iq2000_adjust_insn_length): Likewise for param "insn".
5129 (iq2000_output_conditional_branch): Likewise.
5130
5131 2014-08-25 David Malcolm <dmalcolm@redhat.com>
5132
5133 * config/ia64/ia64.c (ia64_expand_tls_address): Strengthen local
5134 "insns" from rtx to rtx_insn *.
5135 (ia64_emit_cond_move): Likewise for locals "insn", "first".
5136 (struct spill_fill_data): Likewise for field "init_after" and for
5137 elements of array field "prev_insn".
5138 (spill_restore_mem): Likewise for locals "insn", "first".
5139 (do_spill): Likewise for local "insn".
5140 (do_restore): Likewise.
5141 (ia64_expand_prologue): Likewise.
5142 (ia64_expand_epilogue): Likewise.
5143 (emit_insn_group_barriers): Likewise for locals "insn",
5144 "last_label".
5145 (emit_all_insn_group_barriers): Likewise for locals "insn",
5146 "last".
5147 (dfa_stop_insn): Likewise for this global.
5148 (dfa_pre_cycle_insn): Likewise.
5149 (ia64_nop): Likewise.
5150 (final_emit_insn_group_barriers): Likewise for locals "insn",
5151 "last".
5152 (emit_predicate_relation_info): Likewise for locals "head", "n",
5153 "insn", "b", "a".
5154 (ia64_reorg): Likewise for local "insn".
5155 (ia64_output_mi_thunk): Likewise.
5156 (expand_vec_perm_interleave_2): Likewise for local "seq".
5157
5158 2014-08-25 David Malcolm <dmalcolm@redhat.com>
5159
5160 * config/i386/i386-protos.h (ix86_avoid_lea_for_add): Strengthen
5161 param 1 "insn" from rtx to rtx_insn *.
5162 (ix86_use_lea_for_mov): Likewise.
5163 (ix86_avoid_lea_for_addr): Likewise.
5164 (ix86_split_lea_for_addr): Likewise.
5165 (ix86_lea_for_add_ok): Likewise.
5166 (ix86_output_call_insn): Likewise.
5167
5168 * config/i386/i386.c (ix86_va_start): Likewise for local "seq".
5169 (ix86_get_drap_rtx): Likewise for locals "seq", "insn".
5170 (ix86_output_function_epilogue): Likewise for locals "insn",
5171 "deleted_debug_label".
5172 (legitimize_tls_address): Likewise for local "insn".
5173 (get_some_local_dynamic_name): Likewise.
5174 (increase_distance): Likewise for params "prev", "next".
5175 (distance_non_agu_define_in_bb): Likewise for params "insn",
5176 "start" and locals "prev", "next".
5177 (distance_non_agu_define): Likewise for param "insn".
5178 (distance_agu_use_in_bb): Likewise for params "insn", "start" and
5179 locals "next", "prev".
5180 (distance_agu_use): Likewise for param "insn".
5181 (ix86_lea_outperforms): Likewise.
5182 (ix86_ok_to_clobber_flags): Likewise.
5183 (ix86_avoid_lea_for_add): Likewise.
5184 (ix86_use_lea_for_mov): Likewise.
5185 (ix86_avoid_lea_for_addr): Likewise.
5186 (find_nearest_reg_def): Likewise, also for locals "prev", "start".
5187 (ix86_split_lea_for_addr): Likewise for param "insn".
5188 (ix86_lea_for_add_ok): Likewise for param "insn".
5189 (ix86_expand_carry_flag_compare): Likewise for local
5190 "compare_seq".
5191 (ix86_expand_int_movcc): Likewise.
5192 (ix86_output_call_insn): Likewise for param "insn".
5193 (ix86_output_call_insn): Likewise for local "i".
5194 (x86_output_mi_thunk): Introduce local "insn", using it in place
5195 of "tmp" when dealing with insns.
5196 (ix86_avoid_jump_mispredicts): Likewise for locals "insn",
5197 "start".
5198 (ix86_pad_returns): Likewise for locals "ret", "prev".
5199 (ix86_count_insn_bb): Likewise for local "insn".
5200 (ix86_pad_short_function): Likewise for locals "ret", "insn".
5201 (ix86_seh_fixup_eh_fallthru): Likewise for locals "insn", "next".
5202 (ix86_vector_duplicate_value): Likewise for local "insn", "seq".
5203 (expand_vec_perm_interleave2): Likewise for local "seq".
5204 (expand_vec_perm_vperm2f128_vblend): Likewise.
5205 (ix86_loop_unroll_adjust): Likewise for local "insn". Convert
5206 call to for_each_rtx with for_each_rtx_in_insn.
5207
5208 2014-08-25 David Malcolm <dmalcolm@redhat.com>
5209
5210 * config/i386/i386.c (setup_incoming_varargs_64): Strengthen local
5211 "label" from rtx to rtx_code_label *.
5212 (ix86_expand_prologue): Likewise.
5213 (ix86_expand_split_stack_prologue): Likewise for locals "label",
5214 "varargs_label".
5215 (ix86_split_idivmod): Likewise for locals "end_label" and
5216 "qimode_label".
5217 (ix86_expand_branch): Likewise for local "label2".
5218 (ix86_expand_aligntest): Likewise for return type and local "label".
5219 (expand_set_or_movmem_via_loop): Likewise for locals "out_label" and
5220 "top_label".
5221 (expand_movmem_epilogue): Likewise for the various locals named
5222 "label".
5223 (expand_setmem_epilogue): Likewise.
5224 (expand_small_movmem_or_setmem): Likewise for local "label".
5225 (expand_set_or_movmem_prologue_epilogue_by_misaligned_moves):
5226 Strengthen param "done_label" from rtx * to rtx_code_label **.
5227 Strengthen locals "loop_label" and "label" from rtx to
5228 rtx_code_label *.
5229 (expand_set_or_movmem_prologue_epilogue_by_misaligned_moves):
5230 Likewise for locals "loop_label", "label".
5231 (ix86_expand_set_or_movmem): Likewise for locals "label",
5232 "jump_around_label", "hot_label".
5233 (ix86_expand_strlensi_unroll_1): Likewise for locals
5234 "align_2_label", align_3_label", "align_4_label", "end_0_label",
5235 "end_2_label".
5236 (x86_emit_floatuns): Likewise for locals "neglab", "donelab".
5237 (void ix86_emit_i387_log1p): Likewise for locals "label1",
5238 "label2", "jump_label".
5239 (ix86_expand_sse_compare_and_jump): Likewise for return type and
5240 local "label".
5241 (ix86_expand_lfloorceil): Likewise for local "label".
5242 (ix86_expand_rint): Likewise.
5243 (ix86_expand_floorceildf_32): Likewise.
5244 (ix86_expand_floorceil): Likewise.
5245 (ix86_expand_rounddf_32): Likewise.
5246 (ix86_expand_trunc): Likewise.
5247 (ix86_expand_truncdf_32): Likewise.
5248 (ix86_expand_round): Likewise.
5249
5250 2014-08-25 David Malcolm <dmalcolm@redhat.com>
5251
5252 * config/h8300/h8300-protos.h (final_prescan_insn): Strengthen
5253 first param from rtx to rtx_insn *.
5254 (h8300_insn_length_from_table): Likewise.
5255 * config/h8300/h8300.c (F): Likewise for return type and param
5256 "x".
5257 (Fpa): Add a checked cast to rtx_insn *.
5258 (h8300_emit_stack_adjustment): Strengthen local "x" from rtx to
5259 rtx_insn *.
5260 (final_prescan_insn): Likewise for param "insn".
5261 (h8300_binary_length): Likewise.
5262 (h8300_insn_length_from_table): Likewise.
5263
5264 2014-08-25 David Malcolm <dmalcolm@redhat.com>
5265
5266 * config/epiphany/epiphany-protos.h (epiphany_final_prescan_insn):
5267 Strengthen first param "insn" from rtx to rtx_insn *.
5268
5269 * config/epiphany/epiphany.c (epiphany_final_prescan_insn):
5270 Likewise.
5271 (frame_insn): Likewise for return type. Introduce local "insn"
5272 for use in place of local "x" for use as an rtx_insn *.
5273 (frame_move_insn): Strengthen return type from rtx to rtx_insn *.
5274 (epiphany_expand_prologue): Likewise for local "insn".
5275 * config/epiphany/mode-switch-use.c (insert_uses): Likewise.
5276 * config/epiphany/resolve-sw-modes.c
5277 (pass_resolve_sw_modes::execute): Likewise for locals "insn" and
5278 "seq".
5279
5280 2014-08-25 David Malcolm <dmalcolm@redhat.com>
5281
5282 * config/c6x/c6x-protos.h (c6x_get_unit_specifier): Strengthen
5283 param from rtx to rtx_insn *.
5284 (c6x_final_prescan_insn): Likewise for first param.
5285
5286 * config/c6x/c6x.c (c6x_current_insn): Likewise for this variable.
5287 (c6x_output_mi_thunk): Replace use of NULL_RTX with NULL.
5288 (c6x_expand_compare): Strengthen local "insns" from rtx to
5289 rtx_insn *.
5290 (c6x_get_unit_specifier): Likewise for param "insn".
5291 (c6x_print_unit_specifier_field): Likewise.
5292 (c6x_final_prescan_insn): Likewise.
5293 (emit_add_sp_const): Likewise for local "insn".
5294 (c6x_expand_prologue): Likewise.
5295
5296 2014-08-25 David Malcolm <dmalcolm@redhat.com>
5297
5298 * config/bfin/bfin-protos.h (asm_conditional_branch): Strengthen
5299 param 1 from rtx to rtx_insn *.
5300 * config/bfin/bfin.c (expand_prologue_reg_save): Likewise for
5301 the various locals named "insn".
5302 (expand_epilogue_reg_restore): Likewise.
5303 (frame_related_constant_load): Likewise.
5304 (add_to_reg): Likewise.
5305 (emit_link_insn): Likewise.
5306 (do_link): Likewise.
5307 (expand_interrupt_handler_prologue): Likewise.
5308 (branch_dest): Likewise for param "branch".
5309 (asm_conditional_branch): Likewise for param "insn".
5310 (gen_one_bundle): Likewise for elements of param "slot" and local
5311 "t".
5312 (bfin_gen_bundles): Likewise for locals "insn", "next" and
5313 elements of local "slot".
5314 (reorder_var_tracking_notes): Likewise for locals "insn", "next",
5315 "queue", "next_queue", "prev".
5316 (workaround_rts_anomaly): Likewise for locals "insn", "first_insn".
5317 (add_sched_insns_for_speculation): Likewise for local "insn".
5318
5319 2014-08-25 David Malcolm <dmalcolm@redhat.com>
5320
5321 * config/avr/avr-protos.h (output_movqi): Strengthen first param
5322 from rtx to rtx_insn *.
5323 (output_movhi): Likewise.
5324 (output_movsisf): Likewise.
5325 (avr_out_tstsi): Likewise.
5326 (avr_out_tsthi): Likewise.
5327 (avr_out_tstpsi): Likewise.
5328 (avr_out_compare): Likewise.
5329 (avr_out_compare64): Likewise.
5330 (avr_out_movpsi): Likewise.
5331 (ashlqi3_out): Likewise.
5332 (ashlhi3_out): Likewise.
5333 (ashlsi3_out): Likewise.
5334 (ashrqi3_out): Likewise.
5335 (ashrhi3_out): Likewise.
5336 (ashrsi3_out): Likewise.
5337 (lshrqi3_out): Likewise.
5338 (lshrhi3_out): Likewise.
5339 (lshrsi3_out): Likewise.
5340 (avr_out_ashlpsi3): Likewise.
5341 (avr_out_ashrpsi3): Likewise.
5342 (avr_out_lshrpsi3): Likewise.
5343 (avr_out_fract): Likewise.
5344 (avr_out_sbxx_branch): Likewise.
5345 (avr_out_round): Likewise.
5346 (avr_out_xload): Likewise.
5347 (avr_out_movmem): Likewise.
5348 (adjust_insn_length): Likewise.
5349 (avr_out_lpm): Likewise.
5350 (reg_unused_after): Likewise.
5351 (_reg_unused_after): Likewise.
5352 (avr_jump_mode): Likewise for second param.
5353 (jump_over_one_insn): Likewise for first param.
5354 (avr_final_prescan_insn): Likewise.
5355 (out_shift_with_cnt): Likewise for second param.
5356
5357 * config/avr/avr.c (get_sequence_length): Likewise for param
5358 "insns" and local "insn".
5359 (emit_push_byte): Likewise for local "insn".
5360 (emit_push_sfr): Likewise.
5361 (avr_prologue_setup_frame): Likewise for locals "insn",
5362 "fp_plus_insns", "sp_plus_insns".
5363 (avr_expand_epilogue): Likewise for local "fp_plus_insns",
5364 "sp_plus_insns".
5365 (avr_jump_mode): Likewise for param "insn".
5366 (avr_final_prescan_insn): Likewise.
5367 (avr_find_unused_d_reg): Likewise.
5368 (avr_out_lpm_no_lpmx): Likewise.
5369 (avr_out_lpm): Likewise.
5370 (avr_out_xload): Likewise.
5371 (output_movqi): Likewise.
5372 (output_movhi): Likewise.
5373 (out_movqi_r_mr): Likewise.
5374 (out_movhi_r_mr): Likewise.
5375 (out_movsi_r_mr): Likewise.
5376 (out_movsi_mr_r): Likewise.
5377 (output_movsisf): Likewise.
5378 (avr_out_load_psi): Likewise.
5379 (avr_out_store_psi): Likewise.
5380 (avr_out_movpsi): Likewise.
5381 (out_movqi_mr_r): Likewise.
5382 (avr_out_movhi_mr_r_xmega): Likewise.
5383 (out_movhi_mr_r): Likewise.
5384 (compare_condition): Likewise for param "insn" and local "next".
5385 (compare_sign_p): Likewise for param "insn".
5386 (compare_diff_p): Likewise.
5387 (compare_eq_p): Likewise.
5388 (avr_out_compare): Likewise.
5389 (avr_out_compare64): Likewise.
5390 (avr_out_tsthi): Likewise.
5391 (avr_out_tstpsi): Likewise.
5392 (avr_out_tstsi): Likewise.
5393 (out_shift_with_cnt): Likewise.
5394 (ashlqi3_out): Likewise.
5395 (ashlhi3_out): Likewise.
5396 (avr_out_ashlpsi3): Likewise.
5397 (ashlsi3_out): Likewise.
5398 (ashrqi3_out): Likewise.
5399 (ashrhi3_out): Likewise.
5400 (avr_out_ashrpsi3): Likewise.
5401 (ashrsi3_out): Likewise.
5402 (lshrqi3_out): Likewise.
5403 (lshrhi3_out): Likewise.
5404 (avr_out_lshrpsi3): Likewise.
5405 (lshrsi3_out): Likewise.
5406 (avr_out_fract): Likewise.
5407 (avr_out_round): Likewise.
5408 (avr_adjust_insn_length): Likewise.
5409 (reg_unused_after): Likewise.
5410 (_reg_unused_after): Likewise.
5411 (avr_compare_pattern): Likewise.
5412 (avr_reorg_remove_redundant_compare): Likewise for param "insn1"
5413 and locals "branch1", "branch2", "insn2", "jump".
5414 (avr_reorg): Likewise for local "insn".
5415 (avr_2word_insn_p): Likewise for param "insn".
5416 (jump_over_one_insn_p): Likewise.
5417 (avr_out_sbxx_branch): Likewise.
5418 (avr_out_movmem): Likewise.
5419
5420 2014-08-25 David Malcolm <dmalcolm@redhat.com>
5421
5422 * config/arm/arm-protos.h (arm_final_prescan_insn): Strengthen
5423 param from rtx to rtx_insn *.
5424 (thumb1_final_prescan_insn): Likewise.
5425 (thumb2_final_prescan_insn): Likewise.
5426
5427 * config/arm/arm.c (emit_set_insn): Strengthen return type from
5428 rtx to rtx_insn *.
5429 (struct minipool_node): Likewise for field "insn".
5430 (dump_minipool): Likewise for param "scan".
5431 (create_fix_barrier): Likewise for local "from". Strengthen local
5432 "label" from rtx to rtx_code_label *.
5433 (push_minipool_barrier): Strengthen param "insn" from rtx to
5434 rtx_insn *.
5435 (push_minipool_fix): Likewise.
5436 (note_invalid_constants): Likewise.
5437 (thumb2_reorg): Likewise for local "insn".
5438 (arm_reorg): Likewise.
5439 (thumb2_final_prescan_insn): Likewise for param
5440 "insn" and local "first_insn".
5441 (arm_final_prescan_insn): Likewise for param "insn" and locals
5442 "start_insn", "this_insn".
5443 (arm_debugger_arg_offset): Likewise for param "insn".
5444 (thumb1_emit_multi_reg_push): Likewise for return type and local
5445 "insn".
5446 (thumb1_final_prescan_insn): Likewise for param "insn".
5447 (thumb_far_jump_used_p): Likewise for local "insn".
5448 (thumb1_expand_prologue): Likewise.
5449 (arm_expand_epilogue_apcs_frame): Likewise.
5450 (arm_expand_epilogue): Likewise for locals "insn", "tmp".
5451 (arm_split_compare_and_swap): Strengthen locals "label1", "label2"
5452 from rtx to rtx_code_label *.
5453 (arm_split_atomic_op): Likewise for local "label".
5454 (arm_emit_coreregs_64bit_shift): Likewise for local "done_label".
5455
5456 2014-08-25 David Malcolm <dmalcolm@redhat.com>
5457
5458 * config/arc/arc-protos.h (arc_final_prescan_insn): Strengthen
5459 first param from rtx to rtx_insn *.
5460 (arc_verify_short): Likewise.
5461 (arc_short_long): Likewise.
5462 (arc_need_delay): Likewise.
5463
5464 * config/arc/arc.c (struct arc_ccfsm): Likewise for field
5465 "target_insn".
5466 (arc_ccfsm_advance): Likewise for param "insn" and locals
5467 "start_insn", "this_insn".
5468 (arc_ccfsm_record_condition): Likewise for local "seq_insn".
5469 (arc_ccfsm_post_advance): Likewise for param "insn".
5470 (arc_next_active_insn): Likewise for return type and param "insn".
5471 Convert NULL_RTX to NULL as appropriate. Add a checked cast.
5472 (arc_verify_short): Strengthen param "insn" from rtx to rtx_insn *.
5473 (output_short_suffix): Likewise for local "insn".
5474 (arc_final_prescan_insn): Likewise for param "insn". Remove
5475 now-redundant checked cast.
5476 (arc_reorg): Strengthen locals "insn", "top_label", "lp", "prev",
5477 "lp_simple", "next", "mov", "scan", "link_insn" from rtx to
5478 rtx_insn *. Add a checked cast. Introduce local "lc_set_insn"
5479 for use where lc_set became an insn.
5480 (arc_adjust_insn_length): Strengthen locals "prev", "succ" from
5481 rtx to rtx_insn *.
5482 (arc_get_insn_variants): Likewise for local "prev".
5483 (arc_ifcvt): Likewise for locals "insn", "seq", "prev", "pprev",
5484 "next".
5485 (arc_predicate_delay_insns): Likewise for local "insn".
5486 (arc_pad_return): Likewise for local "prev". For now, add a
5487 checked cast when extracting the insn from "final_sequence".
5488 (arc_short_long): Likewise for param "insn".
5489 (arc_need_delay): Likewise for param "insn" and local "next".
5490 (arc_label_align): Likewise for locals "prev", "next".
5491
5492 2014-08-25 David Malcolm <dmalcolm@redhat.com>
5493
5494 * config/alpha/alpha.c (alpha_emit_set_const): Strengthen local
5495 "insn" from rtx to rtx_insn *.
5496 (alpha_gp_save_rtx): Likewise for local "seq".
5497 (alpha_instantiate_decls): Likewise for local "top".
5498 (get_some_local_dynamic_name): Likewise for local "insn".
5499 (alpha_does_function_need_gp): Likewise.
5500 (set_frame_related_p): Likewise for return type and for locals
5501 "seq" and "insn".
5502 (emit_frame_store_1): Likewise for local "insn".
5503 (alpha_expand_prologue): Likewise for locals "insn", "seq".
5504 (alpha_end_function): Likewise for local "insn".
5505 (alpha_output_mi_thunk_osf): Likewise.
5506 (alphaev4_insn_pipe): Likewise for param "insn".
5507 (alphaev5_insn_pipe): Likewise.
5508 (alphaev4_next_group): Likewise for return type and param 1
5509 "insn".
5510 (alphaev5_next_group): Likewise.
5511 (alpha_align_insns_1): Likewise for return type and param 1 of
5512 callback param "next_group", and for locals "i", "next", "prev",
5513 "where", "where2", "insn".
5514
5515 2014-08-25 Bernd Schmidt <bernds@codesourcery.com>
5516
5517 * tree-nested.c (finalize_nesting_tree_1): Initialize temporary earlier
5518 rather than modifying the stmt.
5519
5520 2014-08-25 Jan-Benedict Glaw <jbglaw@lug-owl.de>
5521
5522 * config/rs6000/rs6000.c (rs6000_return_in_msb): Fix fallout from
5523 cgraph_state conversion.
5524
5525 2014-08-25 David Malcolm <dmalcolm@redhat.com>
5526
5527 * config/aarch64/aarch64.c (aarch64_load_symref_appropriately):
5528 Strengthen local "insns" from rtx to rtx_insn *.
5529 (aarch64_set_frame_expr): Likewise for local "insn".
5530 (aarch64_save_or_restore_fprs): Likewise.
5531 (aarch64_save_or_restore_callee_save_registers): Likewise.
5532 (aarch64_expand_prologue): Likewise.
5533 (aarch64_expand_epilogue): Likewise.
5534 (aarch64_output_mi_thunk): Likewise.
5535 (aarch64_split_compare_and_swap): Strengthen locals "label1" and
5536 "label2" from rtx to rtx_code_label *.
5537 (aarch64_split_atomic_op): Likewise for local "label".
5538
5539 2014-08-25 Martin Liska <mliska@suse.cz>
5540
5541 * cgraph.h (symtab_node):
5542 (bool needed_p (void)): created from decide_is_symbol_needed
5543 (bool referred_to_p (void)): created from referred_to_p
5544 (static cgraph_node *get_for_asmname (tree asmname)): created from symtab_node_for_asm
5545 * cgraph.h (cgraph_node):
5546 (void assemble_thunks_and_aliases (void)): created from assemble_thunks_and_aliases
5547 (void expand (void)): created from expand_function
5548 (static void finalize_function (tree, bool)): created from cgraph_finalize_function
5549 (static cgraph_local_info *local_info (tree decl)): created from cgraph_local_info
5550 (static cgraph_global_info *global_info (tree)): created from cgraph_global_info
5551 (static cgraph_rtl_info *rtl_info (tree)): created from cgraph_rtl_info
5552 * cgraph.h (varpool_node):
5553 (static void add (tree decl): created from varpool_add_new_variable
5554 * cgraph.h (cgraph_edge):
5555 void remove (void);
5556 (void remove_caller (void)): created from cgraph_edge_remove_caller
5557 (void remove_callee (void)): created from cgraph_edge_remove_callee
5558 (void set_call_stmt (gimple new_stmt, bool update_speculative = true)):
5559 created from cgraph_set_call_stmt
5560 (void redirect_callee (cgraph_node *n)): created from cgraph_redirect_edge_callee
5561 (cgraph_edge *make_direct (cgraph_node *callee)): created from cgraph_make_edge_direct
5562 (cgraph_edge *make_speculative (cgraph_node *n2, gcov_type direct_count,
5563 gimple redirect_call_stmt_to_callee (void)): created from cgraph_turn_edge_to_speculative
5564 (void speculative_call_info (cgraph_edge *&direct, cgraph_edge *&indirect, ipa_ref *&reference)):
5565 created from cgraph_speculative_call_info
5566 (cgraph_edge * clone (cgraph_node *n, gimple call_stmt, unsigned stmt_uid, gcov_type count_scale,
5567 int freq_scale, bool update_original)): created from cgraph_clone_edge
5568 (cgraph_edge *resolve_speculation (tree callee_decl)): created from cgraph_resolve_speculation
5569 (bool cannot_lead_to_return_p (void)): created from cannot_lead_to_return_p
5570 (bool recursive_p (void)): created from cgraph_edge_recursive_p
5571 (bool maybe_hot_p (void)): created from cgraph_maybe_hot_edge_p
5572 (static unsigned int rebuild_edges (void)): created from rebuild_cgraph_edges
5573 (static void rebuild_references (void)): created from cgraph_rebuild_references
5574 * cgraph.h (symbol_table):
5575 (create_reference): renamed from add_reference
5576 (maybe_create_reference): renamed from maybe_add_reference
5577 (void register_symbol (symtab_node *node)): new function
5578 (void clear_asm_symbols (void)): new function
5579 (void unregister (symtab_node *node)): new function
5580 (void release_symbol (cgraph_node *node, int uid)): new function
5581 (cgraph_node * allocate_cgraph_symbol (void)): new function
5582 (void initialize (void)): created from cgraph_init
5583 (symtab_node *first_symbol (void)):new function
5584 (asm_node *first_asm_symbol (void)):new function
5585 (symtab_node *first_defined_symbol (void)):new function
5586 (varpool_node *first_variable (void)):new function
5587 (varpool_node *next_variable (varpool_node *node)):new function
5588 (varpool_node *first_static_initializer (void)):new function
5589 (varpool_node *next_static_initializer (varpool_node *node)):new function
5590 (varpool_node *first_defined_variable (void)):new function
5591 (varpool_node *next_defined_variable (varpool_node *node)):new function
5592 (cgraph_node *first_defined_function (void)):new function
5593 (cgraph_node *next_defined_function (cgraph_node *node)):new function
5594 (cgraph_node *first_function (void)):new function
5595 (cgraph_node *next_function (cgraph_node *node)):new function
5596 (cgraph_node *first_function_with_gimple_body (void)):new function
5597 (asm_node *finalize_toplevel_asm (tree asm_str)): created from add_asm_node
5598 (bool remove_unreachable_nodes (bool before_inlining_p, FILE *file)):
5599 created from symtab_remove_unreachable_nodes
5600 (void remove_unreferenced_decls (void)): created from varpool_remove_unreferenced_decls
5601 (void process_new_functions (void)): created from cgraph_process_new_functions
5602 (void process_same_body_aliases (void)): created from cgraph_process_same_body_aliases
5603 (bool output_variables (void)): created from varpool_node::output_variables
5604 (void output_asm_statements (void)): created from output_asm_statements
5605 (void finalize_compilation_unit (void)): created from finalize_compilation_unit
5606 (void compile (void)): created from compile
5607 (void output_weakrefs (void)): created from output_weakrefs
5608 (cgraph_node *create_empty (void)): created from cgraph_node::create_empty
5609 (cgraph_edge *create_edge (cgraph_node *caller, cgraph_node *callee, gimple call_stmt,
5610 gcov_type count, int freq, bool indir_unknown_callee)): created from cgraph_node::create_edge
5611 (void free_edge (cgraph_edge *e)): created from cgraph_free_edge
5612 (cgraph_node *next_function_with_gimple_body (cgraph_node *node)):
5613 created from cgraph_next_function_with_gimple_body
5614 (void remove_edge_removal_hook (cgraph_edge_hook_list *)):
5615 created from cgraph_remove_edge_removal_hook
5616 (cgraph_node_hook_list *add_cgraph_removal_hook (cgraph_node_hook, void *)):
5617 created from cgraph_add_node_removal_hook
5618 (void remove_cgraph_removal_hook (cgraph_node_hook_list *)):
5619 created from cgraph_remove_node_removal_hook
5620 (varpool_node_hook_list *add_varpool_removal_hook (varpool_node_hook, void *)):
5621 created from varpool_add_node_removal_hook
5622 (void remove_varpool_removal_hook (varpool_node_hook_list *)):
5623 created from varpool_remove_node_removal_hook
5624 (cgraph_node_hook_list *add_cgraph_insertion_hook (cgraph_node_hook, void *)):
5625 created from cgraph_add_function_insertion_hook
5626 (void remove_cgraph_insertion_hook (cgraph_node_hook_list *)):
5627 created from cgraph_remove_function_insertion_hook
5628 (varpool_node_hook_list *add_varpool_insertion_hook (varpool_node_hook, void *)):
5629 created from varpool_add_variable_insertion_hook
5630 (void remove_varpool_insertion_hook (varpool_node_hook_list *)):
5631 created from varpool_remove_variable_insertion_hook
5632 (cgraph_2edge_hook_list *add_edge_duplication_hook (cgraph_2edge_hook, void *)):
5633 created from cgraph_add_edge_duplication_hook
5634 (void remove_edge_duplication_hook (cgraph_2edge_hook_list *)):
5635 created from cgraph_remove_edge_duplication_hook
5636 (cgraph_2node_hook_list *add_cgraph_duplication_hook (cgraph_2node_hook, void *)):
5637 created from cgraph_add_node_duplication_hook
5638 (void remove_cgraph_duplication_hook (cgraph_2node_hook_list *)):
5639 created from cgraph_remove_node_duplication_hook
5640 (void call_edge_removal_hooks (cgraph_edge *e)):
5641 created from cgraph_call_edge_removal_hooks
5642 (void call_cgraph_insertion_hooks (cgraph_node *node)):
5643 created from call_function_insertion_hooks
5644 (void call_cgraph_removal_hooks (cgraph_node *node)):
5645 created from cgraph_call_node_removal_hooks
5646 (void call_cgraph_duplication_hooks (cgraph_node *node, cgraph_node *node2)):
5647 created from cgraph_node::call_duplication_hooks
5648 (void call_edge_duplication_hooks (cgraph_edge *cs1, cgraph_edge *cs2)):
5649 created from cgraph_call_edge_duplication_hooks
5650 (void call_varpool_removal_hooks (varpool_node *node)):
5651 created from varpool_call_node_removal_hooks
5652 (void call_varpool_insertion_hooks (varpool_node *node)):
5653 created from varpool_call_variable_insertion_hooks
5654 (void insert_to_assembler_name_hash (symtab_node *node, bool with_clones)):
5655 created from insert_to_assembler_name_hash
5656 (void unlink_from_assembler_name_hash (symtab_node *node, bool with_clones)):
5657 created from unlink_from_assembler_name_hash
5658 (void symtab_prevail_in_asm_name_hash (symtab_node *node)):
5659 created from symtab_prevail_in_asm_name_hash
5660 (void symtab_initialize_asm_name_hash (void)):
5661 created from symtab_initialize_asm_name_hash
5662 (void change_decl_assembler_name (tree decl, tree name)):
5663 created from change_decl_assembler_name
5664 (void materialize_all_clones (void)): created from cgraph_materialize_all_clones
5665 (static hashval_t decl_assembler_name_hash (const_tree asmname)):
5666 created from decl_assembler_name_hash
5667 (static bool decl_assembler_name_equal (tree decl, const_tree asmname)):
5668 created from decl_assembler_name_equal
5669 (static hashval_t hash_node_by_assembler_name (const void *p)):
5670 created from hash_node_by_assembler_name
5671 (static int eq_assembler_name (const void *p1, const void *p2)):
5672 created from eq_assembler_name
5673
5674 2014-08-25 Marek Polacek <polacek@redhat.com>
5675
5676 * config/i386/i386.md (SWI1248_AVX512BW): Add missing paren.
5677
5678 2014-08-25 Petr Murzin <petr.murzin@intel.com>
5679
5680 * config/i386/i386.md (SWI1248_AVX512BW): New mode iterator.
5681 (*k<logic><mode>): Add *k<logic>qi and *k<logic>hi and use
5682 SWI1248_AVX512BW mode iterator.
5683
5684 2014-08-25 Kaz Kojima <kkojima@gcc.gnu.org>
5685
5686 PR target/62111
5687 * config/sh/predicates.md (general_extend_operand): Disable
5688 TRUNCATE before reload completes.
5689
5690 2014-08-24 Gerald Pfeifer <gerald@pfeifer.com>
5691
5692 * doc/invoke.texi (Optimize Options): Fix markup in two cases.
5693
5694 2014-08-24 Oleg Endo <olegendo@gcc.gnu.org>
5695
5696 PR target/61996
5697 * config/sh/sh.opt (musermode): Allow negative form.
5698 * config/sh/sh.c (sh_option_override): Disable TARGET_USERMODE for
5699 targets that don't support it.
5700 * doc/invoke.texi (SH Options): Rename sh-*-linux* to sh*-*-linux*.
5701 Document -mno-usermode option.
5702
5703 2014-08-24 Kito Cheng <kito@0xlab.org>
5704
5705 * system.h (CALLER_SAVE_PROFITABLE): Poison.
5706 * regs.h (CALLER_SAVE_PROFITABLE): Remove.
5707 * doc/tm.texi.in (CALLER_SAVE_PROFITABLE): Remove.
5708 * doc/tm.texi: Regenerate.
5709
5710 2014-08-24 Kito Cheng <kito@0xlab.org>
5711
5712 * ira.c: Fix typo in comment.
5713
5714 2014-08-23 Edward Smith-Rowland <3dw4rd@verizon.net>
5715
5716 * doc/invoke.texi: Change c++1y to c++14 and gnu++1y to gnu++14.
5717 Deprecate c++1y. Change language to reflect greater confidence in C++14.
5718
5719 2014-08-23 John David Anglin <danglin@gcc.gnu.org>
5720
5721 PR target/62038
5722 * config/pa/pa.c (pa_output_function_epilogue): Don't set
5723 last_address when the current function is a thunk.
5724 (pa_asm_output_mi_thunk): When we don't have named sections or they
5725 are not being used, check that thunk can reach the stub table with a
5726 short branch.
5727
5728 2014-08-23 David Malcolm <dmalcolm@redhat.com>
5729
5730 * web.c (union_match_dups): Strengthen param "insn" from rtx to
5731 rtx_insn *.
5732 (pass_web::execute): Likewise for local "insn".
5733
5734 2014-08-23 David Malcolm <dmalcolm@redhat.com>
5735
5736 * var-tracking.c (struct micro_operation_def): Strengthen field
5737 "insn" from rtx to rtx_insn *.
5738 (struct emit_note_data_def): Likewise.
5739 (insn_stack_adjust_offset_pre_post): Likewise for param "insn".
5740 (vt_stack_adjustments): Likewise for local "insn".
5741 (adjust_insn): Likewise for param "insn".
5742 (val_store): Likewise.
5743 (val_resolve): Likewise.
5744 (struct count_use_info): Likewise for field "insn".
5745 (log_op_type): Likewise for param "insn".
5746 (reverse_op): Likewise.
5747 (prepare_call_arguments): Likewise.
5748 (add_with_sets): The initial param takes an insn, but we can't
5749 yet strengthen it from rtx to rtx_insn * since it's used as a
5750 cselib_record_sets_hook callback. For now rename initial param
5751 from "insn" to "uncast_insn", and introduce a local "insn" of
5752 the stronger rtx_insn * type, with a checked cast.
5753 (compute_bb_dataflow): Strengthen local "insn" from rtx to
5754 rtx_insn *.
5755 (emit_note_insn_var_location): Likewise.
5756 (emit_notes_for_changes): Likewise.
5757 (emit_notes_for_differences): Likewise.
5758 (next_non_note_insn_var_location): Likewise for return type and
5759 for param "insn".
5760 (emit_notes_in_bb): Likewise for locals "insn" and "next_insn".
5761 (vt_initialize): Likewise for local "insn".
5762 (delete_debug_insns): Likewise for locals "insn" and "next".
5763
5764 2014-08-23 David Malcolm <dmalcolm@redhat.com>
5765
5766 * varasm.c (mark_constants): Strengthen param "insn" from rtx to
5767 rtx_insn *.
5768 (mark_constant_pool): Likewise for local "insn".
5769
5770 2014-08-23 David Malcolm <dmalcolm@redhat.com>
5771
5772 * valtrack.c (dead_debug_reset_uses): Strengthen local "insn" from
5773 rtx to rtx_insn *.
5774 (dead_debug_promote_uses): Likewise.
5775 (dead_debug_insert_temp): Likewise.
5776
5777 2014-08-23 David Malcolm <dmalcolm@redhat.com>
5778
5779 * store-motion.c (store_killed_in_insn): Strengthen param "insn"
5780 from const_rtx to const rtx_insn *.
5781 (store_killed_after): Likewise. Strengthen locals "last", "act"
5782 from rtx to rtx_insn *.
5783 (store_killed_before): Strengthen param "insn" from const_rtx to
5784 const rtx_insn *. Strengthen local "first" from rtx to rtx_insn *.
5785 (find_moveable_store): Strengthen param "insn" from rtx to
5786 rtx_insn *.
5787 (compute_store_table): Likewise for local "insn".
5788 (insert_insn_start_basic_block): Likewise for param "insn" and
5789 locals "prev", "before", "insn".
5790 (insert_store): For now, add a checked cast to rtx_insn * on the
5791 result of gen_move_insn.
5792 (remove_reachable_equiv_notes): Strengthen local "insn" from rtx
5793 to rtx_insn *.
5794 (replace_store_insn): Likewise. For now, add a checked cast to
5795 rtx_insn * on the result of gen_move_insn.
5796
5797 2014-08-22 David Malcolm <dmalcolm@redhat.com>
5798
5799 * stmt.c (expand_case): Strengthen local "before_case" from rtx to
5800 rtx_insn *.
5801 (expand_sjlj_dispatch_table): Likewise.
5802
5803 2014-08-22 David Malcolm <dmalcolm@redhat.com>
5804
5805 * stack-ptr-mod.c (pass_stack_ptr_mod::execute): Strengthen local
5806 "insn" from rtx to rtx_insn *.
5807
5808 2014-08-22 David Malcolm <dmalcolm@redhat.com>
5809
5810 * shrink-wrap.h (requires_stack_frame_p): Strengthen param 1
5811 "insn" from rtx to rtx_insn *.
5812 (dup_block_and_redirect): Likewise for param 3 "before".
5813
5814 * shrink-wrap.c (requires_stack_frame_p): Strengthen param "insn"
5815 from rtx to rtx_insn *.
5816 (move_insn_for_shrink_wrap): Likewise.
5817 (prepare_shrink_wrap): Likewise for locals "insn", "curr".
5818 (dup_block_and_redirect): Likewise for param "before" and local
5819 "insn".
5820 (try_shrink_wrapping): Likewise for locals "insn", "insert_point",
5821 "end".
5822 (convert_to_simple_return): Likewise for local "start".
5823
5824 * config/i386/i386.c (ix86_finalize_stack_realign_flags):
5825 Strengthen local "insn" from rtx to rtx_insn *, for use when
5826 invoking requires_stack_frame_p.
5827
5828 2014-08-22 David Malcolm <dmalcolm@redhat.com>
5829
5830 * sel-sched-ir.c (vinsn_copy): Strengthen local "copy" from rtx to
5831 rtx_insn *.
5832 (speculate_expr): Likewise for locals "orig_insn_rtx",
5833 "spec_insn_rtx".
5834 (eq_transformed_insns): Likewise for locals "i1", "i2".
5835 (check_for_new_jump): Likewise for return type and local "end".
5836 (find_new_jump): Likewise for return type and local "jump".
5837 (sel_split_edge): Likewise for local "jump".
5838 (sel_create_recovery_block): Likewise.
5839 (sel_redirect_edge_and_branch_force): Likewise.
5840 (sel_redirect_edge_and_branch): Likewise.
5841
5842 2014-08-22 David Malcolm <dmalcolm@redhat.com>
5843
5844 * sel-sched.c (substitute_reg_in_expr): Strengthen local
5845 "new_insn" from rtx to rtx_insn *.
5846 (create_insn_rtx_with_rhs): Likewise for return type and for local
5847 "insn_rtx".
5848 (create_insn_rtx_with_lhs): Likewise.
5849 (create_speculation_check): Likewise for local "insn_rtx".
5850 (implicit_clobber_conflict_p): Likewise for local "insn".
5851 (get_expr_cost): Likewise.
5852 (emit_bookkeeping_insn): Likewise for local "new_insn_rtx".
5853 (move_cond_jump): Likewise for locals "next", "prev", "link",
5854 "head", "from", "to".
5855
5856 2014-08-22 David Malcolm <dmalcolm@redhat.com>
5857
5858 * sched-rgn.c (is_cfg_nonregular): Strengthen locals "insn" and
5859 "next" from rtx to rtx_insn *.
5860 (find_conditional_protection): Likewise for local "next".
5861 (is_conditionally_protected): Likewise for local "insn1".
5862 (is_pfree): Likewise for locals "insn1", "insn2".
5863
5864 2014-08-22 David Malcolm <dmalcolm@redhat.com>
5865
5866 * sched-int.h (schedule_ebb): Strengthen params "head", "tail"
5867 from rtx to rtx_insn *.
5868
5869 * sched-ebb.c (earliest_block_with_similiar_load): Strengthen
5870 locals "insn1", "insn2" from rtx to rtx_insn *.
5871 (add_deps_for_risky_insns): Likewise for params "head", "tail" and
5872 locals "insn", "prev", "last_jump", "next_tail".
5873 (schedule_ebb): Likewise for params "head", "tail".
5874 (schedule_ebbs): Likewise for locals "tail", "head".
5875
5876 * config/c6x/c6x.c (hwloop_optimize): For now, add a checked cast
5877 to rtx_insn on "last_insn" in one of the invocations of
5878 schedule_ebb.
5879
5880 2014-08-22 David Malcolm <dmalcolm@redhat.com>
5881
5882 * sched-deps.c (maybe_add_or_update_dep_1): Strengthen locals
5883 "elem", "insn" from rtx to rtx_insn *.
5884 (change_spec_dep_to_hard): Likewise.
5885 (get_back_and_forw_lists): Likewise for local "con".
5886 (sd_add_dep): Likewise for locals "elem", "insn".
5887 (sd_resolve_dep): Likewise for locals "pro", "con".
5888 (sd_unresolve_dep): Likewise.
5889 (sd_delete_dep): Likewise.
5890 (chain_to_prev_insn): Likewise for local "pro".
5891 (find_inc): Likewise for locals "pro", "con".
5892
5893 2014-08-22 David Malcolm <dmalcolm@redhat.com>
5894
5895 * rtlanal.c (reg_used_between_p): Strengthen local "insn" from rtx
5896 to rtx_insn *.
5897 (reg_set_between_p): Strengthen local "insn" from const_rtx to
5898 const rtx_insn *.
5899 (modified_between_p): Strengthen local "insn" from rtx to
5900 rtx_insn *.
5901 (remove_reg_equal_equiv_notes_for_regno): Likewise.
5902 (keep_with_call_p): Strengthen local "i2" from const_rtx to
5903 const rtx_insn *.
5904
5905 2014-08-22 David Malcolm <dmalcolm@redhat.com>
5906
5907 * resource.c (next_insn_no_annul): Strengthen local "next" from
5908 rtx to rtx_insn *.
5909 (mark_referenced_resources): Likewise for local "insn".
5910
5911 2014-08-22 David Malcolm <dmalcolm@redhat.com>
5912
5913 * reload.h (struct insn_chain): Strengthen field "insn" from rtx
5914 to rtx_insn *.
5915 (find_reloads): Likewise for param 1.
5916 (subst_reloads): Likewise for sole param.
5917 (find_equiv_reg): Likwise for param 2.
5918 (regno_clobbered_p): Likwise for param 2.
5919 (reload): Likewise for param 1.
5920
5921 * caller-save.c (save_call_clobbered_regs): Strengthen local
5922 "insn" from rtx to rtx_insn *.
5923 (insert_one_insn): Likewise for local "insn".
5924
5925 * reload.c (this_insn): Likewise for this global.
5926 (find_reloads): Likewise for param "insn".
5927 (find_reloads_toplev): Likewise.
5928 (find_reloads_address): Likewise.
5929 (subst_reg_equivs): Likewise.
5930 (update_auto_inc_notes): Likewise.
5931 (find_reloads_address_1): Likewise.
5932 (find_reloads_subreg_address): Likewise.
5933 (subst_reloads): Likewise.
5934 (find_equiv_reg): Likewise, also for local "p".
5935 (regno_clobbered_p): Likewise for param "insn".
5936
5937 * reload1.c (reg_reloaded_insn): Likewise for the elements of this
5938 array.
5939 (spill_reg_store): Likewise for the elements of this array.
5940 (remove_init_insns): Likewise for local "equiv_insn".
5941 (will_delete_init_insn_p): Likewise for param "insn".
5942 (reload): Likewise for param ""first" and local "insn".
5943 (calculate_needs_all_insns): Strengthen local "insn" from rtx to
5944 rtx_insn *.
5945 (calculate_elim_costs_all_insns): Likewise.
5946 (delete_caller_save_insns): Likewise.
5947 (spill_failure): Likewise for param "insn".
5948 (delete_dead_insn): Likewise.
5949 (set_label_offsets): Likewise.
5950 (eliminate_regs_in_insn): Likewise, also for locals "base_insn" and
5951 "prev_insn".
5952 (elimination_costs_in_insn): Likewise for param "insn".
5953 (set_initial_eh_label_offset): Replace use of NULL_RTX with NULL
5954 when referring to an insn.
5955 (set_initial_label_offsets): Likewise.
5956 (set_offsets_for_label): Strengthen param "insn" from rtx to
5957 rtx_insn *.
5958 (init_eliminable_invariants): Likewise for param "first" and local
5959 "insn".
5960 (fixup_eh_region_note): Likewise for param "insn".
5961 (reload_as_needed): Likewise for locals "prev", "insn",
5962 "old_next", "old_prev", "next".
5963 (gen_reload_chain_without_interm_reg_p): Likewise for locals "insn",
5964 "last".
5965 (reload_inheritance_insn): Strengthen elements of this array from
5966 rtx to rtx_insn *.
5967 (failed_reload): Likewise for param "insn".
5968 (choose_reload_regs): Likewise for local "insn". Replace use of
5969 NULL_RTX with NULL when referring to an insn.
5970 (input_reload_insns): Strengthen elements of this array from rtx
5971 to rtx_insn *.
5972 (other_input_address_reload_insns): Likewise for this global.
5973 (other_input_reload_insns): Likewise for this global.
5974 (input_address_reload_insns): Likwise for the elements of this
5975 array.
5976 (inpaddr_address_reload_insns): Likwise for the elements of this
5977 array.
5978 (output_reload_insns): Likewise for the elements of this array.
5979 (output_address_reload_insns): Likewise for the elements of this
5980 array.
5981 (outaddr_address_reload_insns): Likewise for the elements of this
5982 array.
5983 (operand_reload_insns): Likewise for this global.
5984 (other_operand_reload_insns): Likewise for this global.
5985 (other_output_reload_insns): Likewise for the elements of this
5986 array.
5987 (new_spill_reg_store): Likewise for the elements of this
5988 array.
5989 (emit_input_reload_insns): Likewise for locals "insn", "temp".
5990 Strengthen local "where" from rtx * to rtx_insn **.
5991 (emit_output_reload_insns): Strengthen locals "insn", "p", "next"
5992 from rtx to rtx_insn *.
5993 (do_input_reload): Likewise for local "insn".
5994 (do_output_reload): Likewise for local "insn".
5995 (emit_reload_insns): Likewise for locals "insn" and "store_insn".
5996 (emit_insn_if_valid_for_reload): Likewise for return type and local
5997 "last". Add checked cast to rtx_insn when returning "insn" since
5998 this has been through emit_insn.
5999 (gen_reload): Strengthen return type and locals "last", "insn", "set"
6000 from rtx to rtx_insn *. Add checked cast to rtx_insn when
6001 returning "insn" since it's been through
6002 emit_insn_if_valid_for_reload at this point.
6003 (delete_output_reload): Strengthen param "insn" and locals
6004 "output_reload_insn", "i2" from rtx to rtx_insn *.
6005 (delete_address_reloads): Likewise for params "dead_insn",
6006 "current_insn" and locals "prev", "next".
6007 (delete_address_reloads_1): Likewise for params "dead_insn",
6008 "current_insn" and locals "prev", "i2".
6009 (inc_for_reload): Likewise for locals "last", "add_insn".
6010 (add_auto_inc_notes): Strengthen param "insn" from rtx to
6011 rtx_insn *.
6012
6013 * config/arc/arc-protos.h (regno_clobbered_p): Likewise for 2nd
6014 param of this duplicate of the prototype from reload.h
6015
6016 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6017
6018 * regstat.c (regstat_bb_compute_ri): Strengthen local "insn" from
6019 rtx to rtx_insn *.
6020 (regstat_bb_compute_calls_crossed): Likewise.
6021
6022 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6023
6024 * regrename.c (create_new_chain): Strengthen param "insn" from rtx
6025 to rtx_insn *.
6026 (init_rename_info): Replace use of NULL_RTX with NULL when dealing
6027 with an insn.
6028 (regrename_analyze): Strengthen local "insn" from rtx to
6029 rtx_insn *.
6030 (scan_rtx_reg): Likewise for param "insn".
6031 (scan_rtx_address): Likewise.
6032 (scan_rtx): Likewise.
6033 (restore_operands): Likewise.
6034 (record_out_operands): Likewise.
6035 (build_def_use): Likewise for local "insn". Replace use of
6036 NULL_RTX with NULL when dealing with an insn.
6037
6038 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6039
6040 * rtl.h (reg_scan): Strengthen param "f" from rtx to rtx_insn *.
6041 * reginfo.c (reg_scan): Likewise, also for local "insn".
6042 (reg_scan_mark_refs): Likewise for param "insn".
6043 (init_subregs_of_mode): Likewise for local "insn".
6044
6045 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6046
6047 * regcprop.c (struct queued_debug_insn_change): Strengthen field
6048 "insn" from rtx to rtx_insn *.
6049 (replace_oldest_value_reg): Likewise for param "insn".
6050 (replace_oldest_value_addr): Likewise.
6051 (replace_oldest_value_mem): Likewise.
6052 (apply_debug_insn_changes): Likewise for local "last_insn".
6053 (copyprop_hardreg_forward_1): Likewise for local "insn".
6054
6055 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6056
6057 * reg-stack.c (next_flags_user): Strengthen return type and param
6058 "insn" from rtx to rtx_insn *.
6059 (straighten_stack): Likewise for param "insn".
6060 (check_asm_stack_operands): Likewise.
6061 (remove_regno_note): Likewise.
6062 (emit_pop_insn): Likewise for return type, param "insn", local
6063 "pop_insn".
6064 (emit_swap_insn): Strengthen param "insn" and locals "i1", "tmp",
6065 "limit" from rtx to rtx_insn *.
6066 (swap_to_top): Likewise for param "insn".
6067 (move_for_stack_reg): Likewise.
6068 (move_nan_for_stack_reg): Likewise.
6069 (swap_rtx_condition): Likewise.
6070 (compare_for_stack_reg): Likewise.
6071 (subst_all_stack_regs_in_debug_insn): Likewise.
6072 (subst_stack_regs_pat): Likewise, and local "insn2".
6073 (subst_asm_stack_regs): Strengthen param "insn" from rtx to
6074 rtx_insn *.
6075 (subst_stack_regs): Likewise.
6076 (change_stack): Likewise.
6077 (convert_regs_1): Likewise for locals "insn", "next".
6078
6079 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6080
6081 * ree.c (struct ext_cand): Strengthen field "insn" from rtx to
6082 rtx_insn *.
6083 (combine_set_extension): Likewise for param "curr_insn".
6084 (transform_ifelse): Likewise for param "def_insn".
6085 (get_defs): Likewise for param "def_insn". Strengthen param "dest"
6086 from vec<rtx> * to vec<rtx_insn *> *.
6087 (is_cond_copy_insn): Likewise for param "insn".
6088 (struct ext_state): Strengthen the four vec fields from vec<rtx>
6089 to vec<rtx_insn *>.
6090 (make_defs_and_copies_lists): Strengthen param "extend_insn" and
6091 local "def_insn" from rtx to rtx_insn *.
6092 (get_sub_rtx): Likewise for param "def_insn".
6093 (merge_def_and_ext): Likewise.
6094 (combine_reaching_defs): Likewise.
6095 (add_removable_extension): Likewise for param "insn".
6096 (find_removable_extensions): Likewise for local "insn".
6097 (find_and_remove_re): Likewise for locals "curr_insn" and
6098 "def_insn". Strengthen locals "reinsn_del_list" and
6099 "reinsn_del_list" from auto_vec<rtx> to auto_vec<rtx_insn *>.
6100
6101 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6102
6103 * recog.c (split_insn): Strengthen param "insn" and locals
6104 "first", "last" from rtx to rtx_insn *.
6105 (split_all_insns): Likewise for locals "insn", "next".
6106 (split_all_insns_noflow): Likewise.
6107
6108 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6109
6110 * rtl.h (debug_rtx_list): Strengthen param 1 "x" from const_rtx to
6111 const rtx_insn *.
6112 (debug_rtx_range): Likewise for params 1 and 2 "start" and "end".
6113 (debug_rtx_find): Likewise for param 1 "x".
6114
6115 * print-rtl.c (debug_rtx_list): Strengthen param 1 "x" from
6116 const_rtx to const rtx_insn *. Likewise for local "insn".
6117 (debug_rtx_range): Likewise for params 1 and 2 "start" and "end".
6118 (debug_rtx_find): Likewise for param 1 "x".
6119 (print_rtl): Likewise for local "tmp_rtx", adding a checked cast
6120 from const_rtx to const rtx_insn * within the appropriate cases of
6121 the switch statement.
6122
6123 * config/rs6000/rs6000.c (rs6000_debug_legitimize_address):
6124 Strengthen local "insns" from rtx to rtx_insn * since this is
6125 passed to a call to debug_rtx_list.
6126
6127 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6128
6129 * predict.h (predict_insn_def): Strengthen param "insn" from rtx
6130 to rtx_insn *.
6131
6132 * function.c (stack_protect_epilogue): Add checked cast to
6133 rtx_insn for now when invoking predict_insn_def.
6134
6135 * predict.c (predict_insn): Strengthen param "insn" from rtx to
6136 rtx_insn *.
6137 (predict_insn_def): Likewise.
6138 (rtl_predict_edge): Likewise for local "last_insn".
6139 (can_predict_insn_p): Strengthen param "insn" from const_rtx to
6140 const rtx_insn *.
6141 (combine_predictions_for_insn): Strengthen param "insn" from rtx
6142 to rtx_insn *.
6143 (bb_estimate_probability_locally): Likewise for local "last_insn".
6144 (expensive_function_p): Likewise for local "insn".
6145
6146 * config/cris/cris.c (cris_emit_trap_for_misalignment): Likewise for
6147 local "jmp", since this is used when invoking predict_insn_def.
6148
6149 2014-08-22 Marek Polacek <polacek@redhat.com>
6150
6151 PR c++/62199
6152 * doc/invoke.texi: Update -Wlogical-not-parentheses description.
6153
6154 2014-08-22 Marek Polacek <polacek@redhat.com>
6155
6156 PR c/61271
6157 * ira-color.c (coalesced_pseudo_reg_slot_compare): Wrap LHS of
6158 a comparison in parens.
6159 * lra-spills.c (pseudo_reg_slot_compare): Wrap LHS of a comparison
6160 in parens.
6161
6162 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6163
6164 * rtl.h (fis_get_condition): Strengthen param "jump" from rtx to
6165 rtx_insn *.
6166
6167 * cprop.c (fis_get_condition): Likewise.
6168
6169 * postreload.c (reload_cse_regs): Likewise for param "first".
6170 (reload_cse_simplify): Likewise for param "insn".
6171 (reload_cse_regs_1): Likewise for local "insn".
6172 (reload_cse_simplify_set): Likewise for param "insn".
6173 (reload_cse_simplify_operands): Likewise.
6174 (struct reg_use): Likewise for field "insn".
6175 (reload_combine_purge_insn_uses): Likewise for param "insn".
6176 (fixup_debug_insns): Likewise for params "from", "to" and local
6177 "insn".
6178 (try_replace_in_use): Likewise for local "use_insn".
6179 (reload_combine_recognize_const_pattern): Likewise for param
6180 "insn" and locals "add_moved_after_insn", "use_insn".
6181 (reload_combine_recognize_pattern): Likewise for param "insn" and
6182 local "prev".
6183 (reload_combine): Likewise for locals "insn", "prev".
6184 (reload_combine_note_use): Likewise for param "insn".
6185 (move2add_use_add2_insn): Likewise.
6186 (move2add_use_add3_insn): Likewise.
6187 (reload_cse_move2add): Likewise, also for local "next".
6188 (move2add_note_store): Likewise for local "insn".
6189
6190 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6191
6192 * postreload-gcse.c (struct occr): Strengthen field "insn" from
6193 rtx to rtx_insn *.
6194 (struct unoccr): Likewise.
6195 (struct modifies_mem): Likewise.
6196 (alloc_mem): Likewise for local "insn".
6197 (insert_expr_in_table): Likewise for param "insn".
6198 (dump_expr_hash_table_entry): Likewise for local "insn".
6199 (oprs_unchanged_p): Likewise for param "insn".
6200 (load_killed_in_block_p): Likewise for local "setter".
6201 (record_last_reg_set_info): Likewise for param "insn".
6202 (record_last_reg_set_info_regno): Likewise.
6203 (record_last_mem_set_info): Likewise.
6204 (record_last_set_info): Likewise for local "last_set_insn".
6205 (record_opr_changes): Likewise for param "insn".
6206 (hash_scan_set): Likewise.
6207 (compute_hash_table): Likewise for local "insn".
6208 (get_avail_load_store_reg): Likewise for param "insn".
6209 (eliminate_partially_redundant_load): Likewise, also for locals
6210 "avail_insn", "next_pred_bb_end". Replace use of NULL_RTX with
6211 RTX for insns.
6212 (eliminate_partially_redundant_loads): Likewise for local "insn".
6213
6214 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6215
6216 * optabs.c (expand_doubleword_shift): Strengthen local "insn" from
6217 rtx to rtx_insn *.
6218 (expand_binop): Likewise for locals "entry_last", "last", "insns"
6219 (expand_twoval_unop): Likewise for locals entry_last", "last".
6220 (expand_twoval_binop): Likewise.
6221 (expand_twoval_binop_libfunc): Likewise for local "insns".
6222 (widen_leading): Likewise for local "last".
6223 (expand_doubleword_clz): Likewise for local "seq". Strengthen
6224 locals "hi0_label", "after_label" from rtx to rtx_code_label *.
6225 (widen_bswap): Strengthen local "last" from rtx to rtx_insn *.
6226 (expand_parity): Likewise for locals "last" and "seq".
6227 (expand_ffs): Likewise for local "seq". Strengthen local
6228 "nonzero_label" from rtx to rtx_code_label *.
6229 (expand_absneg_bit): Strengthen local "insns" from rtx to
6230 rtx_insn *.
6231 (expand_unop_direct): Likewise for local "last".
6232 (expand_unop): Likewise for locals "last", "insns".
6233 (expand_abs_nojump): Likewise for local "last".
6234 (expand_abs): Strengthen local "op1" from rtx to rtx_code_label *.
6235 (expand_one_cmpl_abs_nojump): Strengthen local "last" from rtx to
6236 rtx_insn *.
6237 (expand_copysign_absneg): Strengthen local "label" from rtx to
6238 rtx_code_label *.
6239 (expand_copysign_bit): Strengthen local "insns" from rtx to
6240 rtx_insn *.
6241 (struct no_conflict_data): Likewise for fields "first", "insn".
6242 (emit_libcall_block_1): Likewise for param "insns" and locals
6243 "next", "last", "insn".
6244 (emit_libcall_block): For now, add a checked cast to rtx_insn *
6245 on "insns" when invoking emit_libcall_block_1. Ultimately we
6246 want to strengthen insns itself.
6247 (prepare_cmp_insn): Strengthen local "last" from rtx to
6248 rtx_insn *.
6249 (emit_cmp_and_jump_insn_1): Likewise for local "insn".
6250 (prepare_float_lib_cmp): Likewise for local "insns".
6251 (emit_conditional_move): Likewise for local "last".
6252 (emit_conditional_add): Likewise.
6253 (have_sub2_insn): Likewise for local "seq".
6254 (expand_float): Likewise for local "insns". Strengthen locals
6255 "label", "neglabel" from rtx to rtx_code_label *.
6256 (expand_fix): Likewise for locals "last", "insn", "insns" (to
6257 rtx_insn *) and locals "lab1", "lab2" (to rtx_code_label *).
6258 (expand_fixed_convert): Likewise for local "insns" (to
6259 rtx_insn *).
6260 (expand_sfix_optab): Likewise for local "last".
6261 (expand_compare_and_swap_loop): Strengthen local "label" from rtx
6262 to rtx_code_label *.
6263 (maybe_emit_sync_lock_test_and_set): Strengthen local "last_insn"
6264 from rtx to rtx_insn *.
6265 (expand_atomic_fetch_op): Likewise for local "insn".
6266 (maybe_legitimize_operand_same_code): Likewise for local "last".
6267 (maybe_legitimize_operands): Likewise.
6268
6269 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6270
6271 * modulo-sched.c (struct ps_reg_move_info): Strengthen field
6272 "insn" from rtx to rtx_insn *.
6273 (ps_rtl_insn): Likewise for return type.
6274 (doloop_register_get): Likewise for params "head", "tail" and
6275 locals "insn", "first_insn_not_to_check".
6276 (schedule_reg_move): Likewise for local "this_insn".
6277 (schedule_reg_moves): Add a checked cast to rtx_insn * to result
6278 of gen_move_insn for now.
6279 (reset_sched_times): Strengthen local "insn" from rtx to
6280 rtx_insn *.
6281 (permute_partial_schedule): Likewise.
6282 (duplicate_insns_of_cycles): Likewise for local "u_insn".
6283 (dump_insn_location): Likewise for param "insn".
6284 (loop_canon_p): Likewise for local "insn".
6285 (sms_schedule): Likewise.
6286 (print_partial_schedule): Likewise.
6287 (ps_has_conflicts): Likewise.
6288
6289 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6290
6291 * sched-int.h (get_ebb_head_tail): Strengthen params "headp" and
6292 "tailp" from rtx * to rtx_insn **.
6293
6294 * ddg.c (build_intra_loop_deps): Strengthen locals head", "tail"
6295 from rtx to rtx_insn *.
6296 * haifa-sched.c (get_ebb_head_tail): Strengthen params "headp" and
6297 "tailp" from rtx * to rtx_insn **. Strengthen locals "beg_head",
6298 "beg_tail", "end_head", "end_tail", "note", "next", "prev" from
6299 rtx to rtx_insn *.
6300 * modulo-sched.c (const_iteration_count): Strengthen return type
6301 and locals "insn", "head", "tail" from rtx to rtx_insn *. Replace
6302 use of NULL_RTX with NULL when working with insns.
6303 (loop_single_full_bb_p): Strengthen locals "head", "tail" from rtx
6304 to rtx_insn *.
6305 (sms_schedule): Likewise.
6306 * sched-rgn.c (init_ready_list): Likewise, also for locals
6307 "src_head" and "src_next_tail".
6308 (compute_block_dependences): Likewise.
6309 (free_block_dependencies): Likewise.
6310 (debug_rgn_dependencies): Likewise.
6311 (free_rgn_deps): Likewise.
6312 (compute_priorities): Likewise.
6313 (schedule_region): Likewise.
6314 * sel-sched.c (find_ebb_boundaries): Likewise.
6315
6316 * config/sh/sh.c (find_insn_regmode_weight): Strengthen locals
6317 "insn", "next_tail", "head", "tail" from rtx to rtx_insn *.
6318
6319 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6320
6321 * mode-switching.c (struct seginfo): Strengthen field "insn_ptr"
6322 from rtx to rtx_insn *.
6323 (new_seginfo): Likewise for param "insn".
6324 (create_pre_exit): Likewise for locals "last_insn",
6325 "before_return_copy", "return_copy".
6326 (optimize_mode_switching): Likewise for locals "insn", "ins_pos",
6327 "mode_set".
6328
6329 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6330
6331 * lra-int.h (struct lra_insn_recog_data): Strengthen field "insn"
6332 from rtx to rtx_insn *.
6333 (lra_push_insn): Likewise for 1st param.
6334 (lra_push_insn_and_update_insn_regno_info): Likewise.
6335 (lra_pop_insn): Likewise for return type.
6336 (lra_invalidate_insn_data): Likewise for 1st param.
6337 (lra_set_insn_deleted): Likewise.
6338 (lra_delete_dead_insn): Likewise.
6339 (lra_process_new_insns): Likewise for first 3 params.
6340 (lra_set_insn_recog_data): Likewise for 1st param.
6341 (lra_update_insn_recog_data): Likewise.
6342 (lra_set_used_insn_alternative): Likewise.
6343 (lra_invalidate_insn_regno_info): Likewise.
6344 (lra_update_insn_regno_info): Likewise.
6345 (lra_former_scratch_operand_p): Likewise.
6346 (lra_eliminate_regs_1): Likewise.
6347 (lra_get_insn_recog_data): Likewise.
6348
6349 * lra-assigns.c (assign_by_spills): Strengthen local "insn" from
6350 rtx to rtx_insn *.
6351
6352 * lra-coalesce.c (move_freq_compare_func): Likewise for locals
6353 "mv1" and "mv2".
6354 (substitute_within_insn): New.
6355 (lra_coalesce): Strengthen locals "mv", "insn", "next" from rtx to
6356 rtx_insn *. Strengthen sorted_moves from rtx * to rxt_insn **.
6357 Replace call to "substitute" with call to substitute_within_insn.
6358
6359 * lra-constraints.c (curr_insn): Strengthen from rtx to
6360 rtx_insn *.
6361 (get_equiv_with_elimination): Likewise for param "insn".
6362 (match_reload): Strengthen params "before" and "after" from rtx *
6363 to rtx_insn **.
6364 (emit_spill_move): Likewise for return type. Add a checked cast
6365 to rtx_insn * on result of gen_move_insn for now.
6366 (check_and_process_move): Likewise for local "before". Replace
6367 NULL_RTX with NULL when referring to insns.
6368 (process_addr_reg): Strengthen params "before" and "after" from
6369 rtx * to rtx_insn **.
6370 (insert_move_for_subreg): Likewise.
6371 (simplify_operand_subreg): Strengthen locals "before" and "after"
6372 from rtx to rtx_insn *.
6373 (process_address_1): Strengthen params "before" and "after" from
6374 rtx * to rtx_insn **. Strengthen locals "insns", "last_insn" from
6375 rtx to rtx_insn *.
6376 (process_address): Strengthen params "before" and "after" from
6377 rtx * to rtx_insn **.
6378 (emit_inc): Strengthen local "last" from rtx to rtx_insn *.
6379 (curr_insn_transform): Strengthen locals "before" and "after"
6380 from rtx to rtx_insn *. Replace NULL_RTX with NULL when referring
6381 to insns.
6382 (loc_equivalence_callback): Update cast of "data", changing
6383 resulting type from rtx to rtx_insn *.
6384 (substitute_pseudo_within_insn): New.
6385 (inherit_reload_reg): Strengthen param "insn" from rtx to
6386 rtx_insn *; likewise for local "new_insns". Replace NULL_RTX with
6387 NULL when referring to insns. Add a checked cast to rtx_insn *
6388 when using usage_insn to invoke lra_update_insn_regno_info.
6389 (split_reg): Strengthen param "insn" from rtx to rtx_insn *;
6390 likewise for locals "restore", "save". Add checked casts to
6391 rtx_insn * when using usage_insn to invoke
6392 lra_update_insn_regno_info and lra_process_new_insns. Replace
6393 NULL_RTX with NULL when referring to insns.
6394 (split_if_necessary): Strengthen param "insn" from rtx to
6395 rtx_insn *.
6396 (update_ebb_live_info): Likewise for params "head", "tail" and local
6397 "prev_insn".
6398 (get_last_insertion_point): Likewise for return type and local "insn".
6399 (get_live_on_other_edges): Likewise for local "last".
6400 (inherit_in_ebb): Likewise for params "head", "tail" and locals
6401 "prev_insn", "next_insn", "restore".
6402 (remove_inheritance_pseudos): Likewise for local "prev_insn".
6403 (undo_optional_reloads): Likewise for local "insn".
6404
6405 * lra-eliminations.c (lra_eliminate_regs_1): Likewise for param
6406 "insn".
6407 (lra_eliminate_regs): Replace NULL_RTX with NULL when referring to
6408 insns.
6409 (eliminate_regs_in_insn): Strengthen param "insn" from rtx to
6410 rtx_insn *.
6411 (spill_pseudos): Likewise for local "insn".
6412 (init_elimination): Likewise.
6413 (process_insn_for_elimination): Likewise for param "insn".
6414
6415 * lra-lives.c (curr_insn): Likewise.;
6416
6417 * lra-spills.c (assign_spill_hard_regs): Likewise for local "insn".
6418 (remove_pseudos): Likewise for param "insn".
6419 (spill_pseudos): Likewise for local "insn".
6420 (lra_final_code_change): Likewise for locals "insn", "curr".
6421
6422 * lra.c (lra_invalidate_insn_data): Likewise for param "insn".
6423 (lra_set_insn_deleted): Likewise.
6424 (lra_delete_dead_insn): Likewise, and for local "prev".
6425 (new_insn_reg): Likewise for param "insn".
6426 (lra_set_insn_recog_data): Likewise.
6427 (lra_update_insn_recog_data): Likewise.
6428 (lra_set_used_insn_alternative): Likewise.
6429 (get_insn_freq): Likewise.
6430 (invalidate_insn_data_regno_info): Likewise.
6431 (lra_invalidate_insn_regno_info): Likewise.
6432 (lra_update_insn_regno_info): Likewise.
6433 (lra_constraint_insn_stack): Strengthen from vec<rtx> to
6434 vec<rtx_insn *>.
6435 (lra_push_insn_1): Strengthen param "insn" from rtx to
6436 rtx_insn *.
6437 (lra_push_insn): Likewise.
6438 (lra_push_insn_and_update_insn_regno_info): Likewise.
6439 (lra_pop_insn): Likewise for return type and local "insn".
6440 (push_insns): Likewise for params "from", "to", and local "insn".
6441 (setup_sp_offset): Likewise for params "from", "last" and locals
6442 "before", "insn".
6443 (lra_process_new_insns): Likewise for params "insn", "before",
6444 "after" and local "last".
6445 (struct sloc): Likewise for field "insn".
6446 (lra_former_scratch_operand_p): Likewise for param "insn".
6447 (remove_scratches): Likewise for locals "insn", "last".
6448 (check_rtl): Likewise for local "insn".
6449 (add_auto_inc_notes): Likewise for param "insn".
6450 (update_inc_notes): Likewise for local "insn".
6451 (lra): Replace NULL_RTX with NULL when referring to insn.
6452
6453 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6454
6455 * lower-subreg.c (simple_move): Strengthen param "insn" from rtx
6456 to rtx_insn *.
6457 (resolve_reg_notes): Likewise.
6458 (resolve_simple_move): Likewise for return type, param "insn", and
6459 locals "insns", "minsn".
6460 (resolve_clobber): Strengthen param "insn" from rtx to rtx_insn *.
6461 (resolve_use): Likewise.
6462 (resolve_debug): Likewise.
6463 (find_decomposable_shift_zext): Likewise.
6464 (resolve_shift_zext): Likewise for return type, param "insn", and
6465 locals "insns", "in". Eliminate use of NULL_RTX in favor of NULL.
6466 (decompose_multiword_subregs): Likewise for local "insn",
6467 "orig_insn", "decomposed_shift", "end".
6468
6469 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6470
6471 * basic-block.h (basic_block split_edge_and_insert): Strengthen
6472 param "insns" from rtx to rtx_insn *.
6473
6474 * loop-unroll.c (struct iv_to_split): Strengthen field "insn" from
6475 rtx to rtx_insn *.
6476 (struct iv_to_split): Likewise.
6477 (loop_exit_at_end_p): Likewise for local "insn".
6478 (split_edge_and_insert): Likewise for param "insns".
6479 (compare_and_jump_seq): Likewise for return type, param "cinsn",
6480 and locals "seq", "jump".
6481 (unroll_loop_runtime_iterations): Likewise for locals "init_code",
6482 "branch_code"; update invocations of compare_and_jump_seq to
6483 eliminate NULL_RTX in favor of NULL.
6484 (referenced_in_one_insn_in_loop_p): Strengthen local "insn" from
6485 rtx to rtx_insn *.
6486 (reset_debug_uses_in_loop): Likewise.
6487 (analyze_insn_to_expand_var): Likewise for param "insn".
6488 (analyze_iv_to_split_insn): Likewise.
6489 (analyze_insns_in_loop): Likewise for local "insn".
6490 (insert_base_initialization): Likewise for param
6491 "insn" and local "seq".
6492 (split_iv): Likewise for param "insn" and local "seq".
6493 (expand_var_during_unrolling): Likewise for param "insn".
6494 (insert_var_expansion_initialization): Likewise for local "seq".
6495 (combine_var_copies_in_loop_exit): Likewise.
6496 (combine_var_copies_in_loop_exit): Likewise for locals "seq" and
6497 "insn".
6498 (maybe_strip_eq_note_for_split_iv): Likewise for param "insn".
6499 (apply_opt_in_copies): Likewise for locals "insn", "orig_insn",
6500 "next".
6501
6502 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6503
6504 * cfgloop.h (iv_analyze): Strengthen param 1 "insn" from rtx to
6505 rtx_insn *.
6506 (iv_analyze_result): Likewise.
6507 (iv_analyze_expr): Likewise.
6508 (biv_p): Likewise.
6509
6510 * loop-iv.c (iv_get_reaching_def): Strengthen param "insn" and
6511 local "def_insn" from rtx to rtx_insn *.
6512 (get_biv_step_1): Likewise for local "insn".
6513 (iv_analyze_expr): Likewise for param "insn".
6514 (iv_analyze_def): Likewise for local "insn".
6515 (iv_analyze_op): Likewise for param "insn".
6516 (iv_analyze): Likewise.
6517 (iv_analyze_result): Likewise.
6518 (biv_p): Likewise.
6519 (suitable_set_for_replacement): Likewise.
6520 (simplify_using_initial_values): Likewise for local "insn".
6521 (iv_number_of_iterations): Likewise for param "insn".
6522 (check_simple_exit): Add checked cast to rtx_insn when invoking
6523 iv_number_of_iterations for now (until get_condition is
6524 strengthened).
6525
6526 * loop-unroll.c (analyze_iv_to_split_insn): Strengthen param
6527 "insn" from rtx to rtx_insn *.
6528 (analyze_insns_in_loop): Likewise for local "insn".
6529
6530 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6531
6532 * loop-invariant.c (struct use): Strengthen field "insn" from rtx
6533 to rtx_insn *.
6534 (struct invariant): Likewise.
6535 (hash_invariant_expr_1): Likewise for param "insn".
6536 (invariant_expr_equal_p): Likewise for param "insn1", "insn2".
6537 (find_exits): Likewise for local "insn".
6538 (create_new_invariant): Likewise for param "insn".
6539 (check_dependencies): Likewise.
6540 (find_invariant_insn): Likewise.
6541 (record_uses): Likewise.
6542 (find_invariants_insn): Likewise.
6543 (find_invariants_bb): Likewise for local "insn".
6544 (get_pressure_class_and_nregs): Likewise for param "insn".
6545 (calculate_loop_reg_pressure): Likewise for local "insn".
6546
6547 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6548
6549 * loop-doloop.c (doloop_valid_p): Strengthen local "insn" from rtx
6550 to rtx_insn *.
6551 (add_test): Likewise for locals "seq", "jump".
6552 (doloop_modify): Likewise for locals "sequence", "jump_insn".
6553
6554 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6555
6556 * rtl.h (rebuild_jump_labels): Strengthen param "f" from rtx to
6557 rtx_insn *.
6558 (rebuild_jump_labels_chain): Likewise for param "chain".
6559
6560 * cfgexpand.c (pass_expand::execute): Add checked cast to
6561 rtx_insn * when calling rebuild_jump_labels_chain in region where
6562 we know e->insns.r is non-NULL.
6563
6564 * jump.c (rebuild_jump_labels_1): Strengthen param "f" from rtx to
6565 rtx_insn *.
6566 (rebuild_jump_labels): Likewise.
6567 (rebuild_jump_labels_chain): Likewise for param "chain".
6568 (cleanup_barriers): Likewise for locals "insn", "next", "prev".
6569 (init_label_info): Likewise for param "f".
6570 (maybe_propagate_label_ref): Likewise for params "jump_insn",
6571 "prev_nonjump_insn".
6572 (mark_all_labels): Likewise for param "f" and locals "insn",
6573 "prev_nonjump_insn".
6574
6575 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6576
6577 * ira-int.h (struct ira_allocno_copy): Strengthen field "insn"
6578 from rtx to rtx_insn *insn.
6579 (ira_create_copy): Strengthen param "insn" from rtx to rtx_insn *.
6580 (ira_add_allocno_copy): Likewise.
6581 * ira-build.c (find_allocno_copy): Strengthen param "insn" from
6582 rtx to rtx_insn *.
6583 (ira_create_copy): Likewise.
6584 (ira_add_allocno_copy): Likewise.
6585 (create_bb_allocnos): Likewise for local "insn".
6586 * ira-conflicts.c (process_regs_for_copy): Likewise for param "insn".
6587 (process_reg_shuffles): Update NULL_RTX to NULL in invocation of
6588 process_regs_for_copy for rtx_insn * param.
6589 (add_insn_allocno_copies): Strengthen param "insn" from rtx to
6590 rtx_insn *insn. Update NULL_RTX to NULL in invocation of
6591 process_regs_for_copy for rtx_insn * param.
6592 (add_copies): Strengthen local "insn" from rtx to rtx_insn *insn.
6593 * ira-costs.c (record_reg_classes): Likewise for param "insn".
6594 (record_operand_costs): Likewise.
6595 (scan_one_insn): Likewise for return type, and for param "insn".
6596 (process_bb_for_costs): Likewise for local "insn".
6597 (process_bb_node_for_hard_reg_moves): Likewise.
6598 * ira-emit.c (struct move): Likewise for field "insn".
6599 (create_move): Eliminate use of NULL_RTX when dealing with an
6600 rtx_insn *.
6601 (emit_move_list): Strengthen return type and locals "result",
6602 "insn" from rtx to rtx_insn *insn.
6603 (emit_moves): Likewise for locals "insns", "tmp".
6604 (ira_emit): Likewise for local "insn".
6605 * ira-lives.c (mark_hard_reg_early_clobbers): Likewise for param
6606 "insn".
6607 (find_call_crossed_cheap_reg): Likewise.
6608 (process_bb_node_lives): Likewise for local "insn".
6609 * ira.c (decrease_live_ranges_number): Likewise.
6610 (compute_regs_asm_clobbered): Likewise.
6611 (build_insn_chain): Likewise.
6612 (find_moveable_pseudos): Likewise, also locals "def_insn",
6613 "use_insn", "x". Also strengthen local "closest_uses" from rtx *
6614 to rtx_insn **. Add a checked cast when assigning from
6615 "closest_use" into closest_uses array in a region where we know
6616 it's a non-NULL insn.
6617 (interesting_dest_for_shprep): Strengthen param "insn" from rtx
6618 to rtx_insn *.
6619 (split_live_ranges_for_shrink_wrap): Likewise for locals "insn",
6620 "last_interesting_insn", "uin".
6621 (move_unallocated_pseudos): Likewise for locals "def_insn",
6622 "move_insn", "newinsn".
6623
6624 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6625
6626 * internal-fn.c (ubsan_expand_si_overflow_addsub_check):
6627 Strengthen locals "done_label", "do_error" from rtx to
6628 rtx_code_label *.
6629 (ubsan_expand_si_overflow_addsub_check): Strengthen local "last"
6630 from rtx to rtx_insn *. Strengthen local "sub_check from rtx to
6631 rtx_code_label *.
6632 (ubsan_expand_si_overflow_neg_check): Likewise for locals
6633 "done_label", "do_error" to rtx_code_label * and local "last" to
6634 rtx_insn *.
6635 (ubsan_expand_si_overflow_mul_check): Likewise for locals
6636 "done_label", "do_error", "large_op0", "small_op0_large_op1",
6637 "one_small_one_large", "both_ops_large", "after_hipart_neg",
6638 "after_lopart_neg", "do_overflow", "hipart_different" to
6639 rtx_code_label * and local "last" to rtx_insn *.
6640
6641 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6642
6643 * init-regs.c (initialize_uninitialized_regs): Strengthen locals
6644 "insn" and "move_insn" from rtx to rtx_insn *.
6645
6646 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6647
6648 * ifcvt.c (count_bb_insns): Strengthen local "insn" from rtx to
6649 rtx_insn *.
6650 (cheap_bb_rtx_cost_p): Likewise.
6651 (first_active_insn): Likewise for return type and local "insn".
6652 (last_active_insn): Likewise for return type and locals "insn",
6653 "head".
6654 (struct noce_if_info): Likewise for fields "jump", "insn_a",
6655 "insn_b".
6656 (end_ifcvt_sequence): Likewise for return type and locals "insn",
6657 "seq".
6658 (noce_try_move): Likewise for local "seq".
6659 (noce_try_store_flag): Likewise.
6660 (noce_try_store_flag_constants): Likewise.
6661 (noce_try_addcc): Likewise.
6662 (noce_try_store_flag_mask): Likewise.
6663 (noce_try_cmove): Likewise.
6664 (noce_try_minmax): Likewise.
6665 (noce_try_abs): Likewise.
6666 (noce_try_sign_mask): Likewise.
6667 (noce_try_bitop): Likewise.
6668 (noce_can_store_speculate_p): Likewise for local "insn".
6669 (noce_process_if_block): Likewise for locals "insn_a", "insn_b",
6670 seq".
6671 (check_cond_move_block): Likewise for local "insn".
6672 (cond_move_convert_if_block): Likewise.
6673 (cond_move_process_if_block): Likewise for locals "seq",
6674 "loc_insn".
6675 (noce_find_if_block): Likewise for local "jump".
6676 (merge_if_block): Likewise for local "last".
6677 (block_jumps_and_fallthru_p): Likewise for locals "insn", "end".
6678 (find_cond_trap): Likewise for locals "trap", "jump", "newjump".
6679 (block_has_only_trap): Likewise for return type and local "trap".
6680 (find_if_case_1): Likewise for local "jump".
6681 (dead_or_predicable): Likewise for locals "head", "end", "jump",
6682 "insn".
6683
6684 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6685
6686 * hw-doloop.h (struct hwloop_info_d): Strengthen fields
6687 "last_insn", "loop_end" from rtx to rtx_insn *.
6688
6689 * hw-doloop.c (scan_loop): Likewise for local "insn".
6690 (discover_loop): Likewise for param "tail_insn".
6691 (discover_loops): Likewise for local "tail".
6692
6693 * config/bfin/bfin.c (hwloop_optimize): For now, add a checked
6694 cast to rtx_insn * when assigning from an rtx local to a
6695 hwloop_info's "last_insn" field.
6696
6697 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6698
6699 * haifa-sched.c (bb_header): Strengthen from rtx * to rtx_insn **.
6700 (add_delay_dependencies): Strengthen local "pro" from rtx to
6701 rtx_insn *.
6702 (recompute_todo_spec): Likewise.
6703 (dep_cost_1): Likewise for locals "insn", "used".
6704 (schedule_insn): Likewise for local "dbg".
6705 (schedule_insn): Likewise for locals "pro", "next".
6706 (unschedule_insns_until): Likewise for local "con".
6707 (restore_pattern): Likewise for local "next".
6708 (estimate_insn_tick): Likewise for local "pro".
6709 (resolve_dependencies): Likewise for local "next".
6710 (fix_inter_tick): Likewise.
6711 (fix_tick_ready): Likewise for local "pro".
6712 (add_to_speculative_block): Likewise for locals "check", "twin",
6713 "pro".
6714 (sched_extend_bb): Likewise for locals "end", "insn".
6715 (init_before_recovery): Likewise for local "x".
6716 (sched_create_recovery_block): Likewise for local "barrier".
6717 (create_check_block_twin): Likewise for local "pro".
6718 (fix_recovery_deps): Likewise for locals "note", "insn", "jump",
6719 "consumer".
6720 (unlink_bb_notes): Update for change to type of bb_header.
6721 Strengthen locals "prev", "label", "note", "next" from rtx to
6722 rtx_insn *.
6723 (clear_priorities): Likewise for local "pro".
6724
6725 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6726
6727 * gcse.c (struct occr): Strengthen field "insn" from rtx to
6728 rtx_insn *.
6729 (test_insn): Likewise for this global.
6730 (oprs_unchanged_p): Strengthen param "insn" from const_rtx to
6731 const rtx_insn *.
6732 (oprs_anticipatable_p): Likewise.
6733 (oprs_available_p): Likewise.
6734 (insert_expr_in_table): Strengthen param "insn" from rtx to
6735 rtx_insn *.
6736 (hash_scan_set): Likewise.
6737 (hash_scan_clobber): Likewise.
6738 (hash_scan_call): Likewise.
6739 (hash_scan_insn): Likewise.
6740 (compute_hash_table_work): Likewise for local "insn".
6741 (process_insert_insn): Likewise for return type and local "pat".
6742 (insert_insn_end_basic_block): Likewise for locals "new_insn",
6743 "pat", "pat_end", "maybe_cc0_setter".
6744 (pre_edge_insert): Likewise for local "insn".
6745 (pre_insert_copy_insn): Likewise for param "insn".
6746 (pre_insert_copies): Likewise for local "insn".
6747 (struct set_data): Likewise for field "insn".
6748 (single_set_gcse): Likewise for param "insn".
6749 (gcse_emit_move_after): Likewise.
6750 (pre_delete): Likewise for local "insn".
6751 (update_bb_reg_pressure): Likewise for param "from" and local
6752 "insn".
6753 (should_hoist_expr_to_dom): Likewise for param "from".
6754 (hoist_code): Likewise for local "insn".
6755 (get_pressure_class_and_nregs): Likewise for param "insn".
6756 (calculate_bb_reg_pressure): Likewise for local "insn".
6757 (compute_ld_motion_mems): Likewise.
6758
6759 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6760
6761 * genpeep.c (main): Rename param back from "uncast_ins1" to
6762 "ins1", strengthening from rtx to rtx_insn *. Drop now-redundant
6763 checked cast.
6764
6765 * output.h (peephole): Strengthen param from rtx to rtx_insn *.
6766
6767 2014-08-22 Michael Meissner <meissner@linux.vnet.ibm.com>
6768
6769 PR target/62195
6770 * doc/md.texi (Machine Constraints): Update PowerPC wi constraint
6771 documentation to state it is only for VSX operations.
6772
6773 * config/rs6000/rs6000.c (rs6000_init_hard_regno_mode_ok): Make wi
6774 constraint only active if VSX.
6775
6776 * config/rs6000/rs6000.md (lfiwax): Use wj constraint instead of
6777 wi cosntraint for ISA 2.07 lxsiwax/lxsiwzx instructions.
6778 (lfiwzx): Likewise.
6779
6780 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6781
6782 * fwprop.c (single_def_use_dom_walker::before_dom_children):
6783 Strengthen local "insn" from rtx to rtx_insn *.
6784 (use_killed_between): Likewise for param "target_insn".
6785 (all_uses_available_at): Likewise for param "target_insn" and
6786 local "next".
6787 (update_df_init): Likewise for params "def_insn", "insn".
6788 (update_df): Likewise for param "insn".
6789 (try_fwprop_subst): Likewise for param "def_insn" and local
6790 "insn".
6791 (free_load_extend): Likewise for param "insn".
6792 (forward_propagate_subreg): Likewise for param "def_insn" and
6793 local "use_insn".
6794 (forward_propagate_asm): Likewise for param "def_insn" and local
6795 "use_insn".
6796 (forward_propagate_and_simplify): Likewise for param "def_insn"
6797 and local "use_insn".
6798 (forward_propagate_into): Likewise for locals "def_insn" and
6799 "use_insn".
6800
6801 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6802
6803 * function.c (emit_initial_value_sets): Strengthen local "seq"
6804 from rtx to rtx_insn *.
6805 (instantiate_virtual_regs_in_insn): Likewise for param "insn" and
6806 local "seq".
6807 (instantiate_virtual_regs): Likewise for local "insn".
6808 (assign_parm_setup_reg): Likewise for locals "linsn", "sinsn".
6809 (reorder_blocks_1): Likewise for param "insns" and local "insn".
6810 (expand_function_end): Likewise for locals "insn" and "seq".
6811 (epilogue_done): Likewise for local "insn".
6812 (thread_prologue_and_epilogue_insns): Likewise for locals "prev",
6813 "last", "trial".
6814 (reposition_prologue_and_epilogue_notes): Likewise for locals
6815 "insn", "last", "note", "first".
6816 (match_asm_constraints_1): Likewise for param "insn" and local "insns".
6817 (pass_match_asm_constraints::execute): Likewise for local "insn".
6818
6819 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6820
6821 * output.h (final_scan_insn): Strengthen return type from rtx to
6822 rtx_insn *.
6823 (final_forward_branch_p): Likewise for param.
6824 (current_output_insn): Likewise for this global.
6825
6826 * final.c (rtx debug_insn): Likewise for this variable.
6827 (current_output_insn): Likewise.
6828 (get_attr_length_1): Rename param "insn" to "uncast_insn",
6829 adding "insn" back in as an rtx_insn * with a checked cast, so
6830 that macro ADJUST_INSN_LENGTH can be passed an rtx_insn * as the
6831 first param.
6832 (compute_alignments): Strengthen local "label" from rtx to
6833 rtx_insn *.
6834 (shorten_branches): Rename param from "first" to "uncast_first",
6835 introducing a new local rtx_insn * "first" using a checked cast to
6836 effectively strengthen "first" from rtx to rtx_insn * without
6837 affecting the type signature. Strengthen locals "insn", "seq",
6838 "next", "label" from rtx to rtx_insn *.
6839 (change_scope): Strengthen param "orig_insn" and local "insn" from
6840 rtx to rtx_insn *.
6841 (final_start_function): Rename param from "first" to "uncast_first",
6842 introducing a new local rtx_insn * "first" using a checked cast to
6843 effectively strengthen "first" from rtx to rtx_insn * without
6844 affecting the type signature. Strengthen local "insn" from rtx to
6845 rtx_insn *.
6846 (dump_basic_block_info): Strengthen param "insn" from rtx to
6847 rtx_insn *.
6848 (final): Rename param from "first" to "uncast_first",
6849 introducing a new local rtx_insn * "first" using a checked cast to
6850 effectively strengthen "first" from rtx to rtx_insn * without
6851 affecting the type signature. Strengthen locals "insn", "next"
6852 from rtx to rtx_insn *.
6853 (output_alternate_entry_point): Strengthen param "insn" from rtx to
6854 rtx_insn *.
6855 (call_from_call_insn): Strengthen param "insn" from rtx to
6856 rtx_call_insn *.
6857 (final_scan_insn): Rename param from "insn" to "uncast_insn",
6858 introducing a new local rtx_insn * "insn" using a checked cast to
6859 effectively strengthen "insn" from rtx to rtx_insn * without
6860 affecting the type signature. Strengthen return type and locals
6861 "next", "note", "prev", "new_rtx" from rtx to rtx_insn *. Remove
6862 now-redundant checked cast to rtx_insn * from both invocations of
6863 debug_hooks->var_location. Convert CALL_P into a dyn_cast,
6864 introducing a local "call_insn" for use when invoking
6865 call_from_call_insn.
6866 (notice_source_line): Strengthen param "insn" from rtx to
6867 rtx_insn *.
6868 (leaf_function_p): Likewise for local "insn".
6869 (final_forward_branch_p): Likewise.
6870 (leaf_renumber_regs): Likewise for param "first".
6871 (rest_of_clean_state): Likewise for locals "insn" and "next".
6872 (self_recursive_call_p): Likewise for param "insn".
6873 (collect_fn_hard_reg_usage): Likewise for local "insn".
6874 (get_call_fndecl): Likewise for param "insn".
6875 (get_call_cgraph_rtl_info): Likewise.
6876 (get_call_reg_set_usage): Rename param from "insn" to "uncast_insn",
6877 introducing a new local rtx_insn * "insn" using a checked cast to
6878 effectively strengthen "insn" from rtx to rtx_insn * without
6879 affecting the type signature.
6880
6881 * config/arc/arc.c (arc_final_prescan_insn): For now, add checked
6882 cast when assigning from param "insn" to current_output_insn.
6883 (arc_pad_return): Strengthen local "insn" from rtx to rtx_insn *
6884 so that we can assign it back to current_output_insn.
6885
6886 2014-08-20 Pitchumani Sivanupandi <pitchumani.s@atmel.com>
6887
6888 * config/avr/avr-mcus.def: Remove atmega26hvg, atmega64rfa2,
6889 atmega48hvf, atxmega32x1, atmxt224, atmxt224e, atmxt336s,
6890 atmxt540s and atmxt540sreva devices.
6891 * config/avr/avr-tables.opt: Regenerate.
6892 * config/avr/t-multilib: Regenerate.
6893 * doc/avr-mmcu.texi: Regenerate.
6894
6895 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6896
6897 * expr.c (convert_move): Strengthen local "insns" from rtx to
6898 rtx_insn *.
6899 (emit_block_move_via_loop): Strengthen locals "cmp_label" and
6900 "top_label" from rtx to rtx_code_label *.
6901 (move_block_to_reg): Strengthen local "insn", "last" from rtx to
6902 rtx_insn *.
6903 (emit_single_push_insn): Likewise for locals "prev", "last".
6904 (store_expr): Strengthen locals "lab1", "lab2", "label" from rtx
6905 to rtx_code_label *.
6906 (store_constructor): Likewise for locals "loop_start", "loop_end".
6907 (expand_cond_expr_using_cmove): Strengthen local "seq" from rtx to
6908 rtx_insn *.
6909 (expand_expr_real_2): Likewise.
6910 (expand_expr_real_1): Strengthen local "label" from rtx to
6911 rtx_code_label *.
6912
6913 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6914
6915 * expmed.c (store_bit_field_using_insv): Strengthen local "last"
6916 from rtx to rtx_insn *.
6917 (store_bit_field_1): Likewise.
6918 (extract_bit_field_1): Likewise.
6919 (expand_mult_const): Likewise for local "insns".
6920 (expmed_mult_highpart): Strengthen local "label" from rtx to
6921 rtx_code_label *.
6922 (expand_smod_pow2): Likewise.
6923 (expand_sdiv_pow2): Likewise.
6924 (expand_divmod): Strengthen locals "last", "insn" from rtx to
6925 rtx_insn *. Strengthen locals "label", "label1", "label2",
6926 "label3", "label4", "label5", "lab" from rtx to rtx_code_label *.
6927 (emit_cstore): Strengthen local "last" from rtx to rtx_insn *.
6928 (emit_store_flag): Likewise.
6929 (emit_store_flag_force): Strengthen local "label" from rtx to
6930 rtx_code_label *.
6931 (do_cmp_and_jump): Likewise for param "label".
6932
6933 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6934
6935 * explow.c (force_reg): Strengthen local "insn" from rtx to
6936 rtx_insn *.
6937 (adjust_stack_1): Likewise.
6938 (allocate_dynamic_stack_space): Likewise. Strengthen locals
6939 "final_label", "available_label", "space_available" from rtx to
6940 rtx_code_label *.
6941 (probe_stack_range): Likewise for locals "loop_lab", "end_lab".
6942 (anti_adjust_stack_and_probe): Likewise.
6943
6944 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6945
6946 * except.h (sjlj_emit_function_exit_after): Strengthen param
6947 "after" from rtx to rtx_insn *. This is only called with
6948 result of get_last_insn (in function.c) so type-change should be
6949 self-contained.
6950
6951 * function.h (struct rtl_eh): Strengthen field "ehr_label" from
6952 rtx to rtx_code_label *, and field "sjlj_exit_after" from rtx
6953 to rtx_insn *. These fields are only used from except.c so this
6954 type-change should be self-contained to this patch.
6955
6956 * except.c (emit_to_new_bb_before): Strengthen param "seq" and
6957 local "last" from rtx to rtx_insn *.
6958 (dw2_build_landing_pads): Likewise for local "seq".
6959 (sjlj_mark_call_sites): Likewise for locals "insn", "before", p".
6960 (sjlj_emit_function_enter): Strengthen param "dispatch_label" from
6961 rtx to rtx_code_label *. Strengthen locals "fn_begin", "seq" from
6962 rtx to rtx_insn *.
6963 (sjlj_emit_function_exit_after): Strengthen param "after" from rtx
6964 to rtx_insn *.
6965 (sjlj_emit_function_exit): Likewise for locals "seq", "insn".
6966 (sjlj_emit_dispatch_table): Likewise for locals "seq", "seq2".
6967 (sjlj_build_landing_pads): Replace NULL_RTX with NULL when
6968 referring to an insn. Strengthen local "dispatch_label" from
6969 rtx to rtx_code_label *.
6970 (set_nothrow_function_flags): Strengthen local "insn" from rtx to
6971 rtx_insn *.
6972 (expand_eh_return): Strengthen local "around_label" from
6973 rtx to rtx_code_label *.
6974 (convert_to_eh_region_ranges): Strengthen locals "iter",
6975 "last_action_insn", "first_no_action_insn",
6976 "first_no_action_insn_before_switch",
6977 "last_no_action_insn_before_switch", from rtx to rtx_insn *.
6978
6979 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6980
6981 * dwarf2out.c (last_var_location_insn): Strengthen this variable
6982 from rtx to rtx_insn *.
6983 (cached_next_real_insn): Likewise.
6984 (dwarf2out_end_epilogue): Replace use of NULL_RTX with NULL when
6985 working with insns.
6986 (dwarf2out_var_location): Strengthen locals "next_real",
6987 "next_note", "expected_next_loc_note", "last_start", "insn" from
6988 rtx to rtx_insn *.
6989
6990 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6991
6992 * dwarf2cfi.c (add_cfis_to_fde): Strengthen locals "insn", "next"
6993 from rtx to rtx_insn *.
6994 (create_pseudo_cfg): Likewise for local "insn".
6995
6996 2014-08-22 David Malcolm <dmalcolm@redhat.com>
6997
6998 * df-core.c (df_bb_regno_first_def_find): Strengthen local "insn"
6999 from rtx to rtx_insn *.
7000 (df_bb_regno_last_def_find): Likewise.
7001
7002 * df-problems.c (df_rd_bb_local_compute): Likewise.
7003 (df_lr_bb_local_compute): Likewise.
7004 (df_live_bb_local_compute): Likewise.
7005 (df_chain_remove_problem): Likewise.
7006 (df_chain_create_bb): Likewise.
7007 (df_word_lr_bb_local_compute): Likewise.
7008 (df_remove_dead_eq_notes): Likewise for param "insn".
7009 (df_note_bb_compute): Likewise for local "insn".
7010 (simulate_backwards_to_point): Likewise.
7011 (df_md_bb_local_compute): Likewise.
7012
7013 * df-scan.c (df_scan_free_bb_info): Likewise.
7014 (df_scan_start_dump): Likewise.
7015 (df_scan_start_block): Likewise.
7016 (df_install_ref_incremental): Likewise for local "insn".
7017 (df_insn_rescan_all): Likewise.
7018 (df_reorganize_refs_by_reg_by_insn): Likewise.
7019 (df_reorganize_refs_by_insn_bb): Likewise.
7020 (df_recompute_luids): Likewise.
7021 (df_bb_refs_record): Likewise.
7022 (df_update_entry_exit_and_calls): Likewise.
7023 (df_bb_verify): Likewise.
7024
7025 2014-08-22 David Malcolm <dmalcolm@redhat.com>
7026
7027 * ddg.h (struct ddg_node): Strengthen fields "insn" and
7028 "first_note" from rtx to rtx_insn *.
7029 (get_node_of_insn): Likewise for param 2 "insn".
7030 (autoinc_var_is_used_p): Likewise for params "def_insn" and "use_insn".
7031
7032 * ddg.c (mem_read_insn_p): Strengthen param "insn" from rtx to
7033 rtx_insn *.
7034 (mem_write_insn_p): Likewise.
7035 (mem_access_insn_p): Likewise.
7036 (autoinc_var_is_used_p): Likewise for params "def_insn" and "use_insn".
7037 (def_has_ccmode_p): Likewise for param "insn".
7038 (add_cross_iteration_register_deps): Likewise for locals
7039 "def_insn" and "use_insn".
7040 (insns_may_alias_p): Likewise for params "insn1" and "insn2".
7041 (build_intra_loop_deps): Likewise for local "src_insn".
7042 (create_ddg): Strengthen locals "insn" and "first_note" from rtx
7043 to rtx_insn *.
7044 (get_node_of_insn): Likewise for param "insn".
7045
7046 2014-08-22 David Malcolm <dmalcolm@redhat.com>
7047
7048 * dce.c (worklist): Strengthen from vec<rtx> to vec<rtx_insn *>.
7049 (deletable_insn_p): Strengthen param "insn" from rtx to
7050 rtx_insn *. Add checked cast to rtx_call_insn when invoking
7051 find_call_stack_args, since this is guarded by CALL_P (insn).
7052 (marked_insn_p): Strengthen param "insn" from rtx to
7053 rtx_insn *.
7054 (mark_insn): Likewise. Add checked cast to rtx_call_insn when
7055 invoking find_call_stack_args, since this is guarded by
7056 CALL_P (insn).
7057 (mark_nonreg_stores_1): Strengthen cast of "data" from rtx to
7058 rtx_insn *; we know this is an insn since this was called by
7059 mark_nonreg_stores.
7060 (mark_nonreg_stores_2): Likewise.
7061 (mark_nonreg_stores): Strengthen param "insn" from rtx to
7062 rtx_insn *.
7063 (find_call_stack_args): Strengthen param "call_insn" from rtx to
7064 rtx_call_insn *; strengthen locals "insn" and "prev_insn" from rtx
7065 to rtx_insn *.
7066 (remove_reg_equal_equiv_notes_for_defs): Strengthen param "insn"
7067 from rtx to rtx_insn *.
7068 (reset_unmarked_insns_debug_uses): Likewise for locals "insn",
7069 "next", "ref_insn".
7070 (delete_unmarked_insns): Likewise for locals "insn", "next".
7071 (prescan_insns_for_dce): Likewise for locals "insn", "prev".
7072 (mark_reg_dependencies): Likewise for param "insn".
7073 (rest_of_handle_ud_dce): Likewise for local "insn".
7074 (word_dce_process_block): Likewise.
7075 (dce_process_block): Likewise.
7076
7077 2014-08-22 David Malcolm <dmalcolm@redhat.com>
7078
7079 * cse.c (struct qty_table_elem): Strengthen field "const_insn"
7080 from rtx to rtx_insn *.
7081 (struct change_cc_mode_args): Likewise for field "insn".
7082 (this_insn): Strengthen from rtx to rtx_insn *.
7083 (make_new_qty): Replace use of NULL_RTX with NULL when dealing
7084 with insn.
7085 (validate_canon_reg): Strengthen param "insn" from rtx to
7086 rtx_insn *.
7087 (canon_reg): Likewise.
7088 (fold_rtx): Likewise. Replace use of NULL_RTX with NULL when
7089 dealing with insn.
7090 (record_jump_equiv): Strengthen param "insn" from rtx to
7091 rtx_insn *.
7092 (try_back_substitute_reg): Likewise, also for locals "prev",
7093 "bb_head".
7094 (find_sets_in_insn): Likewise for param "insn".
7095 (canonicalize_insn): Likewise.
7096 (cse_insn): Likewise. Add a checked cast.
7097 (invalidate_from_clobbers): Likewise for param "insn".
7098 (invalidate_from_sets_and_clobbers): Likewise.
7099 (cse_process_notes_1): Replace use of NULL_RTX with NULL when
7100 dealing with insn.
7101 (cse_prescan_path): Strengthen local "insn" from rtx to
7102 rtx_insn *.
7103 (cse_extended_basic_block): Likewise for locals "insn" and
7104 "prev_insn".
7105 (cse_main): Likewise for param "f".
7106 (check_for_label_ref): Likewise for local "insn".
7107 (set_live_p): Likewise for second param ("insn").
7108 (insn_live_p): Likewise for first param ("insn") and for local
7109 "next".
7110 (cse_change_cc_mode_insn): Likewise for first param "insn".
7111 (cse_change_cc_mode_insns): Likewise for first and second params
7112 "start" and "end".
7113 (cse_cc_succs): Likewise for locals "insns", "last_insns", "insn"
7114 and "end".
7115 (cse_condition_code_reg): Likewise for locals "last_insn", "insn",
7116 "cc_src_insn".
7117
7118 2014-08-22 Alexander Ivchenko <alexander.ivchenko@intel.com>
7119 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
7120 Anna Tikhonova <anna.tikhonova@intel.com>
7121 Ilya Tocar <ilya.tocar@intel.com>
7122 Andrey Turetskiy <andrey.turetskiy@intel.com>
7123 Ilya Verbin <ilya.verbin@intel.com>
7124 Kirill Yukhin <kirill.yukhin@intel.com>
7125 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
7126
7127 * config/i386/subst.md (define_subst_attr "mask_avx512bw_condition"):
7128 New.
7129 * config/i386/sse.md
7130 (define_mode_iterator VI248_AVX2): Delete.
7131 (define_mode_iterator VI2_AVX2_AVX512BW): New.
7132 (define_mode_iterator VI48_AVX2): Ditto.
7133 (define_insn <shift_insn><mode>3): Delete.
7134 (define_insn "<shift_insn><mode>3<mask_name>" with
7135 VI2_AVX2_AVX512BW): New.
7136 (define_insn "<shift_insn><mode>3<mask_name>" with
7137 VI48_AVX2): Ditto.
7138
7139 2014-08-22 Alexander Ivchenko <alexander.ivchenko@intel.com>
7140 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
7141 Anna Tikhonova <anna.tikhonova@intel.com>
7142 Ilya Tocar <ilya.tocar@intel.com>
7143 Andrey Turetskiy <andrey.turetskiy@intel.com>
7144 Ilya Verbin <ilya.verbin@intel.com>
7145 Kirill Yukhin <kirill.yukhin@intel.com>
7146 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
7147
7148 * config/i386/sse.md
7149 (define_mode_iterator VI4F_BRCST32x2): New.
7150 (define_mode_attr 64x2_mode): Ditto.
7151 (define_mode_attr 32x2mode): Ditto.
7152 (define_insn "<mask_codefor>avx512dq_broadcast<mode><mask_name>"
7153 with VI4F_BRCST32x2): Ditto.
7154 (define_insn "<mask_codefor>avx512vl_broadcast<mode><mask_name>_1"
7155 with V16FI mode iterator): Ditto.
7156 (define_insn "<mask_codefor>avx512dq_broadcast<mode><mask_name>_1"
7157 with V16FI): Ditto.
7158 (define_insn "<mask_codefor>avx512dq_broadcast<mode><mask_name>_1"
7159 with VI8F_BRCST64x2): Ditto.
7160
7161 2014-08-22 Alexander Ivchenko <alexander.ivchenko@intel.com>
7162 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
7163 Anna Tikhonova <anna.tikhonova@intel.com>
7164 Ilya Tocar <ilya.tocar@intel.com>
7165 Andrey Turetskiy <andrey.turetskiy@intel.com>
7166 Ilya Verbin <ilya.verbin@intel.com>
7167 Kirill Yukhin <kirill.yukhin@intel.com>
7168 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
7169
7170 * config/i386/sse.md
7171 (define_mode_iterator VI8_AVX512VL): New.
7172 (define_insn "avx512cd_maskb_vec_dup<mode>"): Macroize.
7173
7174 2014-08-22 Kirill Yukhin <kirill.yukhin@intel.com>
7175
7176 * gcc/config/i386/sse.md (define_mode_iterator V_AVX512VL): Delete.
7177 (define_mode_iterator V48_AVX512VL): New.
7178 (define_mode_iterator V12_AVX512VL): Ditto.
7179 (define_insn <avx512>_load<mode>_mask): Split into two similar
7180 patterns which use different mode iterators: V48_AVX512VL V12_AVX512VL.
7181 Refactor output template.
7182 (define_insn "<avx512>_store<mode>_mask"): Ditto.
7183
7184 2014-08-22 David Malcolm <dmalcolm@redhat.com>
7185
7186 * cprop.c (struct occr): Strengthen field "insn" from rtx to
7187 rtx_insn *.
7188 (reg_available_p): Likewise for param "insn".
7189 (insert_set_in_table): Likewise.
7190 (hash_scan_set): Likewise.
7191 (hash_scan_insn): Likewise.
7192 (make_set_regs_unavailable): Likewise.
7193 (compute_hash_table_work): Likewise for local "insn".
7194 (reg_not_set_p): Strengthen param "insn" from const_rtx to
7195 const rtx_insn *.
7196 (mark_oprs_set): Strengthen param "insn" from rtx to rtx_insn *.
7197 (try_replace_reg): Likewise.
7198 (find_avail_set): Likewise.
7199 (cprop_jump): Likewise for params "setcc", "jump".
7200 (constprop_register): Likewise for param "insn".
7201 (cprop_insn): Likewise.
7202 (do_local_cprop): Likewise.
7203 (local_cprop_pass): Likewise for local "insn".
7204 (bypass_block): Likewise for params "setcc" and "jump".
7205 (bypass_conditional_jumps): Likewise for locals "setcc" and
7206 "insn".
7207 (one_cprop_pass): Likewise for local "insn".
7208
7209 2014-08-22 David Malcolm <dmalcolm@redhat.com>
7210
7211 * compare-elim.c (struct comparison_use): Strengthen field "insn"
7212 from rtx to rtx_insn *.
7213 (struct comparison): Likewise, also for field "prev_clobber".
7214 (conforming_compare): Likewise for param "insn".
7215 (arithmetic_flags_clobber_p): Likewise.
7216 (find_flags_uses_in_insn): Likewise.
7217 (find_comparison_dom_walker::before_dom_children): Likewise for
7218 locals "insn", "next", "last_clobber".
7219 (try_eliminate_compare): Likewise for locals "insn", "bb_head".
7220
7221 2014-08-22 David Malcolm <dmalcolm@redhat.com>
7222
7223 * combine-stack-adj.c (struct csa_reflist): Strengthen field
7224 "insn" from rtx to rtx_insn *.
7225 (single_set_for_csa): Likewise for param "insn".
7226 (record_one_stack_ref): Likewise.
7227 (try_apply_stack_adjustment): Likewise.
7228 (struct record_stack_refs_data): Likewise for field "insn".
7229 (maybe_move_args_size_note): Likewise for params "last" and "insn".
7230 (prev_active_insn_bb): Likewise for return type and param "insn".
7231 (next_active_insn_bb): Likewise.
7232 (force_move_args_size_note): Likewise for params "prev" and "last"
7233 and locals "test", "next_candidate", "prev_candidate".
7234 (combine_stack_adjustments_for_block): Strengthen locals
7235 "last_sp_set", "last2_sp_set", "insn", "next" from rtx to
7236 rtx_insn *.
7237
7238 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7239
7240 * combine.c (i2mod): Strengthen this variable from rtx to rtx_insn *.
7241 (struct reg_stat_struct): Likewise for fields "last_death", "last_set".
7242 (subst_insn): Likewise for this variable.
7243 (added_links_insn): Likewise.
7244 (struct insn_link): Likewise for field "insn".
7245 (alloc_insn_link): Likewise for param "insn".
7246 (struct undobuf): Likewise for field "other_insn".
7247 (find_single_use): Likewise for param "insn" and local "next".
7248 (combine_validate_cost): Likewise for params "i0", "i1", "i2", "i3".
7249 (delete_noop_moves): Likewise for locals "insn", "next".
7250 (create_log_links): Likewise for locals "insn", "use_insn".
7251 Strengthen local "next_use" from rtx * to rtx_insn **.
7252 (insn_a_feeds_b): Likewise for params "a", "b".
7253 (combine_instructions): Likewise for param "f" and locals "insn",
7254 "next", "prev", "first", "last_combined_insn", "link", "link1",
7255 "temp". Replace use of NULL_RTX with NULL when referring to
7256 insns.
7257 (setup_incoming_promotions): Likewise for param "first"
7258 (set_nonzero_bits_and_sign_copies): Likewise for local "insn".
7259 (can_combine_p): Likewise for params "insn", "i3", "pred",
7260 "pred2", "succ", "succ2" and for local "p".
7261 (combinable_i3pat): Likewise for param "i3".
7262 (cant_combine_insn_p): Likewise for param "insn".
7263 (likely_spilled_retval_p): Likewise.
7264 (adjust_for_new_dest): Likewise.
7265 (update_cfg_for_uncondjump): Likewise, also for local "insn".
7266 (try_combine): Likewise for return type and for params "i3", "i2",
7267 "i1", "i0", "last_combined_insn", and for locals "insn",
7268 "cc_use_insn", "p", "first", "last", "i2_insn", "i1_insn",
7269 "i0_insn". Eliminate local "tem" in favor of new locals
7270 "tem_note" and "tem_insn", the latter being an rtx_insn *. Add a
7271 checked cast for now to rtx_insn * on the return type of
7272 gen_rtx_INSN. Replace use of NULL_RTX with NULL when referring to
7273 insns.
7274 (find_split_point): Strengthen param "insn" from rtx to
7275 rtx_insn *.
7276 (simplify_set): Likewise for local "other_insn".
7277 (recog_for_combine): Likewise for param "insn".
7278 (record_value_for_reg): Likewise.
7279 (record_dead_and_set_regs_1): Likewise for local
7280 "record_dead_insn".
7281 (record_dead_and_set_regs): Likewise for param "insn".
7282 (record_promoted_value): Likewise.
7283 (check_promoted_subreg): Likewise.
7284 (get_last_value_validate): Likewise.
7285 (reg_dead_at_p): Likewise.
7286 (move_deaths): Likewise for param "to_insn".
7287 (distribute_notes): Likewise for params "from_insn", "i3", "i2"
7288 and locals "place", "place2", "cc0_setter". Eliminate local "tem
7289 in favor of new locals "tem_note" and "tem_insn", the latter being
7290 an rtx_insn *.
7291 (distribute_links): Strengthen locals "place", "insn" from rtx to
7292 rtx_insn *.
7293
7294 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7295
7296 * cfgrtl.c (can_delete_note_p): Require a const rtx_note * rather
7297 than a const_rtx.
7298 (can_delete_label_p): Require a const rtx_code_label * rather than
7299 a const_rtx.
7300 (delete_insn): Add checked cast to rtx_code_label * when we know
7301 we're dealing with LABEL_P (insn). Strengthen local "bb_note" from
7302 rtx to rtx_insn *.
7303 (delete_insn_chain): Strengthen locals "prev" and "current" from
7304 rtx to rtx_insn *. Add a checked cast when assigning from
7305 "finish" (strengthening the params will come later). Add a
7306 checked cast to rtx_note * in region where we know
7307 NOTE_P (current).
7308 (rtl_delete_block): Strengthen locals "insn" and "end" from rtx to
7309 rtx_insn *.
7310 (compute_bb_for_insn): Likewise.
7311 (free_bb_for_insn): Likewise for local "insn".
7312 (compute_bb_for_insn): Likewise.
7313 (update_bb_for_insn_chain): Strengthen params "begin", "end" and
7314 local "insn" from rtx to rtx_insn *
7315 (flow_active_insn_p): Require a const rtx_insn * rather than a
7316 const_rtx.
7317 (contains_no_active_insn_p): Strengthen local "insn" from rtx to
7318 rtx_insn *.
7319 (can_fallthru): Likewise for locals "insn" and "insn2".
7320 (bb_note): Likewise for local "note".
7321 (first_insn_after_basic_block_note): Likewise for local "note" and
7322 for return type.
7323 (rtl_split_block): Likewise for locals "insn" and "next".
7324 (unique_locus_on_edge_between_p): Likewise for locals "insn" and
7325 "end".
7326 (rtl_merge_blocks): Likewise for locals "b_head", "b_end",
7327 "a_end", "del_first", "del_last", "b_debug_start", "b_debug_end",
7328 "prev", "tmp".
7329 (try_redirect_by_replacing_jump): Likewise for locals "insn" (both of
7330 them), "kill_from", "barrier", "new_insn".
7331 (patch_jump_insn): Likewise for params "insn", "old_label".
7332 (redirect_branch_edge): Likewise for locals "old_label", "insn".
7333 (force_nonfallthru_and_redirect): Likewise for locals "insn",
7334 "old_label", "new_label".
7335 (rtl_tidy_fallthru_edge): Likewise for local "q".
7336 (rtl_split_edge): Likewise for locals "before", "last".
7337 (commit_one_edge_insertion): Likewise for locals "before",
7338 "after", "insns", "tmp", "last", adding a checked cast where
7339 currently necessary.
7340 (commit_edge_insertions): Likewise.
7341 (rtl_dump_bb): Likewise for locals "insn", "last".
7342 (print_rtl_with_bb): Likewise for local "x".
7343 (rtl_verify_bb_insns): Likewise for local "x".
7344 (rtl_verify_bb_pointers): Likewise for local "insn".
7345 (rtl_verify_bb_insn_chain): Likewise for locals "x", "last_head",
7346 "head", "end".
7347 (rtl_verify_fallthru): Likewise for local "insn".
7348 (rtl_verify_bb_layout): Likewise for locals "x" and "rtx_first".
7349 (purge_dead_edges): Likewise for local "insn".
7350 (fixup_abnormal_edges): Likewise for locals "insn", "stop", "next".
7351 (skip_insns_after_block): Likewise for return type and for locals
7352 "insn", "last_insn", "next_head", "prev".
7353 (record_effective_endpoints): Likewise for locals "next_insn",
7354 "insn", "end".
7355 (fixup_reorder_chain): Likewise for locals "bb_end_insn" and "end".
7356 (verify_insn_chain): Likewise for locals "x", "prevx", "nextx".
7357 (cfg_layout_can_duplicate_bb_p): Likewise for local "insn".
7358 (duplicate_insn_chain): For now, add checked cast from rtx to
7359 rtx_insn * when returning insn.
7360 (cfg_layout_duplicate_bb): Likewise for local "insn".
7361 (cfg_layout_delete_block): Likewise for locals "insn", "next",
7362 "prev", "remaints".
7363 (cfg_layout_merge_blocks): Likewise for local "insn", "last".
7364 (rtl_block_empty_p): Likewise.
7365 (rtl_split_block_before_cond_jump): Likewise for locals "insn",
7366 "split_point", "last".
7367 (rtl_block_ends_with_call_p): Likewise for local "insn".
7368 (need_fake_edge_p): Strengthen param "insn" from const_rtx to
7369 const rtx_insn *.
7370 (rtl_flow_call_edges_add): Strengthen locals "insn", "prev_insn",
7371 "split_at_insn" from rtx to rtx_insn *.
7372 (rtl_lv_add_condition_to_bb): Likewise for locals "seq", "jump".
7373 (rtl_can_remove_branch_p): Strengthen local "insn" from const_rtx
7374 to const rtx_insn *.
7375 (rtl_account_profile_record): Likewise.
7376
7377 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7378
7379 * cfgloopanal.c (num_loop_insns): Strengthen local "insn" from
7380 rtx to rtx_insn *.
7381 (average_num_loop_insns): Likewise.
7382 (init_set_costs): Likewise for local "seq".
7383 (seq_cost): Likewise for param "seq", from const_rtx to const
7384 rtx_insn *.
7385
7386 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7387
7388 * cfgloop.c (loop_exits_from_bb_p): Strengthen local "insn" from
7389 rtx to rtx_insn *.
7390
7391 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7392
7393 * basic-block.h (flow_find_cross_jump): Strengthen params 3 and 4
7394 "f1" and "f2" from rtx * to rtx_insn **.
7395 (flow_find_head_matching_sequence): Likewise.
7396
7397 * cfgcleanup.c (try_simplify_condjump): Strengthen local
7398 "cbranch_insn" from rtx to rtx_insn *.
7399 (thread_jump): Likewise for local "insn".
7400 (try_forward_edges): Likewise for local "last".
7401 (merge_blocks_move_predecessor_nojumps): Likewise for local "barrier".
7402 (merge_blocks_move_successor_nojumps): Likewise for locals "barrier",
7403 "real_b_end".
7404 (can_replace_by): Likewise for params "i1", "i2".
7405 (old_insns_match_p): Likewise.
7406 (merge_notes): Likewise.
7407 (walk_to_nondebug_insn): Likewise for param "i1".
7408 (flow_find_cross_jump): Strengthen params "f1" and "f2" from rtx *
7409 to rtx_insn **. Strengthen locals "i1", "i2", "last1", "last2",
7410 "afterlast1", "afterlast2" from rtx to rtx_insn *.
7411 (flow_find_head_matching_sequence): Strengthen params "f1" and
7412 "f2" from rtx * to rtx_insn **. Strengthen locals "i1", "i2",
7413 "last1", "last2", "beforelast1", "beforelast2" from rtx to
7414 rtx_insn *.
7415 (outgoing_edges_match): Likewise for locals "last1", "last2".
7416 (try_crossjump_to_edge): Likewise for local "insn".
7417 Replace call to for_each_rtx with for_each_rtx_in_insn.
7418
7419 (try_crossjump_to_edge): Likewise for locals "newpos1", "newpos2".
7420 (try_head_merge_bb): Likewise for locals "e0_last_head_, "jump",
7421 "e0_last", "e_last", "head", "curr", "insn". Strengthen locals
7422 "headptr", "currptr", "nextptr" from rtx * to rtx_insn **.
7423 (try_optimize_cfg): Strengthen local "last" from rtx to
7424 rtx_insn *.
7425 (delete_dead_jumptables): Likewise for locals "insn", "next",
7426 "label".
7427
7428 * ifcvt.c (cond_exec_process_if_block): Likewise for locals
7429 "rtx then_last_head", "rtx else_last_head", "rtx then_first_tail",
7430 "rtx else_first_tail", to reflect the basic-block.h changes above.
7431
7432 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7433
7434 * cfgbuild.c (make_edges): Strengthen local "insn" from rtx to
7435 rtx_insn *.
7436 (purge_dead_tablejump_edges): Likewise.
7437 (find_bb_boundaries): Likewise for locals "insn", "end",
7438 "flow_transfer_insn".
7439
7440 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7441
7442 * caller-save.c (save_call_clobbered_regs): Strengthen locals
7443 "ins" and "prev" from rtx to rtx_insn *.
7444
7445 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7446
7447 * calls.c (emit_call_1): Strengthen local "call_insn" from rtx to
7448 rtx_insn *.
7449 (internal_arg_pointer_exp_state): Likewise for field "scan_start".
7450 (internal_arg_pointer_based_exp_scan): Likewise for locals "insn",
7451 "scan_start".
7452 (load_register_parameters): Likewise for local "before_arg".
7453 (check_sibcall_argument_overlap): Likewise for param "insn".
7454 (expand_call): Likewise for locals "normal_call_insns",
7455 "tail_call_insns", "insns", "before_call", "after_args",
7456 "before_arg", "last", "prev". Strengthen one of the "last" from
7457 rtx to rtx_call_insn *.
7458 (fixup_tail_calls): Strengthen local "insn" from rtx to
7459 rtx_insn *.
7460 (emit_library_call_value_1): Likewise for locals "before_call" and
7461 "last".
7462
7463 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7464
7465 * builtins.c (expand_builtin_longjmp): Strengthen locals "insn"
7466 and "last" from rtx to rtx_insn *.
7467 (expand_builtin_nonlocal_goto): Likewise for local "insn".
7468 (expand_builtin_apply): Strengthen local "call_insn" from rtx to
7469 rtx_call_insn *.
7470 (expand_errno_check): Strengthen local "lab" from rtx to
7471 rtx_code_label *.
7472 (expand_builtin_mathfn): Strengthen local "insns" from rtx to
7473 rtx_insn *.
7474 (expand_builtin_mathfn_2): Likewise.
7475 (expand_builtin_mathfn_ternary): Likewise.
7476 (expand_builtin_mathfn_3): Likewise.
7477 (expand_builtin_interclass_mathfn): Likewise for local "last".
7478 (expand_builtin_int_roundingfn): Likewise for local "insns".
7479 (expand_builtin_int_roundingfn_2): Likewise.
7480 (expand_builtin_strlen): Likewise for local "before_strlen".
7481 (expand_builtin_strncmp): Likewise for local "seq".
7482 (expand_builtin_signbit): Likewise for local "last".
7483 (expand_builtin_atomic_compare_exchange): Strengthen local "label"
7484 from rtx to rtx_code_label *.
7485 (expand_stack_restore): Strengthen local "prev" from rtx to
7486 rtx_insn *.
7487
7488 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7489
7490 * bt-load.c (struct btr_user_s): Strengthen field "insn" from rtx
7491 to rtx_insn *.
7492 (struct btr_def_s): Likewise.
7493 (insn_sets_btr_p): Strengthen param "insn" from const_rtx to
7494 const rtx_insn *.
7495 (add_btr_def): Likewise.
7496 (new_btr_user): Likewise.
7497 (compute_defs_uses_and_gen): Strengthen locals "insn", "last" from
7498 rtx to rtx_insn *.
7499 (link_btr_uses): Likewise.
7500 (move_btr_def): Likewise for locals "insp", "old_insn",
7501 "new_insn". Add checked cast to rtx_insn * for now on result of
7502 gen_move_insn.
7503 (can_move_up): Strengthen param "insn" from const_rtx to
7504 const rtx_insn *.
7505
7506 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7507
7508 * bb-reorder.c (copy_bb_p): Strengthen local "insn" from rtx to
7509 rtx_insn *.
7510 (get_uncond_jump_length): Likewise for locals "label", "jump".
7511 (fix_up_crossing_landing_pad): Likewise for locals "new_label",
7512 "jump", "insn".
7513 (add_labels_and_missing_jumps): Likewise for local "new_jump".
7514 (fix_up_fall_thru_edges): Likewise for local "old_jump".
7515 (find_jump_block): Likewise for local "insn".
7516 (fix_crossing_conditional_branches): Likewise for locals
7517 "old_jump", "new_jump".
7518 (fix_crossing_unconditional_branches): Likewise for locals
7519 "last_insn", "indirect_jump_sequence", "jump_insn", "cur_insn".
7520 (pass_duplicate_computed_gotos::execute): Likewise for local "insn".
7521
7522 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7523
7524 * auto-inc-dec.c (struct inc_insn): Strengthen field "insn" from
7525 rtx to rtx_insn *.
7526 (struct mem_insn): Likewise for field "insn".
7527 (reg_next_use): Strengthen from rtx * to rtx_insn **.
7528 (reg_next_inc_use): Likewise.
7529 (reg_next_def): Likewise.
7530 (move_dead_notes): Strengthen params "to_insn" and "from_insn"
7531 from rtx to rtx_insn *.
7532 (move_insn_before): Likewise for param "next_insn" and local "insns".
7533 (attempt_change): Likewise for local "mov_insn".
7534 (try_merge): Likewise for param "last_insn".
7535 (get_next_ref): Likewise for return type and local "insn".
7536 Strengthen param "next_array" from rtx * to rtx_insn **.
7537 (parse_add_or_inc): Strengthen param "insn" from rtx to
7538 rtx_insn *.
7539 (find_inc): Likewise for locals "insn" and "other_insn" (three of
7540 the latter).
7541 (merge_in_block): Likewise for locals "insn", "curr",
7542 "other_insn".
7543 (pass_inc_dec::execute): Update allocations of the arrays to
7544 reflect the stronger types.
7545
7546 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7547
7548 * asan.c (asan_clear_shadow): Strengthen locals "insn", "insns"
7549 and "jump" from rtx to rtx_insn *. Strengthen local "top_label"
7550 from rtx to rtx_code_label *.
7551
7552 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7553
7554 * alias.c (init_alias_analysis): Strengthen local "insn" from rtx
7555 to rtx_insn *.
7556
7557 2014-08-21 Michael Meissner <meissner@linux.vnet.ibm.com>
7558
7559 * config/rs6000/rs6000.c (print_operand, 'y' case): Fix code that
7560 generated a warning and prevented bootstrapping the compiler.
7561
7562 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7563
7564 * rtl.h (delete_related_insns): Strengthen return type from rtx to
7565 rtx_insn *.
7566
7567 * jump.c (delete_related_insns): Likewise, also for locals "next"
7568 and "prev".
7569
7570 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7571
7572 * genautomata.c (output_internal_insn_latency_func): When writing
7573 the function "internal_insn_latency" to insn-automata.c,
7574 strengthen params "insn" and "insn2" from rtx to rtx_insn *, thus
7575 allowing the optional guard function of (define_bypass) clauses to
7576 expect a pair of rtx_insn *, rather than a pair of rtx.
7577 (output_insn_latency_func): When writing the function
7578 "insn_latency", add an "uncast_" prefix to params "insn" and
7579 "insn2", reintroducing "insn" and "insn2" as rtx_insn * locals
7580 using checked casts from the params, thus enabling the above
7581 change to the generated "internal_insn_latency" function.
7582
7583 2014-08-21 Jan Hubicka <hubicka@ucw.cz>
7584
7585 PR tree-optimization/62091
7586 * ipa-devirt.c (ipa_polymorphic_call_context::restrict_to_inner_type):
7587 handle correctly arrays.
7588 (extr_type_from_vtbl_ptr_store): Add debug output; handle multiple
7589 inheritance binfos.
7590 (record_known_type): Walk into inner type.
7591 (ipa_polymorphic_call_context::get_dynamic_type): Likewise; strenghten
7592 condition on no type changes.
7593
7594 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7595
7596 * genattrtab.c (write_attr_get): Within the generated get_attr_
7597 functions, rename param "insn" to "uncast_insn" and reintroduce
7598 "insn" as an local rtx_insn * using a checked cast, so that "insn"
7599 is an rtx_insn * within insn-attrtab.c
7600
7601 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7602
7603 * output.h (peephole): Strengthen return type from rtx to
7604 rtx_insn *.
7605 * rtl.h (delete_for_peephole): Likewise for both params.
7606 * genpeep.c (main): In generated "peephole" function, strengthen
7607 return type and local "insn" from rtx to rtx_insn *. For now,
7608 rename param "ins1" to "uncast_ins1", adding "ins1" back as an
7609 rtx_insn *, with a checked cast.
7610 * jump.c (delete_for_peephole): Strengthen params "from", "to" and
7611 locals "insn", "next", "prev" from rtx to rtx_insn *.
7612
7613 2014-08-21 Marc Glisse <marc.glisse@inria.fr>
7614
7615 PR tree-optimization/62112
7616 * gimple-iterator.c (gsi_replace): Return whether EH cleanup is needed.
7617 * gimple-iterator.h (gsi_replace): Return bool.
7618 * tree-ssa-alias.c (ref_may_alias_global_p_1): New helper, code
7619 moved from ref_may_alias_global_p.
7620 (ref_may_alias_global_p, refs_may_alias_p, ref_maybe_used_by_stmt_p):
7621 New overloads.
7622 (ref_maybe_used_by_call_p): Take ao_ref* instead of tree.
7623 (stmt_kills_ref_p_1): Rename...
7624 (stmt_kills_ref_p): ... to this.
7625 * tree-ssa-alias.h (ref_may_alias_global_p, ref_maybe_used_by_stmt_p,
7626 stmt_kills_ref_p): Declare.
7627 * tree-ssa-dse.c (dse_possible_dead_store_p): New argument, use it.
7628 Move the self-assignment case...
7629 (dse_optimize_stmt): ... here. Handle builtin calls. Remove dead code.
7630
7631 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7632
7633 * rtl.h (try_split): Strengthen return type from rtx to rtx_insn *.
7634
7635 * emit-rtl.c (try_split): Likewise, also for locals "before" and
7636 "after". For now, don't strengthen param "trial", which requires
7637 adding checked casts when returning it.
7638
7639 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7640
7641 * debug.h (struct gcc_debug_hooks): Strengthen param 1 of hook
7642 "label" from rtx to rtx_code_label *. Strengthen param 1 of
7643 "var_location" hook from rtx to rtx_insn *.
7644 (debug_nothing_rtx): Delete in favor of...
7645 (debug_nothing_rtx_code_label): New prototype.
7646 (debug_nothing_rtx_rtx): Delete unused prototype.
7647 (debug_nothing_rtx_insn): New prototype.
7648
7649 * final.c (final_scan_insn): Add checked cast to rtx_insn * when
7650 invoking debug_hooks->var_location (in two places, one in a NOTE
7651 case of a switch statement, the other guarded by a CALL_P
7652 conditional. Add checked cast to rtx_code_label * when invoking
7653 debug_hooks->label (within CODE_LABEL case of switch statement).
7654
7655 * dbxout.c (dbx_debug_hooks): Update "label" hook from
7656 debug_nothing_rtx to debug_nothing_rtx_code_label. Update
7657 "var_location" from debug_nothing_rtx to debug_nothing_rtx_insn.
7658 (xcoff_debug_hooks): Likewise.
7659 * debug.c (do_nothing_debug_hooks): Likewise.
7660 (debug_nothing_rtx): Delete in favor of...
7661 (debug_nothing_rtx_insn): New function.
7662 (debug_nothing_rtx_rtx): Delete unused function.
7663 (debug_nothing_rtx_code_label): New function.
7664 * dwarf2out.c (dwarf2_debug_hooks): Update "label" hook from
7665 debug_nothing_rtx to debug_nothing_rtx_code_label.
7666 (dwarf2out_var_location): Strengthen param "loc_note" from rtx
7667 to rtx_insn *.
7668 * sdbout.c (sdb_debug_hooks): Update "var_location" hook from
7669 debug_nothing_rtx to debug_nothing_rtx_insn.
7670 (sdbout_label): Strengthen param "insn" from rtx to
7671 rtx_code_label *.
7672 * vmsdbgout.c (vmsdbg_debug_hooks): Update "label" hook from
7673 debug_nothing_rtx to debug_nothing_rtx_code_label. Update
7674 "var_location" hook from debug_nothing_rtx to
7675 debug_nothing_rtx_insn.
7676
7677 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7678
7679 * recog.h (insn_output_fn): Update this function typedef to match
7680 the changes below to the generated output functions, strengthening
7681 the 2nd param from rtx to rtx_insn *.
7682
7683 * final.c (get_insn_template): Add a checked cast to rtx_insn * on
7684 insn when invoking an output function, to match the new signature
7685 of insn_output_fn with a stronger second param.
7686
7687 * genconditions.c (write_header): In the generated code for
7688 gencondmd.c, strengthen the global "insn" from rtx to rtx_insn *
7689 to match the other changes in this patch.
7690
7691 * genemit.c (gen_split): Strengthen the 1st param "curr_insn" of
7692 the generated "gen_" functions from rtx to rtx_insn * within their
7693 implementations.
7694
7695 * genrecog.c (write_subroutine): Strengthen the 2nd param "insn" of
7696 the subfunctions within the generated "recog_", "split", "peephole2"
7697 function trees from rtx to rtx_insn *. For now, the top-level
7698 generated functions ("recog", "split", "peephole2") continue to
7699 take a plain rtx for "insn", to avoid introducing dependencies on
7700 other patches. Rename this 2nd param from "insn" to
7701 "uncast_insn", and reintroduce "insn" as a local variable of type
7702 rtx_insn *, initialized at the top of the generated function with
7703 a checked cast on "uncast_insn".
7704 (make_insn_sequence): Strengthen the 1st param "curr_insn" of
7705 the generated "gen_" functions from rtx to rtx_insn * within their
7706 prototypes.
7707
7708 * genoutput.c (process_template): Strengthen the 2nd param within
7709 the generated "output_" functions "insn" from rtx to rtx_insn *.
7710
7711 2014-08-20 Jan Hubicka <hubicka@ucw.cz>
7712
7713 * tree-profile.c (tree_profiling): Skip external functions
7714 when doing coverage instrumentation.
7715 * cgraphunit.c (compile): Do not assert that all nodes are reachable.
7716
7717 2014-08-20 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
7718
7719 * config/rs6000/altivec.h (vec_cpsgn): New #define.
7720 (vec_mergee): Likewise.
7721 (vec_mergeo): Likewise.
7722 (vec_cntlz): Likewise.
7723 * config/rs600/rs6000-c.c (altivec_overloaded_builtins): Add new
7724 entries for VEC_AND, VEC_ANDC, VEC_MERGEH, VEC_MERGEL, VEC_NOR,
7725 VEC_OR, VEC_PACKSU, VEC_XOR, VEC_PERM, VEC_SEL, VEC_VCMPGT_P,
7726 VMRGEW, and VMRGOW.
7727 * doc/extend.texi: Document various forms of vec_cpsgn,
7728 vec_splats, vec_and, vec_andc, vec_mergeh, vec_mergel, vec_nor,
7729 vec_or, vec_perm, vec_sel, vec_sub, vec_xor, vec_all_eq,
7730 vec_all_ge, vec_all_gt, vec_all_le, vec_all_lt, vec_all_ne,
7731 vec_any_eq, vec_any_ge, vec_any_gt, vec_any_le, vec_any_lt,
7732 vec_any_ne, vec_mergee, vec_mergeo, vec_packsu, and vec_cntlz.
7733
7734 2014-08-20 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
7735
7736 * config/rs6000/rs6000.c (context.h): New include.
7737 (tree-pass.h): Likewise.
7738 (make_pass_analyze_swaps): New decl.
7739 (rs6000_option_override): Register pass_analyze_swaps.
7740 (swap_web_entry): New subsclass of web_entry_base (df.h).
7741 (special_handling_values): New enum.
7742 (union_defs): New function.
7743 (union_uses): Likewise.
7744 (insn_is_load_p): Likewise.
7745 (insn_is_store_p): Likewise.
7746 (insn_is_swap_p): Likewise.
7747 (rtx_is_swappable_p): Likewise.
7748 (insn_is_swappable_p): Likewise.
7749 (chain_purpose): New enum.
7750 (chain_contains_only_swaps): New function.
7751 (mark_swaps_for_removal): Likewise.
7752 (swap_const_vector_halves): Likewise.
7753 (adjust_subreg_index): Likewise.
7754 (permute_load): Likewise.
7755 (permute_store): Likewise.
7756 (handle_special_swappables): Likewise.
7757 (replace_swap_with_copy): Likewise.
7758 (dump_swap_insn_table): Likewise.
7759 (rs6000_analyze_swaps): Likewise.
7760 (pass_data_analyze_swaps): New pass_data.
7761 (pass_analyze_swaps): New rtl_opt_pass.
7762 (make_pass_analyze_swaps): New function.
7763 * config/rs6000/rs6000.opt (moptimize-swaps): New option.
7764
7765 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7766
7767 * sel-sched-ir.h (create_insn_rtx_from_pattern): Strengthen return
7768 type from rtx to rtx_insn *.
7769 (create_copy_of_insn_rtx): Likewise.
7770 * sel-sched-ir.c (create_insn_rtx_from_pattern): Likewise.
7771 (create_copy_of_insn_rtx): Likewise, also for local "res".
7772
7773 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7774
7775 * rtl.h (find_first_parameter_load): Strengthen return type from
7776 rtx to rtx_insn *.
7777 * rtlanal.c (find_first_parameter_load): Strengthen return type
7778 from rtx to rtx_insn *. Add checked cast for now, to postpone
7779 strengthening the params.
7780
7781 2014-08-21 Manuel López-Ibáñez <manu@gcc.gnu.org>
7782
7783 PR fortran/44054
7784 * diagnostic.c: Set default caret.
7785 (diagnostic_show_locus): Use it. Tell pretty-printer that a new
7786 line is needed.
7787 * diagnostic.h (struct diagnostic_context):
7788
7789 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7790
7791 * sel-sched-ir.h (exit_insn): Strengthen from rtx to rtx_insn *.
7792 (sel_bb_head): Strengthen return type insn_t (currently just an
7793 rtx) to rtx_insn *.
7794 (sel_bb_end): Likewise.
7795
7796 * sel-sched-ir.c (exit_insn): Strengthen from rtx to rtx_insn *.
7797 (sel_bb_head): Strengthen return type and local "head" from
7798 insn_t (currently just an rtx) to rtx_insn *.
7799 (sel_bb_end): Likewise for return type.
7800 (free_nop_and_exit_insns): Replace use of NULL_RTX with NULL when
7801 working with insn.
7802
7803 2014-08-21 David Malcolm <dmalcolm@redhat.com>
7804
7805 * basic-block.h (get_last_bb_insn): Strengthen return type from
7806 rtx to rtx_insn *.
7807 * cfgrtl.c (get_last_bb_insn): Likewise, and for locals "tmp" and
7808 end".
7809
7810 2014-08-21 Manuel López-Ibáñez <manu@gcc.gnu.org>
7811
7812 PR fortran/44054
7813 * diagnostic.c (default_diagnostic_finalizer): Move caret printing
7814 to here ...
7815 (diagnostic_report_diagnostic): ... from here.
7816 * toplev.c (general_init): Move code to c-family.
7817
7818 2014-08-20 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
7819
7820 * df.h (web_entry_base): Replace existing struct web_entry with a
7821 new class web_entry_base with only the predecessor member.
7822 (unionfind_root): Remove declaration and move to class member.
7823 (unionfind_union): Remove declaration and move to friend
7824 function.
7825 (union_defs): Remove declaration.
7826 * web.c (web_entry_base::unionfind_root): Modify to be member
7827 function and adjust accessors.
7828 (unionfind_union): Modify to be friend function and adjust
7829 accessors.
7830 (web_entry): New subclass of web_entry_base containing the reg
7831 member.
7832 (union_match_dups): Modify for struct -> class changes.
7833 (union_defs): Likewise.
7834 (entry_register): Likewise.
7835 (pass_web::execute): Likewise.
7836
7837 2014-08-20 Bill Schmidt <wschmidt@vnet.ibm.com>
7838
7839 * config/rs6000/rs6000-c.c (rs6000_cpu_cpp_builtins): Provide
7840 builtin define __VEC_ELEMENT_REG_ORDER__.
7841
7842 2014-08-20 Martin Jambor <mjambor@suse.cz>
7843 Wei Mi <wmi@google.com>
7844
7845 PR ipa/60449
7846 PR middle-end/61776
7847 * tree-ssa-operands.c (update_stmt_operands): Remove
7848 MODIFIED_NORETURN_CALLS.
7849 * tree-cfgcleanup.c (cleanup_call_ctrl_altering_flag): New func.
7850 (cleanup_control_flow_bb): Use cleanup_call_ctrl_altering_flag.
7851 (split_bb_on_noreturn_calls): Renamed from split_bbs_on_noreturn_calls.
7852 (cleanup_tree_cfg_1): Use split_bb_on_noreturn_calls.
7853 * tree-ssanames.h: Remove MODIFIED_NORETURN_CALLS.
7854 * gimple.h (enum gf_mask): Add GF_CALL_CTRL_ALTERING.
7855 (gimple_call_set_ctrl_altering): New func.
7856 (gimple_call_ctrl_altering_p): Ditto.
7857 * tree-cfg.c (gimple_call_initialize_ctrl_altering): Ditto.
7858 (make_blocks): Use gimple_call_initialize_ctrl_altering.
7859 (is_ctrl_altering_stmt): Use gimple_call_ctrl_altering_p.
7860 (execute_fixup_cfg): Use gimple_call_ctrl_altering_p and
7861 remove MODIFIED_NORETURN_CALLS.
7862
7863 2014-08-20 Jan Hubicka <hubicka@ucw.cz>
7864
7865 * coverage.c (coverage_compute_profile_id): Return non-0;
7866 also handle symbols with unique name.
7867 (coverage_end_function): Do not skip DECL_EXTERNAL functions.
7868
7869 2014-08-20 Steve Ellcey <sellcey@mips.com>
7870
7871 PR middle-end/49191
7872 * doc/sourcebuild.texi (non_strict_align): New.
7873
7874 2014-08-20 Jan Hubicka <hubicka@ucw.cz>
7875
7876 * cgraphunit.c (ipa_passes, compile): Reshedule
7877 symtab_remove_unreachable_nodes passes; update comments.
7878 * ipa-inline.c (pass_data_ipa_inline): Do not schedule
7879 TODO_remove_functions before the pass; the functions ought to be
7880 already removed.
7881 * ipa.c (pass_data_ipa_free_inline_summary): Enable dump; schedule
7882 TODO_remove_functions.
7883 * passes.c (pass_data_early_local_passes): Do not schedule function
7884 removal.
7885 (execute_one_pass): Fix call of symtab_remove_unreachable_nodes.
7886
7887 2014-08-20 Manuel López-Ibáñez <manu@gcc.gnu.org>
7888
7889 PR c/59304
7890 * opts-common.c (set_option): Call diagnostic_classify_diagnostic
7891 before setting the option.
7892 * diagnostic.c (diagnostic_classify_diagnostic): Record
7893 command-line status.
7894
7895 2014-08-20 Richard Biener <rguenther@suse.de>
7896
7897 PR lto/62190
7898 * tree.c (build_common_tree_nodes): Use make_or_reuse_type
7899 to build uint{16,32,64}_type_node.
7900
7901 2014-08-20 Terry Guo <terry.guo@arm.com>
7902
7903 * config/arm/thumb1.md (64bit splitter): Replace const_double_operand
7904 with immediate_operand.
7905
7906 2014-08-20 David Malcolm <dmalcolm@redhat.com>
7907
7908 * cfgrtl.c (duplicate_insn_chain): Convert the checked cast on
7909 "insn" from an as_a to a safe_as_a, for the case when "insn" is
7910 NULL.
7911
7912 2014-08-20 Manuel López-Ibáñez <manu@gcc.gnu.org>
7913
7914 PR preprocessor/51303
7915 * incpath.c (remove_duplicates): Use cpp_warning.
7916
7917 2014-08-20 Manuel López-Ibáñez <manu@gcc.gnu.org>
7918
7919 PR c/60975
7920 PR c/53063
7921 * doc/options.texi (CPP): Document it.
7922 * doc/invoke.texi (Wvariadic-macros): Fix documentation.
7923 * optc-gen.awk: Handle CPP.
7924 * opth-gen.awk: Likewise.
7925
7926 2014-08-19 David Malcolm <dmalcolm@redhat.com>
7927
7928 * rtl.h (unlink_insn_chain): Strengthen return type from rtx to
7929 rtx_insn *.
7930 (duplicate_insn_chain): Likewise.
7931 * cfgrtl.c (unlink_insn_chain): Strengthen return type from rtx to
7932 rtx_insn *, also for locals "prevfirst" and "nextlast". Add a
7933 checked cast for now (until we can strengthen the params in the
7934 same way).
7935 (duplicate_insn_chain): Likewise.
7936
7937 2014-08-19 David Malcolm <dmalcolm@redhat.com>
7938
7939 * rtl.h (next_cc0_user): Strengthen return type from rtx to
7940 rtx_insn *.
7941 (prev_cc0_setter): Likewise.
7942
7943 * emit-rtl.c (next_cc0_user): Strengthen return type from rtx to
7944 rtx_insn *, adding checked casts for now as necessary.
7945 (prev_cc0_setter): Likewise.
7946
7947 2014-08-19 David Malcolm <dmalcolm@redhat.com>
7948
7949 * expr.h (emit_move_insn): Strengthen return type from rtx to
7950 rtx_insn *.
7951 (emit_move_insn_1): Likewise.
7952 (emit_move_complex_push): Likewise.
7953 (emit_move_complex_parts): Likewise.
7954
7955 * expr.c (emit_move_via_integer): Strengthen return type from rtx
7956 to rtx_insn *. Replace use of NULL_RTX with NULL when working
7957 with insns.
7958 (emit_move_complex_push): Strengthen return type from rtx to
7959 rtx_insn *.
7960 (emit_move_complex): Likewise, also for local "ret".
7961 (emit_move_ccmode): Likewise.
7962 (emit_move_multi_word): Likewise for return type and locals
7963 "last_insn", "seq".
7964 (emit_move_insn_1): Likewise for return type and locals "result",
7965 "ret".
7966 (emit_move_insn): Likewise for return type and local "last_insn".
7967 (compress_float_constant): Likewise.
7968
7969 2014-08-19 David Malcolm <dmalcolm@redhat.com>
7970
7971 * emit-rtl.h (emit_copy_of_insn_after): Strengthen return type
7972 from rtx to rtx_insn *.
7973
7974 * rtl.h (emit_insn_before): Likewise.
7975 (emit_insn_before_noloc): Likewise.
7976 (emit_insn_before_setloc): Likewise.
7977 (emit_jump_insn_before): Likewise.
7978 (emit_jump_insn_before_noloc): Likewise.
7979 (emit_jump_insn_before_setloc): Likewise.
7980 (emit_call_insn_before): Likewise.
7981 (emit_call_insn_before_noloc): Likewise.
7982 (emit_call_insn_before_setloc): Likewise.
7983 (emit_debug_insn_before): Likewise.
7984 (emit_debug_insn_before_noloc): Likewise.
7985 (emit_debug_insn_before_setloc): Likewise.
7986 (emit_label_before): Likewise.
7987 (emit_insn_after): Likewise.
7988 (emit_insn_after_noloc): Likewise.
7989 (emit_insn_after_setloc): Likewise.
7990 (emit_jump_insn_after): Likewise.
7991 (emit_jump_insn_after_noloc): Likewise.
7992 (emit_jump_insn_after_setloc): Likewise.
7993 (emit_call_insn_after): Likewise.
7994 (emit_call_insn_after_noloc): Likewise.
7995 (emit_call_insn_after_setloc): Likewise.
7996 (emit_debug_insn_after): Likewise.
7997 (emit_debug_insn_after_noloc): Likewise.
7998 (emit_debug_insn_after_setloc): Likewise.
7999 (emit_label_after): Likewise.
8000 (emit_insn): Likewise.
8001 (emit_debug_insn): Likewise.
8002 (emit_jump_insn): Likewise.
8003 (emit_call_insn): Likewise.
8004 (emit_label): Likewise.
8005 (gen_clobber): Likewise.
8006 (emit_clobber): Likewise.
8007 (gen_use): Likewise.
8008 (emit_use): Likewise.
8009 (emit): Likewise.
8010
8011 (emit_barrier_before): Strengthen return type from rtx to
8012 rtx_barrier *.
8013 (emit_barrier_after): Likewise.
8014 (emit_barrier): Likewise.
8015
8016 * emit-rtl.c (emit_pattern_before_noloc): Strengthen return type
8017 from rtx to rtx_insn *. Add checked casts for now when converting
8018 "last" from rtx to rtx_insn *.
8019 (emit_insn_before_noloc): Likewise for return type.
8020 (emit_jump_insn_before_noloc): Likewise.
8021 (emit_call_insn_before_noloc): Likewise.
8022 (emit_debug_insn_before_noloc): Likewise.
8023 (emit_barrier_before): Strengthen return type and local "insn"
8024 from rtx to rtx_barrier *.
8025 (emit_label_before): Strengthen return type from rtx to
8026 rtx_insn *. Add checked cast for now when returning param
8027 (emit_pattern_after_noloc): Strengthen return type from rtx to
8028 rtx_insn *. Add checked casts for now when converting "last" from
8029 rtx to rtx_insn *.
8030 (emit_insn_after_noloc): Strengthen return type from rtx to
8031 rtx_insn *.
8032 (emit_jump_insn_after_noloc): Likewise.
8033 (emit_call_insn_after_noloc): Likewise.
8034 (emit_debug_insn_after_noloc): Likewise.
8035 (emit_barrier_after): Strengthen return type from rtx to
8036 rtx_barrier *.
8037 (emit_label_after): Strengthen return type from rtx to rtx_insn *.
8038 Add checked cast for now when converting "label" from rtx to
8039 rtx_insn *.
8040 (emit_pattern_after_setloc): Strengthen return type from rtx to
8041 rtx_insn *. Add checked casts for now when converting "last" from
8042 rtx to rtx_insn *.
8043 (emit_pattern_after): Strengthen return type from rtx to
8044 rtx_insn *.
8045 (emit_insn_after_setloc): Likewise.
8046 (emit_insn_after): Likewise.
8047 (emit_jump_insn_after_setloc): Likewise.
8048 (emit_jump_insn_after): Likewise.
8049 (emit_call_insn_after_setloc): Likewise.
8050 (emit_call_insn_after): Likewise.
8051 (emit_debug_insn_after_setloc): Likewise.
8052 (emit_debug_insn_after): Likewise.
8053 (emit_pattern_before_setloc): Likewise. Add checked casts for now
8054 when converting "last" from rtx to rtx_insn *.
8055 (emit_pattern_before): Strengthen return type from rtx to
8056 rtx_insn *.
8057 (emit_insn_before_setloc): Likewise.
8058 (emit_insn_before): Likewise.
8059 (emit_jump_insn_before_setloc): Likewise.
8060 (emit_jump_insn_before): Likewise.
8061 (emit_call_insn_before_setloc): Likewise.
8062 (emit_call_insn_before): Likewise.
8063 (emit_debug_insn_before_setloc): Likewise.
8064 (emit_debug_insn_before): Likewise.
8065 (emit_insn): Strengthen return type and locals "last", "insn",
8066 "next" from rtx to rtx_insn *. Add checked cast to rtx_insn
8067 within cases where we know we have an insn.
8068 (emit_debug_insn): Likewise.
8069 (emit_jump_insn): Likewise.
8070 (emit_call_insn): Strengthen return type and local "insn" from rtx
8071 to rtx_insn *.
8072 (emit_label): Strengthen return type from rtx to rtx_insn *. Add
8073 a checked cast to rtx_insn * for now on "label".
8074 (emit_barrier): Strengthen return type from rtx to rtx_barrier *.
8075 (emit_clobber): Strengthen return type from rtx to rtx_insn *.
8076 (emit_use): Likewise.
8077 (gen_use): Likewise, also for local "seq".
8078 (emit): Likewise for return type and local "insn".
8079 (rtx_insn): Likewise for return type and local "new_rtx".
8080
8081 * cfgrtl.c (emit_barrier_after_bb): Strengthen local "barrier"
8082 from rtx to rtx_barrier *.
8083
8084 * config/sh/sh.c (output_stack_adjust): Since emit_insn has
8085 changed return type from rtx to rtx_insn *, we must update
8086 "emit_fn" type, and this in turn means updating...
8087 (frame_insn): ...this. Strengthen return type from rtx to
8088 rtx_insn *. Introduce a new local "insn" of the appropriate type.
8089
8090 2014-08-19 David Malcolm <dmalcolm@redhat.com>
8091
8092 * emit-rtl.c (emit_jump_table_data): Strengthen return type from
8093 rtx to rtx_jump_table_data *. Also for local.
8094 * rtl.h (emit_jump_table_data): Likewise.
8095
8096 2014-08-19 David Malcolm <dmalcolm@redhat.com>
8097
8098 * basic-block.h (create_basic_block_structure): Strengthen third
8099 param "bb_note" from rtx to rtx_note *.
8100 * rtl.h (emit_note_before): Strengthen return type from rtx to
8101 rtx_note *.
8102 (emit_note_after): Likewise.
8103 (emit_note): Likewise.
8104 (emit_note_copy): Likewise. Also, strengthen param similarly.
8105 * function.h (struct rtl_data): Strengthen field
8106 "x_stack_check_probe_note" from rtx to rtx_note *.
8107
8108 * cfgexpand.c (expand_gimple_basic_block): Strengthen local "note"
8109 from rtx to rtx_note *.
8110 * cfgrtl.c (create_basic_block_structure): Strengthen third param
8111 "bb_note" from rtx to rtx_note *.
8112 (duplicate_insn_chain): Likewise for local "last". Add a checked cast
8113 when calling emit_note_copy.
8114 * emit-rtl.c (make_note_raw): Strengthen return type from rtx to
8115 rtx_note *.
8116 (emit_note_after): Likewise.
8117 (emit_note_before): Likewise.
8118 (emit_note_copy): Likewise. Also, strengthen param similarly.
8119 (emit_note): Likewise.
8120 * except.c (emit_note_eh_region_end): Likewise for return type.
8121 Strengthen local "next" from rtx to rtx_insn *.
8122 (convert_to_eh_region_ranges): Strengthen local "note"
8123 from rtx to rtx_note *.
8124 * final.c (change_scope): Likewise.
8125 (reemit_insn_block_notes): Likewise, for both locals named "note".
8126 Also, strengthen local "insn" from rtx to rtx_insn *.
8127 * haifa-sched.c (sched_extend_bb): Strengthen local "note" from
8128 rtx to rtx_note *.
8129 * reg-stack.c (compensate_edge): Likewise for local "after". Also,
8130 strengthen local "seq" from rtx to rtx_insn *.
8131 * reload1.c (reload_as_needed): Strengthen local "marker" from rtx
8132 to rtx_note *.
8133 * sel-sched-ir.c (bb_note_pool): Strengthen from rtx_vec_t to
8134 vec<rtx_note *>.
8135 (get_bb_note_from_pool): Strengthen return type from rtx to
8136 rtx_note *.
8137 (sel_create_basic_block): Strengthen local "new_bb_note" from
8138 insn_t to rtx_note *.
8139 * var-tracking.c (emit_note_insn_var_location): Strengthen local
8140 "note" from rtx to rtx_note *.
8141 (emit_notes_in_bb): Likewise.
8142
8143 2014-08-19 David Malcolm <dmalcolm@redhat.com>
8144
8145 * function.h (struct rtl_data): Strengthen field
8146 "x_parm_birth_insn" from rtx to rtx_insn *.
8147 * function.c (struct assign_parm_data_all): Strengthen fields
8148 "first_conversion_insn" and "last_conversion_insn" from rtx to
8149 rtx_insn *.
8150
8151 2014-08-19 David Malcolm <dmalcolm@redhat.com>
8152
8153 * cfgexpand.c (expand_used_vars): Strengthen return type from rtx
8154 to rtx_insn *; also for local "var_end_seq".
8155 (maybe_dump_rtl_for_gimple_stmt): Likewise for param "since".
8156 (maybe_cleanup_end_of_block): Likewise for param "last" and local
8157 "insn".
8158 (expand_gimple_cond): Likewise for locals "last2" and "last".
8159 (mark_transaction_restart_calls): Likewise for local "insn".
8160 (expand_gimple_stmt): Likewise for return type and locals "last"
8161 and "insn".
8162 (expand_gimple_tailcall): Likewise for locals "last2" and "last".
8163 (avoid_complex_debug_insns): Likewise for param "insn".
8164 (expand_debug_locations): Likewise for locals "insn", "last",
8165 "prev_insn" and "insn2".
8166 (expand_gimple_basic_block): Likewise for local "last".
8167 (construct_exit_block): Likewise for locals "head", "end",
8168 "orig_end".
8169 (pass_expand::execute): Likewise for locals "var_seq",
8170 "var_ret_seq", "next".
8171
8172 2014-08-19 David Malcolm <dmalcolm@redhat.com>
8173
8174 * asan.h (asan_emit_stack_protection): Strengthen return type from
8175 rtx to rtx_insn *.
8176 * asan.c (asan_emit_stack_protection): Likewise. Add local
8177 "insns" to hold the return value.
8178
8179 2014-08-19 David Malcolm <dmalcolm@redhat.com>
8180
8181 * basic-block.h (bb_note): Strengthen return type from rtx to
8182 rtx_note *.
8183 * sched-int.h (bb_note): Likewise.
8184 * cfgrtl.c (bb_note): Likewise. Add a checked cast to rtx_note *.
8185
8186 2014-08-19 David Malcolm <dmalcolm@redhat.com>
8187
8188 * rtl.h (make_insn_raw): Strengthen return type from rtx to
8189 rtx_insn *.
8190
8191 * emit-rtl.c (make_insn_raw): Strengthen return type and local
8192 "insn" from rtx to rtx_insn *.
8193 (make_debug_insn_raw): Strengthen return type from rtx to
8194 rtx_insn *; strengthen local "insn" from rtx to rtx_debug_insn *.
8195 (make_jump_insn_raw): Strengthen return type from rtx to
8196 rtx_insn *; strengthen local "insn" from rtx to rtx_jump_insn *.
8197 (make_call_insn_raw): Strengthen return type from rtx to
8198 rtx_insn *; strengthen local "insn" from rtx to rtx_call_insn *.
8199 (emit_pattern_before_noloc): Strengthen return type of "make_raw"
8200 callback from rtx to rtx_insn *; likewise for local "insn" and
8201 "next", adding a checked cast to rtx_insn in the relevant cases of
8202 the switch statement.
8203 (emit_pattern_after_noloc): Strengthen return type of "make_raw"
8204 callback from rtx to rtx_insn *.
8205 (emit_pattern_after_setloc): Likewise.
8206 (emit_pattern_after): Likewise.
8207 (emit_pattern_before_setloc): Likewise.
8208 (emit_pattern_before): Likewise.
8209
8210 2014-08-19 David Malcolm <dmalcolm@redhat.com>
8211
8212 * emit-rtl.c (last_call_insn): Strengthen return type from rtx to
8213 rtx_call_insn *.
8214 * rtl.h (is_a_helper <rtx_call_insn *>::test): New overload,
8215 accepting an rtx_insn *.
8216 (last_call_insn): Strengthen return type from rtx to
8217 rtx_call_insn *.
8218
8219 2014-08-19 David Malcolm <dmalcolm@redhat.com>
8220
8221 * rtl.h (delete_trivially_dead_insns): Strengthen initial param
8222 "insns" from rtx to rtx_insn *.
8223 * cse.c (delete_trivially_dead_insns): Likewise, also do it for
8224 locals "insn" and "prev".
8225
8226 2014-08-19 David Malcolm <dmalcolm@redhat.com>
8227
8228 * rtl.h (tablejump_p): Strengthen third param from rtx * to
8229 rtx_jump_table_data **.
8230
8231 * cfgbuild.c (make_edges): Introduce local "table", using it in
8232 place of "tmp" for jump table data.
8233 (find_bb_boundaries): Strengthen local "table" from rtx to
8234 rtx_jump_table_data *.
8235 * cfgcleanup.c (merge_blocks_move_successor_nojumps): Likewise.
8236 (outgoing_edges_match): Likewise for locals "table1" and "table2".
8237 (try_crossjump_to_edge): Likewise.
8238 * cfgrtl.c (try_redirect_by_replacing_jump): Likewise for local
8239 "table".
8240 (patch_jump_insn): Introduce local "table", using it in place of
8241 "tmp" for jump table data.
8242 (force_nonfallthru_and_redirect): Introduce local "table", so that
8243 call to tablejump_p can receive an rtx_jump_table_data **. Update
8244 logic around the call to overwrite "note" appropriately if
8245 tablejump_p returns non-zero.
8246 (get_last_bb_insn): Introduce local "table", using it in place of
8247 "tmp" for jump table data.
8248 * dwarf2cfi.c (create_trace_edges): Likewise.
8249
8250 * config/arm/arm.c (get_jump_table_size): Strengthen param "insn"
8251 from rtx to rtx_jump_table_data *.
8252 (create_fix_barrier): Strengthen local "tmp" from rtx to
8253 rtx_jump_table_data *.
8254 (arm_reorg): Likewise for local "table".
8255
8256 * config/s390/s390.c (s390_chunkify_start): Likewise.
8257
8258 * config/spu/spu.c (spu_emit_branch_hint): Likewise.
8259
8260 * jump.c (delete_related_insns): Strengthen local "lab_next" from
8261 rtx to rtx_jump_table_data *.
8262
8263 * rtlanal.c (tablejump_p): Strengthen param "tablep" from rtx * to
8264 rtx_jump_table_data **. Add a checked cast when writing through
8265 the pointer: we know there that local "table" is non-NULL and that
8266 JUMP_TABLE_DATA_P (table) holds.
8267 (label_is_jump_target_p): Introduce local "table", using it in
8268 place of "tmp" for jump table data.
8269
8270 2014-08-19 Marek Polacek <polacek@redhat.com>
8271
8272 PR c++/62153
8273 * doc/invoke.texi: Document -Wbool-compare.
8274
8275 2014-08-19 David Malcolm <dmalcolm@redhat.com>
8276
8277 * rtl.h (entry_of_function): Strengthen return type from rtx to
8278 rtx_insn *.
8279 * cfgrtl.c (entry_of_function): Likewise.
8280
8281 2014-08-19 David Malcolm <dmalcolm@redhat.com>
8282
8283 * emit-rtl.h (get_insns): Strengthen return type from rtx to
8284 rtx_insn *, adding a checked cast for now.
8285 (get_last_insn): Likewise.
8286
8287 2014-08-19 David Malcolm <dmalcolm@redhat.com>
8288
8289 * rtl.h (gen_label_rtx): Strengthen return type from rtx to
8290 rtx_code_label *.
8291
8292 * emit-rtl.c (gen_label_rtx): Likewise.
8293
8294 2014-08-19 David Malcolm <dmalcolm@redhat.com>
8295
8296 * rtl.h (previous_insn): Strengthen return type from rtx to
8297 rtx_insn *.
8298 (next_insn): Likewise.
8299 (prev_nonnote_insn): Likewise.
8300 (prev_nonnote_insn_bb): Likewise.
8301 (next_nonnote_insn): Likewise.
8302 (next_nonnote_insn_bb): Likewise.
8303 (prev_nondebug_insn): Likewise.
8304 (next_nondebug_insn): Likewise.
8305 (prev_nonnote_nondebug_insn): Likewise.
8306 (next_nonnote_nondebug_insn): Likewise.
8307 (prev_real_insn): Likewise.
8308 (next_real_insn): Likewise.
8309 (prev_active_insn): Likewise.
8310 (next_active_insn): Likewise.
8311
8312 * emit-rtl.c (next_insn): Strengthen return type from rtx to
8313 rtx_insn *, adding a checked cast.
8314 (previous_insn): Likewise.
8315 (next_nonnote_insn): Likewise.
8316 (next_nonnote_insn_bb): Likewise.
8317 (prev_nonnote_insn): Likewise.
8318 (prev_nonnote_insn_bb): Likewise.
8319 (next_nondebug_insn): Likewise.
8320 (prev_nondebug_insn): Likewise.
8321 (next_nonnote_nondebug_insn): Likewise.
8322 (prev_nonnote_nondebug_insn): Likewise.
8323 (next_real_insn): Likewise.
8324 (prev_real_insn): Likewise.
8325 (next_active_insn): Likewise.
8326 (prev_active_insn): Likewise.
8327
8328 * config/sh/sh-protos.h (sh_find_set_of_reg): Convert function ptr
8329 param "stepfunc" so that it returns an rtx_insn * rather than an
8330 rtx, to track the change to prev_nonnote_insn_bb, which is the
8331 only function this is called with.
8332 * config/sh/sh.c (sh_find_set_of_reg): Likewise.
8333
8334 2014-08-19 Jan Hubicka <hubicka@ucw.cz>
8335
8336 * ipa-visibility.c (update_visibility_by_resolution_info): Fix
8337 assert.
8338
8339 2014-08-19 David Malcolm <dmalcolm@redhat.com>
8340
8341 * coretypes.h (class rtx_debug_insn): Add forward declaration.
8342 (class rtx_nonjump_insn): Likewise.
8343 (class rtx_jump_insn): Likewise.
8344 (class rtx_call_insn): Likewise.
8345 (class rtx_jump_table_data): Likewise.
8346 (class rtx_barrier): Likewise.
8347 (class rtx_code_label): Likewise.
8348 (class rtx_note): Likewise.
8349
8350 * rtl.h (class rtx_debug_insn): New, a subclass of rtx_insn,
8351 adding the invariant DEBUG_INSN_P (X).
8352 (class rtx_nonjump_insn): New, a subclass of rtx_insn, adding
8353 the invariant NONJUMP_INSN_P (X).
8354 (class rtx_jump_insn): New, a subclass of rtx_insn, adding
8355 the invariant JUMP_P (X).
8356 (class rtx_call_insn): New, a subclass of rtx_insn, adding
8357 the invariant CALL_P (X).
8358 (class rtx_jump_table): New, a subclass of rtx_insn, adding the
8359 invariant JUMP_TABLE_DATA_P (X).
8360 (class rtx_barrier): New, a subclass of rtx_insn, adding the
8361 invariant BARRIER_P (X).
8362 (class rtx_code_label): New, a subclass of rtx_insn, adding
8363 the invariant LABEL_P (X).
8364 (class rtx_note): New, a subclass of rtx_insn, adding
8365 the invariant NOTE_P(X).
8366 (is_a_helper <rtx_debug_insn *>::test): New.
8367 (is_a_helper <rtx_nonjump_insn *>::test): New.
8368 (is_a_helper <rtx_jump_insn *>::test): New.
8369 (is_a_helper <rtx_call_insn *>::test): New.
8370 (is_a_helper <rtx_jump_table_data *>::test): New functions,
8371 overloaded for both rtx and rtx_insn *.
8372 (is_a_helper <rtx_barrier *>::test): New.
8373 (is_a_helper <rtx_code_label *>::test): New functions, overloaded
8374 for both rtx and rtx_insn *.
8375 (is_a_helper <rtx_note *>::test): New.
8376
8377 2014-08-19 Marek Polacek <polacek@redhat.com>
8378
8379 * config/alpha/alpha.h (CLZ_DEFINED_VALUE_AT_ZERO,
8380 CTZ_DEFINED_VALUE_AT_ZERO): Return 0/1 rather than bool.
8381 * config/i386/i386.h (CLZ_DEFINED_VALUE_AT_ZERO,
8382 CTZ_DEFINED_VALUE_AT_ZERO): Return 0/1 rather than bool.
8383
8384 2014-08-19 David Malcolm <dmalcolm@redhat.com>
8385
8386 * sel-sched-ir.h (BND_TO): insn_t will eventually be an
8387 rtx_insn *. To help with transition, for now, convert from an
8388 access macro into a pair of functions: BND_TO, returning an
8389 rtx_insn *, and...
8390 (SET_BND_TO): New function, for use where BND_TO is used as an
8391 lvalue.
8392
8393 * sel-sched-ir.c (blist_add): Update lvalue usage of BND_TO to
8394 SET_BND_TO.
8395 (BND_TO): New function, adding a checked cast.
8396 (SET_BND_TO): New function.
8397
8398 * sel-sched.c (move_cond_jump): Update lvalue usage of BND_TO to
8399 SET_BND_TO.
8400 (compute_av_set_on_boundaries): Likewise.
8401
8402 2014-08-19 H.J. Lu <hongjiu.lu@intel.com>
8403
8404 * config/i386/i386.md (*ctz<mode>2_falsedep_1): Don't clear
8405 destination if it is used in source.
8406 (*clz<mode>2_lzcnt_falsedep_1): Likewise.
8407 (*popcount<mode>2_falsedep_1): Likewise.
8408
8409 2014-08-19 H.J. Lu <hongjiu.lu@intel.com>
8410
8411 PR other/62168
8412 * configure.ac: Set install_gold_as_default to no first.
8413 * configure: Regenerated.
8414
8415 2014-08-19 David Malcolm <dmalcolm@redhat.com>
8416
8417 * sel-sched-ir.h (BB_NOTE_LIST): struct sel_region_bb_info_def's
8418 "note_list" field will eventually be an rtx_insn *. To help with
8419 transition, for now, convert from an access macro into a pair of
8420 functions: BB_NOTE_LIST, returning an rtx_insn *, and...
8421 (SET_BB_NOTE_LIST): New function, for use where BB_NOTE_LIST is
8422 used as an lvalue.
8423
8424 * sel-sched.c (create_block_for_bookkeeping): Update lvalue usage
8425 of BB_NOTE_LIST to SET_BB_NOTE_LIST.
8426
8427 * sel-sched-ir.c (init_bb): Likewise.
8428 (sel_restore_notes): Likewise.
8429 (move_bb_info): Likewise.
8430 (BB_NOTE_LIST): New function, adding a checked cast to rtx_insn *.
8431 (SET_BB_NOTE_LIST): New function.
8432
8433 2014-08-19 David Malcolm <dmalcolm@redhat.com>
8434
8435 * sel-sched-ir.h (VINSN_INSN_RTX): struct vinsn_def's "insn_rtx"
8436 field will eventually be an rtx_insn *. To help with transition,
8437 for now, convert from an access macro into a pair of functions:
8438 VINSN_INSN_RTX, returning an rtx_insn *, and...
8439 (SET_VINSN_INSN_RTX): New function, for use where VINSN_INSN_RTX
8440 is used as an lvalue.
8441
8442 * sel-sched-ir.c (vinsn_init): Replace VINSN_INSN_RTX with
8443 SET_VINSN_INSN_RTX where it's used as an lvalue.
8444 (VINSN_INSN_RTX): New function.
8445 (SET_VINSN_INSN_RTX): New function.
8446
8447 2014-08-19 David Malcolm <dmalcolm@redhat.com>
8448
8449 * sched-int.h (DEP_PRO): struct _dep's "pro" and "con" fields will
8450 eventually be rtx_insn *, but to help with transition, for now,
8451 convert from an access macro into a pair of functions: DEP_PRO
8452 returning an rtx_insn * and...
8453 (SET_DEP_PRO): New function, for use where DEP_PRO is used as an
8454 lvalue, returning an rtx&.
8455 (DEP_CON): Analogous changes to DEP_PRO above.
8456 (SET_DEP_CON): Likewise.
8457
8458 * haifa-sched.c (create_check_block_twin): Replace DEP_CON used as
8459 an lvalue to SET_DEP_CON.
8460 * sched-deps.c (init_dep_1): Likewise for DEP_PRO and DEP_CON.
8461 (sd_copy_back_deps): Likewise for DEP_CON.
8462 (DEP_PRO): New function, adding a checked cast for now.
8463 (DEP_CON): Likewise.
8464 (SET_DEP_PRO): New function.
8465 (SET_DEP_CON): Likewise.
8466
8467 2014-08-19 Yaakov Selkowitz <yselkowi@redhat.com>
8468
8469 * config.gcc (*-*-cygwin*): Use __cxa_atexit by default.
8470 (extra_options): Add i386/cygwin.opt.
8471 * config/i386/cygwin.h (STARTFILE_SPEC): Use crtbeginS.o if shared.
8472 (CPP_SPEC): Accept -pthread.
8473 (LINK_SPEC): Ditto.
8474 (GOMP_SELF_SPECS): Update comment.
8475 * config/i386/cygwin.opt: New file for -pthread flag.
8476
8477 2014-08-19 David Malcolm <dmalcolm@redhat.com>
8478
8479 * df-core.c (DF_REF_INSN): New, using a checked cast for now.
8480 * df.h (DF_REF_INSN): Convert from a macro to a function, so
8481 that we can return an rtx_insn *.
8482
8483 2014-08-19 Yaakov Selkowitz <yselkowi@redhat.com>
8484
8485 * config/i386/cygwin.h (LINK_SPEC): Pass --tsaware flag only
8486 when building executables, not DLLs. Add --large-address-aware
8487 under the same conditions.
8488 * config/i386/cygwin-w64.h (LINK_SPEC): Pass --tsaware flag only
8489 when building executables, not DLLs. Add --large-address-aware
8490 under the same conditions when using -m32.
8491
8492 * config/i386/cygwin-stdint.h: Throughout, make type
8493 definitions dependent on target architecture, not host.
8494
8495 2014-08-19 David Malcolm <dmalcolm@redhat.com>
8496
8497 * rtl.h (PREV_INSN): Convert to an inline function. Strengthen
8498 the return type from rtx to rtx_insn *, which will enable various
8499 conversions in followup patches. For now this is is done by a
8500 checked cast.
8501 (NEXT_INSN): Likewise.
8502 (SET_PREV_INSN): Convert to an inline function. This is intended
8503 for use as an lvalue, and so returns an rtx& to allow in-place
8504 modification.
8505 (SET_NEXT_INSN): Likewise.
8506
8507 2014-07-08 Mark Wielaard <mjw@redhat.com>
8508
8509 PR debug/59051
8510 * dwarf2out.c (modified_type_die): Handle TYPE_QUAL_RESTRICT.
8511
8512 2014-08-19 Marek Polacek <polacek@redhat.com>
8513
8514 PR c/61271
8515 * cgraphunit.c (handle_alias_pairs): Fix condition.
8516
8517 2014-08-19 Richard Biener <rguenther@suse.de>
8518
8519 * gimple-fold.c (fold_gimple_assign): Properly build a
8520 null-pointer constant when devirtualizing addresses.
8521
8522 2014-07-07 Mark Wielaard <mjw@redhat.com>
8523
8524 * dwarf2out.c (decl_quals): New function.
8525 (modified_type_die): Take one cv_quals argument instead of two,
8526 one for const and one for volatile.
8527 (add_type_attribute): Likewise.
8528 (generic_parameter_die): Call add_type_attribute with one modifier
8529 argument.
8530 (base_type_for_mode): Likewise.
8531 (add_bounds_info): Likewise.
8532 (add_subscript_info): Likewise.
8533 (gen_array_type_die): Likewise.
8534 (gen_descr_array_type_die): Likewise.
8535 (gen_entry_point_die): Likewise.
8536 (gen_enumeration_type_die): Likewise.
8537 (gen_formal_parameter_die): Likewise.
8538 (gen_subprogram_die): Likewise.
8539 (gen_variable_die): Likewise.
8540 (gen_const_die): Likewise.
8541 (gen_field_die): Likewise.
8542 (gen_pointer_type_die): Likewise.
8543 (gen_reference_type_die): Likewise.
8544 (gen_ptr_to_mbr_type_die): Likewise.
8545 (gen_inheritance_die): Likewise.
8546 (gen_subroutine_type_die): Likewise.
8547 (gen_typedef_die): Likewise.
8548 (force_type_die): Likewise.
8549
8550 2014-08-19 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
8551
8552 * configure.ac (gcc_cv_as_comdat_group_group): Only default to no
8553 if unset.
8554 * configure: Regenerate.
8555
8556 2014-08-19 Richard Biener <rguenther@suse.de>
8557
8558 * lto-streamer-out.c (DFS::DFS_write_tree_body): Stream
8559 DECL_EXTERNALs in BLOCKs as non-references.
8560 * tree-streamer-out.c (streamer_write_chain): Likewise.
8561
8562 2014-08-19 Alexander Ivchenko <alexander.ivchenko@intel.com>
8563 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
8564 Anna Tikhonova <anna.tikhonova@intel.com>
8565 Ilya Tocar <ilya.tocar@intel.com>
8566 Andrey Turetskiy <andrey.turetskiy@intel.com>
8567 Ilya Verbin <ilya.verbin@intel.com>
8568 Kirill Yukhin <kirill.yukhin@intel.com>
8569 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
8570
8571 * config/i386/sse.md
8572 (define_mode_iterator VI48_AVX512F): Delete.
8573 (define_mode_iterator VI48_AVX512F_AVX512VL): New.
8574 (define_mode_iterator VI2_AVX512VL): Ditto.
8575 (define_insn "<mask_codefor>avx512f_ufix_notruncv16sfv16si<mask_name><round_name>"):
8576 Delete.
8577 (define_insn
8578 ("<mask_codefor><avx512>_ufix_notrunc<sf2simodelower><mode><mask_name><round_name>"):
8579 New.
8580 (define_insn "avx512cd_maskw_vec_dup<mode>"): Macroize.
8581 (define_insn "<avx2_avx512f>_ashrv<mode><mask_name>"): Delete.
8582 (define_insn "<avx2_avx512bw>_ashrv<mode><mask_name>",
8583 with VI48_AVX512F_AVX512VL): New.
8584 (define_insn "<avx2_avx512bw>_ashrv<mode><mask_name>",
8585 with VI2_AVX512VL): Ditto.
8586
8587 2014-08-19 Marek Polacek <polacek@redhat.com>
8588
8589 * doc/invoke.texi: Document -Wc99-c11-compat.
8590
8591 2014-08-19 David Malcolm <dmalcolm@redhat.com>
8592
8593 * rtl.h (PREV_INSN): Split macro in two: the existing one,
8594 for rvalues, and...
8595 (SET_PREV_INSN): New macro, for use as an lvalue.
8596 (NEXT_INSN, SET_NEXT_INSN): Likewise.
8597
8598 * caller-save.c (save_call_clobbered_regs): Convert lvalue use of
8599 PREV_INSN/NEXT_INSN into SET_PREV_INSN/SET_NEXT_INSN.
8600 * cfgrtl.c (try_redirect_by_replacing_jump): Likewise.
8601 (fixup_abnormal_edges): Likewise.
8602 (unlink_insn_chain): Likewise.
8603 (fixup_reorder_chain): Likewise.
8604 (cfg_layout_delete_block): Likewise.
8605 (cfg_layout_merge_blocks): Likewise.
8606 * combine.c (update_cfg_for_uncondjump): Likewise.
8607 * emit-rtl.c (link_insn_into_chain): Likewise.
8608 (remove_insn): Likewise.
8609 (delete_insns_since): Likewise.
8610 (reorder_insns_nobb): Likewise.
8611 (emit_insn_after_1): Likewise.
8612 * final.c (rest_of_clean_state): Likewise.
8613 (final_scan_insn): Likewise.
8614 * gcse.c (can_assign_to_reg_without_clobbers_p): Likewise.
8615 * haifa-sched.c (concat_note_lists): Likewise.
8616 (remove_notes): Likewise.
8617 (restore_other_notes): Likewise.
8618 (move_insn): Likewise.
8619 (unlink_bb_notes): Likewise.
8620 (restore_bb_notes): Likewise.
8621 * jump.c (delete_for_peephole): Likewise.
8622 * optabs.c (emit_libcall_block_1): Likewise.
8623 * reorg.c (emit_delay_sequence): Likewise.
8624 (fill_simple_delay_slots): Likewise.
8625 * sel-sched-ir.c (sel_move_insn): Likewise.
8626 (sel_remove_insn): Likewise.
8627 (get_bb_note_from_pool): Likewise.
8628 * sel-sched.c (move_nop_to_previous_block): Likewise.
8629
8630 * config/bfin/bfin.c (reorder_var_tracking_notes): Likewise.
8631 * config/c6x/c6x.c (gen_one_bundle): Likewise.
8632 (c6x_gen_bundles): Likewise.
8633 (hwloop_optimize): Likewise.
8634 * config/frv/frv.c (frv_function_prologue): Likewise.
8635 (frv_register_nop): Likewise.
8636 * config/ia64/ia64.c (ia64_init_dfa_pre_cycle_insn): Likewise.
8637 (ia64_reorg): Likewise.
8638 * config/mep/mep.c (mep_reorg_addcombine): Likewise.
8639 (mep_make_bundle): Likewise.
8640 (mep_bundle_insns): Likewise.
8641 * config/picochip/picochip.c (reorder_var_tracking_notes): Likewise.
8642 * config/tilegx/tilegx.c (reorder_var_tracking_notes): Likewise.
8643 * config/tilepro/tilepro.c (reorder_var_tracking_notes): Likewise.
8644
8645 2014-08-19 David Malcolm <dmalcolm@redhat.com>
8646
8647 * basic-block.h (BB_HEAD): Convert to a function. Strengthen the
8648 return type from rtx to rtx_insn *.
8649 (BB_END): Likewise.
8650 (BB_HEADER): Likewise.
8651 (BB_FOOTER): Likewise.
8652 (SET_BB_HEAD): Convert to a function.
8653 (SET_BB_END): Likewise.
8654 (SET_BB_HEADER): Likewise.
8655 (SET_BB_FOOTER): Likewise.
8656
8657 * cfgrtl.c (BB_HEAD): New function, from macro of same name.
8658 Strengthen the return type from rtx to rtx_insn *. For now, this
8659 is done by adding a checked cast, but this will eventually
8660 become a field lookup.
8661 (BB_END): Likewise.
8662 (BB_HEADER): Likewise.
8663 (BB_FOOTER): Likewise.
8664 (SET_BB_HEAD): New function, from macro of same name. This is
8665 intended for use as an lvalue, and so returns an rtx& to allow
8666 in-place modification.
8667 (SET_BB_END): Likewise.
8668 (SET_BB_HEADER): Likewise.
8669 (SET_BB_FOOTER): Likewise.
8670
8671 2014-08-18 David Malcolm <dmalcolm@redhat.com>
8672
8673 * basic-block.h (BB_HEAD): Split macro in two: the existing one,
8674 for rvalues, and...
8675 (SET_BB_HEAD): New macro, for use as a lvalue.
8676 (BB_END, SET_BB_END): Likewise.
8677 (BB_HEADER, SET_BB_HEADER): Likewise.
8678 (BB_FOOTER, SET_BB_FOOTER): Likewise.
8679
8680 * bb-reorder.c (add_labels_and_missing_jumps): Convert lvalue use
8681 of BB_* macros into SET_BB_* macros.
8682 (fix_crossing_unconditional_branches): Likewise.
8683 * caller-save.c (save_call_clobbered_regs): Likewise.
8684 (insert_one_insn): Likewise.
8685 * cfgbuild.c (find_bb_boundaries): Likewise.
8686 * cfgcleanup.c (merge_blocks_move_successor_nojumps): Likewise.
8687 (outgoing_edges_match): Likewise.
8688 (try_optimize_cfg): Likewise.
8689 * cfgexpand.c (expand_gimple_cond): Likewise.
8690 (expand_gimple_tailcall): Likewise.
8691 (expand_gimple_basic_block): Likewise.
8692 (construct_exit_block): Likewise.
8693 * cfgrtl.c (delete_insn): Likewise.
8694 (create_basic_block_structure): Likewise.
8695 (rtl_delete_block): Likewise.
8696 (rtl_split_block): Likewise.
8697 (emit_nop_for_unique_locus_between): Likewise.
8698 (rtl_merge_blocks): Likewise.
8699 (block_label): Likewise.
8700 (try_redirect_by_replacing_jump): Likewise.
8701 (emit_barrier_after_bb): Likewise.
8702 (fixup_abnormal_edges): Likewise.
8703 (record_effective_endpoints): Likewise.
8704 (relink_block_chain): Likewise.
8705 (fixup_reorder_chain): Likewise.
8706 (fixup_fallthru_exit_predecessor): Likewise.
8707 (cfg_layout_duplicate_bb): Likewise.
8708 (cfg_layout_split_block): Likewise.
8709 (cfg_layout_delete_block): Likewise.
8710 (cfg_layout_merge_blocks): Likewise.
8711 * combine.c (update_cfg_for_uncondjump): Likewise.
8712 * emit-rtl.c (add_insn_after): Likewise.
8713 (remove_insn): Likewise.
8714 (reorder_insns): Likewise.
8715 (emit_insn_after_1): Likewise.
8716 * haifa-sched.c (get_ebb_head_tail): Likewise.
8717 (restore_other_notes): Likewise.
8718 (move_insn): Likewise.
8719 (sched_extend_bb): Likewise.
8720 (fix_jump_move): Likewise.
8721 * ifcvt.c (noce_process_if_block): Likewise.
8722 (dead_or_predicable): Likewise.
8723 * ira.c (update_equiv_regs): Likewise.
8724 * reg-stack.c (change_stack): Likewise.
8725 * sel-sched-ir.c (sel_move_insn): Likewise.
8726 * sel-sched.c (move_nop_to_previous_block): Likewise.
8727
8728 * config/c6x/c6x.c (hwloop_optimize): Likewise.
8729 * config/ia64/ia64.c (emit_predicate_relation_info): Likewise.
8730
8731 2014-08-18 David Malcolm <dmalcolm@redhat.com>
8732
8733 * rtl.h (for_each_rtx_in_insn): New function.
8734 * rtlanal.c (for_each_rtx_in_insn): Likewise.
8735
8736 2014-08-18 David Malcolm <dmalcolm@redhat.com>
8737
8738 * coretypes.h (class rtx_insn): Add forward declaration.
8739
8740 * rtl.h: Include is-a.h.
8741 (struct rtx_def): Add dummy "desc" and "tag" GTY options as a
8742 workaround to ensure gengtype knows inheritance is occurring,
8743 whilst continuing to use the pre-existing special-casing for
8744 rtx_def.
8745 (class rtx_insn): New subclass of rtx_def, adding the
8746 invariant that we're dealing with something we can sanely use
8747 INSN_UID, NEXT_INSN, PREV_INSN on.
8748 (is_a_helper <rtx_insn *>::test): New.
8749 (is_a_helper <const rtx_insn *>::test): New.
8750
8751 2014-08-18 David Malcolm <dmalcolm@redhat.com>
8752
8753 * is-a.h (template<T, U> safe_as_a <U *p>) New function.
8754
8755 2014-08-18 Jan Hubicka <hubicka@ucw.cz>
8756
8757 * ipa-visibility.c (update_visibility_by_resolution_info): Do no turn UNDEF
8758 comdats as extern.
8759
8760 2014-08-18 Jan Hubicka <hubicka@ucw.cz>
8761
8762 * gimple-fold.c (fold_gimple_assign): Do not intorudce referneces
8763 to BUILT_IN_UNREACHABLE.
8764
8765 2014-08-18 Uros Bizjak <ubizjak@gmail.com>
8766
8767 PR target/62011
8768 * config/i386/x86-tune.def (X86_TUNE_AVOID_FALSE_DEP_FOR_BMI):
8769 New tune flag.
8770 * config/i386/i386.h (TARGET_AVOID_FALSE_DEP_FOR_BMI): New define.
8771 * config/i386/i386.md (unspec) <UNSPEC_INSN_FALSE_DEP>: New unspec.
8772 (ffs<mode>2): Do not expand with tzcnt for
8773 TARGET_AVOID_FALSE_DEP_FOR_BMI.
8774 (ffssi2_no_cmove): Ditto.
8775 (*tzcnt<mode>_1): Disable for TARGET_AVOID_FALSE_DEP_FOR_BMI.
8776 (ctz<mode>2): New expander.
8777 (*ctz<mode>2_falsedep_1): New insn_and_split pattern.
8778 (*ctz<mode>2_falsedep): New insn.
8779 (*ctz<mode>2): Rename from ctz<mode>2.
8780 (clz<mode>2_lzcnt): New expander.
8781 (*clz<mode>2_lzcnt_falsedep_1): New insn_and_split pattern.
8782 (*clz<mode>2_lzcnt_falsedep): New insn.
8783 (*clz<mode>2): Rename from ctz<mode>2.
8784 (popcount<mode>2): New expander.
8785 (*popcount<mode>2_falsedep_1): New insn_and_split pattern.
8786 (*popcount<mode>2_falsedep): New insn.
8787 (*popcount<mode>2): Rename from ctz<mode>2.
8788 (*popcount<mode>2_cmp): Remove.
8789 (*popcountsi2_cmp_zext): Ditto.
8790
8791 2014-08-18 Ajit Agarwal <ajitkum@xilinx.com>
8792
8793 * config/microblaze/microblaze.c (microblaze_elf_asm_cdtor): New.
8794 (microblaze_elf_asm_constructor,microblaze_elf_asm_destructor): New.
8795 * config/microblaze/microblaze.h
8796 (TARGET_ASM_CONSTRUCTOR,TARGET_ASM_DESTRUCTOR): New Macros.
8797
8798 2014-08-18 H.J. Lu <hongjiu.lu@intel.com>
8799
8800 PR other/62168
8801 * configure.ac: Set install_gold_as_default to no for
8802 --enable-gold=no.
8803 * configure: Regenerated.
8804
8805 2014-08-18 Roman Gareev <gareevroman@gmail.com>
8806
8807 * Makefile.in: Add definition of ISLLIBS, HOST_ISLLIBS.
8808 * config.in: Add undef of HAVE_isl.
8809 * configure: Regenerate.
8810 * configure.ac: Add definition of HAVE_isl.
8811 * graphite-blocking.c: Add checking of HAVE_isl.
8812 * graphite-dependences.c: Likewise.
8813 * graphite-interchange.c: Likewise.
8814 * graphite-isl-ast-to-gimple.c: Likewise.
8815 * graphite-optimize-isl.c: Likewise.
8816 * graphite-poly.c: Likewise.
8817 * graphite-scop-detection.c: Likewise.
8818 * graphite-sese-to-poly.c: Likewise.
8819 * graphite.c: Likewise.
8820 * toplev.c: Replace the checking of HAVE_cloog with the checking
8821 of HAVE_isl.
8822
8823 2014-08-18 Richard Biener <rguenther@suse.de>
8824
8825 PR tree-optimization/62090
8826 * builtins.c (fold_builtin_snprintf): Move to gimple-fold.c.
8827 (fold_builtin_3): Do not fold snprintf.
8828 (fold_builtin_4): Likewise.
8829 * gimple-fold.c (gimple_fold_builtin_snprintf): New function
8830 moved from builtins.c.
8831 (gimple_fold_builtin_with_strlen): Fold snprintf and sprintf.
8832 (gimple_fold_builtin): Do not fold sprintf here.
8833
8834 2014-08-18 Richard Biener <rguenther@suse.de>
8835
8836 * gimple-fold.c (maybe_fold_reference): Move re-gimplification
8837 code to ...
8838 (maybe_canonicalize_mem_ref_addr): ... this function.
8839 (fold_stmt_1): Apply it here before all simplification.
8840
8841 2014-08-18 Ilya Enkovich <ilya.enkovich@intel.com>
8842
8843 PR ipa/61800
8844 * cgraph.h (cgraph_node::create_indirect_edge): Add
8845 compute_indirect_info param.
8846 * cgraph.c (cgraph_node::create_indirect_edge): Compute
8847 indirect_info only when it is required.
8848 * cgraphclones.c (cgraph_clone_edge): Do not recompute
8849 indirect_info fore cloned indirect edge.
8850
8851 2014-08-18 Alexander Ivchenko <alexander.ivchenko@intel.com>
8852 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
8853 Anna Tikhonova <anna.tikhonova@intel.com>
8854 Ilya Tocar <ilya.tocar@intel.com>
8855 Andrey Turetskiy <andrey.turetskiy@intel.com>
8856 Ilya Verbin <ilya.verbin@intel.com>
8857 Kirill Yukhin <kirill.yukhin@intel.com>
8858 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
8859
8860 * config/i386/sse.md
8861 (define_mode_iterator VI8_AVX2_AVX512BW): New.
8862 (define_insn "<sse2_avx2>_psadbw"): Add evex version.
8863
8864 2014-08-18 Alexander Ivchenko <alexander.ivchenko@intel.com>
8865 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
8866 Anna Tikhonova <anna.tikhonova@intel.com>
8867 Ilya Tocar <ilya.tocar@intel.com>
8868 Andrey Turetskiy <andrey.turetskiy@intel.com>
8869 Ilya Verbin <ilya.verbin@intel.com>
8870 Kirill Yukhin <kirill.yukhin@intel.com>
8871 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
8872
8873 * config/i386/sse.md
8874 (define_mode_iterator VF1_AVX512VL): New.
8875 (define_insn "ufloatv16siv16sf2<mask_name><round_name>"): Delete.
8876 (define_insn "ufloat<sseintvecmodelower><mode>2<mask_name><round_name>"):
8877 New.
8878
8879 2014-08-18 Alexander Ivchenko <alexander.ivchenko@intel.com>
8880 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
8881 Anna Tikhonova <anna.tikhonova@intel.com>
8882 Ilya Tocar <ilya.tocar@intel.com>
8883 Andrey Turetskiy <andrey.turetskiy@intel.com>
8884 Ilya Verbin <ilya.verbin@intel.com>
8885 Kirill Yukhin <kirill.yukhin@intel.com>
8886 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
8887
8888 * config/i386/i386.c: Rename ufloatv8siv8df_mask to ufloatv8siv8df2_mask.
8889 * config/i386/i386.md
8890 (define_code_iterator any_float): New.
8891 (define_code_attr floatsuffix): New.
8892 * config/i386/sse.md
8893 (define_mode_iterator VF1_128_256VL): New.
8894 (define_mode_iterator VF2_512_256VL): New.
8895 (define_insn "float<si2dfmodelower><mode>2<mask_name>"): Remove unnecessary
8896 TARGET check.
8897 (define_insn "ufloatv8siv8df<mask_name>"): Delete.
8898 (define_insn "<floatsuffix>float<sseintvecmodelower><mode>2<mask_name><round_name>"):
8899 New.
8900 (define_mode_attr qq2pssuff): New.
8901 (define_mode_attr sselongvecmode): New.
8902 (define_mode_attr sselongvecmodelower): New.
8903 (define_mode_attr sseintvecmode3): New.
8904 (define_insn "<floatsuffix>float<sselongvecmodelower><mode>2<mask_name><round_name>"):
8905 New.
8906 (define_insn "*<floatsuffix>floatv2div2sf2"): New.
8907 (define_insn "<floatsuffix>floatv2div2sf2_mask"): New.
8908 (define_insn "ufloat<si2dfmodelower><mode>2<mask_name>"): New.
8909 (define_insn "ufloatv2siv2df2<mask_name>"): New.
8910
8911 2014-08-18 Alexander Ivchenko <alexander.ivchenko@intel.com>
8912 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
8913 Anna Tikhonova <anna.tikhonova@intel.com>
8914 Ilya Tocar <ilya.tocar@intel.com>
8915 Andrey Turetskiy <andrey.turetskiy@intel.com>
8916 Ilya Verbin <ilya.verbin@intel.com>
8917 Kirill Yukhin <kirill.yukhin@intel.com>
8918 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
8919
8920 * config/i386/sse.md
8921 (define_mode_iterator VF2_AVX512VL): New.
8922 (define_mode_attr sseintvecmode2): New.
8923 (define_insn "ufix_truncv2dfv2si2<mask_name>"): Add masking.
8924 (define_insn "fix_truncv4dfv4si2<mask_name>"): New.
8925 (define_insn "ufix_truncv4dfv4si2<mask_name>"): Ditto.
8926 (define_insn
8927 "<fixsuffix>fix_trunc<mode><sseintvecmodelower>2<mask_name><round_saeonly_name>"):
8928 Ditto.
8929 (define_insn "fix_notrunc<mode><sseintvecmodelower>2<mask_name><round_name>"):
8930 Ditto.
8931 (define_insn "ufix_notrunc<mode><sseintvecmodelower>2<mask_name><round_name>"):
8932 Ditto.
8933
8934 2014-08-18 Alexander Ivchenko <alexander.ivchenko@intel.com>
8935 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
8936 Anna Tikhonova <anna.tikhonova@intel.com>
8937 Ilya Tocar <ilya.tocar@intel.com>
8938 Andrey Turetskiy <andrey.turetskiy@intel.com>
8939 Ilya Verbin <ilya.verbin@intel.com>
8940 Kirill Yukhin <kirill.yukhin@intel.com>
8941 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
8942
8943 * config/i386/i386.md
8944 (define_insn "*movoi_internal_avx"): Add evex version.
8945 (define_insn "*movti_internal"): Ditto.
8946
8947 2014-08-18 Alexander Ivchenko <alexander.ivchenko@intel.com>
8948 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
8949 Anna Tikhonova <anna.tikhonova@intel.com>
8950 Ilya Tocar <ilya.tocar@intel.com>
8951 Andrey Turetskiy <andrey.turetskiy@intel.com>
8952 Ilya Verbin <ilya.verbin@intel.com>
8953 Kirill Yukhin <kirill.yukhin@intel.com>
8954 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
8955
8956 * config/i386/i386.md
8957 (define_attr "isa"): Add avx512dq, noavx512dq.
8958 (define_attr "enabled"): Ditto.
8959 * config/i386/sse.md
8960 (define_insn "vec_extract_hi_<mode><mask_name>"): Support masking.
8961
8962 2014-08-18 Alexander Ivchenko <alexander.ivchenko@intel.com>
8963 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
8964 Anna Tikhonova <anna.tikhonova@intel.com>
8965 Ilya Tocar <ilya.tocar@intel.com>
8966 Andrey Turetskiy <andrey.turetskiy@intel.com>
8967 Ilya Verbin <ilya.verbin@intel.com>
8968 Kirill Yukhin <kirill.yukhin@intel.com>
8969 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
8970
8971 * config/i386/i386.c
8972 (ix86_expand_special_args_builtin): Handle avx512vl_storev8sf_mask,
8973 avx512vl_storev8si_mask, avx512vl_storev4df_mask, avx512vl_storev4di_mask,
8974 avx512vl_storev4sf_mask, avx512vl_storev4si_mask, avx512vl_storev2df_mask,
8975 avx512vl_storev2di_mask, avx512vl_loadv8sf_mask, avx512vl_loadv8si_mask,
8976 avx512vl_loadv4df_mask, avx512vl_loadv4di_mask, avx512vl_loadv4sf_mask,
8977 avx512vl_loadv4si_mask, avx512vl_loadv2df_mask, avx512vl_loadv2di_mask,
8978 avx512bw_loadv64qi_mask, avx512vl_loadv32qi_mask, avx512vl_loadv16qi_mask,
8979 avx512bw_loadv32hi_mask, avx512vl_loadv16hi_mask, avx512vl_loadv8hi_mask.
8980 * config/i386/i386.md (define_mode_attr ssemodesuffix): Allow V32HI mode.
8981 * config/i386/sse.md
8982 (define_mode_iterator VMOVE): Allow V4TI mode.
8983 (define_mode_iterator V_AVX512VL): New.
8984 (define_mode_iterator V): New handling for AVX512VL.
8985 (define_insn "avx512f_load<mode>_mask"): Delete.
8986 (define_insn "<avx512>_load<mode>_mask"): New.
8987 (define_insn "avx512f_store<mode>_mask"): Delete.
8988 (define_insn "<avx512>_store<mode>_mask"): New.
8989
8990
8991 2014-08-18 Yury Gribov <y.gribov@samsung.com>
8992
8993 PR sanitizer/62089
8994 * asan.c (instrument_derefs): Fix bitfield check.
8995
8996 2014-08-17 Segher Boessenkool <segher@kernel.crashing.org>
8997
8998 * config/rs6000/constraints.md ("S"): Require TARGET_POWERPC64.
8999 * config/rs6000/htm.md (ttest): Remove clobber.
9000 * config/rs6000/predicates.md (any_mask_operand): New predicate.
9001 (and_operand): Reformat.
9002 (and_2rld_operand): New predicate.
9003 * config/rs6000/rs6000-protos.h (rs6000_split_logical): Remove last
9004 parameter.
9005 * config/rs6000/rs6000.c (rs6000_split_logical_inner): Remove last
9006 parameter. Handle AND directly.
9007 (rs6000_split_logical_di): Remove last parameter.
9008 (rs6000_split_logical): Remove last parameter. Remove obsolete
9009 comment.
9010 * config/rs6000/rs6000.md (BOOL_REGS_AND_CR0): Delete.
9011 (one_cmpl<mode>2): Adjust call of rs6000_split_logical.
9012 (ctz<mode>2, ffs<mode>2): Delete clobber. Reformat.
9013 (andsi3, andsi3_mc, andsi3_nomc, *andsi3_internal2_mc,
9014 *andsi3_internal3_mc, *andsi3_internal4, *andsi3_internal5_mc,
9015 and 5 anonymous splitters): Delete.
9016 (and<mode>3): New expander.
9017 (*and<mode>3, *and<mode>3_dot, *and<mode>3_dot2): New.
9018 (and<mode>3_imm, *and<mode>3_imm_dot, *and<mode>3_imm_dot2): New.
9019 (*and<mode>3_mask, *and<mode>3_mask_dot, *and<mode>3_mask_dot2): New.
9020 (ior<mode>, xor<mode>3): Adjust call of rs6000_split_logical.
9021 (floatdisf2_internal1): Remove clobbers.
9022 (anddi3, anddi3_mc, anddi3_nomc, anddi3_internal2_mc,
9023 *anddi3_internal3_mc, and 4 anonymous splitters): Delete.
9024 (*anddi3_2rld, *anddi3_2rld_dot, *anddi3_2rld_dot2): New.
9025 (and<mode>3 for BOOL_128): Remove clobber.
9026 (*and<mode>3_internal for BOOL_128): Remove clobber. Adjust call of
9027 rs6000_split_logical.
9028 (*bool<mode>3_internal for BOOL_128): Adjust call of
9029 rs6000_split_logical.
9030 (*boolc<mode>3_internal1 for BOOL_128,
9031 *boolc<mode>3_internal2 for BOOL_128,
9032 *boolcc<mode>3_internal1 for BOOL_128,
9033 *boolcc<mode>3_internal2 for BOOL_128,
9034 *eqv<mode>3_internal1 for BOOL_128,
9035 *eqv<mode>3_internal2 for BOOL_128,
9036 *one_cmpl<mode>3_internal for BOOL_128): Ditto.
9037 * config/rs6000/vector.md (*vec_reload_and_plus_<mptrsize): Remove
9038 clobber.
9039 (*vec_reload_and_reg_<mptrsize>): Delete.
9040
9041 2014-08-17 Segher Boessenkool <segher@kernel.crashing.org>
9042
9043 * config/rs6000/rs6000.md (*boolccsi3_internal1, *boolccsi3_internal2
9044 and split, *boolccsi3_internal3 and split): Delete.
9045 (*boolccdi3_internal1, *boolccdi3_internal2 and split,
9046 *boolccdi3_internal3 and split): Delete.
9047 (*boolcc<mode>3, *boolcc<mode>3_dot, *boolcc<mode>3_dot2): New.
9048 (*eqv<mode>3): Move. Add TODO comment. Fix attributes.
9049
9050 2014-08-17 Segher Boessenkool <segher@kernel.crashing.org>
9051
9052 * config/rs6000/rs6000.md (*boolcsi3_internal1, *boolcsi3_internal2
9053 and split, *boolcsi3_internal3 and split): Delete.
9054 (*boolcdi3_internal1, *boolcdi3_internal2 and split,
9055 *boolcdi3_internal3 and split): Delete.
9056 (*boolc<mode>3, *boolc<mode>3_dot, *boolc<mode>3_dot2): New.
9057
9058 2014-08-17 Segher Boessenkool <segher@kernel.crashing.org>
9059
9060 * config/rs6000/rs6000.c (print_operand) <'e'>: New.
9061 <'u'>: Also support printing the low-order 16 bits.
9062 * config/rs6000/rs6000.md (iorsi3, xorsi3, *boolsi3_internal1,
9063 *boolsi3_internal2 and split, *boolsi3_internal3 and split): Delete.
9064 (iordi3, xordi3, *booldi3_internal1, *booldi3_internal2 and split,
9065 *booldi3_internal3 and split): Delete.
9066 (ior<mode>3, xor<mode>3, *bool<mode>3, *bool<mode>3_dot,
9067 *bool<mode>3_dot2): New.
9068 (two anonymous define_splits for non_logical_cint_operand): Merge.
9069
9070 2014-08-17 Marek Polacek <polacek@redhat.com>
9071 Manuel López-Ibáñez <manu@gcc.gnu.org>
9072
9073 PR c/62059
9074 * diagnostic.c (adjust_line): Add gcc_checking_assert.
9075 (diagnostic_show_locus): Don't print caret diagnostic
9076 if a column is larger than the line_width.
9077
9078 2014-08-17 Roman Gareev <gareevroman@gmail.com>
9079
9080 * common.opt: Make the ISL AST generator to be the main code generator
9081 of Graphite.
9082
9083 2014-08-16 Gerald Pfeifer <gerald@pfeifer.com>
9084
9085 * wide-int.h (generic_wide_int): Declare as class instead of struct.
9086
9087 2014-08-16 John David Anglin <danglin@gcc.gnu.org>
9088
9089 PR target/61641
9090 * config/pa/pa-protos.h (pa_output_addr_vec, pa_output_addr_diff_vec):
9091 Declare.
9092 * config/pa/pa.c (pa_reorg): Remove code to insert brtab marker insns.
9093 (pa_output_addr_vec, pa_output_addr_diff_vec): New.
9094 * config/pa/pa.h (ASM_OUTPUT_ADDR_VEC, ASM_OUTPUT_ADDR_DIFF_VEC):
9095 Define.
9096 * config/pa/pa.md (begin_brtab): Delete insn.
9097 (end_brtab): Likewise.
9098
9099 2014-08-16 Manuel López-Ibáñez <manu@gcc.gnu.org>
9100
9101 * doc/cppopts.texi (ftrack-macro-expansion): Add missing @code.
9102
9103 2014-08-15 Jan Hubicka <hubicka@ucw.cz>
9104
9105 * ipa-utils.h (ipa_polymorphic_call_context): Turn into class; add ctors.
9106 (possible_polymorphic_call_targets, dump_possible_polymorphic_call_targets,
9107 possible_polymorphic_call_target_p, possible_polymorphic_call_target_p): Simplify.
9108 (get_dynamic_type): Remove.
9109 * ipa-devirt.c (ipa_dummy_polymorphic_call_context): Remove.
9110 (clear_speculation): Bring to ipa-deivrt.h
9111 (get_class_context): Rename to ...
9112 (ipa_polymorphic_call_context::restrict_to_inner_class): ... this one.
9113 (contains_type_p): Update.
9114 (get_dynamic_type): Rename to ...
9115 ipa_polymorphic_call_context::get_dynamic_type(): ... this one.
9116 (possible_polymorphic_call_targets): UPdate.
9117 * tree-ssa-pre.c (eliminate_dom_walker::before_dom_children): Update.
9118 * ipa-prop.c (ipa_analyze_call_uses): Update.
9119
9120 2014-08-15 Oleg Endo <olegendo@gcc.gnu.org>
9121
9122 * doc/invoke.texi (SH options): Document missing processor variant
9123 options. Remove references to Hitachi. Undocument deprecated mspace
9124 option.
9125
9126 2014-08-15 Jason Merrill <jason@redhat.com>
9127
9128 * tree.c (type_hash_canon): Uncomment assert.
9129
9130 2014-08-15 Manuel López-Ibáñez <manu@gcc.gnu.org>
9131
9132 * input.h (in_system_header_at): Add comment.
9133
9134 2014-08-15 Manuel López-Ibáñez <manu@gcc.gnu.org>
9135
9136 PR fortran/44054
9137 * diagnostic.c (build_message_string): Make it extern.
9138 * diagnostic.h (build_message_string): Make it extern.
9139
9140 2014-08-15 Vladimir Makarov <vmakarov@redhat.com>
9141
9142 * config/rs6000/rs6000.c (rs6000_emit_move): Use SDmode for
9143 load/store from/to non-floating class pseudo.
9144
9145 2014-08-15 Manuel López-Ibáñez <manu@gcc.gnu.org>
9146
9147 * input.c (diagnostic_file_cache_fini): Fix typo in comment.
9148
9149 2014-08-15 Richard Biener <rguenther@suse.de>
9150
9151 * tree-ssa-structalias.c (readonly_id): Rename to string_id.
9152 (get_constraint_for_ssa_var): Remove dead code.
9153 (get_constraint_for_1): Adjust.
9154 (find_what_var_points_to): Likewise.
9155 (init_base_vars): Likewise. STRING_CSTs do not contain pointers.
9156
9157 2014-08-15 Ilya Tocar <tocarip@gmail.com>
9158
9159 PR target/61878
9160 * config/i386/avx512fintrin.h (_mm512_mask_cmpge_epi32_mask): New.
9161 (_mm512_mask_cmpge_epu32_mask): Ditto.
9162 (_mm512_cmpge_epu32_mask): Ditto.
9163 (_mm512_mask_cmpge_epi64_mask): Ditto.
9164 (_mm512_cmpge_epi64_mask): Ditto.
9165 (_mm512_mask_cmpge_epu64_mask): Ditto.
9166 (_mm512_cmpge_epu64_mask): Ditto.
9167 (_mm512_mask_cmple_epi32_mask): Ditto.
9168 (_mm512_cmple_epi32_mask): Ditto.
9169 (_mm512_mask_cmple_epu32_mask): Ditto.
9170 (_mm512_cmple_epu32_mask): Ditto.
9171 (_mm512_mask_cmple_epi64_mask): Ditto.
9172 (_mm512_cmple_epi64_mask): Ditto.
9173 (_mm512_mask_cmple_epu64_mask): Ditto.
9174 (_mm512_cmple_epu64_mask): Ditto.
9175 (_mm512_mask_cmplt_epi32_mask): Ditto.
9176 (_mm512_cmplt_epi32_mask): Ditto.
9177 (_mm512_mask_cmplt_epu32_mask): Ditto.
9178 (_mm512_cmplt_epu32_mask): Ditto.
9179 (_mm512_mask_cmplt_epi64_mask): Ditto.
9180 (_mm512_cmplt_epi64_mask): Ditto.
9181 (_mm512_mask_cmplt_epu64_mask): Ditto.
9182 (_mm512_cmplt_epu64_mask): Ditto.
9183 (_mm512_mask_cmpneq_epi32_mask): Ditto.
9184 (_mm512_mask_cmpneq_epu32_mask): Ditto.
9185 (_mm512_cmpneq_epu32_mask): Ditto.
9186 (_mm512_mask_cmpneq_epi64_mask): Ditto.
9187 (_mm512_cmpneq_epi64_mask): Ditto.
9188 (_mm512_mask_cmpneq_epu64_mask): Ditto.
9189 (_mm512_cmpneq_epu64_mask): Ditto.
9190 (_mm512_castpd_ps): Ditto.
9191 (_mm512_castpd_si512): Ditto.
9192 (_mm512_castps_pd): Ditto.
9193 (_mm512_castps_si512): Ditto.
9194 (_mm512_castsi512_ps): Ditto.
9195 (_mm512_castsi512_pd): Ditto.
9196 (_mm512_castpd512_pd128): Ditto.
9197 (_mm512_castps512_ps128): Ditto.
9198 (_mm512_castsi512_si128): Ditto.
9199 (_mm512_castpd512_pd256): Ditto.
9200 (_mm512_castps512_ps256): Ditto.
9201 (_mm512_castsi512_si256): Ditto.
9202 (_mm512_castpd128_pd512): Ditto.
9203 (_mm512_castps128_ps512): Ditto.
9204 (_mm512_castsi128_si512): Ditto.
9205 (_mm512_castpd256_pd512): Ditto.
9206 (_mm512_castps256_ps512): Ditto.
9207 (_mm512_castsi256_si512): Ditto.
9208 (_mm512_cmpeq_epu32_mask): Ditto.
9209 (_mm512_mask_cmpeq_epu32_mask): Ditto.
9210 (_mm512_mask_cmpeq_epu64_mask): Ditto.
9211 (_mm512_cmpeq_epu64_mask): Ditto.
9212 (_mm512_cmpgt_epu32_mask): Ditto.
9213 (_mm512_mask_cmpgt_epu32_mask): Ditto.
9214 (_mm512_mask_cmpgt_epu64_mask): Ditto.
9215 (_mm512_cmpgt_epu64_mask): Ditto.
9216 * config/i386/i386-builtin-types.def: Add V16SF_FTYPE_V8SF,
9217 V16SI_FTYPE_V8SI, V16SI_FTYPE_V4SI, V8DF_FTYPE_V2DF.
9218 * config/i386/i386.c (enum ix86_builtins): Add
9219 IX86_BUILTIN_SI512_SI256, IX86_BUILTIN_PD512_PD256,
9220 IX86_BUILTIN_PS512_PS256, IX86_BUILTIN_SI512_SI,
9221 IX86_BUILTIN_PD512_PD, IX86_BUILTIN_PS512_PS.
9222 (bdesc_args): Add __builtin_ia32_si512_256si,
9223 __builtin_ia32_ps512_256ps, __builtin_ia32_pd512_256pd,
9224 __builtin_ia32_si512_si, __builtin_ia32_ps512_ps,
9225 __builtin_ia32_pd512_pd.
9226 (ix86_expand_args_builtin): Handle new FTYPEs.
9227 * config/i386/sse.md (castmode): Add 512-bit modes.
9228 (AVX512MODE2P): New.
9229 (avx512f_<castmode><avxsizesuffix>_<castmode): New.
9230 (avx512f_<castmode><avxsizesuffix>_256<castmode): Ditto.
9231
9232 2014-08-15 Richard Biener <rguenther@suse.de>
9233
9234 * fold-const.c (tree_swap_operands_p): Put all constants
9235 last, also strip sign-changing NOPs when considering further
9236 canonicalization. Canonicalize also when optimizing for size.
9237
9238 2014-08-15 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
9239
9240 * config/aarch64/aarch64.c (aarch64_expand_mov_immediate): Move
9241 one_match > zero_match case to just before simple_sequence.
9242
9243 2014-08-15 Richard Biener <rguenther@suse.de>
9244
9245 * data-streamer.h (streamer_string_index, string_for_index):
9246 Remove.
9247 * data-streamer-out.c (streamer_string_index): Make static.
9248 * data-streamer-in.c (string_for_index): Likewise.
9249 * lto-streamer-out.c (lto_output_location): Use bp_pack_string.
9250 * lto-streamer-in.c (lto_input_location): Use bp_unpack_string.
9251
9252 2014-08-15 Richard Biener <rguenther@suse.de>
9253
9254 PR tree-optimization/62031
9255 * tree-data-ref.c (dr_analyze_indices): Do not set
9256 DR_UNCONSTRAINED_BASE.
9257 (dr_may_alias_p): All indirect accesses have to go the
9258 formerly DR_UNCONSTRAINED_BASE path.
9259 * tree-data-ref.h (struct indices): Remove
9260 unconstrained_base member.
9261 (DR_UNCONSTRAINED_BASE): Remove.
9262
9263 2014-08-15 Jakub Jelinek <jakub@redhat.com>
9264
9265 PR middle-end/62092
9266 * gimplify.c (gimplify_adjust_omp_clauses_1): Don't remove
9267 OMP_CLAUSE_SHARED for global vars if the global var is mentioned
9268 in OMP_CLAUSE_MAP in some outer target region.
9269
9270 2014-08-15 Bin Cheng <bin.cheng@arm.com>
9271
9272 * tree-ssa-loop-ivopts.c (ivopts_data): New field
9273 name_expansion_cache.
9274 (tree_ssa_iv_optimize_init): Initialize name_expansion_cache.
9275 (tree_ssa_iv_optimize_finalize): Free name_expansion_cache.
9276 (strip_wrap_conserving_type_conversions, expr_equal_p): Delete.
9277 (difference_cannot_overflow_p): New parameter. Use affine
9278 expansion for equality check.
9279 (iv_elimination_compare_lt): Pass new argument.
9280
9281 2014-08-14 DJ Delorie <dj@redhat.com>
9282
9283 * config/rl78/rl78-real.md (addqi3_real): Allow adding global
9284 variables to the accumulator.
9285
9286 * config/rl78/predicates.md (rl78_near_mem_operand): New.
9287 * config/rl78/rl78-virt.md (movqi_virt_mm, movqi_virt)
9288 (movhi_virt_mm): Split out near mem-mem moves to avoid problems
9289 with far-far moves.
9290
9291 * config/rl78/rl78-expand.md (umulqihi3): Disable for G10.
9292 * config/rl78/rl78-virt.md (umulhi3_shift_virt): Likewise.
9293 (umulqihi3_virt): Likewise.
9294 * config/rl78/rl78-real.md (umulhi3_shift_real): Likewise.
9295 (umulqihi3_real): Likewise.
9296
9297 * config/rl78/rl78-virt.md (movhi_virt): Allow const->far moves.
9298
9299 2014-08-14 Jan Hubicka <hubicka@ucw.cz>
9300
9301 PR tree-optimization/62091
9302 * tree-ssa-alias.c (walk_aliased_vdefs_1): Do not clear
9303 function_entry_reached.
9304 (walk_aliased_vdefs): Clear it here.
9305 * ipa-devirt.c (check_stmt_for_type_change): Handle static storage.
9306
9307 2014-08-14 Jan Hubicka <hubicka@ucw.cz>
9308
9309 * ipa-utils.h (compare_virtual_tables): Declare.
9310 * ipa-devirt.c (odr_subtypes_equivalent_p): New function
9311
9312 2014-08-14 Marek Polacek <polacek@redhat.com>
9313
9314 DR 458
9315 * ginclude/stdatomic.h (__atomic_type_lock_free): Remove.
9316 (ATOMIC_*_LOCK_FREE): Map to __GCC_ATOMIC_*_LOCK_FREE.
9317
9318 2014-08-14 Tom de Vries <tom@codesourcery.com>
9319
9320 * emit-rtl.h (mem_attrs_eq_p): Remove duplicate declaration.
9321
9322 2014-08-14 Tom de Vries <tom@codesourcery.com>
9323
9324 PR rtl-optimization/62004
9325 PR rtl-optimization/62030
9326 * ifcvt.c (rtx_interchangeable_p): New function.
9327 (noce_try_move, noce_process_if_block): Use rtx_interchangeable_p.
9328 * emit-rtl.h (mem_attrs_eq_p): Declare.
9329
9330 2014-08-14 Roman Gareev <gareevroman@gmail.com>
9331
9332 * graphite-scop-detection.c:
9333 Add inclusion of cp-tree.h.
9334 (graphite_can_represent_scev): Disables the handling of SSA_NAME nodes
9335 in case they are pointers to object types
9336
9337 2014-08-14 Richard Biener <rguenther@suse.de>
9338
9339 * BASE-VER: Change to 5.0.0
9340
9341 2014-08-14 Alexander Ivchenko <alexander.ivchenko@intel.com>
9342 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
9343 Anna Tikhonova <anna.tikhonova@intel.com>
9344 Ilya Tocar <ilya.tocar@intel.com>
9345 Andrey Turetskiy <andrey.turetskiy@intel.com>
9346 Ilya Verbin <ilya.verbin@intel.com>
9347 Kirill Yukhin <kirill.yukhin@intel.com>
9348 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
9349
9350 * config/i386/sse.md (define_mode_attr avx512): New.
9351 (define_mode_attr sse2_avx_avx512f): Allow V8HI, V16HI, V32HI, V2DI,
9352 V4DI modes.
9353 (define_mode_attr sse2_avx2): Allow V64QI, V32HI, V4TI modes.
9354 (define_mode_attr ssse3_avx2): Ditto.
9355 (define_mode_attr sse4_1_avx2): Allow V64QI, V32HI, V8DI modes.
9356 (define_mode_attr avx2_avx512bw): New.
9357 (define_mode_attr ssedoublemodelower): New.
9358 (define_mode_attr ssedoublemode): Allow V8SF, V8SI, V4DI, V4DF, V4SI,
9359 V32HI, V64QI modes.
9360 (define_mode_attr ssebytemode): Allow V8DI modes.
9361 (define_mode_attr sseinsnmode): Allow V4TI, V32HI, V64QI modes.
9362 (define_mode_attr sseintvecmodelower): Allow V8DF, V4TI modes.
9363 (define_mode_attr ssePSmode2): New.
9364 (define_mode_attr ssescalarsize): Allow V64QI, V32QI, V16QI, V8HI,
9365 V16HI, V32HI modes.
9366 (define_mode_attr dbpsadbwmode): New.
9367 (define_mode_attr bcstscalarsuff): Allow V64QI, V32QI, V16QI, V32HI,
9368 V16HI, V8HI, V8SI, V4SI, V4DI, V2DI, V8SF, V4SF, V4DF, V2DF modes.
9369 (vi8_sse4_1_avx2_avx512): New.
9370 (define_insn <sse4_1_avx2>_movntdqa): Use <vi8_sse4_1_avx2_avx512>
9371 mode attribute.
9372 (define_mode_attr blendbits): Move before its immediate use.
9373
9374 2014-08-14 Alexander Ivchenko <alexander.ivchenko@intel.com>
9375 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
9376 Anna Tikhonova <anna.tikhonova@intel.com>
9377 Ilya Tocar <ilya.tocar@intel.com>
9378 Andrey Turetskiy <andrey.turetskiy@intel.com>
9379 Ilya Verbin <ilya.verbin@intel.com>
9380 Kirill Yukhin <kirill.yukhin@intel.com>
9381 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
9382
9383 * config/i386/sse.md: Allow V64QI, V32QI, V32HI, V4HI modes.
9384 * config/i386/subst.md
9385 (define_mode_iterator SUBST_V): Update.
9386 (define_mode_iterator SUBST_A): Ditto.
9387 (define_subst_attr "mask_operand7"): New.
9388 (define_subst_attr "mask_operand10"): New.
9389 (define_subst_attr "mask_operand_arg34") : New.
9390 (define_subst_attr "mask_expand_op3"): New.
9391 (define_subst_attr "mask_mode512bit_condition"): Handle TARGET_AVX512VL.
9392 (define_subst_attr "sd_mask_mode512bit_condition"): Ditto.
9393 (define_subst_attr "mask_avx512vl_condition"): New.
9394 (define_subst_attr "round_mask_operand4"): Ditto.
9395 (define_subst_attr "round_mask_scalar_op3"): Delete.
9396 (define_subst_attr "round_mask_op4"): New.
9397 (define_subst_attr "round_mode512bit_condition"): Allow V8DImode,
9398 V16SImode.
9399 (define_subst_attr "round_modev8sf_condition"): New.
9400 (define_subst_attr "round_modev4sf_condition"): GET_MODE instead of
9401 <MODE>mode.
9402 (define_subst_attr "round_saeonly_mask_operand4"): New.
9403 (define_subst_attr "round_saeonly_mask_op4"): New.
9404 (define_subst_attr "round_saeonly_mode512bit_condition"): Allow
9405 V8DImode, V16SImode.
9406 (define_subst_attr "round_saeonly_modev8sf_condition"): New.
9407 (define_subst_attr "mask_expand4_name" "mask_expand4"): New.
9408 (define_subst_attr "mask_expand4_args"): New.
9409 (define_subst "mask_expand4"): New.
9410
9411 2014-08-14 Alexander Ivchenko <alexander.ivchenko@intel.com>
9412 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
9413 Anna Tikhonova <anna.tikhonova@intel.com>
9414 Ilya Tocar <ilya.tocar@intel.com>
9415 Andrey Turetskiy <andrey.turetskiy@intel.com>
9416 Ilya Verbin <ilya.verbin@intel.com>
9417 Kirill Yukhin <kirill.yukhin@intel.com>
9418 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
9419
9420 * config/i386/i386.md
9421 (define_attr "isa"): Add avx512bw,noavx512bw.
9422 (define_attr "enabled"): Ditto.
9423 (define_split): Add 32/64-bit mask logic.
9424 (define_insn "*k<logic>qi"): New.
9425 (define_insn "*k<logic>hi"): New.
9426 (define_insn "*anddi_1"): Add mask version.
9427 (define_insn "*andsi_1"): Ditto.
9428 (define_insn "*<code><mode>_1"): Ditto.
9429 (define_insn "*<code>hi_1"): Ditto.
9430 (define_insn "kxnor<mode>"): New.
9431 (define_insn "kunpcksi"): New.
9432 (define_insn "kunpckdi"): New.
9433 (define_insn "*one_cmpl<mode>2_1"): Add mask version.
9434 (define_insn "*one_cmplhi2_1"): Ditto.
9435
9436 2014-08-14 Alexander Ivchenko <alexander.ivchenko@intel.com>
9437 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
9438 Anna Tikhonova <anna.tikhonova@intel.com>
9439 Ilya Tocar <ilya.tocar@intel.com>
9440 Andrey Turetskiy <andrey.turetskiy@intel.com>
9441 Ilya Verbin <ilya.verbin@intel.com>
9442 Kirill Yukhin <kirill.yukhin@intel.com>
9443 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
9444
9445 * config/i386/i386.c (ix86_preferred_simd_mode): Allow V64QImode and
9446 V32HImode.
9447
9448 2014-08-14 Alexander Ivchenko <alexander.ivchenko@intel.com>
9449 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
9450 Anna Tikhonova <anna.tikhonova@intel.com>
9451 Ilya Tocar <ilya.tocar@intel.com>
9452 Andrey Turetskiy <andrey.turetskiy@intel.com>
9453 Ilya Verbin <ilya.verbin@intel.com>
9454 Kirill Yukhin <kirill.yukhin@intel.com>
9455 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
9456
9457 * config/i386/i386.c (print_reg): Сorrectly print 64-bit mask
9458 registers.
9459 (inline_secondary_memory_needed): Allow 64 bit wide mask registers.
9460 (ix86_hard_regno_mode_ok): Allow 32/64-bit mask registers and
9461 xmm/ymm16+ when availble.
9462 * config/i386/i386.h
9463 (HARD_REGNO_NREGS): Add mask regs.
9464 (VALID_AVX512F_REG_MODE): Ditto.
9465 (VALID_AVX512F_REG_MODE) : Define.
9466 (VALID_MASK_AVX512BW_MODE): Ditto.
9467 (reg_class) (MASK_REG_P(X)): Define.
9468 * config/i386/i386.md: Do not split long moves with mask register,
9469 use kmovb if avx512bw is availible.
9470 (movdi_internal): Handle mask registers.
9471
9472 2014-08-14 Richard Biener <rguenther@suse.de>
9473
9474 PR tree-optimization/62081
9475 * tree-ssa-loop.c (pass_fix_loops): New pass.
9476 (pass_tree_loop::gate): Do not fixup loops here.
9477 * tree-pass.h (make_pass_fix_loops): Declare.
9478 * passes.def: Schedule pass_fix_loops before GIMPLE loop passes.
9479
9480 2014-08-14 Richard Biener <rguenther@suse.de>
9481
9482 * tree.c (type_hash_lookup, type_hash_add): Merge into ...
9483 (type_hash_canon): ... this and avoid 2nd lookup for the add.
9484
9485 2014-08-14 Richard Biener <rguenther@suse.de>
9486
9487 PR tree-optimization/62090
9488 * builtins.c (fold_builtin_sprintf): Move to gimple-fold.c.
9489 (fold_builtin_2): Do not fold sprintf.
9490 (fold_builtin_3): Likewise.
9491 * gimple-fold.c (gimple_fold_builtin_sprintf): New function
9492 moved from builtins.c.
9493 (gimple_fold_builtin): Fold sprintf.
9494
9495 2014-08-14 Richard Biener <rguenther@suse.de>
9496
9497 PR rtl-optimization/62079
9498 * recog.c (peephole2_optimize): If peep2_do_cleanup_cfg
9499 run cleanup_cfg.
9500
9501 2014-08-14 Ilya Enkovich <ilya.enkovich@intel.com>
9502
9503 * ipa-devirt.c (get_polymorphic_call_info): Use fndecl instead of
9504 current_function_decl.
9505
9506 2014-08-14 Ilya Enkovich <ilya.enkovich@intel.com>
9507
9508 * cgraph.c (cgraph_node::function_symbol): Fix wrong
9509 cgraph_function_node to cgraph_node::function_symbol
9510 refactoring.
9511
9512 2014-08-14 Zhenqiang Chen <zhenqiang.chen@arm.com>
9513
9514 * config/arm/arm.c (arm_option_override): Set max_insns_skipped
9515 to MAX_INSN_PER_IT_BLOCK when optimize_size for THUMB2.
9516
9517 2014-08-13 Chen Gang gang.chen.5i5j@gmail.com
9518
9519 * microblaze/microblaze.md: Remove redundant '@' to avoid compiling
9520 warning.
9521
9522 2014-08-13 Roman Gareev <gareevroman@gmail.com>
9523
9524 * gcc.dg/graphite/pr35356-2.c: Update according to the ISL code
9525 generator.
9526
9527 2014-08-12 Jakub Jelinek <jakub@redhat.com>
9528
9529 PR target/62025
9530 * sched-deps.c (find_inc): Check if inc_insn doesn't clobber
9531 any registers that are used in mem_insn.
9532
9533 2014-08-12 Steve Ellcey <sellcey@mips.com>
9534
9535 * config/mips/mips.h (ASM_SPEC): Pass float options to assembler.
9536
9537 2014-08-12 Steve Ellcey <sellcey@mips.com>
9538
9539 * config/mips/t-mti-elf (MULTILIB_OPTIONS): Remove fp64 multilib.
9540 (MULTILIB_DIRNAMES): Ditto.
9541 * config/mips/t-mti-elf (MULTILIB_OPTIONS): Ditto.
9542 * config/mips/t-mti-elf (MULTILIB_EXCEPTIONS): Ditto.
9543 * config/mips/t-mti-linux (MULTILIB_OPTIONS): Ditto.
9544 * config/mips/t-mti-linux (MULTILIB_DIRNAMES): Ditto.
9545 * config/mips/t-mti-linux (MULTILIB_EXCEPTIONS): Ditto.
9546 * config/mips/mti-linux.h (SYSROOT_SUFFIX_SPEC): Ditto.
9547
9548 2014-08-12 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
9549
9550 PR target/61413
9551 * config/arm/arm.h (TARGET_CPU_CPP_BUILTINS): Fix definition
9552 of __ARM_SIZEOF_WCHAR_T.
9553
9554 2014-08-12 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
9555
9556 PR target/62098
9557 * config/arm/vfp.md (*combine_vcvtf2i): Fix constraint.
9558 Remove unnecessary attributes.
9559
9560 2014-08-12 Yury Gribov <y.gribov@samsung.com>
9561
9562 * internal-fn.c (init_internal_fns): Fix off-by-one.
9563
9564 2014-08-12 Alexander Ivchenko <alexander.ivchenko@intel.com>
9565 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
9566 Anna Tikhonova <anna.tikhonova@intel.com>
9567 Ilya Tocar <ilya.tocar@intel.com>
9568 Andrey Turetskiy <andrey.turetskiy@intel.com>
9569 Ilya Verbin <ilya.verbin@intel.com>
9570 Kirill Yukhin <kirill.yukhin@intel.com>
9571 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
9572
9573 * config/i386/i386.c (standard_sse_constant_opcode): Use
9574 vpxord/vpternlog if avx512 is availible.
9575
9576 2014-08-12 Thomas Preud'homme <thomas.preudhomme@arm.com>
9577
9578 PR middle-end/62103
9579 * gimple-fold.c (fold_ctor_reference): Don't fold in presence of
9580 bitfields, that is when size doesn't match the size of type or the
9581 size of the constructor.
9582
9583 2014-08-11 Michael Meissner <meissner@linux.vnet.ibm.com>
9584
9585 * config/rs6000/constraints.md (wh constraint): New constraint,
9586 for FP registers if direct move is available.
9587 (wi constraint): New constraint, for VSX/FP registers that can
9588 handle 64-bit integers.
9589 (wj constraint): New constraint for VSX/FP registers that can
9590 handle 64-bit integers for direct moves.
9591 (wk constraint): New constraint for VSX/FP registers that can
9592 handle 64-bit doubles for direct moves.
9593 (wy constraint): Make documentation match implementation.
9594
9595 * config/rs6000/rs6000.c (struct rs6000_reg_addr): Add
9596 scalar_in_vmx_p field to simplify tests of whether SFmode or
9597 DFmode can go in the Altivec registers.
9598 (rs6000_hard_regno_mode_ok): Use scalar_in_vmx_p field.
9599 (rs6000_setup_reg_addr_masks): Likewise.
9600 (rs6000_debug_print_mode): Add debug support for scalar_in_vmx_p
9601 field, and wh/wi/wj/wk constraints.
9602 (rs6000_init_hard_regno_mode_ok): Setup scalar_in_vmx_p field, and
9603 the wh/wi/wj/wk constraints.
9604 (rs6000_preferred_reload_class): If SFmode/DFmode can go in the
9605 upper registers, prefer VSX registers unless the operation is a
9606 memory operation with REG+OFFSET addressing.
9607
9608 * config/rs6000/vsx.md (VSr mode attribute): Add support for
9609 DImode. Change SFmode to use ww constraint instead of d to allow
9610 SF registers in the upper registers.
9611 (VSr2): Likewise.
9612 (VSr3): Likewise.
9613 (VSr5): Fix thinko in comment.
9614 (VSa): New mode attribute that is an alternative to wa, that
9615 returns the VSX register class that a mode can go in, but may not
9616 be the preferred register class.
9617 (VS_64dm): New mode attribute for appropriate register classes for
9618 referencing 64-bit elements of vectors for direct moves and normal
9619 moves.
9620 (VS_64reg): Likewise.
9621 (vsx_mov<mode>): Change wa constraint to <VSa> to limit the
9622 register allocator to only registers the data type can handle.
9623 (vsx_le_perm_load_<mode>): Likewise.
9624 (vsx_le_perm_store_<mode>): Likewise.
9625 (vsx_xxpermdi2_le_<mode>): Likewise.
9626 (vsx_xxpermdi4_le_<mode>): Likewise.
9627 (vsx_lxvd2x2_le_<mode>): Likewise.
9628 (vsx_lxvd2x4_le_<mode>): Likewise.
9629 (vsx_stxvd2x2_le_<mode>): Likewise.
9630 (vsx_add<mode>3): Likewise.
9631 (vsx_sub<mode>3): Likewise.
9632 (vsx_mul<mode>3): Likewise.
9633 (vsx_div<mode>3): Likewise.
9634 (vsx_tdiv<mode>3_internal): Likewise.
9635 (vsx_fre<mode>2): Likewise.
9636 (vsx_neg<mode>2): Likewise.
9637 (vsx_abs<mode>2): Likewise.
9638 (vsx_nabs<mode>2): Likewise.
9639 (vsx_smax<mode>3): Likewise.
9640 (vsx_smin<mode>3): Likewise.
9641 (vsx_sqrt<mode>2): Likewise.
9642 (vsx_rsqrte<mode>2): Likewise.
9643 (vsx_tsqrt<mode>2_internal): Likewise.
9644 (vsx_fms<mode>4): Likewise.
9645 (vsx_nfma<mode>4): Likewise.
9646 (vsx_eq<mode>): Likewise.
9647 (vsx_gt<mode>): Likewise.
9648 (vsx_ge<mode>): Likewise.
9649 (vsx_eq<mode>_p): Likewise.
9650 (vsx_gt<mode>_p): Likewise.
9651 (vsx_ge<mode>_p): Likewise.
9652 (vsx_xxsel<mode>): Likewise.
9653 (vsx_xxsel<mode>_uns): Likewise.
9654 (vsx_copysign<mode>3): Likewise.
9655 (vsx_float<VSi><mode>2): Likewise.
9656 (vsx_floatuns<VSi><mode>2): Likewise.
9657 (vsx_fix_trunc<mode><VSi>2): Likewise.
9658 (vsx_fixuns_trunc<mode><VSi>2): Likewise.
9659 (vsx_x<VSv>r<VSs>i): Likewise.
9660 (vsx_x<VSv>r<VSs>ic): Likewise.
9661 (vsx_btrunc<mode>2): Likewise.
9662 (vsx_b2trunc<mode>2): Likewise.
9663 (vsx_floor<mode>2): Likewise.
9664 (vsx_ceil<mode>2): Likewise.
9665 (vsx_<VS_spdp_insn>): Likewise.
9666 (vsx_xscvspdp): Likewise.
9667 (vsx_xvcvspuxds): Likewise.
9668 (vsx_float_fix_<mode>2): Likewise.
9669 (vsx_set_<mode>): Likewise.
9670 (vsx_extract_<mode>_internal1): Likewise.
9671 (vsx_extract_<mode>_internal2): Likewise.
9672 (vsx_extract_<mode>_load): Likewise.
9673 (vsx_extract_<mode>_store): Likewise.
9674 (vsx_splat_<mode>): Likewise.
9675 (vsx_xxspltw_<mode>): Likewise.
9676 (vsx_xxspltw_<mode>_direct): Likewise.
9677 (vsx_xxmrghw_<mode>): Likewise.
9678 (vsx_xxmrglw_<mode>): Likewise.
9679 (vsx_xxsldwi_<mode>): Likewise.
9680 (vsx_xscvdpspn): Tighten constraints to only use register classes
9681 the types use.
9682 (vsx_xscvspdpn): Likewise.
9683 (vsx_xscvdpspn_scalar): Likewise.
9684
9685 * config/rs6000/rs6000.h (enum rs6000_reg_class_enum): Add wh, wi,
9686 wj, and wk constraints.
9687 (GPR_REG_CLASS_P): New helper macro for register classes targeting
9688 general purpose registers.
9689
9690 * config/rs6000/rs6000.md (f32_dm): Use wh constraint for SDmode
9691 direct moves.
9692 (zero_extendsidi2_lfiwz): Use wj constraint for direct move of
9693 DImode instead of wm. Use wk constraint for direct move of DFmode
9694 instead of wm.
9695 (extendsidi2_lfiwax): Likewise.
9696 (lfiwax): Likewise.
9697 (lfiwzx): Likewise.
9698 (movdi_internal64): Likewise.
9699
9700 * doc/md.texi (PowerPC and IBM RS6000): Document wh, wi, wj, and
9701 wk constraints. Make the wy constraint documentation match them
9702 implementation.
9703
9704 2014-08-11 Mircea Namolaru <mircea.namolaru@inria.fr>
9705
9706 Replacement of isl_int by isl_val
9707 * graphite-clast-to-gimple.c: include isl/val.h, isl/val_gmp.h
9708 (compute_bounds_for_param): use isl_val instead of isl_int
9709 (compute_bounds_for_loop): likewise
9710 * graphite-interchange.c: include isl/val.h, isl/val_gmp.h
9711 (build_linearized_memory_access): use isl_val instead of isl_int
9712 (pdr_stride_in_loop): likewise
9713 * graphite-optimize-isl.c:
9714 (getPrevectorMap): use isl_val instead of isl_int
9715 * graphite-poly.c:
9716 (pbb_number_of_iterations_at_time): use isl_val instead of isl_int
9717 graphite-sese-to-poly.c: include isl/val.h, isl/val_gmp.h
9718 (extern the_isl_ctx): declare
9719 (build_pbb_scattering_polyhedrons): use isl_val instead of isl_int
9720 (extract_affine_gmp): likewise
9721 (wrap): likewise
9722 (build_loop_iteration_domains): likewise
9723 (add_param_constraints): likewise
9724
9725 2014-08-11 Richard Biener <rguenther@suse.de>
9726
9727 PR tree-optimization/62075
9728 * tree-vect-slp.c (vect_detect_hybrid_slp_stmts): Properly
9729 handle uses in patterns.
9730
9731 2014-08-11 Alexander Ivchenko <alexander.ivchenko@intel.com>
9732 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
9733 Anna Tikhonova <anna.tikhonova@intel.com>
9734 Ilya Tocar <ilya.tocar@intel.com>
9735 Andrey Turetskiy <andrey.turetskiy@intel.com>
9736 Ilya Verbin <ilya.verbin@intel.com>
9737 Kirill Yukhin <kirill.yukhin@intel.com>
9738 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
9739
9740 * common/config/i386/i386-common.c
9741 (OPTION_MASK_ISA_AVX512VL_SET): Define.
9742 (OPTION_MASK_ISA_AVX512F_UNSET): Update.
9743 (ix86_handle_option): Handle OPT_mavx512vl.
9744 * config/i386/cpuid.h (bit_AVX512VL): Define.
9745 * config/i386/driver-i386.c (host_detect_local_cpu): Detect avx512vl,
9746 set -mavx512vl accordingly.
9747 * config/i386/i386-c.c (ix86_target_macros_internal): Handle
9748 OPTION_MASK_ISA_AVX512VL.
9749 * config/i386/i386.c (ix86_target_string): Handle -mavx512vl.
9750 (ix86_option_override_internal): Define PTA_AVX512VL, handle
9751 PTA_AVX512VL and OPTION_MASK_ISA_AVX512VL.
9752 (ix86_valid_target_attribute_inner_p): Handle OPT_mavx512vl.
9753 * config/i386/i386.h (TARGET_AVX512VL): Define.
9754 (TARGET_AVX512VL_P(x)): Ditto.
9755 * config/i386/i386.opt: Add mavx512vl.
9756
9757 2014-08-11 Felix Yang <fei.yang0953@gmail.com>
9758
9759 PR tree-optimization/62073
9760 * tree-vect-loop.c (vect_is_simple_reduction_1): Check that DEF1 has
9761 a basic block.
9762
9763 2014-08-11 Alexander Ivchenko <alexander.ivchenko@intel.com>
9764 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
9765 Anna Tikhonova <anna.tikhonova@intel.com>
9766 Ilya Tocar <ilya.tocar@intel.com>
9767 Andrey Turetskiy <andrey.turetskiy@intel.com>
9768 Ilya Verbin <ilya.verbin@intel.com>
9769 Kirill Yukhin <kirill.yukhin@intel.com>
9770 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
9771
9772 * common/config/i386/i386-common.c
9773 (OPTION_MASK_ISA_AVX512BW_SET) : Define.
9774 (OPTION_MASK_ISA_AVX512BW_UNSET): Ditto.
9775 (OPTION_MASK_ISA_AVX512VL_UNSET) : Ditto.
9776 (ix86_handle_option): Handle OPT_mavx512bw.
9777 * config/i386/cpuid.h (bit_AVX512BW): Define.
9778 * config/i386/driver-i386.c (host_detect_local_cpu): Detect avx512bw,
9779 set -mavx512bw accordingly.
9780 * config/i386/i386-c.c (ix86_target_macros_internal): Handle
9781 OPTION_MASK_ISA_AVX512BW.
9782 * config/i386/i386.c (ix86_target_string): Handle -mavx512bw.
9783 (ix86_option_override_internal): Define PTA_AVX512BW, handle
9784 PTA_AVX512BW and OPTION_MASK_ISA_AVX512BW.
9785 (ix86_valid_target_attribute_inner_p): Handle OPT_mavx512bw.
9786 * config/i386/i386.h (TARGET_AVX512BW): Define.
9787 (TARGET_AVX512BW_P(x)): Ditto.
9788 * config/i386/i386.opt: Add mavx512bw.
9789
9790 2014-08-11 Richard Biener <rguenther@suse.de>
9791
9792 PR tree-optimization/62070
9793 * tree-ssa-loop-manip.c (gimple_duplicate_loop_to_header_edge):
9794 Remove SSA checking.
9795
9796 2014-08-11 Yury Gribov <y.gribov@samsung.com>
9797
9798 * asan.c (asan_check_flags): New enum.
9799 (build_check_stmt_with_calls): Removed function.
9800 (build_check_stmt): Split inlining logic to
9801 asan_expand_check_ifn.
9802 (instrument_derefs): Rename parameter.
9803 (instrument_mem_region_access): Rename parameter.
9804 (instrument_strlen_call): Likewise.
9805 (asan_expand_check_ifn): New function.
9806 (asan_instrument): Remove old code.
9807 (pass_sanopt::execute): Change handling of
9808 asan-instrumentation-with-call-threshold.
9809 (asan_clear_shadow): Fix formatting.
9810 (asan_function_start): Likewise.
9811 (asan_emit_stack_protection): Likewise.
9812 * doc/invoke.texi (asan-instrumentation-with-call-threshold):
9813 Update description.
9814 * internal-fn.c (expand_ASAN_CHECK): New function.
9815 * internal-fn.def (ASAN_CHECK): New internal function.
9816 * params.def (PARAM_ASAN_INSTRUMENTATION_WITH_CALL_THRESHOLD):
9817 Update description.
9818 (PARAM_ASAN_USE_AFTER_RETURN): Likewise.
9819 * tree.c: Small comment fix.
9820
9821 2014-08-11 Yury Gribov <y.gribov@samsung.com>
9822
9823 * gimple.c (gimple_call_fnspec): Support internal functions.
9824 (gimple_call_return_flags): Use const.
9825 * Makefile.in (GTFILES): Add internal-fn.h to list of GC files.
9826 * internal-fn.def: Add fnspec information.
9827 * internal-fn.h (internal_fn_fnspec): New function.
9828 (init_internal_fns): Declare new function.
9829 * internal-fn.c (internal_fn_fnspec_array): New global variable.
9830 (init_internal_fns): New function.
9831 * tree-core.h: Update macro call.
9832 * tree.c (build_common_builtin_nodes): Initialize internal fns.
9833
9834 2014-08-10 Gerald Pfeifer <gerald@pfeifer.com>
9835
9836 * lto-streamer.h (struct output_block::symbol): Change from
9837 struct symtab_node to plain symtab_node.
9838 (referenced_from_this_partition_p): Change first parameter
9839 from struct symtab_node to plain symtab_node.
9840
9841 2014-08-10 Marek Polacek <polacek@redhat.com>
9842
9843 PR c/51849
9844 * gcc/doc/invoke.texi: Document -Wc90-c99-compat.
9845
9846 2014-08-09 Jan Hubicka <hubicka@ucw.cz>
9847
9848 * ipa-devirt.c (get_dynamic_type): Handle case when instance is in
9849 DECL correctly; do not give up on types in static storage.
9850
9851 2014-08-09 Paolo Carlini <paolo.carlini@oracle.com>
9852
9853 * doc/invoke.texi ([Wnarrowing]): Update for non-constants in C++11.
9854
9855 2014-08-09 Roman Gareev <gareevroman@gmail.com>
9856
9857 * graphite-isl-ast-to-gimple.c:
9858 (translate_isl_ast_node_user): Use nb_loops instead of loop->num + 1.
9859
9860 * gcc.dg/graphite/isl-ast-gen-user-1.c: New testcase.
9861
9862 2014-08-08 Guozhi Wei <carrot@google.com>
9863
9864 * config/rs6000/rs6000.md (*movdi_internal64): Add a new constraint.
9865
9866 2014-08-08 Cary Coutant <ccoutant@google.com>
9867
9868 * dwarf2out.c (get_skeleton_type_unit): Remove.
9869 (output_skeleton_debug_sections): Remove skeleton type units.
9870 (output_comdat_type_unit): Likewise.
9871 (dwarf2out_finish): Likewise.
9872
9873 2014-08-07 Yi Yang <ahyangyi@google.com>
9874
9875 * predict.c (expr_expected_value_1): Remove the redundant assignment.
9876
9877 2014-08-08 Richard Biener <rguenther@suse.de>
9878
9879 * lto-streamer.h (struct lto_input_block): Make it a class
9880 with a constructor.
9881 (LTO_INIT_INPUT_BLOCK, LTO_INIT_INPUT_BLOCK_PTR): Remove.
9882 (struct lto_function_header, struct lto_simple_header,
9883 struct lto_simple_header_with_strings,
9884 struct lto_decl_header, struct lto_function_header): Make
9885 a simple inheritance hieararchy. Remove unused fields.
9886 (struct lto_asm_header): Remove.
9887 * lto-streamer-out.c (produce_asm): Adjust.
9888 (lto_output_toplevel_asms): Likewise.
9889 (produce_asm_for_decls): Likewise.
9890 * lto-section-out.c (lto_destroy_simple_output_block): Likewise.
9891 * data-streamer-in.c (string_for_index): Likewise.
9892 * ipa-inline-analysis.c (inline_read_section): Likewise.
9893 * ipa-prop.c (ipa_prop_read_section): Likewise.
9894 (read_replacements_section): Likewise.
9895 * lto-cgraph.c (input_cgraph_opt_section): Likewise.
9896 * lto-section-in.c (lto_create_simple_input_block): Likewise.
9897 (lto_destroy_simple_input_block): Likewise.
9898 * lto-streamer-in.c (lto_read_body_or_constructor): Likewise.
9899 (lto_input_toplevel_asms): Likewise.
9900
9901 2014-08-08 Alexander Ivchenko <alexander.ivchenko@intel.com>
9902 Maxim Kuznetsov <maxim.kuznetsov@intel.com>
9903 Anna Tikhonova <anna.tikhonova@intel.com>
9904 Ilya Tocar <ilya.tocar@intel.com>
9905 Andrey Turetskiy <andrey.turetskiy@intel.com>
9906 Ilya Verbin <ilya.verbin@intel.com>
9907 Kirill Yukhin <kirill.yukhin@intel.com>
9908 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
9909
9910 * common/config/i386/i386-common.c
9911 (OPTION_MASK_ISA_AVX512DQ_SET): Define.
9912 (OPTION_MASK_ISA_AVX512DQ_UNSET): Ditto.
9913 (ix86_handle_option): Handle OPT_mavx512dq.
9914 * config/i386/cpuid.h (bit_AVX512DQ): Define.
9915 * config/i386/driver-i386.c (host_detect_local_cpu): Detect avx512dq,
9916 set -mavx512dq accordingly.
9917 * config/i386/i386-c.c (ix86_target_macros_internal): Handle
9918 OPTION_MASK_ISA_AVX512DQ.
9919 * config/i386/i386.c (ix86_target_string): Handle -mavx512dq.
9920 (ix86_option_override_internal): Define PTA_AVX512DQ, handle
9921 PTA_AVX512DQ and OPTION_MASK_ISA_AVX512DQ.
9922 (ix86_valid_target_attribute_inner_p): Handle OPT_mavx512dq.
9923 * config/i386/i386.h (TARGET_AVX512DQ): Define.
9924 (TARGET_AVX512DQ_P(x)): Ditto.
9925 * config/i386/i386.opt: Add mavx512dq.
9926
9927 2014-08-08 Richard Biener <rguenther@suse.de>
9928
9929 * builtins.c (c_getstr, readonly_data_expr, init_target_chars,
9930 target_percent, target_percent_s): Export.
9931 (var_decl_component_p, fold_builtin_memory_op, fold_builtin_memset,
9932 fold_builtin_bzero, fold_builtin_strcpy, fold_builtin_strncpy,
9933 fold_builtin_strcat, fold_builtin_fputs, fold_builtin_memory_chk,
9934 fold_builtin_stxcpy_chk, fold_builtin_stxncpy_chk,
9935 fold_builtin_sprintf_chk_1, fold_builtin_snprintf_chk_1):
9936 Move to gimple-fold.c.
9937 (fold_builtin_2): Remove handling of bzero, fputs, fputs_unlocked,
9938 strcat and strcpy.
9939 (fold_builtin_3): Remove handling of memset, bcopy, memcpy,
9940 mempcpy, memmove, strncpy, strcpy_chk and stpcpy_chk.
9941 (fold_builtin_4): Remove handling of memcpy_chk, mempcpy_chk,
9942 memmove_chk, memset_chk, strncpy_chk and stpncpy_chk.
9943 (rewrite_call_expr_array): Remove.
9944 (fold_builtin_sprintf_chk): Likewise.
9945 (fold_builtin_snprintf_chk): Likewise.
9946 (fold_builtin_varargs): Remove handling of sprintf_chk,
9947 vsprintf_chk, snprintf_chk and vsnprintf_chk.
9948 (gimple_fold_builtin_sprintf_chk): Remove.
9949 (gimple_fold_builtin_snprintf_chk): Likewise.
9950 (gimple_fold_builtin_varargs): Likewise.
9951 (fold_call_stmt): Do not call gimple_fold_builtin_varargs.
9952 * predict.c (optimize_bb_for_size_p): Handle NULL bb.
9953 * gimple.c (gimple_seq_add_seq_without_update): New function.
9954 * gimple.h (gimple_seq_add_seq_without_update): Declare.
9955 * gimple-fold.c: Include output.h.
9956 (gsi_replace_with_seq_vops): New function, split out from ...
9957 (gimplify_and_update_call_from_tree): ... here.
9958 (replace_call_with_value): New function.
9959 (replace_call_with_call_and_fold): Likewise.
9960 (var_decl_component_p): Moved from builtins.c.
9961 (gimple_fold_builtin_memory_op): Moved from builtins.c
9962 fold_builtin_memory_op and rewritten to GIMPLE.
9963 (gimple_fold_builtin_memset): Likewise.
9964 (gimple_fold_builtin_strcpy): Likewise.
9965 (gimple_fold_builtin_strncpy): Likewise.
9966 (gimple_fold_builtin_strcat): Likewise.
9967 (gimple_fold_builtin_fputs): Likewise.
9968 (gimple_fold_builtin_memory_chk): Likewise.
9969 (gimple_fold_builtin_stxcpy_chk): Likewise.
9970 (gimple_fold_builtin_stxncpy_chk): Likewise.
9971 (gimple_fold_builtin_snprintf_chk): Likewise.
9972 (gimple_fold_builtin_sprintf_chk): Likewise.
9973 (gimple_fold_builtin_strlen): New function.
9974 (gimple_fold_builtin_with_strlen): New function split out from
9975 gimple_fold_builtin.
9976 (gimple_fold_builtin): Change signature and handle
9977 bzero, memset, bcopy, memcpy, mempcpy and memmove folding
9978 here. Call gimple_fold_builtin_with_strlen.
9979 (gimple_fold_call): Adjust.
9980
9981 2014-08-08 Kugan Vivekanandarajah <kuganv@linaro.org>
9982
9983 * calls.c (precompute_arguments): Check
9984 promoted_for_signed_and_unsigned_p and set the promoted mode.
9985 (promoted_for_signed_and_unsigned_p): New function.
9986 (expand_expr_real_1): Check promoted_for_signed_and_unsigned_p
9987 and set the promoted mode.
9988 * expr.h (promoted_for_signed_and_unsigned_p): New function definition.
9989 * cfgexpand.c (expand_gimple_stmt_1): Call emit_move_insn if
9990 SUBREG is promoted with SRP_SIGNED_AND_UNSIGNED.
9991
9992
9993 2014-08-08 Kugan Vivekanandarajah <kuganv@linaro.org>
9994
9995 * calls.c (precompute_arguments): Use new SUBREG_PROMOTED_SET
9996 instead of SUBREG_PROMOTED_UNSIGNED_SET.
9997 (expand_call): Likewise.
9998 * cfgexpand.c (expand_gimple_stmt_1): Use SUBREG_PROMOTED_SIGN
9999 to get promoted mode.
10000 * combine.c (record_promoted_value): Skip > 0 comparison with
10001 SUBREG_PROMOTED_UNSIGNED_P as it now returns only 0 or 1.
10002 * expr.c (convert_move): Use SUBREG_CHECK_PROMOTED_SIGN instead
10003 of SUBREG_PROMOTED_UNSIGNED_P.
10004 (convert_modes): Likewise.
10005 (store_expr): Use SUBREG_PROMOTED_SIGN to get promoted mode.
10006 Use SUBREG_CHECK_PROMOTED_SIGN instead of SUBREG_PROMOTED_UNSIGNED_P.
10007 (expand_expr_real_1): Use new SUBREG_PROMOTED_SET instead of
10008 SUBREG_PROMOTED_UNSIGNED_SET.
10009 * function.c (assign_parm_setup_reg): Use new SUBREG_PROMOTED_SET
10010 instead of SUBREG_PROMOTED_UNSIGNED_SET.
10011 * ifcvt.c (noce_emit_cmove): Updated to use SUBREG_PROMOTED_GET and
10012 SUBREG_PROMOTED_SET.
10013 * internal-fn.c (ubsan_expand_si_overflow_mul_check): Use
10014 SUBREG_PROMOTED_SET instead of SUBREG_PROMOTED_UNSIGNED_SET.
10015 * optabs.c (widen_operand): Use SUBREG_CHECK_PROMOTED_SIGN instead
10016 of SUBREG_PROMOTED_UNSIGNED_P.
10017 * rtl.h (SUBREG_PROMOTED_UNSIGNED_SET): Remove.
10018 (SUBREG_PROMOTED_SET): New define.
10019 (SUBREG_PROMOTED_GET): Likewise.
10020 (SUBREG_PROMOTED_SIGN): Likewise.
10021 (SUBREG_PROMOTED_SIGNED_P): Likewise.
10022 (SUBREG_CHECK_PROMOTED_SIGN): Likewise.
10023 (SUBREG_PROMOTED_UNSIGNED_P): Updated.
10024 * rtlanal.c (unsigned_reg_p): Use new SUBREG_PROMOTED_GET
10025 instead of SUBREG_PROMOTED_UNSIGNED_GET.
10026 (nonzero_bits1): Skip > 0 comparison with the results as
10027 SUBREG_PROMOTED_UNSIGNED_P now returns only 0 or 1.
10028 (num_sign_bit_copies1): Use SUBREG_PROMOTED_SIGNED_P instead
10029 of !SUBREG_PROMOTED_UNSIGNED_P.
10030 * simplify-rtx.c (simplify_unary_operation_1): Use new
10031 SUBREG_PROMOTED_SIGNED_P instead of !SUBREG_PROMOTED_UNSIGNED_P.
10032 (simplify_subreg): Use new SUBREG_PROMOTED_SIGNED_P,
10033 SUBREG_PROMOTED_UNSIGNED_P and SUBREG_PROMOTED_SET instead of
10034 SUBREG_PROMOTED_UNSIGNED_P and SUBREG_PROMOTED_UNSIGNED_SET.
10035
10036 2014-08-07 Jan Hubicka <hubicka@ucw.cz>
10037
10038 * ipa-devirt.c: Include gimple-pretty-print.h
10039 (referenced_from_vtable_p): Exclude DECL_EXTERNAL from
10040 further tests.
10041 (decl_maybe_in_construction_p): Fix conditional on cdtor check
10042 (get_polymorphic_call_info): Fix return value
10043 (type_change_info): New sturcture based on ipa-prop
10044 variant.
10045 (noncall_stmt_may_be_vtbl_ptr_store): New predicate
10046 based on ipa-prop variant.
10047 (extr_type_from_vtbl_ptr_store): New function
10048 based on ipa-prop variant.
10049 (record_known_type): New function.
10050 (check_stmt_for_type_change): New function.
10051 (get_dynamic_type): New function.
10052 * ipa-prop.c (ipa_analyze_call_uses): Use get_dynamic_type.
10053 * tree-ssa-pre.c: ipa-utils.h
10054 (eliminate_dom_walker::before_dom_children): Use ipa-devirt
10055 machinery; sanity check with ipa-prop devirtualization.
10056 * trans-mem.c (ipa_tm_insert_gettmclone_call): Clear
10057 polymorphic flag.
10058
10059 2014-08-07 Trevor Saunders <tsaunders@mozilla.com>
10060
10061 * Makefile.in: Remove references to pointer-set.c and pointer-set.h.
10062 * alias.c, cfgexpand.c, cgraphbuild.c,
10063 config/aarch64/aarch64-builtins.c, config/aarch64/aarch64.c,
10064 config/alpha/alpha.c, config/darwin.c, config/i386/i386.c,
10065 config/i386/winnt.c, config/ia64/ia64.c, config/m32c/m32c.c,
10066 config/mep/mep.c, config/mips/mips.c, config/rs6000/rs6000.c,
10067 config/s390/s390.c, config/sh/sh.c, config/sparc/sparc.c,
10068 config/spu/spu.c, config/stormy16/stormy16.c, config/tilegx/tilegx.c,
10069 config/tilepro/tilepro.c, config/xtensa/xtensa.c, dominance.c,
10070 dse.c, except.c, gengtype.c, gimple-expr.c,
10071 gimple-ssa-strength-reduction.c, gimplify.c, ifcvt.c,
10072 ipa-visibility.c, lto-streamer.h, omp-low.c, predict.c, stmt.c,
10073 tree-affine.c, tree-cfg.c, tree-eh.c, tree-inline.c, tree-nested.c,
10074 tree-scalar-evolution.c, tree-ssa-loop-im.c, tree-ssa-loop-niter.c,
10075 tree-ssa-phiopt.c, tree-ssa-structalias.c, tree-ssa-uninit.c,
10076 tree-ssa.c, tree.c, var-tracking.c, varpool.c: Remove includes of
10077 pointer-set.h.
10078 * pointer-set.c: Remove file.
10079 * pointer-set.h: Remove file.
10080
10081 2014-08-07 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
10082
10083 * config/arm/arm.md (*cmov<mode>): Set type attribute to fcsel.
10084 * config/arm/types.md (f_sels, f_seld): Delete.
10085
10086 2014-08-07 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
10087
10088 * config/aarch64/aarch64.md (absdi2): Set simd attribute.
10089 (aarch64_reload_mov<mode>): Predicate on TARGET_FLOAT.
10090 (aarch64_movdi_<mode>high): Likewise.
10091 (aarch64_mov<mode>high_di): Likewise.
10092 (aarch64_movdi_<mode>low): Likewise.
10093 (aarch64_mov<mode>low_di): Likewise.
10094 (aarch64_movtilow_tilow): Likewise.
10095 Add comment explaining usage of fp,simd attributes and of
10096 TARGET_FLOAT and TARGET_SIMD.
10097
10098 2014-08-07 Ian Bolton <ian.bolton@arm.com>
10099 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
10100
10101 * config/aarch64/aarch64.c (aarch64_expand_mov_immediate):
10102 Use MOVN when one of the half-words is 0xffff.
10103
10104 2014-08-07 Marat Zakirov <m.zakirov@samsung.com>
10105
10106 * config/arm/thumb1.md (*thumb1_movqi_insn): Copy of thumb1_movhi_insn.
10107
10108 2014-08-07 Maxim Kuvyrkov <maxim.kuvyrkov@linaro.org>
10109
10110 * haifa-sched.c (SCHED_SORT): Delete. Macro used exactly once.
10111 (enum rfs_decition:RFS_*): New constants wrapped in an enum.
10112 (rfs_str): String corresponding to RFS_* constants.
10113 (rank_for_schedule_stats_t): New typedef.
10114 (rank_for_schedule_stats): New static variable.
10115 (rfs_result): New static function.
10116 (rank_for_schedule): Track statistics for deciding heuristics.
10117 (rank_for_schedule_stats_diff, print_rank_for_schedule_stats): New
10118 static functions.
10119 (ready_sort): Use them for debug printouts.
10120 (schedule_block): Init statistics state. Print statistics on
10121 rank_for_schedule decisions.
10122
10123 2014-08-07 Maxim Kuvyrkov <maxim.kuvyrkov@linaro.org>
10124
10125 * haifa-sched.c (rank_for_schedule): Fix INSN_TICK-based heuristics.
10126
10127 2014-08-07 Ilya Tocar <ilya.tocar@intel.com>
10128
10129 * config/i386/sse.md (vec_extract_lo_<mode><mask_name>): Fix
10130 constraint.
10131
10132 2014-08-07 Trevor Saunders <tsaunders@mozilla.com>
10133
10134 * hash-map.h (default_hashmap_traits): Adjust overloads of hash
10135 function to not conflict.
10136 * alias.c, cfgexpand.c, dse.c, except.h, gimple-expr.c,
10137 gimple-ssa-strength-reduction.c, gimple-ssa.h, ifcvt.c,
10138 lto-streamer-out.c, lto-streamer.h, tree-affine.c, tree-affine.h,
10139 tree-predcom.c, tree-scalar-evolution.c, tree-ssa-loop-im.c,
10140 tree-ssa-loop-niter.c, tree-ssa.c, value-prof.c: Use hash_map instead
10141 of pointer_map.
10142
10143 2014-08-07 Marek Polacek <polacek@redhat.com>
10144
10145 * fold-const.c (fold_binary_loc): Add folding of
10146 (PTR0 - (PTR1 p+ A) -> (PTR0 - PTR1) - A.
10147
10148 2013-08-07 Ilya Enkovich <ilya.enkovich@intel.com>
10149
10150 * config/elfos.h (ASM_DECLARE_OBJECT_NAME): Use decl size
10151 instead of type size.
10152 (ASM_FINISH_DECLARE_OBJECT): Likewise.
10153
10154 2014-08-07 Marat Zakirov <m.zakirov@samsung.com>
10155
10156 * config/arm/thumb1.md (*thumb1_movhi_insn): Handle stack pointer.
10157 (*thumb1_movqi_insn): Likewise.
10158 * config/arm/thumb2.md (*thumb2_movhi_insn): Likewise.
10159
10160 2014-08-07 Tom de Vries <tom@codesourcery.com>
10161
10162 * doc/sourcebuild.texi (glibc, glibc_2_12_or_later)
10163 (glibc_2_11_or_earlier): Remove effective-target keywords.
10164
10165 2014-08-07 Kugan Vivekanandarajah <kuganv@linaro.org>
10166
10167 * config/arm/arm.c (bdesc_2arg): Fix typo.
10168 (arm_atomic_assign_expand_fenv): Remove The default implementation.
10169
10170 2014-08-07 Zhenqiang Chen <zhenqiang.chen@arm.com>
10171
10172 * tree-ssa-loop-ivopts.c (get_address_cost): Try aligned offset.
10173
10174 2014-08-06 Vladimir Makarov <vmakarov@redhat.com>
10175
10176 PR debug/61923
10177 * haifa-sched.c (advance_one_cycle): Fix dump.
10178 (schedule_block): Don't advance cycle if we are already at the
10179 beginning of the cycle.
10180
10181 2014-08-06 Martin Jambor <mjambor@suse.cz>
10182
10183 PR ipa/61393
10184 * cgraphclones.c (cgraph_node::create_clone): Also copy tm_clone.
10185
10186 2014-08-06 Richard Biener <rguenther@suse.de>
10187
10188 PR lto/62034
10189 * lto-streamer-in.c (lto_input_tree_1): Assert we do not read
10190 SCCs here.
10191 (lto_input_tree): Pop SCCs here.
10192
10193 2014-08-06 Richard Biener <rguenther@suse.de>
10194
10195 PR tree-optimization/61320
10196 * tree-ssa-loop-ivopts.c (may_be_unaligned_p): Properly
10197 handle misaligned loads.
10198
10199 2014-08-06 Alan Lawrence <alan.lawrence@arm.com>
10200
10201 * config/aarch64/aarch64.c (aarch64_evpc_dup): Enable for bigendian.
10202 (aarch64_expand_vec_perm_const): Check for dup before zip.
10203
10204 2014-08-06 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
10205
10206 * config/aarch64/aarch64.c (aarch64_classify_address): Use REG_P and
10207 CONST_INT_P instead of GET_CODE and compare.
10208 (aarch64_select_cc_mode): Likewise.
10209 (aarch64_print_operand): Likewise.
10210 (aarch64_rtx_costs): Likewise.
10211 (aarch64_simd_valid_immediate): Likewise.
10212 (aarch64_simd_check_vect_par_cnst_half): Likewise.
10213 (aarch64_simd_emit_pair_result_insn): Likewise.
10214
10215 2014-08-05 David Malcolm <dmalcolm@redhat.com>
10216
10217 * gdbhooks.py (find_gcc_source_dir): New helper function.
10218 (class PassNames): New class, locating and parsing passes.def.
10219 (class BreakOnPass): New command "break-on-pass".
10220
10221 2014-08-05 Trevor Saunders <tsaunders@mozilla.com>
10222
10223 * tree-ssa.c (redirect_edge_var_map_dup): insert newe before
10224 getting olde.
10225
10226 2014-08-05 Richard Biener <rguenther@suse.de>
10227
10228 PR rtl-optimization/61672
10229 * emit-rtl.h (mem_attrs_eq_p): Declare.
10230 * emit-rtl.c (mem_attrs_eq_p): Export. Handle NULL mem-attrs.
10231 * cse.c (exp_equiv_p): Use mem_attrs_eq_p.
10232 * cfgcleanup.c (merge_memattrs): Likewise.
10233 Include emit-rtl.h.
10234
10235 2014-08-05 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
10236
10237 * config/aarch64/arm_neon.h (vqdmlals_lane_s32): Use scalar types
10238 rather than singleton vectors.
10239 (vqdmlsls_lane_s32): Likewise.
10240
10241 2014-08-05 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
10242
10243 * config/aarch64/aarch64-simd.md (aarch64_sqdmulh_laneq<mode>):
10244 Use VSDQ_HSI mode iterator.
10245 (aarch64_sqrdmulh_laneq<mode>): Likewise.
10246 (aarch64_sq<r>dmulh_laneq<mode>_internal): New define_insn.
10247 * config/aarch64/aarch64-simd-builtins.def (sqdmulh_laneq):
10248 Use BUILTIN_VDQHS macro.
10249 (sqrdmulh_laneq): Likewise.
10250 * config/aarch64/arm_neon.h (vqdmlalh_laneq_s16): New intrinsic.
10251 (vqdmlals_laneq_s32): Likewise.
10252 (vqdmlslh_laneq_s16): Likewise.
10253 (vqdmlsls_laneq_s32): Likewise.
10254 (vqdmulhh_laneq_s16): Likewise.
10255 (vqdmulhs_laneq_s32): Likewise.
10256 (vqrdmulhh_laneq_s16): Likewise.
10257 (vqrdmulhs_laneq_s32): Likewise.
10258
10259 2014-08-05 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
10260
10261 * config/aarch64/arm_neon.h (vmul_f64): New intrinsic.
10262 (vmuld_laneq_f64): Likewise.
10263 (vmuls_laneq_f32): Likewise.
10264 (vmul_n_f64): Likewise.
10265 (vmuld_lane_f64): Reimplement in C.
10266 (vmuls_lane_f32): Likewise.
10267
10268 2014-08-05 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
10269
10270 * config/arm/cortex-a15.md (cortex_a15_alu_shift): Add crc type
10271 to reservation.
10272 * config/arm/cortex-a53.md (cortex_a53_alu_shift): Likewise.
10273
10274 2014-08-05 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
10275
10276 * config/arm/arm.md (clzsi2): Set predicable_short_it attr to no.
10277 (rbitsi2): Likewise.
10278 (*arm_rev): Set predicable and predicable_short_it attributes.
10279
10280 2014-08-05 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
10281
10282 * convert.c (convert_to_integer): Guard transformation to lrint by
10283 -fno-math-errno.
10284
10285 2014-08-05 James Greenhalgh <james.greenhalgh@arm.com>
10286
10287 * config/aarch64/aarch64-builtins.c
10288 (aarch64_simd_builtin_type_mode): Delete.
10289 (v8qi_UP): Remap to V8QImode.
10290 (v4hi_UP): Remap to V4HImode.
10291 (v2si_UP): Remap to V2SImode.
10292 (v2sf_UP): Remap to V2SFmode.
10293 (v1df_UP): Remap to V1DFmode.
10294 (di_UP): Remap to DImode.
10295 (df_UP): Remap to DFmode.
10296 (v16qi_UP):V16QImode.
10297 (v8hi_UP): Remap to V8HImode.
10298 (v4si_UP): Remap to V4SImode.
10299 (v4sf_UP): Remap to V4SFmode.
10300 (v2di_UP): Remap to V2DImode.
10301 (v2df_UP): Remap to V2DFmode.
10302 (ti_UP): Remap to TImode.
10303 (ei_UP): Remap to EImode.
10304 (oi_UP): Remap to OImode.
10305 (ci_UP): Map to CImode.
10306 (xi_UP): Remap to XImode.
10307 (si_UP): Remap to SImode.
10308 (sf_UP): Remap to SFmode.
10309 (hi_UP): Remap to HImode.
10310 (qi_UP): Remap to QImode.
10311 (aarch64_simd_builtin_datum): Make mode a machine_mode.
10312 (VAR1): Build builtin name.
10313 (aarch64_init_simd_builtins): Remove dead code.
10314
10315 2014-08-05 Roman Gareev <gareevroman@gmail.com>
10316
10317 * graphite-isl-ast-to-gimple.c:
10318 (set_options): New function.
10319 (scop_to_isl_ast): Add calling of set_options.
10320
10321 2014-08-05 Jakub Jelinek <jakub@redhat.com>
10322
10323 * loop-unroll.c (struct iv_to_split): Remove n_loc and loc fields.
10324 (analyze_iv_to_split_insn): Don't initialize them.
10325 (get_ivts_expr): Removed.
10326 (allocate_basic_variable, insert_base_initialization): Use
10327 SET_SRC instead of *get_ivts_expr.
10328 (split_iv): Use &SET_SRC instead of get_ivts_expr.
10329
10330 2014-08-05 Roman Gareev <gareevroman@gmail.com>
10331
10332 * graphite-isl-ast-to-gimple.c: Add a new struct ast_build_info.
10333 (translate_isl_ast_for_loop): Add checking of the
10334 flag_loop_parallelize_all.
10335 (ast_build_before_for): New function.
10336 (scop_to_isl_ast): Add checking of the
10337 flag_loop_parallelize_all.
10338 * graphite-dependences.c: Move the defenition of the
10339 scop_get_dependences from graphite-optimize-isl.c to this file.
10340 (apply_schedule_on_deps): Add checking of the ux's emptiness.
10341 (carries_deps): Add checking of the x's value.
10342 * graphite-optimize-isl.c: Move the defenition of the
10343 scop_get_dependences to graphite-dependences.c.
10344 * graphite-poly.h: Add declarations of scop_get_dependences
10345 and carries_deps.
10346
10347 2014-08-04 Rohit <rohitarulraj@freescale.com>
10348
10349 PR target/60102
10350 * config/rs6000/rs6000.c (rs6000_reg_names): Add SPE high register
10351 names.
10352 (alt_reg_names): Likewise.
10353 (rs6000_dwarf_register_span): For SPE high registers, replace
10354 dwarf register numbers with GCC hard register numbers.
10355 (rs6000_init_dwarf_reg_sizes_extra): Likewise.
10356 (rs6000_dbx_register_number): For SPE high registers, return dwarf
10357 register number for the corresponding GCC hard register number.
10358 * config/rs6000/rs6000.h (FIRST_PSEUDO_REGISTER): Update based on 32
10359 newly added GCC hard register numbers for SPE high registers.
10360 (DWARF_FRAME_REGISTERS): Likewise.
10361 (DWARF_REG_TO_UNWIND_COLUMN): Likewise.
10362 (DWARF_FRAME_REGNUM): Likewise.
10363 (FIXED_REGISTERS): Likewise.
10364 (CALL_USED_REGISTERS): Likewise.
10365 (CALL_REALLY_USED_REGISTERS): Likewise.
10366 (REG_ALLOC_ORDER): Likewise.
10367 (enum reg_class): Likewise.
10368 (REG_CLASS_NAMES): Likewise.
10369 (REG_CLASS_CONTENTS): Likewise.
10370 (SPE_HIGH_REGNO_P): New macro to identify SPE high registers.
10371
10372 2014-08-04 Richard Biener <rguenther@suse.de>
10373
10374 * gimple-fold.h (gimple_fold_builtin): Remove.
10375 * gimple-fold.c (gimple_fold_builtin): Make static.
10376 * tree-ssa-ccp.c (pass_fold_builtins::execute): Use
10377 fold_stmt, not gimple_fold_builtin.
10378
10379 2014-08-04 Martin Liska <mliska@suse.cz>
10380
10381 * cgraph.h (csi_end_p): Removed.
10382 (csi_next): Likewise.
10383 (csi_node): Likewise.
10384 (csi_start): Likewise.
10385 (cgraph_node_in_set_p): Likewise.
10386 (cgraph_node_set_size): Likewise.
10387 (vsi_end_p): Likewise.
10388 (vsi_next): Likewise.
10389 (vsi_node): Likewise.
10390 (vsi_start): Likewise.
10391 (varpool_node_set_size): Likewise.
10392 (cgraph_node_set_nonempty_p): Likewise.
10393 (varpool_node_set_nonempty_p): Likewise.
10394 * cgraphunit.c (cgraph_process_new_functions): vec replaces
10395 cgraph_node_set.
10396 * ipa-inline-transform.c: Likewise.
10397 * ipa-utils.c (cgraph_node_set_new): Removed.
10398 (cgraph_node_set_add): Likewise.
10399 (cgraph_node_set_remove): Likewise.
10400 (cgraph_node_set_find): Likewise.
10401 (dump_cgraph_node_set): Likewise.
10402 (debug_cgraph_node_set): Likewise.
10403 (free_cgraph_node_set): Likewise.
10404 (varpool_node_set_new): Likewise.
10405 (varpool_node_set_add): Likewise.
10406 (varpool_node_set_remove): Likewise.
10407 (varpool_node_set_find): Likewise.
10408 (dump_varpool_node_set): Likewise.
10409 (free_varpool_node_set): Likewise.
10410 (debug_varpool_node_set): Likewise.
10411 * tree-emutls.c (struct tls_var_data):
10412 (emutls_index): Removed.
10413 (emutls_decl): Likewise.
10414 (gen_emutls_addr): Function implementation uses newly added
10415 hash_map<varpool_node *, tls_var_data>.
10416 (clear_access_vars): Likewise.
10417 (create_emultls_var): Likewise.
10418 (ipa_lower_emutls): Likewise.
10419 (reset_access): New function.
10420
10421 2014-08-04 Ganesh Gopalasubramanian <Ganesh.Gopalasubramanian@amd.com>
10422
10423 * config/i386/i386.c (ix86_option_override_internal): Add
10424 PTA_RDRND and PTA_MOVBE for bdver4.
10425
10426 2014-08-04 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
10427 James Greenhalgh <james.greenhalgh@arm.com>
10428
10429 * doc/md.texi (clrsb): Document.
10430 (clz): Change reference to x into operand 1.
10431 (ctz): Likewise.
10432 (popcount): Likewise.
10433
10434 2014-08-04 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
10435
10436 PR target/61713
10437 * gcc/optabs.c (expand_atomic_test_and_set): Do not try to emit
10438 move to subtarget in serial version if result is ignored.
10439
10440 2014-08-04 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
10441 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
10442
10443 * sched-deps.c (try_group_insn): Generalise macro fusion hook usage
10444 to any two insns. Update comment. Rename to sched_macro_fuse_insns.
10445 (sched_analyze_insn): Update use of try_group_insn to
10446 sched_macro_fuse_insns.
10447 * config/i386/i386.c (ix86_macro_fusion_pair_p): Reject 2nd
10448 arguments that are not conditional jumps.
10449
10450 2014-08-04 Ganesh Gopalasubramanian <Ganesh.Gopalasubramanian@amd.com>
10451
10452 * config/i386/driver-i386.c (host_detect_local_cpu): Handle AMD's extended
10453 family information. Handle BTVER2 cpu with cpuid family value.
10454
10455 2014-08-04 Tom de Vries <tom@codesourcery.com>
10456
10457 * doc/sourcebuild.texi (glibc, glibc_2_12_or_later)
10458 (glibc_2_11_or_earlier): Document effective-target keywords.
10459
10460 2014-08-01 Jan Hubicka <hubicka@ucw.cz>
10461
10462 * ipa-devirt.c (odr_type_warn_count): Add type.
10463 (possible_polymorphic_call_targets): Set it.
10464 (ipa_devirt): Use it.
10465
10466 2014-08-01 Jan Hubicka <hubicka@ucw.cz>
10467
10468 * doc/invoke.texi (Wsuggest-final-types, Wsuggest-final-methods):
10469 Document.
10470 * ipa-devirt.c: Include hash-map.h
10471 (struct polymorphic_call_target_d): Add type_warning and decl_warning.
10472 (clear_speculation): Break out of ...
10473 (get_class_context): ... here; speed up handling obviously useless
10474 speculations.
10475 (odr_type_warn_count, decl_warn_count): New structures.
10476 (final_warning_record): New structure.
10477 (final_warning_records): New static variable.
10478 (possible_polymorphic_call_targets): Cleanup handling of
10479 speculative info; do not build speculation when user do not care;
10480 record info about warnings when asked for.
10481 (add_decl_warning): New function.
10482 (type_warning_cmp): New function.
10483 (decl_warning_cmp): New function.
10484 (ipa_devirt): Handle -Wsuggest-final-methods and -Wsuggest-final-types.
10485 (gate): Enable pass when warnings are requested.
10486 * common.opt (Wsuggest-final-types, Wsuggest-final-methods): New
10487 options.
10488
10489 2014-08-02 Trevor Saunders <tsaunders@mozilla.com>
10490
10491 * hash-map.h (default_hashmap_traits::mark_key_deleted):
10492 Fix cast.
10493 (hash_map::remove): New method.
10494 (hash_map::traverse): New method.
10495 * cgraph.h, except.c, except.h, gimple-ssa-strength-reduction.c,
10496 ipa-utils.c, lto-cgraph.c, lto-streamer.h, omp-low.c, predict.c,
10497 tree-cfg.c, tree-cfgcleanup.c, tree-eh.c, tree-eh.h, tree-inline.c,
10498 tree-inline.h, tree-nested.c, tree-sra.c, tree-ssa-loop-im.c,
10499 tree-ssa-loop-ivopts.c, tree-ssa-reassoc.c, tree-ssa-structalias.c,
10500 tree-ssa.c, tree-ssa.h, var-tracking.c: Use hash_map instead of
10501 pointer_map.
10502
10503 2014-08-02 Trevor Saunders <tsaunders@mozilla.com>
10504
10505 * hash-set.h: new File.
10506 * cfgexpand.c, cfgloop.c, cgraph.c, cgraphbuild.c, cgraphunit.c,
10507 cprop.c, cse.c, gimple-walk.c, gimple-walk.h, gimplify.c, godump.c,
10508 ipa-devirt.c, ipa-pure-const.c, ipa-visibility.c, ipa.c, lto-cgraph.c,
10509 lto-streamer-out.c, stmt.c, tree-cfg.c, tree-core.h, tree-eh.c,
10510 tree-inline.c, tree-inline.h, tree-nested.c, tree-pretty-print.c,
10511 tree-ssa-loop-niter.c, tree-ssa-phiopt.c, tree-ssa-threadedge.c,
10512 tree-ssa-uninit.c, tree.c, tree.h, value-prof.c, varasm.c,
10513 varpool.c: Use hash_set instead of pointer_set.
10514
10515 2014-08-01 Alan Lawrence <alan.lawrence@arm.com>
10516
10517 * config/aarch64/aarch64-simd-builtins.def (dup_lane, get_lane): Delete.
10518
10519 2014-08-01 Jiong Wang <jiong.wang@arm.com>
10520
10521 * config/aarch64/aarch64.c (aarch64_classify_address): Accept all offset
10522 for frame access when strict_p is false.
10523
10524 2014-08-01 Renlin Li <renlin.li@arm.com>
10525 2014-08-01 Jiong Wang <jiong.wang@arm.com>
10526
10527 * config/aarch64/aarch64.c (offset_7bit_signed_scaled_p): Rename to
10528 aarch64_offset_7bit_signed_scaled_p, remove static and use it.
10529 * config/aarch64/aarch64-protos.h (aarch64_offset_7bit_signed_scaled_p):
10530 Declaration.
10531 * config/aarch64/predicates.md (aarch64_mem_pair_offset): Define new
10532 predicate.
10533 * config/aarch64/aarch64.md (loadwb_pair, storewb_pair): Use
10534 aarch64_mem_pair_offset.
10535
10536 2014-08-01 Jiong Wang <jiong.wang@arm.com>
10537
10538 * config/aarch64/aarch64.md (loadwb_pair<GPI:mode>_<P:mode>): Fix
10539 offset.
10540 (loadwb_pair<GPI:mode>_<P:mode>): Likewise.
10541 * config/aarch64/aarch64.c (aarch64_gen_loadwb_pair): Likewise.
10542
10543 2014-08-01 Matthew Fortune <matthew.fortune@imgtec.com>
10544
10545 * config/mips/mips.h (REGISTER_PREFIX): Define macro.
10546
10547 2014-08-01 James Greenhalgh <james.greenhalgh@arm.com>
10548
10549 PR regression/61510
10550 * cgraphunit.c (analyze_functions): Use get_create rather than get
10551 for decls which are clones of abstract functions.
10552
10553 2014-08-01 Martin Liska <mliska@suse.cz>
10554
10555 * gimple-iterator.h (gsi_next_nonvirtual_phi): New function.
10556 * ipa-prop.h (count_formal_params): Global function created from static.
10557 * ipa-prop.c (count_formal_params): Likewise.
10558 * ipa-utils.c (ipa_merge_profiles): Be more tolerant if we merge
10559 profiles for semantically equivalent functions.
10560 * passes.c (do_per_function): If we load body of a function
10561 during WPA, this condition should behave same.
10562 * varpool.c (ctor_for_folding): More tolerant assert for variable
10563 aliases created during WPA.
10564
10565 2014-08-01 Martin Liska <mliska@suse.cz>
10566
10567 * doc/invoke.texi (Options That Control Optimization): Documentation
10568 for -foptimize-strlen introduced. Optimization levels default options
10569 fixed.
10570
10571 2014-08-01 Jakub Jelinek <jakub@redhat.com>
10572
10573 * opts.c (common_handle_option): Handle -fsanitize=alignment.
10574 * ubsan.h (enum ubsan_null_ckind): Add UBSAN_CTOR_CALL.
10575 (ubsan_expand_bounds_ifn, ubsan_expand_null_ifn): Change return
10576 type to bool.
10577 * stor-layout.h (min_align_of_type): New prototype.
10578 * asan.c (pass_sanopt::execute): Don't perform gsi_next if
10579 ubsan_expand* told us not to do it. Remove the extra gsi_end_p
10580 check.
10581 * ubsan.c: Include builtins.h.
10582 (ubsan_expand_bounds_ifn): Change return type to bool,
10583 always return true.
10584 (ubsan_expand_null_ifn): Change return type to bool, change
10585 argument to gimple_stmt_iterator *. Handle both null and alignment
10586 sanitization, take type from ckind argument's type rather than
10587 first argument.
10588 (instrument_member_call): Removed.
10589 (instrument_mem_ref): Remove t argument, add mem and base arguments.
10590 Handle both null and alignment sanitization, don't say whole
10591 struct access is member access. Build 3 argument IFN_UBSAN_NULL
10592 call instead of 2 argument.
10593 (instrument_null): Adjust instrument_mem_ref caller. Don't
10594 instrument calls here.
10595 (pass_ubsan::gate, pass_ubsan::execute): Handle SANITIZE_ALIGNMENT
10596 like SANITIZE_NULL.
10597 * stor-layout.c (min_align_of_type): New function.
10598 * flag-types.h (enum sanitize_code): Add SANITIZE_ALIGNMENT.
10599 Or it into SANITIZE_UNDEFINED.
10600 * doc/invoke.texi (-fsanitize=alignment): Document.
10601
10602 2014-07-31 Andi Kleen <ak@linux.intel.com>
10603
10604 * tree-ssa-tail-merge.c (same_succ_hash): Convert to inchash.
10605
10606 2014-07-31 Andi Kleen <ak@linux.intel.com>
10607
10608 * tree-ssa-sccvn.c (vn_reference_op_compute_hash): Convert to
10609 inchash.
10610 (vn_reference_compute_hash): Dito.
10611 (vn_nary_op_compute_hash): Dito.
10612 (vn_phi_compute_hash): Dito.
10613 * tree-ssa-sccvn.h (vn_hash_constant_with_type): Dito.
10614
10615 2014-07-31 Andi Kleen <ak@linux.intel.com>
10616
10617 * tree-ssa-dom.c (iterative_hash_exprs_commutative):
10618 Rename to inchash:add_expr_commutative. Convert to inchash.
10619 (iterative_hash_hashable_expr): Rename to
10620 inchash:add_hashable_expr. Convert to inchash.
10621 (avail_expr_hash): Dito.
10622
10623 2014-07-31 Andi Kleen <ak@linux.intel.com>
10624
10625 * ipa-devirt.c (polymorphic_call_target_hasher::hash):
10626 Convert to inchash.
10627
10628 2014-07-31 Andi Kleen <ak@linux.intel.com>
10629
10630 * asan.c (asan_mem_ref_hasher::hash): Convert to inchash.
10631
10632 2014-07-31 Andi Kleen <ak@linux.intel.com>
10633
10634 * Makefile.in (OBJS): Add rtlhash.o
10635 * dwarf2out.c (addr_table_entry_do_hash): Convert to inchash.
10636 (loc_checksum): Dito.
10637 (loc_checksum_ordered): Dito.
10638 (hash_loc_operands): Dito.
10639 (hash_locs): Dito.
10640 (hash_loc_list): Dito.
10641 * rtl.c (iterative_hash_rtx): Moved to rtlhash.c
10642 * rtl.h (iterative_hash_rtx): Moved to rtlhash.h
10643 * rtlhash.c: New file.
10644 * rtlhash.h: New file.
10645
10646 2014-07-31 Andi Kleen <ak@linux.intel.com>
10647
10648 * inchash.h (inchash): Change inchash class to namespace.
10649 (class hash): ... Rename from inchash.
10650 (add_object): Move from macro to class template.
10651 * lto-streamer-out.c (hash_tree): Change inchash
10652 to inchash::hash.
10653 * tree.c (build_type_attribute_qual_variant): Dito.
10654 (type_hash_list): Dito.
10655 (attribute_hash_list): Dito.
10656 (iterative_hstate_expr): Rename to inchash::add_expr
10657 (build_range_type_1): Change inchash to inchash::hash
10658 and use hash::add_expr.
10659 (build_array_type_1): Dito.
10660 (build_function_type): Dito
10661 (build_method_type_directly): Dito.
10662 (build_offset_type): Dito.
10663 (build_complex_type): Dito.
10664 (make_vector_type): Dito.
10665 * tree.h (iterative_hash_expr): Dito.
10666
10667 2014-07-31 Chen Gang <gang.chen.5i5j@gmail.com>
10668
10669 * gcc.c (do_spec_1): Allocate enough space for saved_suffix.
10670
10671 2014-07-31 James Greenhalgh <james.greenhalgh@arm.com>
10672
10673 * config/aarch64/arm_neon.h (vpadd_<suf><8,16,32,64>): Move to
10674 correct alphabetical position.
10675 (vpaddd_f64): Rewrite using builtins.
10676 (vpaddd_s64): Move to correct alphabetical position.
10677 (vpaddd_u64): New.
10678
10679 2014-07-31 Oleg Endo <olegendo@gcc.gnu.org>
10680
10681 PR target/61844
10682 * config/sh/sh.c (sh_legitimate_address_p,
10683 sh_legitimize_reload_address): Handle reg+reg address modes when
10684 ALLOW_INDEXED_ADDRESS is false.
10685 * config/sh/predicates.md (general_movsrc_operand,
10686 general_movdst_operand): Likewise.
10687
10688 2014-07-31 James Greenhalgh <james.greenhalgh@arm.com>
10689
10690 * config/aarch64/aarch64-builtins.c
10691 (aarch64_gimple_fold_builtin): Don't fold reduction operations for
10692 BYTES_BIG_ENDIAN.
10693
10694 2014-07-31 James Greenhalgh <james.greenhalgh@arm.com>
10695
10696 * config/aarch64/aarch64.c (aarch64_simd_vect_par_cnst_half): Vary
10697 the generated mask based on BYTES_BIG_ENDIAN.
10698 (aarch64_simd_check_vect_par_cnst_half): New.
10699 * config/aarch64/aarch64-protos.h
10700 (aarch64_simd_check_vect_par_cnst_half): New.
10701 * config/aarch64/predicates.md (vect_par_cnst_hi_half): Refactor
10702 the check out to aarch64_simd_check_vect_par_cnst_half.
10703 (vect_par_cnst_lo_half): Likewise.
10704 * config/aarch64/aarch64-simd.md
10705 (aarch64_simd_move_hi_quad_<mode>): Always use vec_par_cnst_lo_half.
10706 (move_hi_quad_<mode>): Always generate a low mask.
10707
10708 2014-07-30 Senthil Kumar Selvaraj <senthil_kumar.selvaraj@atmel.com>
10709
10710 * doc/invoke.texi (AVR Options): Add documentation about
10711 __AVR_DEVICE_NAME__ built-in macro.
10712
10713 2014-07-31 Charles Baylis <charles.baylis@linaro.org>
10714
10715 PR target/61948
10716 * config/arm/neon.md (ashldi3_neon): Don't emit arm_ashldi3_1bit unless
10717 constraints are satisfied.
10718 (<shift>di3_neon): Likewise.
10719
10720 2014-07-31 Richard Biener <rguenther@suse.de>
10721
10722 PR tree-optimization/61964
10723 * tree-ssa-tail-merge.c (gimple_equal_p): Handle non-SSA LHS solely
10724 by structural equality.
10725
10726 2014-07-31 Yury Gribov <y.gribov@samsung.com>
10727
10728 * doc/cpp.texi (__SANITIZE_ADDRESS__): Updated description.
10729 * doc/invoke.texi (-fsanitize=kernel-address): Describe new option.
10730 * flag-types.h (SANITIZE_USER_ADDRESS, SANITIZE_KERNEL_ADDRESS):
10731 New enums.
10732 * gcc.c (sanitize_spec_function): Support new option.
10733 (SANITIZER_SPEC): Remove now redundant check.
10734 * opts.c (common_handle_option): Support new option.
10735 (finish_options): Check for incompatibilities.
10736 * toplev.c (process_options): Split userspace-specific checks.
10737
10738 2014-07-31 Richard Biener <rguenther@suse.de>
10739
10740 * lto-streamer.h (struct output_block): Remove global.
10741 (struct data_in): Remove labels, num_named_labels and
10742 num_unnamed_labels.
10743 * lto-streamer-in.c (lto_data_in_delete): Do not free labels.
10744 * lto-streamer-out.c (produce_asm_for_decls): Do not set global.
10745
10746 2014-07-31 Marc Glisse <marc.glisse@inria.fr>
10747
10748 PR c++/60517
10749 * common.opt (-Wreturn-local-addr): Moved from c.opt.
10750 * gimple-ssa-isolate-paths.c: Include diagnostic-core.h and intl.h.
10751 (isolate_path): New argument to avoid inserting a trap.
10752 (find_implicit_erroneous_behaviour): Handle returning the address
10753 of a local variable.
10754 (find_explicit_erroneous_behaviour): Likewise.
10755
10756 2014-07-31 Bingfeng Mei <bmei@broadcom.com>
10757
10758 PR lto/61868
10759 * toplev.c (init_random_seed): Move piece of code never called to
10760 set_random_seed.
10761 (set_random_seed): see above.
10762
10763 2014-07-31 Tom de Vries <tom@codesourcery.com>
10764
10765 * tree-ssa-loop.c (pass_tree_loop_init::execute): Remove dead code.
10766
10767 2014-07-31 Richard Sandiford <rdsandiford@googlemail.com>
10768
10769 * ira.c (insn_contains_asm_1, insn_contains_asm): Delete.
10770 (compute_regs_asm_clobbered): Use extract_asm_operands instead.
10771
10772 2014-07-31 Richard Biener <rguenther@suse.de>
10773
10774 * data-streamer.h (streamer_write_data_stream): Declare here,
10775 renamed from ...
10776 * lto-streamer.h (lto_output_data_stream): ... this. Remove.
10777 * lto-cgraph.c (lto_output_node): Adjust.
10778 (lto_output_varpool_node): Likewise.
10779 * data-streamer-out.c (streamer_string_index): Likewise.
10780 (streamer_write_data_stream, lto_append_block): Move from ...
10781 * lto-section-out.c (lto_output_data_stream,
10782 lto_append_block): ... here.
10783
10784 2014-07-30 Mike Stump <mikestump@comcast.net>
10785
10786 * configure.ac: Also check for popen.
10787 * tree-loop-distribution.c (dot_rdg): Autoconfize popen use.
10788 * configure: Regenerate.
10789 * config.in: Regenerate.
10790
10791 2014-07-30 Martin Jambor <mjambor@suse.cz>
10792
10793 * tree-sra.c (sra_ipa_modify_assign): Change type of the first
10794 parameter to gimple.
10795
10796 2014-07-30 Ulrich Weigand <Ulrich.Weigand@de.ibm.com>
10797
10798 * config/s390/s390.c (s390_emit_tpf_eh_return): Pass original return
10799 address as second parameter to __tpf_eh_return routine.
10800
10801 2014-07-30 Jiong Wang <jiong.wang@arm.com>
10802
10803 * config/arm/arm.c (arm_get_frame_offsets): Adjust condition for
10804 Thumb2.
10805
10806 2014-07-30 Tom Tromey <tromey@redhat.com>
10807
10808 PR c/59855
10809 * doc/invoke.texi (Warning Options): Document -Wdesignated-init.
10810 * doc/extend.texi (Type Attributes): Document designated_init
10811 attribute.
10812
10813 2014-07-30 Roman Gareev <gareevroman@gmail.com>
10814
10815 * graphite-isl-ast-to-gimple.c:
10816 (gcc_expression_from_isl_ast_expr_id): Add calling of fold_convert.
10817 (gcc_expression_from_isl_expression): Pass type to
10818 gcc_expression_from_isl_ast_expr_id.
10819
10820 2014-07-30 Richard Biener <rguenther@suse.de>
10821
10822 * lto-streamer.h (lto_write_data): New function.
10823 * langhooks.c (lhd_append_data): Do not free block.
10824 * lto-section-out.c (lto_write_data): New function writing
10825 raw data to the current section.
10826 (lto_write_stream): Adjust for langhook semantic change.
10827 (lto_destroy_simple_output_block): Write header directly.
10828 * lto-opts.c (lto_write_options): Write options directly.
10829 * lto-streamer-out.c (produce_asm): Write heaeder directly.
10830 (lto_output_toplevel_asms): Likewise.
10831 (copy_function_or_variable): Copy data directly.
10832 (write_global_references): Output index table directly.
10833 (lto_output_decl_state_refs): Likewise.
10834 (write_symbol): Write data directly.
10835 (produce_symtab): Adjust.
10836 (produce_asm_for_decls): Output header and refs directly.
10837
10838 2014-07-29 Jan Hubicka <hubicka@ucw.cz>
10839
10840 * ipa-devirt.c (polymorphic_call_target_d): Rename nonconstruction_targets
10841 to speculative_targets
10842 (get_class_context): Fix handling of contextes without outer type;
10843 avoid matching non-polymorphic types in LTO.
10844 (possible_polymorphic_call_targets): Trun nonconstruction_targetsp
10845 parameter to speculative_targetsp; handle speculation.
10846 (dump_possible_polymorphic_call_targets): Update dumping.
10847
10848 2014-07-29 Jan Hubicka <hubicka@ucw.cz>
10849
10850 * common.opt (Wodr): Enable by default.
10851
10852 2014-07-29 Olivier Hainque <hainque@adacore.com>
10853
10854 * config/vxworksae.h (VXWORKS_OVERRIDE_OPTIONS): Define.
10855
10856 2014-07-29 H.J. Lu <hongjiu.lu@intel.com>
10857
10858 PR bootstrap/61914
10859 * gengtype.c (strtoken): New function.
10860 (create_user_defined_type): Replace strtok with strtoken.
10861
10862 2014-07-29 Nathan Sidwell <nathan@acm.org>
10863
10864 * gcov-io.c (gcov_var): Make hidden.
10865 * gcov-tool.c (gcov_list, gcov_exit): Remove declarations.
10866 (gcov_do_dump): Declare.
10867 (gcov_output_files): Call gcov_do_dump, not gcov_exit).
10868
10869 2014-07-29 Martin Jambor <mjambor@suse.cz>
10870
10871 * tree-sra.c (sra_modify_constructor_assign): Change type of stmt
10872 parameter to gimple.
10873 (sra_modify_assign): Likewise.
10874
10875 2014-07-29 Richard Biener <rguenther@suse.de>
10876
10877 PR middle-end/52478
10878 * expr.c (expand_expr_real_2): Revert last change.
10879
10880 2014-07-28 Jan Hubicka <hubicka@ucw.cz>
10881
10882 * cgraph.c (cgraph_node::create_indirect_edge): Copy speculative data.
10883 * cgraph.h (cgraph_indirect_call_info): Add speculative data.
10884 * gimple-fold.c (fold_gimple_assign): Fix check for virtual
10885 call.
10886 * ipa-devirt.c (ipa_dummy_polymorphic_call_context): Update
10887 (contains_type_p): Forward declare.
10888 (polymorphic_call_target_hasher::hash): Hash speculative info.
10889 (polymorphic_call_target_hasher::equal): Compare speculative info.
10890 (get_class_context): Handle speuclation.
10891 (contains_type_p): Update.
10892 (get_polymorphic_call_info_for_decl): Update.
10893 (walk_ssa_copies): Break out from ...
10894 (get_polymorphic_call_info): ... here; set speculative context
10895 before giving up.
10896 * ipa-prop.c (ipa_write_indirect_edge_info,
10897 ipa_read_indirect_edge_info): Stream speculative context.
10898 * ipa-utils.h (ipa_polymorphic_call_context): Add speculative info
10899 (SPECULATIVE_OFFSET, SPECULATIVE_OUTER_TYPE,
10900 SPECULATIVE_MAYBE_DERIVED_TYPE).
10901 (possible_polymorphic_call_targets overriders): Update.
10902 (dump_possible_polymorphic_call_targets overriders): Update.
10903 (dump_possible_polymorphic_call_target_p overriders): Update.
10904
10905 2014-07-28 Jan Hubicka <hubicka@ucw.cz>
10906
10907 * gimple-fold.c (fold_gimple_assign): Fix condition guarding
10908 ipa-devirt path; fix thinko there.
10909
10910 2014-07-28 Trevor Saunders <tsaunders@mozilla.com>
10911
10912 * config/i386/i386.c (ix86_return_in_memory): Replace one
10913 ATTRIBUTE_UNUSED where the attribute can actually sometimes be unused.
10914
10915 2014-07-28 Marek Polacek <polacek@redhat.com>
10916
10917 * doc/invoke.texi (-Wno-odr): Fix @item entry. Tweak wording.
10918
10919 2014-07-28 Peter Bergner <bergner@vnet.ibm.com>
10920
10921 * config.gcc (powerpc*-*-linux*): Include gnu-user.h in tm_file.
10922 * config/rs6000/sysv4.h (CC1_SPEC): Undefine it before defining it.
10923 * config/rs6000/linux.h (CPLUSPLUS_CPP_SPEC): Delete define.
10924 (LINK_GCC_C_SEQUENCE_SPEC): Likewise.
10925 (USE_LD_AS_NEEDED): Likewise.
10926 (ASM_APP_ON): Likewise.
10927 (ASM_APP_OFF): Likewise.
10928 (TARGET_POSIX_IO): Likewise.
10929 * config/rs6000/linux64.h (CPLUSPLUS_CPP_SPEC): Likewise.
10930 (LINK_GCC_C_SEQUENCE_SPEC): Likewise.
10931 (USE_LD_AS_NEEDED): Likewise.
10932 (ASM_APP_ON): Likewise.
10933 (ASM_APP_OFF): Likewise.
10934 (TARGET_POSIX_IO): Likewise.
10935
10936 2014-07-28 Eric Botcazou <ebotcazou@adacore.com>
10937
10938 PR middle-end/61734
10939 * fold-const.c (fold_comparison): Disable X - Y CMP 0 to X CMP Y for
10940 operators other than the equality operators.
10941
10942 2014-07-28 Richard Biener <rguenther@suse.de>
10943
10944 PR middle-end/52478
10945 * optabs.c (gen_int_libfunc): For -ftrapv libfuncs make
10946 sure to register SImode ones, not only >= word_mode ones.
10947 * expr.c (expand_expr_real_2): When expanding -ftrapv
10948 binops do not use OPTAB_LIB_WIDEN.
10949
10950 2014-07-28 Richard Sandiford <rdsandiford@googlemail.com>
10951
10952 PR middle-end/61919
10953 * tree-outof-ssa.c (insert_partition_copy_on_edge)
10954 (insert_value_copy_on_edge, insert_rtx_to_part_on_edge)
10955 (insert_part_to_rtx_on_edge): Copy partition_to_pseudo rtxes before
10956 inserting them in the insn stream.
10957
10958 2014-07-28 Marek Polacek <polacek@redhat.com>
10959
10960 PR middle-end/61913
10961 * common.opt (Wodr): Add Var.
10962
10963 2014-07-28 Richard Biener <rguenther@suse.de>
10964
10965 PR tree-optimization/61921
10966 * tree-ssa-structalias.c (create_variable_info_for_1): Check
10967 if there is a varpool node before dereferencing it.
10968
10969 2014-07-28 Roman Gareev <gareevroman@gmail.com>
10970
10971 * graphite-sese-to-poly.c:
10972 (new_pbb_from_pbb): Set a new id of pbb1->domain (instead of using the
10973 id of the pbb), which contains pointer to the pbb1.
10974
10975 * gcc.dg/graphite/isl-ast-gen-if-2.c: New testcase.
10976
10977 2014-07-28 Roman Gareev <gareevroman@gmail.com>
10978
10979 * graphite-isl-ast-to-gimple.c:
10980 (graphite_create_new_guard): New function.
10981 (translate_isl_ast_node_if): New function.
10982 (translate_isl_ast): Add calling of translate_isl_ast_node_if.
10983
10984 * gcc.dg/graphite/isl-ast-gen-if-1.c: New testcase.
10985
10986 2014-07-27 Anthony Green <green@moxielogic.com>
10987
10988 * config.gcc: Add moxie-*-moxiebox* configuration.
10989 * config/moxie/moxiebox.h: New file.
10990
10991 2014-07-26 Andrew Pinski <apinski@cavium.com>
10992
10993 * config/aarch64/aarch64.md (*extr_insv_lower_reg<mode>): Remove +
10994 from the read only register.
10995
10996 2014-07-26 Richard Sandiford <rdsandiford@googlemail.com>
10997
10998 * ira-costs.c (find_costs_and_classes): For -O0, use the best class
10999 as the allocation class if it isn't likely to be spilled.
11000
11001 2014-07-26 Richard Sandiford <rdsandiford@googlemail.com>
11002
11003 * rtl.h (tls_referenced_p): Declare.
11004 * rtlanal.c (tls_referenced_p_1, tls_referenced_p): New functions.
11005 * config/mips/mips.c (mips_tls_symbol_ref_1): Delete.
11006 (mips_cannot_force_const_mem): Use tls_referenced_p.
11007 * config/pa/pa-protos.h (pa_tls_referenced_p): Delete.
11008 * config/pa/pa.h (CONSTANT_ADDRESS_P): Use tls_referenced_p
11009 instead of pa_tls_referenced_p.
11010 * config/pa/pa.c (hppa_legitimize_address, pa_cannot_force_const_mem)
11011 (pa_emit_move_sequence, pa_emit_move_sequence): Likewise.
11012 (pa_legitimate_constant_p): Likewise.
11013 (pa_tls_symbol_ref_1, pa_tls_referenced_p): Delete.
11014 * config/rs6000/rs6000.c (rs6000_tls_referenced_p): Delete.
11015 (rs6000_cannot_force_const_mem, rs6000_emit_move)
11016 (rs6000_address_for_altivec): Use tls_referenced_p instead of
11017 rs6000_tls_referenced_p.
11018 (rs6000_tls_symbol_ref_1): Delete.
11019
11020 2014-07-26 Marc Glisse <marc.glisse@inria.fr>
11021
11022 PR target/44551
11023 * simplify-rtx.c (simplify_binary_operation_1) <VEC_SELECT>:
11024 Optimize inverse of a VEC_CONCAT.
11025
11026 2014-07-25 Xinliang David Li <davidxl@google.com>
11027
11028 * params.def: New parameter.
11029 * coverage.c (get_coverage_counts): Check new flag.
11030 (coverage_compute_profile_id): Check new flag.
11031 (coverage_begin_function): Check new flag.
11032 (coverage_end_function): Check new flag.
11033 * value-prof.c (coverage_node_map_initialized_p): New function.
11034 (init_node_map): Populate map with all functions.
11035 * doc/invoke.texi: Document new parameter.
11036
11037 2014-07-25 Jan Hubicka <hubicka@ucw.cz>
11038 Richard Biener <rguenther@suse.de>
11039
11040 * lto-streamer-out.c (struct sccs): Turn to ...
11041 (class DFS): ... this one; refactor the DFS walk so it can
11042 be re-done on per-SCC basis.
11043 (DFS::DFS): New constructor.
11044 (DFS::~DFS): New destructor.
11045 (hash_tree): Add new MAP argument holding in-SCC hash values;
11046 remove POINTER_TYPE hashing hack.
11047 (scc_entry_compare): Rename to ...
11048 (DFS::scc_entry_compare): ... this one.
11049 (hash_scc): Rename to ...
11050 (DFS::hash_scc): ... this one; pass output_block instead
11051 of streamer_cache; work harder to get unique and stable SCC
11052 hashes.
11053 (DFS_write_tree): Rename to ...
11054 (DFS::DFS_write_tree): ... this one; add SINGLE_P parameter.
11055 (lto_output_tree): Update.
11056
11057 2014-07-25 Andi Kleen <ak@linux.intel.com>
11058
11059 * lto-streamer-out.c (hash_tree): Convert to inchash.
11060
11061 2014-07-25 Andi Kleen <ak@linux.intel.com>
11062
11063 * tree.c (build_type_attribute_qual_variant): Use inchash.
11064 (type_hash_list): Dito.
11065 (attribute_hash_list): Dito
11066 (iterative_hstate_expr): Dito.
11067 (iterative_hash_expr): Dito.
11068 (build_range_type_1): Dito.
11069 (build_array_type_1): Dito.
11070 (build_function_type): Dito.
11071 (build_method_type_directly): Dito.
11072 (build_offset_type): Dito.
11073 (build_complex_type): Dito.
11074 (make_vector_type): Dito.
11075 * tree.h (iterative_hash_expr): Add compat wrapper.
11076 (iterative_hstate_expr): Add.
11077
11078 2014-07-25 Andi Kleen <ak@linux.intel.com>
11079
11080 * Makefile.in (OBJS): Add inchash.o.
11081 (PLUGIN_HEADERS): Add inchash.h.
11082 * ipa-devirt.c: Include inchash.h.
11083 * lto-streamer-out.c: Dito.
11084 * tree-ssa-dom.c: Dito.
11085 * tree-ssa-pre.c: Dito.
11086 * tree-ssa-sccvn.c: Dito.
11087 * tree-ssa-tail-merge.c: Dito.
11088 * asan.c: Dito.
11089 * tree.c (iterative_hash_hashval_t): Move to ...
11090 (iterative_hash_host_wide_int): Move to ...
11091 * inchash.c: Here. New file.
11092 * tree.h (iterative_hash_hashval_t): Move to ...
11093 (iterative_hash_host_wide_int): Move to ...
11094 * inchash.h: Here. New file.
11095
11096 2014-07-25 Richard Biener <rguenther@suse.de>
11097
11098 PR middle-end/61762
11099 PR middle-end/61894
11100 * fold-const.c (native_encode_int): Add and handle offset
11101 parameter to do partial encodings of expr.
11102 (native_encode_fixed): Likewise.
11103 (native_encode_real): Likewise.
11104 (native_encode_complex): Likewise.
11105 (native_encode_vector): Likewise.
11106 (native_encode_string): Likewise.
11107 (native_encode_expr): Likewise.
11108 * fold-const.c (native_encode_expr): Add offset parameter
11109 defaulting to -1.
11110 * gimple-fold.c (fold_string_cst_ctor_reference): Remove.
11111 (fold_ctor_reference): Handle all reads from tcc_constant
11112 ctors.
11113
11114 2014-07-25 Richard Biener <rguenther@suse.de>
11115
11116 * tree-inline.c (estimate_move_cost): Mark speed_p argument
11117 as possibly unused.
11118
11119 2014-07-23 Senthil Kumar Selvaraj <senthil_kumar.selvaraj@atmel.com>
11120
11121 * config/avr/avr-c.c (avr_cpu_cpp_builtins): Add __AVR_DEVICE_NAME__.
11122
11123 2014-07-24 Kyle McMartin <kyle@redhat.com>
11124
11125 * config/aarch64/aarch64-linux.h (TARGET_ASM_FILE_END): Define.
11126
11127 2014-07-24 Ulrich Weigand <Ulrich.Weigand@de.ibm.com>
11128
11129 * config/rs6000/rs6000-protos.h (rs6000_special_adjust_field_align_p):
11130 Add prototype.
11131 * config/rs6000/rs6000.c (rs6000_special_adjust_field_align_p): New
11132 function.
11133 * config/rs6000/sysv4.h (ADJUST_FIELD_ALIGN): Call it.
11134 * config/rs6000/linux64.h (ADJUST_FIELD_ALIGN): Likewise.
11135 * config/rs6000/freebsd64.h (ADJUST_FIELD_ALIGN): Likewise.
11136
11137 2014-07-24 Ulrich Weigand <Ulrich.Weigand@de.ibm.com>
11138
11139 * config/rs6000/rs6000.c (rs6000_function_arg_boundary): In the AIX
11140 and ELFv2 ABI, do not use the "mode == BLKmode" check to test for
11141 aggregate types. Instead, *all* aggregate types, except for single-
11142 element or homogeneous float/vector aggregates, are quadword-aligned
11143 if required by their type alignment. Issue -Wpsabi note when a type
11144 is now treated differently than before.
11145
11146 2014-07-24 Ulrich Weigand <Ulrich.Weigand@de.ibm.com>
11147
11148 * config/rs6000/rs6000.c (rs6000_function_arg): If a float argument
11149 does not fit fully into floating-point registers, and there is still
11150 space in the register parameter area, use GPRs to pass those parts
11151 of the argument. Issue -Wpsabi note if any parameter is now treated
11152 differently than before.
11153 (rs6000_arg_partial_bytes): Update.
11154
11155 2014-07-24 Uros Bizjak <ubizjak@gmail.com>
11156
11157 * config/alpha/elf.h: Define TARGET_UNWIND_TABLES_DEFAULT.
11158
11159 2014-07-24 Richard Sandiford <rdsandiford@googlemail.com>
11160
11161 * rtl.h (target_rtl): Remove lang_dependent_initialized.
11162 * toplev.c (initialize_rtl): Don't use it. Move previously
11163 "language-dependent" calls to...
11164 (backend_init): ...here.
11165 (lang_dependent_init_target): Don't set lang_dependent_initialized.
11166 Assert that RTL initialization hasn't happend yet.
11167
11168 2014-07-24 Richard Sandiford <rdsandiford@googlemail.com>
11169
11170 PR rtl-optimization/61629
11171 * reginfo.c (reinit_regs): Only call ira_init and recog_init if
11172 they have already been initialized.
11173
11174 2014-07-24 Richard Sandiford <rdsandiford@googlemail.com>
11175
11176 PR middle-end/61268
11177 * function.c (assign_parm_setup_reg): Prevent invalid sharing of
11178 DECL_INCOMING_RTL and entry_parm.
11179 (get_arg_pointer_save_area): Likewise arg_pointer_save_area.
11180 * calls.c (load_register_parameters): Likewise argument values.
11181 (emit_library_call_value_1, store_one_arg): Likewise argument
11182 save areas.
11183 * config/i386/i386.c (assign_386_stack_local): Likewise the local
11184 stack slot.
11185 * explow.c (validize_mem): Modify the argument in-place.
11186
11187 2014-07-24 Jiong Wang <jiong.wang@arm.com>
11188
11189 * config/aarch64/aarch64.c (aarch64_popwb_single_reg): New function.
11190 (aarch64_expand_epilogue): Optimize epilogue when !frame_pointer_needed.
11191
11192 2014-07-24 Jiong Wang <jiong.wang@arm.com>
11193
11194 * config/aarch64/aarch64.c (aarch64_pushwb_single_reg): New function.
11195 (aarch64_expand_prologue): Optimize prologue when !frame_pointer_needed.
11196
11197 2014-07-24 Jiong Wang <jiong.wang@arm.com>
11198
11199 * config/aarch64/aarch64.c (aarch64_restore_callee_saves)
11200 (aarch64_save_callee_saves): New parameter "skip_wb".
11201 (aarch64_expand_prologue, aarch64_expand_epilogue): Update call site.
11202
11203 2014-07-24 Jiong Wang <jiong.wang@arm.com>
11204
11205 * config/aarch64/aarch64.h (frame): New fields "wb_candidate1" and
11206 "wb_candidate2".
11207 * config/aarch64/aarch64.c (aarch64_layout_frame): Initialize above.
11208
11209 2014-07-24 Roman Gareev <gareevroman@gmail.com>
11210
11211 * graphite-isl-ast-to-gimple.c:
11212 (graphite_create_new_loop): Add calling of isl_id_free to properly
11213 decrement reference counts.
11214
11215 * gcc.dg/graphite/isl-ast-gen-blocks-4.c: New testcase.
11216
11217 2014-07-24 Martin Liska <mliska@suse.cz>
11218 * config/mips/mips.c (mips_start_unique_function): Correct cgraph_node
11219 function used.
11220 * config/rs6000/rs6000.c (call_ABI_of_interest): Likewise.
11221 (rs6000_code_end): Likewise.
11222
11223 2014-07-24 Martin Liska <mliska@suse.cz>
11224
11225 * config/rs6000/rs6000.c (rs6000_xcoff_declare_function_name): Correct
11226 symtab_node funtion used.
11227 (rs6000_xcoff_declare_object_name): Likewise.
11228
11229 2014-07-24 Martin Liska <mliska@suse.cz>
11230
11231 * cgraphunit.c (compile): Correct function used.
11232
11233 2014-07-24 Jan Hubicka <hubicka@ucw.cz>
11234
11235 * lto-streamer-out.c (tree_is_indexable): Consider IMPORTED_DECL
11236 as non-indexable.
11237
11238 2014-07-24 Jan Hubicka <hubicka@ucw.cz>
11239
11240 PR lto/61802
11241 * varasm.c (bss_initializer_p): Handle offlined ctors.
11242 (align_variable, get_variable_align): Likewise.
11243 (make_decl_one_only): Likewise.
11244 (default_binds_local_p_1): Likewise.
11245 (decl_binds_to_current_def_p): Likewise.
11246 (get_variable_section): Get constructor if it is offlined.
11247 (assemble_variable_contents): Sanity check that the caller
11248 streamed in the ctor in LTO.
11249
11250 2014-07-24 Roman Gareev <gareevroman@gmail.com>
11251
11252 * graphite-isl-ast-to-gimple.c:
11253 (binary_op_to_tree): Add calling of translate_isl_ast_node_block.
11254 (gcc_expression_from_isl_expr_op): Move isl_ast_op_pdiv_q,
11255 isl_ast_op_pdiv_r to the different case.
11256
11257 * gcc.dg/graphite/isl-ast-gen-blocks-3.c: New testcase.
11258
11259 2014-07-24 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
11260
11261 PR middle-end/61876
11262 * convert.c (convert_to_integer): Do not convert BUILT_IN_ROUND and cast
11263 when flag_errno_math is on.
11264
11265 2014-07-24 Martin Liska <mliska@suse.cz>
11266
11267 * cgraph.h (varpool_node):
11268 (availability get_availability (void)):
11269 created from cgraph_variable_initializer_availability
11270 (inline varpool_node *ultimate_alias_target (availability *availability = NULL)
11271 created from: cgraph_variable_initializer_availability
11272 (inline varpool_node *get_alias_target (void)): created from varpool_alias_target
11273 (void finalize_named_section_flags (void)):
11274 created from varpool_finalize_named_section_flags
11275 (bool assemble_decl (void)): created from varpool_assemble_decl
11276 (void analyze (void)): created from varpool_analyze_node
11277 (bool call_for_node_and_aliases (bool (*callback) (varpool_node *, void *),
11278 void *data, bool include_overwritable)): created fromvarpool_for_node_and_aliases
11279 (void remove_initializer (void)): created from varpool_remove_initializer
11280 (tree get_constructor (void)): created from varpool_get_constructor
11281 (bool externally_visible_p (void)): created from varpool_externally_visible_p
11282 (bool ctor_useable_for_folding_p (void)): created from varpool_ctor_useable_for_folding_p
11283 (inline bool all_refs_explicit_p ()): created from varpool_all_refs_explicit_p
11284 (inline bool can_remove_if_no_refs_p (void)): created from varpool_can_remove_if_no_refs
11285 (static inline varpool_node *get (const_tree decl)): created from varpool_get_node
11286 (static void finalize_decl (tree decl)): created from varpool_finalize_decl
11287 (static bool output_variables (void)): created from varpool_output_variables
11288 (static varpool_node * create_extra_name_alias (tree alias, tree decl)):
11289 created from varpool_extra_name_alias
11290 (static varpool_node * create_alias (tree, tree)): created from varpool_create_variable_alias
11291 (static void dump_varpool (FILE *f)): created from dump_varpool
11292 (static void DEBUG_FUNCTION debug_varpool (void)): created from debug_varpool
11293 (static varpool_node *create_empty (void)): created from varpool_create_empty_node
11294 (static varpool_node *get_create (tree decl)): created from varpool_node_for_decl
11295 (static varpool_node *get_for_asmname (tree asmname)): created from varpool_node_for_asm
11296 (void assemble_aliases (void)): created from assemble_aliases
11297
11298 2014-07-24 Martin Liska <mliska@suse.cz>
11299
11300 * cgraph.h (symtab_node):
11301 (void register_symbol (void)): created from symtab_register_node
11302 (void remove (void)): created from symtab_remove_node
11303 (void dump (FILE *f)): created from dump_symtab_node
11304 (void DEBUG_FUNCTION debug (void)): created from debug_symtab_node
11305 (void DEBUG_FUNCTION verify (void)): created from verify_symtab_node
11306 (struct ipa_ref *add_reference (symtab_node *referred_node,
11307 enum ipa_ref_use use_type)): created from add_reference
11308 (struct ipa_ref *add_reference (symtab_node *referred_node,
11309 enum ipa_ref_use use_type, gimple stmt)): created from add_reference
11310 (struct ipa_ref *maybe_add_reference (tree val, enum ipa_ref_use use_type,
11311 gimple stmt)): created from maybe_add_reference
11312 (bool semantically_equivalent_p (symtab_node *target)): created from
11313 symtab_semantically_equivalent_p
11314 (void remove_from_same_comdat_group (void)): created from
11315 remove_from_same_comdat_group
11316 (void add_to_same_comdat_group (symtab_node *old_node)): created from
11317 symtab_add_to_same_comdat_group
11318 (void dissolve_same_comdat_group_list (void)): created from
11319 symtab_dissolve_same_comdat_group_list
11320 (bool used_from_object_file_p (void)): created from symtab_used_from_object_file_p
11321 (symtab_node *ultimate_alias_target (enum availability *avail = NULL)):
11322 created from symtab_alias_ultimate_target
11323 (inline symtab_node *next_defined_symbol (void)): created from
11324 symtab_next_defined_symbol
11325 (bool resolve_alias (symtab_node *target)): created from
11326 symtab_resolve_alias
11327 (bool call_for_symbol_and_aliases (bool (*callback) (symtab_node *, void *),
11328 void *data, bool include_overwrite)): created from symtab_for_node_and_aliases
11329 (symtab_node *noninterposable_alias (void)): created from symtab_nonoverwritable_alias
11330 (inline symtab_node *get_alias_target (void)): created from symtab_alias_target
11331 (void set_section (const char *section)): created from set_section_1
11332 (enum availability get_availability (void)): created from symtab_node_availability
11333 (void make_decl_local (void)): created from symtab_make_decl_local
11334 (bool real_symbol_p (void)): created from symtab_read_node
11335 (can_be_discarded_p (void)): created from symtab_can_be_discarded
11336 (inline bool comdat_local_p (void)): created from symtab_comdat_local_p
11337 (inline bool in_same_comdat_group_p (symtab_node *target)): created from
11338 symtab_in_same_comdat_p;
11339 (bool address_taken_from_non_vtable_p (void)): created from
11340 address_taken_from_non_vtable_p
11341 (static inline symtab_node *get (const_tree decl)): created from symtab_get_node
11342 (static void dump_table (FILE *)): created from dump_symtab
11343 (static inline DEBUG_FUNCTION void debug_symtab (void)): created from debug_symtab
11344 (static DEBUG_FUNCTION void verify_symtab_nodes (void)): created from verify_symtab
11345 (static bool used_from_object_file_p_worker (symtab_node *node)): created from
11346 symtab_used_from_object_file_p
11347 (void dump_base (FILE *)): created from dump_symtab_base
11348 (bool DEBUG_FUNCTION verify_base (void)): created from verify_symtab_base
11349 (void unregister (void)): created from symtab_unregister_node
11350 (struct symbol_priority_map *priority_info (void)): created from symtab_priority_info
11351 (static bool set_implicit_section (symtab_node *n, void *)): created from set_implicit_section
11352 (static bool noninterposable_alias (symtab_node *node, void *data)): created from
11353 symtab_nonoverwritable_alias_1
11354 * cgraph.h (cgraph_node):
11355 (bool remove_symbol_and_inline_clones (cgraph_node *forbidden_node = NULL)):
11356 created from cgraph_remove_node_and_inline_clones
11357 (void record_stmt_references (gimple stmt)): created from ipa_record_stmt_references
11358 (void set_call_stmt_including_clones (gimple old_stmt, gimple new_stmt,
11359 bool update_speculative = true)): created from cgraph_set_call_stmt_including_clones
11360 (cgraph_node *function_symbol (enum availability *avail = NULL)):
11361 created from cgraph_function_node
11362 (cgraph_node *create_clone (tree decl, gcov_type count, int freq, bool update_original,
11363 vec<cgraph_edge *> redirect_callers, bool call_duplication_hook,
11364 struct cgraph_node *new_inlined_to, bitmap args_to_skip)):
11365 created from cgraph_create_clone
11366 (cgraph_node *create_virtual_clone (vec<cgraph_edge *> redirect_callers,
11367 vec<ipa_replace_map *, va_gc> *tree_map, bitmap args_to_skip, const char * suffix)):
11368 created from cgraph_create_virtual_clone
11369 (cgraph_node *find_replacement (void)): created from cgraph_find_replacement_node
11370 (cgraph_node *create_version_clone (tree new_decl, vec<cgraph_edge *> redirect_callers,
11371 bitmap bbs_to_copy)): created from cgraph_copy_node_for_versioning
11372 (cgraph_node *create_version_clone_with_body (vec<cgraph_edge *> redirect_callers,
11373 vec<ipa_replace_map *, va_gc> *tree_map, bitmap args_to_skip, bool skip_return,
11374 bitmap bbs_to_copy, basic_block new_entry_block, const char *clone_name)):
11375 created from cgraph_function_version_info
11376 (struct cgraph_function_version_info *insert_new_function_version (void)):
11377 created from insert_new_cgraph_node_version
11378 (struct cgraph_function_version_info *function_version (void)): created from
11379 get_cgraph_node_version
11380 (void analyze (void)): created from analyze_function
11381 (cgraph_node * create_thunk (tree alias, tree, bool this_adjusting,
11382 HOST_WIDE_INT fixed_offset, HOST_WIDE_INT virtual_value, tree virtual_offset,
11383 tree real_alias) cgraph_add_thunk
11384 (inline cgraph_node *get_alias_target (void)): created from cgraph_alias_target
11385 (cgraph_node *ultimate_alias_target (availability *availability = NULL)):
11386 created from cgraph_function_or_thunk_node
11387 (bool expand_thunk (bool output_asm_thunks, bool force_gimple_thunk)):
11388 created from expand_thunk
11389 (void reset (void)): created from cgraph_reset_node
11390 (void create_wrapper (cgraph_node *target)): created from cgraph_make_wrapper
11391 (void DEBUG_FUNCTION verify_node (void)): created from verify_cgraph_node
11392 (void remove (void)): created from cgraph_remove_node
11393 (void dump (FILE *f)): created from dump_cgraph_node
11394 (void DEBUG_FUNCTION debug (void)): created from debug_cgraph_node
11395 (bool get_body (void)): created from cgraph_get_body
11396 (void release_body (void)): created from cgraph_release_function_body
11397 (void unnest (void)): created from cgraph_unnest_node
11398 (void make_local (void)): created from cgraph_make_node_local
11399 (void mark_address_taken (void)): created from cgraph_mark_address_taken_node
11400 (struct cgraph_edge *create_edge (cgraph_node *callee, gimple call_stmt,
11401 gcov_type count, int freq)): created from cgraph_create_edge
11402 (struct cgraph_edge *create_indirect_edge (gimple call_stmt, int ecf_flags,
11403 gcov_type count, int freq)): created from cgraph_create_indirect_edge
11404 (void create_edge_including_clones (struct cgraph_node *callee, gimple old_stmt,
11405 gimple stmt, gcov_type count, int freq, cgraph_inline_failed_t reason)):
11406 created from cgraph_create_edge_including_clones
11407 (cgraph_edge *get_edge (gimple call_stmt)): created from cgraph_edge
11408 (vec<cgraph_edge *> collect_callers (void)): created from collect_callers_of_node
11409 (void remove_callers (void)): created from cgraph_node_remove_callers
11410 (void remove_callees (void)): created from cgraph_node_remove_callees
11411 (enum availability get_availability (void)): created from cgraph_function_body_availability
11412 (void set_nothrow_flag (bool nothrow)): created from cgraph_set_nothrow_flag
11413 (void set_const_flag (bool readonly, bool looping)): created from cgraph_set_const_flag
11414 (void set_pure_flag (bool pure, bool looping)): created from cgraph_set_pure_flag
11415 (void call_duplication_hooks (cgraph_node *node2)): created from
11416 cgraph_call_node_duplication_hooks
11417 (bool call_for_symbol_and_aliases (bool (*callback) (cgraph_node *, void *),
11418 void *data, bool include_overwritable)): created from cgraph_for_node_and_aliases
11419 (bool call_for_symbol_thunks_and_aliases (bool (*callback) (cgraph_node *node, void *data),
11420 void *data, bool include_overwritable)): created from cgraph_for_node_thunks_and_aliases
11421 (void call_function_insertion_hooks (void)):
11422 created from cgraph_call_function_insertion_hooks
11423 (inline void mark_force_output (void)): created from cgraph_mark_force_output_node
11424 (bool local_p (void)): created from cgraph_local_node
11425 (bool can_be_local_p (void)): created from cgraph_node_can_be_local_p
11426 (bool cannot_return_p (void)): created from cgraph_node_cannot_return
11427 (bool only_called_directly_p (void)): created from cgraph_only_called_directly_p
11428 (inline bool only_called_directly_or_aliased_p (void)):
11429 created from cgraph_only_called_directly_or_aliased_p
11430 (bool will_be_removed_from_program_if_no_direct_calls_p (void)):
11431 created from cgraph_will_be_removed_from_program_if_no_direct_calls
11432 (bool can_remove_if_no_direct_calls_and_refs_p (void)):
11433 created from cgraph_can_remove_if_no_direct_calls_and_refs_p
11434 (bool can_remove_if_no_direct_calls_p (void)):
11435 created from cgraph_can_remove_if_no_direct_calls_p
11436 (inline bool has_gimple_body_p (void)):
11437 created from cgraph_function_with_gimple_body_p
11438 (bool optimize_for_size_p (void)): created from cgraph_optimize_for_size_p
11439 (static void dump_cgraph (FILE *f)): created from dump_cgraph
11440 (static inline void debug_cgraph (void)): created from debug_cgraph
11441 (static void record_function_versions (tree decl1, tree decl2)):
11442 created from record_function_versions
11443 (static void delete_function_version (tree decl)):
11444 created from delete_function_version
11445 (static void add_new_function (tree fndecl, bool lowered)):
11446 created from cgraph_add_new_function
11447 (static inline cgraph_node *get (const_tree decl)): created from cgraph_get_node
11448 (static cgraph_node * create (tree decl)): created from cgraph_create_node
11449 (static cgraph_node * create_empty (void)): created from cgraph_create_empty_node
11450 (static cgraph_node * get_create (tree)): created from cgraph_get_create_node
11451 (static cgraph_node *get_for_asmname (tree asmname)):
11452 created from cgraph_node_for_asm
11453 (static cgraph_node * create_same_body_alias (tree alias, tree decl)):
11454 created from cgraph_same_body_alias
11455 (static bool used_from_object_file_p_worker (cgraph_node *node,
11456 void *): new function
11457 (static bool non_local_p (cgraph_node *node, void *)):
11458 created from cgraph_non_local_node_p_1
11459 (static void DEBUG_FUNCTION verify_cgraph_nodes (void)):
11460 created from verify_cgraph
11461 (static bool make_local (cgraph_node *node, void *)):
11462 created from cgraph_make_node_local
11463 (static cgraph_node *create_alias (tree alias, tree target)):
11464 created from cgraph_create_function_alias
11465 (static cgraph_edge * create_edge (cgraph_node *caller, cgraph_node *callee,
11466 gimple call_stmt, gcov_type count, int freq, bool indir_unknown_callee)):
11467 created from cgraph_create_edge_1
11468 * cgraph.h (varpool_node):
11469 (void remove (void)): created from varpool_remove_node
11470 (void dump (FILE *f)): created from dump_varpool_node
11471
11472 2014-07-24 Richard Biener <rguenther@suse.de>
11473
11474 PR ipa/61823
11475 * tree-ssa-structalias.c (create_variable_info_for_1):
11476 Use varpool_get_constructor.
11477 (create_variable_info_for): Likewise.
11478
11479 2014-07-24 Jiong Wang <jiong.wang@arm.com>
11480
11481 * config/aarch64/aarch64.c (aarch64_expand_epilogue): Don't
11482 subtract outgoing area size when restoring stack_pointer_rtx.
11483
11484 2014-07-24 Nick Clifton <nickc@redhat.com>
11485
11486 * config/rx/rx.md (stack_push): Adjust RTL to account for the fact
11487 that operations are taking place in parallel.
11488 * config/rx.h (FRAME_POINTER_CFA_OFFSET): Delete.
11489
11490 2014-07-24 Thomas Schwinge <thomas@codesourcery.com>
11491
11492 * omp-low.c (extract_omp_for_data): Add missing break statement.
11493
11494 2014-07-24 Richard Biener <rguenther@suse.de>
11495
11496 * tree-inline.h (estimate_move_cost): Add speed_p parameter.
11497 * tree-inline.c (estimate_move_cost): Add speed_p parameter
11498 and adjust MOVE_RATIO query accordingly.
11499 (estimate_num_insns): Adjust callers.
11500 * ipa-prop.c (ipa_populate_param_decls): Likewise.
11501 * ipa-cp.c (gather_context_independent_values,
11502 estimate_local_effects): Likewise.
11503 * ipa-split.c (consider_split): Likewise.
11504
11505 2014-07-24 Trevor Saunders <tsaunders@mozilla.com>
11506
11507 * config/i386/driver-i386.c: Remove names of unused arguments and
11508 unnecessary unused attributes.
11509 * config/i386/host-mingw32.c: Likewise.
11510 * config/i386/i386.c: Likewise.
11511 * config/i386/winnt-stubs.c: Likewise.
11512 * config/i386/winnt.c: Likewise.
11513
11514 2014-07-23 Jiong Wang <jiong.wang@arm.com>
11515
11516 * config/aarch64/aarch64.c (aarch64_popwb_pair_reg)
11517 (aarch64_gen_loadwb_pair): New helper function.
11518 (aarch64_expand_epilogue): Simplify code using new helper functions.
11519 * config/aarch64/aarch64.md (loadwb_pair<GPF:mode>_<P:mode>): Define.
11520
11521 2014-07-23 Jiong Wang <jiong.wang@arm.com>
11522
11523 * config/aarch64/aarch64.c (aarch64_pushwb_pair_reg)
11524 (aarch64_gen_storewb_pair): New helper function.
11525 (aarch64_expand_prologue): Simplify code using new helper functions.
11526 * config/aarch64/aarch64.md (storewb_pair<GPF:mode>_<P:mode>): Define.
11527
11528 2014-07-23 Jiong Wang <jiong.wang@arm.com>
11529
11530 * config/aarch64/aarch64.md: (aarch64_save_or_restore_callee_saves):
11531 Rename to aarch64_save_callee_saves, remove restore code.
11532 (aarch64_restore_callee_saves): New function.
11533
11534 2014-07-23 Jiong Wang <jiong.wang@arm.com>
11535
11536 * config/aarch64/aarch64.c (aarch64_save_or_restore_fprs): Deleted.
11537 (aarch64_save_callee_saves): New function to handle reg save
11538 for both core and vectore regs.
11539
11540 2014-07-23 Jiong Wang <jiong.wang@arm.com>
11541
11542 * config/aarch64/aarch64.c (aarch64_gen_load_pair)
11543 (aarch64_gen_store_pair): New helper function.
11544 (aarch64_save_or_restore_callee_save_registers)
11545 (aarch64_save_or_restore_fprs): Use new helper functions.
11546
11547 2014-07-23 Jiong Wang <jiong.wang@arm.com>
11548
11549 * config/aarch64/aarch64.c (aarch64_next_callee_save): New function.
11550 (aarch64_save_or_restore_callee_save_registers)
11551 (aarch64_save_or_restore_fprs): Use aarch64_next_callee_save.
11552
11553 2014-07-23 Jiong Wang <jiong.wang@arm.com>
11554
11555 * config/aarch64/aarch64.c
11556 (aarch64_save_or_restore_callee_save_registers)
11557 (aarch64_save_or_restore_fprs): Hoist calculation of register rtx.
11558
11559 2014-07-23 Jiong Wang <jiong.wang@arm.com>
11560
11561 * config/aarch64/aarch64.c
11562 (aarch64_save_or_restore_callee_save_registers)
11563 (aarch64_save_or_restore_fprs): Remove 'increment'.
11564
11565 2014-07-23 Jiong Wang <jiong.wang@arm.com>
11566
11567 * config/aarch64/aarch64.c
11568 (aarch64_save_or_restore_callee_save_registers)
11569 (aarch64_save_or_restore_fprs): Use register offset in
11570 cfun->machine->frame.reg_offset.
11571
11572 2014-07-23 Jiong Wang <jiong.wang@arm.com>
11573
11574 * config/aarch64/aarch64.c
11575 (aarch64_save_or_restore_callee_save_registers)
11576 (aarch64_save_or_restore_fprs): Remove base_rtx.
11577
11578 2014-07-23 Jiong Wang <jiong.wang@arm.com>
11579
11580 * config/aarch64/aarch64.c
11581 (aarch64_save_or_restore_callee_save_registers): Rename 'offset'
11582 to 'start_offset'. Remove local variable 'start_offset'.
11583
11584 2014-07-23 Jiong Wang <jiong.wang@arm.com>
11585
11586 * config/aarch64/aarch64.c (aarch64_save_or_restore_fprs): Change
11587 type to HOST_WIDE_INT.
11588
11589 2014-07-23 Jiong Wang <jiong.wang@arm.com>
11590
11591 * config/aarch64/aarch64.c (aarch64_expand_prologue)
11592 (aarch64_save_or_restore_fprs)
11593 (aarch64_save_or_restore_callee_save_registers): GNU-Stylize code.
11594
11595 2014-07-23 Sebastian Huber <sebastian.huber@embedded-brains.de>
11596
11597 * config/arm/t-rtems-eabi: Add
11598 mthumb/march=armv7-r/mfpu=vfpv3-d16/mfloat-abi=hard,
11599 mthumb/march=armv7-m/mfpu=fpv4-sp-d16/mfloat-abi=hard,
11600 mbig-endian/mthumb/march=armv7-r, and
11601 mbig-endian/mthumb/march=armv7-r/mfpu=vfpv3-d16/mfloat-abi=hard
11602 multilibs.
11603
11604 2014-07-23 Sebastian Huber <sebastian.huber@embedded-brains.de>
11605 Chris Johns <chrisj@rtems.org>
11606 Joel Sherrill <joel.sherrill@oarcorp.com>
11607
11608 * config.gcc: Add nios2-*-rtems*.
11609 * config/nios2/rtems.h: New file.
11610 * gcc/config/nios2/t-rtems: New file.
11611
11612 2014-07-23 Segher Boessenkool <segher@kernel.crashing.org>
11613
11614 PR target/61396
11615 * config/rs6000/rs6000.c (paired_expand_vector_init): Only allow
11616 constant numbers, not general constants.
11617 (rs6000_expand_vector_init): Ditto.
11618
11619 2014-07-23 Nathan Sidwell <nathan@acm.org>
11620
11621 * gcov-tool.c (gcov_list): Declare here.
11622 (set_gcov_list): Remove.
11623 (gcov_output_files): Set gcov_list directly.
11624
11625 2014-07-23 Host Schirmeier <horst@schirmeier.com>
11626
11627 * doc/invoke.texi: -O3 enables -ftree-loop-distribute-patterns.
11628
11629 2014-07-23 Jiong Wang <jiong.wang@arm.com>
11630
11631 * config/arm/arm.c (arm_get_frame_offsets): If both r3 and other
11632 callee-saved registers are available for padding purpose
11633 and r3 is not mandatory, then prefer use those callee-saved
11634 instead of r3.
11635
11636 2014-07-23 Richard Biener <rguenther@suse.de>
11637
11638 * params.def (PARAM_MAX_COMBINE_INSNS): New.
11639 * combine.c: Include statistics.h and params.h.
11640 (combine_instructions): Guard three and four insn combines
11641 with max-combine-insns value. Record statistics for combines
11642 performed.
11643 * doc/invoke.texi (max-combine-insns): Document new param.
11644
11645 2014-07-23 Roman Gareev <gareevroman@gmail.com>
11646
11647 * graphite-isl-ast-to-gimple.c:
11648 (translate_isl_ast_node_block): New function.
11649 (translate_isl_ast): Add calling of translate_isl_ast_node_block.
11650
11651 * gcc.dg/graphite/isl-ast-gen-blocks-1.c: New testcase.
11652 * gcc.dg/graphite/isl-ast-gen-blocks-2.c: New testcase.
11653
11654 2014-07-23 Roman Gareev <gareevroman@gmail.com>
11655
11656 * graphite-isl-ast-to-gimple.c:
11657 (get_max_schedule_dimensions): New function.
11658 (extend_schedule): Likewise.
11659 (generate_isl_schedule): Add calling of extend_schedule and
11660 get_max_schedule_dimensions.
11661
11662 2014-07-22 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
11663
11664 * config/aarch64/aarch64.c (aarch64_rtx_costs): Handle CLRSB, CLZ.
11665 (case UNSPEC): Handle UNSPEC_RBIT.
11666
11667 2014-07-22 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
11668
11669 * config/aarch64/aarch64.md: Delete UNSPEC_CLS.
11670 (clrsb<mode>2): Use clrsb RTL code instead of UNSPEC_CLS.
11671
11672 2014-07-22 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
11673
11674 * config/aarch64/arm_neon.h (vbsl_f64): New intrinsic.
11675
11676 2014-07-22 Roman Gareev <gareevroman@gmail.com>
11677
11678 * graphite-isl-ast-to-gimple.c:
11679 Add inclusion of gimple-ssa.h, tree-into-ssa.h.
11680 (ivs_params_clear):
11681 (build_iv_mapping): New function.
11682 (translate_isl_ast_node_user): Likewise.
11683 (translate_isl_ast): Add calling of translate_isl_ast_node_user.
11684
11685 * gcc.dg/graphite/isl-ast-gen-single-loop-1.c: New testcase.
11686 * gcc.dg/graphite/isl-ast-gen-single-loop-2.c: New testcase.
11687 * gcc.dg/graphite/isl-ast-gen-single-loop-3.c: New testcase.
11688
11689 2014-07-21 Bin Cheng <bin.cheng@arm.com>
11690
11691 PR target/55701
11692 * config/arm/arm.md (setmem): New pattern.
11693 * config/arm/arm-protos.h (struct tune_params): New fields.
11694 (arm_gen_setmem): New prototype.
11695 * config/arm/arm.c (arm_slowmul_tune): Initialize new fields.
11696 (arm_fastmul_tune, arm_strongarm_tune, arm_xscale_tune): Ditto.
11697 (arm_9e_tune, arm_v6t2_tune, arm_cortex_tune): Ditto.
11698 (arm_cortex_a8_tune, arm_cortex_a7_tune): Ditto.
11699 (arm_cortex_a15_tune, arm_cortex_a53_tune): Ditto.
11700 (arm_cortex_a57_tune, arm_cortex_a5_tune): Ditto.
11701 (arm_cortex_a9_tune, arm_cortex_a12_tune): Ditto.
11702 (arm_v7m_tune, arm_v6m_tune, arm_fa726te_tune): Ditto.
11703 (arm_const_inline_cost): New function.
11704 (arm_block_set_max_insns): New function.
11705 (arm_block_set_non_vect_profit_p): New function.
11706 (arm_block_set_vect_profit_p): New function.
11707 (arm_block_set_unaligned_vect): New function.
11708 (arm_block_set_aligned_vect): New function.
11709 (arm_block_set_unaligned_non_vect): New function.
11710 (arm_block_set_aligned_non_vect): New function.
11711 (arm_block_set_vect, arm_gen_setmem): New functions.
11712
11713 2014-07-21 Bin Cheng <bin.cheng@arm.com>
11714
11715 * config/arm/arm.c (output_move_neon): Handle REG explicitly.
11716
11717 2014-07-21 Uros Bizjak <ubizjak@gmail.com>
11718
11719 PR target/61855
11720 * config/i386/avx512fintrin.h: Move constants for mantissa extraction
11721 out of #ifdef __OPTIMIZE__.
11722
11723 2014-07-20 Eric Botcazou <ebotcazou@adacore.com>
11724
11725 * cse.c (exp_equiv_p) <MEM>: For GCSE, return 0 for expressions with
11726 different trapping status if -fnon-call-exceptions is enabled.
11727
11728 2014-07-20 Eric Botcazou <ebotcazou@adacore.com>
11729
11730 * expr.c (store_field): Handle VOIDmode for calls that return values
11731 in multiple locations.
11732
11733 2014-07-20 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
11734
11735 * config/rs6000/altivec.md (unspec enum): Fix typo in UNSPEC_VSLDOI.
11736 (altivec_vsldoi_<mode>): Likewise.
11737
11738 2014-07-20 Roman Gareev <gareevroman@gmail.com>
11739
11740 * graphite-isl-ast-to-gimple.c: Fixes a formatting issue related
11741 to the number of characters in the line.
11742
11743 2014-07-20 Roman Gareev <gareevroman@gmail.com>
11744
11745 * graphite-isl-ast-to-gimple.c: Add using of
11746 build_nonstandard_integer_type instead of int128_integer_type_node.
11747
11748 2014-07-19 Eric Botcazou <ebotcazou@adacore.com>
11749
11750 * toplev.c (output_stack_usage): Adjust the location of the warning.
11751
11752 2014-07-19 Daniel Cederman <cederman@gaisler.com>
11753
11754 * config/sparc/sync.md (*membar_storeload_leon3): New insn.
11755 (*membar_storeload): Disable for LEON3.
11756
11757 2014-07-18 Bernd Edlinger <bernd.edlinger@hotmail.de>
11758
11759 PR rtl-optimization/61461
11760 * sched-vis.c (print_pattern) <ADDR_VEC, ADDR_DIFF_VEC>: Fixed.
11761
11762 2014-07-18 Uros Bizjak <ubizjak@gmail.com>
11763
11764 PR target/61794
11765 * config/i386/sse.md (avx512f_vextract<shuffletype>32x4_1_maskm):
11766 Fix instruction constraint.
11767 (<mask_codefor>avx512f_vextract<shuffletype>32x4_1<mask_name>): Ditto.
11768
11769 2014-07-18 Jonathan Wakely <jwakely@redhat.com>
11770
11771 * doc/extend.texi (Template Instantiation): Remove stray parenthesis.
11772
11773 2014-07-18 Chung-Ju Wu <jasonwucj@gmail.com>
11774
11775 * config/nds32/nds32.c (nds32_can_eliminate): Follow the
11776 GNU coding standards.
11777 (nds32_register_move_cost): Likewise.
11778 (nds32_memory_move_cost): Likewise.
11779 (nds32_address_cost): Likewise.
11780
11781 2014-07-18 Jan-Benedict Glaw <jbglaw@lug-owl.de>
11782
11783 * config/mmix/mmix.c (mmix_intval): Drop unused automatic variable.
11784
11785 2014-07-17 John David Anglin <danglin@gcc.gnu.org>
11786
11787 * config/pa/pa-linux.h (TARGET_OS_CPP_BUILTINS): Remove defines for
11788 __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1, __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2
11789 and __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4.
11790 (HAVE_sync_compare_and_swapqi): Define.
11791 (HAVE_sync_compare_and_swaphi): Likewise.
11792 (HAVE_sync_compare_and_swapsi): Likewise.
11793
11794 2014-07-17 Richard Sandiford <rdsandiford@googlemail.com>
11795
11796 * config/mips/p5600.md: Add missing cpu tests.
11797
11798 2014-07-17 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
11799
11800 * config/aarch64/arm_neon.h (vfma_f64): New intrinsic.
11801 (vmla_f64): Likewise.
11802 (vfms_f64): Likewise.
11803 (vmls_f64): Likewise.
11804
11805 2014-07-17 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
11806
11807 * config/aarch64/aarch64.c (aarch64_frint_unspec_p): New function.
11808 (aarch64_rtx_costs): Handle FIX, UNSIGNED_FIX, UNSPEC.
11809
11810 2014-07-17 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
11811
11812 * config/aarch64/arm_neon.h (vmlal_high_lane_s16): Fix type.
11813 (vmlal_high_lane_s32): Likewise.
11814 (vmlal_high_lane_u16): Likewise.
11815 (vmlal_high_lane_u32): Likewise.
11816 (vmlsl_high_lane_s16): Likewise.
11817 (vmlsl_high_lane_s32): Likewise.
11818 (vmlsl_high_lane_u16): Likewise.
11819 (vmlsl_high_lane_u32): Likewise.
11820
11821 2014-07-17 Terry Guo <terry.guo@arm.com>
11822
11823 * config/arm/types.md (alu_reg): Replaced by alu_sreg and alu_dsp_reg.
11824 (alus_reg): Renamed to alus_sreg.
11825 * config/arm/arm-fixed.md: Change type of non-dsp instructions
11826 from alu_reg to alu_sreg. Change type of dsp instructions from
11827 alu_reg to alu_dsp_reg.
11828 * config/arm/thumb1.md: Likewise.
11829 * config/arm/thumb2.md: Likewise.
11830 * config/arm/arm.c (cortexa7_older_only): Use new ALU type names.
11831 * config/arm/arm1020e.md (1020alu_op): Replace alu_reg and alus_reg
11832 with alu_sreg and alus_sreg.
11833 * config/arm/arm1026ejs.md (alu_op): Likewise.
11834 * config/arm/arm1136jfs.md (11_alu_op): Likewise.
11835 * config/arm/arm926ejs.md (9_alu_op): Likewise.
11836 * config/arm/fa526.md (526_alu_op): Likewise.
11837 * config/arm/fa606te.md (606te_alu_op): Likewise.
11838 * config/arm/fa626te.md (626te_alu_op): Likewise.
11839 * config/arm/fa726te.md (726te_alu_op): Likewise.
11840 * config/arm/fmp626.md (mp626_alu_op): Likewise.
11841 * config/arm/arm.md (core_cycles): Replace alu_reg and alus_reg with
11842 alu_sreg, alu_dsp_reg and alus_sreg.
11843 * config/arm/cortex-a15.md (cortex_a15_alu): Likewise.
11844 * config/arm/cortex-a5.md (cortex_a5_alu): Likewise.
11845 * config/arm/cortex-a53.md (cortex_a53_alu): Likewise.
11846 * config/arm/cortex-a7.md (cortex_a7_alu_sreg): Likewise.
11847 * config/arm/cortex-a8.md (cortex_a8_alu): Likewise.
11848 * config/arm/cortex-a9.md (cortex_a9_dp): Likewise.
11849 * config/arm/cortex-m4.md (cortex_m4_alu): Likewise.
11850 * config/arm/cortex-r4.md (cortex_r4_alu): Likewise.
11851 * config/arm/marvell-pj4.md (pj4_alu, pj4_alu_conds): Likewise.
11852 * config/aarch64/aarch64.md (*addsi3_aarch64, *addsi3_aarch64_uxtw,
11853 subsi3, *adddi3_aarch64, *subsi3_uxtw, subdi3, absdi2, neg<mode>2,
11854 *negsi2_uxtw, tlsle_small_<mode>): Rename type alu_reg to alu_sreg.
11855 (add<mode>3_compare0, *addsi3_compare0_uxtw, *add<mode>3nr_compare0,
11856 sub<mode>3_compare0, *compare_neg<mode>, *neg<mode>2_compare0,
11857 subsi3_compare0_uxtw, *negsi2_compare0_uxtw, *cmp<mode>): Rename type
11858 alus_reg to alus_sreg.
11859
11860 2014-07-17 Andreas Schwab <schwab@linux-m68k.org>
11861
11862 * real.c (encode_ieee_extended_motorola): Clear integer bit in the
11863 infinity format.
11864
11865 2014-07-17 Richard Biener <rguenther@suse.de>
11866
11867 PR rtl-optimization/61801
11868 * sched-deps.c (sched_analyze_2): For ASM_OPERANDS and ASM_INPUT
11869 don't set reg_pending_barrier if it appears in a debug-insn.
11870
11871 2014-07-16 DJ Delorie <dj@redhat.com>
11872
11873 * config/rx/rx.c (rx_option_override): Fix alignment values.
11874 (rx_align_for_label): Likewise.
11875
11876 2014-07-17 Hans-Peter Nilsson <hp@axis.com>
11877
11878 PR target/61737.
11879 * config/cris/cris.c (TARGET_LEGITIMATE_CONSTANT_P)
11880 (TARGET_CANNOT_FORCE_CONST_MEM): Define.
11881 (cris_cannot_force_const_mem, cris_legitimate_constant_p): New
11882 functions.
11883 (cris_print_index, cris_print_operand, cris_constant_index_p)
11884 (cris_side_effect_mode_ok): Replace CONSTANT_P with CRIS_CONSTANT_P.
11885 (cris_address_cost): Ditto last CONSTANT_P.
11886 (cris_symbol_type_of): Rename from cris_pic_symbol_type_of. All
11887 callers changed. Yield cris_offsettable_symbol for non-PIC
11888 constant symbolic expressions including labels. Yield cris_unspec
11889 for all unspecs.
11890 (cris_expand_pic_call_address): New parameter MARKERP. Set its
11891 target to pic_offset_table_rtx for calls that will likely go
11892 through PLT, const0_rtx when they can't. All callers changed.
11893 Assert flag_pic. Use CONSTANT_P, not CONSTANT_ADDRESS_P, for
11894 symbolic expressions to be PICified. Remove second, redundant,
11895 assert on can_create_pseudo_p returning non-zero. Use
11896 replace_equiv_address_nv, not replace_equiv_address, for final
11897 operand update.
11898 * config/cris/cris.md ("movsi"): Move variable t to pattern
11899 toplevel. Adjust assert for new cris_symbol_type member. Use
11900 CONSTANT_P instead of CONSTANT_ADDRESS_P.
11901 ("*movsi_internal") <case 9>: Make check for valid unspec operands
11902 for lapc stricter.
11903 <case CRIS_UNSPEC_PCREL, CRIS_UNSPEC_PLT_PCREL>: Clear condition codes.
11904 ("call", "call_value"): Use second incoming operand as a marker
11905 for pic-offset-table-register being used.
11906 ("*expanded_call_non_v32", "*expanded_call_v32")
11907 ("*expanded_call_value_non_v32", "*expanded_call_value_v32"): For
11908 second incoming operand to CALL, match cris_call_type_marker.
11909 ("*expanded_call_value_side"): Ditto. Disable before reload_completed.
11910 ("*expanded_call_side"): Ditto. Fix typo in comment.
11911 (moverside, movemside peepholes): Check for CRIS_CONSTANT_P, not
11912 CONSTANT_P.
11913 * config/cris/predicates.md ("cris_call_type_marker"): New predicate.
11914 * config/cris/cris.h (CRIS_CONSTANT_P): New macro.
11915 (enum cris_symbol_type): Rename from cris_pic_symbol_type. All
11916 users changed. Add members cris_offsettable_symbol and cris_unspec.
11917 (cris_symbol_type): Rename from cris_pic_symbol_type.
11918 * config/cris/constraints.md ("T"): Use CRIS_CONSTANT_P, not
11919 just CONSTANT_P.
11920 * config/cris/cris-protos.h (cris_symbol_type_of,
11921 cris_expand_pic_call_address): Adjust prototypes.
11922 (cris_legitimate_constant_p): New prototype.
11923
11924 * config.gcc (crisv32-*-linux* | cris-*-linux*): Do not override
11925 an existing tmake_file. Don't add t-slibgcc and t-linux.
11926
11927 2014-07-17 Jason Merrill <jason@redhat.com>
11928
11929 PR c++/61623
11930 * symtab.c (symtab_remove_from_same_comdat_group): Also
11931 set_comdat_group to NULL_TREE.
11932 (verify_symtab): Fix diagnostic.
11933
11934 2014-07-16 David Wohlferd <dw@LimeGreenSocks.com>
11935
11936 PR target/61662
11937 * config/i386/ia32intrin.h: Use __LP64__ to determine size of long.
11938
11939 2014-07-16 Dodji Seketeli <dodji@redhat.com>
11940
11941 Support location tracking for built-in macro tokens
11942 * input.h (is_location_from_builtin_token): New function declaration.
11943 * input.c (is_location_from_builtin_token): New function definition.
11944 * toplev.c (general_init): Tell libcpp what the pre-defined
11945 spelling location for built-in tokens is.
11946
11947 2014-07-16 Jakub Jelinek <jakub@redhat.com>
11948
11949 * omp-low.c (create_omp_child_function): Don't set DECL_NAMELESS
11950 on the FUNCTION_DECL.
11951
11952 2014-07-16 Richard Biener <rguenther@suse.de>
11953
11954 PR other/61782
11955 * doc/extend.texi (always_inline): Clarify.
11956
11957 2014-07-15 Eric Christopher <echristo@gmail.com>
11958
11959 * doc/invoke.texi (Link Options): Document -z option.
11960
11961 2014-07-15 Uros Bizjak <ubizjak@gmail.com>
11962
11963 * config/alpha/alpha.c (alpha_atomic_assign_expand_fenv): New.
11964 (TARGET_ATOMIC_ASSIGN_EXPAND_FENV): New define.
11965
11966 2014-07-15 Jan Hubicka <hubicka@ucw.cz>
11967
11968 * fold-const.c (fold_checksum_tree): Fix typo in previous patch.
11969
11970 2014-07-15 Bernd Schmidt <bernds@codesourcery.com>
11971
11972 * asan.c (asan_finish_file): Use varpool_finalize_decl instead of
11973 varpool_assemble_decl.
11974 * varpool.c (varpool_assemble_decl): Assert that node->definition is
11975 true.
11976
11977 2014-07-15 Michael Matz <matz@suse.de>
11978
11979 PR rtl-optimization/61772
11980 * ifcvt.c (dead_or_predicable): Check jump to be free of side effects.
11981
11982 2014-07-15 Richard Biener <rguenther@suse.de>
11983
11984 * opts.c (default_options_table): Disable bit-ccp at -Og.
11985
11986 2014-07-14 Jan Hubicka <hubicka@ucw.cz>
11987
11988 * fold-const.c (fold_checksum_tree): Move checking of DECL_RESULT.
11989
11990 2014-07-14 Jan Hubicka <hubicka@ucw.cz>
11991
11992 * tree.c (tree_code_size): Add TRANSLATION_UNIT_DECL,
11993 NAMESPACE_DECL, IMPORTED_DECL and NAMELIST_DECL;
11994 call langhook for unknown declaration.
11995 (find_decls_types_r): Do not walk DECL_ARGUMENT_FLD.
11996 * tree.h (DECL_ARGUMENTS): Update.
11997 * print-tree.c (print_node): Update.
11998 * tree-core.h (tree_decl_non_common): Remove arguments.
11999 (tree_function_decl): Add arguments.
12000
12001 2014-07-14 Richard Earnshaw <rearnsha@arm.com>
12002
12003 * aarch64.md (add_losym_<mode>): Set type to alu_imm.
12004
12005 2014-07-14 Richard Biener <rguenther@suse.de>
12006
12007 PR tree-optimization/61779
12008 * tree-ssa-copy.c (copy_prop_visit_cond_stmt): Always try
12009 simplifying a condition.
12010
12011 2014-07-14 Richard Biener <rguenther@suse.de>
12012
12013 * builtins.c (c_strlen): Make only_value == 2 really only
12014 affect warning generation.
12015
12016 2014-07-14 Richard Biener <rguenther@suse.de>
12017
12018 PR tree-optimization/61757
12019 PR tree-optimization/61783
12020 PR tree-optimization/61787
12021 * tree-ssa-dom.c (record_equality): Revert canonicalization
12022 change and add comment.
12023 (propagate_rhs_into_lhs): Revert previous fix, removing
12024 loop depth restriction again.
12025
12026 2014-07-14 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
12027
12028 * config/arm/cortex-a15.md (cortex_a15_alu): Handle clz, rbit.
12029 * config/arm/cortex-a5.md (cortex_a5_alu): Likewise.
12030 * config/arm/cortex-a53.md (cortex_a53_alu): Likewise.
12031 * config/arm/cortex-a7.md (cortex_a7_alu_reg): Likewise.
12032 * config/arm/cortex-a9.md (cortex_a9_dp): Likewise.
12033 * config/arm/cortex-m4.md (cortex_m4_alu): Likewise.
12034 * config/arm/cortex-r4.md (cortex_r4_alu): Likewise.
12035
12036 2014-07-14 Richard Biener <rguenther@suse.de>
12037
12038 * cgraph.h (decl_in_symtab_p): Make inline.
12039
12040 2014-07-14 Jakub Jelinek <jakub@redhat.com>
12041
12042 PR middle-end/61294
12043 * doc/invoke.texi (-Wmemset-transposed-args): Document.
12044
12045 PR target/61656
12046 * config/i386/i386.c (classify_argument): Don't merge classes above
12047 number of words.
12048
12049 2014-07-13 Jan Hubicka <hubicka@ucw.cz>
12050
12051 * cgraph.h (symtab_node): Add nonzero_address.
12052 (decl_in_symtab_p): Break out from ...
12053 (symtab_get_node): ... here.
12054 * fold-const.c: Include cgraph.h
12055 (tree_single_nonzero_warnv_p): Use symtab to determine
12056 if symbol is non-zero.
12057 * symtab.c (symtab_node::nonzero_address): New method.
12058
12059 2014-07-12 Jan Hubicka <hubicka@ucw.cz>
12060
12061 * ipa-devirt.c (odr_subtypes_equivalent_p): Disable temporary hack
12062 forgotten in previous commit.
12063
12064 2014-07-12 Jan Hubicka <hubicka@ucw.cz>
12065
12066 * tree.c (type_in_anonymous_namespace_p): Ignore TREE_PUBLIC
12067 on builtin types.
12068 * ipa-devirt.c: Include stor-layout.h and intl.h
12069 (odr_subtypes_equivalent_p): New function.
12070 (warn_odr): New function.
12071 (warn_type_mismatch): New function.
12072 (odr_types_equivalent_p): New function.
12073 (add_type_duplicate): Use it.
12074 * common.opt (Wodr): New flag.
12075 * doc/invoke.texi (Wodr): Document new warning.
12076
12077 2014-07-12 Jan Hubicka <hubicka@ucw.cz>
12078
12079 * timevar.def (TV_IPA_LTO_DECL_INIT_IO): Remove.
12080 (TV_IPA_LTO_CTORS_IN, TV_IPA_LTO_CTORS_OUT): New timevar.
12081 * cgraph.c (cgraph_get_body): Push GIMPLE_IN timevar.
12082 (varpool_get_constructor): Push CTORS_IN timevar.
12083 * lto-streamer-out.c (lto_output): Push TV_IPA_LTO_CTORS_OUT timevar.
12084
12085 2014-07-12 Uros Bizjak <ubizjak@gmail.com>
12086
12087 * config/i386/i386-builtin-types.def: Add USHORT_FTYPE_VOID.
12088 Remove VOID_FTYPE_PUSHORT.
12089 * config/i386/i386.c (bdesc_special_args) <__builtin_ia32_fnstsw>:
12090 Change code to USHORT_FTYPE_VOID.
12091 (ix86_expand_special_args_builtin): Handle USHORT_FTYPE_VOID.
12092 (ix86_expand_builtin): Remove IX86_BUILTIN_FNSTSW handling.
12093 (ix86_atomic_assign_expand_fenv): Update for
12094 __builtin_ia32_fnstsw changes.
12095 * config/i386/i386.md (x86_fnstsw_1): Set length unconditionally to 2.
12096 (fnstsw): Change operand 0 to nonimmediate operand.
12097
12098 2014-07-11 Jan Hubicka <hubicka@ucw.cz>
12099
12100 * vapool.c: Include tree-ssa-alias.h, gimple.h and lto-streamer.h
12101 (varpool_get_constructor): New function.
12102 (varpool_ctor_useable_for_folding_p): Break out from ...
12103 (ctor_for_folding): ... here; use varpool_get_constructor.
12104 (varpool_assemble_decl): Likewise.
12105 * lto-streamer.h (struct output_block): Turn cgraph_node
12106 to symbol filed.
12107 (lto_input_variable_constructor): Declare.
12108 * ipa-visibility.c (function_and_variable_visibility): Use
12109 varpool_get_constructor.
12110 * cgraph.h (varpool_get_constructor): Declare.
12111 (varpool_ctor_useable_for_folding_p): New function.
12112 * lto-streamer-out.c (get_symbol_initial_value): Take encoder
12113 parameter; return error_mark_node for non-trivial constructors.
12114 (lto_write_tree_1, DFS_write_tree): Update use of
12115 get_symbol_initial_value.
12116 (output_function): Update initialization of symbol.
12117 (output_constructor): New function.
12118 (copy_function): Rename to ..
12119 (copy_function_or_variable): ... this one; handle vars too.
12120 (lto_output): Output variable sections.
12121 * lto-streamer-in.c (input_constructor): New function.
12122 (lto_read_body): Rename from ...
12123 (lto_read_body_or_constructor): ... this one; handle vars too.
12124 (lto_input_variable_constructor): New function.
12125 * ipa-prop.c (ipa_prop_write_jump_functions,
12126 ipa_prop_write_all_agg_replacement): Update.
12127 * lto-cgraph.c (compute_ltrans_boundary): Use it.
12128 (output_cgraph_opt_summary): Set symbol to NULL.
12129
12130 2014-07-11 Jan Hubicka <hubicka@ucw.cz>
12131
12132 * ipa-prop.c (ipa_binfo_from_known_type_jfunc): In LTO do not walk
12133 non-polymorphic types.
12134 * ipa-cp.c (ipa_get_jf_ancestor_result): Likewise.
12135 * ipa-devirt.c (types_same_for_odr): Do not explode when one
12136 of types is not polymorphic.
12137
12138 2014-07-11 Vladimir Makarov <vmakarov@redhat.com>
12139
12140 * lra-constraints.c (remove_inheritance_pseudos): Process
12141 destination pseudo too.
12142
12143 2014-07-11 Rong Xu <xur@google.com>
12144
12145 * gcov-tool.c (gcov_output_files): Fix build error introduced in
12146 commit r212448.
12147
12148 2014-07-11 Pitchumani Sivanupandi <pitchumani.s@atmel.com>
12149
12150 * config/avr/avr-arch.h (avr_mcu_t): Add text section start attribute.
12151 * config/avr/avr-devices.c (AVR_MCU): Same.
12152 (avr_mcu_types): add text start value to end of device list.
12153 * config/avr/avr-mcus.def: Add text section start for all devices.
12154 (ata5782): Add new avr5 device.
12155 (ata5831): Same.
12156 * config/avr/avr-tables.opt: Regenerate.
12157 * config/avr/avr.h: Add declaration for text section start handler.
12158 (EXTRA_SPEC_FUNCTIONS): Add text section start handler to
12159 SPEC functions.
12160 (LINK_SPEC): Include text section start handler to linker spec.
12161 * config/avr/driver-avr.c (avr_device_to_text_start): New function to
12162 pass -Ttext option to linker if the text section start for the device
12163 is not zero.
12164 * config/avr/t-multilib: Regenerate.
12165 * doc/avr-mmcu.texi: Regenerate.
12166
12167 2014-07-11 David Edelsohn <dje.gcc@gmail.com>
12168
12169 * config/rs6000/aix51.h (LINK_SPEC): Remove -bnodelcsect.
12170 * config/rs6000/aix52.h (LINK_SPEC): Same.
12171 * config/rs6000/aix53.h (LINK_SPEC): Same.
12172 * config/rs6000/aix61.h (LINK_SPEC): Same.
12173 * config/rs6000/xcoff.h (MAKE_DECL_ONE_ONLY): Define.
12174
12175 2014-07-11 Roman Gareev <gareevroman@gmail.com>
12176
12177 * graphite-isl-ast-to-gimple.c (gmp_cst_to_tree): New function.
12178 (graphite_verify): New function.
12179 (ivs_params_clear): New function.
12180 (gcc_expression_from_isl_ast_expr_id): New function.
12181 (gcc_expression_from_isl_expr_int): New function.
12182 (binary_op_to_tree): New function.
12183 (ternary_op_to_tree): New function.
12184 (unary_op_to_tree): New function.
12185 (nary_op_to_tree): New function.
12186 (gcc_expression_from_isl_expr_op): New function.
12187 (gcc_expression_from_isl_expression): New function.
12188 (graphite_create_new_loop): New function.
12189 (translate_isl_ast_for_loop): New function.
12190 (get_upper_bound): New function.
12191 (graphite_create_new_loop_guard): New function.
12192 (translate_isl_ast_node_for): New function.
12193 (translate_isl_ast): New function.
12194 (add_parameters_to_ivs_params): New function.
12195 (scop_to_isl_ast): New parameter ip.
12196 (graphite_regenerate_ast_isl): Add generation of GIMPLE code.
12197
12198 2014-07-11 Jan Hubicka <hubicka@ucw.cz>
12199
12200 * config/xtensa/predicates.md (call expander): Update for
12201 DECL_SECTION_NAME being string.
12202
12203 2014-07-11 Richard Biener <rguenther@suse.de>
12204
12205 PR middle-end/61473
12206 * builtins.c (fold_builtin_memory_op): Inline memory moves that
12207 can be implemented with a single load followed by a single store.
12208 (c_strlen): Only warn when only_value is not 2.
12209
12210 2014-07-11 Evgeny Stupachenko <evstupac@gmail.com>
12211
12212 * config/i386/i386.c (expand_vec_perm_pblendv): Disable for AVX.
12213
12214 2014-07-11 Marat Zakirov <m.zakirov@samsung.com>
12215
12216 PR target/61561
12217 * config/arm/arm.md (*movhi_insn_arch4): Handle stack pointer.
12218 (*movhi_bytes): Likewise.
12219 (*arm_movqi_insn): Likewise.
12220
12221 2014-07-11 Uros Bizjak <ubizjak@gmail.com>
12222
12223 PR target/56858
12224 * config/alpha/alpha.c: Include tree-pass.h, context.h
12225 and pass_manager.h.
12226 (pass_data_handle_trap_shadows): New pass.
12227 (pass_handle_trap_shadows::gate): New pass gate function.
12228 (make_pass_handle_trap_shadows): New function.
12229 (rest_of_handle_trap_shadows): Ditto.
12230
12231 (alpha_align_insns_1): Rename from alpha_align_insns.
12232 (pass_data_align_insns): New pass.
12233 (pass_align_insns::gate): New pass gate function.
12234 (make_pass_aling_insns): New function.
12235 (rest_of_align_insns): Ditto.
12236 (alpha_align_insns): Ditto.
12237
12238 (alpha_option_override): Declare handle_trap_shadows info
12239 and align_insns_info. Register handle_trap_shadows and align_insns
12240 passes here.
12241 (alpha_reorg): Do not call alpha_trap_shadows and
12242 alpha_align_insn from here.
12243
12244 (alpha_pad_function_end): Do not skip BARRIERs.
12245
12246 2014-07-10 Rong Xu <xur@google.com>
12247
12248 Add gcov-tool: an offline gcda profile processing tool support.
12249 * gcov-io.c (gcov_position): Make avaialble to gcov-tool.
12250 (gcov_is_error): Ditto.
12251 (gcov_read_string): Ditto.
12252 (gcov_read_sync): Ditto.
12253 * gcov-io.h: Move counter defines to gcov-counter.def.
12254 * gcov-dump.c (tag_counters): Use gcov-counter.def.
12255 * coverage.c: Ditto.
12256 * gcov-tool.c: Offline gcda profile processing tool.
12257 (unlink_gcda_file): Remove one gcda file.
12258 (unlink_profile_dir): Remove gcda files from the profile path.
12259 (gcov_output_files): Output gcda files to an output dir.
12260 (profile_merge): Merge two profiles in directory.
12261 (print_merge_usage_message): Print merge usage.
12262 (merge_usage): Print merge usage and exit.
12263 (do_merge): Driver for profile merge sub-command.
12264 (profile_rewrite): Rewrite profile.
12265 (print_rewrite_usage_message): Print rewrite usage.
12266 (rewrite_usage): Print rewrite usage and exit.
12267 (do_rewrite): Driver for profile rewrite sub-command.
12268 (print_usage): Print gcov-info usage and exit.
12269 (print_version): Print gcov-info version.
12270 (process_args): Process arguments.
12271 (main): Main routine for gcov-tool.
12272 * Makefile.in: Build and install gcov-tool.
12273 * gcov-counter.def: New file split from gcov-io.h.
12274 * doc/gcc.texi: Include gcov-tool.texi.
12275 * doc/gcov-tool.texi: Document for gcov-tool.
12276
12277 2014-07-10 Richard Biener <rguenther@suse.de>
12278
12279 PR tree-optimization/61757
12280 * tree-ssa-dom.c (loop_depth_of_name): Restore.
12281 (propagate_rhs_into_lhs): Revert part of last change.
12282
12283 2014-07-10 Thomas Schwinge <thomas@codesourcery.com>
12284
12285 * fold-const.c (fold_checksum_tree): Look at DECL_VINDEX only for
12286 FUNCTION_DECLs.
12287
12288 2014-07-10 Eric Botcazou <ebotcazou@adacore.com>
12289
12290 PR middle-end/53590
12291 * function.c (allocate_struct_function): Revert r188667 change.
12292
12293 * gimple-low.c (lower_builtin_setjmp): Use properly-typed constant.
12294
12295 2014-07-10 Tom G. Christensen <tgc@jupiterrise.com>
12296
12297 * doc/install.texi: Remove links to defunct package providers for
12298 Solaris.
12299
12300 2014-07-09 Tom de Vries <tom@codesourcery.com>
12301
12302 * final.c (get_call_fndecl): Declare.
12303 (self_recursive_call_p): New function.
12304 (collect_fn_hard_reg_usage): Handle self-recursive function calls.
12305
12306 2014-07-08 Jan Hubicka <hubicka@ucw.cz>
12307
12308 * ipa-devirt.c (record_node): Walk through aliases.
12309
12310 2014-07-08 Jan Hubicka <hubicka@ucw.cz>
12311
12312 * lto-streamer-out.c (hash_scc): Avoid quadratic hashing loop.
12313
12314 2014-07-08 Jan Hubicka <hubicka@ucw.cz>
12315
12316 Revert:
12317 * stor-layout.c (finish_builtin_struct): Copy fields into the variants.
12318
12319 2014-07-08 Jan Hubicka <hubicka@ucw.cz>
12320
12321 * ipa-visibility.c (function_and_variable_visibility): Remove
12322 temporary hack disabling local aliases on AIX.
12323
12324 2014-07-08 Jan Hubicka <hubicka@ucw.cz>
12325
12326 * ipa-cp.c (devirtualization_time_bonus): Walk through aliases.
12327 * ipa-inline-analysis.c (estimate_edge_devirt_benefit): Likewise.
12328
12329 2014-07-08 Jan Hubicka <hubicka@ucw.cz>
12330
12331 * rs6000/rs6000-protos.h (rs6000_xcoff_declare_object_name): Declare.
12332 * rs6000/rs6000.c: Inline output of .set instruction.
12333 (declare_alias_data): New struct.
12334 (rs6000_declare_alias): New function.
12335 (rs6000_xcoff_declare_function_name): Use it.
12336 (rs6000_xcoff_declare_object_name): New function.
12337 * config/rs6000/xcoff.h: Define ASM_DECLARE_OBJECT_NAME.
12338 (ASM_OUTPUT_DEF): Turn to empty definition.
12339
12340 2014-07-08 Trevor Saunders <tsaunders@mozilla.com>
12341
12342 PR bootstrap/61679
12343 * hash-table.h: use hash_table::value_type instead of
12344 Descriptor::value_type in the return types of several methods.
12345
12346 2014-07-08 Trevor Saunders <tsaunders@mozilla.com>
12347
12348 * tree-pass.h (pass_data): Remove has_execute member.
12349 * passes.c (execute_one_pass): Don't check pass->has_execute.
12350 * asan.c, auto-inc-dec.c, bb-reorder.c, bt-load.c, cfgcleanup.c,
12351 cfgexpand.c, cfgrtl.c, cgraphbuild.c, combine-stack-adj.c, combine.c,
12352 compare-elim.c, config/arc/arc.c, config/epiphany/mode-switch-use.c,
12353 config/epiphany/resolve-sw-modes.c, config/i386/i386.c,
12354 config/mips/mips.c, config/rl78/rl78.c, config/s390/s390.c,
12355 config/sh/sh_optimize_sett_clrt.cc, config/sh/sh_treg_combine.cc,
12356 config/sparc/sparc.c, cprop.c, cse.c, dce.c, df-core.c, dse.c,
12357 dwarf2cfi.c, except.c, final.c, function.c, fwprop.c, gcse.c,
12358 gimple-low.c, gimple-ssa-isolate-paths.c,
12359 gimple-ssa-strength-reduction.c, graphite.c, ifcvt.c, init-regs.c,
12360 ipa-comdats.c, ipa-cp.c, ipa-devirt.c, ipa-inline-analysis.c,
12361 ipa-inline.c, ipa-profile.c, ipa-pure-const.c, ipa-reference.c,
12362 ipa-split.c, ipa-visibility.c, ipa.c, ira.c, jump.c, loop-init.c,
12363 lower-subreg.c, mode-switching.c, modulo-sched.c, omp-low.c, passes.c,
12364 postreload-gcse.c, postreload.c, predict.c, recog.c, ree.c,
12365 reg-stack.c, regcprop.c, reginfo.c, regrename.c, reorg.c, sched-rgn.c,
12366 stack-ptr-mod.c, store-motion.c, tracer.c, trans-mem.c,
12367 tree-call-cdce.c, tree-cfg.c, tree-cfgcleanup.c, tree-complex.c,
12368 tree-eh.c, tree-emutls.c, tree-if-conv.c, tree-into-ssa.c,
12369 tree-loop-distribution.c, tree-nrv.c, tree-object-size.c,
12370 tree-parloops.c, tree-pass.h, tree-predcom.c, tree-profile.c,
12371 tree-sra.c, tree-ssa-ccp.c, tree-ssa-copy.c, tree-ssa-copyrename.c,
12372 tree-ssa-dce.c, tree-ssa-dom.c, tree-ssa-dse.c, tree-ssa-forwprop.c,
12373 tree-ssa-ifcombine.c, tree-ssa-loop-ch.c, tree-ssa-loop-im.c,
12374 tree-ssa-loop-ivcanon.c, tree-ssa-loop-prefetch.c,
12375 tree-ssa-loop-unswitch.c, tree-ssa-loop.c, tree-ssa-math-opts.c,
12376 tree-ssa-phiopt.c, tree-ssa-phiprop.c, tree-ssa-pre.c,
12377 tree-ssa-reassoc.c, tree-ssa-sink.c, tree-ssa-strlen.c,
12378 tree-ssa-structalias.c, tree-ssa-uncprop.c, tree-ssa-uninit.c,
12379 tree-ssa.c, tree-ssanames.c, tree-stdarg.c, tree-switch-conversion.c,
12380 tree-tailcall.c, tree-vect-generic.c, tree-vectorizer.c, tree-vrp.c,
12381 tree.c, tsan.c, ubsan.c, var-tracking.c, vtable-verify.c,
12382 web.c: Remove initializer for pass_data::has_execute.
12383
12384 2014-07-08 Trevor Saunders <tsaunders@mozilla.com>
12385
12386 * graphite-htab.h: Use hash_map instead of hash_table.
12387 * graphite-clast-to-gimple.c: Adjust.
12388 * passes.c: Use hash_map instead of hash_table.
12389 * sese.c: Likewise.
12390 * sese.h: Remove now unused code.
12391
12392 2014-07-08 Sriraman Tallam <tmsriram@google.com>
12393
12394 PR target/61599
12395 * config/i386/i386.c (ix86_in_large_data_p): Check for size less
12396 than zero.
12397
12398 2014-07-08 Jakub Jelinek <jakub@redhat.com>
12399
12400 PR rtl-optimization/61673
12401 * combine.c (simplify_comparison): Test just mode's sign bit
12402 in tmode rather than the sign bit and any bits above it.
12403
12404 2014-07-08 Roman Gareev <gareevroman@gmail.com>
12405
12406 * graphite-isl-ast-to-gimple.c (generate_isl_context):
12407 Add __isl_give to the declaration.
12408 (generate_isl_schedule): Likewise.
12409 (scop_to_isl_ast): Likewise.
12410
12411 2014-07-08 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
12412
12413 * config/arm/arm.c (cortexa5_extra_costs): New table.
12414 (arm_cortex_a5_tune): Use cortexa5_extra_costs.
12415
12416 2014-07-08 Jakub Jelinek <jakub@redhat.com>
12417
12418 PR tree-optimization/61725
12419 * tree-vrp.c (extract_range_basic): Don't assume vr0 is unsigned
12420 range, use range_includes_zerop_p instead of integer_zerop on
12421 vr0->min, only use log2 of max if min is not negative.
12422
12423 2014-07-08 Richard Biener <rguenther@suse.de>
12424
12425 * tree-ssa-dom.h (loop_depth_of_name): Remove.
12426 * tree-ssa-dom.c (record_equivalences_from_phis): Remove
12427 restriction on loop depth difference.
12428 (record_equality): Likewise.
12429 (propagate_rhs_into_lhs): Likewise. Simplify condition.
12430 (loop_depth_of_name): Remove.
12431 * tree-ssa-copy.c (copy_prop_visit_phi_node): Remove
12432 restriction on loop depth difference.
12433 (init_copy_prop): Likewise.
12434
12435 2014-07-08 Jan Hubicka <hubicka@ucw.cz>
12436
12437 * tree-ssa-alias.c (walk_aliased_vdefs_1): Add FUNCTION_ENTRY_REACHED
12438 parameter.
12439 (walk_aliased_vdefs): Likewise.
12440 * tree-ssa-alias.h (walk_aliased_vdefs): Likewise.
12441 * ipa-prop.c (stmt_may_be_vtbl_ptr_store): Skip clobbers
12442 (detect_type_change_from_memory_writes): Check if entry was reached.
12443
12444 2014-07-08 Richard Biener <rguenther@suse.de>
12445
12446 PR tree-optimization/61681
12447 * tree-ssa-structalias.c (find_what_var_points_to): Expand
12448 NONLOCAL inside ESCAPED.
12449
12450 2014-07-08 Richard Biener <rguenther@suse.de>
12451
12452 PR tree-optimization/61680
12453 * tree-vect-data-refs.c (vect_analyze_data_ref_dependence):
12454 Handle properly all read-write dependences with group accesses.
12455
12456 2014-07-08 Yuri Rumyantsev <ysrumyan@gmail.com>
12457
12458 PR tree-optimization/61576
12459 * tree-if-conv.c (is_cond_scalar_reduction): Add check that basic
12460 block containing reduction statement is predecessor of phi basi block.
12461
12462 2014-07-08 Marek Polacek <polacek@redhat.com>
12463
12464 PR c/60226
12465 * fold-const.c (round_up_loc): Change the parameter type.
12466 Remove assert.
12467 * fold-const.h (round_up_loc): Adjust declaration.
12468 * stor-layout.c (finalize_record_size): Check for too large types.
12469
12470 2014-07-07 Jan Hubicka <hubicka@ucw.cz>
12471
12472 * symtab.c: Include calls.h.
12473 (symtab_nonoverwritable_alias_1): Check sanity of the local alias.
12474
12475 2014-07-07 Maciej W. Rozycki <macro@codesourcery.com>
12476
12477 * config/rs6000/rs6000.c (output_vec_const_move): Handle
12478 little-endian code generation.
12479 * config/rs6000/spe.md (spe_evmergehi): Rename to...
12480 (vec_perm00_v2si): ... this. Handle little-endian code generation.
12481 (spe_evmergehilo): Rename to...
12482 (vec_perm01_v2si): ... this. Handle little-endian code generation.
12483 (spe_evmergelo): Rename to...
12484 (vec_perm11_v2si): ... this. Handle little-endian code generation.
12485 (spe_evmergelohi): Rename to...
12486 (vec_perm10_v2si): ... this. Handle little-endian code generation.
12487 (spe_evmergehi, spe_evmergehilo): New expanders.
12488 (spe_evmergelo, spe_evmergelohi): Likewise.
12489 (*frob_<SPE64:mode>_<DITI:mode>): Handle little-endian code generation.
12490 (*frob_tf_ti): Likewise.
12491 (*frob_<mode>_di_2): Likewise.
12492 (*frob_tf_di_8_2): Likewise.
12493 (*frob_di_<mode>): Likewise.
12494 (*frob_ti_tf): Likewise.
12495 (*frob_<DITI:mode>_<SPE64:mode>_2): Likewise.
12496 (*frob_ti_<mode>_8_2): Likewise.
12497 (*frob_ti_tf_2): Likewise.
12498 (mov_si<mode>_e500_subreg0): Rename to...
12499 (mov_si<mode>_e500_subreg0_be): ... this. Restrict to the big
12500 endianness only.
12501 (*mov_si<mode>_e500_subreg0_le): New instruction pattern.
12502 (*mov_si<mode>_e500_subreg0_elf_low): Rename to...
12503 (*mov_si<mode>_e500_subreg0_elf_low_be): ... this. Restrict to
12504 the big endianness only.
12505 (*mov_si<mode>_e500_subreg0_elf_low_le): New instruction pattern.
12506 (*mov_si<mode>_e500_subreg0_2): Rename to...
12507 (*mov_si<mode>_e500_subreg0_2_be): ... this. Restrict to the
12508 big big endianness only.
12509 (*mov_si<mode>_e500_subreg0_2_le): New instruction pattern.
12510 (*mov_si<mode>_e500_subreg4): Rename to...
12511 (*mov_si<mode>_e500_subreg4_be): ... this. Restrict to the big
12512 endianness only.
12513 (mov_si<mode>_e500_subreg4_le): New instruction pattern.
12514 (*mov_si<mode>_e500_subreg4_elf_low): Rename to...
12515 (*mov_si<mode>_e500_subreg4_elf_low_be): ... this. Restrict to
12516 the big endianness only.
12517 (*mov_si<mode>_e500_subreg4_elf_low_le): New instruction/splitter
12518 pattern.
12519 (*mov_si<mode>_e500_subreg4_2): Rename to...
12520 (*mov_si<mode>_e500_subreg4_2_be): ... this. Restrict to the big
12521 endianness only.
12522 (*mov_si<mode>_e500_subreg4_2_le): New instruction pattern.
12523 (*mov_sitf_e500_subreg8): Rename to...
12524 (*mov_sitf_e500_subreg8_be): ... this. Restrict to the big
12525 endianness only.
12526 (*mov_sitf_e500_subreg8_le): New instruction pattern.
12527 (*mov_sitf_e500_subreg8_2): Rename to...
12528 (*mov_sitf_e500_subreg8_2_be): ... this. Restrict to the big
12529 endianness only.
12530 (*mov_sitf_e500_subreg8_2_le): New instruction pattern.
12531 (*mov_sitf_e500_subreg12): Rename to...
12532 (*mov_sitf_e500_subreg12_be): ... this. Restrict to the big
12533 endianness only.
12534 (*mov_sitf_e500_subreg12_le): New instruction pattern.
12535 (*mov_sitf_e500_subreg12_2): Rename to...
12536 (*mov_sitf_e500_subreg12_2_be): ... this. Restrict to the big
12537 endianness only.
12538 (*mov_sitf_e500_subreg12_2_le): New instruction pattern.
12539
12540 2014-07-07 Max Ostapenko <m.ostapenko@partner.samsung.com>
12541
12542 * asan.c (instrument_strlen_call): Do not instrument first byte
12543 in strlen if already instrumented.
12544
12545 2014-07-07 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
12546
12547 * config/arm/arm.opt (mwords-little-endian): Delete.
12548 * config/arm/arm.h (TARGET_CPU_CPP_BUILTINS): Remove handling
12549 of TARGET_LITTLE_WORDS.
12550 (WORDS_BIG_ENDIAN): Define to BYTES_BIG_ENDIAN.
12551 * config/arm/arm.c (arm_option_override): Remove TARGET_LITTLE_WORDS
12552 warning.
12553 * doc/invoke.texi: Remove references to -mwords-little-endian.
12554
12555 2014-07-07 Jakub Jelinek <jakub@redhat.com>
12556
12557 * expmed.c (struct init_expmed_rtl): Change all fields but
12558 pow2 and cint from struct rtx_def to rtx.
12559 (init_expmed_one_conv, init_expmed_one_mode): Adjust for that change.
12560 (init_expmed): Likewise. Allocate all the 18 rtxes and ggc_free them
12561 at the end again.
12562
12563 2014-07-06 Marek Polacek <polacek@redhat.com>
12564
12565 PR c/6940
12566 * doc/invoke.texi: Document -Wsizeof-array-argument.
12567
12568 2014-07-05 Gerald Pfeifer <gerald@pfeifer.com>
12569
12570 * wide-int.h (wide_int_storage): Change declaration from struct
12571 to class.
12572
12573 2014-07-05 Jan Hubicka <hubicka@ucw.cz>
12574
12575 * cgraph.c (cgraph_create_indirect_edge): Update call of
12576 get_polymorphic_call_info.
12577 * ipa-utils.h (get_polymorphic_call_info): Add parameter CALL.
12578 (possible_polymorphic_call_targets): Add parameter call.
12579 (decl_maybe_in_construction_p): New predicate.
12580 (get_polymorphic_call_info): Add parameter call;
12581 use decl_maybe_in_construction_p.
12582 * gimple-fold.c (fold_gimple_assign): Update use of
12583 possible_polymorphic_call_targets.
12584 (gimple_fold_call): Likewise.
12585 * ipa-prop.c: Inlcude calls.h
12586 (ipa_binfo_from_known_type_jfunc): Check that known type is record.
12587 (param_type_may_change_p): New predicate.
12588 (detect_type_change_from_memory_writes): Break out from ...
12589 (detect_type_change): ... this one; use param_type_may_change_p.
12590 (detect_type_change_ssa): Use param_type_may_change_p.
12591 (compute_known_type_jump_func): Use decl_maybe_in_construction_p.
12592
12593 2014-07-05 Charles Baylis <charles.baylis@linaro.org>
12594
12595 PR target/49423
12596 * config/arm/arm-protos.h (arm_legitimate_address_p,
12597 arm_is_constant_pool_ref): Add prototypes.
12598 * config/arm/arm.c (arm_legitimate_address_p): Remove static.
12599 (arm_is_constant_pool_ref) New function.
12600 * config/arm/arm.md (unaligned_loadhis, arm_zero_extendhisi2_v6,
12601 arm_zero_extendqisi2_v6): Use Uh constraint for memory operand.
12602 (arm_extendhisi2, arm_extendhisi2_v6): Use Uh constraint for memory
12603 operand. Remove pool_range and neg_pool_range attributes.
12604 (arm_extendqihi_insn, arm_extendqisi, arm_extendqisi_v6): Remove
12605 pool_range and neg_pool_range attributes.
12606 * config/arm/constraints.md (Uh): New constraint.
12607 (Uq): Don't allow constant pool references.
12608
12609 2014-07-04 James Greenhalgh <james.greenhalgh@arm.com>
12610
12611 * config/aarch64/aarch64-simd.md (move_lo_quad_internal_<mode>): New.
12612 (move_lo_quad_internal_be_<mode>): Likewise.
12613 (move_lo_quad_<mode>): Convert to define_expand.
12614 (aarch64_simd_move_hi_quad_<mode>): Gate on BYTES_BIG_ENDIAN.
12615 (aarch64_simd_move_hi_quad_be_<mode>): New.
12616 (move_hi_quad_<mode>): Use appropriate insn for BYTES_BIG_ENDIAN.
12617 (aarch64_combinez<mode>): Gate on BYTES_BIG_ENDIAN.
12618 (aarch64_combinez_be<mode>): New.
12619 (aarch64_combine<mode>): Convert to define_expand.
12620 (aarch64_combine_internal<mode>): New.
12621 (aarch64_simd_combine<mode>): Remove bogus RTL description.
12622
12623 2014-07-04 Tom de Vries <tom@codesourcery.com>
12624
12625 * doc/md.texi (@subsection Constraint Modifier Characters): Clarify
12626 combination of earlyclobber and read/write modifiers.
12627
12628 2014-07-04 Tom de Vries <tom@codesourcery.com>
12629
12630 * config/aarch64/aarch64-simd.md
12631 (define_insn "vec_unpack_trunc_<mode>"): Fix constraint.
12632
12633 2014-07-04 Richard Earnshaw <rearnsha@arm.com>
12634
12635 PR target/61714
12636 * config/aarch64/aarch64.h (OPTION_DEFAULT_SPECS): Define.
12637
12638 2014-07-04 Jakub Jelinek <jakub@redhat.com>
12639
12640 PR middle-end/61654
12641 * cgraphunit.c (expand_thunk): Call free_dominance_info.
12642
12643 PR tree-optimization/61684
12644 * tree-ssa-ifcombine.c (recognize_single_bit_test): Make sure
12645 rhs1 of conversion is a SSA_NAME before using SSA_NAME_DEF_STMT on it.
12646
12647 2014-07-04 Chung-Ju Wu <jasonwucj@gmail.com>
12648 Kito Cheng <kito@0xlab.org>
12649 Monk Chiang <sh.chiang04@gmail.com>
12650
12651 * config/nds32/nds32.c (nds32_have_prologue_p): Move to ...
12652 (nds32_symbol_load_store_p): Move to ...
12653 (nds32_fp_as_gp_check_available): Move to ...
12654 * config/nds32/nds32-fp-as-gp.c: ... here.
12655 * config/nds32/nds32-protos.h (nds32_symbol_load_store_p): Remove
12656 extern declaration.
12657
12658 2014-07-04 Chung-Ju Wu <jasonwucj@gmail.com>
12659 Kito Cheng <kito@0xlab.org>
12660 Monk Chiang <sh.chiang04@gmail.com>
12661
12662 * config/nds32/nds32.c (nds32_expand_load_multiple): Move to ...
12663 (nds32_expand_store_multiple): Move to ...
12664 (nds32_expand_movmemqi): Move to ...
12665 * config/nds32/nds32-memory-manipulation.c: ... here.
12666
12667 2014-07-04 Chung-Ju Wu <jasonwucj@gmail.com>
12668 Kito Cheng <kito@0xlab.org>
12669 Monk Chiang <sh.chiang04@gmail.com>
12670
12671 * config/nds32/nds32.c (nds32_byte_to_size): Move to ...
12672 (nds32_output_casesi_pc_relative): Move to ...
12673 (nds32_output_casesi): Move to ...
12674 (nds32_mem_format): Move to ...
12675 (nds32_output_16bit_store): Move to ...
12676 (nds32_output_16bit_load): Move to ...
12677 (nds32_output_32bit_store): Move to ...
12678 (nds32_output_32bit_load): Move to ...
12679 (nds32_output_32bit_load_s): Move to ...
12680 (nds32_output_stack_push): Move to ...
12681 (nds32_output_stack_pop): Move to ...
12682 * config/nds32/nds32-md-auxiliary.c: ... here.
12683
12684 2014-07-04 Chung-Ju Wu <jasonwucj@gmail.com>
12685 Ling-Hua Tseng <uranus@tinlans.org>
12686
12687 * config/nds32/nds32-pipelines-auxiliary.c: Add comment to describe
12688 the purpose of this file.
12689
12690 2014-07-04 Chung-Ju Wu <jasonwucj@gmail.com>
12691 Kito Cheng <kito@0xlab.org>
12692 Monk Chiang <sh.chiang04@gmail.com>
12693
12694 * config/nds32/nds32.c (nds32_rtx_costs): Move implementation to ...
12695 (nds32_address_cost): Move implementation to ...
12696 * config/nds32/nds32-cost.c: ... here.
12697 * config/nds32/nds32-protos.h (nds32_rtx_costs_impl): Declare.
12698 (nds32_address_cost_impl): Declare.
12699
12700 2014-07-04 Chung-Ju Wu <jasonwucj@gmail.com>
12701 Kito Cheng <kito@0xlab.org>
12702 Monk Chiang <sh.chiang04@gmail.com>
12703
12704 * config/nds32/nds32.c
12705 (nds32_consecutive_registers_load_store_p): Move to ...
12706 (nds32_valid_multiple_load_store): Move to ...
12707 (nds32_valid_stack_push_pop): Move to ...
12708 (nds32_can_use_bclr_p): Move to ...
12709 (nds32_can_use_bset_p): Move to ...
12710 (nds32_can_use_btgl_p): Move to ...
12711 (nds32_can_use_bitci_p): Move to ...
12712 * config/nds32/nds32-predicates.c: ... here.
12713
12714 2014-07-04 Chung-Ju Wu <jasonwucj@gmail.com>
12715 Kito Cheng <kito@0xlab.org>
12716 Monk Chiang <sh.chiang04@gmail.com>
12717
12718 * config/nds32/nds32.c
12719 (nds32_expand_builtin_null_ftype_reg): Move to ...
12720 (nds32_expand_builtin_reg_ftype_imm): Move to ...
12721 (nds32_expand_builtin_null_ftype_reg_imm): Move to ...
12722 (nds32_init_builtins): Move implementation to ...
12723 (nds32_expand_builtin): Move implementation to ...
12724 * config/nds32/nds32-intrinsic.c: ... here.
12725 * config/nds32/nds32-protos.h (nds32_init_builtins_impl): Declare.
12726 (nds32_expand_builtin_impl): Declare.
12727
12728 2014-07-04 Chung-Ju Wu <jasonwucj@gmail.com>
12729 Kito Cheng <kito@0xlab.org>
12730 Monk Chiang <sh.chiang04@gmail.com>
12731
12732 * config/nds32/nds32.c (nds32_emit_section_head_template): Move to ...
12733 (nds32_emit_section_tail_template): Move to ...
12734 (nds32_emit_isr_jmptbl_section): Move to ...
12735 (nds32_emit_isr_vector_section): Move to ...
12736 (nds32_emit_isr_reset_conten): Move to ...
12737 (nds32_check_isr_attrs_conflict): Move to ...
12738 (nds32_construct_isr_vectors_information): Move to ...
12739 (nds32_asm_file_start): Move implementation to ...
12740 (nds32_asm_file_end): Move implementation to ...
12741 * config/nds32/nds32-isr.c: ... here.
12742 * config/nds32/nds32-protos.h
12743 (nds32_check_isr_attrs_conflict): Declare.
12744 (nds32_construct_isr_vectors_information): Declare.
12745 (nds32_asm_file_start_for_isr): Declare.
12746 (nds32_asm_file_end_for_isr): Declare.
12747
12748 2014-07-04 Chung-Ju Wu <jasonwucj@gmail.com>
12749 Kito Cheng <kito@0xlab.org>
12750 Monk Chiang <sh.chiang04@gmail.com>
12751
12752 * config.gcc (nds32*): Add new modules to extra_objs.
12753 (nds32le-*-*): Use t-nds32 makefile fragment for new modules.
12754 (nds32be-*-*): Likewise.
12755 * config/nds32/nds32-cost.c: New file.
12756 * config/nds32/nds32-fp-as-gp.c: New file.
12757 * config/nds32/nds32-intrinsic.c: New file.
12758 * config/nds32/nds32-isr.c: New file.
12759 * config/nds32/nds32-md-auxiliary.c: New file.
12760 * config/nds32/nds32-memory-manipulation.c: New file.
12761 * config/nds32/nds32-pipelines-auxiliary.c: New file.
12762 * config/nds32/nds32-predicates.c: New file.
12763 * config/nds32/t-nds32: New file.
12764
12765 2014-07-03 Jakub Jelinek <jakub@redhat.com>
12766
12767 PR tree-optimization/61682
12768 * wide-int.cc (wi::mul_internal): Handle high correctly for umul_ppmm
12769 using cases and when one of the operands is equal to 1.
12770
12771 2014-07-03 Segher Boessenkool <segher@kernel.crashing.org>
12772
12773 * config/rs6000/rs6000.md (rotl<mode>3, ashl<mode>3, lshr<mode>3,
12774 ashr<mode>3): Correct mode of operands[2].
12775 (rotl<mode>3_dot, rotl<mode>3_dot2, ashl<mode>3_dot, ashl<mode>3_dot2,
12776 lshr<mode>3_dot, lshr<mode>3_dot2, ashr<mode>3_dot, ashr<mode>3_dot2):
12777 Correct mode of operands[2]. Fix split condition.
12778
12779 2014-07-03 Richard Earnshaw <rearnsha@arm.com>
12780
12781 * arm.md (arch): Add armv6_or_vfpv3.
12782 (arch_enabled): Add test for the above.
12783 * vfp.md (divsf_vfp, divdf_vfp): Add earlyclobber when code can run
12784 on VFP9.
12785 (sqrtsf_vfp, sqrtdf_vfp): Likewise.
12786
12787 2014-07-03 Jakub Jelinek <jakub@redhat.com>
12788
12789 * gcov-io.c (gcov_read_words): Don't call memmove if excess is 0.
12790 * data-streamer-in.c (streamer_read_hwi): Shift UHWI 1 instead of
12791 HWI 1 and negate the unsigned value.
12792 * expmed.c (expand_sdiv_pow2): For modes wider than word always
12793 use AND instead of shift.
12794 * wide-int-print.cc (print_decs): Negate UHWI instead of HWI.
12795
12796 2014-07-03 Marek Polacek <polacek@redhat.com>
12797
12798 * doc/invoke.texi (-fsanitize=bounds): Tweak wording.
12799 (-fsanitize=float-divide-by-zero): Move to the table with
12800 -fsanitize=undefined suboptions.
12801 (-fsanitize=float-cast-overflow): Likewise.
12802
12803 2014-07-03 Maciej W. Rozycki <macro@codesourcery.com>
12804
12805 * config/rs6000/rs6000.c (rs6000_adjust_atomic_subword): Use
12806 BYTES_BIG_ENDIAN rather than WORDS_BIG_ENDIAN to check for byte
12807 endianness.
12808
12809 2014-07-03 Zhenqiang Chen <zhenqiang.chen@linaro.org>
12810
12811 * loop-invariant.c (struct invariant): Add a new member: eqno;
12812 (find_identical_invariants): Update eqno;
12813 (create_new_invariant): Init eqno;
12814 (get_inv_cost): Compute comp_cost with eqno;
12815
12816 2014-07-02 Segher Boessenkool <segher@kernel.crashing.org>
12817
12818 * genconfig.c (have_rotate_flag, have_rotatert_flag): New variables.
12819 (walk_insn_part) <ROTATE, ROTATERT>: New cases.
12820 (main): Conditionally write HAVE_rotate resp. HAVE_rotatert.
12821 * simplify-rtx.c (simplify_binary_operation_1) <ROTATE, ROTATERT>:
12822 Only do the transformation if both HAVE_rotate and HAVE_rotatert.
12823
12824 2014-07-02 Christian Bruel <christian.bruel@st.com>
12825
12826 PR target/29349
12827 PR target/53513
12828 * mode-switching.c (struct bb_info): Add mode_out, mode_in caches.
12829 (make_preds_opaque): Delete.
12830 (clear_mode_bit, mode_bit_p, set_mode_bit): New macros.
12831 (commit_mode_sets): New function.
12832 (optimize_mode_switching): Handle current_mode to mode_switching_emit.
12833 Process all modes at once.
12834 * basic-block.h (pre_edge_lcm_avs): Declare.
12835 * lcm.c (pre_edge_lcm_avs): Renamed from pre_edge_lcm.
12836 Call clear_aux_for_edges. Fix comments.
12837 (pre_edge_lcm): New wrapper function to call pre_edge_lcm_avs.
12838 (pre_edge_rev_lcm): Idem.
12839 * config/epiphany/epiphany.c (emit_set_fp_mode): Add prev_mode
12840 parameter.
12841 * config/epiphany/epiphany-protos.h (emit_set_fp_mode): Idem.
12842 * config/epiphany/resolve-sw-modes.c (pass_resolve_sw_modes::execute):
12843 Idem.
12844 * config/i386/i386.c (x96_emit_mode_set): Idem.
12845 * config/sh/sh.c (sh_emit_mode_set): Likewise. Handle PR toggle.
12846 * config/sh/sh.md (toggle_pr): Defined if TARGET_FPU_SINGLE.
12847 (fpscr_toggle) Disallow from delay slot.
12848 * target.def (emit_mode_set): Add prev_mode parameter.
12849 * doc/tm.texi: Regenerate.
12850
12851 2014-07-02 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
12852
12853 * config/aarch64/aarch64.c (aarch64_expand_vec_perm): Delete unused
12854 variable i.
12855
12856 2014-07-01 Jan Hubicka <hubicka@ucw.cz>
12857
12858 * ipa-utils.h (method_class_type, vtable_pointer_value_to_binfo,
12859 vtable_pointer_value_to_vtable): Constify.
12860 (contains_polymorphic_type_p): Declare.
12861 * ipa-devirt.c (method_class_type, vtable_pointer_value_to_binfo,
12862 vtable_pointer_value_to_vtable): Constify.
12863 (contains_polymorphic_type_p): New predicate.
12864 * ipa-prop.c (ipa_set_jf_known_type): Allow types containing
12865 polymorphic types.
12866 (ipa_set_ancestor_jf): Likewise.
12867 (detect_type_change): Return false in easy cases.
12868 (compute_complex_assign_jump_func): Require type to contain
12869 polymorphic type.
12870 (compute_known_type_jump_func): Likewise.
12871
12872 2014-07-01 Jan Hubicka <hubicka@ucw.cz>
12873
12874 * tree.c (decls_same_for_odr, decls_same_for_odr, types_same_for_odr):
12875 Remove.
12876 (type_in_anonymous_namespace_p): Constify argument.
12877 * tree.h (types_same_for_odr, type_in_anonymous_namespace_p): Constify.
12878 * ipa-devirt.c (odr_type_d): Add ODR_VIOLATED field.
12879 (main_odr_variant): New function.
12880 (hash_type_name): Make static; update assert; do not ICE on
12881 non-records.
12882 (types_same_for_odr): Bring here from tree.c; simplify and remove
12883 old structural comparing code that doesn't work for templates.
12884 (odr_hasher::equal): Update assert.
12885 (add_type_duplicate): Return true when bases should be computed;
12886 replace incomplete loader by complete; do not output duplicated
12887 warnings; do not ICE on non-records; set odr_violated flag.
12888 (get_odr_type): Be ready to replace incomplete type by complete
12889 one; work on ODR variants instead of main variants; reorder item
12890 in array so bases have still smaller indexes.
12891 (dump_type_inheritance_graph): Be ready for holdes in odr_types array.
12892 (possible_polymorphic_call_targets): Do not ICE when BINFO is NULL.
12893
12894 2014-07-01 Cary Coutant <ccoutant@google.com>
12895
12896 * dwarf2out.c (remove_addr_table_entry): Remove unnecessary hash table
12897 lookup.
12898 (resolve_addr_in_expr): When replacing the rtx in a location list
12899 entry, get a new address table entry.
12900 (dwarf2out_finish): Call index_location_lists even if there are no
12901 addr_index_table entries yet.
12902
12903 2014-07-01 Trevor Saunders <tsaunders@mozilla.com>
12904
12905 * config/i386/winnt.c (i386_pe_section_type_flags): Revert previous
12906 change for not being obvious.
12907
12908 2014-07-01 Trevor Saunders <tsaunders@mozilla.com>
12909
12910 * config/i386/winnt.c (i386_pe_section_type_flags): Remove name of
12911 unused argument.
12912
12913 2014-07-01 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
12914
12915 * config/aarch64/arm_neon.h (vcage_f64): New intrinsic.
12916 (vcagt_f64): Likewise.
12917 (vcale_f64): Likewise.
12918 (vcaled_f64): Likewise.
12919 (vcales_f32): Likewise.
12920 (vcalt_f64): Likewise.
12921 (vcaltd_f64): Likewise.
12922 (vcalts_f32): Likewise.
12923
12924 2014-07-01 Marek Polacek <polacek@redhat.com>
12925
12926 * doc/invoke.texi: Document -Wint-conversion.
12927
12928 2014-07-01 Marek Polacek <polacek@redhat.com>
12929
12930 PR c/58286
12931 * doc/invoke.texi: Document -Wincompatible-pointer-types.
12932
12933 2014-07-01 Martin Liska <mliska@suse.cz>
12934
12935 IPA REF alias refactoring
12936 * cgraph.h (iterate_direct_aliases): New function.
12937 (FOR_EACH_ALIAS): New macro iterates all direct aliases for a node.
12938 * cgraph.c (cgraph_for_node_thunks_and_aliases): Usage of
12939 FOR_EACH_ALIAS added.
12940 (cgraph_for_node_and_aliases): Likewise.
12941 * cgraphunit.c (assemble_thunks_and_aliases): Likewise.
12942 * ipa-inline.c (reset_edge_caches): Likewise.
12943 (update_caller_keys): Likewise.
12944 * trans-mem.c (ipa_tm_execute): Likewise.
12945 *varpool.c (varpool_analyze_node): Likewise.
12946 (varpool_for_node_and_aliases): Likewise.
12947 * ipa-ref.h (first_alias): New function.
12948 (last_alias): Likewise.
12949 (has_aliases_p): Likewise.
12950 * ipa-ref.c (ipa_ref::remove_reference): Removal function
12951 is sensitive to IPA_REF_ALIASes.
12952 * symtab.c (symtab_node::add_reference): Node of IPA_REF_ALIAS type
12953 are put at the beginning of the list.
12954 (symtab_node::iterate_direct_aliases): New function.
12955
12956 2014-06-28 Jan Hubicka <hubicka@ucw.cz>
12957
12958 Revert:
12959 * tree-streamer-out.c (pack_ts_type_common_value_fields): Stream if
12960 type is complete.
12961 (write_ts_type_common_tree_pointers): Do not stream fields not set
12962 for incomplete types; do not stream duplicated fields for variants;
12963 sanity check that variant and type match.
12964 (write_ts_type_non_common_tree_pointers): Likewise.
12965 * tree-streamer-in.c (unpack_ts_type_common_value_fields): Mark in
12966 TYPE_SIZE whether type is complete.
12967 (lto_input_ts_type_common_tree_pointers): Do same changes as in
12968 write_ts_type_common_tree_pointers
12969 (lto_input_ts_type_non_common_tree_pointers): Likewise.
12970
12971 2014-06-30 Joseph Myers <joseph@codesourcery.com>
12972
12973 * var-tracking.c (add_stores): Return instead of asserting if old
12974 and new values for conditional store are the same.
12975
12976 2014-06-30 Richard Henderson <rth@redhat.com>
12977
12978 PR rtl-opt/61608
12979 PR target/39284
12980 * bb-reorder.c (pass_duplicate_computed_gotos::execute): Cleanup
12981 the cfg if there were any changes.
12982 * passes.def: Revert move of peephole2 after reorder_blocks;
12983 move duplicate_computed_gotos before peephole2.
12984
12985 2014-06-30 Uros Bizjak <ubizjak@gmail.com>
12986
12987 * except.c (emit_note_eh_region_end): New helper function.
12988 (convert_to_eh_region_ranges): Use emit_note_eh_region_end to
12989 emit EH_REGION_END note.
12990 * jump.c (cleanup_barriers): Do not split a call and its
12991 corresponding CALL_ARG_LOCATION note.
12992
12993 2014-06-30 Jeff Law <law@redhat.com>
12994
12995 PR tree-optimization/61607
12996 * tree-ssa-threadedge.c (simplify_control_stmt_condition): Look
12997 deeper into the SSA_NAME_VALUE chain.
12998
12999 2014-06-30 Marek Polacek <polacek@redhat.com>
13000
13001 * convert.c (convert_to_integer): Don't instrument conversions if the
13002 function has no_sanitize_undefined attribute.
13003 * ubsan.c: Don't run the ubsan pass if the function has
13004 no_sanitize_undefined attribute.
13005
13006 2014-06-30 Jakub Jelinek <jakub@redhat.com>
13007
13008 * doc/invoke.texi (-fsanitize=bounds): Move to the table with
13009 -fsanitize=undefined suboptions.
13010
13011 2014-06-30 Alan Lawrence <alan.lawrence@arm.com>
13012
13013 * config/aarch64/aarch64-simd.md (vec_perm): Enable for bigendian.
13014 * config/aarch64/aarch64.c (aarch64_expand_vec_perm): Remove assert
13015 against bigendian and adjust indices.
13016
13017 2014-06-30 Gerald Pfeifer <gerald@pfeifer.com>
13018
13019 * doc/install.texi (Specific, aarch64*-*-*): Fix markup. Reword a bit.
13020
13021 2014-06-30 Marcus Shawcroft <marcus.shawcroft@arm.com>
13022
13023 PR target/61633
13024 * config/aarch64/aarch64.md (*aarch64_ashr_sisd_or_int_<mode>3):
13025 Add alternative; make early clobber. Adjust both split patterns
13026 to use operand 0 as the working register.
13027
13028 2014-06-30 Jakub Jelinek <jakub@redhat.com>
13029
13030 * ira-build.c (sort_conflict_id_map): Don't call qsort if num is 0,
13031 as ira_object_id_map might be NULL, or 1.
13032
13033 2014-06-30 Zhenqiang Chen <zhenqiang.chen@linaro.org>
13034
13035 * loop-invariant.c (get_inv_cost): Handle register class.
13036 (gain_for_invariant): Check the register pressure of the inv
13037 and its overlapped register class, other than all.
13038
13039 2014-06-30 Gerald Pfeifer <gerald@pfeifer.com>
13040
13041 * doc/invoke.texi (Optimize Options): Fix descriptions of
13042 ipa-cp-loop-hint-bonus and ipa-cp-array-index-hint-bonus.
13043
13044 2014-06-29 David Wohlferd <dw@LimeGreenSocks.com>
13045
13046 * doc/extend.texi (Function Attributes): Update 'naked' attribute
13047 documentation.
13048
13049 2014-06-29 Tobias Grosser <tobias@grosser.es>
13050
13051 PR bootstrap/61650
13052 * graphite-isl-ast-to-gimple.c: Add missing guards.
13053
13054 2014-06-29 Roman Gareev <gareevroman@gmail.com>
13055
13056 * Makefile.in: Add the compilation of graphite-isl-ast-to-gimple.o.
13057 * common.opt: Add new switch fgraphite-code-generator=[isl|cloog].
13058 * flag-types.h: Add new enum fgraphite_generator.
13059 * graphite-isl-ast-to-gimple.c: New.
13060 * graphite-isl-ast-to-gimple.h: New.
13061 * graphite.c (graphite_transform_loops): Add choice of Graphite
13062 code generator, which depends on flag_graphite_code_gen.
13063
13064 2014-06-29 Roman Gareev <gareevroman@gmail.com>
13065
13066 * graphite-dependences.c (subtract_commutative_associative_deps):
13067 Add NULL checking of the following variables: must_raw_no_source,
13068 may_raw_no_source, must_war_no_source, may_war_no_source,
13069 must_waw_no_source, may_waw_no_source, must_raw, may_raw,
13070 must_war, may_war, must_waw, may_waw.
13071
13072 2014-06-29 Roman Gareev <gareevroman@gmail.com>
13073
13074 * graphite-clast-to-gimple.c: gloog is renamed to
13075 graphite_regenerate_ast_cloog. gloog_error is renamed to
13076 graphite_regenerate_error.
13077 * graphite-clast-to-gimple.h: The definition of the struct
13078 bb_pbb_def is moved to graphite-htab.h.
13079 Add inclusion of the hash-table.h.
13080 * graphite-htab.h: The declaration of the function gloog is moved
13081 to graphite-clast-to-gimple.h and renamed to
13082 graphite_regenerate_ast_cloog.
13083 * graphite.c (graphite_transform_loops): gloog is renamed
13084 to graphite_regenerate_ast_cloog.
13085
13086 2014-06-28 Jan Hubicka <hubicka@ucw.cz>
13087
13088 * tree-streamer-out.c (pack_ts_type_common_value_fields): Stream if
13089 type is complete.
13090 (write_ts_type_common_tree_pointers): Do not stream fields not set
13091 for incomplete types; do not stream duplicated fields for variants;
13092 sanity check that variant and type match.
13093 (write_ts_type_non_common_tree_pointers): Likewise.
13094 * tree-streamer-in.c (unpack_ts_type_common_value_fields): Mark in
13095 TYPE_SIZE whether type is complete.
13096 (lto_input_ts_type_common_tree_pointers): Do same changes as in
13097 write_ts_type_common_tree_pointers
13098 (lto_input_ts_type_non_common_tree_pointers): Likewise.
13099
13100 2014-06-28 Jan Hubicka <hubicka@ucw.cz>
13101
13102 * cgraph.c (dump_cgraph_node): Dump init&fini priorities.
13103
13104 2014-06-28 Jan Hubicka <hubicka@ucw.cz>
13105
13106 * tree-inline.c (remap_type_1): Do not duplicate fields
13107 that are shared in between type and its main variant.
13108
13109 2014-06-28 Jan Hubicka <hubicka@ucw.cz>
13110
13111 * ipa-prop.c (ipa_set_jf_known_type): Record always the main variant
13112 of the type.
13113 (ipa_set_ancestor_jf) Likewise.
13114 (check_stmt_for_type_change): Check that we work on main variant.
13115 (detect_type_change): Look into main variant.
13116 (compute_known_type_jump_func): Check that main variant has BINFO.
13117
13118 2014-06-28 Jan Hubicka <hubicka@ucw.cz>
13119
13120 * ipa-devirt.c (set_type_binfo): New function.
13121 (add_type_duplicate): Use it.
13122 (get_odr_type): Sanity check that binfos points to main variants.
13123 (get_class_context): Be sure the context's outer_type is main variant.
13124 (contains_type_p): Walk main variant.
13125 (get_polymorphic_call_info_for_decl): Set outer_type to be
13126 main variant.
13127 (get_polymorphic_call_info): Likewise.
13128 (possible_polymorphic_call_targets): Sanity check that we operate
13129 on main variant.
13130
13131 2014-06-28 Jan Hubicka <hubicka@ucw.cz>
13132
13133 * stor-layout.c (finish_builtin_struct): Copy fields into the variants.
13134
13135 2014-06-28 Ulrich Weigand <Ulrich.Weigand@de.ibm.com>
13136
13137 * config/rs6000/rs6000.c (rs6000_aggregate_candidate): Revert
13138 accidental change due to wide-int branch merge.
13139
13140 2014-06-27 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
13141
13142 * configure.ac (gcc_cv_as_compress_debug): Check for assembler
13143 compressed debug support.
13144 (gcc_cv_ld_compress_debug): Check for linker compressed debug support.
13145 * configure: Regenerate.
13146 * config.in: Regenerate.
13147 * common.opt (compressed_debug_sections): New enum.
13148 (gz, gz=): New options.
13149 * gcc.c (LINK_COMPRESS_DEBUG_SPEC, ASM_COMPRESS_DEBUG_SPEC): Define.
13150 (LINK_COMMAND_SPEC): Invoke LINK_COMPRESS_DEBUG_SPEC.
13151 (asm_options): Invoke ASM_COMPRESS_DEBUG_SPEC.
13152 * config/darwin.h (LINK_COMMAND_SPEC_A): Invoke
13153 LINK_COMPRESS_DEBUG_SPEC.
13154 * config/i386/djgpp.h (LINK_COMMAND_SPEC): Likewise.
13155 * opts.c (common_handle_option): Handle OPT_gz, OPT_gz_.
13156 * doc/invoke.texi (Option Summary, Debugging Options): Add -gz[=type].
13157 (Debugging Options): Document -gz[=type].
13158
13159 2014-06-27 Martin Jambor <mjambor@suse.cz>
13160
13161 PR ipa/61160
13162 * cgraphclones.c (duplicate_thunk_for_node): Removed parameter
13163 args_to_skip, use those from node instead. Copy args_to_skip and
13164 combined_args_to_skip from node to the new thunk.
13165 (redirect_edge_duplicating_thunks): Removed parameter args_to_skip.
13166 (cgraph_create_virtual_clone): Moved computation of
13167 combined_args_to_skip...
13168 (cgraph_clone_node): ...here, simplify it to bitmap_ior..
13169
13170 2014-06-27 trevor Saunders <tsaunders@mozilla.com>
13171
13172 * config/i386/winnt.c (i386_pe_section_type_flags): Remove
13173 redundant diagnostic machinary.
13174
13175 2014-06-27 Richard Biener <rguenther@suse.de>
13176
13177 * tree-ssa-math-opts.c (bswap_replace): Fix
13178 SLOW_UNALIGNED_ACCESS test to only apply to unaligned object.
13179
13180 2014-06-27 Martin Liska <mliska@suse.cz>
13181
13182 * gimple.h (gimple_location_safe): New function introduced.
13183 * cgraphunit.c (walk_polymorphic_call_targets): Usage
13184 of gimple_location_safe replaces gimple_location.
13185 (gimple_fold_call): Likewise.
13186 * ipa-devirt.c (ipa_devirt): Likewise.
13187 * ipa-prop.c (ipa_make_edge_direct_to_target): Likewise.
13188 * ipa.c (walk_polymorphic_call_targets): Likewise.
13189 * tree-ssa-pre.c (eliminate_dom_walker::before_dom_children): Likewise.
13190
13191 2014-06-27 Jakub Jelinek <jakub@redhat.com>
13192
13193 PR tree-optimization/57233
13194 PR tree-optimization/61299
13195 * tree-vect-generic.c (get_compute_type, count_type_subparts): New
13196 functions.
13197 (expand_vector_operations_1): Use them. If {L,R}ROTATE_EXPR
13198 would be lowered to scalar shifts, check if corresponding
13199 shifts and vector BIT_IOR_EXPR are supported and don't lower
13200 or lower just to narrower vector type in that case.
13201 * expmed.c (expand_shift_1): Fix up handling of vector
13202 shifts and rotates.
13203
13204 2014-06-26 Uros Bizjak <ubizjak@gmail.com>
13205
13206 PR target/61586
13207 * config/alpha/alpha.c (alpha_handle_trap_shadows): Handle BARRIER RTX.
13208
13209 2014-06-26 Jan Hubicka <hubicka@ucw.cz>
13210
13211 * doc/invoke.texi (-fsemantic-interposition): Document.
13212 * common.opt (fsemantic-interposition): New flag.
13213 * varasm.c (decl_replaceable_p): Use it.
13214
13215 2014-06-26 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
13216
13217 PR target/61542
13218 * config/rs6000/vsx.md (vsx_extract_v4sf): Fix bug with element
13219 extraction other than index 3.
13220
13221 2014-06-26 Teresa Johnson <tejohnson@google.com>
13222
13223 * doc/invoke.texi: Fix typo.
13224 * dumpfile.c: Add support for documented -fdump-* options
13225 optimized/missed/note/optall.
13226
13227 2014-06-26 Martin Jambor <mjambor@suse.cz>
13228
13229 * params.def (PARAM_ALLOW_LOAD_DATA_RACES)
13230 (PARAM_ALLOW_PACKED_LOAD_DATA_RACES)
13231 (PARAM_ALLOW_PACKED_STORE_DATA_RACES): Removed.
13232 (PARAM_ALLOW_STORE_DATA_RACES): Set default to zero.
13233 * opts.c (default_options_optimization): Set
13234 PARAM_ALLOW_STORE_DATA_RACES to one at -Ofast.
13235 * doc/invoke.texi (allow-load-data-races)
13236 (allow-packed-load-data-races, allow-packed-store-data-races): Removed.
13237 (allow-store-data-races): Document the new default.
13238
13239 2014-06-26 Martin Jambor <mjambor@suse.cz>
13240
13241 * ipa-prop.c (ipa_impossible_devirt_target): No longer static,
13242 renamed to ipa_impossible_devirt_target. Fix typo.
13243 * ipa-prop.h (ipa_impossible_devirt_target): Declare.
13244 * ipa-cp.c (ipa_get_indirect_edge_target_1): Use
13245 ipa_impossible_devirt_target.
13246
13247 2014-06-26 Richard Biener <rguenther@suse.de>
13248
13249 PR tree-optimization/61607
13250 * tree-ssa-copy.c (copy_prop_visit_phi_node): Adjust comment
13251 explaining why we restrict copies on loop depth.
13252 * tree-ssa-dom.c (cprop_operand): Remove restriction on
13253 on loop depth.
13254 (record_equivalences_from_phis): Instead add it here.
13255
13256 2014-06-26 Bernd Schmidt <bernds@codesourcery.com>
13257
13258 * Makefile.in (COLLECT2_OBJS): Add collect-utils.o.
13259 (LTO_WRAPPER_OBJS): New variable.
13260 (lto-wrapper$(exeext)): Use it.
13261 * collect2.c: Include "collect-utils.h".
13262 (verbose, debug): Remove variables.
13263 (at_file_supplied): No longer static.
13264 (tool_name): New variable.
13265 (do_wait, fork_execute, maybe_unlink): Don't declare.
13266 (tool_cleanup): No longer static.
13267 (notice): Remove function.
13268 (maybe_run_lto_and_relink, main, do_dsymutil): Add new arg to
13269 fork_execute calls.
13270 (collect_wait, do_wait, collect_execute): Remove functions.
13271 (maybe_unlink): No longer static.
13272 * collect2.h (verbose, debug): Don't declare.
13273 (at_file_supplied): Declare.
13274 * collect-utils.c (utils_cleanup): New arg from_signal. All callers
13275 changed.
13276 (collect_execute): Replace with implementation from collect2, plus a
13277 new arg use_atfile. All callers changed.
13278 (collect_wait): Replace with implementation from collect2.
13279 (maybe_unlink_file): Remove function.
13280 (fork_execute): Replace with implementation from collect2, plus a
13281 new arg use_atfile. All callers changed.
13282 (do_wait): Add call to utils_cleanup to the error path.
13283 * collect-utils.h (collect_execute, fork_execute, utils_cleanup)
13284 (tool_cleanup): Adjust declarations.
13285 * lto-wrapper.c (tool_cleanup): Add unused bool argument.
13286 * tlink.c: Include "collect-utils.h".
13287 (tlink_execute): New arg use_atfile. All callers changed.
13288 (tlink_init, tlink_execute): Remove declarations.
13289
13290 * collect-utils.c (save_temps): New variable.
13291 (do_wait): Use it instead of debug. Use fatal_error.
13292 * collect-utils.h (save_temps): Declare.
13293 * collect2.c (verbose): Rename from vflag. All uses changed.
13294 (tool_cleanup): New function, copied from collect_atexit.
13295 (collect_atexit, handler): Just call it.
13296 * collect2.h (verbose): Declaration renamed from vflag.
13297 * lto-wrapper.c (maybe_unlink, run_gcc): Use save_temps instead of
13298 debug.
13299
13300 * Makefile.in (ALL_HOST_BACKEND_OBJS): Add collect-utils.o.
13301 (lto-wrapper$(exeext)): Link with collect-utils.o.
13302 * collect-utils.c: New file.
13303 * collect-utils.h: New file.
13304 * lto-wrapper.c: Include "collect-utils.h".
13305 (args_name): Delete variable.
13306 (tool_name): New variable.
13307 (tool_cleanup): New function.
13308 (maybe_unlink): Renamed from maybe_unlink_file. All callers changed.
13309 (lto_wrapper_cleanup, fatal_signal, collect_execute, collect_wait)
13310 (fork_execute): Remove functions.
13311
13312 2014-06-26 Nick Clifton <nickc@redhat.com>
13313
13314 * config/frv/frv.c (frv_in_small_data_p): Remove redundant assert.
13315
13316 * doc/extend.texi (Function Attributes): Fix typo in description
13317 of RX vector attribute.
13318
13319 2014-06-26 James Greenhalgh <james.greenhalgh@arm.com>
13320
13321 * config.gcc (supported_defaults): Error when passing either
13322 --with-tune or --with-arch in conjunction with --with-cpu for ARM.
13323
13324 2014-06-26 Richard Biener <rguenther@suse.de>
13325
13326 * tree-ssa-dom.c (cprop_operand): Remove restriction on
13327 propagating volatile pointers.
13328
13329 2014-06-26 Richard Biener <rguenther@suse.de>
13330
13331 PR tree-optimization/61607
13332 * tree-ssa-threadupdate.c (ssa_redirect_edges): Cancel the
13333 loop if we redirected its latch edge.
13334 (thread_block_1): Do not cancel loops prematurely.
13335
13336 2014-06-25 Jan Hubicka <hubicka@ucw.cz>
13337
13338 * toplev.c (backend_init_target): Move init_emit_regs and
13339 init_regs to...
13340 (backend_init) ... here; skip ira_init_once and backend_init_target.
13341 (target_reinit) ... and here; clear
13342 this_target_rtl->lang_dependent_initialized.
13343 (lang_dependent_init_target): Clear
13344 this_target_rtl->lang_dependent_initialized;
13345 break out rtl initialization to ...
13346 (initialize_rtl): ... here; call also backend_init_target
13347 and ira_init_once.
13348 * toplev.h (initialize_rtl): New function.
13349 * function.c: Include toplev.h
13350 (init_function_start): Call initialize_rtl.
13351 * rtl.h (target_rtl): Add target_specific_initialized,
13352 lang_dependent_initialized.
13353
13354 2014-06-25 Paul Gortmaker <paul.gortmaker@windriver.com>
13355 Jakub Jelinek <jakub@redhat.com>
13356
13357 * gcc.c (set_multilib_dir): Malloc "." pointer as well.
13358
13359 2014-06-25 Tom de Vries <tom@codesourcery.com>
13360
13361 * config/arm/arm.c (arm_emit_call_insn): Remove clobber of CC_REGNUM.
13362
13363 2014-06-25 Bernd Edlinger <bernd.edlinger@hotmail.de>
13364
13365 * tree-ssa-forwprop.c (associate_plusminus): For widening conversions
13366 check for undefined overflow in (T)(P + A) - (T)P -> (T)A.
13367 Issue a strict overflow warning if appropriate.
13368
13369 2014-06-25 Martin Liska <mliska@suse.cz>
13370
13371 IPA REF refactoring
13372 * Makefile.in: Removed header file (ipa-ref-inline.h).
13373 * cgraph.c (cgraph_turn_edge_to_speculative): New IPA REF function
13374 called.
13375 (cgraph_speculative_call_info): Likewise.
13376 (cgraph_for_node_thunks_and_aliases): Likewise.
13377 (cgraph_for_node_and_aliases): Likewise.
13378 (verify_cgraph_node): Likewise.
13379 * cgraph.h: Batch of IPA REF functions become member functions of
13380 symtab_node: add_reference, maybe_add_reference, clone_references,
13381 clone_referring, clone_reference, find_reference,
13382 remove_stmt_references, remove_all_references,
13383 remove_all_referring, dump_references, dump_referring,
13384 has_alias_p, iterate_reference, iterate_referring.
13385 * cgraphbuild.c (record_reference): New IPA REF function used.
13386 (record_type_list): Likewise.
13387 (record_eh_tables): Likewise.
13388 (mark_address): Likewise.
13389 (mark_load): Likewise.
13390 (mark_store): Likewise.
13391 (pass_build_cgraph_edges): Likewise.
13392 (rebuild_cgraph_edge): Likewise.
13393 (cgraph_rebuild_references): Likewise.
13394 (pass_remove_cgraph_callee_edges): Likewise.
13395 * cgraphclones.c (cgraph_clone_node): Likewise.
13396 (cgraph_create_virtual_clone): Likewise.
13397 (cgraph_materialize_clone): Likewise.
13398 (cgraph_materialize_all_clones): Likewise.
13399 * cgraphunit.c (cgraph_reset_node): Likewise.
13400 (cgraph_reset_node): Likewise.
13401 (analyze_function): Likewise.
13402 (assemble_thunks_and_aliases): Likewise.
13403 (expand_function): Likewise.
13404 * ipa-comdats.c (propagate_comdat_group): Likewise.
13405 (enqueue_references): Likewise.
13406 * ipa-cp.c (ipcp_discover_new_direct_edges): Likewise.
13407 (create_specialized_node): Likewise.
13408 * ipa-devirt.c (referenced_from_vtable_p): Likewise.
13409 * ipa-inline-transform.c (can_remove_node_now_p_1): Likewise.
13410 * ipa-inline.c (reset_edge_caches): Likewise.
13411 (update_caller_keys): Likewise.
13412 (execute): Likewise.
13413 * ipa-prop.c (remove_described_reference): Likewise.
13414 (propagate_controlled_uses): Likewise.
13415 (ipa_edge_duplication_hook): Likewise.
13416 (ipa_modify_call_arguments): Likewise.
13417 * ipa-pure-const.c (propagate_pure_const): Likewise.
13418 * ipa-ref-inline.h: Header file removed, functions moved
13419 to symtab_node class.
13420 * ipa-ref.c (remove_reference): New class member function.
13421 (cannot_lead_to_return): New class member function.
13422 (referring_ref_list): Likewise.
13423 (referred_ref_list): Likewise.
13424 Rest of functions moved to symtab_node class.
13425 * ipa-ref.h: New member functions remove_reference,
13426 cannot_lead_to_return, referring_ref_list, referred_ref_list added
13427 to ipa_ref class.
13428 ipa_ref_list class has new member functions: first_reference,
13429 first_referring, clear, nreferences.
13430 * ipa-reference.c (analyze_function): New IPA REF function used.
13431 (write_node_summary_p): Likewise.
13432 (ipa_reference_write_optimization_summary): Likewise.
13433 * ipa-split.c (split_function): Likewise.
13434 * ipa-utils.c (ipa_reverse_postorder): Likewise.
13435 * ipa-visibility.c (cgraph_non_local_node_p_1): Likewise.
13436 (function_and_variable_visibility): Likewise.
13437 * ipa.c (has_addr_references_p): Likewise.
13438 (process_references): Argument type changed.
13439 (symtab_remove_unreachable_nodes): New IPA REF function used.
13440 (process_references): Likewise.
13441 (set_writeonly_bit): Likewise.
13442 * lto-cgraph.c: Implementation of new symtab_node member functions
13443 that uses new IPA REF functions.
13444 * lto-streamer-in.c (fixup_call_stmt_edges_1): New IPA REF
13445 function used.
13446 * lto-streamer-out.c (output_symbol_p): Likewise.
13447 * lto-streamer.h (referenced_from_this_partition_p): Argument type
13448 changed.
13449 * symtab.c: Implementation of new IPA REF API.
13450 * trans-mem.c (ipa_tm_create_version_alias): New IPA REF function used.
13451 (ipa_tm_create_version): Likewise.
13452 (ipa_tm_execute): Likewise.
13453 * tree-emutls.c (gen_emutls_addr): Likewise.
13454 * tree-inline.c (copy_bb): Likewise.
13455 (delete_unreachable_blocks_update_callgraph): Likewise.
13456 * varpool.c (varpool_remove_unreferenced_decls): Likewise.
13457 (varpool_for_node_and_aliases): Likewise.
13458
13459 2014-06-25 Trevor Saunders <tsaunders@mozilla.com>
13460
13461 * config/i386/winnt.c (i386_find_on_wrapper_list): Fix typo.
13462
13463 2014-06-25 Trevor Saunders <tsaunders@mozilla.com>
13464
13465 PR bootstrap/61598
13466 * fold-const.c (fold_checksum_tree): Use a hash_table of const
13467 tree_node * instead of tree_node *.
13468 (fold): Adjust.
13469 (print_fold_checksum): Likewise.
13470 (fold_check_failed): Likewise.
13471 (debug_fold_checksum): Likewise.
13472 (fold_build1_stat_loc): Likewise.
13473 (fold_build2_stat_loc): Likewise.
13474 (fold_build3_stat_loc): Likewise.
13475 (fold_build_call_array_loc): Likewise.
13476
13477 2014-06-25 David Edelsohn <dje.gcc@gmail.com>
13478
13479 * config/rs6000/xcoff.h (ASM_DECLARE_FUNCTION_NAME): Replace
13480 implementation with call to...
13481 * config/rs6000/rs6000.c (rs6000_xcoff_declare_function_name): New
13482 function.
13483 * config/rs6000/rs6000-protos.h (rs6000_xcoff_declare_function_name):
13484 Declare.
13485
13486 2014-06-25 Marc Glisse <marc.glisse@inria.fr>
13487
13488 PR tree-optimization/57742
13489 * tree-ssa-strlen.c (handle_builtin_memset): Update strinfo
13490 after replacing the statement.
13491
13492 2014-06-25 Nick Clifton <nickc@redhat.com>
13493
13494 * config/v850/v850.c (GHS_default_section_names): Change to const
13495 char * type.
13496 (GHS_current_section_names): Likewise.
13497 (v850_insert_attributes): Do not build strings, just assign the
13498 names directly. Change the type of 'chosen_section' to const
13499 char*.
13500 * config/v850/v850-c.c (ghs_pragma_section): Assign the alias
13501 directly to the array entry.
13502 * config/v850/v850.h (GHS_default_section_names): Change to const
13503 char * type.
13504 (GHS_current_section_names): Likewise.
13505
13506 2014-06-25 Jakub Jelinek <jakub@redhat.com>
13507
13508 * langhooks-def.h (LANG_HOOKS_OMP_CLAUSE_LINEAR_CTOR): Define.
13509 (LANG_HOOKS_DECLS): Add it.
13510 * gimplify.c (gimplify_omp_for): Make sure OMP_CLAUSE_LINEAR_STEP
13511 has correct type.
13512 * tree.h (OMP_CLAUSE_LINEAR_ARRAY): Define.
13513 * langhooks.h (struct lang_hooks_for_decls): Add
13514 omp_clause_linear_ctor hook.
13515 * omp-low.c (lower_rec_input_clauses): Set max_vf even if
13516 OMP_CLAUSE_LINEAR_ARRAY is set. Don't fold_convert
13517 OMP_CLAUSE_LINEAR_STEP. For OMP_CLAUSE_LINEAR_ARRAY in
13518 combined simd loop use omp_clause_linear_ctor hook.
13519
13520 2014-06-24 Cong Hou <congh@google.com>
13521
13522 * tree-vect-patterns.c (vect_recog_sad_pattern): New function for SAD
13523 pattern recognition.
13524 (type_conversion_p): PROMOTION is true if it's a type promotion
13525 conversion, and false otherwise. Return true if the given expression
13526 is a type conversion one.
13527 * tree-vectorizer.h: Adjust the number of patterns.
13528 * tree.def: Add SAD_EXPR.
13529 * optabs.def: Add sad_optab.
13530 * cfgexpand.c (expand_debug_expr): Add SAD_EXPR case.
13531 * expr.c (expand_expr_real_2): Likewise.
13532 * gimple-pretty-print.c (dump_ternary_rhs): Likewise.
13533 * gimple.c (get_gimple_rhs_num_ops): Likewise.
13534 * optabs.c (optab_for_tree_code): Likewise.
13535 * tree-cfg.c (estimate_operator_cost): Likewise.
13536 * tree-ssa-operands.c (get_expr_operands): Likewise.
13537 * tree-vect-loop.c (get_initial_def_for_reduction): Likewise.
13538 * config/i386/sse.md: Add SSE2 and AVX2 expand for SAD.
13539 * doc/generic.texi: Add document for SAD_EXPR.
13540 * doc/md.texi: Add document for ssad and usad.
13541
13542 2014-06-24 Trevor Saunders <tsaunders@mozilla.com>
13543
13544 * config/i386/winnt.c (i386_pe_section_type_flags): Fix const
13545 qualification in cast.
13546
13547 2014-06-24 Jan Hubicka <hubicka@ucw.cz>
13548
13549 * tree.c (find_decls_types_r): Do not check DECL_VINDEX for TYPE_DECL.
13550 * tree.h (DECL_VINDEX, DECL_SAVED_TREE): Restrict to DECL_FUNCTION.
13551 * tree-core.h (tree_decl_non_common): Move saved_tree and vindex...
13552 (tree_function_decl): ... here.
13553 * tree-streamer-out.c (write_ts_decl_non_common_tree_pointers): Move
13554 streaming of vindex to ...
13555 (write_ts_function_decl_tree_pointers): ... here.
13556 * tree-streamer-in.c (lto_input_ts_decl_non_common_tree_pointers):
13557 Do not stream DECL_VINDEX.
13558 (lto_input_ts_function_decl_tree_pointers): Stream it here.
13559
13560 2014-06-24 Catherine Moore <clm@codesourcery.com>
13561 Sandra Loosemore <sandra@codesourcery.com>
13562
13563 * config/mips/mips.c (mips_order_regs_for_local_alloc): Delete.
13564 * config/mips/mips.h (ADJUST_REG_ALLOC_ORDER): Delete.
13565 * config/mips/mips-protos.h (mips_order_regs_for_local_alloc): Delete.
13566
13567 2014-06-24 Marc Glisse <marc.glisse@inria.fr>
13568
13569 * doc/invoke.texi (Warning Options): Remove duplicated
13570 -Wmaybe-uninitialized.
13571
13572 2014-06-24 Marc Glisse <marc.glisse@inria.fr>
13573
13574 PR tree-optimization/57742
13575 * tree-ssa-strlen.c (get_string_length): Ignore malloc.
13576 (handle_builtin_malloc, handle_builtin_memset): New functions.
13577 (strlen_optimize_stmt): Call them.
13578 * passes.def: Move strlen after loop+dom but before vrp.
13579
13580 2014-06-24 Jakub Jelinek <jakub@redhat.com>
13581
13582 PR target/61570
13583 * config/i386/driver-i386.c (host_detect_local_cpu): For unknown
13584 model family 6 CPU with has_longmode never use a CPU without
13585 64-bit support.
13586
13587 2014-06-24 H.J. Lu <hongjiu.lu@intel.com>
13588
13589 PR target/61570
13590 * config/i386/driver-i386.c (host_detect_local_cpu): Revert
13591 the last change.
13592
13593 2014-06-24 Trevor Saunders <tsaunders@mozilla.com>
13594
13595 * alloc-pool.c (alloc_pool_hash): Use hash_map instead of hash_table.
13596 * dominance.c (iterate_fix_dominators): Use hash_map instead of
13597 pointer_map.
13598 * hash-map.h: New file.
13599 * ipa-comdats.c: Use hash_map instead of pointer_map.
13600 * ipa.c: Likewise.
13601 * lto-section-out.c: Adjust.
13602 * lto-streamer.h: Replace pointer_map with hash_map.
13603 * symtab.c (verify_symtab): Likewise.
13604 * tree-ssa-strlen.c (decl_to_stridxlist_htab): Likewise.
13605 * tree-ssa-uncprop.c (val_ssa_equiv): Likewise.
13606 * tree-streamer.h: Likewise.
13607 * tree-streamer.c: Adjust.
13608 * pointer-set.h: Remove pointer_map.
13609
13610 2014-06-24 Trevor Saunders <tsaunders@mozilla.com>
13611
13612 * hash-table.h: Add a template arg to choose between storing values
13613 and storing pointers to values, and then provide partial
13614 specializations for both.
13615 * tree-browser.c (tree_upper_hasher): Provide the type the hash table
13616 should store, not the type values should point to.
13617 * tree-into-ssa.c (var_info_hasher): Likewise.
13618 * tree-ssa-dom.c (expr_elt_hasher): Likewise.
13619 * tree-complex.c: Adjust.
13620 * tree-hasher.h (int_tree_hasher): store int_tree_map in the hash
13621 table instead of int_tree_map *.
13622 * tree-parloops.c: Adjust.
13623 * tree-ssa-reassoc.c (ocount_hasher): Don't lie to hash_map about what
13624 type is being stored.
13625 * tree-vectorizer.c: Adjust.
13626
13627 2014-06-24 Trevor Saunders <tsaunders@mozilla.com>
13628
13629 * hash-table.h: Remove a layer of indirection from hash_table so that
13630 it contains the hash table's data instead of a pointer to the data.
13631 * alloc-pool.c, asan.c, attribs.c, bitmap.c, cfg.c,
13632 config/arm/arm.c, config/i386/winnt.c, config/ia64/ia64.c,
13633 config/mips/mips.c, config/sol2.c, coverage.c, cselib.c,
13634 data-streamer-out.c, dse.c, dwarf2cfi.c, dwarf2out.c, except.c,
13635 fold-const.c, gcse.c, ggc-common.c,
13636 gimple-ssa-strength-reduction.c, gimplify.c,
13637 graphite-clast-to-gimple.c, graphite-dependences.c,
13638 graphite-htab.h, graphite.c, haifa-sched.c, ipa-devirt.c,
13639 ipa-profile.c, ira-color.c, ira-costs.c, loop-invariant.c,
13640 loop-iv.c, loop-unroll.c, lto-streamer-in.c, lto-streamer-out.c,
13641 lto-streamer.c, lto-streamer.h, passes.c, plugin.c,
13642 postreload-gcse.c, sese.c, statistics.c, store-motion.c,
13643 trans-mem.c, tree-browser.c, tree-cfg.c, tree-complex.c,
13644 tree-eh.c, tree-into-ssa.c, tree-parloops.c, tree-sra.c,
13645 tree-ssa-ccp.c, tree-ssa-coalesce.c, tree-ssa-dom.c,
13646 tree-ssa-live.c, tree-ssa-loop-im.c,
13647 tree-ssa-loop-ivopts.c, tree-ssa-phiopt.c, tree-ssa-pre.c,
13648 tree-ssa-reassoc.c, tree-ssa-sccvn.c, tree-ssa-strlen.c,
13649 tree-ssa-structalias.c, tree-ssa-tail-merge.c,
13650 tree-ssa-threadupdate.c, tree-ssa-uncprop.c,
13651 tree-vect-data-refs.c, tree-vect-loop.c, tree-vectorizer.c,
13652 tree-vectorizer.h, valtrack.c, valtrack.h, var-tracking.c,
13653 vtable-verify.c, vtable-verify.h: Adjust.
13654
13655 2014-06-24 Richard Biener <rguenther@suse.de>
13656
13657 PR tree-optimization/61572
13658 * tree-ssa-sink.c (statement_sink_location): Do not sink
13659 loads from hard registers.
13660
13661 2014-06-24 Jakub Jelinek <jakub@redhat.com>
13662
13663 * gimplify.c (gimplify_omp_for): For #pragma omp for simd iterator
13664 not mentioned in clauses use private clause if the iterator is
13665 declared in #pragma omp for simd, and when adding lastprivate
13666 instead, add it to the outer #pragma omp for too. Diagnose
13667 if the variable is private in outer context. For simd collapse > 1
13668 loops, replace all iterators with temporaries.
13669 * omp-low.c (lower_rec_input_clauses): Handle LINEAR clause the
13670 same even in collapse > 1 loops.
13671
13672 * gimplify.c (gimplify_scan_omp_clauses) <case OMP_CLAUSE_MAP,
13673 OMP_CLAUSE_TO, OMP_CLAUSE_FROM): Make sure OMP_CLAUSE_SIZE is
13674 non-NULL.
13675 <case OMP_CLAUSE_ALIGNED>: Gimplify OMP_CLAUSE_ALIGNED_ALIGNMENT.
13676 (gimplify_adjust_omp_clauses_1): Make sure OMP_CLAUSE_SIZE is
13677 non-NULL.
13678 (gimplify_adjust_omp_clauses): Likewise.
13679 * omp-low.c (lower_rec_simd_input_clauses,
13680 lower_rec_input_clauses, expand_omp_simd): Handle non-constant
13681 safelen the same as safelen(1).
13682 * tree-nested.c (convert_nonlocal_omp_clauses,
13683 convert_local_omp_clauses): Handle OMP_CLAUSE_ALIGNED. For
13684 OMP_CLAUSE_{MAP,TO,FROM} if not decl use walk_tree.
13685 (convert_nonlocal_reference_stmt, convert_local_reference_stmt):
13686 Fixup handling of GIMPLE_OMP_TARGET.
13687 (convert_tramp_reference_stmt, convert_gimple_call): Handle
13688 GIMPLE_OMP_TARGET.
13689
13690 2014-06-24 Chung-Lin Tang <cltang@codesourcery.com>
13691
13692 PR tree-optimization/61554
13693 * tree-ssa-propagate.c: Include "bitmap.h".
13694 (substitute_and_fold_dom_walker): Add 'bitmap need_eh_cleanup' member,
13695 properly update constructor/destructor.
13696 (substitute_and_fold_dom_walker::before_dom_children):
13697 Remove call to gimple_purge_dead_eh_edges, add bb->index to
13698 need_eh_cleaup instead.
13699 (substitute_and_fold): Call gimple_purge_all_dead_eh_edges on
13700 need_eh_cleanup.
13701
13702 2014-06-23 Jan Hubicka <hubicka@ucw.cz>
13703
13704 * varpool.c (dump_varpool_node): Dump used_by_single_function.
13705 * tree-pass.h (make_pass_ipa_single_use): New pass.
13706 * cgraph.h (used_by_single_function): New flag.
13707 * lto-cgraph.c (lto_output_varpool_node, input_varpool_node):
13708 Stream it.
13709 * passes.def (pass_ipa_single_use): Scedule.
13710 * ipa.c (BOTTOM): New macro.
13711 (meet): New function
13712 (propagate_single_user): New function.
13713 (ipa_single_use): New function.
13714 (pass_data_ipa_single_use): New pass.
13715 (pass_ipa_single_use): New pass.
13716 (pass_ipa_single_use::gate): New gate.
13717 (make_pass_ipa_single_use): New function.
13718
13719 2014-06-23 Kai Tietz <ktietz@redhat.com>
13720
13721 PR target/39284
13722 * passes.def (peephole2): Move peephole2 pass before sched2 pass.
13723 * config/i386/i386.md (peehole2): Combine memories and indirect jumps.
13724
13725 2014-06-23 Richard Biener <rguenther@suse.de>
13726
13727 * tree-ssa-loop.c (gate_loop): New function.
13728 (pass_tree_loop::gate): Call it.
13729 (pass_data_tree_no_loop, pass_tree_no_loop,
13730 make_pass_tree_no_loop): New.
13731 * tree-vectorizer.c: Include tree-scalar-evolution.c
13732 (pass_slp_vectorize::execute): Initialize loops and SCEV if
13733 required.
13734 (pass_slp_vectorize::clone): New method.
13735 * timevar.def (TV_TREE_NOLOOP): New.
13736 * tree-pass.h (make_pass_tree_no_loop): Declare.
13737 * passes.def (pass_tree_no_loop): New pass group with
13738 SLP vectorizer.
13739
13740 2014-06-23 H.J. Lu <hongjiu.lu@intel.com>
13741
13742 PR target/61570
13743 * config/i386/driver-i386.c (host_detect_local_cpu): Set arch
13744 to x86-64 if a 32-bit processor supports SSE2 and 64-bit.
13745
13746 2014-06-23 James Greenhalgh <james.greenhalgh@arm.com>
13747
13748 * config/aarch64/aarch64.md (addsi3_aarch64): Set "simd" attr to
13749 "yes" where needed.
13750
13751 2014-06-23 Alan Modra <amodra@gmail.com>
13752
13753 PR bootstrap/61583
13754 * tree-vrp.c (remove_range_assertions): Do not set is_unreachable
13755 to zero on debug statements.
13756
13757 2014-06-23 Alan Lawrence <alan.lawrence@arm.com>
13758
13759 PR target/60825
13760 * config/aarch64/aarch64-builtins.c (aarch64_types_unop_qualifiers):
13761 Ignore third operand if present by marking qualifier_internal.
13762
13763 * config/aarch64/aarch64-simd-builtins.def (abs): Comment.
13764
13765 * config/aarch64/arm_neon.h (int64x1_t, uint64x1_t): Typedef to GCC
13766 vector extension.
13767 (aarch64_vget_lane_s64, aarch64_vdup_lane_s64,
13768 arch64_vdupq_lane_s64, aarch64_vdupq_lane_u64): Remove macro.
13769 (vqadd_s64, vqadd_u64, vqsub_s64, vqsub_u64, vqneg_s64, vqabs_s64,
13770 vcreate_s64, vcreate_u64, vreinterpret_s64_f64, vreinterpret_u64_f64,
13771 vcombine_u64, vbsl_s64, vbsl_u64, vceq_s64, vceq_u64, vceqz_s64,
13772 vceqz_u64, vcge_s64, vcge_u64, vcgez_s64, vcgt_s64, vcgt_u64,
13773 vcgtz_s64, vcle_s64, vcle_u64, vclez_s64, vclt_s64, vclt_u64,
13774 vcltz_s64, vdup_n_s64, vdup_n_u64, vld1_s64, vld1_u64, vmov_n_s64,
13775 vmov_n_u64, vqdmlals_lane_s32, vqdmlsls_lane_s32,
13776 vqdmulls_lane_s32, vqrshl_s64, vqrshl_u64, vqrshl_u64, vqshl_s64,
13777 vqshl_u64, vqshl_n_s64, vqshl_n_u64, vqshl_n_s64, vqshl_n_u64,
13778 vqshlu_n_s64, vrshl_s64, vrshl_u64, vrshr_n_s64, vrshr_n_u64,
13779 vrsra_n_s64, vrsra_n_u64, vshl_n_s64, vshl_n_u64, vshl_s64,
13780 vshl_u64, vshr_n_s64, vshr_n_u64, vsli_n_s64, vsli_n_u64,
13781 vsqadd_u64, vsra_n_s64, vsra_n_u64, vsri_n_s64, vsri_n_u64,
13782 vst1_s64, vst1_u64, vtst_s64, vtst_u64, vuqadd_s64): Wrap existing
13783 logic in GCC vector extensions
13784
13785 (vpaddd_s64, vaddd_s64, vaddd_u64, vceqd_s64, vceqd_u64, vceqzd_s64
13786 vceqzd_u64, vcged_s64, vcged_u64, vcgezd_s64, vcgtd_s64, vcgtd_u64,
13787 vcgtzd_s64, vcled_s64, vcled_u64, vclezd_s64, vcltd_s64, vcltd_u64,
13788 vcltzd_s64, vqdmlals_s32, vqdmlsls_s32, vqmovnd_s64, vqmovnd_u64
13789 vqmovund_s64, vqrshld_s64, vqrshld_u64, vqrshrnd_n_s64,
13790 vqrshrnd_n_u64, vqrshrund_n_s64, vqshld_s64, vqshld_u64,
13791 vqshld_n_u64, vqshrnd_n_s64, vqshrnd_n_u64, vqshrund_n_s64,
13792 vrshld_u64, vrshrd_n_u64, vrsrad_n_u64, vshld_n_u64, vshld_s64,
13793 vshld_u64, vslid_n_u64, vsqaddd_u64, vsrad_n_u64, vsrid_n_u64,
13794 vsubd_s64, vsubd_u64, vtstd_s64, vtstd_u64): Fix type signature.
13795
13796 (vabs_s64): Use GCC vector extensions; call __builtin_aarch64_absdi.
13797
13798 (vget_high_s64, vget_high_u64): Reimplement with GCC vector
13799 extensions.
13800
13801 (__GET_LOW, vget_low_u64): Wrap result using vcreate_u64.
13802 (vget_low_s64): Use __GET_LOW macro.
13803 (vget_lane_s64, vget_lane_u64, vdupq_lane_s64, vdupq_lane_u64): Use
13804 gcc vector extensions, add call to __builtin_aarch64_lane_boundsi.
13805 (vdup_lane_s64, vdup_lane_u64,): Add __builtin_aarch64_lane_bound_si.
13806 (vdupd_lane_s64, vdupd_lane_u64): Fix type signature, add
13807 __builtin_aarch64_lane_boundsi, use GCC vector extensions.
13808
13809 (vcombine_s64): Use GCC vector extensions; remove cast.
13810 (vqaddd_s64, vqaddd_u64, vqdmulls_s32, vqshld_n_s64, vqshlud_n_s64,
13811 vqsubd_s64, vqsubd_u64, vrshld_s64, vrshrd_n_s64, vrsrad_n_s64,
13812 vshld_n_s64, vshrd_n_s64, vslid_n_s64, vsrad_n_s64, vsrid_n_s64):
13813 Fix type signature; remove cast.
13814
13815 2014-06-23 Alan Lawrence <alan.lawrence@arm.com>
13816
13817 PR target/60825
13818 * config/aarch64/aarch64.c (aarch64_simd_mangle_map): Add entry for
13819 V1DFmode.
13820 * config/aarch64/aarch64-builtins.c (aarch64_simd_builtin_type_mode):
13821 add V1DFmode
13822 (BUILTIN_VD1): New.
13823 (BUILTIN_VD_RE): Remove.
13824 (aarch64_init_simd_builtins): Add V1DF to modes/modenames.
13825 (aarch64_fold_builtin): Update reinterpret patterns, df becomes v1df.
13826 * config/aarch64/aarch64-simd-builtins.def (create): Make a v1df
13827 variant but not df.
13828 (vreinterpretv1df*, vreinterpret*v1df): New.
13829 (vreinterpretdf*, vreinterpret*df): Remove.
13830 * config/aarch64/aarch64-simd.md (aarch64_create,
13831 aarch64_reinterpret*): Generate V1DFmode pattern not DFmode.
13832 * config/aarch64/iterators.md (VD_RE): Include V1DF, remove DF.
13833 (VD1): New.
13834 * config/aarch64/arm_neon.h (float64x1_t): typedef with gcc extensions.
13835 (vcreate_f64): Remove cast, use v1df builtin.
13836 (vcombine_f64): Remove cast, get elements with gcc vector extensions.
13837 (vget_low_f64, vabs_f64, vceq_f64, vceqz_f64, vcge_f64, vgfez_f64,
13838 vcgt_f64, vcgtz_f64, vcle_f64, vclez_f64, vclt_f64, vcltz_f64,
13839 vdup_n_f64, vdupq_lane_f64, vld1_f64, vld2_f64, vld3_f64, vld4_f64,
13840 vmov_n_f64, vst1_f64): Use gcc vector extensions.
13841 (vget_lane_f64, vdupd_lane_f64, vmulq_lane_f64, ): Use gcc extensions,
13842 add range check using __builtin_aarch64_im_lane_boundsi.
13843 (vfma_lane_f64, vfmad_lane_f64, vfma_laneq_f64, vfmaq_lane_f64,
13844 vfms_lane_f64, vfmsd_lane_f64, vfms_laneq_f64, vfmsq_lane_f64): Fix
13845 type signature, use gcc vector extensions.
13846 (vreinterpret_p8_f64, vreinterpret_p16_f64, vreinterpret_f32_f64,
13847 vreinterpret_f64_f32, vreinterpret_f64_p8, vreinterpret_f64_p16,
13848 vreinterpret_f64_s8, vreinterpret_f64_s16, vreinterpret_f64_s32,
13849 vreinterpret_f64_s64, vreinterpret_f64_u8, vreinterpret_f64_u16,
13850 vreinterpret_f64_u32, vreinterpret_f64_u64, vreinterpret_s8_f64,
13851 vreinterpret_s16_f64, vreinterpret_s32_f64, vreinterpret_s64_f64,
13852 vreinterpret_u8_f64, vreinterpret_u16_f64, vreinterpret_u32_f64,
13853 vreinterpret_u64_f64): Use v1df builtin not df.
13854
13855 2014-06-23 James Greenhalgh <james.greenhalgh@arm.com>
13856
13857 * config/aarch64/aarch64.md (*addsi3_aarch64): Add alternative in
13858 vector registers.
13859
13860 2014-06-23 Jan Hubicka <hubicka@ucw.cz>
13861
13862 * lto-cgraph.c (lto_output_node, input_node): Set/get init/fini
13863 priority directly.
13864
13865 2014-06-23 Zhenqiang Chen <zhenqiang.chen@linaro.org>
13866
13867 * loop-invariant.c (pre_check_invariant_p): New function.
13868 (find_invariant_insn): Call pre_check_invariant_p.
13869
13870 2014-06-22 Richard Henderson <rth@redhat.com>
13871
13872 PR target/61565
13873 * compare-elim.c (struct comparison): Add eh_note.
13874 (find_comparison_dom_walker::before_dom_children): Don't eliminate
13875 a redundant comparison in a different EH region. Purge EH edges if
13876 necessary.
13877
13878 2014-06-22 Segher Boessenkool <segher@kernel.crashing.org>
13879
13880 * config/rs6000/rs6000.md (maybe_var_shift): New define_attr.
13881 (var_shift): Use it.
13882 (rotl<mode>3, *rotlsi3_64, *rotl<mode>3_dot, *rotl<mode>3_dot2,
13883 *rotlsi3_internal4, *rotlsi3_internal5, *rotlsi3_internal6,
13884 *rotlsi3_internal8le, *rotlsi3_internal8be, *rotlsi3_internal9le,
13885 *rotlsi3_internal9be, *rotlsi3_internal10le, *rotlsi3_internal10be,
13886 *rotlsi3_internal11le, *rotlsi3_internal11be, *rotlsi3_internal12le,
13887 *rotlsi3_internal12be, ashl<mode>3, *ashlsi3_64, *ashl<mode>3_dot,
13888 *ashl<mode>3_dot2, lshr<mode>3, *lshrsi3_64, *lshr<mode>3_dot,
13889 *lshr<mode>3_dot2, *ashr<mode>3, *ashrsi3_64, *ashr<mode>3_dot,
13890 *ashr<mode>3_dot2, *rotldi3_internal4, *rotldi3_internal5,
13891 *rotldi3_internal6, *rotldi3_internal7le, *rotldi3_internal7be,
13892 *rotldi3_internal8le, *rotldi3_internal8be, *rotldi3_internal9le,
13893 *rotldi3_internal9be, *rotldi3_internal10le, *rotldi3_internal10be,
13894 *rotldi3_internal11le, *rotldi3_internal11be, *rotldi3_internal12le,
13895 *rotldi3_internal12be, *rotldi3_internal13le, *rotldi3_internal13be,
13896 *rotldi3_internal14le, *rotldi3_internal14be, *rotldi3_internal15le,
13897 *rotldi3_internal15be): Use the new attribute. Merge register and
13898 integer alternatives.
13899
13900 2014-06-22 Segher Boessenkool <segher@kernel.crashing.org>
13901
13902 * config/rs6000/rs6000.md (ashrsi3, two anonymous define_insns and
13903 define_splits, ashrdi3, *ashrdi3_internal1, *ashrdi3_internal2 and
13904 split, *ashrdi3_internal3 and split): Delete, merge into...
13905 (ashr<mode>3): New expander.
13906 (*ashr<mode>3, ashr<mode>3_dot, ashr<mode>3_dot2): New.
13907 (*ashrsi3_64): Fix formatting. Replace "i" by "n".
13908
13909 2014-06-22 Segher Boessenkool <segher@kernel.crashing.org>
13910
13911 * config/rs6000/rs6000.md (rotlsi3, *rotlsi3_internal2 and split,
13912 *rotlsi3_internal3 and split, rotldi3, *rotldi3_internal2 and split,
13913 *rotldi3_internal3 and split): Delete, merge into...
13914 (rotl<mode>3, rotl<mode>3_dot, rotl<mode>3_dot2): New.
13915 (*rotlsi3_64): Fix formatting. Fix condition. Replace "i" by "n".
13916 Use "rotlw" extended mnemonic.
13917
13918 2014-06-22 Segher Boessenkool <segher@kernel.crashing.org>
13919
13920 * config/rs6000/rs6000.md (ashlsi3, two anonymous define_insns
13921 and define_splits, ashldi3, *ashldi3_internal1, *ashldi3_internal2
13922 and split, *ashldi3_internal3 and split): Delete, merge into...
13923 (ashl<mode>3, ashl<mode>3_dot, ashl<mode>3_dot2): New.
13924 (*ashlsi3_64): Fix formatting. Replace "i" by "n".
13925
13926 2014-06-22 Segher Boessenkool <segher@kernel.crashing.org>
13927
13928 * config/rs6000/rs6000.md ("hH"): New define_mode_attr.
13929 (lshrsi3, two anonymous define_insns and define_splits,
13930 lshrdi3, *lshrdi3_internal1, *lshrdi3_internal2 and split,
13931 *lshrdi3_internal3 and split): Delete, merge into...
13932 (lshr<mode>3, lshr<mode>3_dot, lshr<mode>3_dot2): New.
13933 (*lshrsi3_64): Fix formatting. Replace "i" by "n".
13934
13935 2014-06-22 Segher Boessenkool <segher@kernel.crashing.org>
13936
13937 * config/rs6000/rs6000.md (lshrsi3, and its two dot patterns):
13938 Remove "O" alternative.
13939
13940 2014-06-22 Richard Sandiford <rdsandiford@googlemail.com>
13941
13942 * config/mips/mips.c (mips_move_to_gpr_cost): Remove mode argument.
13943 (mips_move_from_gpr_cost): Likewise.
13944 (mips_register_move_cost): Update accordingly.
13945 (mips_secondary_reload_class): Remove name of in_p.
13946
13947 2014-06-22 Marc Glisse <marc.glisse@inria.fr>
13948
13949 PR target/61503
13950 * config/i386/i386.md (x86_64_shrd, x86_shrd,
13951 ix86_rotr<dwi>3_doubleword): Replace ashiftrt with lshiftrt.
13952
13953 2014-06-21 Jan-Benedict Glaw <jbglaw@lug-owl.de>
13954
13955 * config/nios2/nios2.c: Include "builtins.h".
13956
13957 2014-06-20 Jan Hubicka <hubicka@ucw.cz>
13958
13959 * cgraph.h (tls_model_names): New variable.
13960 * print-tree.c (print_node): Simplify.
13961 * varpool.c (tls_model_names): New variable.
13962 (dump_varpool_node): Output tls model.
13963
13964 2014-06-20 Jan Hubicka <hubicka@ucw.cz>
13965
13966 * ipa-visibility.c (function_and_variable_visibility): Disable
13967 temporarily local aliases for some targets.
13968
13969 2014-06-20 Marek Polacek <polacek@redhat.com>
13970
13971 * asan.c (pass_sanopt::execute): Handle IFN_UBSAN_BOUNDS.
13972 * flag-types.h (enum sanitize_code): Add SANITIZE_BOUNDS and or it
13973 into SANITIZE_UNDEFINED.
13974 * doc/invoke.texi: Describe -fsanitize=bounds.
13975 * gimplify.c (gimplify_call_expr): Add gimplification of internal
13976 functions created in the FEs.
13977 * internal-fn.c: Move "internal-fn.h" after "tree.h".
13978 (expand_UBSAN_BOUNDS): New function.
13979 * internal-fn.def (UBSAN_BOUNDS): New internal function.
13980 * internal-fn.h: Don't define internal functions here.
13981 * opts.c (common_handle_option): Add -fsanitize=bounds.
13982 * sanitizer.def (BUILT_IN_UBSAN_HANDLE_OUT_OF_BOUNDS,
13983 BUILT_IN_UBSAN_HANDLE_OUT_OF_BOUNDS_ABORT): Add.
13984 * tree-core.h: Define internal functions here.
13985 (struct tree_base): Add ifn field.
13986 * tree-pretty-print.c: Include "internal-fn.h".
13987 (dump_generic_node): Handle functions without CALL_EXPR_FN.
13988 * tree.c (get_callee_fndecl): Likewise.
13989 (build_call_expr_internal_loc): New function.
13990 * tree.def (CALL_EXPR): Update description.
13991 * tree.h (CALL_EXPR_IFN): Define.
13992 (build_call_expr_internal_loc): Declare.
13993 * ubsan.c (get_ubsan_type_info_for_type): Return 0 for non-arithmetic
13994 types.
13995 (ubsan_type_descriptor): Change bool parameter to enum
13996 ubsan_print_style. Adjust the code. Add handling of
13997 UBSAN_PRINT_ARRAY.
13998 (ubsan_expand_bounds_ifn): New function.
13999 (ubsan_expand_null_ifn): Adjust ubsan_type_descriptor call.
14000 (ubsan_build_overflow_builtin): Likewise.
14001 (instrument_bool_enum_load): Likewise.
14002 (ubsan_instrument_float_cast): Likewise.
14003 * ubsan.h (enum ubsan_print_style): New enum.
14004 (ubsan_expand_bounds_ifn): Declare.
14005 (ubsan_type_descriptor): Adjust declaration. Use a default parameter.
14006
14007 2014-06-20 Maciej W. Rozycki <macro@codesourcery.com>
14008
14009 * config/rs6000/rs6000.md: Append `DONE' to preparation
14010 statements of `bswap' pattern splitters.
14011
14012 2014-06-20 Tom de Vries <tom@codesourcery.com>
14013
14014 * target.def (call_fusage_contains_non_callee_clobbers): Update
14015 definition.
14016 * doc/tm.texi: Regenerate.
14017
14018 2014-06-20 Yury Gribov <y.gribov@samsung.com>
14019 Max Ostapenko <m.ostapenko@partner.samsung.com>
14020
14021 PR sanitizer/61547
14022 * asan.c (instrument_strlen_call): Fixed instrumentation of
14023 trailing byte.
14024
14025 2014-06-20 Martin Jambor <mjambor@suse.cz>
14026
14027 PR ipa/61540
14028 * ipa-prop.c (impossible_devirt_target): New function.
14029 (try_make_edge_direct_virtual_call): Use it, also instead of
14030 asserting.
14031
14032 2014-06-20 Yury Gribov <y.gribov@samsung.com>
14033 Max Ostapenko <m.ostapenko@partner.samsung.com>
14034
14035 PR sanitizer/61530
14036 * asan.c (build_check_stmt): Add condition.
14037
14038 2014-06-20 Martin Jambor <mjambor@suse.cz>
14039
14040 PR ipa/61211
14041 * cgraph.c (clone_of_p): Allow skipped_branch to deal with
14042 expanded clones.
14043
14044 2014-06-20 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
14045
14046 * config/aarch64/iterators.md (VCOND): Handle SI and HI modes.
14047 Update comments.
14048 (VCONQ): Make comment more helpful.
14049 (VCON): Delete.
14050 * config/aarch64/aarch64-simd.md
14051 (aarch64_sqdmulh_lane<mode>):
14052 Use VCOND for operands 2. Update lane checking and flipping logic.
14053 (aarch64_sqrdmulh_lane<mode>): Likewise.
14054 (aarch64_sq<r>dmulh_lane<mode>_internal): Likewise.
14055 (aarch64_sqdmull2<mode>): Remove VCON, use VQ_HSI mode iterator.
14056 (aarch64_sqdml<SBINQOPS:as>l_lane<mode>_internal, VD_HSI): Change mode
14057 attribute of operand 3 to VCOND.
14058 (aarch64_sqdml<SBINQOPS:as>l_lane<mode>_internal, SD_HSI): Likewise.
14059 (aarch64_sqdml<SBINQOPS:as>l2_lane<mode>_internal): Likewise.
14060 (aarch64_sqdmull_lane<mode>_internal, VD_HSI): Likewise.
14061 (aarch64_sqdmull_lane<mode>_internal, SD_HSI): Likewise.
14062 (aarch64_sqdmull2_lane<mode>_internal): Likewise.
14063 (aarch64_sqdml<SBINQOPS:as>l_laneq<mode>_internal, VD_HSI: New
14064 define_insn.
14065 (aarch64_sqdml<SBINQOPS:as>l_laneq<mode>_internal, SD_HSI): Likewise.
14066 (aarch64_sqdml<SBINQOPS:as>l2_laneq<mode>_internal): Likewise.
14067 (aarch64_sqdmull_laneq<mode>_internal, VD_HSI): Likewise.
14068 (aarch64_sqdmull_laneq<mode>_internal, SD_HSI): Likewise.
14069 (aarch64_sqdmull2_laneq<mode>_internal): Likewise.
14070 (aarch64_sqdmlal_lane<mode>): Change mode attribute of penultimate
14071 operand to VCOND. Update lane flipping and bounds checking logic.
14072 (aarch64_sqdmlal2_lane<mode>): Likewise.
14073 (aarch64_sqdmlsl_lane<mode>): Likewise.
14074 (aarch64_sqdmull_lane<mode>): Likewise.
14075 (aarch64_sqdmull2_lane<mode>): Likewise.
14076 (aarch64_sqdmlal_laneq<mode>):
14077 Replace VCON usage with VCONQ.
14078 Emit aarch64_sqdmlal_laneq<mode>_internal insn.
14079 (aarch64_sqdmlal2_laneq<mode>): Emit
14080 aarch64_sqdmlal2_laneq<mode>_internal insn.
14081 Replace VCON with VCONQ.
14082 (aarch64_sqdmlsl2_lane<mode>): Replace VCON with VCONQ.
14083 (aarch64_sqdmlsl2_laneq<mode>): Likewise.
14084 (aarch64_sqdmull_laneq<mode>): Emit
14085 aarch64_sqdmull_laneq<mode>_internal insn.
14086 Replace VCON with VCONQ.
14087 (aarch64_sqdmull2_laneq<mode>): Emit
14088 aarch64_sqdmull2_laneq<mode>_internal insn.
14089 (aarch64_sqdmlsl_laneq<mode>): Replace VCON usage with VCONQ.
14090 * config/aarch64/arm_neon.h (vqdmlal_high_lane_s16): Change type
14091 of 3rd argument to int16x4_t.
14092 (vqdmlalh_lane_s16): Likewise.
14093 (vqdmlslh_lane_s16): Likewise.
14094 (vqdmull_high_lane_s16): Likewise.
14095 (vqdmullh_lane_s16): Change type of 2nd argument to int16x4_t.
14096 (vqdmlal_lane_s16): Don't create temporary int16x8_t value.
14097 (vqdmlsl_lane_s16): Likewise.
14098 (vqdmull_lane_s16): Don't create temporary int16x8_t value.
14099 (vqdmlal_high_lane_s32): Change type 3rd argument to int32x2_t.
14100 (vqdmlals_lane_s32): Likewise.
14101 (vqdmlsls_lane_s32): Likewise.
14102 (vqdmull_high_lane_s32): Change type 2nd argument to int32x2_t.
14103 (vqdmulls_lane_s32): Likewise.
14104 (vqdmlal_lane_s32): Don't create temporary int32x4_t value.
14105 (vqdmlsl_lane_s32): Likewise.
14106 (vqdmull_lane_s32): Don't create temporary int32x4_t value.
14107 (vqdmulhh_lane_s16): Change type of second argument to int16x4_t.
14108 (vqrdmulhh_lane_s16): Likewise.
14109 (vqdmlsl_high_lane_s16): Likewise.
14110 (vqdmulhs_lane_s32): Change type of second argument to int32x2_t.
14111 (vqdmlsl_high_lane_s32): Likewise.
14112 (vqrdmulhs_lane_s32): Likewise.
14113
14114 2014-06-20 Tom de Vries <tom@codesourcery.com>
14115
14116 * final.c (collect_fn_hard_reg_usage): Add separate IOR_HARD_REG_SET for
14117 get_call_reg_set_usage.
14118
14119 2014-06-20 Tom de Vries <tom@codesourcery.com>
14120
14121 * final.c (collect_fn_hard_reg_usage): Don't save function_used_regs if
14122 it contains all call_used_regs.
14123
14124 2014-06-20 Tom de Vries <tom@codesourcery.com>
14125
14126 * final.c (collect_fn_hard_reg_usage): Add and use variable
14127 function_used_regs.
14128
14129 2014-06-20 Jan Hubicka <hubicka@ucw.cz>
14130
14131 * cgraph.h (struct symtab_node): Add field in_init_priority_hash
14132 (set_init_priority, get_init_priority, set_fini_priority,
14133 get_fini_priority): New methods.
14134 * tree.c (init_priority_for_decl): Remove.
14135 (init_ttree): Do not initialize init priority.
14136 (decl_init_priority_lookup, decl_fini_priority_lookup): Rewrite.
14137 (decl_priority_info): Remove.
14138 (decl_init_priority_insert): Rewrite.
14139 (decl_fini_priority_insert): Rewrite.
14140 * tree.h (tree_priority_map_eq, tree_priority_map_hash,
14141 tree_priority_map_marked_p): Remove.
14142 * lto-cgraph.c (lto_output_node, input_node): Stream init priorities.
14143 * lto-streamer-out.c (hash_tree): Do not hash priorities.
14144 * tree-streamer-out.c (pack_ts_decl_with_vis_value_fields): Do
14145 not output priorities.
14146 (pack_ts_function_decl_value_fields): Likewise.
14147 * tree-streamer-in.c (unpack_ts_decl_with_vis_value_fields): Do
14148 not input priorities.
14149 (unpack_ts_function_decl_value_fields): Likewise.
14150 * symtab.c (symbol_priority_map): Declare.
14151 (init_priority_hash): Declare.
14152 (symtab_unregister_node): Unregister from priority hash, too.
14153 (symtab_node::get_init_priority, cgraph_node::get_fini_priority):
14154 New methods.
14155 (symbol_priority_map_eq, symbol_priority_map_hash): New functions.
14156 (symbol_priority_info): New function.
14157 (symtab_node::set_init_priority, cgraph_node::set_fini_priority):
14158 New methods.
14159 * tree-core.h (tree_priority_map): Remove.
14160
14161 2014-06-20 Jakub Jelinek <jakub@redhat.com>
14162
14163 * tree-ssa-math-opts.c (do_shift_rotate, find_bswap_or_nop_1): Cast
14164 0xff to uint64_t before shifting it up.
14165
14166 2014-06-20 Julian Brown <julian@codesourcery.com>
14167 Chung-Lin Tang <cltang@codesourcery.com>
14168
14169 * config/arm/arm.c (arm_output_mi_thunk): Fix offset for
14170 TARGET_THUMB1_ONLY. Add comments.
14171
14172 2014-06-19 Tom de Vries <tom@codesourcery.com>
14173
14174 * config/aarch64/aarch64-protos.h (aarch64_emit_call_insn): Change
14175 return type to void.
14176 * config/aarch64/aarch64.c (aarch64_emit_call_insn): Same.
14177
14178 2014-06-19 Zhenqiang Chen <zhenqiang.chen@linaro.org>
14179
14180 * loop-invariant.c (get_inv_cost): Skip invariants, which are marked
14181 as "move", from depends_on.
14182
14183 2014-06-19 Terry Guo <terry.guo@arm.com>
14184
14185 * config/arm/thumb1.md (define_split): Split 64bit constant in earlier
14186 stage.
14187
14188 2014-06-18 Segher Boessenkool <segher@kernel.crashing.org>
14189
14190 * config/rs6000/rs6000.h (FIXED_REGISTERS): Update comment.
14191 Remove cr5.
14192 (REG_ALLOC_ORDER): Update comment. Move cr5 earlier.
14193
14194 2014-06-18 Kaz Kojima <kkojima@gcc.gnu.org>
14195
14196 PR target/61550
14197 * config/sh/sh.c (prepare_move_operands): Don't process TLS
14198 addresses here if reload in progress or completed.
14199
14200 2014-06-18 Robert Suchanek <robert.suchanek@imgtec.com>
14201
14202 * config/mips/constraints.md ("d"): BASE_REG_CLASS replaced by
14203 "TARGET_MIPS16 ? M16_REGS : GR_REGS".
14204 * config/mips/mips.c (mips_regno_to_class): Update for M16_SP_REGS.
14205 (mips_regno_mode_ok_for_base_p): Remove use of !strict_p for MIPS16.
14206 (mips_register_priority): New function that implements the target
14207 hook TARGET_REGISTER_PRIORITY.
14208 (mips_spill_class): Likewise for TARGET_SPILL_CLASS.
14209 (mips_lra_p): Likewise for TARGET_LRA_P.
14210 (TARGET_REGISTER_PRIORITY): Define macro.
14211 (TARGET_SPILL_CLASS): Likewise.
14212 (TARGET_LRA_P): Likewise.
14213 * config/mips/mips.h (reg_class): Add M16_SP_REGS and SPILL_REGS
14214 classes.
14215 (REG_CLASS_NAMES): Likewise.
14216 (REG_CLASS_CONTENTS): Likewise.
14217 (BASE_REG_CLASS): Use M16_SP_REGS.
14218 * config/mips/mips.md (*mul_acc_si): Add alternative tuned for LRA.
14219 New set attribute to enable alternatives depending on the register
14220 allocator used.
14221 (*mul_acc_si_r3900, *mul_sub_si): Likewise.
14222 (*lea64): Disable pattern for MIPS16.
14223 * config/mips/mips.opt (mlra): New option.
14224
14225 2014-06-18 Robert Suchanek <robert.suchanek@imgtec.com>
14226
14227 * lra-constraints.c (base_to_reg): New function.
14228 (process_address): Use new function.
14229
14230 2014-06-18 Tom de Vries <tom@codesourcery.com>
14231
14232 * config/aarch64/aarch64-protos.h (aarch64_emit_call_insn): Declare.
14233 * config/aarch64/aarch64.c
14234 (TARGET_CALL_FUSAGE_CONTAINS_NON_CALLEE_CLOBBERS): Redefine as true.
14235 (aarch64_emit_call_insn): New function.
14236 (aarch64_load_symref_appropriately): Use aarch64_emit_call_insn instead
14237 of emit_call_insn.
14238 * config/aarch64/aarch64.md (define_expand "call_internal")
14239 (define_expand "call_value_internal", define_expand "sibcall_internal")
14240 (define_expand "sibcall_value_internal"): New.
14241 (define_expand "call", define_expand "call_value")
14242 (define_expand "sibcall", define_expand "sibcall_value"): Use internal
14243 expand variant and aarch64_emit_call_insn.
14244
14245 2014-06-18 Radovan Obradovic <robradovic@mips.com>
14246 Tom de Vries <tom@codesourcery.com>
14247
14248 * config/arm/arm-protos.h (arm_emit_call_insn): Add bool parameter.
14249 * config/arm/arm.c (TARGET_CALL_FUSAGE_CONTAINS_NON_CALLEE_CLOBBERS):
14250 Redefine to true.
14251 (arm_emit_call_insn): Add and use sibcall parameter. Add IP and CC
14252 clobbers to CALL_INSN_FUNCTION_USAGE.
14253 (define_expand "sibcall_internal")
14254 (define_expand "sibcall_value_internal"): New.
14255 (define_expand "call", define_expand "call_value"): Add argument to
14256 arm_emit_call_insn.
14257 (define_expand "sibcall"): Use sibcall_internal and arm_emit_call_insn.
14258 (define_expand "sibcall_value"): Use sibcall_value_internal and
14259 arm_emit_call_insn.
14260
14261 2014-06-18 Charles Baylis <charles.baylis@linaro.org>
14262
14263 * config/arm/bpabi.c (__gnu_uldivmod_helper): Remove.
14264
14265 2014-06-18 Charles Baylis <charles.baylis@linaro.org>
14266
14267 * config/arm/bpabi-v6m.S (__aeabi_uldivmod): Perform division using
14268 __udivmoddi4.
14269
14270 2014-06-18 Charles Baylis <charles.baylis@linaro.org>
14271
14272 * config/arm/bpabi.S (__aeabi_ldivmod, __aeabi_uldivmod,
14273 push_for_divide, pop_for_divide): Use .cfi_* directives for DWARF
14274 annotations. Fix DWARF information.
14275
14276 2014-06-18 Charles Baylis <charles.baylis@linaro.org>
14277
14278 * config/arm/bpabi.S (__aeabi_ldivmod): Perform division using
14279 __udivmoddi4, and fixups for negative operands.
14280
14281 2014-06-18 Charles Baylis <charles.baylis@linaro.org>
14282
14283 * config/arm/bpabi.S (__aeabi_ldivmod): Optimise stack manipulation.
14284
14285 2014-06-18 Charles Baylis <charles.baylis@linaro.org>
14286
14287 * config/arm/bpabi.S (__aeabi_uldivmod): Perform division using call
14288 to __udivmoddi4.
14289
14290 2014-06-18 Charles Baylis <charles.baylis@linaro.org>
14291
14292 * config/arm/bpabi.S (__aeabi_uldivmod): Optimise stack pointer
14293 manipulation.
14294
14295 2014-06-18 Charles Baylis <charles.baylis@linaro.org>
14296
14297 * config/arm/bpabi.S (__aeabi_uldivmod, __aeabi_ldivmod): Add comment
14298 describing register usage on function entry and exit.
14299
14300 2014-06-18 Charles Baylis <charles.baylis@linaro.org>
14301
14302 * config/arm/bpabi.S (__aeabi_uldivmod): Fix whitespace.
14303 (__aeabi_ldivmod): Fix whitespace.
14304
14305 2014-06-18 Andreas Schwab <schwab@suse.de>
14306
14307 * doc/md.texi (Standard Names): Use @itemx for grouped items.
14308 Remove blank line after @item.
14309
14310 2014-06-18 Richard Henderson <rth@redhat.com>
14311
14312 PR target/61545
14313 * config/aarch64/aarch64.md (tlsdesc_small_<PTR>): Clobber CC_REGNUM.
14314
14315 2014-06-18 Charles Baylis <charles.baylis@linaro.org>
14316
14317 * config/arm/arm.c (neon_vector_mem_operand): Allow register
14318 POST_MODIFY for neon loads and stores.
14319 (arm_print_operand): Output post-index register for neon loads and
14320 stores.
14321
14322 2014-06-18 Richard Biener <rguenther@suse.de>
14323
14324 * tree-ssa-dce.c (perform_tree_ssa_dce): Fixup bogus commit.
14325
14326 2014-06-18 Richard Biener <rguenther@suse.de>
14327
14328 * tree-pass.h (make_pass_dce_loop): Remove.
14329 * passes.def: Replace pass_dce_loop with pass_dce.
14330 * tree-ssa-dce.c (perform_tree_ssa_dce): If something
14331 changed free niter estimates and reset the scev cache.
14332 (tree_ssa_dce_loop, pass_data_dce_loop, pass_dce_loop,
14333 make_pass_dce_loop): Remove.
14334 * tree-ssa-copy.c: Include tree-ssa-loop-niter.h.
14335 (fini_copy_prop): Return whether something changed. Always
14336 let substitute_and_fold perform DCE and free niter estimates
14337 and reset the scev cache if so.
14338 (execute_copy_prop): If sth changed schedule cleanup-cfg.
14339 (pass_data_copy_prop): Do not unconditionally schedule
14340 cleanup-cfg or update-ssa.
14341
14342 2014-06-18 Yuri Rumyantsev <ysrumyan@gmail.com>
14343
14344 PR tree-optimization/61518
14345 * tree-if-conv.c (is_cond_scalar_reduction): Add missed check that
14346 reduction var is used in reduction stmt or phi-function only.
14347
14348 2014-06-18 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
14349
14350 * config/arm/arm_neon.h (vadd_f32): Change #ifdef to __FAST_MATH.
14351
14352 2014-06-18 Thomas Preud'homme <thomas.preudhomme@arm.com>
14353
14354 PR tree-optimization/61517
14355 * tree-ssa-math-opts.c (find_bswap_or_nop_1): Adapt to return a stmt
14356 whose rhs's first tree is the source expression instead of the
14357 expression itself.
14358 (find_bswap_or_nop): Likewise.
14359 (bsap_replace): Rename stmt in cur_stmt. Pass gsi by value and src as a
14360 gimple stmt whose rhs's first tree is the source. In the memory source
14361 case, move the stmt to be replaced close to one of the original load to
14362 avoid the problem of a store between the load and the stmt's original
14363 location.
14364 (pass_optimize_bswap::execute): Adapt to change in bswap_replace's
14365 signature.
14366
14367 2014-06-18 Andreas Schwab <schwab@suse.de>
14368
14369 PR rtl-optimization/54555
14370 * postreload.c (move2add_use_add2_insn): Substitute
14371 STRICT_LOW_PART only if it is cheaper.
14372
14373 2014-06-18 Uros Bizjak <ubizjak@gmail.com>
14374
14375 * config/i386/i386.md (*sibcall_memory): Rename from *sibcall_intern.
14376 Do not use unspec as call operand. Use memory_operand instead of
14377 memory_nox32_operand and add "m" operand constraint. Disable
14378 pattern for TARGET_X32.
14379 (*sibcall_pop_memory): Ditto.
14380 (*sibcall_value_memory): Ditto.
14381 (*sibcall_value_pop_memory): Ditto.
14382 (sibcall peepholes): Merge SImode and DImode patterns using
14383 W mode iterator. Use memory_operand instead of memory_nox32_operand.
14384 Disable pattern for TARGET_X32. Check if eliminated register is
14385 really dead after call insn. Generate call RTX without unspec operand.
14386 (sibcall_value peepholes): Ditto.
14387 (sibcall_pop peepholes): Fix call insn RTXes. Use memory_operand
14388 instead of memory_nox32_operand. Check if eliminated register is
14389 really dead after call insn. Generate call RTX without unspec operand.
14390 (sibcall_value_pop peepholes): Ditto.
14391 * config/i386/predicates.md (memory_nox32_operand): Remove predicate.
14392
14393 2014-06-18 Terry Guo <terry.guo@arm.com>
14394
14395 PR target/61544
14396 * config/arm/arm.c (thumb1_reorg): Move to next basic block if we
14397 reach the head.
14398
14399 2014-06-18 Olivier Hainque <hainque@adacore.com>
14400
14401 * tree-core.h (tree_block): Add an "end_locus" field, allowing
14402 memorization of the end of block source location.
14403 * tree.h (BLOCK_SOURCE_END_LOCATION): New accessor.
14404 * gimplify.c (gimplify_bind_expr): Propagate the block start and
14405 end source location info we have on the block entry/exit code we
14406 generate.
14407
14408 2014-06-18 Richard Biener <rguenther@suse.de>
14409
14410 * common.opt (fssa-phiopt): New option.
14411 * opts.c (default_options_table): Enable -fssa-phiopt with -O1+
14412 but not with -Og.
14413 * tree-ssa-phiopt.c (pass_phiopt): Add gate method.
14414 * doc/invoke.texi (-fssa-phiopt): Document.
14415
14416 2014-06-18 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
14417
14418 * genattrtab.c (n_bypassed): New variable.
14419 (process_bypasses): Initialise n_bypassed.
14420 Count number of bypassed reservations.
14421 (make_automaton_attrs): Allocate space for bypassed reservations
14422 rather than number of bypasses.
14423
14424 2014-06-18 Richard Biener <rguenther@suse.de>
14425
14426 * tree-ssa-propagate.c (replace_phi_args_in): Return whether
14427 we propagated anything.
14428 (substitute_and_fold_dom_walker::before_dom_children): Something
14429 changed if we propagated into PHI arguments.
14430 * tree-ssa-pre.c (eliminate): Always schedule cfg-cleanup if
14431 we removed a stmt.
14432
14433 2014-06-18 Evgeny Stupachenko <evstupac@gmail.com>
14434
14435 * config/i386/i386.c (ix86_reassociation_width): Add alternative for
14436 vector case.
14437 * config/i386/i386.h (TARGET_VECTOR_PARALLEL_EXECUTION): New.
14438 * config/i386/x86-tune.def (X86_TUNE_VECTOR_PARALLEL_EXECUTION): New.
14439 * tree-vect-data-refs.c (vect_shift_permute_load_chain): New.
14440 Introduces alternative way of loads group permutaions.
14441 (vect_transform_grouped_load): Try alternative way of permutations.
14442
14443 2014-06-18 Jakub Jelinek <jakub@redhat.com>
14444
14445 * gimplify.c (omp_notice_variable): If n is non-NULL and no flags
14446 changed in ORT_TARGET region, don't jump to do_outer.
14447 (struct gimplify_adjust_omp_clauses_data): New type.
14448 (gimplify_adjust_omp_clauses_1): Adjust for data being
14449 a struct gimplify_adjust_omp_clauses_data pointer instead
14450 of tree *. Pass pre_p as a new argument to
14451 lang_hooks.decls.omp_finish_clause hook.
14452 (gimplify_adjust_omp_clauses): Add pre_p argument, adjust
14453 splay_tree_foreach to pass both list_p and pre_p.
14454 (gimplify_omp_parallel, gimplify_omp_task, gimplify_omp_for,
14455 gimplify_omp_workshare, gimplify_omp_target_update): Adjust
14456 gimplify_adjust_omp_clauses callers.
14457 * langhooks.c (lhd_omp_finish_clause): New function.
14458 * langhooks-def.h (lhd_omp_finish_clause): New prototype.
14459 (LANG_HOOKS_OMP_FINISH_CLAUSE): Define to lhd_omp_finish_clause.
14460 * langhooks.h (struct lang_hooks_for_decls): Add a new
14461 gimple_seq * argument to omp_finish_clause hook.
14462 * omp-low.c (scan_sharing_clauses): Call scan_omp_op on
14463 non-DECL_P OMP_CLAUSE_DECL if ctx->outer.
14464 (scan_omp_parallel, lower_omp_for): When adding
14465 _LOOPTEMP_ clause var, add it to outer ctx's decl_map as identity.
14466 * tree-core.h (OMP_CLAUSE_MAP_TO_PSET): New map kind.
14467 * tree-nested.c (convert_nonlocal_omp_clauses,
14468 convert_local_omp_clauses): Handle various OpenMP 4.0 clauses.
14469 * tree-pretty-print.c (dump_omp_clause): Handle OMP_CLAUSE_MAP_TO_PSET.
14470
14471 2014-06-17 Andrew MacLeod <amacleod@redhat.com>
14472
14473 * tree-dfa.h (get_addr_base_and_unit_offset_1): Move from here.
14474 * tree-dfa.c (get_addr_base_and_unit_offset_1): To here.
14475
14476 2014-06-17 Xinliang David Li <davidxl@google.com>
14477
14478 * tree-pretty-print.c (dump_function_header): Print cgraph uid.
14479 * passes.c (pass_init_dump_file): Do not set initialize
14480 flag to false unconditionally.
14481
14482 2014-06-17 Richard Biener <rguenther@suse.de>
14483
14484 * genopinit.c (main): Use vec<>::qsort method.
14485 * tree-ssa-loop-niter.c (discover_iteration_bound_by_body_walk):
14486 Likewise.
14487 * tree-vect-data-refs.c (vect_analyze_data_ref_accesses): Likewise.
14488
14489 2014-06-17 Matthew Fortune <matthew.fortune@imgtec.com>
14490
14491 * config/mips/mips-protos.h (mips_expand_fcc_reload): Remove.
14492 * config/mips/mips.c (mips_expand_fcc_reload): Remove.
14493 (mips_move_to_gpr_cost): Remove ST_REGS case.
14494 (mips_move_from_gpr_cost): Likewise.
14495 (mips_register_move_cost): Likewise.
14496 (mips_secondary_reload_class): Likewise.
14497
14498 2014-06-17 Richard Biener <rguenther@suse.de>
14499
14500 * passes.def (pass_all_early_optimizations): Remove copy-prop pass.
14501 (pass_all_optimizations): Move 3rd copy-prop pass from after
14502 fre to before ifcombine/phiopt.
14503
14504 2014-06-17 Richard Biener <rguenther@suse.de>
14505
14506 * tree-switch-conversion.c (collect_switch_conv_info): Simplify
14507 and allow all blocks to be forwarders.
14508
14509 2014-06-17 Yufeng Zhang <yufeng.zhang@arm.com>
14510
14511 PR target/61483
14512 * config/aarch64/aarch64.c (aarch64_layout_arg): Add new local
14513 variable 'size'; calculate 'size' right in the front; use
14514 'size' to compute 'nregs' (when 'allocate_ncrn != 0') and
14515 pcum->aapcs_stack_words.
14516
14517 2014-06-17 Nick Clifton <nickc@redhat.com>
14518
14519 * config/msp430/msp430.md (mulhisi3): Add a NOP after the DINT.
14520 (umulhi3, mulsidi3, umulsidi3): Likewise.
14521
14522 2014-06-17 Thomas Schwinge <thomas@codesourcery.com>
14523
14524 PR middle-end/61508
14525 * fold-const.c (fold_checksum_tree) <TS_DECL_WITH_VIS>: Remove
14526 check for section name.
14527
14528 2014-06-17 Richard Biener <rguenther@suse.de>
14529
14530 * tree-ssa-propagate.c: Include domwalk.h.
14531 (substitute_and_fold): Outline main worker into a domwalker ...
14532 (substitute_and_fold_dom_walker::before_dom_children): ... here.
14533 Schedule stmts we can fully propagate for removal. Remove
14534 poor-mans DCE.
14535 (substitute_and_fold): Apply a dominator walk to perform
14536 substitution. Process stmts scheduled for removal here.
14537
14538 2014-06-17 Richard Biener <rguenther@suse.de>
14539
14540 * tree-ssa-loop-im.c (determine_max_movement): Adjust cost
14541 of PHI node moving.
14542
14543 2014-06-17 Kugan Vivekanandarajah <kuganv@linaro.org>
14544
14545 * config/arm/arm.c (arm_atomic_assign_expand_fenv): call
14546 default_atomic_assign_expand_fenv for !TARGET_HARD_FLOAT.
14547 (arm_init_builtins) : Initialize builtins __builtins_arm_set_fpscr and
14548 __builtins_arm_get_fpscr only when TARGET_HARD_FLOAT.
14549 * config/arm/vfp.md (set_fpscr): Make pattern conditional on
14550 TARGET_HARD_FLOAT.
14551 (get_fpscr) : Likewise.
14552
14553 2014-06-16 Vladimir Makarov <vmakarov@redhat.com>
14554
14555 PR rtl-optimization/61325
14556 * lra-constraints.c (valid_address_p): Add forward declaration.
14557 (simplify_operand_subreg): Check address validity before and after
14558 alter_reg of memory subreg.
14559
14560 2014-06-16 Uros Bizjak <ubizjak@gmail.com>
14561
14562 * config/i386/i386.c (decide_alg): Correctly handle
14563 maximum size of stringop algorithm.
14564
14565 2014-06-16 Yury Gribov <y.gribov@samsung.com>
14566
14567 * asan.c (build_check_stmt): Fix maybe-uninitialized warning.
14568
14569 2014-06-16 Vladimir Makarov <vmakarov@redhat.com>
14570
14571 PR rtl-optimization/61522
14572 * lra-assigns.c (assign_by_spills): Check null targetm.spill_class.
14573
14574 2014-06-16 Jan Hubicka <hubicka@ucw.cz>
14575
14576 Revert:
14577 * symtab.c (symtab_node::reset_section): New method.
14578 * cgraph.c (cgraph_node_cannot_be_local_p_1): Accept non-local
14579 for localization.
14580 * cgraph.h (reset_section): Declare.
14581 * ipa-inline-analysis.c (do_estimate_growth): Check for comdat groups;
14582 do not consider comdat locals.
14583 * cgraphclones.c (set_new_clone_decl_and_node_flags): Get section
14584 for new symbol.
14585 * ipa-visiblity.c (cgraph_externally_visible_p): Cleanup.
14586 (update_visibility_by_resolution_info): Consider UNDEF; fix checking;
14587 reset sections of symbols dragged out of the comdats.
14588 (function_and_variable_visibility): Reset sections of
14589 localized symbols.
14590
14591 2014-06-16 Richard Biener <rguenther@suse.de>
14592
14593 PR tree-optimization/61482
14594 * tree-vrp.c (adjust_range_with_scev): Avoid setting of
14595 [-INF(OVF), +INF(OVF)] range.
14596
14597 2014-06-16 Ganesh Gopalasubramanian <Ganesh.Gopalasubramanian@amd.com>
14598
14599 * config/i386/i386.c (ix86_expand_sse2_mulvxdi3): Issue
14600 instructions "vpmuludq" and "vpaddq" instead of "vpmacsdql" for
14601 handling 32-bit multiplication.
14602
14603 2014-06-16 Chung-Lin Tang <cltang@codesourcery.com>
14604
14605 PR middle-end/61430
14606 * lra-lives.c (process_bb_lives): Skip creating copy during
14607 insn scan when src/dest has constrained to same regno.
14608
14609 2014-06-15 Jan Hubicka <hubicka@ucw.cz>
14610
14611 * tree-vect-data-refs.c (vect_can_force_dr_alignment_p): Check again
14612 DECL_IN_CONSTANT_POOL and TREE_ASM_WRITTEN.
14613
14614 2014-06-16 Yury Gribov <y.gribov@samsung.com>
14615
14616 * asan.c (check_func): New function.
14617 (maybe_create_ssa_name): Likewise.
14618 (build_check_stmt_with_calls): Likewise.
14619 (use_calls_p): Likewise.
14620 (report_error_func): Change interface.
14621 (build_check_stmt): Allow non-integer lengths; add support
14622 for new parameter.
14623 (asan_instrument): Likewise.
14624 (instrument_mem_region_access): Moved code to build_check_stmt.
14625 (instrument_derefs): Likewise.
14626 (instrument_strlen_call): Likewise.
14627 * cfgcleanup.c (old_insns_match_p): Add support for new functions.
14628 * doc/invoke.texi: Describe new parameter.
14629 * params.def: Define new parameter.
14630 * params.h: Likewise.
14631 * sanitizer.def: Describe new builtins.
14632
14633 2014-06-16 Richard Biener <rguenther@suse.de>
14634
14635 * tree-ssa-pre.c (eliminate_dom_walker::before_dom_children):
14636 Make all defs available at the end.
14637 (eliminate): If we remove a PHI node schedule cfg-cleanup.
14638
14639 2014-06-18 Jakub Jelinek <jakub@redhat.com>
14640
14641 PR plugins/45078
14642 * config.gcc (arm*-*-linux-*): Include vxworks-dummy.h in tm_file.
14643
14644 2014-06-16 Richard Sandiford <rdsandiford@googlemail.com>
14645
14646 PR bootstrap/61516
14647 * auto-inc-dec.c (merge_in_block): Fix location of insn_info
14648 initialization. Replace remaining use of uid.
14649
14650 2014-06-15 Jan Hubicka <hubicka@ucw.cz>
14651
14652 * c-family/c-common.c (handle_tls_model_attribute): Use
14653 set_decl_tls_model.
14654 * c-family/c-common.c (handle_tls_model_attribute): Use
14655 set_decl_tls_model.
14656 * cgraph.h (struct varpool_node): Add tls_model.
14657 * tree.c (decl_tls_model, set_decl_tls_model): New functions.
14658 * tree.h (DECL_TLS_MODEL): Update.
14659 (DECL_THREAD_LOCAL_P): Check that variable is static.
14660 (decl_tls_model): Declare.
14661 (set_decl_tls_model): Declare.
14662 * tree-emutls.c (get_emutls_init_templ_addr): First build decl and then
14663 set symbol prorperties.
14664 (get_emutls_init_templ_addr): Cleanup.
14665 (new_emutls_decl): Update.
14666 * lto-cgraph.c (lto_output_varpool_node): Stream TLS model
14667 (lto_input_varpool_node): Likewise.
14668 * lto-streamer-out.c (hash_tree): Likewise.
14669 * tree-streamer-in.c (unpack_ts_decl_with_vis_value_fields): Do
14670 not stream DECL_TLS_MODEL.
14671 * tree-profile.c (init_ic_make_global_vars): Use set_decl_tls_model.
14672 * tree-core.h (tree_decl_with_vis): Remove tls_model; update comments.
14673
14674 2014-06-15 Richard Sandiford <rdsandiford@googlemail.com>
14675
14676 * df.h (DF_REF_REG_USE_P, DF_MWS_REG_USE_P): Remove null checks.
14677
14678 2014-06-15 Richard Sandiford <rdsandiford@googlemail.com>
14679
14680 * df.h (df_mw_hardreg, df_base_ref): Add a link pointer.
14681 (df_insn_info): Turn defs, uses, eq_uses and mw_hardregs into linked
14682 lists.
14683 (df_scan_bb_info): Likewise artificial_defs and artificial_uses.
14684 (DF_REF_NEXT_LOC, DF_MWS_NEXT): New macros.
14685 (FOR_EACH_INSN_INFO_DEF, FOR_EACH_INSN_INFO_USE)
14686 (FOR_EACH_INSN_INFO_EQ_USE, FOR_EACH_INSN_INFO_MW)
14687 (FOR_EACH_ARTIFICIAL_USE, FOR_EACH_ARTIFICIAL_DEF)
14688 (df_get_artificial_defs, df_get_artificial_uses)
14689 (df_single_def, df_single_use): Update accordingly.
14690 (df_refs_chain_dump): Take the first element in a linked list as
14691 parameter, rather than a pointer to an array of pointers.
14692 * df-core.c (df_refs_chain_dump, df_mws_dump): Likewise.
14693 * df-problems.c (df_rd_bb_local_compute_process_def): Likewise.
14694 (df_chain_create_bb_process_use): Likewise.
14695 (df_md_bb_local_compute_process_def): Likewise.
14696 * fwprop.c (process_defs, process_uses): Likewise.
14697 (register_active_defs, update_uses): Likewise.
14698 (forward_propagate_asm): Update for new df_ref linking.
14699 * df-scan.c (df_scan_free_ref_vec, df_scan_free_mws_vec): Delete.
14700 (df_null_ref_rec, df_null_mw_rec): Likewise.
14701 (df_scan_free_internal): Don't free df_ref and df_mw_hardreg lists
14702 explicitly.
14703 (df_scan_free_bb_info): Remove check for null artificial_defs.
14704 (df_install_ref_incremental): Adjust for new df_ref linking.
14705 Use a single-element insertion rather than a full sort.
14706 (df_ref_chain_delete_du_chain): Take the first element
14707 in a linked list as parameter, rather than a pointer to an array of
14708 pointers.
14709 (df_ref_chain_delete, df_mw_hardreg_chain_delete): Likewise.
14710 (df_add_refs_to_table, df_refs_verify, df_mws_verify): Likewise.
14711 (df_insn_info_delete): Remove check for null defs and call to
14712 df_scan_free_mws_vec.
14713 (df_insn_rescan): Initialize df_ref and df_mw_hardreg lists to
14714 null rather than df_null_*_rec.
14715 (df_insn_rescan_debug_internal): Likewise, and update null
14716 checks in the same way. Remove check for null defs.
14717 (df_ref_change_reg_with_loc_1): Fix choice of list for defs.
14718 Move a single element rather doing a full sort.
14719 (df_mw_hardreg_chain_delete_eq_uses): Adjust for new df_mw_hardreg
14720 linking.
14721 (df_notes_rescan): Likewise. Use a merge rather than a full sort.
14722 Initialize df_ref and df_mw_hardreg lists to null rather than
14723 df_null_*_rec.
14724 (df_ref_compare): Take df_refs as parameter, transferring the
14725 old interface to...
14726 (df_ref_ptr_compare): ...this new function.
14727 (df_sort_and_compress_refs): Update accordingly.
14728 (df_mw_compare): Take df_mw_hardregs as parameter, transferring the
14729 old interface to...
14730 (df_mw_ptr_compare): ...this new function.
14731 (df_sort_and_compress_mws): Update accordingly.
14732 (df_install_refs, df_install_mws): Return a linked list rather than
14733 an array of pointers.
14734 (df_refs_add_to_chains): Assert that old lists are empty rather
14735 than freeing them.
14736 (df_insn_refs_verify): Don't handle null defs speciailly.
14737 * web.c (union_match_dups): Update for new df_ref linking.
14738
14739 2014-06-15 Richard Sandiford <rdsandiford@googlemail.com>
14740
14741 * df.h (df_ref_create, df_ref_remove): Delete.
14742 * df-scan.c (df_ref_create, df_ref_compress_rec): Likewise.
14743 (df_ref_remove): Likewise.
14744
14745 2014-06-15 Richard Sandiford <rdsandiford@googlemail.com>
14746
14747 * df.h (df_single_def, df_single_use): New functions.
14748 * ira.c (find_moveable_pseudos): Use them.
14749
14750 2014-06-15 Richard Sandiford <rdsandiford@googlemail.com>
14751
14752 * df.h (FOR_EACH_INSN_INFO_MW): New macro.
14753 * df-problems.c (df_note_bb_compute): Use it.
14754 * regstat.c (regstat_bb_compute_ri): Likewise.
14755
14756 2014-06-15 Richard Sandiford <rdsandiford@googlemail.com>
14757
14758 * df.h (FOR_EACH_ARTIFICIAL_USE, FOR_EACH_ARTIFICIAL_DEF): New macros.
14759 * cse.c (cse_extended_basic_block): Use them.
14760 * dce.c (mark_artificial_use): Likewise.
14761 * df-problems.c (df_rd_simulate_artificial_defs_at_top): Likewise.
14762 (df_lr_bb_local_compute, df_live_bb_local_compute): Likewise.
14763 (df_chain_remove_problem, df_chain_bb_dump): Likewise.
14764 (df_word_lr_bb_local_compute, df_note_bb_compute): Likewise.
14765 (df_simulate_initialize_backwards): Likewise.
14766 (df_simulate_finalize_backwards): Likewise.
14767 (df_simulate_initialize_forwards): Likewise.
14768 (df_md_simulate_artificial_defs_at_top): Likewise.
14769 * df-scan.c (df_reorganize_refs_by_reg_by_insn): Likewise.
14770 * regrename.c (init_rename_info): Likewise.
14771 * regstat.c (regstat_bb_compute_ri): Likewise.
14772 (regstat_bb_compute_calls_crossed): Likewise.
14773
14774 2014-06-15 Richard Sandiford <rdsandiford@googlemail.com>
14775
14776 * df.h (DF_INSN_INFO_MWS, FOR_EACH_INSN_INFO_DEF): New macros.
14777 (FOR_EACH_INSN_INFO_USE, FOR_EACH_INSN_INFO_EQ_USE): Likewise.
14778 (FOR_EACH_INSN_DEF, FOR_EACH_INSN_USE, FOR_EACH_INSN_EQ_USE): Likewise.
14779 * auto-inc-dec.c (find_inc, merge_in_block): Use them.
14780 * combine.c (create_log_links): Likewise.
14781 * compare-elim.c (find_flags_uses_in_insn): Likewise.
14782 (try_eliminate_compare): Likewise.
14783 * cprop.c (make_set_regs_unavailable, mark_oprs_set): Likewise.
14784 * dce.c (deletable_insn_p, find_call_stack_args): Likewise.
14785 (remove_reg_equal_equiv_notes_for_defs): Likewise.
14786 (reset_unmarked_insns_debug_uses, mark_reg_dependencies): Likewise.
14787 (word_dce_process_block, dce_process_block): Likewise.
14788 * ddg.c (def_has_ccmode_p): Likewise.
14789 * df-core.c (df_bb_regno_first_def_find): Likewise.
14790 (df_bb_regno_last_def_find, df_find_def, df_find_use): Likewise.
14791 * df-problems.c (df_rd_simulate_one_insn): Likewise.
14792 (df_lr_bb_local_compute, df_live_bb_local_compute): Likewise.
14793 (df_chain_remove_problem, df_chain_insn_top_dump): Likewise.
14794 (df_chain_insn_bottom_dump, df_word_lr_bb_local_compute): Likewise.
14795 (df_word_lr_simulate_defs, df_word_lr_simulate_uses): Likewise.
14796 (df_remove_dead_eq_notes, df_note_bb_compute): Likewise.
14797 (df_simulate_find_defs, df_simulate_find_uses): Likewise.
14798 (df_simulate_find_noclobber_defs, df_simulate_defs): Likewise.
14799 (df_simulate_uses, df_md_simulate_one_insn): Likewise.
14800 * df-scan.c (df_reorganize_refs_by_reg_by_insn): Likewise.
14801 * fwprop.c (local_ref_killed_between_p): Likewise.
14802 (all_uses_available_at, free_load_extend): Likewise.
14803 * gcse.c (update_bb_reg_pressure, calculate_bb_reg_pressure): Likewise.
14804 * hw-doloop.c (scan_loop): Likewise.
14805 * ifcvt.c (dead_or_predicable): Likewise.
14806 * init-regs.c (initialize_uninitialized_regs): Likewise.
14807 * ira-lives.c (mark_hard_reg_early_clobbers): Likewise.
14808 (process_bb_node_lives): Likewise.
14809 * ira.c (compute_regs_asm_clobbered, build_insn_chain): Likewise.
14810 (find_moveable_pseudos): Likewise.
14811 * loop-invariant.c (check_dependencies, record_uses): Likewise.
14812 * recog.c (peep2_find_free_register): Likewise.
14813 * ree.c (get_defs): Likewise.
14814 * regstat.c (regstat_bb_compute_ri): Likewise.
14815 (regstat_bb_compute_calls_crossed): Likewise.
14816 * sched-deps.c (find_inc, find_mem): Likewise.
14817 * sel-sched-ir.c (maybe_downgrade_id_to_use): Likewise.
14818 (maybe_downgrade_id_to_use, setup_id_reg_sets): Likewise.
14819 * shrink-wrap.c (requires_stack_frame_p): Likewise.
14820 (prepare_shrink_wrap): Likewise.
14821 * store-motion.c (compute_store_table, build_store_vectors): Likewise.
14822 * web.c (union_defs, pass_web::execute): Likewise.
14823 * config/i386/i386.c (increase_distance, insn_defines_reg): Likewise.
14824 (insn_uses_reg_mem, ix86_ok_to_clobber_flags): Likewise.
14825
14826 2014-06-13 Vladimir Makarov <vmakarov@redhat.com>
14827
14828 * lra-assign.c (assign_by_spills): Add code to assign vector regs
14829 to inheritance pseudos.
14830 * config/i386/i386.c (ix86_spill_class): Add check on NO_REGS.
14831
14832 2014-06-13 Peter Bergner <bergner@vnet.ibm.com>
14833
14834 PR target/61415
14835 * config/rs6000/rs6000-builtin.def (BU_MISC_1): Delete.
14836 (BU_MISC_2): Rename to ...
14837 (BU_LDBL128_2): ... this.
14838 * config/rs6000/rs6000.h (RS6000_BTM_LDBL128): New define.
14839 (RS6000_BTM_COMMON): Add RS6000_BTM_LDBL128.
14840 * config/rs6000/rs6000.c (rs6000_builtin_mask_calculate): Handle
14841 RS6000_BTM_LDBL128.
14842 (rs6000_invalid_builtin): Add long double 128-bit builtin support.
14843 (rs6000_builtin_mask_names): Add RS6000_BTM_LDBL128.
14844 * config/rs6000/rs6000.md (unpacktf_0): Remove define)expand.
14845 (unpacktf_1): Likewise.
14846 * doc/extend.texi (__builtin_longdouble_dw0): Remove documentation.
14847 (__builtin_longdouble_dw1): Likewise.
14848 * doc/sourcebuild.texi (longdouble128): Document.
14849
14850 2014-06-13 Jeff Law <law@redhat.com>
14851
14852 PR rtl-optimization/61094
14853 PR rtl-optimization/61446
14854 * ree.c (combine_reaching_defs): Get the mode for the copy from
14855 the extension insn rather than the defining insn.
14856
14857 2014-06-13 Dehao Chen <dehao@google.com>
14858
14859 * dwarf2out.c (add_linkage_name): Emit more linkage name.
14860
14861 2014-06-13 Thomas Schwinge <thomas@codesourcery.com>
14862
14863 * doc/install.texi (--enable-linker-plugin-configure-flags)
14864 (--enable-linker-plugin-flags): Document new flags.
14865
14866 2014-06-13 Martin Jambor <mjambor@suse.cz>
14867
14868 PR ipa/61186
14869 * ipa-devirt.c (possible_polymorphic_call_targets): Store NULL to
14870 cache_token if returning early.
14871
14872 2014-06-13 Nick Clifton <nickc@redhat.com>
14873
14874 * config/rx/rx.h (JUMP_ALIGN): Return the log value if user
14875 requested alignment is active.
14876 (LABEL_ALIGN): Likewise.
14877 (LOOP_ALIGN): Likewise.
14878
14879 2014-06-13 Richard Biener <rguenther@suse.de>
14880
14881 * tree-ssa-pre.c (eliminate_dom_walker::before_dom_children):
14882 Rewrite to propagate the VN result into all uses where
14883 possible and to remove stmts becoming dead because of that.
14884 (eliminate): Generalize stmt removal handling, remove in
14885 reverse dominator order to support proper debug stmt
14886 generation. Update stmts before removing stmts.
14887 * tree-ssa-propagate.c (propagate_tree_value): Remove bogus assert.
14888
14889 2014-06-13 Thomas Preud'homme <thomas.preudhomme@arm.com>
14890
14891 PR tree-optimization/61375
14892 * tree-ssa-math-opts.c (init_symbolic_number): Cancel optimization if
14893 symbolic number cannot be represented in an uint64_t.
14894 (find_bswap_or_nop_1): Likewise.
14895
14896 2014-06-12 Jan Hubicka <hubicka@ucw.cz>
14897
14898 * symtab.c (symtab_node::reset_section): New method.
14899 * cgraph.c (cgraph_node_cannot_be_local_p_1): Accept non-local
14900 for localization.
14901 * cgraph.h (reset_section): Declare.
14902 * ipa-inline-analysis.c (do_estimate_growth): Check for comdat groups;
14903 do not consider comdat locals.
14904 * cgraphclones.c (set_new_clone_decl_and_node_flags): Get section
14905 for new symbol.
14906 * ipa-visiblity.c (cgraph_externally_visible_p): Cleanup.
14907 (update_visibility_by_resolution_info): Consider UNDEF; fix checking;
14908 reset sections of symbols dragged out of the comdats.
14909 (function_and_variable_visibility): Reset sections of
14910 localized symbols.
14911
14912 2014-06-12 Jan Hubicka <hubicka@ucw.cz>
14913
14914 * tree-vect-data-refs.c (vect_can_force_dr_alignment_p): Reorg
14915 to use symtab and decl_binds_to_current_def_p
14916 * tree-vectorizer.c (increase_alignment): Increase alignment
14917 of alias target, too.
14918
14919 2014-06-12 Jakub Jelinek <jakub@redhat.com>
14920
14921 PR middle-end/61486
14922 * gimplify.c (struct gimplify_omp_ctx): Add distribute field.
14923 (gimplify_adjust_omp_clauses): Don't or in GOVD_LASTPRIVATE
14924 if outer combined construct is distribute.
14925 (gimplify_omp_for): For OMP_DISTRIBUTE set
14926 gimplify_omp_ctxp->distribute.
14927 * omp-low.c (scan_sharing_clauses) <case OMP_CLAUSE_SHARED>: For
14928 GIMPLE_OMP_TEAMS, if decl isn't global in outer context, record
14929 mapping into decl map.
14930
14931 2014-06-12 Jason Merrill <jason@redhat.com>
14932
14933 * common.opt (fabi-version): Change default to 0.
14934
14935 2014-06-12 Jason Merrill <jason@redhat.com>
14936
14937 * toplev.c (process_options): Reject -fabi-version=1.
14938
14939 2014-06-12 Jeff Law <law@redhat.com>
14940
14941 PR tree-optimization/61009
14942 * tree-ssa-threadedge.c (thread_through_normal_block): Correct return
14943 value when we stop processing a block due to problematic PHIs.
14944
14945 2014-06-12 Alan Lawrence <alan.lawrence@arm.com>
14946
14947 * config/aarch64/arm_neon.h (vmlaq_n_f64, vmlsq_n_f64, vrsrtsq_f64,
14948 vcge_p8, vcgeq_p8, vcgez_p8, vcgez_u8, vcgez_u16, vcgez_u32, vcgez_u64,
14949 vcgezq_p8, vcgezq_u8, vcgezq_u16, vcgezq_u32, vcgezq_u64, vcgezd_u64,
14950 vcgt_p8, vcgtq_p8, vcgtz_p8, vcgtz_u8, vcgtz_u16, vcgtz_u32, vcgtz_u64,
14951 vcgtzq_p8, vcgtzq_u8, vcgtzq_u16, vcgtzq_u32, vcgtzq_u64, vcgtzd_u64,
14952 vcle_p8, vcleq_p8, vclez_p8, vclez_u64, vclezq_p8, vclezd_u64, vclt_p8,
14953 vcltq_p8, vcltz_p8, vcltzq_p8, vcltzd_u64): Remove functions as they
14954 are not in the spec.
14955
14956 2014-06-10 Alan Lawrence <alan.lawrence@arm.com>
14957
14958 PR target/59843
14959 * config/aarch64/aarch64-modes.def: Add V1DFmode.
14960 * config/aarch64/aarch64.c (aarch64_vector_mode_supported_p):
14961 Support V1DFmode.
14962
14963 2014-06-12 Eric Botcazou <ebotcazou@adacore.com>
14964
14965 * tree-core.h (DECL_NONALIASED): Use proper spelling in comment.
14966
14967 2014-06-12 Georg-Johann Lay <avr@gjlay.de>
14968
14969 PR target/61443
14970 * config/avr/avr.md (push<mode>1): Avoid (subreg(mem)) when
14971 loading from address spaces.
14972
14973 2014-06-12 Martin Liska <mliska@suse.cz>
14974
14975 PR ipa/61462
14976 * ipa-prop.c (ipa_make_edge_direct_to_target): Check that gimple call
14977 statement is reachable.
14978
14979 2014-06-11 Jan Hubicka <hubicka@ucw.cz>
14980
14981 * symtab.c (section_hash): New hash.
14982 (symtab_unregister_node): Clear section before freeing.
14983 (hash_section_hash_entry): New haser.
14984 (eq_sections): New function.
14985 (symtab_node::set_section_for_node): New method.
14986 (set_section_1): Update.
14987 (symtab_node::set_section): Take string instead of tree as parameter.
14988 (symtab_resolve_alias): Update.
14989 * cgraph.h (section_hash_entry_d): New structure.
14990 (section_hash_entry): New typedef.
14991 (cgraph_node): Change comdat_group_ to x_comdat_group,
14992 change section_ to x_section and turn into section_hash_entry;
14993 update accestors; put set_section_for_node offline.
14994 * tree.c (decl_section_name): Turn into string.
14995 (set_decl_section_name): Change parameter to be string.
14996 * tree.h (decl_section_name, set_decl_section_name): Update prototypes.
14997 * sdbout.c (sdbout_one_type): Update.
14998 * tree-vect-data-refs.c (vect_can_force_dr_alignment_p): Update.
14999 * varasm.c (IN_NAMED_SECTION, get_named_section,
15000 resolve_unique_section, hot_function_section, get_named_text_section,
15001 USE_SELECT_SECTION_FOR_FUNCTIONS, default_function_rodata_section,
15002 make_decl_rtl, default_unique_section): Update.
15003 * config/c6x/c6x.c (c6x_in_small_data_p): Update.
15004 (c6x_elf_unique_section): Update.
15005 * config/nios2/nios2.c (nios2_in_small_data_p): Update.
15006 * config/pa/pa.c (pa_function_section): Update.
15007 * config/pa/pa.h (IN_NAMED_SECTION_P): Update.
15008 * config/ia64/ia64.c (ia64_in_small_data_p): Update.
15009 * config/arc/arc.c (arc_in_small_data_p): Update.
15010 * config/arm/unknown-elf.h (IN_NAMED_SECTION_P): Update.
15011 * config/mcore/mcore.c (mcore_unique_section): Update.
15012 * config/mips/mips.c (mips16_build_function_stub): Update.
15013 (mips16_build_call_stub): Update.
15014 (mips_function_rodata_section): Update.
15015 (mips_in_small_data_p): Update.
15016 * config/score/score.c (score_in_small_data_p): Update.
15017 * config/rx/rx.c (rx_in_small_data): Update.
15018 * config/rs6000/rs6000.c (rs6000_elf_in_small_data_p): Update.
15019 (rs6000_xcoff_asm_named_section): Update.
15020 (rs6000_xcoff_unique_section): Update.
15021 * config/frv/frv.c (frv_string_begins_with): Update.
15022 (frv_in_small_data_p): Update.
15023 * config/v850/v850.c (v850_encode_data_area): Update.
15024 * config/bfin/bfin.c (DECL_SECTION_NAME): Update.
15025 (bfin_handle_l1_data_attribute): Update.
15026 (bfin_handle_l2_attribute): Update.
15027 * config/mep/mep.c (mep_unique_section): Update.
15028 * config/microblaze/microblaze.c (microblaze_elf_in_small_data_p):
15029 Update.
15030 * config/h8300/h8300.c (h8300_handle_eightbit_data_attribute): Update.
15031 (h8300_handle_tiny_data_attribute): Update.
15032 * config/m32r/m32r.c (m32r_in_small_data_p): Update.
15033 (m32r_in_small_data_p): Update.
15034 * config/alpha/alpha.c (alpha_in_small_data_p): Update.
15035 * config/i386/i386.c (ix86_in_large_data_p): Update.
15036 * config/i386/winnt.c (i386_pe_unique_section): Update.
15037 * config/darwin.c (darwin_function_section): Update.
15038 * config/lm32/lm32.c (lm32_in_small_data_p): Update.
15039 * tree-emutls.c (get_emutls_init_templ_addr): Update.
15040 (new_emutls_decl): Update.
15041 * lto-cgraph.c (lto_output_node, input_node, input_varpool_node,
15042 input_varpool_node): Update.
15043 (ead_string_cst): Turn to ...
15044 (read_string): ... this one.
15045 * dwarf2out.c (secname_for_decl): Update.
15046 * asan.c (asan_protect_global): Update.
15047
15048 2014-06-11 DJ Delorie <dj@redhat.com>
15049
15050 * config/rx/rx.h (FUNCTION_BOUNDARY): Adjust for RX100/200 4-byte
15051 cache lines.
15052 * config/rx/rx.c (rx_option_override): Likewise.
15053 (rx_align_for_label): Likewise.
15054
15055 * config/rx/rx.c (rx_max_skip_for_label): Don't skip anything if -Os.
15056
15057 2014-06-11 Maciej W. Rozycki <macro@codesourcery.com>
15058
15059 * config/mmix/mmix-protos.h (mmix_asm_output_source_line): Remove
15060 prototype.
15061
15062 2014-06-11 Richard Sandiford <rdsandiford@googlemail.com>
15063
15064 * common.md: New file.
15065 * doc/md.texi: Update description of generic, machine-independent
15066 constraints.
15067 * config/s390/constraints.md (e): Delete.
15068 * Makefile.in (md_file): Include common.md.
15069 * config/m32c/t-m32c (md_file): Likewise.
15070 * genpreds.c (general_mem): New array.
15071 (generic_constraint_letters): Remove constraints now defined by
15072 common.md.
15073 (add_constraint): Map TARGET_MEM_CONSTRAINT to general_mem.
15074 Allow the first character to be '<' or '>' as well.
15075 * genoutput.c (general_mem): New array.
15076 (indep_constraints): Remove constraints now defined by common.md.
15077 (note_constraint): Map TARGET_MEM_CONSTRAINT to general_mem.
15078 Remove special handling of 'm'.
15079 * ira-costs.c (record_reg_classes): Remove special handling of
15080 constraints now defined by common.md.
15081 * ira.c (ira_setup_alts, ira_get_dup_out_num): Likewise.
15082 * ira-lives.c (single_reg_class): Likewise.
15083 (ira_implicitly_set_insn_hard_regs): Likewise.
15084 * lra-constraints.c (reg_class_from_constraints): Likewise.
15085 (process_alt_operands, process_address, curr_insn_transform): Likewise.
15086 * postreload.c (reload_cse_simplify_operands): Likewise.
15087 * reload.c (push_secondary_reload, scratch_reload_class)
15088 (find_reloads, alternative_allows_const_pool_ref): Likewise.
15089 * reload1.c (maybe_fix_stack_asms): Likewise.
15090 * targhooks.c (default_secondary_reload): Likewise.
15091 * stmt.c (parse_output_constraint): Likewise.
15092 * recog.c (preprocess_constraints): Likewise.
15093 (constrain_operands, peep2_find_free_register): Likewise.
15094 (asm_operand_ok): Likewise, but add a comment saying why 'o'
15095 must be handled specially.
15096
15097 2014-06-11 Richard Sandiford <rdsandiford@googlemail.com>
15098
15099 * system.h (CONST_DOUBLE_OK_FOR_CONSTRAINT_P): Poison.
15100 * genpreds.c (have_const_dbl_constraints): Delete.
15101 (add_constraint): Don't set it.
15102 (write_tm_preds_h): Don't call CONST_DOUBLE_OK_FOR_CONSTRAINT_P.
15103 * ira-costs.c (record_reg_classes): Handle CONST_INT and CONST_DOUBLE
15104 constraints using the lookup_constraint logic.
15105 * ira-lives.c (single_reg_class): Likewise.
15106 * ira.c (ira_setup_alts): Likewise.
15107 * lra-constraints.c (process_alt_operands): Likewise.
15108 * recog.c (asm_operand_ok, constrain_operands): Likewise.
15109 * reload.c (find_reloads): Likewise.
15110
15111 2014-06-11 Richard Sandiford <rdsandiford@googlemail.com>
15112
15113 * genpreds.c (const_int_start, const_int_end): New variables.
15114 (choose_enum_order): Output CONST_INT constraints before memory
15115 constraints.
15116 (write_tm_preds_h): Always define insn_const_int_ok_for_constraint.
15117 Add CT_CONST_INT.
15118 * ira-costs.c (record_reg_classes): Handle CT_CONST_INT.
15119 * ira.c (ira_setup_alts): Likewise.
15120 * lra-constraints.c (process_alt_operands): Likewise.
15121 * recog.c (asm_operand_ok, preprocess_constraints): Likewise.
15122 * reload.c (find_reloads): Likewise.
15123
15124 2014-06-11 Richard Sandiford <rdsandiford@googlemail.com>
15125
15126 * recog.h (operand_alternative): Remove offmem_ok, nonffmem_ok,
15127 decmem_ok and incmem_ok. Reformat other bitfields for consistency.
15128 * recog.c (preprocess_constraints): Update accordingly.
15129
15130 2014-06-11 Richard Sandiford <rdsandiford@googlemail.com>
15131
15132 * system.h (REG_CLASS_FROM_CONSTRAINT): Poison.
15133 (REG_CLASS_FOR_CONSTRAINT, EXTRA_CONSTRAINT_STR): Likewise.
15134 (EXTRA_MEMORY_CONSTRAINT, EXTRA_ADDRESS_CONSTRAINT): Likewise.
15135 * genpreds.c (print_type_tree): New function.
15136 (write_tm_preds_h): Remove REG_CLASS_FROM_CONSTRAINT,
15137 REG_CLASS_FOR_CONSTRAINT, EXTRA_MEMORY_CONSTRAINT,
15138 EXTRA_ADDRESS_CONSTRAINT and EXTRA_CONSTRAINT_STR.
15139 Write out enum constraint_type and get_constraint_type.
15140 * lra-constraints.c (satisfies_memory_constraint_p): Take a
15141 constraint_num rather than a constraint string.
15142 (satisfies_address_constraint_p): Likewise.
15143 (reg_class_from_constraints): Avoid old constraint macros.
15144 (process_alt_operands, process_address_1): Likewise.
15145 (curr_insn_transform): Likewise.
15146 * ira-costs.c (record_reg_classes): Likewise.
15147 (record_operand_costs): Likewise.
15148 * ira-lives.c (single_reg_class): Likewise.
15149 (ira_implicitly_set_insn_hard_regs): Likewise.
15150 * ira.c (ira_setup_alts, ira_get_dup_out_num): Likewise.
15151 * postreload.c (reload_cse_simplify_operands): Likewise.
15152 * recog.c (asm_operand_ok, preprocess_constraints): Likewise.
15153 (constrain_operands, peep2_find_free_register): Likewise.
15154 * reload.c (push_secondary_reload, scratch_reload_class): Likewise.
15155 (find_reloads, alternative_allows_const_pool_ref): Likewise.
15156 * reload1.c (maybe_fix_stack_asms): Likewise.
15157 * stmt.c (parse_output_constraint, parse_input_constraint): Likewise.
15158 * targhooks.c (default_secondary_reload): Likewise.
15159 * config/m32c/m32c.c (m32c_matches_constraint_p): Avoid reference
15160 to EXTRA_CONSTRAINT_STR.
15161 * config/sparc/constraints.md (U): Likewise REG_CLASS_FROM_CONSTRAINT.
15162
15163 2014-06-11 Richard Sandiford <rdsandiford@googlemail.com>
15164
15165 * genpreds.c (write_constraint_satisfied_p_1): Replace with...
15166 (write_constraint_satisfied_p_array): ...this new function.
15167 (write_tm_preds_h): Replace write_constraint_satisfied_p_1 with
15168 an array.
15169 (write_insn_preds_c): Update accordingly.
15170
15171 2014-06-11 Richard Sandiford <rdsandiford@googlemail.com>
15172
15173 * genpreds.c (write_lookup_constraint): Rename to...
15174 (write_lookup_constraint_1): ...this.
15175 (write_lookup_constraint_array): New function.
15176 (write_tm_preds_h): Define lookup_constraint as an inline function
15177 that uses write_lookup_constraint_array where possible.
15178 (write_insn_preds_c): Update for the changes above.
15179
15180 2014-06-11 Richard Sandiford <rdsandiford@googlemail.com>
15181
15182 * doc/md.texi (regclass_for_constraint): Rename to...
15183 (reg_class_for_constraint): ...this.
15184 * genpreds.c (num_constraints, enum_order, register_start)
15185 (register_end, satisfied_start, memory_start, memory_end)
15186 (address_start, address_end): New variables.
15187 (add_constraint): Count the number of constraints.
15188 (choose_enum_order): New function.
15189 (write_enum_constraint_num): Iterate over enum_order.
15190 (write_regclass_for_constraint): Rename to...
15191 (write_reg_class_for_constraint_1): ...this and update output
15192 accordingly.
15193 (write_constraint_satisfied_p): Rename to...
15194 (write_constraint_satisfied_p_1): ...this and update output
15195 accordingly. Do nothing if all extra constraints are register
15196 constraints.
15197 (write_insn_extra_memory_constraint): Delete.
15198 (write_insn_extra_address_constraint): Delete.
15199 (write_range_function): New function.
15200 (write_tm_preds_h): Define constraint_satisfied_p and
15201 reg_class_for_constraint as inline functions that do a range check
15202 before calling the out-of-line function. Use write_range_function
15203 to implement insn_extra_{register,memory,address}_constraint,
15204 the first of which is new.
15205 (write_insn_preds_c): Update after above changes to write_* functions.
15206 (main): Call choose_enum_order.
15207
15208 2014-06-11 Thomas Preud'homme <thomas.preudhomme@arm.com>
15209
15210 PR tree-optimization/61306
15211 * tree-ssa-math-opts.c (struct symbolic_number): Store type of
15212 expression instead of its size.
15213 (do_shift_rotate): Adapt to change in struct symbolic_number. Return
15214 false to prevent optimization when the result is unpredictable due to
15215 arithmetic right shift of signed type with highest byte is set.
15216 (verify_symbolic_number_p): Adapt to change in struct symbolic_number.
15217 (init_symbolic_number): Likewise.
15218 (find_bswap_or_nop_1): Likewise. Return NULL to prevent optimization
15219 when the result is unpredictable due to sign extension.
15220
15221 2014-06-11 Terry Guo <terry.guo@arm.com>
15222
15223 * config/arm/arm.md (*thumb1_adddi3): Move into new file thumb1.md.
15224 (*thumb1_addsi3): Ditto.
15225 (*thumb_subdi3): Ditto.
15226 (thumb1_subsi3_insn): Ditto.
15227 (*thumb_mulsi3): Ditto.
15228 (*thumb_mulsi3_v6): Ditto.
15229 (*thumb1_andsi3_insn): Ditto.
15230 (thumb1_bicsi3): Ditto.
15231 (*thumb1_iorsi3_insn): Ditto.
15232 (*thumb1_xorsi3_insn): Ditto.
15233 (*thumb1_ashlsi3): Ditto.
15234 (*thumb1_ashrsi3): Ditto.
15235 (*thumb1_lshrsi3): Ditto.
15236 (*thumb1_rotrsi3): Ditto.
15237 (*thumb1_negdi2): Ditto.
15238 (*thumb1_negsi2): Ditto.
15239 (*thumb1_abssi2): Ditto.
15240 (*thumb1_neg_abssi2): Ditto.
15241 (*thumb1_one_cmplsi2): Ditto.
15242 (*thumb1_zero_extendhisi2): Ditto.
15243 (*thumb1_zero_extendqisi2): Ditto.
15244 (*thumb1_zero_extendqisi2_v6): Ditto.
15245 (thumb1_extendhisi2): Ditto.
15246 (thumb1_extendqisi2): Ditto.
15247 (*thumb1_movdi_insn): Ditto.
15248 (*thumb1_movsi_insn): Ditto.
15249 (*thumb1_movhi_insn): Ditto.
15250 (thumb_movhi_clobber): Ditto.
15251 (*thumb1_movqi_insn): Ditto.
15252 (*thumb1_movhf): Ditto.
15253 (*thumb1_movsf_insn): Ditto.
15254 (*thumb_movdf_insn): Ditto.
15255 (movmem12b): Ditto.
15256 (movmem8b): Ditto.
15257 (cbranchqi4): Ditto.
15258 (cbranchsi4_insn): Ditto.
15259 (cbranchsi4_scratch): Ditto.
15260 (*negated_cbranchsi4): Ditto.
15261 (*tbit_cbranch): Ditto.
15262 (*tlobits_cbranch): Ditto.
15263 (*tstsi3_cbranch): Ditto.
15264 (*cbranchne_decr1): Ditto.
15265 (*addsi3_cbranch): Ditto.
15266 (*addsi3_cbranch_scratch): Ditto.
15267 (*thumb_cmpdi_zero): Ditto.
15268 (cstoresi_eq0_thumb1): Ditto.
15269 (cstoresi_ne0_thumb1): Ditto.
15270 (*cstoresi_eq0_thumb1_insn): Ditto.
15271 (*cstoresi_ne0_thumb1_insn): Ditto.
15272 (cstoresi_nltu_thumb1): Ditto.
15273 (cstoresi_ltu_thumb1): Ditto.
15274 (thumb1_addsi3_addgeu): Ditto.
15275 (*thumb_jump): Ditto.
15276 (*call_reg_thumb1_v5): Ditto.
15277 (*call_reg_thumb1): Ditto.
15278 (*call_value_reg_thumb1_v5): Ditto.
15279 (*call_value_reg_thumb1): Ditto.
15280 (*call_insn): Ditto.
15281 (*call_value_insn): Ditto.
15282 (thumb1_casesi_internal_pic): Ditto.
15283 (thumb1_casesi_dispatch): Ditto.
15284 (*thumb1_indirect_jump): Ditto.
15285 (prologue_thumb1_interwork): Ditto.
15286 (*epilogue_insns): Ditto.
15287 (consttable_1): Ditto.
15288 (consttable_2): Ditto.
15289 (tablejump): Ditto.
15290 (*thumb1_tablejump): Ditto.
15291 (thumb_eh_return): Ditto.
15292 (define_peephole2): Two of them are thumb1 only and got moved into
15293 new file thumb1.md.
15294 (define_split): Six of them are thumb1 only and got moved into new
15295 file thumb1.md.
15296 * config/arm/thumb1.md: New file comprised of above thumb1 only
15297 patterns.
15298
15299 2014-06-11 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
15300
15301 * config.gcc (aarch64*-*-*): Add arm_acle.h to extra headers.
15302 * Makefile.in (TEXI_GCC_FILES): Add aarch64-acle-intrinsics.texi to
15303 dependencies.
15304 * config/aarch64/aarch64-builtins.c (AARCH64_CRC32_BUILTINS): Define.
15305 (aarch64_crc_builtin_datum): New struct.
15306 (aarch64_crc_builtin_data): New.
15307 (aarch64_init_crc32_builtins): New function.
15308 (aarch64_init_builtins): Initialise CRC32 builtins when appropriate.
15309 (aarch64_crc32_expand_builtin): New.
15310 (aarch64_expand_builtin): Add CRC32 builtin expansion case.
15311 * config/aarch64/aarch64.h (TARGET_CPU_CPP_BUILTINS): Define
15312 __ARM_FEATURE_CRC32 when appropriate.
15313 (TARGET_CRC32): Define.
15314 * config/aarch64/aarch64.md (UNSPEC_CRC32B, UNSPEC_CRC32H,
15315 UNSPEC_CRC32W, UNSPEC_CRC32X, UNSPEC_CRC32CB, UNSPEC_CRC32CH,
15316 UNSPEC_CRC32CW, UNSPEC_CRC32CX): New unspec values.
15317 (aarch64_<crc_variant>): New pattern.
15318 * config/aarch64/arm_acle.h: New file.
15319 * config/aarch64/iterators.md (CRC): New int iterator.
15320 (crc_variant, crc_mode): New int attributes.
15321 * doc/aarch64-acle-intrinsics.texi: New file.
15322 * doc/extend.texi (aarch64): Document aarch64 ACLE intrinsics.
15323 Include aarch64-acle-intrinsics.texi.
15324
15325 2014-06-11 Evgeny Stupachenko <evstupac@gmail.com>
15326
15327 * tree-vect-data-refs.c (vect_grouped_store_supported): New
15328 check for stores group of length 3.
15329 (vect_permute_store_chain): New permutations for stores group of
15330 length 3.
15331 * tree-vect-stmts.c (vect_model_store_cost): Change cost
15332 of vec_perm_shuffle for the new permutations.
15333
15334 2014-06-11 Jan Hubicka <hubicka@ucw.cz>
15335
15336 * ipa-visibility.c (function_and_variable_visibility): Disable virtual
15337 table rewriting temporarily on targets not supporting ONE_ONLY.
15338
15339 2014-06-11 Richard Biener <rguenther@suse.de>
15340
15341 PR middle-end/61437
15342 Revert
15343 2014-06-04 Richard Biener <rguenther@suse.de>
15344
15345 * tree.h (may_be_aliased): Trust TREE_ADDRESSABLE from
15346 TREE_PUBLIC and DECL_EXTERNAL decls.
15347
15348 2014-06-10 Jan Hubicka <hubicka@ucw.cz>
15349
15350 * varasm.c (set_implicit_section): New function.
15351 (resolve_unique_section): Use it to set implicit section
15352 for aliases, too.
15353 (get_named_text_section): Use symtab_get_node (decl)->implicit_section
15354 (default_function_section): Likewise.
15355 (decl_binds_to_current_def_p): Constify argument.
15356 * varasm.h (decl_binds_to_current_def_p): Update prototype.
15357 * asan.c (asan_protect_global): Use
15358 symtab_get_node (decl)->implicit_section.
15359 * symtab.c (dump_symtab_base): Dump implicit sections.
15360 (verify_symtab_base): Verify sanity of sectoins and comdats.
15361 (symtab_resolve_alias): Alias share the section of its target.
15362 (set_section_1): New function.
15363 (symtab_node::set_section): Move here, recurse to aliases.
15364 (verify_symtab): Check for duplicated symtab lists.
15365 * tree-core.h (implicit_section_name_p): Remove.
15366 * tree-vect-data-refs.c: Include varasm.h.
15367 (vect_can_force_dr_alignment_p): Fix conditional on when
15368 decl bints to current definition; use
15369 symtab_get_node (decl)->implicit_section.
15370 * cgraph.c (cgraph_make_node_local_1): Fix section set.
15371 * cgraph.h (struct symtab_node): Add implicit_section.
15372 (set_section): Rename to ...
15373 (set_section_for_node): ... this one.
15374 (set_section): Declare.
15375 * tree.h (DECL_HAS_IMPLICIT_SECTION_NAME_P): Remove.
15376 * lto-cgraph.c (lto_output_node, lto_output_varpool_node,
15377 input_overwrite_node, input_varpool_node): Stream implicit_section.
15378 * ipa.c (symtab_remove_unreachable_nodes): Do not check symtab before
15379 removal; it will fail in LTO.
15380
15381 2014-06-10 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
15382
15383 * config/aarch64/aarch64-simd.md (move_lo_quad_<mode>):
15384 Change second alternative type to f_mcr.
15385 * config/aarch64/aarch64.md (*movsi_aarch64): Change 11th
15386 and 12th alternatives' types to f_mcr and f_mrc.
15387 (*movdi_aarch64): Same for 12th and 13th alternatives.
15388 (*movsf_aarch64): Change 9th alternatives' type to mov_reg.
15389 (aarch64_movtilow_tilow): Change type to fmov.
15390
15391 2014-06-10 Jiong Wang <jiong.wang@arm.com>
15392
15393 * config/aarch64/aarch64.c (aarch64_save_or_restore_fprs)
15394 (aarch64_save_or_restore_callee_save_registers): Fix layout.
15395
15396 2014-06-10 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
15397
15398 * config/aarch64/aarch64-simd.md (aarch64_sqdmulh_lane<mode>):
15399 New expander.
15400 (aarch64_sqrdmulh_lane<mode>): Likewise.
15401 (aarch64_sq<r>dmulh_lane<mode>): Rename to...
15402 (aarch64_sq<r>dmulh_lane<mode>_internal): ...this.
15403 (aarch64_sqdmulh_laneq<mode>): New expander.
15404 (aarch64_sqrdmulh_laneq<mode>): Likewise.
15405 (aarch64_sq<r>dmulh_laneq<mode>): Rename to...
15406 (aarch64_sq<r>dmulh_laneq<mode>_internal): ...this.
15407 (aarch64_sqdmulh_lane<mode>): New expander.
15408 (aarch64_sqrdmulh_lane<mode>): Likewise.
15409 (aarch64_sq<r>dmulh_lane<mode>): Rename to...
15410 (aarch64_sq<r>dmulh_lane<mode>_internal): ...this.
15411 (aarch64_sqdmlal_lane<mode>): Add lane flip for big-endian.
15412 (aarch64_sqdmlal_laneq<mode>): Likewise.
15413 (aarch64_sqdmlsl_lane<mode>): Likewise.
15414 (aarch64_sqdmlsl_laneq<mode>): Likewise.
15415 (aarch64_sqdmlal2_lane<mode>): Likewise.
15416 (aarch64_sqdmlal2_laneq<mode>): Likewise.
15417 (aarch64_sqdmlsl2_lane<mode>): Likewise.
15418 (aarch64_sqdmlsl2_laneq<mode>): Likewise.
15419 (aarch64_sqdmull_lane<mode>): Likewise.
15420 (aarch64_sqdmull_laneq<mode>): Likewise.
15421 (aarch64_sqdmull2_lane<mode>): Likewise.
15422 (aarch64_sqdmull2_laneq<mode>): Likewise.
15423
15424 2014-06-10 Richard Biener <rguenther@suse.de>
15425
15426 PR tree-optimization/61438
15427 * tree-ssa-pre.c (eliminate_dom_walker): Add do_pre member.
15428 (eliminate_dom_walker::before_dom_children): Only try to inhibit
15429 insertion of IVs if running PRE.
15430 (eliminate): Adjust.
15431 (pass_pre::execute): Likewise.
15432 (pass_fre::execute): Likewise.
15433
15434 2014-06-10 Richard Biener <rguenther@suse.de>
15435
15436 PR middle-end/61456
15437 * tree-ssa-alias.c (nonoverlapping_component_refs_of_decl_p):
15438 Do not use the main variant for the type comparison.
15439 (ncr_compar): Likewise.
15440 (nonoverlapping_component_refs_p): Likewise.
15441
15442 2014-06-10 Marcus Shawcroft <marcus.shawcroft@arm.com>
15443
15444 * config/aarch64/aarch64.c (aarch64_save_or_restore_fprs): Fix
15445 REG_CFA_RESTORE mode.
15446
15447 2014-06-10 Evgeny Stupachenko <evstupac@gmail.com>
15448
15449 * config/i386/i386.c (expand_vec_perm_pblendv): New.
15450 * config/i386/i386.c (ix86_expand_vec_perm_const_1): Use
15451 expand_vec_perm_pblendv.
15452
15453 2014-06-10 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
15454
15455 * doc/arm-acle-intrinsics.texi: Specify when CRC32 intrinsics are
15456 available.
15457 Simplify description of __crc32d and __crc32cd intrinsics.
15458 * doc/extend.texi (ARM ACLE Intrinsics): Remove comment about CRC32
15459 availability.
15460
15461 2014-06-10 Thomas Schwinge <thomas@codesourcery.com>
15462
15463 PR lto/61334
15464 * configure.ac: Use gcc_AC_CHECK_DECLS to check for strnlen prototype.
15465 * config.in: Regenerate.
15466 * configure: Likewise.
15467
15468 2014-06-10 Jan Hubicka <hubicka@ucw.cz>
15469
15470 * ipa-reference.c (is_proper_for_analysis): Exclude addressable
15471 and public vars.
15472 (intersect_static_var_sets): Remove.
15473 (propagate): Do not prune local statics.
15474
15475 2014-06-10 Jakub Jelinek <jakub@redhat.com>
15476
15477 PR fortran/60928
15478 * omp-low.c (lower_rec_input_clauses) <case OMP_CLAUSE_LASTPRIVATE>:
15479 Set lastprivate_firstprivate even if omp_private_outer_ref
15480 langhook returns true.
15481 <case OMP_CLAUSE_REDUCTION>: When calling omp_clause_default_ctor
15482 langhook, call unshare_expr on new_var and call
15483 build_outer_var_ref to get the last argument.
15484
15485 2014-06-10 Marek Polacek <polacek@redhat.com>
15486
15487 PR c/60988
15488 * doc/extend.texi: Add cindex for transparent_union.
15489
15490 2014-06-09 Thomas Preud'homme <thomas.preudhomme@arm.com>
15491
15492 * tree-ssa-math-opts.c (find_bswap_or_nop_load): Check return value of
15493 init_symbolic_number ().
15494
15495 2014-05-18 John David Anglin <danglin@gcc.gnu.org>
15496
15497 PR middle-end/61141
15498 * emit-rtl.c (reset_all_used_flags): In a sequence, check that
15499 XVECEXP (pat, 0, i) is an INSN before calling reset_insn_used_flags.
15500 (verify_rtl_sharing): Likewise.
15501
15502 2014-06-09 Marc Glisse <marc.glisse@inria.fr>
15503
15504 PR c++/54442
15505 * tree.c (build_qualified_type): Use a canonical type for
15506 TYPE_CANONICAL.
15507
15508 2014-06-09 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
15509
15510 * config/arm/arm-modes.def: Remove XFmode.
15511
15512 2014-06-09 Alan Lawrence <alan.lawrence@arm.com>
15513
15514 PR target/61062
15515 * config/arm/arm_neon.h (vtrn_s8, vtrn_s16, vtrn_u8, vtrn_u16, vtrn_p8,
15516 vtrn_p16, vtrn_s32, vtrn_f32, vtrn_u32, vtrnq_s8, vtrnq_s16, vtrnq_s32,
15517 vtrnq_f32, vtrnq_u8, vtrnq_u16, vtrnq_u32, vtrnq_p8, vtrnq_p16,
15518 vzip_s8, vzip_s16, vzip_u8, vzip_u16, vzip_p8, vzip_p16, vzip_s32,
15519 vzip_f32, vzip_u32, vzipq_s8, vzipq_s16, vzipq_s32, vzipq_f32,
15520 vzipq_u8, vzipq_u16, vzipq_u32, vzipq_p8, vzipq_p16, vuzp_s8, vuzp_s16,
15521 vuzp_s32, vuzp_f32, vuzp_u8, vuzp_u16, vuzp_u32, vuzp_p8, vuzp_p16,
15522 vuzpq_s8, vuzpq_s16, vuzpq_s32, vuzpq_f32, vuzpq_u8, vuzpq_u16,
15523 vuzpq_u32, vuzpq_p8, vuzpq_p16): Correct mask for bigendian.
15524
15525 2014-06-09 Jan Hubicka <hubicka@ucw.cz>
15526
15527 * tree-core.h (tree_decl_with_vis): Remove section_name.
15528
15529 2014-06-09 Kito Cheng <kito@0xlab.org>
15530
15531 * ira.c (ira): Don't call init_caller_save if LRA enabled
15532 since LRA use its own infrastructure to handle that.
15533
15534 2014-06-07 Jan Hubicka <hubicka@ucw.cz>
15535
15536 * symtab.c (dump_symtab_base): Update dumping.
15537 (symtab_make_decl_local): Clear only DECL_COMDAT.
15538 * tree-vect-data-refs.c (Check that variable is static before
15539 tampering with sections.
15540 * cgraphclones.c (duplicate_thunk_for_node): Do not clear section name.
15541 (cgraph_create_virtual_clone): Likewise.
15542 * tree.c (decl_comdat_group, decl_comdat_group_id): Constify argument.
15543 (decl_section_name, set_decl_section_name): New accessors.
15544 (find_decls_types_r): Do not walk section name
15545 * tree.h (DECL_SECTION_NAME): Implement using decl_section_name.
15546 (decl_comdat_group, decl_comdat_group_id): Constify.
15547 (decl_section_name, set_decl_section_name): Update.
15548 * varpool.c (varpool_finalize_named_section_flags): Use get_section.
15549 * cgraph.c (cgraph_add_thunk): Reset node instead of rebuilding.
15550 (cgraph_make_node_local_1): Clear section and comdat group.
15551 * cgraph.h (set_comdat_group): Sanity check.
15552 (get_section, set_section): New.
15553 * ipa-comdats.c (ipa_comdats): Use get_section.
15554 * ipa.c (ipa_discover_readonly_nonaddressable_var): Likewise.
15555 * lto-streamer-out.c: Do not follow section names.
15556 * c-family/c-common.c (handle_section_attribute): Update.
15557 * lto-cgraph.c (lto_output_node): Output section.
15558 (lto_output_varpool_node): Likewise.
15559 (read_comdat_group): Rename to ...
15560 (read_identifier): ... this one.
15561 (read_string_cst): New function.
15562 (input_node, input_varpool_node): Input section names.
15563 * tree-emutls.c (get_emutls_init_templ_addr): Update.
15564 (new_emutls_decl): Update.
15565 (secname_for_decl): Check section names only of static vars.
15566 * config/mep/mep.c (mep_unique_section): Use set_decl_section_name.
15567 * config/i386/winnt.c (i386_pe_unique_section): Likewise.
15568 * config/i386/i386.c (x86_64_elf_unique_section): Likewise.
15569 * config/c6x/c6x.c (c6x_elf_unique_section): Likewise.
15570 * config/rs6000/rs6000.c (rs6000_xcoff_unique_section): Likewise.
15571 * config/mcore/mcore.c (mcore_unique_section): Likewise.
15572 * config/mips/mips.c (mips16_build_function_stub): Likewise.
15573 * config/v850/v850.c (v850_insert_attributes): Likewise.
15574 * config/h8300/h8300.c (h8300_handle_eightbit_data_attribute):
15575 Likewise.
15576 (h8300_handle_tiny_data_attribute): Likewise.
15577 * config/bfin/bfin.c (bfin_handle_l1_text_attribute): Likewise.
15578 (bfin_handle_l2_attribute): Likewise.
15579
15580 2014-06-07 Jan Hubicka <hubicka@ucw.cz>
15581
15582 * symtab.c (symtab_nonoverwritable_alias): Copy VIRTUAL flag;
15583 remove static initializer.
15584
15585 2014-06-07 Jan Hubicka <hubicka@ucw.cz>
15586
15587 * varasm.c (use_blocks_for_decl_p): Check symbol table
15588 instead of alias attribute.
15589 (place_block_symbol): Recurse on aliases.
15590
15591 2014-06-07 Jan Hubicka <hubicka@ucw.cz>
15592
15593 * ipa-visibility.c: Include varasm.h
15594 (can_replace_by_local_alias): Ceck decl_binds_to_current_def_p.
15595
15596 2014-06-07 Jan Hubicka <hubicka@ucw.cz>
15597
15598 * cgraphunit.c (assemble_thunks_and_aliases): Expand thunks before
15599 outputting aliases.
15600
15601 2014-06-07 Steven Bosscher <steven@gcc.gnu.org>
15602
15603 * gcse.c (can_assign_to_reg_without_clobbers_p): Do not let pointers
15604 from test_insn into GGC space escape via SET_SRC.
15605
15606 2014-06-07 Eric Botcazou <ebotcazou@adacore.com>
15607
15608 * tree-ssa-tail-merge.c (same_succ_hash): Hash the static chain of a
15609 call statement, if any.
15610 (gimple_equal_p) <GIMPLE_CALL>: Compare the static chain of the call
15611 statements, if any. Tidy up.
15612
15613 2014-06-06 Michael Meissner <meissner@linux.vnet.ibm.com>
15614
15615 PR target/61431
15616 * config/rs6000/vsx.md (VSX_LE): Split VSX_D into 2 separate
15617 iterators, VSX_D that handles 64-bit types, and VSX_LE that
15618 handles swapping the two 64-bit double words on little endian
15619 systems. Include V1TImode and optionally TImode in VSX_LE so that
15620 these types are properly swapped. Change all of the insns and
15621 splits that do the 64-bit swaps to use VSX_LE.
15622 (vsx_le_perm_load_<mode>): Likewise.
15623 (vsx_le_perm_store_<mode>): Likewise.
15624 (splitters for little endian memory operations): Likewise.
15625 (vsx_xxpermdi2_le_<mode>): Likewise.
15626 (vsx_lxvd2x2_le_<mode>): Likewise.
15627 (vsx_stxvd2x2_le_<mode>): Likewise.
15628
15629 2014-06-06 Uros Bizjak <ubizjak@gmail.com>
15630
15631 PR target/61423
15632 * config/i386/i386.md (*floatunssi<mode>2_i387_with_xmm): New
15633 define_insn_and_split pattern, merged from *floatunssi<mode>2_1
15634 and corresponding splitters. Zero extend general register
15635 or memory input operand to XMM temporary. Enable for
15636 TARGET_SSE2 and TARGET_INTER_UNIT_MOVES_TO_VEC only.
15637 (floatunssi<mode>2): Update expander predicate.
15638
15639 2014-06-06 Vladimir Makarov <vmakarov@redhat.com>
15640
15641 PR rtl-optimization/61325
15642 * lra-constraints.c (process_address_1): Check scale equal to one
15643 to prevent transformation: base + scale * index => base + new_reg.
15644
15645 2014-06-06 Richard Biener <rguenther@suse.de>
15646
15647 PR tree-optimization/59299
15648 * tree-ssa-sink.c (all_immediate_uses_same_place): Work on
15649 a def operand.
15650 (nearest_common_dominator_of_uses): Likewise.
15651 (statement_sink_location): Adjust. Support sinking loads.
15652
15653 2014-06-06 Martin Jambor <mjambor@suse.cz>
15654
15655 * ipa-prop.c (get_place_in_agg_contents_list): New function.
15656 (build_agg_jump_func_from_list): Likewise.
15657 (determine_known_aggregate_parts): Renamed to
15658 determine_locally_known_aggregate_parts. Moved some functionality
15659 to the two functions above, removed bound checks.
15660
15661 2014-06-06 James Greenhalgh <james.greenhalgh@arm.com>
15662
15663 * config/aarch64/aarch64-protos.h (aarch64_expand_movmem): New.
15664 * config/aarch64/aarch64.c (aarch64_move_pointer): New.
15665 (aarch64_progress_pointer): Likewise.
15666 (aarch64_copy_one_part_and_move_pointers): Likewise.
15667 (aarch64_expand_movmen): Likewise.
15668 * config/aarch64/aarch64.h (MOVE_RATIO): Set low.
15669 * config/aarch64/aarch64.md (movmem<mode>): New.
15670
15671 2014-06-06 Bingfeng Mei <bmei@broadcom.com>
15672
15673 * targhooks.c (default_add_stmt_cost): Call target specific
15674 hook instead of default one.
15675
15676 2014-06-06 Thomas Preud'homme <thomas.preudhomme@arm.com>
15677
15678 * ChangeLog (2014-05-23): Fix ChangeLog entry to refer to target
15679 endianness instead of host endianness.
15680 * tree-ssa-math-opts.c (find_bswap_or_nop_1): Likewise in dumps and
15681 comments.
15682
15683 2014-06-06 Eric Botcazou <ebotcazou@adacore.com>
15684
15685 PR debug/53927
15686 * function.c (instantiate_decls): Process the saved static chain.
15687 (expand_function_start): If not optimizing, save the static chain
15688 onto the stack.
15689 * tree-nested.c (convert_all_function_calls): Always create the static
15690 chain for nested functions if not optimizing.
15691
15692 2014-06-06 Eric Botcazou <ebotcazou@adacore.com>
15693
15694 * tree-cfg.c (make_edges) <GIMPLE_RETURN>: Put a location on the edge.
15695
15696 2014-06-06 Richard Biener <rguenther@suse.de>
15697
15698 * cfgexpand.c (expand_gimple_cond): Remove check for current_loops.
15699 (construct_init_block): Likewise.
15700 (construct_exit_block): Likewise.
15701 (pass_expand::execute): Likewise.
15702 * graphite.c (graphite_transforms): Replace check for current_loops
15703 with a check for > 1 loops.
15704 (pass_graphite_transforms::execute): Adjust.
15705 * ipa-split.c (split_function): Remove check for current_loops.
15706 * omp-low.c (expand_parallel_call): Likewise.
15707 (expand_omp_for_init_counts): Likewise.
15708 (extract_omp_for_update_vars): Likewise.
15709 (expand_omp_for_generic): Likewise.
15710 (expand_omp_sections): Likewise.
15711 (expand_omp_target): Likewise.
15712 * tracer.c (tail_duplicate): Likewise.
15713 (pass_tracer::execute): Likewise.
15714 * trans-mem.c (expand_transaction): Likewise.
15715 * tree-complex.c (expand_complex_div_wide): Likewise.
15716 * tree-eh.c (lower_resx): Likewise.
15717 (cleanup_empty_eh_merge_phis): Likewise.
15718 * tree-predcom.c (run_tree_predictive_commoning): Replace check for
15719 current_loops with a check for > 1 loops.
15720 (pass_predcom::execute): Adjust.
15721 * tree-scalar-evolution.c (scev_reset): Remove check for current_loops.
15722 * tree-ssa-copy.c (copy_prop_visit_phi_node): Likewise.
15723 * tree-ssa-dom.c (pass_phi_only_cprop::execute): Likewise.
15724 * tree-ssa-tail-merge.c (tail_merge_optimize): Likewise.
15725 * tree-ssa-threadupdate.c (thread_through_all_blocks): Likewise.
15726 * tree-switch-conversion.c (process_switch): Likewise.
15727 * tree-tailcall.c (tree_optimize_tail_calls_1): Likewise.
15728 * tree-vrp.c (vrp_visit_phi_node): Likewise.
15729 (execute_vrp): Likewise.
15730 * ubsan.c (ubsan_expand_null_ifn): Likewise.
15731
15732 2014-06-06 Eric Botcazou <ebotcazou@adacore.com>
15733
15734 * rtl.h (insn_location): Declare.
15735 * cfgcleanup.c (try_forward_edges): Compare the locus of locations
15736 with UNKNOWN_LOCATION.
15737 * emit-rtl.c (insn_location): New function.
15738 * final.c (notice_source_line): Check that the instruction has a
15739 location before retrieving it and use insn_location.
15740 * modulo-sched.c (loop_single_full_bb_p): Likewise.
15741 * print-rtl.c (print_rtx): Likewise.
15742
15743 2014-06-06 Richard Biener <rguenther@suse.de>
15744
15745 * passes.def: Move 2nd VRP pass before phi-only-cprop.
15746
15747 2014-06-06 Christian Bruel <christian.bruel@st.com>
15748
15749 PR tree-optimization/43934
15750 * tree-ssa-loop-im.c (determine_max_movement): Add PHI def constant
15751 cost.
15752
15753 2014-06-06 Richard Sandiford <rdsandiford@googlemail.com>
15754
15755 * ira-lives.c (single_reg_class): Add missing break. Explicitly
15756 return NO_REGS for extra address and memory constraints. Handle
15757 operands that match (or are equivalent to something that matches)
15758 extra constant constraints. Ignore other non-register operands.
15759
15760 2014-06-06 Alan Modra <amodra@gmail.com>
15761
15762 PR target/61300
15763 * doc/tm.texi.in (INCOMING_REG_PARM_STACK_SPACE): Document.
15764 * doc/tm.texi: Regenerate.
15765 * function.c (INCOMING_REG_PARM_STACK_SPACE): Provide default.
15766 Use throughout in place of REG_PARM_STACK_SPACE.
15767 * config/rs6000/rs6000.c (rs6000_reg_parm_stack_space): Add
15768 "incoming" param. Pass to rs6000_function_parms_need_stack.
15769 (rs6000_function_parms_need_stack): Add "incoming" param, ignore
15770 prototype_p when incoming. Use function decl when incoming
15771 to handle K&R style functions.
15772 * config/rs6000/rs6000.h (REG_PARM_STACK_SPACE): Adjust.
15773 (INCOMING_REG_PARM_STACK_SPACE): Define.
15774
15775 2014-06-05 Senthil Kumar Selvaraj <senthil_kumar.selvaraj@atmel.com>
15776
15777 PR target/52472
15778 * cfgexpand.c (expand_debug_expr): Use address space of nested
15779 TREE_TYPE for ADDR_EXPR and MEM_REF.
15780
15781 2014-06-05 Jeff Law <law@redhat.com>
15782
15783 PR tree-optimization/61289
15784 * tree-ssa-threadedge.c (invalidate_equivalences): Remove SRC_MAP and
15785 DST_MAP parameters. Invalidate by walking all the SSA_NAME_VALUES
15786 looking for those which match LHS. All callers changed.
15787 (record_temporary_equivalences_from_phis): Remove SRC_MAP and DST_MAP
15788 parameters and code which manipulated them. All callers changed.
15789 (record_temporary_equivalences_from_stmts_at_dest): Remove SRC_MAP
15790 and DST_MAP parameters. Simplify invalidation code by just calling
15791 invalidate_equivalences. All callers changed.
15792 (thread_across_edge): Simplify now that we don't need to maintain
15793 the map of equivalences to invalidate.
15794
15795 2014-06-05 Kai Tietz <ktietz@redhat.com>
15796 Richard Henderson <rth@redhat.com>
15797
15798 PR target/46219
15799 * config/i386/predicates.md (memory_nox32_operand): Add memory_operand
15800 checking for !TARGET_X32.
15801 * config/i386/i386.md (UNSPEC_PEEPSIB): New unspec constant.
15802 (sibcall_intern): New define_insn, plus required peepholes.
15803 (sibcall_pop_intern): Likewise.
15804 (sibcall_value_intern): Likewise.
15805 (sibcall_value_pop_intern): Likewise.
15806
15807 2014-06-05 Ilya Enkovich <ilya.enkovich@intel.com>
15808
15809 * tree-inline.c (tree_function_versioning): Check DF info existence
15810 before accessing it.
15811
15812 2014-06-05 Marcus Shawcroft <marcus.shawcroft@arm.com>
15813
15814 * config/aarch64/aarch64.h (aarch64_frame): Add hard_fp_offset and
15815 frame_size.
15816 * config/aarch64/aarch64.c (aarch64_layout_frame): Initialize
15817 aarch64_frame hard_fp_offset and frame_size.
15818 (aarch64_expand_prologue): Use aarch64_frame hard_fp_offset and
15819 frame_size; remove original_frame_size.
15820 (aarch64_expand_epilogue, aarch64_final_eh_return_addr): Likewise.
15821 (aarch64_initial_elimination_offset): Remove frame_size and
15822 offset. Use aarch64_frame frame_size.
15823
15824 2014-06-05 Marcus Shawcroft <marcus.shawcroft@arm.com>
15825 Jiong Wang <jiong.wang@arm.com>
15826 Renlin <renlin.li@arm.com>
15827
15828 * config/aarch64/aarch64.c (aarch64_layout_frame): Correct
15829 initialization of R30 offset. Update offset. Iterate core
15830 regisers upto X30. Remove X29, X30 specific code.
15831
15832 2014-06-05 Marcus Shawcroft <marcus.shawcroft@arm.com>
15833 Jiong Wang <jiong.wang@arm.com>
15834
15835 * config/aarch64/aarch64.c (SLOT_NOT_REQUIRED, SLOT_REQUIRED): Define.
15836 (aarch64_layout_frame): Use SLOT_NOT_REQUIRED and SLOT_REQUIRED.
15837 (aarch64_register_saved_on_entry): Adjust test.
15838
15839 2014-06-05 Marcus Shawcroft <marcus.shawcroft@arm.com>
15840
15841 * config/aarch64/aarch64.h (machine_function): Move
15842 saved_varargs_size from here...
15843 (aarch64_frame): ... to here.
15844
15845 * config/aarch64/aarch64.c (aarch64_expand_prologue)
15846 (aarch64_expand_epilogue, aarch64_final_eh_return_addr)
15847 (aarch64_initial_elimination_offset)
15848 (aarch64_setup_incoming_varargs): Adjust location of
15849 saved_varargs_size.
15850
15851 2014-06-05 Marcus Shawcroft <marcus.shawcroft@arm.com>
15852
15853 * config/aarch64/aarch64.c (aarch64_expand_prologue): Update stack
15854 layout comment.
15855
15856 2014-06-05 Jaydeep Patil <Jaydeep.Patil@imgtec.com>
15857 Prachi Godbole <Prachi.Godbole@imgtec.com>
15858
15859 * config/mips/mips-cpus.def: Add definition for p5600. Updated
15860 mips32r5 entry to use PROCESSOR_P5600.
15861 * config/mips/mips-tables.opt: Regenerate.
15862 * config/mips/mips-protos.h (mips_fmadd_bypass): Add prototype.
15863 * config/mips/mips.c (mips_fmadd_bypass): New function.
15864 (mips_rtx_cost_data): Add costs for p5600.
15865 (mips_issue_rate): Add support for p5600.
15866 (mips_multipass_dfa_lookahead): Likewise.
15867 * config/mips/mips.h (TUNE_P5600): New define.
15868 (TUNE_MACC_CHAINS): Add TUNE_P5600.
15869 (MIPS_ISA_LEVEL_SPEC): Map -march=p5600 to -mips32r5.
15870 * config/mips/mips.md: Include p5600.md.
15871 (processor): Add p5600.
15872 * config/mips/p5600.md: New file.
15873
15874 2014-06-05 Evgeny Stupachenko <evstupac@gmail.com>
15875
15876 * config/i386/sse.md (*ssse3_palignr<mode>_perm): New.
15877 * config/i386/predicates.md (palignr_operand): New.
15878 Indicates if permutation is suitable for palignr instruction.
15879
15880 2014-06-05 Yuri Rumyantsev <ysrumyan@gmail.com>
15881
15882 PR tree-optimization/61319
15883 * tree-if-conv.c (is_cond_scalar_reduction): Add missed check that
15884 stmt belongs to loop.
15885
15886 2014-06-05 Richard Biener <rguenther@suse.de>
15887
15888 * gimplify.c (create_tmp_from_val): Remove is_formal parameter
15889 and set DECL_GIMPLE_REG_P unconditionally if appropriate.
15890 (lookup_tmp_var): Adjust.
15891 (prepare_gimple_addressable): Unset DECL_GIMPLE_REG_P here.
15892
15893 2014-06-05 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
15894
15895 * config/arm/arm.md (enabled): Disable opt_enabled attribute.
15896
15897 2014-06-05 Marek Polacek <polacek@redhat.com>
15898
15899 PR c/49706
15900 * doc/invoke.texi: Document -Wlogical-not-parentheses.
15901
15902 2014-06-04 Tom de Vries <tom@codesourcery.com>
15903
15904 * config/s390/s390.md ("addptrdi3", "addptrsi3"): Use INTVAL only on
15905 CONST_INT.
15906
15907 2014-06-04 Marc Glisse <marc.glisse@inria.fr>
15908
15909 PR tree-optimization/61385
15910 * tree-ssa-phiopt.c (value_replacement): Punt if there are PHI nodes.
15911
15912 2014-06-04 Bernd Schmidt <bernds@codesourcery.com>
15913
15914 * lto-wrapper.c (fatal, fatal_perror): Remove functions. All callers
15915 changed to use fatal_error.
15916 (main): Ensure lto_wrapper_cleanup is run atexit.
15917
15918 2014-06-04 Richard Sandiford <rdsandiford@googlemail.com>
15919
15920 * lra-constraints.c (valid_address_p): Move earlier in file.
15921 (address_eliminator): New structure.
15922 (satisfies_memory_constraint_p): New function.
15923 (satisfies_address_constraint_p): Likewise.
15924 (process_alt_operands, process_address, curr_insn_transform): Use them.
15925
15926 2014-06-04 Richard Sandiford <rdsandiford@googlemail.com>
15927
15928 * lra-int.h (lra_static_insn_data): Make operand_alternative a
15929 const pointer.
15930 (target_lra_int, default_target_lra_int, this_target_lra_int)
15931 (op_alt_data): Delete.
15932 * lra.h (lra_init): Delete.
15933 * lra.c (default_target_lra_int, this_target_lra_int): Delete.
15934 (init_insn_code_data_once): Remove op_alt_data handling.
15935 (finish_insn_code_data_once): Likewise.
15936 (init_op_alt_data): Delete.
15937 (get_static_insn_data): Initialize operand_alternative to null.
15938 (free_insn_recog_data): Cast operand_alternative before freeing it.
15939 (setup_operand_alternative): Take the operand_alternative as
15940 parameter and assume it isn't already cached in the static
15941 insn data.
15942 (lra_set_insn_recog_data): Update accordingly.
15943 (lra_init): Delete.
15944 * ira.c (ira_init): Don't call lra_init.
15945 * target-globals.h (this_target_lra_int): Declare.
15946 (target_globals): Remove lra_int.
15947 (restore_target_globals): Update accordingly.
15948 * target-globals.c: Don't include lra-int.h.
15949 (default_target_globals, save_target_globals): Remove lra_int.
15950
15951 2014-06-04 Richard Sandiford <rdsandiford@googlemail.com>
15952
15953 * recog.h (operand_alternative): Convert reg_class, reject,
15954 matched and matches into bitfields.
15955 (preprocess_constraints): New overload.
15956 (preprocess_insn_constraints): New function.
15957 (preprocess_constraints): Take the insn as parameter.
15958 (recog_op_alt): Change into a pointer.
15959 (target_recog): Add x_op_alt.
15960 * recog.c (asm_op_alt): New variable.
15961 (recog_op_alt): Change into a pointer.
15962 (preprocess_constraints): New overload, replacing the old function
15963 definition with one that doesn't use global state.
15964 (preprocess_insn_constraints): New function.
15965 (preprocess_constraints): Use them. Take the insn as parameter.
15966 Use asm_op_alt for asms.
15967 (recog_init): Free existing x_op_alt entries.
15968 * ira-lives.c (check_and_make_def_conflict): Make operand_alternative
15969 pointer const.
15970 (make_early_clobber_and_input_conflicts): Likewise.
15971 (process_bb_node_lives): Pass the insn to process_constraints.
15972 * reg-stack.c (check_asm_stack_operands): Likewise.
15973 (subst_asm_stack_regs): Likewise.
15974 * regcprop.c (copyprop_hardreg_forward_1): Likewise.
15975 * regrename.c (build_def_use): Likewise.
15976 * sched-deps.c (sched_analyze_insn): Likewise.
15977 * sel-sched.c (get_reg_class, implicit_clobber_conflict_p): Likewise.
15978 * config/arm/arm.c (xscale_sched_adjust_cost): Likewise.
15979 (note_invalid_constants): Likewise.
15980 * config/i386/i386.c (ix86_legitimate_combined_insn): Likewise.
15981 (ix86_legitimate_combined_insn): Make operand_alternative pointer
15982 const.
15983
15984 2014-06-04 Richard Sandiford <rdsandiford@googlemail.com>
15985
15986 * recog.c (preprocess_constraints): Don't skip disabled alternatives.
15987 * ira-lives.c (check_and_make_def_conflict): Check for disabled
15988 alternatives.
15989 (make_early_clobber_and_input_conflicts): Likewise.
15990 * config/i386/i386.c (ix86_legitimate_combined_insn): Likewise.
15991
15992 2014-06-04 Richard Sandiford <rdsandiford@googlemail.com>
15993
15994 * recog.h (alternative_class): New function.
15995 (which_op_alt): Return a const recog_op_alt.
15996 * reg-stack.c (check_asm_stack_operands): Update type accordingly.
15997 (subst_asm_stack_regs): Likewise.
15998 * config/arm/arm.c (note_invalid_constants): Likewise.
15999 * regcprop.c (copyprop_hardreg_forward_1): Likewise. Don't modify
16000 the operand_alternative; use alternative class instead.
16001 * sel-sched.c (get_reg_class): Likewise.
16002 * regrename.c (build_def_use): Likewise.
16003 (hide_operands, restore_operands, record_out_operands): Update type
16004 accordingly.
16005
16006 2014-06-04 Richard Sandiford <rdsandiford@googlemail.com>
16007
16008 * recog.h (recog_op_alt): Convert to a flat array.
16009 (which_op_alt): New function.
16010 * recog.c (recog_op_alt): Convert to a flat array.
16011 (preprocess_constraints): Update accordingly, grouping all
16012 operands of the same alternative together, rather than the
16013 other way around.
16014 * ira-lives.c (check_and_make_def_conflict): Likewise.
16015 (make_early_clobber_and_input_conflicts): Likewise.
16016 * config/i386/i386.c (ix86_legitimate_combined_insn): Likewise.
16017 * reg-stack.c (check_asm_stack_operands): Use which_op_alt.
16018 (subst_asm_stack_regs): Likewise.
16019 * regcprop.c (copyprop_hardreg_forward_1): Likewise.
16020 * regrename.c (hide_operands, record_out_operands): Likewise.
16021 (build_def_use): Likewise.
16022 * sel-sched.c (get_reg_class): Likewise.
16023 * config/arm/arm.c (note_invalid_constants): Likewise.
16024
16025 2014-06-04 Jason Merrill <jason@redhat.com>
16026
16027 PR c++/51253
16028 PR c++/61382
16029 * gimplify.c (gimplify_arg): Non-static.
16030 * gimplify.h: Declare it.
16031
16032 2014-06-04 Richard Biener <rguenther@suse.de>
16033
16034 * tree.h (may_be_aliased): Trust TREE_ADDRESSABLE from
16035 TREE_PUBLIC and DECL_EXTERNAL decls.
16036
16037 2014-06-04 Matthew Fortune <matthew.fortune@imgtec.com>
16038
16039 * regcprop.c (copyprop_hardreg_forward_1): Account for
16040 HARD_REGNO_CALL_PART_CLOBBERED.
16041
16042 2014-06-04 Richard Biener <rguenther@suse.de>
16043
16044 * configure.ac: Check whether the underlying type of int64_t
16045 is long or long long.
16046 * configure: Regenerate.
16047 * config.in: Likewise.
16048 * hwint.h (HOST_WIDE_INT): Match the underlying type of int64_t.
16049 (HOST_WIDE_INT_PRINT_*): Define in terms of PRI*64.
16050
16051 2014-06-04 Richard Biener <rguenther@suse.de>
16052
16053 PR tree-optimization/60098
16054 * tree-ssa-dse.c (dse_possible_dead_store_p): Walk until
16055 we hit a kill.
16056 (dse_optimize_stmt): Simplify, now that we found a kill
16057 earlier.
16058
16059 2014-06-04 Richard Biener <rguenther@suse.de>
16060
16061 * tree-ssa-alias.c (stmt_may_clobber_ref_p): Improve handling
16062 of accesses with non-invariant address.
16063
16064 2014-06-04 Martin Liska <mliska@suse.cz>
16065
16066 * cgraph.h (cgraph_make_wrapper): New function introduced.
16067 * cgraphunit.c (cgraph_make_wrapper): The function implementation.
16068 * ipa-inline.h (inline_analyze_function): The function is global.
16069 * ipa-inline-analysis.c (inline_analyze_function): Likewise.
16070
16071 2014-06-04 Martin Liska <mliska@suse.cz>
16072
16073 * tree.h (private_lookup_attribute_starting): New function.
16074 (lookup_attribute_starting): Likewise.
16075 * tree.c (private_lookup_attribute_starting): Likewise.
16076
16077 2014-06-04 Martin Liska <mliska@suse.cz>
16078
16079 * cgraph.h (expand_thunk): New argument added.
16080 (address_taken_from_non_vtable_p): New global function.
16081 * ipa-visibility.c (address_taken_from_non_vtable_p): Likewise.
16082 * cgraphclones.c (duplicate_thunk_for_node): Argument added to call.
16083 * cgraphunit.c (analyze_function): Likewise.
16084 (assemble_thunks_and_aliases): Argument added to call.
16085 (expand_thunk): New argument forces to produce GIMPLE thunk.
16086
16087 2014-06-04 Martin Liska <mliska@suse.cz>
16088
16089 * coverage.h (coverage_compute_cfg_checksum): Argument added.
16090 * coverage.c (coverage_compute_cfg_checksum): Likewise.
16091 * profile.c (branch_prob): Likewise.
16092
16093 2014-06-04 Martin Jambor <mjambor@suse.cz>
16094
16095 PR ipa/61340
16096 * ipa-pure-const.c (propagate_pure_const): Add unreachable default
16097 handler for switch on an ipa_ref_use enum.
16098 * ipa-reference.c (analyze_function): Likewise.
16099
16100 2014-06-04 Kai Tietz <ktietz@redhat.com>
16101
16102 * recog.c (peep2_attempt): Copy SIBLING_CALL_P flag
16103 from old call-instruction.
16104
16105 2014-06-04 Bin Cheng <bin.cheng@arm.com>
16106
16107 * config/aarch64/aarch64.c (aarch64_classify_address)
16108 (aarch64_legitimize_reload_address): Support full addressing modes
16109 for vector modes.
16110 * config/aarch64/aarch64.md (mov<mode>, movmisalign<mode>)
16111 (*aarch64_simd_mov<mode>, *aarch64_simd_mov<mode>): Relax predicates.
16112
16113 2014-06-03 Andrew Pinski <apinski@cavium.com>
16114
16115 * config/aarch64/aarch64.c (aarch64_if_then_else_costs): Allow non comparisons
16116 for OP0.
16117
16118 2014-06-03 Andrew Pinski <apinski@cavium.com>
16119
16120 * config/aarch64/aarch64.c (aarch64_if_then_else_costs): New function.
16121 (aarch64_rtx_costs): Use aarch64_if_then_else_costs.
16122
16123 2014-06-03 Kai Tietz <ktietz@redhat.com>
16124
16125 * config/i386/i386.c (ix86_function_value_regno_p): Disallow DX_REG
16126 for 64-bit ms-abi.
16127
16128 2014-06-03 Dehao Chen <dehao@google.com>
16129
16130 * tree-cfg.c (gimple_merge_blocks): Only reset count when BBs are in
16131 the same loop.
16132
16133 2014-06-03 Marek Polacek <polacek@redhat.com>
16134
16135 PR c/60439
16136 * doc/invoke.texi: Document -Wswitch-bool.
16137 * function.c (stack_protect_epilogue): Cast controlling expression of
16138 the switch to int.
16139 * gengtype.c (walk_type): Generate switch expression with its
16140 controlling expression cast to int.
16141
16142 2014-06-03 Vishnu K S <Vishnu.k_s@atmel.com>
16143
16144 * config/avr/avr-mcus.def: Add new avr25 devices attiny441, attiny828
16145 and attiny841.
16146 * config/avr/avr-tables.opt: Regenerate.
16147 * config/avr/t-multilib: Regenerate.
16148 * doc/avr-mmcu.texi: Regenerate.
16149
16150 2014-06-03 Vishnu K S <vishnu.k_s@atmel.com>
16151 Pitchumani Sivanupandi <pitchumani.s@atmel.com>
16152
16153 * config/avr/avr-mcus.def (ata6616c): Add new avr25 device.
16154 (ata6617c, ata664251): Add new avr35 devices.
16155 (ata6612c): Add new avr4 device.
16156 (ata6613c, ata6614q): Add new avr5 devices.
16157 * config/avr/avr-tables.opt: Regenerate.
16158 * config/avr/t-multilib: Regenerate.
16159 * doc/avr-mmcu.texi: Regenerate.
16160
16161 2014-06-03 Alan Lawrence <alan.lawrence@arm.com>
16162
16163 * gcc/config/aarch64/aarch64-builtins.c
16164 (aarch64_types_binop_ssu_qualifiers): New static data.
16165 (TYPES_BINOP_SSU): Define.
16166 * gcc/config/aarch64/aarch64-simd-builtins.def (suqadd, ushl, urshl,
16167 urshr_n, ushll_n): Use appropriate unsigned qualifiers.
16168 * gcc/config/aarch64/arm_neon.h (vrshl_u8, vrshl_u16, vrshl_u32,
16169 vrshl_u64, vrshlq_u8, vrshlq_u16, vrshlq_u32, vrshlq_u64, vrshld_u64,
16170 vrshr_n_u8, vrshr_n_u16, vrshr_n_u32, vrshr_n_u64, vrshrq_n_u8,
16171 vrshrq_n_u16, vrshrq_n_u32, vrshrq_n_u64, vrshrd_n_u64, vshll_n_u8,
16172 vshll_n_u16, vshll_n_u32, vuqadd_s8, vuqadd_s16, vuqadd_s32,
16173 vuqadd_s64, vuqaddq_s8, vuqaddq_s16, vuqaddq_s32, vuqaddq_s64,
16174 vuqaddb_s8, vuqaddh_s16, vuqadds_s32, vuqaddd_s64): Add signedness
16175 suffix to builtin function name, remove cast.
16176 (vshl_s8, vshl_s16, vshl_s32, vshl_s64, vshl_u8, vshl_u16, vshl_u32,
16177 vshl_u64, vshlq_s8, vshlq_s16, vshlq_s32, vshlq_s64, vshlq_u8,
16178 vshlq_u16, vshlq_u32, vshlq_u64, vshld_s64, vshld_u64): Remove cast.
16179
16180 2014-06-03 Alan Lawrence <alan.lawrence@arm.com>
16181
16182 * gcc/config/aarch64/aarch64-builtins.c
16183 (aarch64_types_binop_uus_qualifiers,
16184 aarch64_types_shift_to_unsigned_qualifiers,
16185 aarch64_types_unsigned_shiftacc_qualifiers): Define.
16186 * gcc/config/aarch64/aarch64-simd-builtins.def (uqshl, uqrshl, uqadd,
16187 uqsub, usqadd, usra_n, ursra_n, uqshrn_n, uqrshrn_n, usri_n, usli_n,
16188 sqshlu_n, uqshl_n): Update qualifiers.
16189 * gcc/config/aarch64/arm_neon.h (vqadd_u8, vqadd_u16, vqadd_u32,
16190 vqadd_u64, vqaddq_u8, vqaddq_u16, vqaddq_u32, vqaddq_u64, vqsub_u8,
16191 vqsub_u16, vqsub_u32, vqsub_u64, vqsubq_u8, vqsubq_u16, vqsubq_u32,
16192 vqsubq_u64, vqaddb_u8, vqaddh_u16, vqadds_u32, vqaddd_u64, vqrshl_u8,
16193 vqrshl_u16, vqrshl_u32, vqrshl_u64, vqrshlq_u8, vqrshlq_u16,
16194 vqrshlq_u32, vqrshlq_u64, vqrshlb_u8, vqrshlh_u16, vqrshls_u32,
16195 vqrshld_u64, vqrshrn_n_u16, vqrshrn_n_u32, vqrshrn_n_u64,
16196 vqrshrnh_n_u16, vqrshrns_n_u32, vqrshrnd_n_u64, vqshl_u8, vqshl_u16,
16197 vqshl_u32, vqshl_u64, vqshlq_u8, vqshlq_u16, vqshlq_u32, vqshlq_u64,
16198 vqshlb_u8, vqshlh_u16, vqshls_u32, vqshld_u64, vqshl_n_u8, vqshl_n_u16,
16199 vqshl_n_u32, vqshl_n_u64, vqshlq_n_u8, vqshlq_n_u16, vqshlq_n_u32,
16200 vqshlq_n_u64, vqshlb_n_u8, vqshlh_n_u16, vqshls_n_u32, vqshld_n_u64,
16201 vqshlu_n_s8, vqshlu_n_s16, vqshlu_n_s32, vqshlu_n_s64, vqshluq_n_s8,
16202 vqshluq_n_s16, vqshluq_n_s32, vqshluq_n_s64, vqshlub_n_s8,
16203 vqshluh_n_s16, vqshlus_n_s32, vqshlud_n_s64, vqshrn_n_u16,
16204 vqshrn_n_u32, vqshrn_n_u64, vqshrnh_n_u16, vqshrns_n_u32,
16205 vqshrnd_n_u64, vqsubb_u8, vqsubh_u16, vqsubs_u32, vqsubd_u64,
16206 vrsra_n_u8, vrsra_n_u16, vrsra_n_u32, vrsra_n_u64, vrsraq_n_u8,
16207 vrsraq_n_u16, vrsraq_n_u32, vrsraq_n_u64, vrsrad_n_u64, vsli_n_u8,
16208 vsli_n_u16, vsli_n_u32,vsli_n_u64, vsliq_n_u8, vsliq_n_u16,
16209 vsliq_n_u32, vsliq_n_u64, vslid_n_u64, vsqadd_u8, vsqadd_u16,
16210 vsqadd_u32, vsqadd_u64, vsqaddq_u8, vsqaddq_u16, vsqaddq_u32,
16211 vsqaddq_u64, vsqaddb_u8, vsqaddh_u16, vsqadds_u32, vsqaddd_u64,
16212 vsra_n_u8, vsra_n_u16, vsra_n_u32, vsra_n_u64, vsraq_n_u8,
16213 vsraq_n_u16, vsraq_n_u32, vsraq_n_u64, vsrad_n_u64, vsri_n_u8,
16214 vsri_n_u16, vsri_n_u32, vsri_n_u64, vsriq_n_u8, vsriq_n_u16,
16215 vsriq_n_u32, vsriq_n_u64, vsrid_n_u64): Remove casts.
16216
16217 2014-06-03 Teresa Johnson <tejohnson@google.com>
16218
16219 * tree-sra.c (modify_function): Record caller nodes after rebuild.
16220
16221 2014-06-02 Jason Merrill <jason@redhat.com>
16222
16223 PR c++/61020
16224 * varpool.c (ctor_for_folding): Handle uninitialized vtables.
16225
16226 2014-06-03 Alan Lawrence <alan.lawrence@arm.com>
16227
16228 * config/aarch64/aarch64.c (aarch64_evpc_ext): allow and handle
16229 location == 0.
16230
16231 2014-06-03 Alan Lawrence <alan.lawrence@arm.com>
16232
16233 * config/aarch64/aarch64-simd.md (aarch64_rev<REVERSE:rev-op><mode>):
16234 New pattern.
16235 * config/aarch64/aarch64.c (aarch64_evpc_rev): New function.
16236 (aarch64_expand_vec_perm_const_1): Add call to aarch64_evpc_rev.
16237 * config/aarch64/iterators.md (REVERSE): New iterator.
16238 (UNSPEC_REV64, UNSPEC_REV32, UNSPEC_REV16): New enum elements.
16239 (rev_op): New int_attribute.
16240 * config/aarch64/arm_neon.h (vrev16_p8, vrev16_s8, vrev16_u8,
16241 vrev16q_p8, vrev16q_s8, vrev16q_u8, vrev32_p8, vrev32_p16, vrev32_s8,
16242 vrev32_s16, vrev32_u8, vrev32_u16, vrev32q_p8, vrev32q_p16, vrev32q_s8,
16243 vrev32q_s16, vrev32q_u8, vrev32q_u16, vrev64_f32, vrev64_p8,
16244 vrev64_p16, vrev64_s8, vrev64_s16, vrev64_s32, vrev64_u8, vrev64_u16,
16245 vrev64_u32, vrev64q_f32, vrev64q_p8, vrev64q_p16, vrev64q_s8,
16246 vrev64q_s16, vrev64q_s32, vrev64q_u8, vrev64q_u16, vrev64q_u32):
16247 Replace temporary __asm__ with __builtin_shuffle.
16248
16249 2014-06-03 Andrew Bennett <andrew.bennett@imgtec.com>
16250
16251 * config/mips/mips-cpus.def: Add mips32r3, mips32r5, mips64r3 and
16252 mips64r5.
16253 * config/mips/mips-tables.opt: Regenerate.
16254 * config/mips/mips.c (mips_compute_frame_info): Changed if statement
16255 to use mips_isa_rev rather than ISA_MIPS32R2.
16256 * config/mips/mips.h (ISA_MIPS32R3): New define.
16257 (ISA_MIPS32R5): New define.
16258 (ISA_MIPS64R3): New define.
16259 (ISA_MIPS64R5): New define.
16260 (TARGET_CPU_CPP_BUILTINS): Added support for ISA_MIPS32R3,
16261 ISA_MIPS32R5, ISA_MIPS64R3 and ISA_MIPS64R5.
16262 (MIPS_ISA_LEVEL_SPEC): Added support for mips32r3, mips32r5, mips64r3
16263 and mips64r5.
16264 (MIPS_ISA_SYNCI_SPEC): Likewise.
16265 (ISA_HAS_64BIT_REGS): Added ISA_MIPS64R3 and ISA_MIPS64R5.
16266 (LINK_SPEC): Added mips32r3 and mips32r5.
16267 * config/mips/t-isa3264 (MULTILIB_MATCHES): Map mips32r3 and mips32r5
16268 to mips32r2; and mips64r3 and mips64r5 to mips64r2.
16269 * config/mips/t-mti-elf (MULTILIB_MATCHES): Likewise.
16270 * config/mips/t-mti-linux (MULTILIB_MATCHES): Likewise.
16271 * config/mips/t-sde (MULTILIB_MATCHES): Likewise.
16272 * config/mips/t-sdemtk (MULTILIB_MATCHES): New define.
16273 * doc/invoke.texi: Document mips32r3, mips32r5, mips64r3 and mips64r5.
16274
16275 2014-06-03 Andrew Bennett <andrew.bennett@imgtec.com>
16276
16277 * doc/invoke.texi: Document -mxpa and -mno-xpa MIPS command line
16278 options.
16279 * config/mips/mips.opt (mxpa): New option.
16280 * config/mips/mips.h (ASM_SPEC): Pass mxpa and mno-xpa to the
16281 assembler.
16282
16283 2014-06-03 Martin Jambor <mjambor@suse.cz>
16284
16285 PR ipa/61160
16286 * ipa-cp.c (cgraph_edge_brings_value_p): Handle edges leading to
16287 thunks.
16288
16289 2014-06-03 Thomas Preud'homme <thomas.preudhomme@arm.com>
16290
16291 PR tree-optimization/61328
16292 * tree-ssa-math-opts.c (init_symbolic_number): Extract symbolic number
16293 initialization from find_bswap_or_nop_1.
16294 (find_bswap_or_nop_1): Test return value of find_bswap_or_nop_1 stored
16295 in source_expr2 before using the size value the function sets. Also
16296 make use of init_symbolic_number () in both the old place and
16297 find_bswap_or_nop_load () to avoid reading uninitialized memory when
16298 doing recursion in the GIMPLE_BINARY_RHS case.
16299
16300 2014-06-03 Richard Biener <rguenther@suse.de>
16301
16302 PR tree-optimization/61383
16303 * tree-ssa-ifcombine.c (bb_no_side_effects_p): Make sure
16304 stmts can't trap.
16305
16306 2014-06-03 Richard Sandiford <rdsandiford@googlemail.com>
16307
16308 * defaults.h (USE_MD_CONSTRAINTS, EXTRA_MEMORY_CONSTRAINT)
16309 (EXTRA_ADDRESS_CONSTRAINT, DEFAULT_CONSTRAINT_LEN, CONSTRAINT_LEN)
16310 (CONST_OK_FOR_CONSTRAINT_P, CONST_DOUBLE_OK_FOR_LETTER_P)
16311 (REG_CLASS_FROM_CONSTRAINT, EXTRA_CONSTRAINT_STR): Delete definitions
16312 in this file.
16313 (REG_CLASS_FROM_LETTER, CONST_OK_FOR_LETTER_P)
16314 (CONST_DOUBLE_OK_FOR_LETTER_P, EXTRA_CONSTRAINT): Move poising to...
16315 * system.h: ...here and make it unconditional.
16316 * target.def (conditional_register_usage): Mention
16317 define_register_constraint instead of old-style constraint macros.
16318 * doc/tm.texi.in: Remove documentation for old-style constraint macros.
16319 * doc/tm.texi: Regenerate.
16320 * genoutput.c: Remove USE_MD_CONSTRAINTS conditions and all code
16321 protected by !USE_MD_CONSTRAINTS.
16322 * config/frv/frv.md: Remove quote from old version of documentation.
16323 * config/frv/frv.c (frv_conditional_register_usage): Likewise.
16324 * config/m32r/m32r.c (easy_di_const, easy_df_const): Avoid mentioning
16325 CONST_DOUBLE_OK_FOR_LETTER.
16326 * config/sh/constraints.md: Likewise EXTRA_CONSTRAINT.
16327
16328 2014-06-02 Andrew Pinski <apinski@cavium.com>
16329
16330 * config/aarch64/aarch64-linux.h (GLIBC_DYNAMIC_LINKER):
16331 /lib/ld-linux32-aarch64.so.1 is used for ILP32.
16332 (LINUX_TARGET_LINK_SPEC): Update linker script for ILP32.
16333 file whose name depends on -mabi= and -mbig-endian.
16334 * config/aarch64/t-aarch64-linux (MULTILIB_OSDIRNAMES):
16335 Handle LP64 better and handle ilp32 too.
16336 (MULTILIB_OPTIONS): Delete.
16337 (MULTILIB_DIRNAMES): Delete.
16338
16339 2014-06-02 Andrew MacLeod <amacleod@redhat.com>
16340
16341 * expr.h: Remove prototypes of functions defined in builtins.c.
16342 * tree.h: (build_call_expr_*, build_string_literal): Add prototypes.
16343 Remove prototypes of functions defined in builtins.c.
16344 * builtins.h: Update prototype list to include all exported functions.
16345 * builtins.c: (default_libc_has_function, gnu_libc_has_function,
16346 no_c99_libc_has_function): Move to targhooks.c
16347 (build_string_literal, build_call_expr_loc_array,
16348 build_call_expr_loc_vec, build_call_expr_loc, build_call_expr): Move
16349 to tree.c.
16350 (expand_builtin_object_size, fold_builtin_object_size): Make static.
16351 * targhooks.c (default_libc_has_function, gnu_libc_has_function,
16352 no_c99_libc_has_function): Relocate from builtins.c.
16353 * tree.c: Include builtins.h.
16354 (build_call_expr_loc_array, build_call_expr_loc_vec,
16355 build_call_expr_loc, build_call_expr, build_string_literal): Relocate
16356 from builtins.c.
16357 * fold-const.h (fold_fma): Move prototype to builtins.h.
16358 * realmpfr.h (do_mpc_arg2): Move prototype to builtins.h.
16359 * asan.c: Include builtins.h.
16360 * cfgexpand.c: Likewise.
16361 * convert.c: Likewise.
16362 * emit-rtl.c: Likewise.
16363 * except.c: Likewise.
16364 * expr.c: Likewise.
16365 * fold-const.c: Likewise.
16366 * gimple-fold.c: Likewise.
16367 * gimple-ssa-strength-reduction.c: Likewise.
16368 * gimplify.c: Likewise.
16369 * ipa-inline.c: Likewise.
16370 * ipa-prop.c: Likewise.
16371 * lto-streamer-out.c: Likewise.
16372 * stmt.c: Likewise.
16373 * tree-inline.c: Likewise.
16374 * tree-object-size.c: Likewise.
16375 * tree-sra.c: Likewise.
16376 * tree-ssa-ccp.c: Likewise.
16377 * tree-ssa-forwprop.c: Likewise.
16378 * tree-ssa-loop-ivcanon.c: Likewise.
16379 * tree-ssa-loop-ivopts.c: Likewise.
16380 * tree-ssa-math-opts.c: Likewise.
16381 * tree-ssa-reassoc.c: Likewise.
16382 * tree-ssa-threadedge.c: Likewise.
16383 * tree-streamer-in.c: Likewise.
16384 * tree-vect-data-refs.c: Likewise.
16385 * tree-vect-patterns.c: Likewise.
16386 * tree-vect-stmts.c: Likewise.
16387 * config/aarch64/aarch64.c: Likewise.
16388 * config/alpha/alpha.c: Likewise.
16389 * config/arc/arc.c: Likewise.
16390 * config/arm/arm.c: Likewise.
16391 * config/avr/avr.c: Likewise.
16392 * config/bfin/bfin.c: Likewise.
16393 * config/c6x/c6x.c: Likewise.
16394 * config/cr16/cr16.c: Likewise.
16395 * config/cris/cris.c: Likewise.
16396 * config/epiphany/epiphany.c: Likewise.
16397 * config/fr30/fr30.c: Likewise.
16398 * config/frv/frv.c: Likewise.
16399 * config/h8300/h8300.c: Likewise.
16400 * config/i386/i386.c: Likewise.
16401 * config/i386/winnt.c: Likewise.
16402 * config/ia64/ia64.c: Likewise.
16403 * config/iq2000/iq2000.c: Likewise.
16404 * config/lm32/lm32.c: Likewise.
16405 * config/m32c/m32c.c: Likewise.
16406 * config/m32r/m32r.c: Likewise.
16407 * config/m68k/m68k.c: Likewise.
16408 * config/mcore/mcore.c: Likewise.
16409 * config/mep/mep.c: Likewise.
16410 * config/microblaze/microblaze.c: Likewise.
16411 * config/mips/mips.c: Likewise.
16412 * config/mmix/mmix.c: Likewise.
16413 * config/mn10300/mn10300.c: Likewise.
16414 * config/moxie/moxie.c: Likewise.
16415 * config/msp430/msp430.c: Likewise.
16416 * config/nds32/nds32.c: Likewise.
16417 * config/pa/pa.c: Likewise.
16418 * config/pdp11/pdp11.c: Likewise.
16419 * config/picochip/picochip.c: Likewise.
16420 * config/rl78/rl78.c: Likewise.
16421 * config/rs6000/rs6000.c: Likewise.
16422 * config/rx/rx.c: Likewise.
16423 * config/s390/s390.c: Likewise.
16424 * config/score/score.c: Likewise.
16425 * config/sh/sh.c: Likewise.
16426 * config/sparc/sparc.c: Likewise.
16427 * config/spu/spu.c: Likewise.
16428 * config/stormy16/stormy16.c: Likewise.
16429 * config/tilegx/tilegx.c: Likewise.
16430 * config/tilepro/tilepro.c: Likewise.
16431 * config/v850/v850.c: Likewise.
16432 * config/vax/vax.c: Likewise.
16433 * config/xtensa/xtensa.c: Likewise.
16434
16435 2014-06-02 Jeff Law <law@redhat.com>
16436
16437 PR rtl-optimization/61094
16438 * ree.c (combine_reaching_defs): Do not reextend an insn if it
16439 was marked as do_no_reextend. If a copy is needed to eliminate
16440 an extension, then mark it as do_not_reextend.
16441
16442 2014-06-02 Marcus Shawcroft <marcus.shawcroft@arm.com>
16443
16444 * config/aarch64/aarch64.md (set_fpcr): Drop ISB after FPCR write.
16445
16446 2014-06-02 Richard Henderson <rth@redhat.com>
16447
16448 PR target/61336
16449 * config/alpha/alpha.c (print_operand_address): Allow symbolic
16450 addresses inside asms. Use output_operand_lossage instead of
16451 gcc_unreachable.
16452
16453 2014-06-02 Uros Bizjak <ubizjak@gmail.com>
16454
16455 PR target/61239
16456 * config/i386/i386.c (ix86_expand_vec_perm) [case V32QImode]: Use
16457 GEN_INT (-128) instead of GEN_INT (128) to set MSB of QImode constant.
16458
16459 2014-06-02 Tom de Vries <tom@codesourcery.com>
16460
16461 * config/aarch64/aarch64.c (aarch64_float_const_representable_p): Handle
16462 case that x has VOIDmode.
16463
16464 2014-06-02 Bernd Schmidt <bernds@codesourcery.com>
16465
16466 * varasm.c (copy_constant): Delete function.
16467 (build_constant_desc): Don't call it.
16468
16469 2014-06-02 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
16470
16471 PR target/61154
16472 * config/arm/arm.h (TARGET_SUPPORTS_WIDE_INT): Define.
16473 * config/arm/arm.md (mov64 splitter): Replace const_double_operand
16474 with immediate_operand.
16475
16476 2014-06-02 Andreas Schwab <schwab@suse.de>
16477
16478 * config/ia64/ia64.c
16479 (ia64_first_cycle_multipass_dfa_lookahead_guard): Check
16480 pending_data_specs first.
16481
16482 2014-06-02 Richard Biener <rguenther@suse.de>
16483
16484 PR tree-optimization/61378
16485 * tree-ssa-sccvn.c (vn_reference_lookup_3): Initialize
16486 valueized_anything.
16487
16488 2014-06-01 Uros Bizjak <ubizjak@gmail.com>
16489
16490 * config/i386/constraints.md (Bw): Rename from 'w'.
16491 (Bz): Rename from 'z'.
16492 * config/i386/i386.md: Change 'w' to 'Bw' and 'z' to 'Bz' globally.
16493
16494 2014-06-01 Kai Tietz <ktietz@redhat.com>
16495
16496 PR target/61377
16497 * config/i386/constrains.md (define_constrain): New 'Bs' constraint.
16498 * config/i386/i386.md (sibcall_insn_operand): Use Bs
16499 instead of m constraint.
16500
16501 2014-05-31 Andreas Schwab <schwab@linux-m68k.org>
16502
16503 * config/m68k/m68k.md (beq0_di, bne0_di): Make the "o" constraint
16504 a separate alternative where the scratch operand 2 is marked as
16505 early clobber.
16506
16507 2014-05-31 Kugan Vivekanandarajah <kuganv@linaro.org>
16508
16509 * config/arm/arm.c (TARGET_ATOMIC_ASSIGN_EXPAND_FENV): New define.
16510 (arm_builtins) : Add ARM_BUILTIN_GET_FPSCR and ARM_BUILTIN_SET_FPSCR.
16511 (bdesc_2arg) : Add description for builtins __builtins_arm_set_fpscr
16512 and __builtins_arm_get_fpscr.
16513 (arm_init_builtins) : Initialize builtins __builtins_arm_set_fpscr and
16514 __builtins_arm_get_fpscr.
16515 (arm_expand_builtin) : Expand builtins __builtins_arm_set_fpscr and
16516 __builtins_arm_ldfpscr.
16517 (arm_atomic_assign_expand_fenv): New function.
16518 * config/arm/vfp.md (set_fpscr): New pattern.
16519 (get_fpscr) : Likewise.
16520 * config/arm/unspecs.md (unspecv): Add VUNSPEC_GET_FPSCR and
16521 VUNSPEC_SET_FPSCR.
16522 * doc/extend.texi (AARCH64 Built-in Functions) : Document
16523 __builtins_arm_set_fpscr, __builtins_arm_get_fpscr.
16524
16525 2014-05-30 Jakub Jelinek <jakub@redhat.com>
16526
16527 * asan.c (report_error_func): Add SLOW_P argument, use
16528 BUILT_IN_ASAN_*_N if set.
16529 (build_check_stmt): Likewise.
16530 (instrument_derefs): If T has insufficient alignment,
16531 force same handling as for odd sizes.
16532
16533 * sanitizer.def (BUILT_IN_ASAN_REPORT_LOAD_N,
16534 BUILT_IN_ASAN_REPORT_STORE_N): New.
16535 * asan.c (struct asan_mem_ref): Change access_size type to
16536 HOST_WIDE_INT.
16537 (asan_mem_ref_init, asan_mem_ref_new, get_mem_refs_of_builtin_call,
16538 update_mem_ref_hash_table): Likewise.
16539 (asan_mem_ref_hasher::hash): Hash in a HWI.
16540 (report_error_func): Change size_in_bytes argument to HWI.
16541 Use *_N builtins if size_in_bytes is larger than 16 or not power of
16542 two.
16543 (build_shadow_mem_access): New function.
16544 (build_check_stmt): Use it. Change size_in_bytes argument to HWI.
16545 Handle size_in_bytes not power of two or larger than 16.
16546 (instrument_derefs): Don't give up if size_in_bytes is not
16547 power of two or is larger than 16.
16548
16549 2014-05-30 Kai Tietz <ktietz@redhat.com>
16550
16551 PR target/60104
16552 * config/i386/i386.c (x86_output_mi_thunk): Add memory case
16553 for sibling-tail-calls.
16554 * config/i386/i386.md (sibcall_insn_operand): Add memory-constrain
16555 to its use.
16556 * config/i386/predicates.md (sibcall_memory_operand): New predicate.
16557 (sibcall_insn_operand): Add check for sibcall_memory_operand.
16558
16559 2014-05-30 Pitchumani Sivanupandi <pitchumani.s@atmel.com>
16560
16561 * config/avr/avr-mcus.def: Change ATA6289 ISA to AVR4
16562 * config/avr/avr-tables.opt: Regenerate.
16563 * config/avr/t-multilib: Regenerate.
16564 * doc/avr-mmcu.texi: Regenerate.
16565
16566 2014-05-30 Ian Lance Taylor <iant@google.com>
16567
16568 * config/i386/xmmintrin.h (_mm_pause): Move out of scope of pragma
16569 target("sse").
16570
16571 2014-05-30 Tom de Vries <tom@codesourcery.com>
16572
16573 * config/i386/i386.c (TARGET_CALL_FUSAGE_CONTAINS_NON_CALLEE_CLOBBERS):
16574 Redefine as true.
16575
16576 2014-05-30 Tom de Vries <tom@codesourcery.com>
16577
16578 * lra-int.h (struct lra_reg): Add field actual_call_used_reg_set.
16579 * lra.c (initialize_lra_reg_info_element): Add init of
16580 actual_call_used_reg_set field.
16581 (lra): Call lra_create_live_ranges before lra_inheritance for
16582 -fuse-caller-save.
16583 * lra-assigns.c (lra_assign): Allow call_used_regs to cross calls for
16584 -fuse-caller-save.
16585 * lra-constraints.c (need_for_call_save_p): Use actual_call_used_reg_set
16586 instead of call_used_reg_set for -fuse-caller-save.
16587 * lra-lives.c (process_bb_lives): Calculate actual_call_used_reg_set.
16588
16589 2014-05-30 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
16590
16591 * config/arm/thumb2.md (*thumb2_movhi_insn): Set type of movw
16592 to mov_imm.
16593 * config/arm/vfp.md (*thumb2_movsi_vfp): Likewise.
16594
16595 2014-05-30 Richard Sandiford <rdsandiford@googlemail.com>
16596
16597 * ira.c (ira_get_dup_out_num): Check for output operands at
16598 the start of the loop. Handle cases where an included alternative
16599 follows an excluded one.
16600
16601 2014-05-29 Mike Stump <mikestump@comcast.net>
16602
16603 PR debug/61352
16604 * collect2.c (maybe_run_lto_and_relink): Be sure to always run
16605 post ld passes when lto is used.
16606
16607 2014-05-29 Vladimir Makarov <vmakarov@redhat.com>
16608
16609 PR rtl-optimization/61325
16610 * lra-constraints.c (process_address): Rename to process_address_1.
16611 (process_address): New function.
16612
16613 2014-05-29 Alan Lawrence <alan.lawrence@arm.com>
16614
16615 * config/aarch64/aarch64-builtins.c (aarch64_types_binopv_qualifiers,
16616 TYPES_BINOPV): New static data.
16617 * config/aarch64/aarch64-simd-builtins.def (im_lane_bound):
16618 New builtin.
16619 * config/aarch64/aarch64-simd.md (aarch64_ext,
16620 aarch64_im_lane_boundsi): New patterns.
16621 * config/aarch64/aarch64.c (aarch64_expand_vec_perm_const_1): Match
16622 patterns for EXT.
16623 (aarch64_evpc_ext): New function.
16624
16625 * config/aarch64/iterators.md (UNSPEC_EXT): New enum element.
16626
16627 * config/aarch64/arm_neon.h (vext_f32, vext_f64, vext_p8, vext_p16,
16628 vext_s8, vext_s16, vext_s32, vext_s64, vext_u8, vext_u16, vext_u32,
16629 vext_u64, vextq_f32, vextq_f64, vextq_p8, vextq_p16, vextq_s8,
16630 vextq_s16, vextq_s32, vextq_s64, vextq_u8, vextq_u16, vextq_u32,
16631 vextq_u64): Replace __asm with __builtin_shuffle and im_lane_boundsi.
16632
16633 2014-05-29 Tom de Vries <tom@codesourcery.com>
16634
16635 * rtl.h (BLOCK_SYMBOL_CHECK): Use SYMBOL_REF_FLAGS.
16636
16637 2014-05-29 Richard Earnshaw <rearnsha@arm.com>
16638 Richard Sandiford <rdsandiford@googlemail.com>
16639
16640 * arm/iterators.md (shiftable_ops): New code iterator.
16641 (t2_binop0, arith_shift_insn): New code attributes.
16642 * arm/predicates.md (shift_nomul_operator): New predicate.
16643 * arm/arm.md (insn_enabled): Delete.
16644 (enabled): Remove insn_enabled test.
16645 (*arith_shiftsi): Delete. Replace with ...
16646 (*<arith_shift_insn>_multsi): ... new pattern.
16647 (*<arith_shift_insn>_shiftsi): ... new pattern.
16648 * config/arm/arm.c (arm_print_operand): Handle operand format 'b'.
16649
16650 2014-05-29 Radovan Obradovic <robradovic@mips.com>
16651 Tom de Vries <tom@codesourcery.com>
16652
16653 * config/mips/mips.h (POST_CALL_TMP_REG): Define.
16654 * config/mips/mips.c (mips_emit_call_insn): Add POST_CALL_TMP_REG
16655 clobber.
16656 (mips_split_call): Use POST_CALL_TMP_REG.
16657 (TARGET_CALL_FUSAGE_CONTAINS_NON_CALLEE_CLOBBERS): Redefine to true.
16658
16659 2014-05-29 Tom de Vries <tom@codesourcery.com>
16660
16661 * final.c (collect_fn_hard_reg_usage): Guard variable declaration
16662 with #ifdef STACK_REGS.
16663
16664 2014-05-28 Jan Hubicka <hubicka@ucw.cz>
16665
16666 * varasm.c (get_variable_section): Walk aliases.
16667 (place_block_symbol): Walk aliases.
16668
16669 2014-05-28 Tom de Vries <tom@codesourcery.com>
16670
16671 Revert:
16672 2014-05-28 Tom de Vries <tom@codesourcery.com>
16673
16674 * lra-int.h (struct lra_reg): Add field actual_call_used_reg_set.
16675 * lra.c (initialize_lra_reg_info_element): Add init of
16676 actual_call_used_reg_set field.
16677 (lra): Call lra_create_live_ranges before lra_inheritance for
16678 -fuse-caller-save.
16679 * lra-assigns.c (lra_assign): Allow call_used_regs to cross calls for
16680 -fuse-caller-save.
16681 * lra-constraints.c (need_for_call_save_p): Use
16682 actual_call_used_reg_set instead of call_used_reg_set for
16683 -fuse-caller-save.
16684 * lra-lives.c (process_bb_lives): Calculate actual_call_used_reg_set.
16685
16686 2014-05-28 Richard Sandiford <rdsandiford@googlemail.com>
16687
16688 * doc/md.texi: Document that the % constraint character must
16689 be at the beginning of the string.
16690 * genoutput.c (validate_insn_alternatives): Check that '=',
16691 '+' and '%' only appear at the beginning of a constraint.
16692 * ira.c (commutative_constraint_p): Delete.
16693 (ira_get_dup_out_num): Expect the '%' commutativity marker to be
16694 at the start of the string.
16695 * config/alpha/alpha.md (*movmemdi_1, *clrmemdi_1): Remove
16696 duplicate '='s.
16697 * config/arm/neon.md (bicdi3_neon): Likewise.
16698 * config/iq2000/iq2000.md (addsi3_internal, subsi3_internal, sgt_si)
16699 (slt_si, sltu_si): Likewise.
16700 * config/vax/vax.md (sbcdi3): Likewise.
16701 * config/h8300/h8300.md (*cmpstz): Remove duplicate '+'.
16702 * config/arc/arc.md (mulsi_600, mulsidi_600, umulsidi_600)
16703 (mul64): Move '%' to beginning of constraint.
16704 * config/arm/arm.md (*xordi3_insn): Likewise.
16705 * config/nds32/nds32.md (add<mode>3, mulsi3, andsi3, iorsi3)
16706 (xorsi3): Likewise.
16707
16708 2014-05-28 Richard Sandiford <rdsandiford@googlemail.com>
16709
16710 * doc/md.texi: Document the restrictions on the "enabled" attribute.
16711
16712 2014-05-28 Jason Merrill <jason@redhat.com>
16713
16714 PR c++/47202
16715 * cgraph.h (symtab_node::get_comdat_group_id): New.
16716 * cgraphunit.c (analyze_functions): Call it.
16717 * symtab.c (dump_symtab_node): Likewise.
16718 * tree.c (decl_comdat_group_id): New.
16719 * tree.h: Declare it.
16720 * lto-streamer-out.c (write_symbol): Use it.
16721 * trans-mem.c (ipa_tm_create_version_alias): Likewise.
16722
16723 2014-05-28 Francois-Xavier Coudert <fxcoudert@gcc.gnu.org>
16724
16725 PR bootstrap/PR61146
16726 * wide-int.cc: Do not include longlong.h when compiling with clang.
16727
16728 2014-05-28 Richard Biener <rguenther@suse.de>
16729
16730 * tree-ssa-propagate.c (add_control_edge): Print less vertical space.
16731 * tree-vrp.c (extract_range_from_ssa_name): Also copy VR_UNDEFINED.
16732 (vrp_visit_assignment_or_call): Print less vertical space.
16733 (vrp_visit_stmt): Likewise.
16734 (vrp_visit_phi_node): Likewise. For a PHI argument with
16735 VR_VARYING range consider recording it as copy.
16736
16737 2014-05-28 Richard Biener <rguenther@suse.de>
16738
16739 Revert
16740 2014-05-28 Richard Biener <rguenther@suse.de>
16741
16742 * hwint.h (HOST_WIDE_INT_PRINT_*): Define in terms of PRI*64.
16743
16744 2014-05-28 Bernd Edlinger <bernd.edlinger@hotmail.de>
16745
16746 * expr.c (expand_assignment): Fold the bitpos in the to_rtx if
16747 sufficiently aligned and an offset is used at the same time.
16748 (expand_expr_real_1): Likewise.
16749
16750 2014-05-28 Richard Biener <rguenther@suse.de>
16751
16752 PR middle-end/61045
16753 * fold-const.c (fold_comparison): When folding
16754 X +- C1 CMP Y +- C2 to X CMP Y +- C2 +- C1 also ensure
16755 the sign of the remaining constant operand stays the same.
16756
16757 2014-05-28 Kaushik Phatak <kaushik.phatak@kpit.com>
16758
16759 * config/rl78/rl78.h (TARGET_CPU_CPP_BUILTINS): Define
16760 __RL78_64BIT_DOUBLES__ or __RL78_32BIT_DOUBLES__.
16761 (ASM_SPEC): Pass -m64bit-doubles or -m32bit-doubles on
16762 to the assembler.
16763 (DOUBLE_TYPE_SIZE): Use 64 bit if TARGET_64BIT_DOUBLES is true.
16764 * gcc/config/rl78/rl78.opt (m64bit-doubles): New option.
16765 (m32bit-doubles) Likewise.
16766 * gcc/config/rl78/t-rl78: Add 64-bit-double multilib.
16767 * doc/invoke.texi: Document -m32bit-doubles and -m64bit-doubles
16768 option for RL78.
16769
16770 2014-05-28 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
16771
16772 * configure.ac ($gcc_cv_ld_clearcap): New test.
16773 * configure: Regenerate.
16774 * config.in: Regenerate.
16775 * config/sol2.opt (mclear-hwcap): New option.
16776 * config/sol2.h (LINK_CLEARCAP_SPEC): Define.
16777 * config/sol2-clearcap.map: Moved here from
16778 testsuite/gcc.target/i386/clearcap.map.
16779 * config/sol2-clearcapv2.map: Move here from
16780 gcc.target/i386/clearcapv2.map.
16781 * config/t-sol2 (install): Depend on install-clearcap-map.
16782 (install-clearcap-map): New target.
16783 * doc/invoke.texi (Option Summary, Solaris 2 Options): Document
16784 -mclear-hwcap.
16785
16786 2014-05-28 Richard Biener <rguenther@suse.de>
16787
16788 * hwint.h (*_HALF_WIDE_INT*): Move to ...
16789 * wide-int.cc (HOST_BITS_PER_HALF_WIDE_INT, HOST_HALF_WIDE_INT):
16790 ... here and remove the rest.
16791 * hwint.h (HOST_WIDE_INT_PRINT_*): Define in terms of PRI*64.
16792
16793 2014-05-28 Richard Biener <rguenther@suse.de>
16794
16795 PR tree-optimization/61335
16796 * tree-vrp.c (vrp_visit_phi_node): If the compare of old and
16797 new range fails, drop to varying.
16798
16799 2014-05-28 Olivier Hainque <hainque@adacore.com>
16800
16801 * config/rs6000/vxworks.h (VXCPU_FOR_8548): New. Default to PPC85XX.
16802 (CPP_SPEC): Add entry for -mcpu=8548.
16803 * config/rs6000/vxworksae.h: Reinstate. Override VXCPU_FOR_8548.
16804 * config.gcc (powerpc-wrs-vxworksae, tm_file): Add back vxworksae.h.
16805
16806 2014-05-28 Tom de Vries <tom@codesourcery.com>
16807
16808 * lra-int.h (struct lra_reg): Add field actual_call_used_reg_set.
16809 * lra.c (initialize_lra_reg_info_element): Add init of
16810 actual_call_used_reg_set field.
16811 (lra): Call lra_create_live_ranges before lra_inheritance for
16812 -fuse-caller-save.
16813 * lra-assigns.c (lra_assign): Allow call_used_regs to cross calls for
16814 -fuse-caller-save.
16815 * lra-constraints.c (need_for_call_save_p): Use
16816 actual_call_used_reg_set instead of call_used_reg_set for
16817 -fuse-caller-save.
16818 * lra-lives.c (process_bb_lives): Calculate actual_call_used_reg_set.
16819
16820 2014-05-28 Radovan Obradovic <robradovic@mips.com>
16821 Tom de Vries <tom@codesourcery.com>
16822
16823 * doc/invoke.texi (@item Optimization Options): Add -fuse-caller-save
16824 to gccoptlist.
16825 (@item -fuse-caller-save): New item.
16826
16827 2014-05-28 Radovan Obradovic <robradovic@mips.com>
16828 Tom de Vries <tom@codesourcery.com>
16829
16830 * opts.c (default_options_table): Add OPT_LEVELS_2_PLUS entry with
16831 OPT_fuse_caller_save.
16832
16833 2014-05-28 Radovan Obradovic <robradovic@mips.com>
16834 Tom de Vries <tom@codesourcery.com>
16835
16836 * df-scan.c (df_get_call_refs): Use get_call_reg_set_usage.
16837 * caller-save.c (setup_save_areas, save_call_clobbered_regs): Use
16838 get_call_reg_set_usage.
16839 * resource.c (mark_set_resources, mark_target_live_regs): Use
16840 get_call_reg_set_usage.
16841 * ira-int.h (struct ira_allocno): Add crossed_calls_clobbered_regs
16842 field.
16843 (ALLOCNO_CROSSED_CALLS_CLOBBERED_REGS): Define.
16844 * ira-lives.c (process_bb_node_lives): Use get_call_reg_set_usage.
16845 Calculate ALLOCNO_CROSSED_CALLS_CLOBBERED_REGS.
16846 * ira-build.c (ira_create_allocno): Init
16847 ALLOCNO_CROSSED_CALLS_CLOBBERED_REGS.
16848 (create_cap_allocno, propagate_allocno_info)
16849 (propagate_some_info_from_allocno)
16850 (copy_info_to_removed_store_destinations): Handle
16851 ALLOCNO_CROSSED_CALLS_CLOBBERED_REGS.
16852 * ira-costs.c (ira_tune_allocno_costs): Use
16853 ALLOCNO_CROSSED_CALLS_CLOBBERED_REGS to adjust costs.
16854
16855 2014-05-28 Radovan Obradovic <robradovic@mips.com>
16856 Tom de Vries <tom@codesourcery.com>
16857
16858 * cgraph.h (struct cgraph_rtl_info): Add function_used_regs
16859 and function_used_regs_valid fields.
16860 * final.c: Move include of hard-reg-set.h to before rtl.h to declare
16861 find_all_hard_reg_sets.
16862 (collect_fn_hard_reg_usage, get_call_fndecl, get_call_cgraph_rtl_info)
16863 (get_call_reg_set_usage): New function.
16864 (rest_of_handle_final): Use collect_fn_hard_reg_usage.
16865 * regs.h (get_call_reg_set_usage): Declare.
16866
16867 2014-05-28 Georg-Johann Lay <avr@gjlay.de>
16868
16869 PR libgcc/61152
16870 * config/dbx.h (License): Add Runtime Library Exception.
16871 * config/newlib-stdint.h (License): Same.
16872 * config/rtems.h (License): Same
16873 * config/initfini-array.h (License): Same
16874 * config/v850/v850.h (License): Same.
16875 * config/v850/v850-opts.h (License): Same
16876 * config/v850/rtems.h (License): Same.
16877
16878 2014-05-28 Georg-Johann Lay <avr@gjlay.de>
16879
16880 PR target/61044
16881 * doc/extend.texi (Local Labels): Note that label differences are
16882 not supported for AVR.
16883
16884 2014-05-28 Richard Sandiford <rdsandiford@googlemail.com>
16885 Olivier Hainque <hainque@adacore.com>
16886
16887 * rtl.h (set_for_reg_notes): Declare.
16888 * emit-rtl.c (set_for_reg_notes): New function.
16889 (set_unique_reg_note): Use it.
16890 * optabs.c (add_equal_note): Likewise
16891
16892 2014-05-27 Andrew Pinski <apinski@cavium.com>
16893
16894 * config/aarch64/aarch64.md (stack_protect_set_<mode>):
16895 Use <w> for the register in assembly template.
16896 (stack_protect_test): Use the mode of operands[0] for the result.
16897 (stack_protect_test_<mode>): Use <w> for the register
16898 in assembly template.
16899
16900 2014-05-27 DJ Delorie <dj@redhat.com>
16901
16902 * config/rx/rx.c (add_vector_labels): New.
16903 (rx_output_function_prologue): Call it.
16904 (rx_handle_func_attribute): Don't require empty arguments.
16905 (rx_handle_vector_attribute): New.
16906 (rx_attribute_table): Add "vector" attribute.
16907 * doc/extend.texi (interrupt, vector): Document new/changed
16908 RX-specific attributes.
16909
16910 * config/rx/rx.c (rx_adjust_insn_length): Skip for non-insns.
16911
16912 2014-05-27 Eric Botcazou <ebotcazou@adacore.com>
16913
16914 * double-int.c (div_and_round_double) <ROUND_DIV_EXPR>: Use the proper
16915 predicate to detect a negative quotient.
16916
16917 2014-05-27 Eric Botcazou <ebotcazou@adacore.com>
16918
16919 * fold-const.c (fold_comparison): Clean up and extend X +- C1 CMP C2
16920 to X CMP C2 -+ C1 transformation to EQ_EXPR/NE_EXPR.
16921 Add X - Y CMP 0 to X CMP Y transformation.
16922 (fold_binary_loc) <EQ_EXPR/NE_EXPR>: Remove same transformations.
16923
16924 2014-05-27 Segher Boessenkool <segher@kernel.crashing.org>
16925
16926 * stmt.c (dump_case_nodes): Don't convert values to HOST_WIDE_INT
16927 before printing.
16928
16929 2014-05-27 Steve Ellcey <sellcey@mips.com>
16930
16931 * config/mips/mips.c: Add include of cgraph.h.
16932
16933 2014-05-27 Richard Biener <rguenther@suse.de>
16934
16935 * system.h (__STDC_FORMAT_MACROS): Define as very first thing.
16936
16937 2014-05-27 Georg-Johann Lay <avr@gjlay.de>
16938
16939 PR libgcc/61152
16940 * config/arm/arm.h (License): Add note to COPYING.RUNTIME.
16941 * config/arm/arm-cores.def (License): Same.
16942 * config/arm/arm-opts.h (License): Same.
16943 * config/arm/aout.h (License): Same.
16944 * config/arm/bpabi.h (License): Same.
16945 * config/arm/elf.h (License): Same.
16946 * config/arm/linux-elf.h (License): Same.
16947 * config/arm/linux-gas.h (License): Same.
16948 * config/arm/netbsd-elf.h (License): Same.
16949 * config/arm/uclinux-eabi.h (License): Same.
16950 * config/arm/uclinux-elf.h (License): Same.
16951 * config/arm/vxworks.h (License): Same.
16952
16953 2014-05-27 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
16954
16955 * config/arm/neon.md (neon_bswap<mode>): New pattern.
16956 * config/arm/arm.c (neon_itype): Add NEON_BSWAP.
16957 (arm_init_neon_builtins): Handle NEON_BSWAP.
16958 Define required type nodes.
16959 (arm_expand_neon_builtin): Handle NEON_BSWAP.
16960 (arm_builtin_vectorized_function): Handle BUILTIN_BSWAP builtins.
16961 * config/arm/arm_neon_builtins.def (bswap): Define builtins.
16962 * config/arm/iterators.md (VDQHSD): New mode iterator.
16963
16964 2014-05-27 Richard Biener <rguenther@suse.de>
16965
16966 * tree-vrp.c (vrp_evaluate_conditional_warnv_with_ops_using_ranges):
16967 Try using literal operands when comparing value-ranges failed.
16968
16969 2014-05-27 Richard Sandiford <rdsandiford@googlemail.com>
16970
16971 * ira.c (commutative_operand): Adjust for change to recog_data.
16972 [Missing from previous commit.]
16973
16974 2014-05-27 Richard Sandiford <rdsandiford@googlemail.com>
16975
16976 * system.h (TEST_BIT): New macro.
16977 * recog.h (alternative_mask): New type.
16978 (ALL_ALTERNATIVES, ALTERNATIVE_BIT): New macros.
16979 (recog_data_d): Replace alternative_enabled_p array with
16980 enabled_alternatives.
16981 (target_recog): New structure.
16982 (default_target_recog, this_target_recog): Declare.
16983 (get_enabled_alternatives, recog_init): Likewise.
16984 * recog.c (default_target_recog, this_target_recog): New variables.
16985 (get_enabled_alternatives): New function.
16986 (extract_insn): Use it.
16987 (recog_init): New function.
16988 (preprocess_constraints, constrain_operands): Adjust for change to
16989 recog_data.
16990 * postreload.c (reload_cse_simplify_operands): Likewise.
16991 * reload.c (find_reloads): Likewise.
16992 * ira-costs.c (record_reg_classes): Likewise.
16993 * ira-lives.c (single_reg_class): Likewise. Fix bug in which
16994 all alternatives after a disabled one would be skipped.
16995 (ira_implicitly_set_insn_hard_regs): Likewise.
16996 * ira.c (ira_setup_alts): Adjust for change to recog_data.
16997 * lra-int.h (lra_insn_recog_data): Replace alternative_enabled_p
16998 with enabled_alternatives.
16999 * lra.c (free_insn_recog_data): Update accordingly.
17000 (lra_update_insn_recog_data): Likewise.
17001 (lra_set_insn_recog_data): Likewise. Use get_enabled_alternatives.
17002 * lra-constraints.c (process_alt_operands): Likewise. Handle
17003 only_alternative as part of the enabled mask.
17004 * target-globals.h (this_target_recog): Declare.
17005 (target_globals): Add a recog field.
17006 (restore_target_globals): Restore this_target_recog.
17007 * target-globals.c: Include recog.h.
17008 (default_target_globals): Initialize recog field.
17009 (save_target_globals): Likewise.
17010 * reginfo.c (reinit_regs): Call recog_init.
17011 * toplev.c (backend_init_target): Likewise.
17012
17013 2014-05-27 Richard Sandiford <rdsandiford@googlemail.com>
17014
17015 * gencodes.c (main): Make LAST_INSN_CODE higher than any insn code,
17016 rather than any named insn's code.
17017
17018 2014-05-27 Georg-Johann Lay <avr@gjlay.de>
17019
17020 PR libgcc/61152
17021 * config/arm/arm-opts.h (License): Add GCC Runtime Library Exception.
17022 * config/arm/arm-cores.def (License): Same.
17023
17024 2014-05-26 Jan Hubicka <hubicka@ucw.cz>
17025
17026 * tree.h (decl_comdat_group): Declare.
17027 * cgraph.h (symtab_in_same_comdat_p): Move offline to ...
17028 * tree.c (decl_comdat_group): Here.
17029
17030 2014-05-26 Richard Sandiford <r.sandiford@uk.ibm.com>
17031
17032 PR rtl-optimization/61222
17033 * combine.c (simplify_shift_const_1): When moving a PLUS outside
17034 the shift, truncate the PLUS operand to the result mode.
17035
17036 2014-05-26 Uros Bizjak <ubizjak@gmail.com>
17037
17038 PR target/61271
17039 * config/i386/i386.c (ix86_rtx_costs)
17040 <case CONST_INT, case CONST, case LABEL_REF, case SYMBOL_REF>:
17041 Fix condition.
17042
17043 2014-05-26 Martin Jambor <mjambor@suse.cz>
17044
17045 * ira.c (split_live_ranges_for_shrink_wrap): Remove bailout on
17046 subreg uses.
17047
17048 2014-05-26 Richard Biener <rguenther@suse.de>
17049
17050 * wide-int.h (wi::int_traits <long>, wi::int_traits <unsigned long>,
17051 wi::int_traits <long long>, wi::int_traits <unsigned long long>):
17052 Provide specializations.
17053 (wi::int_traits <HOST_WIDE_INT>,
17054 wi::int_traits <unsigned HOST_WIDE_INT>): Remove specializations.
17055
17056 2014-05-26 Alan Modra <amodra@gmail.com>
17057
17058 PR target/61098
17059 * config/rs6000/rs6000.c (rs6000_emit_set_const): Remove unneeded
17060 params and return a bool. Remove dead code. Update comment.
17061 Assert we have a const_int source. Remove bogus code from
17062 32-bit HWI days. Move !TARGET_POWERPC64 handling, and correct
17063 handling of constants > 2G and reg_equal note, from..
17064 (rs6000_emit_set_long_const): ..here. Remove unneeded param and
17065 return value. Update comment. If we can, use a new pseudo
17066 for intermediate calculations.
17067 * config/rs6000/rs6000-protos.h (rs6000_emit_set_const): Update
17068 prototype.
17069 * config/rs6000/rs6000.md (movsi_internal1_single+1): Update
17070 call to rs6000_emit_set_const in splitter.
17071 (movdi_internal64+2, +3): Likewise.
17072
17073 2014-05-26 Richard Biener <rguenther@suse.de>
17074
17075 * system.h: Define __STDC_FORMAT_MACROS before
17076 including inttypes.h.
17077 * hwint.h (HOST_WIDEST_INT, HOST_BITS_PER_WIDEST_INT,
17078 HOST_WIDEST_INT_PRINT, HOST_WIDEST_INT_PRINT_DEC,
17079 HOST_WIDEST_INT_PRINT_DEC_C, HOST_WIDEST_INT_PRINT_UNSIGNED,
17080 HOST_WIDEST_INT_PRINT_HEX, HOST_WIDEST_INT_PRINT_DOUBLE_HEX,
17081 HOST_WIDEST_INT_C): Remove.
17082 (PRId64, PRIi64, PRIo64, PRIu64, PRIx64, PRIX64): Define
17083 if C99 inttypes.h is not available.
17084 * coretypes.h (gcov_type, gcov_type_unsigned): Use [u]int64_t.
17085 * gcov-io.h (gcov_type, gcov_type_unsigned): Likewise.
17086 * gcov-io.c (gcov_histo_index): Drop non-64bit hwi case.
17087 * cfgloop.h (struct niter_desc): Use uint64_t for niter field.
17088 * bitmap.c (struct bitmap_descriptor_d): Use uint64_t for counters.
17089 (struct output_info): Likewise.
17090 (print_statistics): Adjust.
17091 (dump_bitmap_statistics): Likewise.
17092 * bt-load.c (migrate_btr_defs): Print with PRId64.
17093 * cfg.c (dump_edge_info, dump_bb_info): Likewise.
17094 (MAX_SAFE_MULTIPLIER): Adjust.
17095 * cfghooks.c (dump_bb_for_graph): Print with PRId64.
17096 * cgraph.c (cgraph_redirect_edge_call_stmt_to_callee,
17097 dump_cgraph_node): Likewise.
17098 * final.c (dump_basic_block_info): Likewise.
17099 * gcov-dump.c (tag_counters, tag_summary, dump_working_sets): Likewise.
17100 * gcov.c (format_gcov): Likewise.
17101 * ipa-cp.c (good_cloning_opportunity_p): Likewise. Use int64_t
17102 for calculation.
17103 (get_clone_agg_value): Use HOST_WIDE_INT for offset.
17104 * ipa-inline.c (compute_max_insns): Use int64_t for calcuation.
17105 (inline_small_functions, dump_overall_stats, dump_inline_stats):
17106 Use PRId64 for dumping.
17107 * ipa-profile.c (dump_histogram, ipa_profile): Likewise.
17108 * ira-color.c (struct allocno_hard_regs): Use int64_t for cost.
17109 (add_allocno_hard_regs): Adjust.
17110 * loop-doloop.c (doloop_modify): Print using PRId64.
17111 * loop-iv.c (inverse): Compute in uint64_t.
17112 (determine_max_iter, iv_number_of_iterations): Likewise.
17113 * loop-unroll.c (decide_peel_completely, decide_peel_simple):
17114 Print using PRId64.
17115 * lto-streamer-out.c (write_symbol): Use uint64_t.
17116 * mcf.c (CAP_INFINITY): Use int64_t maximum.
17117 (dump_fixup_edge, create_fixup_graph, cancel_negative_cycle,
17118 find_max_flow, adjust_cfg_counts): Use int64_t and dump with PRId64.
17119 * modulo-sched.c (const_iteration_count): Use int64_t.
17120 (sms_schedule): Dump using PRId64.
17121 * predict.c (dump_prediction): Likewise.
17122 * pretty-print.h (pp_widest_integer): Remove.
17123 * profile.c (get_working_sets, is_edge_inconsistent,
17124 is_inconsistent, read_profile_edge_counts): Dump using PRId64.
17125 * tree-pretty-print.c (pp_double_int): Remove case handling
17126 HOST_BITS_PER_DOUBLE_INT == HOST_BITS_PER_WIDEST_INT.
17127 * tree-ssa-math-opts.c (struct symbolic_number): Use uint64_t
17128 and adjust users.
17129 (pass_optimize_bswap::execute): Remove restriction on hosts.
17130 * tree-streamer-in.c (streamer_alloc_tree): Use HOST_WIDE_INT.
17131 * tree-streamer-out.c (streamer_write_tree_header): Likewise.
17132 * tree.c (widest_int_cst_value): Remove.
17133 * tree.h (widest_int_cst_value): Likewise.
17134 * value-prof.c (dump_histogram_value): Print using PRId64.
17135 * gengtype.c (main): Also inject int64_t.
17136 * ggc-page.c (struct max_alignment): Use int64_t.
17137 * alloc-pool.c (struct allocation_object_def): Likewise.
17138 * ira-conflicts.c (build_conflict_bit_table): Use uint64_t
17139 for computation.
17140 * doc/tm.texi.in: Remove reference to HOST_WIDEST_INT.
17141 * doc/tm.texi: Regenerated.
17142 * gengtype-lex.l (IWORD): Handle [u]int64_t.
17143 * config/sh/sh.c (expand_cbranchdi4): Use gcov_type.
17144 * config/mmix/mmix-protos.h (mmix_intval, mmix_shiftable_wyde_value,
17145 mmix_output_register_setting): Use [u]int64_t in prototypes.
17146 * config/mmix/mmix.c (mmix_print_operand, mmix_output_register_setting,
17147 mmix_shiftable_wyde_value, mmix_output_shiftvalue_op_from_str,
17148 mmix_output_octa, mmix_output_shifted_value): Adjust.
17149 (mmix_intval): Adjust. Remove unreachable case.
17150 * config/mmix/mmix.md (*nonlocal_goto_receiver_expanded): Use int64_t.
17151
17152 2014-05-26 Richard Biener <rguenther@suse.de>
17153
17154 * configure.ac: Drop __int64 type check. Insist that we
17155 found uint64_t and int64_t.
17156 * hwint.h (HOST_BITS_PER___INT64): Remove.
17157 (HOST_BITS_PER_WIDE_INT): Define to 64 and remove __int64 case.
17158 (HOST_WIDE_INT_PRINT_*): Remove 32bit case.
17159 (HOST_WIDEST_INT*): Define to HOST_WIDE_INT*.
17160 (HOST_WIDEST_FAST_INT): Remove __int64 case.
17161 * vmsdbg.h (struct _DST_SRC_COMMAND): Use int64_t
17162 for dst_q_src_df_rms_cdt.
17163 * configure: Regenerate.
17164 * config.in: Likewise.
17165
17166 2014-05-26 Michael Tautschnig <mt@debian.org>
17167
17168 PR target/61249
17169 * doc/extend.texi (X86 Built-in Functions): Fix parameter lists of
17170 __builtin_ia32_vfrczs[sd] and __builtin_ia32_mpsadbw256.
17171
17172 2014-05-26 Zhenqiang Chen <zhenqiang.chen@linaro.org>
17173
17174 PR rtl-optimization/61278
17175 * shrink-wrap.c (move_insn_for_shrink_wrap): Check df_live.
17176
17177 2014-05-26 Zhenqiang Chen <zhenqiang.chen@linaro.org>
17178
17179 PR rtl-optimization/61220
17180 Part of PR rtl-optimization/61225
17181 * shrink-wrap.c (move_insn_for_shrink_wrap): Skip SP and FP adjustment
17182 insn; skip split_edge for a block with only one successor.
17183
17184 2014-05-23 Jan Hubicka <hubicka@ucw.cz>
17185
17186 * symtab.c (symtab_nonoverwritable_alias): Copy READONLY flag
17187 for variables.
17188
17189 2014-05-23 Jan Hubicka <hubicka@ucw.cz>
17190
17191 * ipa-visibility.c (can_replace_by_local_alias_in_vtable): New function.
17192 (update_vtable_references): New function.
17193 (function_and_variable_visibility): Rewrite also vtable initializers.
17194 * varpool.c (cgraph_variable_initializer_availability): Remove assert.
17195
17196 2014-05-23 Jan Hubicka <hubicka@ucw.cz>
17197
17198 * ggc.h (ggc_grow): New function.
17199 * ggc-none.c (ggc_grow): New function.
17200 * ggc-page.c (ggc_grow): Likewise.
17201
17202 2014-05-23 Jan Hubicka <hubicka@ucw.cz>
17203
17204 * ipa.c (cgraph_non_local_node_p_1, cgraph_local_node_p,
17205 address_taken_from_non_vtable_p, comdat_can_be_unshared_p_1,
17206 comdat_can_be_unshared_p, cgraph_externally_visible_p,
17207 varpool_externally_visible_p, can_replace_by_local_alias,
17208 update_visibility_by_resolution_info, function_and_variable_visibility,
17209 pass_data_ipa_function_and_variable_visibility,
17210 make_pass_ipa_function_and_variable_visibility,
17211 whole_program_function_and_variable_visibility,
17212 pass_data_ipa_whole_program_visibility,
17213 make_pass_ipa_whole_program_visibility): Move to ipa-visibility.c
17214 * cgraph.h (cgraph_local_node_p): Declare.
17215 * ipa-visibility.c: New file.
17216 * Makefile.in (OBJS): Add ipa-visiblity.o
17217
17218 2014-05-23 Jan Hubicka <hubicka@ucw.cz>
17219
17220 * gimple-fold.c (can_refer_decl_in_current_unit_p): Be sure
17221 that var decl is available.
17222
17223 2014-05-23 Jan Hubicka <hubicka@ucw.cz>
17224
17225 * tree-core.h (tree_decl_with_vis): Replace comdat_group by
17226 symtab_node pointer.
17227 * tree.c (copy_node_stat): Be sure to not copy symtab_node pointer.
17228 (find_decls_types_r): Do not walk COMDAT_GROUP.
17229 * tree.h (DECL_COMDAT_GROUP): Revamp to use decl_comdat_group.
17230 * varasm.c (make_decl_one_only): Use set_comdat_group;
17231 create node if needed.
17232 * ipa-inline-transform.c (save_inline_function_body): Update
17233 way we decl->symtab mapping.
17234 * symtab.c (symtab_hash, hash_node, eq_node
17235 symtab_insert_node_to_hashtable): Remove.
17236 (symtab_register_node): Update.
17237 (symtab_unregister_node): Update.
17238 (symtab_get_node): Reimplement as inline function.
17239 (symtab_add_to_same_comdat_group): Update.
17240 (symtab_dissolve_same_comdat_group_list): Update.
17241 (dump_symtab_base): Update.
17242 (verify_symtab_base): Update.
17243 (symtab_make_decl_local): Update.
17244 (fixup_same_cpp_alias_visibility): Update.
17245 (symtab_nonoverwritable_alias): Update.
17246 * cgraphclones.c (set_new_clone_decl_and_node_flags): Update.
17247 * ipa.c (update_visibility_by_resolution_info): UPdate.
17248 * bb-reorder.c: Include cgraph.h
17249 * lto-streamer-out.c (DFS_write_tree_body, hash_tree): Do not deal
17250 with comdat groups.
17251 * ipa-comdats.c (set_comdat_group, ipa_comdats): Update.
17252 * cgraph.c (cgraph_get_create_node): Update.
17253 * cgraph.h (struct symtab_node): Add get_comdat_group, set_comdat_group
17254 and comdat_group_.
17255 (symtab_get_node): Make inline.
17256 (symtab_insert_node_to_hashtable): Remove.
17257 (symtab_can_be_discarded): Update.
17258 (decl_comdat_group): New function.
17259 * tree-streamer-in.c (lto_input_ts_decl_with_vis_tree_pointers):
17260 Update.
17261 * lto-cgraph.c (lto_output_node, lto_output_varpool_node): Stream out
17262 comdat group name.
17263 (read_comdat_group): New function.
17264 (input_node, input_varpool_node): Use it.
17265 * trans-mem.c (ipa_tm_create_version_alias): Update code creating
17266 comdat groups.
17267 * mips.c (mips_start_unique_function): Likewise.
17268 (ix86_code_end): Likewise.
17269 (rs6000_code_end): Likweise.
17270 * tree-streamer-out.c (DECL_COMDAT_GROUP): Do not stream comdat group.
17271
17272 2014-05-23 Jan Hubicka <hubicka@ucw.cz>
17273
17274 * gengtype-state.c (fatal_reading_state): Bring offline.
17275 * optabs.c (widening_optab_handler): Bring offline.
17276 * optabs.h (widening_optab_handler): Likewise.
17277 * final.c (get_attr_length_1): Likewise.
17278
17279 2014-05-23 Jan Hubicka <hubicka@ucw.cz>
17280
17281 * sched-int.h (sd_iterator_cond): Manually tail recurse.
17282
17283 2014-05-23 Segher Boessenkool <segher@kernel.crashing.org>
17284
17285 * config/rs6000/440.md (ppc440-integer): Include shift without dot.
17286 (ppc440-compare): Include shift with dot.
17287 * config/rs6000/e300c2c3.md (ppce300c3_iu): Include shift without dot.
17288 * config/rs6000/e5500.md (e5500_sfx2): Include constant shift
17289 without dot.
17290 * config/rs6000/e6500.md (e6500_sfx): Exclude constant shift
17291 without dot.
17292 (e6500_sfx2): Include it.
17293 * config/rs6000/rs6000.md ( *zero_extend<mode>di2_internal1,
17294 *zero_extend<mode>di2_internal2, *zero_extend<mode>di2_internal3,
17295 *zero_extendsidi2_lfiwzx, andsi3_mc, andsi3_nomc,
17296 andsi3_internal0_nomc, extzvsi_internal, extzvdi_internal,
17297 *extzvdi_internal1, *extzvdi_internal2, rotlsi3, *rotlsi3_64,
17298 *rotlsi3_internal4, *rotlsi3_internal7le, *rotlsi3_internal7be,
17299 *rotlsi3_internal10le, *rotlsi3_internal10be, rlwinm,
17300 *lshiftrt_internal1le, *lshiftrt_internal1be,
17301 *lshiftrt_internal4le, *lshiftrt_internal4be, rotldi3,
17302 *rotldi3_internal4, *rotldi3_internal7le, *rotldi3_internal7be,
17303 *rotldi3_internal10le, *rotldi3_internal10be,
17304 *rotldi3_internal13le, *rotldi3_internal13be, *ashldi3_internal4,
17305 ashldi3_internal5, *ashldi3_internal6, *ashldi3_internal7,
17306 ashldi3_internal8, *ashldi3_internal9, anddi3_mc, anddi3_nomc,
17307 *anddi3_internal2_mc, *anddi3_internal3_mc, and 4 anonymous
17308 define_insns): Use type "shift" in the appropriate alternatives.
17309
17310 2014-05-23 Segher Boessenkool <segher@kernel.crashing.org>
17311
17312 * config/rs6000/rs6000.md (type): Add "logical". Delete
17313 "fast_compare".
17314 (dot): Adjust comment.
17315 (andsi3_mc, *andsi3_internal2_mc, *andsi3_internal3_mc,
17316 *andsi3_internal4, *andsi3_internal5_mc, *boolsi3_internal2,
17317 *boolsi3_internal3, *boolccsi3_internal2, *boolccsi3_internal3,
17318 anddi3_mc, *anddi3_internal2_mc, *anddi3_internal3_mc,
17319 *booldi3_internal2, *booldi3_internal3, *boolcdi3_internal2,
17320 *boolcdi3_internal3, *boolccdi3_internal2, *boolccdi3_internal3,
17321 *mov<mode>_internal2, and 10 anonymous define_insns): Use "logical".
17322 * config/rs6000/rs6000.c (rs6000_adjust_cost): Adjust.
17323
17324 * config/rs6000/40x.md (ppc403-integer, ppc403-compare): Adjust.
17325 * config/rs6000/440.md (ppc440-integer, ppc440-compare): Adjust.
17326 * config/rs6000/476.md (ppc476-simple-integer, ppc476-compare): Adjust.
17327 * config/rs6000/603.md (ppc603-integer, ppc603-compare): Adjust.
17328 * config/rs6000/6xx.md (ppc604-integer, ppc604-compare): Adjust.
17329 * config/rs6000/7450.md (ppc7450-integer, ppc7450-compare): Adjust.
17330 * config/rs6000/7xx.md (ppc750-integer, ppc750-compare): Adjust.
17331 * config/rs6000/8540.md (ppc8540_su): Adjust.
17332 * config/rs6000/cell.md (cell-integer, cell-fast-cmp,
17333 cell-cmp-microcoded): Adjust.
17334 * config/rs6000/e300c2c3.md (ppce300c3_cmp, ppce300c3_iu): Adjust.
17335 * config/rs6000/e500mc.md (e500mc_su): Adjust.
17336 * config/rs6000/e500mc64.md (e500mc64_su, e500mc64_su2): Adjust.
17337 * config/rs6000/e5500.md (e5500_sfx, e5500_sfx2): Adjust.
17338 * config/rs6000/e6500.md (e6500_sfx, e6500_sfx2): Adjust.
17339 * config/rs6000/mpc.md (mpccore-integer, mpccore-compare): Adjust.
17340 * config/rs6000/power4.md (power4-integer, power4-cmp): Adjust.
17341 * config/rs6000/power5.md (power5-integer, power5-cmp): Adjust.
17342 * config/rs6000/power6.md (power6-integer, power6-fast-compare):
17343 Adjust.
17344 * config/rs6000/power7.md (power7-integer, power7-cmp): Adjust.
17345 * config/rs6000/power8.md (power8-1cyc, power8-fast-compare):
17346 Adjust. Adjust comment.
17347 * config/rs6000/rs64.md (rs64a-integer, rs64a-compare): Adjust.
17348 * config/rs6000/titan.md (titan_fxu_adder, titan_fxu_alu): Adjust.
17349
17350 2014-05-23 Segher Boessenkool <segher@kernel.crashing.org>
17351
17352 * config/rs6000/rs6000.md (type): Add "add".
17353 (*add<mode>3_internal1, addsi3_high, *add<mode>3_internal2,
17354 *add<mode>3_internal3, *neg<mode>2_internal, and 5 anonymous
17355 define_insns): Use it.
17356 * config/rs6000/rs6000.c (rs6000_adjust_cost): Adjust.
17357
17358 * config/rs6000/40x.md (ppc403-integer, ppc403-compare): Adjust.
17359 * config/rs6000/440.md (ppc440-integer, ppc440-compare): Adjust.
17360 * config/rs6000/476.md (ppc476-simple-integer, ppc476-compare): Adjust.
17361 * config/rs6000/601.md (ppc601-integer): Adjust.
17362 * config/rs6000/603.md (ppc603-integer, ppc603-compare): Adjust.
17363 * config/rs6000/6xx.md (ppc604-integer, ppc604-compare): Adjust.
17364 * config/rs6000/7450.md (ppc7450-integer, ppc7450-compare): Adjust.
17365 * config/rs6000/7xx.md (ppc750-integer, ppc750-compare): Adjust.
17366 * config/rs6000/8540.md (ppc8540_su): Adjust.
17367 * config/rs6000/cell.md (cell-integer, cell-fast-cmp,
17368 cell-cmp-microcoded): Adjust.
17369 * config/rs6000/e300c2c3.md (ppce300c3_cmp, ppce300c3_iu): Adjust.
17370 * config/rs6000/e500mc.md (e500mc_su): Adjust.
17371 * config/rs6000/e500mc64.md (e500mc64_su, e500mc64_su2): Adjust.
17372 * config/rs6000/e5500.md (e5500_sfx, e5500_sfx2): Adjust.
17373 * config/rs6000/e6500.md (e6500_sfx, e6500_sfx2): Adjust.
17374 * config/rs6000/mpc.md (mpccore-integer, mpccore-compare): Adjust.
17375 * config/rs6000/power4.md (power4-integer, power4-cmp): Adjust.
17376 * config/rs6000/power5.md (power5-integer, power5-cmp): Adjust.
17377 * config/rs6000/power6.md (power6-integer, power6-fast-compare):
17378 Adjust.
17379 * config/rs6000/power7.md (power7-integer, power7-cmp): Adjust.
17380 * config/rs6000/power8.md (power8-1cyc, power8-fast-compare): Adjust.
17381 * config/rs6000/rs64.md (rs64a-integer, rs64a-compare): Adjust.
17382 * config/rs6000/titan.md (titan_fxu_adder, titan_fxu_alu): Adjust.
17383
17384 2014-05-23 Segher Boessenkool <segher@kernel.crashing.org>
17385
17386 * config/rs6000/rs6000.md (type): Delete "var_shift_rotate",
17387 "delayed_compare", "var_delayed_compare".
17388 (var_shift): New attribute.
17389 (cell_micro): Adjust.
17390 (*andsi3_internal2_mc, *andsi3_internal3_mc, *andsi3_internal4,
17391 *andsi3_internal5_mc, *extzvsi_internal1, *extzvsi_internal2,
17392 rotlsi3, *rotlsi3_64, *rotlsi3_internal2, *rotlsi3_internal3,
17393 *rotlsi3_internal4, *rotlsi3_internal5, *rotlsi3_internal6,
17394 *rotlsi3_internal8le, *rotlsi3_internal8be, *rotlsi3_internal9le,
17395 *rotlsi3_internal9be, *rotlsi3_internal10le, *rotlsi3_internal10be,
17396 *rotlsi3_internal11le, *rotlsi3_internal11be, *rotlsi3_internal12le,
17397 *rotlsi3_internal12be, ashlsi3, *ashlsi3_64, lshrsi3, *lshrsi3_64,
17398 *lshiftrt_internal2le, *lshiftrt_internal2be, *lshiftrt_internal3le,
17399 *lshiftrt_internal3be, *lshiftrt_internal5le, *lshiftrt_internal5be,
17400 *lshiftrt_internal5le, *lshiftrt_internal5be, ashrsi3, *ashrsi3_64,
17401 rotldi3, *rotldi3_internal2, *rotldi3_internal3, *rotldi3_internal4,
17402 *rotldi3_internal5, *rotldi3_internal6, *rotldi3_internal7le,
17403 *rotldi3_internal7be, *rotldi3_internal8le, *rotldi3_internal8be,
17404 *rotldi3_internal9le, *rotldi3_internal9be, *rotldi3_internal10le,
17405 *rotldi3_internal10be, *rotldi3_internal11le, *rotldi3_internal11be,
17406 *rotldi3_internal12le, *rotldi3_internal12be, *rotldi3_internal13le,
17407 *rotldi3_internal13be, *rotldi3_internal14le, *rotldi3_internal14be,
17408 *rotldi3_internal15le, *rotldi3_internal15be, *ashldi3_internal1,
17409 *ashldi3_internal2, *ashldi3_internal3, *lshrdi3_internal1,
17410 *lshrdi3_internal2, *lshrdi3_internal3, *ashrdi3_internal1,
17411 *ashrdi3_internal2, *ashrdi3_internal3, *anddi3_internal2_mc,
17412 *anddi3_internal3_mc, as well as 11 anonymous define_insns): Adjust.
17413 * config/rs6000/rs6000.c (rs6000_adjust_cost, is_cracked_insn,
17414 insn_must_be_first_in_group, insn_must_be_last_in_group): Adjust.
17415
17416 * config/rs6000/40x.md (ppc403-integer, ppc403-compare): Adjust.
17417 * config/rs6000/440.md (ppc440-integer): Adjust.
17418 * config/rs6000/476.md (ppc476-simple-integer, ppc476-compare): Adjust.
17419 * config/rs6000/601.md (ppc601-integer, ppc601-compare): Adjust.
17420 * config/rs6000/603.md (ppc603-integer, ppc603-compare): Adjust.
17421 * config/rs6000/6xx.md (ppc604-integer, ppc604-compare): Adjust.
17422 * config/rs6000/7450.md (ppc7450-integer, ppc7450-compare): Adjust.
17423 * config/rs6000/7xx.md (ppc750-integer, ppc750-compare): Adjust.
17424 * config/rs6000/8540.md (ppc8540_su): Adjust.
17425 * config/rs6000/cell.md (cell-integer, cell-fast-cmp,
17426 cell-cmp-microcoded): Adjust.
17427 * config/rs6000/e300c2c3.md (ppce300c3_cmp): Adjust.
17428 * config/rs6000/e500mc.md (e500mc_su): Adjust.
17429 * config/rs6000/e500mc64.md (e500mc64_su, e500mc64_su2,
17430 e500mc64_delayed): Adjust.
17431 * config/rs6000/e5500.md (e5500_sfx, e5500_delayed): Adjust.
17432 * config/rs6000/e6500.md (e6500_sfx, e6500_delayed): Adjust.
17433 * config/rs6000/mpc.md (mpccore-integer, mpccore-compare): Adjust.
17434 * config/rs6000/power4.md (power4-integer, power4-compare): Adjust.
17435 * config/rs6000/power5.md (power5-integer, power5-compare): Adjust.
17436 * config/rs6000/power6.md (power6-shift, power6-var-rotate,
17437 power6-delayed-compare, power6-var-delayed-compare): Adjust.
17438 * config/rs6000/power7.md (power7-integer, power7-compare): Adjust.
17439 * config/rs6000/power8.md (power8-1cyc, power8-compare): Adjust.
17440 Adjust comment.
17441 * config/rs6000/rs64.md (rs64a-integer, rs64a-compare): Adjust.
17442 * config/rs6000/titan.md (titan_fxu_shift_and_rotate): Adjust.
17443
17444 2014-05-23 Segher Boessenkool <segher@kernel.crashing.org>
17445
17446 * config/rs6000/rs6000.md (type): Delete "idiv", "ldiv". Add "div".
17447 (bits): New mode_attr.
17448 (idiv_ldiv): Delete mode_attr.
17449 (udiv<mode>3, *div<mode>3, div<div_extend>_<mode>): Adjust.
17450 * config/rs6000/rs6000.c (rs6000_adjust_cost, is_cracked_insn,
17451 rs6000_adjust_priority, is_nonpipeline_insn,
17452 insn_must_be_first_in_group, insn_must_be_last_in_group): Adjust.
17453
17454 * config/rs6000/40x.md (ppc403-idiv): Adjust.
17455 * config/rs6000/440.md (ppc440-idiv): Adjust.
17456 * config/rs6000/476.md (ppc476-idiv): Adjust.
17457 * config/rs6000/601.md (ppc601-idiv): Adjust.
17458 * config/rs6000/603.md (ppc603-idiv): Adjust.
17459 * config/rs6000/6xx.md (ppc604-idiv, ppc620-idiv, ppc630-idiv,
17460 ppc620-ldiv): Adjust.
17461 * config/rs6000/7450.md (ppc7450-idiv): Adjust.
17462 * config/rs6000/7xx.md (ppc750-idiv): Adjust.
17463 * config/rs6000/8540.md (ppc8540_divide): Adjust.
17464 * config/rs6000/a2.md (ppca2-idiv, ppca2-ldiv): Adjust.
17465 * config/rs6000/cell.md (cell-idiv, cell-ldiv): Adjust.
17466 * config/rs6000/e300c2c3.md (ppce300c3_divide): Adjust.
17467 * config/rs6000/e500mc.md (e500mc_divide): Adjust.
17468 * config/rs6000/e500mc64.md (e500mc64_divide): Adjust.
17469 * config/rs6000/e5500.md (e5500_divide, e5500_divide_d): Adjust.
17470 * config/rs6000/e6500.md (e6500_divide, e6500_divide_d): Adjust.
17471 * config/rs6000/mpc.md (mpccore-idiv): Adjust.
17472 * config/rs6000/power4.md (power4-idiv, power4-ldiv): Adjust.
17473 * config/rs6000/power5.md (power5-idiv, power5-ldiv): Adjust.
17474 * config/rs6000/power6.md (power6-idiv, power6-ldiv): Adjust.
17475 * config/rs6000/power7.md (power7-idiv, power7-ldiv): Adjust.
17476 * config/rs6000/power8.md (power8-idiv, power8-ldiv): Adjust.
17477 * config/rs6000/rs64.md (rs64a-idiv, rs64a-ldiv): Adjust.
17478 * config/rs6000/titan.md (titan_fxu_div): Adjust.
17479
17480 2014-05-23 Segher Boessenkool <segher@kernel.crashing.org>
17481
17482 * config/rs6000/rs6000.md (type): Delete "insert_word",
17483 "insert_dword". Add "insert".
17484 (size): Update comment.
17485 * config/rs6000/rs6000.c (rs6000_adjust_cost, is_cracked_insn,
17486 insn_must_be_first_in_group): Adjust.
17487 (insvsi_internal, *insvsi_internal1, *insvsi_internal2,
17488 *insvsi_internal3, *insvsi_internal4, *insvsi_internal5,
17489 *insvsi_internal6, insvdi_internal): Adjust.
17490
17491 * config/rs6000/40x.md (ppc403-integer): Adjust.
17492 * config/rs6000/440.md (ppc440-integer): Adjust.
17493 * config/rs6000/476.md (ppc476-simple-integer): Adjust.
17494 * config/rs6000/601.md (ppc601-integer): Adjust.
17495 * config/rs6000/603.md (ppc603-integer): Adjust.
17496 * config/rs6000/6xx.md (ppc604-integer): Adjust.
17497 * config/rs6000/7450.md (ppc7450-integer): Adjust.
17498 * config/rs6000/7xx.md (ppc750-integer): Adjust.
17499 * config/rs6000/8540.md (ppc8540_su): Adjust.
17500 * config/rs6000/cell.md (cell-integer, cell-insert): Adjust.
17501 * config/rs6000/e300c2c3.md (ppce300c3_iu): Adjust.
17502 * config/rs6000/e500mc.md (e500mc_su): Adjust.
17503 * config/rs6000/e500mc64.md (e500mc64_su): Adjust.
17504 * config/rs6000/e5500.md (e5500_sfx): Adjust.
17505 * config/rs6000/e6500.md (e6500_sfx): Adjust.
17506 * config/rs6000/mpc.md (mpccore-integer): Adjust.
17507 * config/rs6000/power4.md (power4-integer, power4-insert): Adjust.
17508 * config/rs6000/power5.md (power5-integer, power5-insert): Adjust.
17509 * config/rs6000/power6.md (power6-insert, power6-insert-dword): Adjust.
17510 * config/rs6000/power7.md (power7-integer): Adjust.
17511 * config/rs6000/power8.md (power8-1cyc): Adjust.
17512 * config/rs6000/rs64.md (rs64a-integer): Adjust.
17513 * config/rs6000/titan.md (titan_fxu_shift_and_rotate): Adjust.
17514
17515 2014-05-23 Segher Boessenkool <segher@kernel.crashing.org>
17516
17517 * config/rs6000/rs6000.md (type): Add "mul". Delete "imul",
17518 "imul2", "imul3", "lmul", "imul_compare", "lmul_compare".
17519 (size): New attribute.
17520 (dot): New attribute.
17521 (cell_micro): Adjust.
17522 (mulsi3, *mulsi3_internal1, *mulsi3_internal2, mulsidi3,
17523 umulsidi3, smulsi3_highpart, umulsi3_highpart, muldi3,
17524 *muldi3_internal1, *muldi3_internal2, smuldi3_highpart,
17525 umuldi3_highpart): Adjust.
17526 * config/rs6000/rs6000.c (rs6000_adjust_cost, is_cracked_insn,
17527 rs6000_adjust_priority, is_nonpipeline_insn,
17528 insn_must_be_first_in_group, insn_must_be_last_in_group): Adjust.
17529
17530 * config/rs6000/40x.md (ppc403-imul, ppc405-imul, ppc405-imul2,
17531 ppc405-imul3): Adjust.
17532 * config/rs6000/440.md (ppc440-imul, ppc440-imul2): Adjust.
17533 * config/rs6000/476.md (ppc476-imul): Adjust.
17534 * config/rs6000/601.md (ppc601-imul): Adjust.
17535 * config/rs6000/603.md (ppc603-imul, ppc603-imul2): Adjust.
17536 * config/rs6000/6xx.md (ppc604-imul, ppc604e-imul, ppc620-imul,
17537 ppc620-imul2, ppc620-imul3, ppc620-lmul): Adjust.
17538 * config/rs6000/7450.md (ppc7450-imul, ppc7450-imul2): Adjust.
17539 * config/rs6000/7xx.md (ppc750-imul, ppc750-imul2, ppc750-imul3):
17540 Adjust.
17541 * config/rs6000/8540.md (ppc8540_multiply): Adjust.
17542 * config/rs6000/a2.md (ppca2-imul, ppca2-lmul): Adjust.
17543 * config/rs6000/cell.md (cell-lmul, cell-lmul-cmp, cell-imul23,
17544 cell-imul): Adjust.
17545 * config/rs6000/e300c2c3.md (ppce300c3_multiply): Adjust.
17546 * config/rs6000/e500mc.md (e500mc_multiply): Adjust.
17547 * config/rs6000/e500mc64.md (e500mc64_multiply): Adjust.
17548 * config/rs6000/e5500.md (e5500_multiply, e5500_multiply_i): Adjust.
17549 * config/rs6000/e6500.md (e6500_multiply, e6500_multiply_i): Adjust.
17550 * config/rs6000/mpc.md (mpccore-imul): Adjust.
17551 * config/rs6000/power4.md (power4-lmul-cmp, power4-imul-cmp,
17552 power4-lmul, power4-imul, power4-imul3): Adjust.
17553 * config/rs6000/power5.md (power5-lmul-cmp, power5-imul-cmp,
17554 power5-lmul, power5-imul, power5-imul3): Adjust.
17555 * config/rs6000/power6.md (power6-lmul-cmp, power6-imul-cmp,
17556 power6-lmul, power6-imul, power6-imul3): Adjust.
17557 * config/rs6000/power7.md (power7-mul, power7-mul-compare): Adjust.
17558 * config/rs6000/power8.md (power8-mul, power8-mul-compare): Adjust.
17559
17560 * config/rs6000/rs64.md (rs64a-imul, rs64a-imul2, rs64a-imul3,
17561 rs64a-lmul): Adjust.
17562 * config/rs6000/titan.md (titan_imul): Adjust.
17563
17564 2014-05-23 Segher Boessenkool <segher@kernel.crashing.org>
17565
17566 * config/rs6000/rs6000.md (type): Add new value "halfmul".
17567 (*macchwc, *macchw, *macchwuc, *macchwu, *machhwc, *machhw,
17568 *machhwuc, *machhwu, *maclhwc, *maclhw, *maclhwuc, *maclhwu,
17569 *nmacchwc, *nmacchw, *nmachhwc, *nmachhw, *nmaclhwc, *nmaclhw,
17570 *mulchwc, *mulchw, *mulchwuc, *mulchwu, *mulhhwc, *mulhhw,
17571 *mulhhwuc, *mulhhwu, *mullhwc, *mullhw, *mullhwuc, *mullhwu): Use it.
17572 * config/rs6000/40x.md (ppc405-imul3): Add type halfmul.
17573 * config/rs6000/440.md (ppc440-imul2): Add type halfmul.
17574 * config/rs6000/476.md (ppc476-imul): Add type halfmul.
17575 * config/rs6000/titan.md: Delete nonsensical comment.
17576 (titan_imul): Add type imul3.
17577 (titan_mulhw): Remove type imul3; add type halfmul.
17578
17579 2014-05-23 Segher Boessenkool <segher@kernel.crashing.org>
17580
17581 * config/rs6000/rs6000.md (type): Reorder, reformat.
17582
17583 2014-05-23 Martin Jambor <mjambor@suse.cz>
17584
17585 PR tree-optimization/53787
17586 * params.def (PARAM_IPA_MAX_AA_STEPS): New param.
17587 * ipa-prop.h (ipa_node_params): Rename uses_analysis_done to
17588 analysis_done, update all uses.
17589 * ipa-prop.c: Include domwalk.h
17590 (param_analysis_info): Removed.
17591 (param_aa_status): New type.
17592 (ipa_bb_info): Likewise.
17593 (func_body_info): Likewise.
17594 (ipa_get_bb_info): New function.
17595 (aa_overwalked): Likewise.
17596 (find_dominating_aa_status): Likewise.
17597 (parm_bb_aa_status_for_bb): Likewise.
17598 (parm_preserved_before_stmt_p): Changed to use new param AA info.
17599 (load_from_unmodified_param): Accept func_body_info as a parameter
17600 instead of parms_ainfo.
17601 (parm_ref_data_preserved_p): Changed to use new param AA info.
17602 (parm_ref_data_pass_through_p): Likewise.
17603 (ipa_load_from_parm_agg_1): Likewise. Update callers.
17604 (compute_complex_assign_jump_func): Changed to use new param AA info.
17605 (compute_complex_ancestor_jump_func): Likewise.
17606 (ipa_compute_jump_functions_for_edge): Likewise.
17607 (ipa_compute_jump_functions): Removed.
17608 (ipa_compute_jump_functions_for_bb): New function.
17609 (ipa_analyze_indirect_call_uses): Likewise, moved variable
17610 declarations down.
17611 (ipa_analyze_virtual_call_uses): Accept func_body_info instead of node
17612 and info, moved variable declarations down.
17613 (ipa_analyze_call_uses): Accept and pass on func_body_info instead of
17614 node and info.
17615 (ipa_analyze_stmt_uses): Likewise.
17616 (ipa_analyze_params_uses): Removed.
17617 (ipa_analyze_params_uses_in_bb): New function.
17618 (ipa_analyze_controlled_uses): Likewise.
17619 (free_ipa_bb_info): Likewise.
17620 (analysis_dom_walker): New class.
17621 (ipa_analyze_node): Handle node-specific forbidden analysis,
17622 initialize and free func_body_info, use dominator walker.
17623 (ipcp_modif_dom_walker): New class.
17624 (ipcp_transform_function): Create and free func_body_info, use
17625 ipcp_modif_dom_walker, moved a lot of functionality there.
17626
17627 2014-05-23 Marek Polacek <polacek@redhat.com>
17628 Jakub Jelinek <jakub@redhat.com>
17629
17630 * builtins.def: Change SANITIZE_FLOAT_DIVIDE to SANITIZE_NONDEFAULT.
17631 * gcc.c (sanitize_spec_function): Likewise.
17632 * convert.c (convert_to_integer): Include "ubsan.h". Add
17633 floating-point to integer instrumentation.
17634 * doc/invoke.texi: Document -fsanitize=float-cast-overflow.
17635 * flag-types.h (enum sanitize_code): Add SANITIZE_FLOAT_CAST and
17636 SANITIZE_NONDEFAULT.
17637 * opts.c (common_handle_option): Handle -fsanitize=float-cast-overflow.
17638 * sanitizer.def (BUILT_IN_UBSAN_HANDLE_FLOAT_CAST_OVERFLOW,
17639 BUILT_IN_UBSAN_HANDLE_FLOAT_CAST_OVERFLOW_ABORT): Add.
17640 * ubsan.c: Include "realmpfr.h" and "dfp.h".
17641 (get_ubsan_type_info_for_type): Handle REAL_TYPEs.
17642 (ubsan_type_descriptor): Set tkind to 0xffff for types other than
17643 float/double/long double.
17644 (ubsan_instrument_float_cast): New function.
17645 * ubsan.h (ubsan_instrument_float_cast): Declare.
17646
17647 2014-05-23 Jiong Wang <jiong.wang@arm.com>
17648
17649 * config/aarch64/predicates.md (aarch64_call_insn_operand): New
17650 predicate.
17651 * config/aarch64/constraints.md ("Ucs", "Usf"): New constraints.
17652 * config/aarch64/aarch64.md (*sibcall_insn, *sibcall_value_insn):
17653 Adjust for tailcalling through registers.
17654 * config/aarch64/aarch64.h (enum reg_class): New caller save
17655 register class.
17656 (REG_CLASS_NAMES): Likewise.
17657 (REG_CLASS_CONTENTS): Likewise.
17658 * config/aarch64/aarch64.c (aarch64_function_ok_for_sibcall):
17659 Allow tailcalling without decls.
17660
17661 2014-05-23 Thomas Schwinge <thomas@codesourcery.com>
17662
17663 * gimplify.c (omp_notice_variable) <case OMP_CLAUSE_DEFAULT_NONE>:
17664 Rewrite check for ORT_PARALLEL and ORT_COMBINED_PARALLEL.
17665
17666 * omp-low.c (expand_omp_for_static_chunk): Rename variable si to
17667 gsi, and variables v_* to v*.
17668
17669 2014-05-23 Eric Botcazou <ebotcazou@adacore.com>
17670
17671 * varasm.c (output_constructor_bitfield): Fix thinkos in latest change.
17672
17673 2014-05-23 Thomas Schwinge <thomas@codesourcery.com>
17674
17675 * gimple.h (enum gf_mask): Add and use GF_OMP_FOR_SIMD.
17676 * omp-low.c: Update accordingly.
17677
17678 * gimple.h (enum gf_mask): Rewrite "<< 0" shift expressions used
17679 for GF_OMP_FOR_KIND_MASK, GF_OMP_FOR_KIND_FOR,
17680 GF_OMP_FOR_KIND_DISTRIBUTE, GF_OMP_FOR_KIND_SIMD,
17681 GF_OMP_FOR_KIND_CILKSIMD, GF_OMP_TARGET_KIND_MASK,
17682 GF_OMP_TARGET_KIND_REGION, GF_OMP_TARGET_KIND_DATA,
17683 GF_OMP_TARGET_KIND_UPDATE.
17684
17685 * gimplify.c (omp_notice_variable) <case OMP_CLAUSE_DEFAULT_NONE>:
17686 Explicitly enumerate the expected region types.
17687
17688 2014-05-23 Paul Eggert <eggert@cs.ucla.edu>
17689
17690 PR other/56955
17691 * doc/extend.texi (Function Attributes): Fix __attribute__ ((malloc))
17692 documentation; the old documentation didn't clearly state the
17693 constraints on the contents of the pointed-to storage.
17694
17695 2014-05-23 Maxim Kuvyrkov <maxim.kuvyrkov@linaro.org>
17696
17697 Fix bootstrap error on ia64
17698 * config/ia64/ia64.c (ia64_first_cycle_multipass_dfa_lookahead_guard):
17699 Return default value.
17700
17701 2014-05-23 Thomas Preud'homme <thomas.preudhomme@arm.com>
17702
17703 PR tree-optimization/54733
17704 * tree-ssa-math-opts.c (nop_stats): New "bswap_stats" structure.
17705 (CMPNOP): Define.
17706 (find_bswap_or_nop_load): New.
17707 (find_bswap_1): Renamed to ...
17708 (find_bswap_or_nop_1): This. Also add support for memory source.
17709 (find_bswap): Renamed to ...
17710 (find_bswap_or_nop): This. Also add support for memory source and
17711 detection of bitwise operations equivalent to load in target
17712 endianness.
17713 (execute_optimize_bswap): Likewise. Also move its leading comment back
17714 in place and split statement transformation into ...
17715 (bswap_replace): This.
17716
17717 2014-05-22 Vladimir Makarov <vmakarov@redhat.com>
17718
17719 PR rtl-optimization/61215
17720 * lra-elelimination.c (lra_eliminate_regs_1): Don't use
17721 simplify_gen_subreg until final substitution.
17722
17723 2014-05-23 Alan Modra <amodra@gmail.com>
17724
17725 PR target/61231
17726 * config/rs6000/rs6000.c (mem_operand_gpr): Handle SImode.
17727 * config/rs6000/rs6000.md (extendsidi2_lfiwax, extendsidi2_nocell):
17728 Use "Y" constraint rather than "m".
17729
17730 2014-05-23 Kugan Vivekanandarajah <kuganv@linaro.org>
17731
17732 * config/aarch64/aarch64.c (TARGET_ATOMIC_ASSIGN_EXPAND_FENV): New
17733 define.
17734 * config/aarch64/aarch64-protos.h (aarch64_atomic_assign_expand_fenv):
17735 New function declaration.
17736 * config/aarch64/aarch64-builtins.c (aarch64_builtins) : Add
17737 AARCH64_BUILTIN_GET_FPCR, AARCH64_BUILTIN_SET_FPCR.
17738 AARCH64_BUILTIN_GET_FPSR and AARCH64_BUILTIN_SET_FPSR.
17739 (aarch64_init_builtins) : Initialize builtins
17740 __builtins_aarch64_set_fpcr, __builtins_aarch64_get_fpcr.
17741 __builtins_aarch64_set_fpsr and __builtins_aarch64_get_fpsr.
17742 (aarch64_expand_builtin) : Expand builtins __builtins_aarch64_set_fpcr
17743 __builtins_aarch64_get_fpcr, __builtins_aarch64_get_fpsr,
17744 and __builtins_aarch64_set_fpsr.
17745 (aarch64_atomic_assign_expand_fenv): New function.
17746 * config/aarch64/aarch64.md (set_fpcr): New pattern.
17747 (get_fpcr) : Likewise.
17748 (set_fpsr) : Likewise.
17749 (get_fpsr) : Likewise.
17750 (unspecv): Add UNSPECV_GET_FPCR and UNSPECV_SET_FPCR, UNSPECV_GET_FPSR
17751 and UNSPECV_SET_FPSR.
17752 * doc/extend.texi (AARCH64 Built-in Functions) : Document
17753 __builtins_aarch64_set_fpcr, __builtins_aarch64_get_fpcr.
17754 __builtins_aarch64_set_fpsr and __builtins_aarch64_get_fpsr.
17755
17756 2014-05-22 Vladimir Makarov <vmakarov@redhat.com>
17757
17758 PR rtl-optimization/60969
17759 * ira-costs.c (record_reg_classes): Process NO_REGS for matching
17760 constraints. Set up mem cost for NO_REGS case.
17761
17762 2014-05-22 Thomas Schwinge <thomas@codesourcery.com>
17763
17764 * builtin-types.def: Simplify examples for DEF_FUNCTION_TYPE_*.
17765
17766 2012-05-22 Bernd Schmidt <bernds@codesourcery.com>
17767
17768 * config/darwin.c: Include "lto-section-names.h".
17769 (LTO_SEGMENT_NAME): Don't define.
17770 * config/i386/winnt.c: Include "lto-section-names.h".
17771 * lto-streamer.c: Include "lto-section-names.h".
17772 * lto-streamer.h (LTO_SECTION_NAME_PREFIX): Don't define.
17773 * lto-wrapper.c: Include "lto-section-names.h".
17774 (LTO_SECTION_NAME_PREFIX): Don't define.
17775 * lto-section-names.h: New file.
17776 * cgraphunit.c: Include "lto-section-names.h".
17777
17778 2014-05-22 Peter Bergner <bergner@vnet.ibm.com>
17779
17780 * config/rs6000/htm.md (ttest): Use correct shift value to get CR0.
17781
17782 2014-05-22 Richard Earnshaw <rearnsha@arm.com>
17783
17784 PR target/61208
17785 * arm.md (arm_cmpdi_unsigned): Fix length calculation for Thumb2.
17786
17787 2014-05-22 Nick Clifton <nickc@redhat.com>
17788
17789 * config/msp430/msp430.h (ASM_SPEC): Add spaces after inserted options.
17790
17791 2014-05-22 Eric Botcazou <ebotcazou@adacore.com>
17792
17793 * tree-ssa-forwprop.c (associate_plusminus): Extend (T)(P + A) - (T)P
17794 -> (T)A transformation to integer types.
17795
17796 2014-05-22 Teresa Johnson <tejohnson@google.com>
17797
17798 * gcov-io.c (gcov_position): Use gcov_nonruntime_assert.
17799 (gcov_is_error): Remove gcc_assert from IN_LIBGCOV code.
17800 (gcov_rewrite): Use gcov_nonruntime_assert.
17801 (gcov_open): Ditto.
17802 (gcov_write_words): Ditto.
17803 (gcov_write_length): Ditto.
17804 (gcov_read_words): Use gcov_nonruntime_assert, and remove
17805 gcc_assert from IN_LIBGCOV code.
17806 (gcov_read_summary): Use gcov_error to flag profile corruption.
17807 (gcov_sync): Use gcov_nonruntime_assert.
17808 (gcov_seek): Remove gcc_assert from IN_LIBGCOV code.
17809 (gcov_histo_index): Use gcov_nonruntime_assert.
17810 (static void gcov_histogram_merge): Ditto.
17811 (compute_working_sets): Ditto.
17812 * gcov-io.h (gcov_nonruntime_assert): Define.
17813 (gcov_error): Define for !IN_LIBGCOV
17814
17815 2014-05-22 Richard Biener <rguenther@suse.de>
17816
17817 * tree-ssa-alias.c (ref_maybe_used_by_call_p_1): Handle
17818 BUILT_IN_REALLOC like BUILT_IN_STRDUP.
17819 (call_may_clobber_ref_p_1): Handle BUILT_IN_REALLOC as allocation
17820 and deallocation site.
17821 * tree-ssa-structalias.c (find_func_aliases_for_builtin_call):
17822 Handle BUILT_IN_REALLOC similar to BUILT_IN_STRDUP with also
17823 passing through the incoming points-to set.
17824 (handle_lhs_call): Use flags argument instead of recomputing it.
17825 (find_func_aliases_for_call): Call handle_lhs_call with proper
17826 call return flags.
17827
17828 2014-05-22 Jakub Jelinek <jakub@redhat.com>
17829
17830 * tree-streamer-in.c (unpack_ts_real_cst_value_fields): Make sure
17831 all padding bits in REAL_VALUE_TYPE are cleared.
17832
17833 2014-05-22 Maxim Kuvyrkov <maxim.kuvyrkov@linaro.org>
17834
17835 Cleanup and improve multipass_dfa_lookahead_guard
17836 * config/i386/i386.c (core2i7_first_cycle_multipass_filter_ready_try,)
17837 (core2i7_first_cycle_multipass_begin,)
17838 (core2i7_first_cycle_multipass_issue,)
17839 (core2i7_first_cycle_multipass_backtrack): Update signature.
17840 * config/ia64/ia64.c
17841 (ia64_first_cycle_multipass_dfa_lookahead_guard_spec): Remove.
17842 (ia64_first_cycle_multipass_dfa_lookahead_guard): Update signature.
17843 (TARGET_SCHED_FIRST_CYCLE_MULTIPASS_DFA_LOOKAHEAD_GUARD_SPEC): Remove
17844 hook definition.
17845 (ia64_first_cycle_multipass_dfa_lookahead_guard): Merge logic from
17846 ia64_first_cycle_multipass_dfa_lookahead_guard_spec. Update return
17847 values.
17848 * config/rs6000/rs6000.c (rs6000_use_sched_lookahead_guard): Update
17849 return values.
17850 * doc/tm.texi: Regenerate.
17851 * doc/tm.texi.in
17852 (TARGET_SCHED_FIRST_CYCLE_MULTIPASS_DFA_LOOKAHEAD_GUARD_SPEC): Remove.
17853 * haifa-sched.c (ready_try): Make signed to allow negative values.
17854 (rebug_ready_list_1): Update.
17855 (choose_ready): Simplify.
17856 (sched_extend_ready_list): Update.
17857
17858 2014-05-22 Maxim Kuvyrkov <maxim.kuvyrkov@linaro.org>
17859
17860 Remove IA64 speculation tweaking flags
17861 * config/ia64/ia64.c (ia64_set_sched_flags): Delete handling of
17862 speculation tuning flags.
17863 (msched-prefer-non-data-spec-insns,)
17864 (msched-prefer-non-control-spec-insns): Obsolete options.
17865 * haifa-sched.c (choose_ready): Remove handling of
17866 PREFER_NON_CONTROL_SPEC and PREFER_NON_DATA_SPEC.
17867 * sched-int.h (enum SPEC_SCHED_FLAGS): Remove PREFER_NON_CONTROL_SPEC
17868 and PREFER_NON_DATA_SPEC.
17869 * sel-sched.c (process_spec_exprs): Remove handling of
17870 PREFER_NON_CONTROL_SPEC and PREFER_NON_DATA_SPEC.
17871
17872 2014-05-22 Maxim Kuvyrkov <maxim.kuvyrkov@linaro.org>
17873
17874 Improve scheduling debug output
17875 * haifa-sched.c (debug_ready_list): Remove unnecessary prototype.
17876 (advance_one_cycle): Update.
17877 (schedule_insn, queue_to_ready): Add debug printouts.
17878 (debug_ready_list_1): New static function.
17879 (debug_ready_list): Update.
17880 (max_issue): Add debug printouts.
17881 (dump_insn_stream): New static function.
17882 (schedule_block): Use it. Also better indent printouts.
17883
17884 2014-05-22 Maxim Kuvyrkov <maxim.kuvyrkov@linaro.org>
17885
17886 Fix sched_insn debug counter
17887 * haifa-sched.c (schedule_insn): Update.
17888 (struct haifa_saved_data): Add nonscheduled_insns_begin.
17889 (save_backtrack_point, restore_backtrack_point): Update.
17890 (first_nonscheduled_insn): New static function.
17891 (queue_to_ready, choose_ready): Use it.
17892 (schedule_block): Init nonscheduled_insns_begin.
17893 (sched_emit_insn): Update.
17894
17895
17896 2014-05-22 Kugan Vivekanandarajah <kuganv@linaro.org>
17897
17898 * config/aarch64/aarch64.c (aarch64_regno_regclass) : Change CORE_REGS
17899 to GENERAL_REGS.
17900 (aarch64_secondary_reload) : LikeWise.
17901 (aarch64_class_max_nregs) : Remove CORE_REGS.
17902 * config/aarch64/aarch64.h (enum reg_class) : Remove CORE_REGS.
17903 (REG_CLASS_NAMES) : Likewise.
17904 (REG_CLASS_CONTENTS) : LikeWise.
17905 (INDEX_REG_CLASS) : Change CORE_REGS to GENERAL_REGS.
17906
17907 2014-05-21 Guozhi Wei <carrot@google.com>
17908
17909 PR target/61202
17910 * config/aarch64/arm_neon.h (vqdmulh_n_s16): Change the last operand's
17911 constraint.
17912 (vqdmulhq_n_s16): Likewise.
17913
17914 2014-05-21 Segher Boessenkool <segher@kernel.crashing.org>
17915
17916 * config/rs6000/predicates.md (update_indexed_address_mem): Delete.
17917
17918 2014-05-21 Marek Polacek <polacek@redhat.com>
17919
17920 PR sanitizer/61272
17921 * ubsan.c (is_ubsan_builtin_p): Turn assert into a condition.
17922
17923 2014-05-21 Martin Jambor <mjambor@suse.cz>
17924
17925 * doc/invoke.texi (Optimize Options): Document parameters
17926 ipa-cp-eval-threshold, ipa-max-agg-items, ipa-cp-loop-hint-bonus and
17927 ipa-cp-array-index-hint-bonus.
17928
17929 2014-05-21 Mark Wielaard <mjw@redhat.com>
17930
17931 PR debug/16063
17932 * dwarf2out.c (gen_enumeration_type_die): Add DW_AT_type if DWARF
17933 version >= 3 or not strict DWARF.
17934 * langhooks.h (struct lang_hooks_for_types): Add
17935 enum_underlying_base_type.
17936 * langhooks.c (lhd_enum_underlying_base_type): New function.
17937 * gcc/langhooks.h (struct lang_hooks_for_types): Add
17938 enum_underlying_base_type.
17939 * langhooks-def.h (lhd_enum_underlying_base_type): New declaration.
17940 (LANG_HOOKS_ENUM_UNDERLYING_BASE_TYPE): New define.
17941 (LANG_HOOKS_FOR_TYPES_INITIALIZER): Add new lang hook.
17942
17943 2014-05-21 Richard Biener <rguenther@suse.de>
17944
17945 * doc/invoke.texi (-flto-partition=): Document one and none algorithms.
17946
17947 2014-05-21 John Marino <gnugcc@marino.st>
17948
17949 * config.gcc (*-*-dragonfly*): New target.
17950 * configure.ac: Detect dl_iterate_phdr (*freebsd*, *dragonfly*).
17951 * configure: Regenerate.
17952 * config/dragonfly-stdint.h: New.
17953 * config/dragonfly.h: New.
17954 * config/dragonfly.opt: New.
17955 * config/i386/dragonfly.h: New.
17956 * ginclude/stddef.h: Detect _PTRDIFF_T_DECLARED for DragonFly.
17957
17958 2014-05-21 Richard Sandiford <rsandifo@linux.vnet.ibm.com>
17959
17960 * tree.def (VOID_CST): New.
17961 * tree-core.h (TI_VOID): New.
17962 * tree.h (void_node): New.
17963 * tree.c (tree_node_structure_for_code, tree_code_size)
17964 (iterative_hash_expr): Handle VOID_CST.
17965 (build_common_tree_nodes): Initialize void_node.
17966
17967 2014-05-21 Bernd Schmidt <bernds@codesourcery.com>
17968
17969 * reload1.c (remove_init_insns, will_delete_init_insn_p): New static
17970 functions.
17971 (reload, calculate_needs_all_insns, reload_as_needed): Use them.
17972
17973 * config/bfin/bfin.c (split_load_immediate): Use gen_int_mode in a few
17974 more places.
17975
17976 * cfgrtl.c (cfg_layout_initialize): Weaken assert to only trigger if
17977 flag_reorder_blocks_and_partition.
17978 * hw-doloop.c (reorg_loops): Avoid reordering if that flag is set.
17979
17980 2014-05-21 Oleg Endo <olegendo@gcc.gnu.org>
17981
17982 PR target/54236
17983 * config/sh/sh.md (*addc_r_1): Rename to addc_t_r. Remove empty
17984 constraints.
17985 (*addc_r_t): Add new insn_and_split.
17986
17987 2014-05-21 Jakub Jelinek <jakub@redhat.com>
17988
17989 PR middle-end/61252
17990 * omp-low.c (handle_simd_reference): New function.
17991 (lower_rec_input_clauses): Use it. Defer adding reference
17992 initialization even for reduction without placeholder if in simd,
17993 handle it properly later on.
17994
17995 2014-05-20 Jan Hubicka <hubicka@ucw.cz>
17996
17997 PR tree-optimization/60899
17998 * gimple-fold.c (can_refer_decl_in_current_unit_p): Cleanup;
17999 assume all static symbols will have definition wile parsing and
18000 check the do have definition later in compilation; check that
18001 variable referring symbol will be output before concluding that
18002 reference is safe; be conservative for referring local statics;
18003 be more precise about when comdat is output in other partition.
18004
18005 2014-05-20 Jan Hubicka <hubicka@ucw.cz>
18006
18007 PR bootstrap/60984
18008 * ipa-inline-transform.c (inline_call): Use add CALLEE_REMOVED
18009 parameter.
18010 * ipa-inline.c (inline_to_all_callers): If callee was removed; return.
18011 (ipa_inline): Loop inline_to_all_callers until no more aliases
18012 are removed.
18013
18014 2014-05-20 Jan Hubicka <hubicka@ucw.cz>
18015
18016 * ipa.c (ipa_discover_readonly_nonaddressable_var): Fix dumping;
18017 set writeonly flag only for vars actually written to.
18018
18019 2014-05-20 Dehao Chen <dehao@google.com>
18020
18021 * ipa-inline-transform.c (clone_inlined_nodes): Use min of edge count
18022 and callee count to get clone count.
18023 * tree-inline.c (expand_call_inline): Use callee count instead of bb
18024 count in copy_body.
18025
18026 2014-05-20 Richard Sandiford <rdsandiford@googlemail.com>
18027
18028 PR rtl-optimization/61243
18029 * emit-rtl.c (emit_copy_of_insn_after): Copy CROSSING_JUMP_P.
18030
18031 2014-05-20 Xinliang David Li <davidxl@google.com>
18032
18033 * cgraphunit.c (walk_polymorphic_call_targets): Add
18034 dbgcnt and fopt-info support.
18035 * ipa-prop.c (ipa_make_edge_direct_to_target): Ditto.
18036 * ipa-devirt.c (ipa_devirt): Ditto.
18037 * tree-ssa-pre.c (eliminate_dom_walker::before_dom_children): Ditto.
18038 * ipa.c (walk_polymorphic_call_targets): Ditto.
18039 * gimple-fold.c (fold_gimple_assign): Ditto.
18040 (gimple_fold_call): Ditto.
18041 * dbgcnt.def: New counter.
18042
18043 2014-05-20 DJ Delorie <dj@redhat.com>
18044
18045 * config/msp430/msp430.md (split): Don't allow subregs when
18046 splitting SImode adds.
18047 (andneghi): Fix subtraction logic.
18048 * config/msp430/predicates.md (msp430_nonsubreg_or_imm_operand): New.
18049
18050 2014-05-20 Jan Hubicka <hubicka@ucw.cz>
18051
18052 * tree.h (DECL_ONE_ONLY): Return true only for externally visible
18053 symbols.
18054 * except.c (switch_to_exception_section, resolve_unique_section,
18055 get_named_text_section, default_function_rodata_section,
18056 align_variable, get_block_for_decl, default_section_type_flags):
18057 Use DECL_COMDAT_GROUP instead of DECL_ONE_ONLY.
18058 * symtab.c (symtab_add_to_same_comdat_group,
18059 symtab_make_decl_local, fixup_same_cpp_alias_visibility,
18060 symtab_nonoverwritable_alias, symtab_get_symbol_partitioning_class):
18061 Likewise.
18062 * cgraphclones.c (cgraph_create_virtual_clone): Likewise.
18063 * bb-reorder.c (pass_partition_blocks::gate): Likewise.
18064 * config/c6x/c6x.c (c6x_elf_unique_section): Likewise.
18065 (c6x_function_in_section_p): Likewise.
18066 * config/darwin.c (machopic_select_section): Likewise.
18067 * config/arm/arm.c (arm_function_in_section_p): Likewise.
18068 * config/mips/mips.c (mips_function_rodata_section): Likewise.
18069 * config/mep/mep.c (mep_select_section): LIkewise.
18070 * config/i386/i386.c (x86_64_elf_unique_section): Likewise.
18071
18072 2014-05-20 Eric Botcazou <ebotcazou@adacore.com>
18073
18074 * tree-ssa-dom.c (hashable_expr_equal_p) <EXPR_CALL>: Also compare the
18075 EH region of calls to pure functions that can throw an exception.
18076 * tree-ssa-sccvn.c (vn_reference_eq): Remove duplicated test.
18077 (copy_reference_ops_from_call): Also copy the EH region of the call if
18078 it can throw an exception.
18079
18080 2014-05-20 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
18081
18082 * simplify-rtx.c (simplify_binary_operation_1): Optimize case of
18083 nested VEC_SELECTs that are inverses of each other.
18084
18085 2014-05-20 Richard Biener <rguenther@suse.de>
18086
18087 * tree-ssa-sccvn.c (process_scc): Dump SCC here, when iterating,
18088 (extract_and_process_scc_for_name): not here.
18089 (cond_dom_walker::before_dom_children): Only process
18090 stmts that end the BB in interesting ways.
18091 (run_scc_vn): Mark param uses as visited.
18092
18093 2014-05-20 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
18094
18095 * config/arm/arm.md (arith_shiftsi): Do not predicate for
18096 arm_restrict_it.
18097
18098 2014-05-20 Nick Clifton <nickc@redhat.com>
18099
18100 * config/msp430/msp430.c (TARGET_GIMPLIFY_VA_ARG_EXPR): Define.
18101 (msp430_gimplify_va_arg_expr): New function.
18102 (msp430_print_operand): Handle (CONST (ZERO_EXTRACT)).
18103
18104 * config/msp430/msp430.md (zero_extendpsisi2): Use + constraint on
18105 operand 0 in order to prevent confusion about the number of
18106 registers involved.
18107
18108 2014-05-20 Richard Biener <rguenther@suse.de>
18109
18110 PR tree-optimization/61221
18111 * tree-ssa-pre.c (el_to_update): Remove.
18112 (eliminate_dom_walker::before_dom_children): Handle released
18113 VDEFs by value-numbering them to the associated VUSE. Update
18114 stmt immediately for substituted call address.
18115 (eliminate): Remove delayed stmt updating code.
18116 * tree-ssa-sccvn.c (vuse_ssa_val): New function valueizing
18117 possibly late re-numbered vuses.
18118 (vn_reference_lookup_2): Adjust.
18119 (vn_reference_lookup_pieces): Likewise.
18120 (vn_reference_lookup): Likewise.
18121
18122 2014-05-20 Richard Biener <rguenther@suse.de>
18123
18124 * config.gcc: Remove need_64bit_hwint.
18125 * configure.ac: Do not define NEED_64BIT_HOST_WIDE_INT.
18126 * hwint.h: Do not check NEED_64BIT_HOST_WIDE_INT but assume
18127 it to be true.
18128 * config.in: Regenerate.
18129 * configure: Likewise.
18130
18131 2014-05-19 David Wohlferd <dw@LimeGreenSocks.com>
18132
18133 * doc/extend.texi: Create Label Attributes section,
18134 move all label attributes into it and reference it.
18135
18136 2014-05-19 Richard Earnshaw <rearnsha@arm.com>
18137
18138 * arm.c (thumb1_reorg): When scanning backwards skip anything
18139 that's not a proper insn.
18140
18141 2014-05-19 Richard Biener <rguenther@suse.de>
18142
18143 PR tree-optimization/61221
18144 * tree-ssa-pre.c (eliminate_dom_walker::before_dom_children):
18145 Do nothing for unreachable blocks.
18146 * tree-ssa-sccvn.c (cond_dom_walker::before_dom_children):
18147 Improve unreachability detection.
18148
18149 2014-05-19 Richard Biener <rguenther@suse.de>
18150
18151 PR tree-optimization/61209
18152 * tree-ssa-sccvn.c (visit_phi): Avoid setting expr to VN_TOP.
18153
18154 2014-05-19 Nick Clifton <nickc@redhat.com>
18155
18156 * except.c (init_eh): Fix computation of builtin setjmp buffer
18157 size to allow for targets where POINTER_SIZE > BITS_PER_WORD.
18158
18159 2014-05-19 Richard Biener <rguenther@suse.de>
18160
18161 PR tree-optimization/61184
18162 * tree-vrp.c (is_negative_overflow_infinity): Use
18163 TREE_OVERFLOW_P and do that check first.
18164 (is_positive_overflow_infinity): Likewise.
18165 (is_overflow_infinity): Likewise.
18166 (vrp_operand_equal_p): Properly treat operands with
18167 differing overflow as not equal.
18168
18169 2014-05-19 Bernd Schmidt <bernds@codesourcery.com>
18170
18171 * simplify-rtx.c (simplify_unary_operation_1): Use CONST_INT_P in
18172 shift simplification where it was intended.
18173
18174 2014-05-19 Christian Bruel <christian.bruel@st.com>
18175
18176 PR target/61195
18177 * config/sh/sh.md (movsf_ie): Unset fp_mode for fmov.
18178
18179 2014-05-19 Richard Sandiford <r.sandiford@uk.ibm.com>
18180
18181 PR target/61084
18182 * config/sparc/sparc.c (sparc_fold_builtin): Use widest_int rather
18183 than wide_int.
18184
18185 2014-05-19 Richard Sandiford <rdsandiford@googlemail.com>
18186
18187 * reg-notes.def (CROSSING_JUMP): Likewise.
18188 * rtl.h (rtx_def): Update comment for jump flag.
18189 (CROSSING_JUMP_P): Define.
18190 * cfgcleanup.c (try_forward_edges, try_optimize_cfg): Use it instead
18191 of a REG_CROSSING_JUMP note.
18192 * cfghooks.c (tidy_fallthru_edges): Likewise.
18193 * cfgrtl.c (fixup_partition_crossing, rtl_verify_edges): Likewise.
18194 * emit-rtl.c (try_split): Likewise.
18195 * haifa-sched.c (sched_create_recovery_edges): Likewise.
18196 * ifcvt.c (find_if_case_1, find_if_case_2): Likewise.
18197 * jump.c (redirect_jump_2): Likewise.
18198 * reorg.c (follow_jumps, fill_slots_from_thread): Likewise.
18199 (relax_delay_slots): Likewise.
18200 * config/arc/arc.md (jump_i, cbranchsi4_scratch, *bbit): Likewise.
18201 (bbit_di): Likewise.
18202 * config/arc/arc.c (arc_reorg, arc_can_follow_jump): Likewise.
18203 * config/sh/sh.md (jump_compact): Likewise.
18204 * bb-reorder.c (rotate_loop): Likewise.
18205 (pass_duplicate_computed_gotos::execute): Likewise.
18206 (add_reg_crossing_jump_notes): Rename to...
18207 (update_crossing_jump_flags): ...this.
18208 (pass_partition_blocks::execute): Update accordingly.
18209
18210 2014-05-19 Richard Sandiford <rdsandiford@googlemail.com>
18211
18212 * tree.h: Remove extraneous template <>.
18213
18214 2014-05-17 Jan Hubicka <hubicka@ucw.cz>
18215
18216 * ipa.c (symtab_remove_unreachable_nodes): Remove
18217 symbol from comdat group if its body was eliminated.
18218 (comdat_can_be_unshared_p_1): Static symbols can always be privatized.
18219 * symtab.c (symtab_remove_from_same_comdat_group): Break out from ...
18220 (symtab_unregister_node): ... this one.
18221 (verify_symtab_base): More strict checking of comdats.
18222 * cgraph.h (symtab_remove_from_same_comdat_group): Declare.
18223
18224 2014-05-17 Jan Hubicka <hubicka@ucw.cz>
18225
18226 * tree-pass.h (make_pass_ipa_comdats): New pass.
18227 * timevar.def (TV_IPA_COMDATS): New timevar.
18228 * passes.def (pass_ipa_comdats): Add.
18229 * Makefile.in (OBJS): Add ipa-comdats.o
18230 * ipa-comdats.c: New file.
18231
18232 2014-05-17 Jan Hubicka <hubicka@ucw.cz>
18233
18234 * ipa.c (update_visibility_by_resolution_info): New function.
18235 (function_and_variable_visibility): Use it.
18236
18237 2014-05-17 Jan Hubicka <hubicka@ucw.cz>
18238
18239 * cgraph.h (symtab_first_defined_symbol, symtab_next_defined_symbol):
18240 New functions.
18241 (FOR_EACH_DEFINED_SYMBOL): New macro.
18242 (varpool_first_static_initializer, varpool_next_static_initializer,
18243 varpool_first_defined_variable, varpool_next_defined_variable):
18244 Fix comments.
18245 (symtab_in_same_comdat_p): Correctly deal with inline functions.
18246
18247 2014-05-17 Trevor Saunders <tsaunders@mozilla.com>
18248
18249 * ggc-page.c (ggc_handle_finalizers): Add comment.
18250
18251 2014-05-17 Trevor Saunders <tsaunders@mozilla.com>
18252
18253 * ggc-common.c (ggc_internal_cleared_alloc): Adjust.
18254 * ggc-none.c (ggc_internal_alloc): Assert if a finalizer is passed.
18255 (ggc_internal_cleared_alloc): Likewise.
18256 * ggc-page.c (finalizer): New class.
18257 (vec_finalizer): Likewise.
18258 (globals::finalizers): New member.
18259 (globals::vec_finalizers): Likewise.
18260 (ggc_internal_alloc): Record the finalizer if any for the block being
18261 allocated.
18262 (ggc_handle_finalizers): New function.
18263 (ggc_collect): Call ggc_handle_finalizers.
18264 * ggc.h (ggc_internal_alloc): Add arguments to allow installing a
18265 finalizer.
18266 (ggc_internal_cleared_alloc): Likewise.
18267 (finalize): New function.
18268 (need_finalization_p): Likewise.
18269 (ggc_alloc): Install the type's destructor as the finalizer if it
18270 might do something.
18271 (ggc_cleared_alloc): Likewise.
18272 (ggc_vec_alloc): Likewise.
18273 (ggc_cleared_vec_alloc): Likewise.
18274
18275 2014-05-17 Trevor Saunders <tsaunders@mozilla.com>
18276
18277 * ggc.h (ggc_alloc_cleared_simd_clone_stat): Remove function.
18278
18279 2014-05-17 Trevor Saunders <tsaunders@mozilla.com>
18280
18281 * alias.c (record_alias_subset): Adjust.
18282 * bitmap.c (bitmap_element_allocate): Likewise.
18283 (bitmap_gc_alloc_stat): Likewise.
18284 * cfg.c (init_flow): Likewise.
18285 (alloc_block): Likewise.
18286 (unchecked_make_edge): Likewise.
18287 * cfgloop.c (alloc_loop): Likewise.
18288 (flow_loops_find): Likewise.
18289 (rescan_loop_exit): Likewise.
18290 * cfgrtl.c (init_rtl_bb_info): Likewise.
18291 * cgraph.c (insert_new_cgraph_node_version): Likewise.
18292 (cgraph_allocate_node): Likewise.
18293 (cgraph_create_edge_1): Likewise.
18294 (cgraph_allocate_init_indirect_info): Likewise.
18295 * cgraphclones.c (cgraph_clone_edge): Likewise.
18296 * cgraphunit.c (add_asm_node): Likewise.
18297 (init_lowered_empty_function): Likewise.
18298 * config/aarch64/aarch64.c (aarch64_init_machine_status): Likewise.
18299 * config/alpha/alpha.c (alpha_init_machine_status): Likewise.
18300 (alpha_use_linkage): Likewise.
18301 * config/arc/arc.c (arc_init_machine_status): Likewise.
18302 * config/arm/arm.c (arm_init_machine_status): Likewise.
18303 * config/avr/avr.c (avr_init_machine_status): Likewise.
18304 * config/bfin/bfin.c (bfin_init_machine_status): Likewise.
18305 * config/c6x/c6x.c (c6x_init_machine_status): Likewise.
18306 * config/cris/cris.c (cris_init_machine_status): Likewise.
18307 * config/darwin.c (machopic_indirection_name): Likewise.
18308 (darwin_build_constant_cfstring): Likewise.
18309 (darwin_enter_string_into_cfstring_table): Likewise.
18310 * config/epiphany/epiphany.c (epiphany_init_machine_status): Likewise.
18311 * config/frv/frv.c (frv_init_machine_status): Likewise.
18312 * config/i386/i386.c (get_dllimport_decl): Likewise.
18313 (ix86_init_machine_status): Likewise.
18314 (assign_386_stack_local): Likewise.
18315 * config/i386/winnt.c (i386_pe_record_external_function): Likewise.
18316 (i386_pe_maybe_record_exported_symbol): Likewise.
18317 (i386_pe_record_stub): Likewise.
18318 * config/ia64/ia64.c (ia64_init_machine_status): Likewise.
18319 * config/iq2000/iq2000.c (iq2000_init_machine_status): Likewise.
18320 * config/m32c/m32c.c (m32c_init_machine_status): Likewise.
18321 (m32c_note_pragma_address): Likewise.
18322 * config/mep/mep.c (mep_init_machine_status): Likewise.
18323 (mep_note_pragma_flag): Likewise.
18324 * config/mips/mips.c (mflip_mips16_use_mips16_p): Likewise.
18325 (mips16_local_alias): Likewise.
18326 (mips_init_machine_status): Likewise.
18327 * config/mmix/mmix.c (mmix_init_machine_status): Likewise.
18328 * config/moxie/moxie.c (moxie_init_machine_status): Likewise.
18329 * config/msp430/msp430.c (msp430_init_machine_status): Likewise.
18330 * config/nds32/nds32.c (nds32_init_machine_status): Likewise.
18331 * config/nios2/nios2.c (nios2_init_machine_status): Likewise.
18332 * config/pa/pa.c (pa_init_machine_status): Likewise.
18333 (pa_get_deferred_plabel): Likewise.
18334 * config/rl78/rl78.c (rl78_init_machine_status): Likewise.
18335 * config/rs6000/rs6000.c (builtin_function_type): Likewise.
18336 (rs6000_init_machine_status): Likewise.
18337 (output_toc): Likewise.
18338 * config/s390/s390.c (s390_init_machine_status): Likewise.
18339 * config/score/score.c (score_output_external): Likewise.
18340 * config/sparc/sparc.c (sparc_init_machine_status): Likewise.
18341 * config/spu/spu.c (spu_init_machine_status): Likewise.
18342 * config/tilegx/tilegx.c (tilegx_init_machine_status): Likewise.
18343 * config/tilepro/tilepro.c (tilepro_init_machine_status): Likewise.
18344 * config/xtensa/xtensa.c (xtensa_init_machine_status): Likewise.
18345 * coverage.c (coverage_end_function): Likewise.
18346 * dbxout.c (dbxout_init): Likewise.
18347 * doc/gty.texi: Don't mention variable_size attribute.
18348 * dwarf2cfi.c (new_cfi): Adjust.
18349 (new_cfi_row): Likewise.
18350 (copy_cfi_row): Likewise.
18351 (create_cie_data): Likewise.
18352 * dwarf2out.c (dwarf2out_alloc_current_fde): Likewise.
18353 (new_loc_descr): Likewise.
18354 (find_AT_string_in_table): Likewise.
18355 (add_addr_table_entry): Likewise.
18356 (new_die): Likewise.
18357 (add_var_loc_to_decl): Likewise.
18358 (clone_die): Likewise.
18359 (clone_as_declaration): Likewise.
18360 (break_out_comdat_types): Likewise.
18361 (new_loc_list): Likewise.
18362 (add_loc_descr_to_each): Likewise.
18363 (add_location_or_const_value_attribute): Likewise.
18364 (add_linkage_name): Likewise.
18365 (lookup_filename): Likewise.
18366 (dwarf2out_var_location): Likewise.
18367 (new_line_info_table): Likewise.
18368 (dwarf2out_init): Likewise.
18369 (mem_loc_descriptor): Likewise.
18370 (loc_descriptor): Likewise.
18371 (add_const_value_attribute): Likewise.
18372 (tree_add_const_value_attribute): Likewise.
18373 (comp_dir_string): Likewise.
18374 (dwarf2out_vms_debug_main_pointer): Likewise.
18375 (string_cst_pool_decl): Likewise.
18376 * emit-rtl.c (set_mem_attrs): Likewise.
18377 (get_reg_attrs): Likewise.
18378 (start_sequence): Likewise.
18379 (init_emit): Likewise.
18380 (init_emit_regs): Likewise.
18381 * except.c (init_eh_for_function): Likewise.
18382 (gen_eh_region): Likewise.
18383 (gen_eh_region_catch): Likewise.
18384 (gen_eh_landing_pad): Likewise.
18385 (add_call_site): Likewise.
18386 * function.c (add_frame_space): Likewise.
18387 (insert_temp_slot_address): Likewise.
18388 (assign_stack_temp_for_type): Likewise.
18389 (get_hard_reg_initial_val): Likewise.
18390 (allocate_struct_function): Likewise.
18391 (prepare_function_start): Likewise.
18392 (types_used_by_var_decl_insert): Likewise.
18393 * gengtype.c (variable_size_p): Remove function.
18394 (enum alloc_quantity): Remove enum.
18395 (write_typed_alloc_def): Remove function.
18396 (write_typed_struct_alloc_def): Likewise.
18397 (write_typed_typedef_alloc_def): Likewise.
18398 (write_typed_alloc_defns): Likewise.
18399 (main): Adjust.
18400 * ggc-common.c (ggc_cleared_alloc_htab_ignore_args): Adjust.
18401 (ggc_cleared_alloc_ptr_array_two_args): Likewise.
18402 * ggc.h (ggc_alloc): new function.
18403 (ggc_cleared_alloc): Likewise.
18404 (ggc_vec_alloc): Template on type of vector element, and remove
18405 element size argument.
18406 (ggc_cleared_vec_alloc): Likewise.
18407 * gimple.c (gimple_build_omp_for): Adjust.
18408 (gimple_copy): Likewise.
18409 * ipa-cp.c (get_replacement_map): Likewise.
18410 (find_aggregate_values_for_callers_subset): Likewise.
18411 (known_aggs_to_agg_replacement_list): Likewise.
18412 * ipa-devirt.c (get_odr_type): Likewise.
18413 * ipa-prop.c (ipa_node_duplication_hook): Likewise.
18414 (read_agg_replacement_chain): Likewise.
18415 * loop-iv.c (get_simple_loop_desc): Likewise.
18416 * lto-cgraph.c (input_node_opt_summary): Likewise.
18417 * lto-section-in.c (lto_new_in_decl_state): Likewise.
18418 * lto-streamer-in.c (lto_input_eh_catch_list): Likewise.
18419 (input_eh_region): Likewise.
18420 (input_eh_lp): Likewise.
18421 (input_cfg): Likewise.
18422 * optabs.c (set_optab_libfunc): Likewise.
18423 (init_tree_optimization_optabs): Likewise.
18424 (set_conv_libfunc): Likewise.
18425 * passes.c (do_per_function_toporder): Likewise.
18426 * rtl.h: Don't use variable_size gty attribute.
18427 * sese.c (if_region_set_false_region): Adjust.
18428 * stringpool.c (gt_pch_save_stringpool): Likewise.
18429 * target-globals.c (save_target_globals): Likewise.
18430 * toplev.c (general_init): Likewise.
18431 * trans-mem.c (record_tm_replacement): Likewise.
18432 (split_bb_make_tm_edge): Likewise.
18433 * tree-cfg.c (move_sese_region_to_fn): Likewise.
18434 * tree-data-ref.h (lambda_vector_new): Likewise.
18435 * tree-eh.c (add_stmt_to_eh_lp_fn): Likewise.
18436 * tree-iterator.c (tsi_link_before): Likewise.
18437 (tsi_link_after): Likewise.
18438 * tree-scalar-evolution.c (new_scev_info_str): Likewise.
18439 * tree-ssa-loop-niter.c (record_estimate): Likewise.
18440 * tree-ssa-operands.c (ssa_operand_alloc): Likewise.
18441 * tree-ssa-operands.h: Don't use variable_size gty attribute.
18442 * tree-ssa.c (init_tree_ssa): Adjust.
18443 * tree-ssanames.c (set_range_info): Likewise.
18444 (get_ptr_info): Likewise.
18445 (duplicate_ssa_name_ptr_info): Likewise.
18446 (duplicate_ssa_name_range_info): Likewise.
18447 * tree-streamer-in.c (unpack_ts_real_cst_value_fields): Likewise.
18448 (unpack_ts_fixed_cst_value_fields): Likewise.
18449 * tree.c (build_fixed): Likewise.
18450 (build_real): Likewise.
18451 (build_string): Likewise.
18452 (decl_priority_info): Likewise.
18453 (decl_debug_expr_insert): Likewise.
18454 (decl_value_expr_insert): Likewise.
18455 (decl_debug_args_insert): Likewise.
18456 (type_hash_add): Likewise.
18457 (build_omp_clause): Likewise.
18458 * ubsan.c (decl_for_type_insert): Likewise.
18459 * varasm.c (get_unnamed_section): Likewise.
18460 (get_noswitch_section): Likewise.
18461 (get_section): Likewise.
18462 (get_block_for_section): Likewise.
18463 (create_block_symbol): Likewise.
18464 (build_constant_desc): Likewise.
18465 (create_constant_pool): Likewise.
18466 (force_const_mem): Likewise.
18467 (record_tm_clone_pair): Likewise.
18468 * varpool.c (varpool_create_empty_node): Likewise.
18469
18470 2014-05-17 Trevor Saunders <tsaunders@mozilla.com>
18471
18472 * dwarf2out.c (tree_add_const_value_attribute): Call
18473 ggc_internal_cleared_alloc instead of ggc_alloc_cleared_atomic.
18474 * gengtype.c (write_typed_alloc_def): Call ggc_internal_<x>alloc
18475 instead of ggc_internal_<x>alloc_stat.
18476 * ggc-common.c (ggc_internal_cleared_alloc): Drop _stat suffix.
18477 (ggc_realloc): Likewise.
18478 * ggc-none.c (ggc_internal_alloc): Likewise.
18479 (ggc_internal_cleared_alloc): Likewise.
18480 * ggc-page.c: Likewise.
18481 * ggc.h (ggc_internal_alloc_stat): Likewise.
18482 (ggc_internal_alloc): Remove macro.
18483 (ggc_internal_cleared_alloc_stat): Drop _stat suffix.
18484 (ggc_internal_cleared_alloc): Remove macro.
18485 (GGC_RESIZEVEC): Adjust.
18486 (ggc_resizevar): Remove macro.
18487 (ggc_internal_vec_alloc_stat): Drop _stat suffix.
18488 (ggc_internal_cleared_vec_alloc_stat): Likewise.
18489 (ggc_internal_vec_cleared_alloc): Remove macro.
18490 (ggc_alloc_atomic_stat): Drop _stat suffix.
18491 (ggc_alloc_atomic): Remove macro.
18492 (ggc_alloc_cleared_atomic): Remove macro.
18493 (ggc_alloc_string_stat): Drop _stat suffix.
18494 (ggc_alloc_string): Remove macro.
18495 (ggc_alloc_rtx_def_stat): Adjust.
18496 (ggc_alloc_tree_node_stat): Likewise.
18497 (ggc_alloc_cleared_tree_node_stat): Likewise.
18498 (ggc_alloc_cleared_gimple_statement_stat): Likewise.
18499 (ggc_alloc_cleared_simd_clone_stat): Likewise.
18500 * gimple.c (gimple_build_omp_for): Likewise.
18501 (gimple_copy): Likewise.
18502 * stringpool.c (ggc_alloc_string_stat): Drop _stat suffix.
18503 * toplev.c (realloc_for_line_map): Adjust.
18504 * tree-data-ref.h (lambda_vector_new): Likewise.
18505 * tree-phinodes.c (allocate_phi_node): Likewise.
18506 * tree.c (grow_tree_vec_stat): Likewise.
18507 * vec.h (va_gc::reserve): Adjust.
18508
18509 2014-05-17 Ajit Agarwal <ajitkum@xilinx.com>
18510
18511 * config/microblaze/microblaze.c (break_handler): New Declaration.
18512 (microblaze_break_function_p,microblaze_is_break_handler): New.
18513 (compute_frame_size): Use microblaze_break_function_p.
18514 Add the test of break_handler.
18515 (microblaze_function_prologue) : Add the test of variable
18516 break_handler. Check the fnname by BREAK_HANDLER_NAME.
18517 (microblaze_function_epilogue) : Add the test of break_handler.
18518 (microblaze_globalize_label) : Add the test of break_handler.
18519 Check the name by BREAK_HANDLER_NAME.
18520
18521 * config/microblaze/microblaze.h (BREAK_HANDLER_NAME): New macro
18522
18523 * config/microblaze/microblaze.md (*<optab>,<optab>_internal): Add
18524 microblaze_is_break_handler test.
18525 (call_internal1,call_value_intern): Use microblaze_break_function_p.
18526 Use SYMBOL_REF_DECL.
18527
18528 * config/microblaze/microblaze-protos.h
18529 (microblaze_break_function_p,microblaze_is_break_handler):
18530 New Declaration.
18531
18532 * doc/extend.texi (MicroBlaze break_handler Functions): Document
18533 new MicroBlaze break_handler functions.
18534
18535 2014-05-17 Uros Bizjak <ubizjak@gmail.com>
18536
18537 * doc/extend.texi (Size of an asm): Move node text according
18538 to its @menu entry position.
18539
18540 2014-05-17 Marc Glisse <marc.glisse@inria.fr>
18541
18542 PR tree-optimization/61140
18543 PR tree-optimization/61150
18544 PR tree-optimization/61197
18545 * tree-ssa-phiopt.c (value_replacement): Punt on multiple phis.
18546
18547 2014-05-17 Uros Bizjak <ubizjak@gmail.com>
18548
18549 * doc/invoke.texi (free): Mention Alpha. Also enabled at -Os.
18550
18551 2014-05-17 Richard Sandiford <r.sandiford@uk.ibm.com>
18552
18553 * wide-int.cc: Only include longlong.h if W_TYPE_SIZE==32 or
18554 __SIZEOF_INT128__ is defined.
18555
18556 2014-05-17 Richard Sandiford <rdsandiford@googlemail.com>
18557
18558 * config/rs6000/rs6000.c (rs6000_real_tls_symbol_ref_p): New function.
18559 (rs6000_delegitimize_address): Use it.
18560
18561 2014-05-17 Richard Sandiford <rdsandiford@googlemail.com>
18562
18563 * emit-rtl.h (replace_equiv_address, replace_equiv_address_nv): Add an
18564 inplace argument. Store the new address in the original MEM when true.
18565 * emit-rtl.c (change_address_1): Likewise.
18566 (adjust_address_1, adjust_automodify_address_1, offset_address):
18567 Update accordingly.
18568 * rtl.h (plus_constant): Add an inplace argument.
18569 * explow.c (plus_constant): Likewise. Try to reuse the original PLUS
18570 when true. Avoid generating (plus X (const_int 0)).
18571 * function.c (instantiate_virtual_regs_in_rtx): Adjust the PLUS
18572 in-place. Pass true to plus_constant.
18573 (instantiate_virtual_regs_in_insn): Pass true to replace_equiv_address.
18574
18575 2014-05-16 Dehao Chen <dehao@google.com>
18576
18577 * tree-cfg.c (gimple_merge_blocks): Updates bb count with max count.
18578
18579 2014-05-16 Oleg Endo <olegendo@gcc.gnu.org>
18580
18581 PR target/54089
18582 * config/sh/predicates.md (negt_reg_shl31_operand): Match additional
18583 patterns.
18584 * config/sh/sh.md (*negt_msb): Merge SH2A and non-SH2A variants.
18585
18586 2014-05-16 Dehao Chen <dehao@google.com>
18587
18588 * ira-int.h (REG_FREQ_FROM_EDGE_FREQ): Use
18589 optimize_function_for_size_p.
18590 * regs.h (REG_FREQ_FROM_BB): Likewise.
18591
18592 2014-05-16 Oleg Endo <olegendo@gcc.gnu.org>
18593
18594 PR target/51244
18595 * config/sh/sh.c (sh_eval_treg_value): Handle t_reg_operand and
18596 negt_reg_operand cases.
18597 * config/sh/sh.md (*cset_zero): Likewise by using cbranch_treg_value
18598 predicate.
18599 * config/sh/predicates.md (cbranch_treg_value): Simplify.
18600
18601 2014-05-16 Oleg Endo <olegendo@gcc.gnu.org>
18602
18603 * config/sh/sh.c (sh_option_override): Set branch cost to 2 for all
18604 target variants.
18605
18606 2014-05-16 David Malcolm <dmalcolm@redhat.com>
18607
18608 Revert:
18609 2014-04-29 David Malcolm <dmalcolm@redhat.com>
18610
18611 * tree-cfg.c (dump_function_to_file): Dump the return type of
18612 functions, in a line to itself before the function body, mimicking
18613 the layout of a C function.
18614
18615 2014-05-16 Dehao Chen <dehao@google.com>
18616
18617 * cfghooks.c (make_forwarder_block): Use direct computation to
18618 get fall-through edge's count and frequency.
18619
18620 2014-05-16 Benno Schulenberg <bensberg@justemail.net>
18621
18622 * config/arc/arc.c (arc_init): Fix typo in error message.
18623 * config/i386/i386.c (ix86_expand_builtin): Likewise.
18624 (split_stack_prologue_scratch_regno): Likewise.
18625 * fortran/check.c (gfc_check_fn_rc2008): Remove duplicate
18626 word from error message.
18627
18628 2014-05-16 Zhouyi Zhou <yizhouzhou@ict.ac.cn>
18629
18630 * ira-costs.c: Fix typo in comment.
18631
18632 2014-05-16 David Wohlferd <dw@LimeGreenSocks.com>
18633
18634 * doc/extend.texi: (Visibility Pragmas) Fix misplaced @xref
18635
18636 2014-05-16 Jan Hubicka <hubicka@ucw.cz>
18637
18638 * varpool.c (dump_varpool_node): Dump write-only flag.
18639 * lto-cgraph.c (lto_output_varpool_node, input_varpool_node): Stream
18640 write-only flag.
18641 * tree-cfg.c (execute_fixup_cfg): Remove statements setting
18642 write-only variables.
18643 * ipa.c (process_references): New function.
18644 (set_readonly_bit): New function.
18645 (set_writeonly_bit): New function.
18646 (clear_addressable_bit): New function.
18647 (ipa_discover_readonly_nonaddressable_var): Mark write only variables;
18648 fix handling of aliases.
18649 * cgraph.h (struct varpool_node): Add writeonly flag.
18650
18651 2014-05-16 Vladimir Makarov <vmakarov@redhat.com>
18652
18653 PR rtl-optimization/60969
18654 * ira-costs.c (record_reg_classes): Allow only memory for pseudo.
18655 Calculate costs for this case.
18656
18657 2014-05-16 Eric Botcazou <ebotcazou@adacore.com>
18658
18659 * fold-const (fold_unary_loc) <NON_LVALUE_EXPR>: New case.
18660 <CASE_CONVERT>: Pass arg0 instead of op0 to fold_convert_const.
18661
18662 2014-05-16 Richard Biener <rguenther@suse.de>
18663
18664 PR tree-optimization/61194
18665 * tree-vect-patterns.c (adjust_bool_pattern): Also handle
18666 bool patterns ending in a COND_EXPR.
18667
18668 2014-05-16 James Greenhalgh <james.greenhalgh@arm.com>
18669
18670 * config/aarch64/aarch64.c (aarch64_rtx_mult_cost): Fix FNMUL case.
18671
18672 2014-05-16 James Greenhalgh <james.greenhalgh@arm.com>
18673
18674 * config/aarch64/aarch64.c (aarch64_rtx_costs): Handle the case
18675 where we were unable to cost an RTX.
18676
18677 2014-05-16 James Greenhalgh <james.greenhalgh@arm.com>
18678
18679 * config/aarch64/aarch64.c (aarch64_rtx_costs): Cost SYMBOL_REF,
18680 HIGH, LO_SUM.
18681
18682 2014-05-16 James Greenhalgh <james.greenhalgh@arm.com>
18683 Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
18684
18685 * config/aarch64/aarch64.c (aarch64_rtx_costs): Cost TRUNCATE.
18686
18687 2014-05-16 James Greenhalgh <james.greenhalgh@arm.com>
18688 Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
18689
18690 * config/aarch64/aarch64.c (aarch64_rtx_costs): Cost FMA,
18691 FLOAT_EXTEND, FLOAT_TRUNCATE, ABS, SMAX, and SMIN.
18692
18693 2014-05-16 James Greenhalgh <james.greenhalgh@arm.com>
18694 Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
18695
18696 * config/aarch64/aarch64.c (aarch64_rtx_costs): Cost comparison
18697 operators.
18698
18699 2014-05-16 James Greenhalgh <james.greenhalgh@arm.com>
18700 Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
18701
18702 * config/aarch64/aarch64.c (aarch64_rtx_costs): Improve costs for
18703 DIV/MOD.
18704
18705 2014-05-16 James Greenhalgh <james.greenhalgh@arm.com>
18706 Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
18707
18708 * config/aarch64/aarch64.c (aarch64_rtx_arith_op_extract_p): New.
18709 (aarch64_rtx_costs): Improve costs for SIGN/ZERO_EXTRACT.
18710
18711 2014-05-16 James Greenhalgh <james.greenhalgh@arm.com>
18712 Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
18713
18714 * config/aarch64/aarch64.c (aarch64_rtx_costs): Improve costs for
18715 rotates and shifts.
18716
18717 2014-05-16 James Greenhalgh <james.greenhalgh@arm.com>
18718 Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
18719
18720 * config/aarch64/aarch64.c (aarch64_rtx_costs): Cost
18721 ZERO_EXTEND and SIGN_EXTEND better.
18722
18723 2014-05-16 James Greenhalgh <james.greenhalgh@arm.com>
18724 Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
18725
18726 * config/aarch64/aarch64.c (aarch64_rtx_costs): Improve cost for
18727 logical operations.
18728
18729 2014-05-16 James Greenhalgh <james.greenhalgh@arm.com>
18730 Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
18731
18732 * config/aarch64/aarch64.c (aarch64_rtx_costs): Use address
18733 costs when costing loads and stores to memory.
18734
18735 2014-05-16 James Greenhalgh <james.greenhalgh@arm.com>
18736 Philip Tomsich <philipp.tomsich@theobroma-systems.com>
18737
18738 * config/aarch64/aarch64.c (aarch64_rtx_costs): Improve costing
18739 for SET RTX.
18740
18741 2014-05-16 James Greenhalgh <james.greenhalgh@arm.com>
18742
18743 * config/aarch64/aarch64.c (aarch64_rtx_costs): Set default costs.
18744
18745 2014-05-16 James Greenhalgh <james.greenhalgh@arm.com>
18746 Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
18747
18748 * config/aarch64/aarch64.c (aarch64_strip_shift_or_extend): Rename
18749 to...
18750 (aarch64_strip_extend): ...this, don't strip shifts, check RTX is
18751 well formed.
18752 (aarch64_rtx_mult_cost): New.
18753 (aarch64_rtx_costs): Use it, refactor as appropriate.
18754
18755 2014-05-16 James Greenhalgh <james.greenhalgh@arm.com>
18756 Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
18757
18758 * config/aarch64/aarch64.c (aarch64_build_constant): Conditionally
18759 emit instructions, return number of instructions which would
18760 be emitted.
18761 (aarch64_add_constant): Update call to aarch64_build_constant.
18762 (aarch64_output_mi_thunk): Likewise.
18763 (aarch64_rtx_costs): Estimate cost of a CONST_INT, cost of
18764 a CONST_DOUBLE.
18765
18766 2014-05-16 James Greenhalgh <james.greenhalgh@arm.com>
18767
18768 * config/aarch64/aarch64.c (aarch64_rtx_costs_wrapper): New.
18769 (TARGET_RTX_COSTS): Call it.
18770
18771 2014-05-16 James Greenhalgh <james.greenhalgh@arm.com>
18772
18773 * config/aarch64/aarch64.c (cortexa57_addrcost_table): New.
18774 (cortexa57_vector_cost): Likewise.
18775 (cortexa57_tunings): Use them.
18776
18777 2014-05-16 James Greenhalgh <james.greenhalgh@arm.com>
18778
18779 * config/aarch64/aarch64-protos.h (scale_addr_mode_cost): New.
18780 (cpu_addrcost_table): Use it.
18781 * config/aarch64/aarch64.c (generic_addrcost_table): Initialize it.
18782 (aarch64_address_cost): Rewrite using aarch64_classify_address,
18783 move it.
18784
18785 2014-05-16 Richard Biener <rguenther@suse.de>
18786
18787 * tree-ssa-sccvn.c: Include tree-cfg.h and domwalk.h.
18788 (set_ssa_val_to): Handle unexpected sets to VN_TOP.
18789 (visit_phi): Ignore edges marked as not executable.
18790 (class cond_dom_walker): New.
18791 (cond_dom_walker::before_dom_children): Value-number
18792 control statements and mark successor edges as not
18793 executable if possible.
18794 (run_scc_vn): First walk all control statements in
18795 dominator order, marking edges as not executable.
18796 * tree-inline.c (copy_edges_for_bb): Be not confused
18797 about random edge flags.
18798
18799 2014-05-16 Richard Biener <rguenther@suse.de>
18800
18801 * tree-ssa-sccvn.c (visit_use): Also constant-fold calls.
18802
18803 2014-05-15 Peter Bergner <bergner@vnet.ibm.com>
18804
18805 PR target/61193
18806 * config/rs6000/htmxlintrin.h (_HTM_TBEGIN_STARTED): New define.
18807 (__TM_simple_begin): Use it.
18808 (__TM_begin): Likewise.
18809
18810 2014-05-15 Martin Jambor <mjambor@suse.cz>
18811
18812 PR ipa/61085
18813 * ipa-prop.c (update_indirect_edges_after_inlining): Check
18814 type_preserved flag when the indirect edge is polymorphic.
18815
18816 2014-05-15 Martin Jambor <mjambor@suse.cz>
18817
18818 PR tree-optimization/61090
18819 * tree-sra.c (sra_modify_expr): Pass the current gsi to
18820 build_ref_for_model.
18821
18822 2014-05-15 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
18823
18824 * config/arm/arm.c (arm_option_override): Use the SCHED_PRESSURE_MODEL
18825 enum name for PARAM_SCHED_PRESSURE_ALGORITHM.
18826
18827 2014-05-15 Jakub Jelinek <jakub@redhat.com>
18828
18829 PR tree-optimization/61158
18830 * fold-const.c (fold_binary_loc): If X is zero-extended and
18831 shiftc >= prec, make sure zerobits is all ones instead of
18832 invoking undefined behavior.
18833
18834 2014-05-15 Zhenqiang Chen <zhenqiang.chen@linaro.org>
18835
18836 * regcprop.h: New file.
18837 * regcprop.c (skip_debug_insn_p): New decl.
18838 (replace_oldest_value_reg): Check skip_debug_insn_p.
18839 (copyprop_hardreg_forward_bb_without_debug_insn): New function.
18840 * shrink-wrap.c: Include regcprop.h.
18841 (prepare_shrink_wrap): Call
18842 copyprop_hardreg_forward_bb_without_debug_insn.
18843
18844 2014-05-15 Zhenqiang Chen <zhenqiang.chen@linaro.org>
18845
18846 * shrink-wrap.h: Update comment.
18847 * shrink-wrap.c: Update comment.
18848 (next_block_for_reg): Rename to live_edge_for_reg.
18849 (live_edge_for_reg): Allow live_edge->dest has two predecessors.
18850 (move_insn_for_shrink_wrap): Split live_edge.
18851 (prepre_shrink_wrap): One more parameter for move_insn_for_shrink_wrap.
18852
18853 2014-05-14 Eric Botcazou <ebotcazou@adacore.com>
18854
18855 * config/sparc/sparc-protos.h (sparc_absnegfloat_split_legitimate):
18856 Delete.
18857 * config/sparc/sparc.c (sparc_absnegfloat_split_legitimate): Likewise.
18858 * config/sparc/sparc.md (fptype_ut699): New attribute.
18859 (in_branch_delay): Return false if -mfix-ut699 is specified and
18860 fptype_ut699 is set to single.
18861 (truncdfsf2): Add fptype_ut699 attribute.
18862 (fix_truncdfsi2): Likewise.
18863 (floatsisf2): Change fptype attribute.
18864 (fix_truncsfsi2): Likewise.
18865 (negtf2_notv9): Delete.
18866 (negtf2_v9): Likewise.
18867 (negtf2_hq): New instruction.
18868 (negtf2): New instruction and splitter.
18869 (negdf2_notv9): Rewrite.
18870 (abstf2_notv9): Delete.
18871 (abstf2_hq_v9): Likewise.
18872 (abstf2_v9): Likewise.
18873 (abstf2_hq): New instruction.
18874 (abstf2): New instruction and splitter.
18875 (absdf2_notv9): Rewrite.
18876
18877 2014-05-14 Cary Coutant <ccoutant@google.com>
18878
18879 PR debug/61013
18880 * opts.c (common_handle_option): Don't special-case "-g".
18881 (set_debug_level): Default to at least level 2 with "-g".
18882
18883 2014-05-14 DJ Delorie <dj@redhat.com>
18884
18885 * config/msp430/msp430.c (msp430_builtin): Add
18886 MSP430_BUILTIN_DELAY_CYCLES.
18887 (msp430_init_builtins): Register void __delay_cycles(long long).
18888 (msp430_builtin_decl): Add it.
18889 (cg_magic_constant): New.
18890 (msp430_expand_delay_cycles): New.
18891 (msp430_expand_builtin): Call it.
18892 (msp430_print_operand_raw): Change integer printing from "int" to
18893 HOST_WIDE_INT.
18894 * config/msp430/msp430.md (define_constants): Add delay_cycles tags.
18895 (delay_cycles_start): New.
18896 (delay_cycles_end): New.
18897 (delay_cycles_32): New.
18898 (delay_cycles_32x): New.
18899 (delay_cycles_16): New.
18900 (delay_cycles_16x): New.
18901 (delay_cycles_2): New.
18902 (delay_cycles_1): New.
18903 * doc/extend.texi: Document __delay_cycles().
18904
18905 2014-05-14 Sandra Loosemore <sandra@codesourcery.com>
18906
18907 * config/nios2/nios2.md (nios2_cbranch): Fix paste-o in
18908 length attribute computation.
18909
18910 2014-05-14 Richard Sandiford <rdsandiford@googlemail.com>
18911
18912 PR debug/61188
18913 * print-rtl.c (print_rtx): Suppress uids if flag_dump_unnumbered.
18914
18915 2014-05-14 Richard Sandiford <r.sandiford@uk.ibm.com>
18916
18917 PR target/61084
18918 * config/sparc/sparc.md: Fix types of low and high in DI constant
18919 splitter. Use gen_int_mode in some other splitters.
18920
18921 2014-05-14 Martin Jambor <mjambor@suse.cz>
18922
18923 PR ipa/60897
18924 * ipa-prop.c (ipa_modify_formal_parameters): Reset DECL_LANG_SPECIFIC.
18925
18926 2014-05-14 James Norris <jnorris@codesourcery.com>
18927
18928 * omp-low.c (expand_parallel_call): Remove shadow variable.
18929 (expand_omp_taskreg): Likewise.
18930
18931 2014-05-14 Ilya Tocar <ilya.tocar@intel.com>
18932
18933 * common/config/i386/i386-common.c
18934 (OPTION_MASK_ISA_CLFLUSHOPT_SET): Define.
18935 (OPTION_MASK_ISA_XSAVES_SET): Ditto.
18936 (OPTION_MASK_ISA_XSAVEC_SET): Ditto.
18937 (OPTION_MASK_ISA_CLFLUSHOPT_UNSET): Ditto.
18938 (OPTION_MASK_ISA_XSAVES_UNSET): Ditto.
18939 (OPTION_MASK_ISA_XSAVEC_UNSET): Ditto.
18940 (ix86_handle_option): Handle OPT_mxsavec, OPT_mxsaves, OPT_mclflushopt.
18941 * config.gcc (i[34567]86-*-*): Add clflushoptintrin.h,
18942 xsavecintrin.h, xsavesintrin.h.
18943 (x86_64-*-*): Ditto.
18944 * config/i386/clflushoptintrin.h: New.
18945 * config/i386/xsavecintrin.h: Ditto.
18946 * config/i386/xsavesintrin.h: Ditto.
18947 * config/i386/cpuid.h (bit_CLFLUSHOPT): Define.
18948 (bit_XSAVES): Ditto.
18949 (bit_XSAVES): Ditto.
18950 * config/i386/driver-i386.c (host_detect_local_cpu): Handle
18951 -mclflushopt, -mxsavec, -mxsaves, -mno-xsaves, -mno-xsavec,
18952 -mno-clflushopt.
18953 * config/i386/i386-c.c (ix86_target_macros_internal): Handle
18954 OPTION_MASK_ISA_CLFLUSHOPT, OPTION_MASK_ISA_XSAVEC,
18955 OPTION_MASK_ISA_XSAVES.
18956 * config/i386/i386.c (ix86_target_string): Handle -mclflushopt,
18957 -mxsavec, -mxsaves.
18958 (PTA_CLFLUSHOPT) Define.
18959 (PTA_XSAVEC): Ditto.
18960 (PTA_XSAVES): Ditto.
18961 (ix86_option_override_internal): Handle new options.
18962 (ix86_valid_target_attribute_inner_p): Ditto.
18963 (ix86_builtins): Add IX86_BUILTIN_XSAVEC, IX86_BUILTIN_XSAVEC64,
18964 IX86_BUILTIN_XSAVES, IX86_BUILTIN_XRSTORS, IX86_BUILTIN_XSAVES64,
18965 IX86_BUILTIN_XRSTORS64, IX86_BUILTIN_CLFLUSHOPT.
18966 (bdesc_special_args): Add __builtin_ia32_xsaves,
18967 __builtin_ia32_xrstors, __builtin_ia32_xsavec, __builtin_ia32_xsaves64,
18968 __builtin_ia32_xrstors64, __builtin_ia32_xsavec64.
18969 (ix86_init_mmx_sse_builtins): Add __builtin_ia32_clflushopt.
18970 (ix86_expand_builtin): Handle new builtins.
18971 * config/i386/i386.h (TARGET_CLFLUSHOPT) Define.
18972 (TARGET_CLFLUSHOPT_P): Ditto.
18973 (TARGET_XSAVEC): Ditto.
18974 (TARGET_XSAVEC_P): Ditto.
18975 (TARGET_XSAVES): Ditto.
18976 (TARGET_XSAVES_P): Ditto.
18977 * config/i386/i386.md (ANY_XSAVE): Add UNSPECV_XSAVEC, UNSPECV_XSAVES.
18978 (ANY_XSAVE64)" Add UNSPECV_XSAVEC64, UNSPECV_XSAVES64.
18979 (attr xsave): Add xsavec, xsavec64, xsaves, xsaves64.
18980 (ANY_XRSTOR): New.
18981 (ANY_XRSTOR64): Ditto.
18982 (xrstor): Ditto.
18983 (xrstor): Change into <xrstor>.
18984 (xrstor_rex64): Change into <xrstor>_rex64.
18985 (xrstor64): Change into <xrstor>64
18986 (clflushopt): New.
18987 * config/i386/i386.opt (mclflushopt): New.
18988 (mxsavec): Ditto.
18989 (mxsaves): Ditto.
18990 * config/i386/x86intrin.h: Add clflushoptintrin.h, xsavesintrin.h,
18991 xsavecintrin.h.
18992 * doc/invoke.texi: Document new options.
18993
18994 2014-05-14 Andrey Belevantsev <abel@ispras.ru>
18995
18996 PR rtl-optimization/60866
18997 * sel-sched-ir (sel_init_new_insn): New parameter old_seqno.
18998 Default it to -1. Pass it down to init_simplejump_data.
18999 (init_simplejump_data): New parameter old_seqno. Pass it down
19000 to get_seqno_for_a_jump.
19001 (get_seqno_for_a_jump): New parameter old_seqno. Use it for
19002 initializing new jump seqno as a last resort. Add comment.
19003 (sel_redirect_edge_and_branch): Save old seqno of the conditional
19004 jump and pass it down to sel_init_new_insn.
19005 (sel_redirect_edge_and_branch_force): Likewise.
19006
19007 2014-05-14 Georg-Johann Lay <avr@gjlay.de>
19008
19009 * config/avr/avr.h (REG_CLASS_CONTENTS): Use unsigned suffix for
19010 shifted values to avoid build warning.
19011
19012 2014-05-14 Eric Botcazou <ebotcazou@adacore.com>
19013
19014 * cfgcleanup.c (try_forward_edges): Use location_t for locations.
19015 * cfgrtl.c (rtl_merge_blocks): Fix comment.
19016 (cfg_layout_merge_blocks): Likewise.
19017 * except.c (emit_to_new_bb_before): Remove prev_bb local variable.
19018
19019 2014-05-14 Andrey Belevantsev <abel@ispras.ru>
19020
19021 PR rtl-optimization/60901
19022 * config/i386/i386.c (ix86_dependencies_evaluation_hook): Check that
19023 bb predecessor belongs to the same scheduling region. Adjust comment.
19024
19025 2014-05-13 Peter Bergner <bergner@vnet.ibm.com>
19026
19027 * doc/sourcebuild.texi: (dfp_hw): Document.
19028 (p8vector_hw): Likewise.
19029 (powerpc_eabi_ok): Likewise.
19030 (powerpc_elfv2): Likewise.
19031 (powerpc_htm_ok): Likewise.
19032 (ppc_recip_hw): Likewise.
19033 (vsx_hw): Likewise.
19034
19035 2014-05-13 Cary Coutant <ccoutant@google.com>
19036
19037 * opts.c (finish_options): Use -ggnu-pubnames with -gsplit-dwarf.
19038
19039 2014-05-13 David Malcolm <dmalcolm@redhat.com>
19040
19041 * gengtype-parse.c (require3): Eliminate in favor of...
19042 (require4): New.
19043 (require_template_declaration): Update to support optional single *
19044 on a type.
19045
19046 * gengtype.c (get_ultimate_base_class): Add a non-const overload.
19047 (create_user_defined_type): Handle a single level of explicit
19048 pointerness within template arguments.
19049 (struct write_types_data): Add field "kind".
19050 (filter_type_name): Handle "*" character.
19051 (write_user_func_for_structure_ptr): Require a write_types_data
19052 rather than just a prefix string, so that we can look up the kind
19053 of the wtd and use it as an index into wrote_user_func_for_ptr,
19054 ensuring that such functions are written at most once. Support
19055 subclasses by invoking the marking function of the ultimate base class.
19056 (write_user_func_for_structure_body): Require a write_types_data
19057 rather than just a prefix string, so that we can pass this to
19058 write_user_func_for_structure_ptr.
19059 (write_func_for_structure): Likewise.
19060 (ggc_wtd): Add initializer of new "kind" field.
19061 (pch_wtd): Likewise.
19062
19063 * gengtype.h (enum write_types_kinds): New.
19064 (struct type): Add field wrote_user_func_for_ptr to the "s"
19065 union member.
19066
19067 2014-05-13 Richard Sandiford <r.sandiford@uk.ibm.com>
19068
19069 * fold-const.c (optimize_bit_field_compare): Use wi:: operations
19070 instead of const_binop.
19071 (fold_binary_loc): Likewise.
19072
19073 2014-05-13 Richard Sandiford <r.sandiford@uk.ibm.com>
19074
19075 * tree-dfa.h (get_addr_base_and_unit_offset_1): Update array index
19076 calculation to match get_ref_base_and_extent.
19077
19078 2014-05-13 Catherine Moore <clm@codesourcery.com>
19079 Sandra Loosemore <sandra@codesourcery.com>
19080
19081 * configure.ac: Fix assembly for explicit JALR relocation check.
19082 * configure: Regenerate.
19083
19084 2014-05-13 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
19085
19086 * config/arm/arm.c (neon_itype): Remove NEON_RESULTPAIR.
19087 (arm_init_neon_builtins): Remove handling of NEON_RESULTPAIR.
19088 Remove associated type declarations and initialisations.
19089 (arm_expand_neon_builtin): Likewise.
19090 (neon_emit_pair_result_insn): Delete.
19091 * config/arm/arm_neon_builtins (vtrn, vzip, vuzp): Delete.
19092 * config/arm/neon.md (neon_vtrn<mode>): Delete.
19093 (neon_vzip<mode>): Likewise.
19094 (neon_vuzp<mode>): Likewise.
19095
19096 2014-05-13 Richard Biener <rguenther@suse.de>
19097
19098 PR ipa/60973
19099 * tree-inline.c (remap_gimple_stmt): Clear tail call flag,
19100 it needs revisiting whether the call still may be tail-called.
19101
19102 2014-05-13 Richard Sandiford <rdsandiford@googlemail.com>
19103
19104 * rtl.def (SYMBOL_REF): Remove middle "0" field.
19105 * rtl.h (block_symbol): Reduce number of fields to 2.
19106 (rtx_def): Add u2.symbol_ref_flags.
19107 (SYMBOL_REF_FLAGS): Use it.
19108 (SYMBOL_REF_DATA, SET_SYMBOL_REF_DECL, SYMBOL_REF_DECL)
19109 (SET_SYMBOL_REF_CONSTANT, SYMBOL_REF_CONSTANT): Lower index.
19110 * gengtype.c (adjust_field_rtx_def): Remove SYMBOL_REF_FLAGS handling.
19111 Lower index of SYMBOL_REF_DATA.
19112 * print-rtl.c (print_rtx): Lower index for SYMBOL_REF_DATA.
19113 Print SYMBOL_REF_FLAGS at the same time.
19114 * genattrtab.c (attr_rtx_1): Only initialize 1 "0" SYMBOL_REF field.
19115
19116 2014-05-13 Richard Sandiford <rdsandiford@googlemail.com>
19117
19118 * rtl.def (VAR_LOCATION): Remove "i" field.
19119 * rtl.h (rtx_def): Add u2.var_location_status.
19120 (PAT_VAR_LOCATION_STATUS): Use it.
19121 (gen_rtx_VAR_LOCATION): Declare.
19122 * gengenrtl.c (excluded_rtx): Add VAR_LOCATION.
19123 * emit-rtl.c (gen_rtx_VAR_LOCATION): New function.
19124 * var-tracking.c (emit_note_insn_var_location): Remove casts.
19125
19126 2014-05-13 Richard Sandiford <rdsandiford@googlemail.com>
19127
19128 * rtl.def (scratch): Fix outdated comment and remove "0" field.
19129 * gengtype.c (adjust_field_rtx_def): Update accordingly.
19130
19131 2014-05-13 Richard Sandiford <rdsandiford@googlemail.com>
19132
19133 * rtl.def (DEBUG_INSN, INSN, JUMP_INSN, CALL_INSN, JUMP_TABLE_DATA)
19134 (BARRIER, CODE_LABEL, NOTE): Remove first "i" field.
19135 * rtl.h (rtx_def): Add insn_uid to u2 field.
19136 (RTX_FLAG_CHECK8): Delete in favor of...
19137 (RTL_INSN_CHAIN_FLAG_CHECK): ...this new macro.
19138 (INSN_DELETED_P): Update accordingly.
19139 (INSN_UID): Use u2.insn_uid.
19140 (INSN_CHAIN_CODE_P): Define.
19141 (PREV_INSN, NEXT_INSN, BLOCK_FOR_INSN, PATTERN, INSN_LOCATION)
19142 (INSN_CODE, REG_NOTES, CALL_INSN_FUNCTION_USAGE, CODE_LABEL_NUMBER)
19143 (NOTE_DATA, NOTE_DELETED_LABEL_NAME, NOTE_BLOCK, NOTE_EH_HANDLER)
19144 (NOTE_BASIC_BLOCK, NOTE_VAR_LOCATION, NOTE_CFI, NOTE_LABEL_NUMBER)
19145 (NOTE_KIND, LABEL_NAME, LABEL_NUSES, JUMP_LABEL, LABEL_REFS): Lower
19146 indices accordingly.
19147 * print-rtl.c (print_rtx): Print INSN_UIDs before the main loop.
19148 Update indices for insn-chain rtxes.
19149 * gengtype.c (gen_rtx_next): Adjust test for insn-chain rtxes.
19150 (adjust_field_rtx_def): Lower '0' indices for all insn-chain rtxes.
19151 * emit-rtl.c (gen_label_rtx): Update gen_rtx_LABEL call.
19152 * caller-save.c (init_caller_save): Update gen_rtx_INSN calls.
19153 * combine.c (try_combine): Likewise.
19154 * ira.c (setup_prohibited_mode_move_regs): Likewise.
19155
19156 2014-05-13 Richard Sandiford <rdsandiford@googlemail.com>
19157
19158 * rtl.def (REG): Remove middle field.
19159 * rtl.h (rtx_def): Add orignal_regno to u2.
19160 (ORIGINAL_REGNO): Use it instead of field 1.
19161 (REG_ATTRS): Lower field index accordingly.
19162 * gengtype.c (adjust_field_rtx_def): Remove handling of
19163 ORIGINAL_REGNO. Move REG_ATTRS index down.
19164 * print-rtl.c (print_rtx): Move ORIGINAL_REGNO handling to the
19165 code that prints the REGNO.
19166
19167 2014-05-13 Richard Sandiford <rdsandiford@googlemail.com>
19168
19169 * print-rtl.c (print_rtx): Guard whole '0' block with ifndef
19170 GENERATOR_FILE.
19171
19172 2014-05-13 Richard Sandiford <rdsandiford@googlemail.com>
19173
19174 * rtl.h (rtx_def): Mark u2 as GTY ((skip)).
19175
19176 2014-05-13 Bin Cheng <bin.cheng@arm.com>
19177
19178 * tree-ssa-loop-ivopts.c (contain_complex_addr_expr): New.
19179 (alloc_iv): Lower base expressions containing ADDR_EXPR.
19180
19181 2014-05-13 Ian Bolton <ian.bolton@arm.com>
19182
19183 * config/aarch64/aarch64-protos.h
19184 (aarch64_hard_regno_caller_save_mode): New prototype.
19185 * config/aarch64/aarch64.c (aarch64_hard_regno_caller_save_mode):
19186 New function.
19187 * config/aarch64/aarch64.h (HARD_REGNO_CALLER_SAVE_MODE): New macro.
19188
19189 2014-05-13 Christian Bruel <christian.bruel@st.com>
19190
19191 * target.def (mode_switching): New hook vector.
19192 (mode_emit, mode_needed, mode_after, mode_entry): New hooks.
19193 (mode_exit, modepriority_to_mode): Likewise.
19194 * mode-switching.c (MODE_NEEDED, MODE_AFTER, MODE_ENTRY): Hookify.
19195 (MODE_EXIT, MODE_PRIORITY_TO_MODE, EMIT_MODE_SET): Likewise.
19196 * target.h: Include tm.h and hard-reg-set.h.
19197 * doc/tm.texi.in (EMIT_MODE_SET, MODE_NEEDED, MODE_AFTER, MODE_ENTRY)
19198 (MODE_EXIT, MODE_PRIORITY_TO_MODE): Delete and hookify.
19199 * doc/tm.texi Regenerate.
19200 * config/sh/sh.h (MODE_NEEDED, MODE_AFTER, MODE_ENTRY): Delete
19201 (MODE_EXIT, MODE_PRIORITY_TO_MODE, EMIT_MODE_SET): Likewise.
19202 * config/sh/sh.c (sh_emit_mode_set, sh_mode_priority): Hookify.
19203 (sh_mode_needed, sh_mode_after, sh_mode_entry, sh_mode_exit): Likewise.
19204 * config/i386/i386.h (MODE_NEEDED, MODE_AFTER, MODE_ENTRY): Delete
19205 (MODE_EXIT, MODE_PRIORITY_TO_MODE, EMIT_MODE_SET): Likewise.
19206 * config/i386/i386-protos.h (ix86_mode_needed, ix86_mode_after)
19207 (ix86_mode_entrym, ix86_emit_mode_set): Remove external declaration.
19208 * config/i386/i386.c (ix86_mode_needed, ix86_mode_after,
19209 (ix86_mode_exit, ix86_mode_entry, ix86_mode_priority)
19210 (ix86_emit_mode_set): Hookify.
19211 * config/epiphany/epiphany.h (MODE_NEEDED, MODE_AFTER, MODE_ENTRY):
19212 Delete.
19213 (MODE_EXIT, MODE_PRIORITY_TO_MODE, EMIT_MODE_SET): Likewise.
19214 * config/epiphany/epiphany-protos.h (epiphany_mode_needed)
19215 (emit_set_fp_mode, epiphany_mode_entry_exit, epiphany_mode_after)
19216 (epiphany_mode_priority_to_mode): Remove declaration.
19217 * config/epiphany/epiphany.c (emit_set_fp_mode): Hookify.
19218 (epiphany_mode_needed, epiphany_mode_priority_to_mode): Likewise.
19219 (epiphany_mode_entry, epiphany_mode_exit, epiphany_mode_after):
19220 Likewise.
19221 (epiphany_mode_priority_to_mode): Change priority type. Hookify.
19222 (epiphany_mode_needed, epiphany_mode_entry_exit): Hookify.
19223 (epiphany_mode_after, epiphany_mode_entry, emit_set_fp_mode): Hookify.
19224
19225 2014-05-13 Jakub Jelinek <jakub@redhat.com>
19226
19227 PR target/61060
19228 * config/i386/i386.c (ix86_expand_set_or_movmem): If count_exp
19229 is const0_rtx, return immediately. Don't test count == 0 when
19230 it is always true.
19231
19232 2014-05-13 Zhenqiang Chen <zhenqiang.chen@linaro.org>
19233
19234 * Makefile.in: add shrink-wrap.o.
19235 * config/i386/i386.c: include "shrink-wrap.h"
19236 * function.c: Likewise.
19237 (requires_stack_frame_p, next_block_for_reg,
19238 move_insn_for_shrink_wrap, prepare_shrink_wrap,
19239 dup_block_and_redirect): Move to shrink-wrap.c
19240 (thread_prologue_and_epilogue_insns): Extract three code segments
19241 as functions in shrink-wrap.c
19242 * function.h: Move #ifdef HAVE_simple_return ... #endif block to
19243 shrink-wrap.h
19244 * shrink-wrap.c: New file.
19245 * shrink-wrap.h: New file.
19246
19247 2014-05-12 David Wohlferd <dw@LimeGreenSocks.com>
19248
19249 * doc/extend.texi: Reflect current numbers of pragmas. Remove
19250 reference to Solaris.
19251
19252 2014-05-12 Mike Stump <mikestump@comcast.net>
19253
19254 PR other/31778
19255 * genattrtab.c (filename): Add.
19256 (convert_set_attr_alternative): Improve error message.
19257 (check_defs): Restore read_md_filename for error messages.
19258 (gen_insn): Save filename.
19259
19260 2014-05-12 Dimitris Papavasiliou <dpapavas@gmail.com>
19261
19262 * doc/invoke.texi: Document new switches -Wno-shadow-ivar,
19263 -fno-local-ivars and -fivar-visibility.
19264 * c-family/c.opt: Make -Wshadow also implicitly enable
19265 -Wshadow-ivar.
19266
19267 2014-05-12 David Wohlferd <dw@LimeGreenSocks.com>
19268
19269 * doc/tm.texi: Remove reference to deleted macro.
19270 * doc/tm.texi.in: Likewise.
19271
19272 2014-05-12 Senthil Kumar Selvaraj <senthil_kumar.selvaraj@atmel.com>
19273
19274 PR target/60991
19275 * config/avr/avr.c (avr_out_store_psi): Use correct constant
19276 to restore Y.
19277
19278 2014-05-12 Georg-Johann Lay <avr@gjlay.de>
19279
19280 PR libgcc/61152
19281 * config/arm/arm.h (License): Add GCC Runtime Library Exception.
19282 * config/arm/aout.h (License): Same.
19283 * config/arm/bpabi.h (License): Same.
19284 * config/arm/elf.h (License): Same.
19285 * config/arm/linux-elf.h (License): Same.
19286 * config/arm/linux-gas.h (License): Same.
19287 * config/arm/netbsd-elf.h (License): Same.
19288 * config/arm/uclinux-eabi.h (License): Same.
19289 * config/arm/uclinux-elf.h (License): Same.
19290 * config/arm/vxworks.h (License): Same.
19291
19292 2014-05-11 Jakub Jelinek <jakub@redhat.com>
19293
19294 * tree.h (OMP_CLAUSE_LINEAR_STMT): Define.
19295 * tree.c (omp_clause_num_ops): Increase OMP_CLAUSE_LINEAR
19296 number of operands to 3.
19297 (walk_tree_1): Walk all operands of OMP_CLAUSE_LINEAR.
19298 * tree-nested.c (convert_nonlocal_omp_clauses,
19299 convert_local_omp_clauses): Handle OMP_CLAUSE_DEPEND.
19300 * gimplify.c (gimplify_scan_omp_clauses): Handle
19301 OMP_CLAUSE_LINEAR_STMT.
19302 * omp-low.c (lower_rec_input_clauses): Fix typo.
19303 (maybe_add_implicit_barrier_cancel, lower_omp_1): Add
19304 cast between Fortran boolean_type_node and C _Bool if
19305 needed.
19306
19307 2014-05-11 Richard Sandiford <rdsandiford@googlemail.com>
19308
19309 PR tree-optimization/61136
19310 * wide-int.h (multiple_of_p): Define a version that doesn't return
19311 the quotient.
19312 * fold-const.c (extract_muldiv_1): Use wi::multiple_of_p instead of an
19313 integer_zerop/const_binop pair.
19314 (multiple_of_p): Likewise, converting both operands to widest_int
19315 precision.
19316
19317 2014-05-09 Teresa Johnson <tejohnson@google.com>
19318
19319 * cgraphunit.c (analyze_functions): Use correct dump file.
19320
19321 2014-05-09 Florian Weimer <fweimer@redhat.com>
19322
19323 * cfgexpand.c (stack_protect_decl_p): New function, extracted from
19324 expand_used_vars.
19325 (stack_protect_return_slot_p): New function.
19326 (expand_used_vars): Call stack_protect_decl_p and
19327 stack_protect_return_slot_p for -fstack-protector-strong.
19328
19329 2014-05-09 David Wohlferd <LimeGreenSocks@yahoo.com>
19330 Andrew Haley <aph@redhat.com>
19331 Richard Sandiford <rdsandiford@googlemail.com>
19332
19333 * doc/extend.texi: Rewrite inline asm page / re-org asm-related
19334 pages.
19335
19336 2014-05-09 Kenneth Zadeck <zadeck@naturalbridge.com>
19337
19338 PR middle-end/61111
19339 * fold-const.c (fold_binary_loc): Changed width of mask.
19340
19341 2014-05-09 Georg-Johann Lay <avr@gjlay.de>
19342
19343 * config/avr/avr-fixed.md (round<mode>3): Use -1U instead of -1 in
19344 unsigned int initializers for regno_in, regno_out.
19345
19346 2014-05-09 Georg-Johann Lay <avr@gjlay.de>
19347
19348 PR target/61055
19349 * config/avr/avr.md (cc): Add new attribute set_vzn.
19350 (addqi3, addqq3, adduqq3, subqi3, subqq3, subuqq3, negqi2) [cc]:
19351 Set cc insn attribute to set_vzn instead of set_zn for alternatives
19352 with INC, DEC or NEG.
19353 * config/avr/avr.c (avr_notice_update_cc): Handle SET_VZN.
19354 (avr_out_plus_1): ADIW sets cc0 to CC_SET_CZN.
19355 INC, DEC and ADD+ADC set cc0 to CC_CLOBBER.
19356
19357 2014-05-09 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
19358
19359 Revert:
19360 2014-05-08 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
19361
19362 * wide-int.cc (UTItype): Define.
19363 (UDWtype): Define for appropriate W_TYPE_SIZE.
19364
19365 2014-05-09 Richard Biener <rguenther@suse.de>
19366
19367 * Makefile.in (GTFILES): Remove tree-ssa-propagate.c.
19368 * tree-ssa-propagate.c: Do not include gt-tree-ssa-propagate.h.
19369 (interesting_ssa_edges, varying_ssa_edges): Move out of GC space.
19370 (add_ssa_edge, process_ssa_edge_worklist, ssa_prop_init,
19371 ssa_propagate): Adjust.
19372
19373 2014-05-08 Jeff Law <law@redhat.com>
19374
19375 PR tree-optimization/61009
19376 * tree-ssa-threadedge.c (thread_through_normal_block): Return a
19377 tri-state rather than a boolean. When a block is too big to
19378 thread through, inform caller via negative return value.
19379 (thread_across_edge): If a block was too big for normal threading,
19380 then it's too big for a joiner too, so remove temporary equivalences
19381 and return immediately.
19382
19383 2014-05-08 Manuel López-Ibáñez <manu@gcc.gnu.org>
19384 Matthias Klose <doko@ubuntu.com>
19385
19386 PR driver/61106
19387 * optc-gen.awk: Fix option handling for -Wunused-parameter.
19388
19389 2014-05-08 Uros Bizjak <ubizjak@gmail.com>
19390
19391 PR target/59952
19392 * config/i386/i386.c (PTA_HASWELL): Remove PTA_RTM.
19393
19394 2014-05-08 Uros Bizjak <ubizjak@gmail.com>
19395
19396 PR target/61092
19397 * config/alpha/alpha.c: Include gimple-iterator.h.
19398 (alpha_gimple_fold_builtin): New function. Move
19399 ALPHA_BUILTIN_UMULH folding from ...
19400 (alpha_fold_builtin): ... here.
19401 (TARGET_GIMPLE_FOLD_BUILTIN): New define.
19402
19403 2014-05-08 Wei Mi <wmi@google.com>
19404
19405 PR target/58066
19406 * config/i386/i386.c (ix86_compute_frame_layout): Update
19407 preferred_stack_boundary for call, expanded from tls descriptor.
19408 * config/i386/i386.md (*tls_global_dynamic_32_gnu): Update RTX
19409 to depend on SP register.
19410 (*tls_local_dynamic_base_32_gnu): Ditto.
19411 (*tls_local_dynamic_32_once): Ditto.
19412 (tls_global_dynamic_64_<mode>): Set
19413 ix86_tls_descriptor_calls_expanded_in_cfun.
19414 (tls_local_dynamic_base_64_<mode>): Ditto.
19415 (tls_global_dynamic_32): Set
19416 ix86_tls_descriptor_calls_expanded_in_cfun. Update RTX
19417 to depend on SP register.
19418 (tls_local_dynamic_base_32): Ditto.
19419
19420 2014-05-08 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
19421
19422 * config/arm/arm_neon.h: Update comment.
19423 * config/arm/neon-docgen.ml: Delete.
19424 * config/arm/neon-gen.ml: Delete.
19425 * doc/arm-neon-intrinsics.texi: Update comment.
19426
19427 2014-05-08 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
19428
19429 * config/arm/arm_neon_builtins.def (vadd, vsub): Only define the v2sf
19430 and v4sf versions.
19431 (vand, vorr, veor, vorn, vbic): Remove.
19432 * config/arm/neon.md (neon_vadd, neon_vsub, neon_vadd_unspec): Adjust
19433 iterator.
19434 (neon_vsub_unspec): Likewise.
19435 (neon_vorr, neon_vand, neon_vbic, neon_veor, neon_vorn): Remove.
19436
19437 2014-05-08 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
19438
19439 * config/arm/arm_neon.h (vadd_s8): GNU C implementation
19440 (vadd_s16): Likewise.
19441 (vadd_s32): Likewise.
19442 (vadd_f32): Likewise.
19443 (vadd_u8): Likewise.
19444 (vadd_u16): Likewise.
19445 (vadd_u32): Likewise.
19446 (vadd_s64): Likewise.
19447 (vadd_u64): Likewise.
19448 (vaddq_s8): Likewise.
19449 (vaddq_s16): Likewise.
19450 (vaddq_s32): Likewise.
19451 (vaddq_s64): Likewise.
19452 (vaddq_f32): Likewise.
19453 (vaddq_u8): Likewise.
19454 (vaddq_u16): Likewise.
19455 (vaddq_u32): Likewise.
19456 (vaddq_u64): Likewise.
19457 (vmul_s8): Likewise.
19458 (vmul_s16): Likewise.
19459 (vmul_s32): Likewise.
19460 (vmul_f32): Likewise.
19461 (vmul_u8): Likewise.
19462 (vmul_u16): Likewise.
19463 (vmul_u32): Likewise.
19464 (vmul_p8): Likewise.
19465 (vmulq_s8): Likewise.
19466 (vmulq_s16): Likewise.
19467 (vmulq_s32): Likewise.
19468 (vmulq_f32): Likewise.
19469 (vmulq_u8): Likewise.
19470 (vmulq_u16): Likewise.
19471 (vmulq_u32): Likewise.
19472 (vsub_s8): Likewise.
19473 (vsub_s16): Likewise.
19474 (vsub_s32): Likewise.
19475 (vsub_f32): Likewise.
19476 (vsub_u8): Likewise.
19477 (vsub_u16): Likewise.
19478 (vsub_u32): Likewise.
19479 (vsub_s64): Likewise.
19480 (vsub_u64): Likewise.
19481 (vsubq_s8): Likewise.
19482 (vsubq_s16): Likewise.
19483 (vsubq_s32): Likewise.
19484 (vsubq_s64): Likewise.
19485 (vsubq_f32): Likewise.
19486 (vsubq_u8): Likewise.
19487 (vsubq_u16): Likewise.
19488 (vsubq_u32): Likewise.
19489 (vsubq_u64): Likewise.
19490 (vand_s8): Likewise.
19491 (vand_s16): Likewise.
19492 (vand_s32): Likewise.
19493 (vand_u8): Likewise.
19494 (vand_u16): Likewise.
19495 (vand_u32): Likewise.
19496 (vand_s64): Likewise.
19497 (vand_u64): Likewise.
19498 (vandq_s8): Likewise.
19499 (vandq_s16): Likewise.
19500 (vandq_s32): Likewise.
19501 (vandq_s64): Likewise.
19502 (vandq_u8): Likewise.
19503 (vandq_u16): Likewise.
19504 (vandq_u32): Likewise.
19505 (vandq_u64): Likewise.
19506 (vorr_s8): Likewise.
19507 (vorr_s16): Likewise.
19508 (vorr_s32): Likewise.
19509 (vorr_u8): Likewise.
19510 (vorr_u16): Likewise.
19511 (vorr_u32): Likewise.
19512 (vorr_s64): Likewise.
19513 (vorr_u64): Likewise.
19514 (vorrq_s8): Likewise.
19515 (vorrq_s16): Likewise.
19516 (vorrq_s32): Likewise.
19517 (vorrq_s64): Likewise.
19518 (vorrq_u8): Likewise.
19519 (vorrq_u16): Likewise.
19520 (vorrq_u32): Likewise.
19521 (vorrq_u64): Likewise.
19522 (veor_s8): Likewise.
19523 (veor_s16): Likewise.
19524 (veor_s32): Likewise.
19525 (veor_u8): Likewise.
19526 (veor_u16): Likewise.
19527 (veor_u32): Likewise.
19528 (veor_s64): Likewise.
19529 (veor_u64): Likewise.
19530 (veorq_s8): Likewise.
19531 (veorq_s16): Likewise.
19532 (veorq_s32): Likewise.
19533 (veorq_s64): Likewise.
19534 (veorq_u8): Likewise.
19535 (veorq_u16): Likewise.
19536 (veorq_u32): Likewise.
19537 (veorq_u64): Likewise.
19538 (vbic_s8): Likewise.
19539 (vbic_s16): Likewise.
19540 (vbic_s32): Likewise.
19541 (vbic_u8): Likewise.
19542 (vbic_u16): Likewise.
19543 (vbic_u32): Likewise.
19544 (vbic_s64): Likewise.
19545 (vbic_u64): Likewise.
19546 (vbicq_s8): Likewise.
19547 (vbicq_s16): Likewise.
19548 (vbicq_s32): Likewise.
19549 (vbicq_s64): Likewise.
19550 (vbicq_u8): Likewise.
19551 (vbicq_u16): Likewise.
19552 (vbicq_u32): Likewise.
19553 (vbicq_u64): Likewise.
19554 (vorn_s8): Likewise.
19555 (vorn_s16): Likewise.
19556 (vorn_s32): Likewise.
19557 (vorn_u8): Likewise.
19558 (vorn_u16): Likewise.
19559 (vorn_u32): Likewise.
19560 (vorn_s64): Likewise.
19561 (vorn_u64): Likewise.
19562 (vornq_s8): Likewise.
19563 (vornq_s16): Likewise.
19564 (vornq_s32): Likewise.
19565 (vornq_s64): Likewise.
19566 (vornq_u8): Likewise.
19567 (vornq_u16): Likewise.
19568 (vornq_u32): Likewise.
19569 (vornq_u64): Likewise.
19570
19571 2014-05-08 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
19572
19573 * wide-int.cc (UTItype): Define.
19574 (UDWtype): Define for appropriate W_TYPE_SIZE.
19575
19576 2014-05-08 Marc Glisse <marc.glisse@inria.fr>
19577
19578 PR tree-optimization/59100
19579 * tree-ssa-phiopt.c: Include tree-inline.h.
19580 (neutral_element_p, absorbing_element_p): New functions.
19581 (value_replacement): Handle conditional binary operations with a
19582 neutral or absorbing element.
19583
19584 2014-05-08 Richard Biener <rguenther@suse.de>
19585
19586 * tree-ssa-sccvn.c (vn_get_expr_for): Valueize operands before
19587 folding the expression.
19588 (valueize_expr): Remove.
19589 (visit_reference_op_load): Do not valueize the result of
19590 vn_get_expr_for.
19591 (simplify_binary_expression): Likewise.
19592 (simplify_unary_expression): Likewise.
19593
19594 2014-05-08 Richard Biener <rguenther@suse.de>
19595
19596 * gimplify.c (gimplify_call_expr): Use saved fnptrtype for
19597 looking at TYPE_ARG_TYPES.
19598
19599 2014-05-08 Richard Biener <rguenther@suse.de>
19600
19601 * gimple-fold.c (gimple_fold_stmt_to_constant_1): Remove
19602 pointer propagation special-case.
19603
19604 2014-05-08 Bin Cheng <bin.cheng@arm.com>
19605
19606 * tree-affine.c (tree_to_aff_combination): Handle MEM_REF for
19607 core part of address expressions.
19608
19609 2014-05-08 Alan Modra <amodra@gmail.com>
19610
19611 PR target/60737
19612 * config/rs6000/rs6000.c (expand_block_move): Allow 64-bit
19613 loads and stores when -mno-strict-align at any alignment.
19614 (expand_block_clear): Similarly. Also correct calculation of
19615 instruction count.
19616
19617 2014-05-07 Thomas Preud'homme <thomas.preudhomme@arm.com>
19618
19619 PR middle-end/39246
19620 * tree-complex.c (expand_complex_move): Keep line info when expanding
19621 complex move.
19622 * tree-ssa-uninit.c (warn_uninit): New argument. Ignore assignment
19623 of complex expression. Use new argument to display correct location
19624 for values coming from phi statement.
19625 (warn_uninitialized_vars): Adapt to new signature of warn_uninit.
19626 (warn_uninitialized_phi): Pass location of phi argument to
19627 warn_uninit.
19628 * tree-ssa.c (ssa_undefined_value_p): For SSA_NAME initialized by a
19629 COMPLEX_EXPR, recurse on each part of the COMPLEX_EXPR.
19630
19631 2014-05-07 Segher Boessenkool <segher@kernel.crashing.org>
19632
19633 * config/rs6000/predicates.md (indexed_address_mem): New.
19634 * config/rs6000/rs6000.md (type): Remove load_ext, load_ext_u,
19635 load_ext_ux, load_ux, load_u, store_ux, store_u, fpload_ux, fpload_u,
19636 fpstore_ux, fpstore_u.
19637 (sign_extend, indexed, update): New.
19638 (cell_micro): Adjust.
19639 (*zero_extend<mode>di2_internal1, *zero_extendsidi2_lfiwzx,
19640 *extendsidi2_lfiwax, *extendsidi2_nocell, *extendsfdf2_fpr,
19641 *movsi_internal1, *movsi_internal1_single, *movhi_internal,
19642 *movqi_internal, *movcc_internal1, mov<mode>_hardfloat,
19643 *mov<mode>_softfloat, *mov<mode>_hardfloat32, *mov<mode>_hardfloat64,
19644 *mov<mode>_softfloat64, *movdi_internal32, *movdi_internal64,
19645 *mov<mode>_string, *ldmsi8, *ldmsi7, *ldmsi6, *ldmsi5, *ldmsi4,
19646 *ldmsi3, *stmsi8, *stmsi7, *stmsi6, *stmsi5, *stmsi4, *stmsi3,
19647 *movdi_update1, movdi_<mode>_update, movdi_<mode>_update_stack,
19648 *movsi_update1, *movsi_update2, movsi_update, movsi_update_stack,
19649 *movhi_update1, *movhi_update2, *movhi_update3, *movhi_update4,
19650 *movqi_update1, *movqi_update2, *movqi_update3, *movsf_update1,
19651 *movsf_update2, *movsf_update3, *movsf_update4, *movdf_update1,
19652 *movdf_update2, load_toc_aix_si, load_toc_aix_di, probe_stack_<mode>,
19653 *stmw, *lmw, as well as 10 anonymous patterns): Adjust.
19654
19655 * config/rs6000/dfp.md (movsd_store, movsd_load): Adjust.
19656 * config/rs6000/vsx.md (*vsx_movti_32bit, *vsx_extract_<mode>_load,
19657 *vsx_extract_<mode>_store): Adjust.
19658 * config/rs6000/rs6000.c (rs6000_adjust_cost, is_microcoded_insn,
19659 is_cracked_insn, insn_must_be_first_in_group,
19660 insn_must_be_last_in_group): Adjust.
19661
19662 * config/rs6000/40x.md (ppc403-load, ppc403-store, ppc405-float):
19663 Adjust.
19664 * config/rs6000/440.md (ppc440-load, ppc440-store, ppc440-fpload,
19665 ppc440-fpstore): Adjust.
19666 * config/rs6000/476.md (ppc476-load, ppc476-store, ppc476-fpload,
19667 ppc476-fpstore): Adjust.
19668 * config/rs6000/601.md (ppc601-load, ppc601-store, ppc601-fpload,
19669 ppc601-fpstore): Adjust.
19670 * config/rs6000/603.md (ppc603-load, ppc603-store, ppc603-fpload):
19671 Adjust.
19672 * config/rs6000/6xx.md (ppc604-load, ppc604-store, ppc604-fpload):
19673 Adjust.
19674 * config/rs6000/7450.md (ppc7450-load, ppc7450-store, ppc7450-fpload,
19675 ppc7450-fpstore): Adjust.
19676 * config/rs6000/7xx.md (ppc750-load, ppc750-store): Adjust.
19677 * config/rs6000/8540.md (ppc8540_load, ppc8540_store): Adjust.
19678 * config/rs6000/a2.md (ppca2-load, ppca2-fp-load, ppca2-fp-store):
19679 Adjust.
19680 * config/rs6000/cell.md (cell-load, cell-load-ux, cell-load-ext,
19681 cell-fpload, cell-fpload-update, cell-store, cell-store-update,
19682 cell-fpstore, cell-fpstore-update): Adjust.
19683 * config/rs6000/e300c2c3.md (ppce300c3_load, ppce300c3_fpload,
19684 ppce300c3_store, ppce300c3_fpstore): Adjust.
19685 * config/rs6000/e500mc.md (e500mc_load, e500mc_fpload, e500mc_store,
19686 e500mc_fpstore): Adjust.
19687 * config/rs6000/e500mc64.md (e500mc64_load, e500mc64_fpload,
19688 e500mc64_store, e500mc64_fpstore): Adjust.
19689 * config/rs6000/e5500.md (e5500_load, e5500_fpload, e5500_store,
19690 e5500_fpstore): Adjust.
19691 * config/rs6000/e6500.md (e6500_load, e6500_fpload, e6500_store,
19692 e6500_fpstore): Adjust.
19693 * config/rs6000/mpc.md (mpccore-load, mpccore-store, mpccore-fpload):
19694 Adjust.
19695 * config/rs6000/power4.md (power4-load, power4-load-ext,
19696 power4-load-ext-update, power4-load-ext-update-indexed,
19697 power4-load-update-indexed, power4-load-update, power4-fpload,
19698 power4-fpload-update, power4-store, power4-store-update,
19699 power4-store-update-indexed, power4-fpstore, power4-fpstore-update):
19700 Adjust.
19701 * config/rs6000/power5.md (power5-load, power5-load-ext,
19702 power5-load-ext-update, power5-load-ext-update-indexed,
19703 power5-load-update-indexed, power5-load-update, power5-fpload,
19704 power5-fpload-update, power5-store, power5-store-update,
19705 power5-store-update-indexed, power5-fpstore, power5-fpstore-update):
19706 Adjust.
19707 * config/rs6000/power6.md (power6-load, power6-load-ext,
19708 power6-load-update, power6-load-update-indexed,
19709 power6-load-ext-update, power6-load-ext-update-indexed, power6-fpload,
19710 power6-fpload-update, power6-store, power6-store-update,
19711 power6-store-update-indexed, power6-fpstore, power6-fpstore-update):
19712 Adjust.
19713 * config/rs6000/power7.md (power7-load, power7-load-ext,
19714 power7-load-update, power7-load-update-indexed,
19715 power7-load-ext-update, power7-load-ext-update-indexed, power7-fpload,
19716 power7-fpload-update, power7-store, power7-store-update,
19717 power7-store-update-indexed, power7-fpstore, power7-fpstore-update):
19718 Adjust.
19719 * config/rs6000/power8.md (power8-load, power8-load-update,
19720 power8-load-ext, power8-load-ext-update, power8-fpload,
19721 power8-fpload-update, power8-store, power8-store-update-indexed,
19722 power8-fpstore, power8-fpstore-update): Adjust.
19723 * config/rs6000/rs64.md (rs64a-load, rs64a-store, rs64a-fpload):
19724 Adjust.
19725 * config/rs6000/titan.md (titan_lsu_load, titan_lsu_fpload,
19726 titan_lsu_store, titan_lsu_fpstore): Adjust.
19727 * config/rs6000/xfpu.md (fp-load, fp-store): Adjust.
19728
19729 2014-05-07 Oleg Endo <olegendo@gcc.gnu.org>
19730
19731 PR target/60884
19732 * config/sh/sh-mem.cc (sh_expand_strlen): Use loop when emitting
19733 unrolled byte insns. Emit address increments after move insns.
19734
19735 2014-05-07 David Malcolm <dmalcolm@redhat.com>
19736
19737 * gimple.h (gimple_builtin_call_types_compatible_p): Accept a
19738 const_gimple, rather than a gimple.
19739 (gimple_call_builtin_p): Likewise, for the three variants.
19740
19741 * gimple.c (gimple_builtin_call_types_compatible_p): Likewise.
19742 (gimple_call_builtin_p): Likewise, for the three variants.
19743
19744 2014-05-07 Richard Sandiford <rsandifo@linux.vnet.ibm.com>
19745
19746 PR tree-optimization/61095
19747 * tree-ssanames.c (get_nonzero_bits): Fix type extension in wi::shwi.
19748
19749 2014-05-07 Richard Biener <rguenther@suse.de>
19750
19751 PR tree-optimization/61034
19752 * tree-ssa-alias.c (call_may_clobber_ref_p_1): Export.
19753 (maybe_skip_until): Use translate to take into account
19754 lattices when trying to do disambiguations.
19755 (get_continuation_for_phi_1): Likewise.
19756 (get_continuation_for_phi): Adjust for added translate arguments.
19757 (walk_non_aliased_vuses): Likewise.
19758 * tree-ssa-alias.h (get_continuation_for_phi): Adjust prototype.
19759 (walk_non_aliased_vuses): Likewise.
19760 (call_may_clobber_ref_p_1): Declare.
19761 * tree-ssa-sccvn.c (vn_reference_lookup_3): Also disambiguate against
19762 calls. Stop early if we are only supposed to disambiguate.
19763 * tree-ssa-pre.c (translate_vuse_through_block): Adjust.
19764
19765 2014-05-07 Joern Rennecke <joern.rennecke@embecosm.com>
19766
19767 * config/epiphany/epiphany.c (epiphany_handle_interrupt_attribute):
19768 Emit an error when the function has arguments.
19769
19770 2014-05-07 Thomas Schwinge <thomas@codesourcery.com>
19771
19772 * cfgloop.h (unswitch_loops): Remove.
19773 * doc/passes.texi: Remove references to loop-unswitch.c
19774 * timevar.def (TV_LOOP_UNSWITCH): Remove.
19775
19776 2014-05-07 Evgeny Stupachenko <evstupac@gmail.com>
19777
19778 * tree-vect-data-refs.c (vect_grouped_load_supported): New
19779 check for loads group of length 3.
19780 (vect_permute_load_chain): New permutations for loads group of
19781 length 3.
19782 * tree-vect-stmts.c (vect_model_load_cost): Change cost
19783 of vec_perm_shuffle for the new permutations.
19784
19785 2014-05-07 Alan Lawrence <alan.lawrence@arm.com>
19786
19787 * config/aarch64/arm_neon.h (vtrn1_f32, vtrn1_p8, vtrn1_p16, vtrn1_s8,
19788 vtrn1_s16, vtrn1_s32, vtrn1_u8, vtrn1_u16, vtrn1_u32, vtrn1q_f32,
19789 vtrn1q_f64, vtrn1q_p8, vtrn1q_p16, vtrn1q_s8, vtrn1q_s16, vtrn1q_s32,
19790 vtrn1q_s64, vtrn1q_u8, vtrn1q_u16, vtrn1q_u32, vtrn1q_u64, vtrn2_f32,
19791 vtrn2_p8, vtrn2_p16, vtrn2_s8, vtrn2_s16, vtrn2_s32, vtrn2_u8,
19792 vtrn2_u16, vtrn2_u32, vtrn2q_f32, vtrn2q_f64, vtrn2q_p8, vtrn2q_p16,
19793 vtrn2q_s8, vtrn2q_s16, vtrn2q_s32, vtrn2q_s64, vtrn2q_u8, vtrn2q_u16,
19794 vtrn2q_u32, vtrn2q_u64): Replace temporary asm with __builtin_shuffle.
19795
19796 2014-05-07 Thomas Schwinge <thomas@codesourcery.com>
19797
19798 * loop-unswitch.c: Delete.
19799
19800 2014-05-07 Richard Biener <rguenther@suse.de>
19801
19802 * config.gcc: Always set need_64bit_hwint to yes.
19803
19804 2014-05-07 Chung-Ju Wu <jasonwucj@gmail.com>
19805
19806 * config/nds32/nds32.h (HONOR_REG_ALLOC_ORDER): Have it in favor
19807 of using optimize_size.
19808
19809 2014-05-06 Mike Stump <mikestump@comcast.net>
19810
19811 * wide-int.h (wi::int_traits <HOST_WIDE_INT>): Always define.
19812
19813 2014-05-06 Joseph Myers <joseph@codesourcery.com>
19814
19815 * config/i386/sse.md (*mov<mode>_internal)
19816 (*<sse>_loadu<ssemodesuffix><avxsizesuffix><mask_name>)
19817 (*<sse2_avx_avx512f>_loaddqu<mode><mask_name>)
19818 (<sse>_andnot<mode>3, <code><mode>3, *andnot<mode>3)
19819 (*<code><mode>3, *andnot<mode>3<mask_name>)
19820 (<mask_codefor><code><mode>3<mask_name>): Only consider
19821 TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL for modes of size 16.
19822
19823 2014-05-06 Richard Sandiford <rdsandiford@googlemail.com>
19824
19825 Revert:
19826 2014-05-03 Richard Sandiford <rdsandiford@googlemail.com>
19827
19828 * lra-constraints.c (valid_address_p): Move earlier in file.
19829 Add a constraint argument to the address_info version.
19830 (satisfies_memory_constraint_p): New function.
19831 (satisfies_address_constraint_p): Likewise.
19832 (process_alt_operands, curr_insn_transform): Use them.
19833 (process_address): Pass the constraint to valid_address_p when
19834 checking address operands.
19835
19836 2014-05-06 Richard Sandiford <r.sandiford@uk.ibm.com>
19837
19838 * lto-cgraph.c (compute_ltrans_boundary): Make node variables local
19839 to their respective blocks. Fix inadvertent use of "node".
19840
19841 2014-05-06 Richard Sandiford <rdsandiford@googlemail.com>
19842
19843 * emit-rtl.c (init_derived_machine_modes): New functionm, split
19844 out from...
19845 (init_emit_once): ...here.
19846 * rtl.h (init_derived_machine_modes): Declare.
19847 * toplev.c (do_compile): Call it even if no_backend.
19848
19849 2014-05-06 Kenneth Zadeck <zadeck@naturalbridge.com>
19850 Mike Stump <mikestump@comcast.net>
19851 Richard Sandiford <rdsandiford@googlemail.com>
19852 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
19853
19854 * alias.c (ao_ref_from_mem): Use wide-int interfaces.
19855 (rtx_equal_for_memref_p): Update comment.
19856 (adjust_offset_for_component_ref): Use wide-int interfaces.
19857 * builtins.c (get_object_alignment_2): Likewise.
19858 (c_readstr): Likewise.
19859 (target_char_cast): Add comment.
19860 (determine_block_size): Use wide-int interfaces.
19861 (expand_builtin_signbit): Likewise.
19862 (fold_builtin_int_roundingfn): Likewise.
19863 (fold_builtin_bitop): Likewise.
19864 (fold_builtin_bswap): Likewise.
19865 (fold_builtin_logarithm): Use signop.
19866 (fold_builtin_pow): Likewise.
19867 (fold_builtin_memory_op): Use wide-int interfaces.
19868 (fold_builtin_object_size): Likewise.
19869 * cfgloop.c (alloc_loop): Initialize nb_iterations_upper_bound and
19870 nb_iterations_estimate.
19871 (record_niter_bound): Use wide-int interfaces.
19872 (get_estimated_loop_iterations_int): Likewise.
19873 (get_estimated_loop_iterations): Likewise.
19874 (get_max_loop_iterations): Likewise.
19875 * cfgloop.h: Include wide-int.h.
19876 (struct nb_iter_bound): Change bound to widest_int.
19877 (struct loop): Change nb_iterations_upper_bound and
19878 nb_iterations_estimate to widest_int.
19879 (record_niter_bound): Switch to use widest_int.
19880 (get_estimated_loop_iterations): Likewise.
19881 (get_max_loop_iterations): Likewise.
19882 (gcov_type_to_double_int): Rename to gcov_type_to_wide_int and
19883 update for wide-int.
19884 * cgraph.c (cgraph_add_thunk): Use wide-int interfaces.
19885 * combine.c (try_combine): Likewise.
19886 (subst): Use CONST_SCALAR_INT_P rather than CONST_INT_P.
19887 * config/aarch64/aarch64.c (aapcs_vfp_sub_candidate): Use wide-int
19888 interfaces.
19889 (aarch64_float_const_representable_p): Likewise.
19890 * config/arc/arc.c: Include wide-int.h.
19891 (arc_can_use_doloop_p): Use wide-int interfaces.
19892 * config/arm/arm.c (aapcs_vfp_sub_candidate): Likewise.
19893 (vfp3_const_double_index): Likewise.
19894 * config/avr/avr.c (avr_out_round): Likewise.
19895 (avr_fold_builtin): Likewise.
19896 * config/bfin/bfin.c (bfin_local_alignment): Likewise.
19897 (bfin_can_use_doloop_p): Likewise.
19898 * config/darwin.c (darwin_mergeable_constant_section): Likewise.
19899 (machopic_select_rtx_section): Update to handle CONST_WIDE_INT.
19900 * config/i386/i386.c: Include wide-int.h.
19901 (ix86_data_alignment): Use wide-int interfaces.
19902 (ix86_local_alignment): Likewise.
19903 (ix86_emit_swsqrtsf): Update real_from_integer.
19904 * config/msp430/msp430.c (msp430_attr): Use wide-int interfaces.
19905 * config/nds32/nds32.c (nds32_insert_attributes): Likewise.
19906 * config/rs6000/predicates.md (any_operand): Add const_wide_int.
19907 (zero_constant): Likewise.
19908 (input_operand): Likewise.
19909 (splat_input_operand): Likewise.
19910 (non_logical_cint_operand): Change const_double to const_wide_int.
19911 * config/rs6000/rs6000.c (num_insns_constant): Handle CONST_WIDE_INT.
19912 (easy_altivec_constant): Remove comment.
19913 (paired_expand_vector_init): Use CONSTANT_P.
19914 (rs6000_legitimize_address): Handle CONST_WIDE_INT.
19915 (rs6000_emit_move): Update checks.
19916 (rs6000_aggregate_candidate): Use wide-int interfaces.
19917 (rs6000_expand_ternop_builtin): Likewise.
19918 (rs6000_output_move_128bit): Handle CONST_WIDE_INT.
19919 (rs6000_assemble_integer): Likewise.
19920 (rs6000_hash_constant): Likewise.
19921 (output_toc): Likewise.
19922 (rs6000_rtx_costs): Likewise.
19923 (rs6000_emit_swrsqrt); Update call to real_from_integer.
19924 * config/rs6000/rs6000-c.c: Include wide-int.h.
19925 (altivec_resolve_overloaded_builtin): Use wide-int interfaces.
19926 * config/rs6000/rs6000.h (TARGET_SUPPORTS_WIDE_INT): New.
19927 * config/rs6000/rs6000.md: Use const_scalar_int_operand.
19928 Handle CONST_WIDE_INT.
19929 * config/sol2-c.c (solaris_pragma_align): Change low to unsigned HWI.
19930 Use tree_fits_uhwi_p.
19931 * config/sparc/sparc.c: Include wide-int.h.
19932 (sparc_fold_builtin): Use wide-int interfaces.
19933 * config/vax/vax.c: Include wide-int.h.
19934 (vax_float_literal): Use real_from_integer.
19935 * coretypes.h (struct hwivec_def): New.
19936 (hwivec): New.
19937 (const_hwivec): New.
19938 * cse.c (hash_rtx_cb): Handle CONST_WIDE_INT.
19939 (equiv_constant): Handle CONST_WIDE_INT.
19940 * cselib.c (rtx_equal_for_cselib_1): Use CASE_CONST_UNIQUE.
19941 (cselib_hash_rtx): Handle CONST_WIDE_INT.
19942 * dbxout.c (stabstr_U): Use wide-int interfaces.
19943 (dbxout_type): Update to use cst_fits_shwi_p.
19944 * defaults.h (LOG2_BITS_PER_UNIT): Define.
19945 (TARGET_SUPPORTS_WIDE_INT): Add default.
19946 * dfp.c: Include wide-int.h.
19947 (decimal_real_to_integer2): Use wide-int interfaces and rename to
19948 decimal_real_to_integer.
19949 * dfp.h (decimal_real_to_integer2): Return a wide_int and rename to
19950 decimal_real_to_integer.
19951 * doc/generic.texi (Constant expressions): Update for wide_int.
19952 * doc/rtl.texi (const_double): Likewise.
19953 (const_wide_int, CONST_WIDE_INT, CONST_WIDE_INT_VEC): New.
19954 (CONST_WIDE_INT_NUNITS, CONST_WIDE_INT_ELT): New.
19955 * doc/tm.texi.in (REAL_VALUE_TO_INT): Remove.
19956 (REAL_VALUE_FROM_INT): Remove.
19957 (TARGET_SUPPORTS_WIDE_INT): New.
19958 * doc/tm.texi: Regenerate.
19959 * dojump.c (prefer_and_bit_test): Use wide-int interfaces.
19960 * double-int.h: Include wide-int.h.
19961 (struct wi::int_traits): New.
19962 * dwarf2out.c (get_full_len): New.
19963 (dw_val_equal_p): Add case dw_val_class_wide_int.
19964 (size_of_loc_descr): Likewise.
19965 (output_loc_operands): Likewise.
19966 (insert_double): Remove.
19967 (insert_wide_int): New.
19968 (add_AT_wide): New.
19969 (print_die): Add case dw_val_class_wide_int.
19970 (attr_checksum): Likewise.
19971 (attr_checksum_ordered): Likewise.
19972 (same_dw_val_p): Likewise.
19973 (size_of_die): Likewise.
19974 (value_format): Likewise.
19975 (output_die): Likewise.
19976 (double_int_type_size_in_bits): Rename to offset_int_type_size_in_bits.
19977 Use wide-int.
19978 (clz_loc_descriptor): Use wide-int interfaces.
19979 (mem_loc_descriptor): Likewise. Handle CONST_WIDE_INT.
19980 (loc_descriptor): Use wide-int interfaces. Handle CONST_WIDE_INT.
19981 (round_up_to_align): Use wide-int interfaces.
19982 (field_byte_offset): Likewise.
19983 (insert_double): Rename to insert_wide_int. Use wide-int interfaces.
19984 (add_const_value_attribute): Handle CONST_WIDE_INT. Update
19985 CONST_DOUBLE handling. Use wide-int interfaces.
19986 (add_bound_info): Use tree_fits_uhwi_p. Use wide-int interfaces.
19987 (gen_enumeration_type_die): Use add_AT_wide.
19988 (hash_loc_operands): Add case dw_val_class_wide_int.
19989 (compare_loc_operands): Likewise.
19990 * dwarf2out.h: Include wide-int.h.
19991 (wide_int_ptr): New.
19992 (enum dw_val_class): Add dw_val_class_wide_int.
19993 (struct dw_val_struct): Add val_wide.
19994 * emit-rtl.c (const_wide_int_htab): New.
19995 (const_wide_int_htab_hash): New.
19996 (const_wide_int_htab_eq): New.
19997 (lookup_const_wide_int): New.
19998 (const_double_htab_hash): Use wide-int interfaces.
19999 (const_double_htab_eq): Likewise.
20000 (rtx_to_double_int): Conditionally compile for wide-int.
20001 (immed_double_int_const): Rename to immed_wide_int_const and
20002 update for wide-int.
20003 (immed_double_const): Conditionally compile for wide-int.
20004 (init_emit_once): Use wide-int interfaces.
20005 * explow.c (plus_constant): Likewise.
20006 * expmed.c (mask_rtx): Move further up file. Use wide-int interfaces.
20007 (lshift_value): Use wide-int interfaces.
20008 (expand_mult): Likewise.
20009 (choose_multiplier): Likewise.
20010 (expand_smod_pow2): Likewise.
20011 (make_tree): Likewise.
20012 * expr.c (convert_modes): Consolidate handling of constants.
20013 Use wide-int interfaces.
20014 (emit_group_load_1): Add note.
20015 (store_expr): Update comment.
20016 (get_inner_reference): Use wide-int interfaces.
20017 (expand_constructor): Update comment.
20018 (expand_expr_real_2): Use wide-int interfaces.
20019 (expand_expr_real_1): Likewise.
20020 (reduce_to_bit_field_precision): Likewise.
20021 (const_vector_from_tree): Likewise.
20022 * final.c: Include wide-int-print.h.
20023 (output_addr_const): Handle CONST_WIDE_INT. Use CONST_DOUBLE_AS_INT_P.
20024 * fixed-value.c: Include wide-int.h.
20025 (fixed_from_string): Use wide-int interfaces.
20026 (fixed_to_decimal): Likewise.
20027 (fixed_convert_from_real): Likewise.
20028 (real_convert_from_fixed): Likewise.
20029 * fold-const.h (mem_ref_offset): Return an offset_int.
20030 (div_if_zero_remainder): Remove code parameter.
20031 * fold-const.c (div_if_zero_remainder): Remove code parameter.
20032 Use wide-int interfaces.
20033 (may_negate_without_overflow_p): Use wide-int interfaces.
20034 (negate_expr_p): Likewise.
20035 (fold_negate_expr): Likewise.
20036 (int_const_binop_1): Likewise.
20037 (const_binop): Likewise.
20038 (fold_convert_const_int_from_int): Likewise.
20039 (fold_convert_const_int_from_real): Likewise.
20040 (fold_convert_const_int_from_fixed): Likewise.
20041 (fold_convert_const_fixed_from_int): Likewise.
20042 (all_ones_mask_p): Take an unsigned size. Use wide-int interfaces.
20043 (sign_bit_p): Use wide-int interfaces.
20044 (make_range_step): Likewise.
20045 (build_range_check): Likewise. Pass an integer of the correct type
20046 instead of using integer_one_node.
20047 (range_predecessor): Pass an integer of the correct type instead
20048 of using integer_one_node.
20049 (range_successor): Likewise.
20050 (merge_ranges): Likewise.
20051 (unextend): Use wide-int interfaces.
20052 (extract_muldiv_1): Likewise.
20053 (fold_div_compare): Likewise.
20054 (fold_single_bit_test): Likewise.
20055 (fold_sign_changed_comparison): Likewise.
20056 (try_move_mult_to_index): Update calls to div_if_zero_remainder.
20057 (fold_plusminus_mult_expr): Use wide-int interfaces.
20058 (native_encode_int): Likewise.
20059 (native_interpret_int): Likewise.
20060 (fold_unary_loc): Likewise.
20061 (pointer_may_wrap_p): Likewise.
20062 (size_low_cst): Likewise.
20063 (mask_with_tz): Likewise.
20064 (fold_binary_loc): Likewise.
20065 (fold_ternary_loc): Likewise.
20066 (multiple_of_p): Likewise.
20067 (tree_call_nonnegative_warnv_p): Update calls to
20068 tree_int_cst_min_precision and real_from_integer.
20069 (fold_negate_const): Use wide-int interfaces.
20070 (fold_abs_const): Likewise.
20071 (fold_relational_const): Use tree_int_cst_lt.
20072 (round_up_loc): Use wide-int interfaces.
20073 * genemit.c (gen_exp): Add CONST_WIDE_INT case.
20074 * gengenrtl.c (excluded_rtx): Add CONST_WIDE_INT case.
20075 * gengtype.c: Remove include of double-int.h.
20076 (do_typedef): Use wide-int interfaces.
20077 (open_base_files): Add wide-int.h.
20078 (main): Add offset_int and widest_int typedefs.
20079 * gengtype-lex.l: Handle "^".
20080 (CXX_KEYWORD): Add "static".
20081 * gengtype-parse.c (require3): New.
20082 (require_template_declaration): Handle constant template arguments
20083 and nested templates.
20084 * gengtype-state.c: Don't include "double-int.h".
20085 * genpreds.c (write_one_predicate_function): Update comment.
20086 (write_tm_constrs_h): Add check for hval and lval use in
20087 CONST_WIDE_INT.
20088 * genrecog.c (validate_pattern): Add CONST_WIDE_INT case.
20089 (add_to_sequence): Likewise.
20090 * gensupport.c (struct std_pred_table): Add const_scalar_int_operand
20091 and const_double_operand.
20092 * gimple.c (preprocess_case_label_vec_for_gimple): Use wide-int
20093 interfaces.
20094 * gimple-fold.c (get_base_constructor): Likewise.
20095 (fold_array_ctor_reference): Likewise.
20096 (fold_nonarray_ctor_reference): Likewise.
20097 (fold_const_aggregate_ref_1): Likewise.
20098 (gimple_val_nonnegative_real_p): Likewise.
20099 (gimple_fold_indirect_ref): Likewise.
20100 * gimple-pretty-print.c (dump_ssaname_info): Likewise.
20101 * gimple-ssa-strength-reduction.c: Include wide-int-print.h.
20102 (struct slsr_cand_d): Change index to be widest_int.
20103 (struct incr_info_d): Change incr to be widest_int.
20104 (alloc_cand_and_find_basis): Use wide-int interfaces.
20105 (slsr_process_phi): Likewise.
20106 (backtrace_base_for_ref): Likewise. Return a widest_int.
20107 (restructure_reference): Take a widest_int instead of a double_int.
20108 (slsr_process_ref): Use wide-int interfaces.
20109 (create_mul_ssa_cand): Likewise.
20110 (create_mul_imm_cand): Likewise.
20111 (create_add_ssa_cand): Likewise.
20112 (create_add_imm_cand): Take a widest_int instead of a double_int.
20113 (slsr_process_add): Use wide-int interfaces.
20114 (slsr_process_cast): Likewise.
20115 (slsr_process_copy): Likewise.
20116 (dump_candidate): Likewise.
20117 (dump_incr_vec): Likewise.
20118 (replace_ref): Likewise.
20119 (cand_increment): Likewise. Return a widest_int.
20120 (cand_abs_increment): Likewise.
20121 (replace_mult_candidate): Take a widest_int instead of a double_int.
20122 (replace_unconditional_candidate): Use wide-int interfaces.
20123 (incr_vec_index): Take a widest_int instead of a double_int.
20124 (create_add_on_incoming_edge): Likewise.
20125 (create_phi_basis): Use wide-int interfaces.
20126 (replace_conditional_candidate): Likewise.
20127 (record_increment): Take a widest_int instead of a double_int.
20128 (record_phi_increments): Use wide-int interfaces.
20129 (phi_incr_cost): Take a widest_int instead of a double_int.
20130 (lowest_cost_path): Likewise.
20131 (total_savings): Likewise.
20132 (analyze_increments): Use wide-int interfaces.
20133 (ncd_with_phi): Take a widest_int instead of a double_int.
20134 (ncd_of_cand_and_phis): Likewise.
20135 (nearest_common_dominator_for_cands): Likewise.
20136 (insert_initializers): Use wide-int interfaces.
20137 (all_phi_incrs_profitable): Likewise.
20138 (replace_one_candidate): Likewise.
20139 (replace_profitable_candidates): Likewise.
20140 * godump.c: Include wide-int-print.h.
20141 (go_output_typedef): Use wide-int interfaces.
20142 * graphite-clast-to-gimple.c (gmp_cst_to_tree): Likewise.
20143 * graphite-sese-to-poly.c (tree_int_to_gmp): Likewise.
20144 (build_loop_iteration_domains): Likewise.
20145 * hooks.h: Include wide-int.h rather than double-int.h.
20146 (hook_bool_dint_dint_uint_bool_true): Delete.
20147 (hook_bool_wint_wint_uint_bool_true): Declare.
20148 * hooks.c (hook_bool_dint_dint_uint_bool_true): Removed.
20149 (hook_bool_wint_wint_uint_bool_true): New.
20150 * internal-fn.c (ubsan_expand_si_overflow_addsub_check): Use wide-int
20151 interfaces.
20152 (ubsan_expand_si_overflow_mul_check): Likewise.
20153 * ipa-devirt.c (get_polymorphic_call_info): Likewise.
20154 * ipa-prop.c (compute_complex_assign_jump_func): Likewise.
20155 (get_ancestor_addr_info): Likewise.
20156 (ipa_modify_call_arguments): Likewise.
20157 * loop-doloop.c (doloop_modify): Likewise.
20158 (doloop_optimize): Likewise.
20159 * loop-iv.c (iv_number_of_iterations): Likewise.
20160 * loop-unroll.c (decide_unroll_constant_iterations): Likewise.
20161 (unroll_loop_constant_iterations): Likewise.
20162 (decide_unroll_runtime_iterations): Likewise.
20163 (unroll_loop_runtime_iterations): Likewise.
20164 (decide_peel_simple): Likewise.
20165 (decide_unroll_stupid): Likewise.
20166 * lto-streamer-in.c (streamer_read_wi): Add.
20167 (input_cfg): Use wide-int interfaces.
20168 (lto_input_tree_1): Likewise.
20169 * lto-streamer-out.c (streamer_write_wi): Add.
20170 (hash_tree): Use wide-int interfaces.
20171 (output_cfg): Likewise.
20172 * Makefile.in (OBJS): Add wide-int.o and wide-int-print.o.
20173 (GTFILES): Add wide-int.h and signop.h.
20174 (TAGS): Look for .cc files too.
20175 * omp-low.c (scan_omp_1_op): Use wide-int interfaces.
20176 * optabs.c (expand_subword_shift): Likewise.
20177 (expand_doubleword_shift): Likewise.
20178 (expand_absneg_bit): Likewise.
20179 (expand_copysign_absneg): Likewise.
20180 (expand_copysign_bit): Likewise.
20181 * postreload.c (reload_cse_simplify_set): Likewise.
20182 * predict.c (predict_iv_comparison): Likewise.
20183 * pretty-print.h: Include wide-int-print.h.
20184 (pp_wide_int) New.
20185 * print-rtl.c (print_rtx): Add CONST_WIDE_INT case.
20186 * print-tree.c: Include wide-int-print.h.
20187 (print_node_brief): Use wide-int interfaces.
20188 (print_node): Likewise.
20189 * read-rtl.c (validate_const_wide_int): New.
20190 (read_rtx_code): Add CONST_WIDE_INT case.
20191 * real.c: Include wide-int.h.
20192 (real_to_integer2): Delete.
20193 (real_to_integer): New function, returning a wide_int.
20194 (real_from_integer): Take a wide_int rather than two HOST_WIDE_INTs.
20195 (ten_to_ptwo): Update call to real_from_integer.
20196 (real_digit): Likewise.
20197 * real.h: Include signop.h, wide-int.h and insn-modes.h.
20198 (real_to_integer2, REAL_VALUE_FROM_INT, REAL_VALUE_FROM_UNSIGNED_INT)
20199 (REAL_VALUE_TO_INT): Delete.
20200 (real_to_integer): Declare a wide-int form.
20201 (real_from_integer): Take a wide_int rather than two HOST_WIDE_INTs.
20202 * recog.c (const_int_operand): Improve comment.
20203 (const_scalar_int_operand): New.
20204 (const_double_operand): Add a separate definition for CONST_WIDE_INT.
20205 * rtlanal.c (commutative_operand_precedence): Handle CONST_WIDE_INT.
20206 (split_double): Likewise.
20207 * rtl.c (DEF_RTL_EXPR): Handle CONST_WIDE_INT.
20208 (rtx_size): Likewise.
20209 (rtx_alloc_stat_v): New.
20210 (rtx_alloc_stat): Now calls rtx_alloc_stat_v.
20211 (cwi_output_hex): New.
20212 (iterative_hash_rtx): Handle CONST_WIDE_INT.
20213 (cwi_check_failed_bounds): New.
20214 * rtl.def (CONST_WIDE_INT): New.
20215 * rtl.h: Include <utility> and wide-int.h.
20216 (struct hwivec_def): New.
20217 (CWI_GET_NUM_ELEM): New.
20218 (CWI_PUT_NUM_ELEM): New.
20219 (struct rtx_def): Add num_elem and hwiv.
20220 (CASE_CONST_SCALAR_INT): Modify for TARGET_SUPPORTS_WIDE_INT.
20221 (CASE_CONST_UNIQUE): Likewise.
20222 (CASE_CONST_ANY): Likewise.
20223 (CONST_SCALAR_INT_P): Likewise.
20224 (CONST_WIDE_INT_P): New.
20225 (CWI_ELT): New.
20226 (HWIVEC_CHECK): New.
20227 (cwi_check_failed_bounds): New.
20228 (CWI_ELT): New.
20229 (HWIVEC_CHECK): New.
20230 (CONST_WIDE_INT_VEC) New.
20231 (CONST_WIDE_INT_NUNITS) New.
20232 (CONST_WIDE_INT_ELT) New.
20233 (rtx_mode_t): New type.
20234 (wi::int_traits <rtx_mode_t>): New.
20235 (wi::shwi): New.
20236 (wi::min_value): New.
20237 (wi::max_value): New.
20238 (rtx_alloc_v) New.
20239 (const_wide_int_alloc): New.
20240 (immed_wide_int_const): New.
20241 * sched-vis.c (print_value): Handle CONST_WIDE_INT.
20242 * sel-sched-ir.c (lhs_and_rhs_separable_p): Update comment.
20243 * signop.h: New file.
20244 * simplify-rtx.c (mode_signbit_p): Handle CONST_WIDE_INT.
20245 (simplify_const_unary_operation): Use wide-int interfaces.
20246 (simplify_binary_operation_1): Likewise.
20247 (simplify_const_binary_operation): Likewise.
20248 (simplify_const_relational_operation): Likewise.
20249 (simplify_immed_subreg): Likewise.
20250 * stmt.c (expand_case): Likewise.
20251 * stor-layout.h (set_min_and_max_values_for_integral_type): Take a
20252 signop rather than a bool.
20253 * stor-layout.c (layout_type): Use wide-int interfaces.
20254 (initialize_sizetypes): Update calls to
20255 set_min_and_max_values_for_integral_type.
20256 (set_min_and_max_values_for_integral_type): Take a signop rather
20257 than a bool. Use wide-int interfaces.
20258 (fixup_signed_type): Update accordingly. Remove
20259 HOST_BITS_PER_DOUBLE_INT limit.
20260 (fixup_unsigned_type): Likewise.
20261 * system.h (STATIC_CONSTANT_P): New.
20262 (STATIC_ASSERT): New.
20263 * target.def (can_use_doloop_p): Take widest_ints rather than
20264 double_ints.
20265 * target.h: Include wide-int.h rather than double-int.h.
20266 * targhooks.h (can_use_doloop_if_innermost): Take widest_ints rather
20267 than double_ints.
20268 * targhooks.c (default_cxx_get_cookie_size): Use tree_int_cst_lt
20269 rather than INT_CST_LT_UNSIGNED.
20270 (can_use_doloop_if_innermost): Take widest_ints rather than
20271 double_ints.
20272 * tree-affine.c: Include wide-int-print.h.
20273 (double_int_ext_for_comb): Delete.
20274 (wide_int_ext_for_comb): New.
20275 (aff_combination_zero): Use wide-int interfaces.
20276 (aff_combination_const): Take a widest_int instead of a double_int.
20277 (aff_combination_elt): Use wide-int interfaces.
20278 (aff_combination_scale): Take a widest_int instead of a double_int.
20279 (aff_combination_add_elt): Likewise.
20280 (aff_combination_add_cst): Likewise.
20281 (aff_combination_add): Use wide-int interfaces.
20282 (aff_combination_convert): Likewise.
20283 (tree_to_aff_combination): Likewise.
20284 (add_elt_to_tree): Take a widest_int instead of a double_int.
20285 (aff_combination_to_tree): Use wide-int interfaces.
20286 (aff_combination_remove_elt): Likewise.
20287 (aff_combination_add_product): Take a widest_int instead of
20288 a double_int.
20289 (aff_combination_mult): Use wide-int interfaces.
20290 (aff_combination_expand): Likewise.
20291 (double_int_constant_multiple_p): Delete.
20292 (wide_int_constant_multiple_p): New.
20293 (aff_combination_constant_multiple_p): Take a widest_int pointer
20294 instead of a double_int pointer.
20295 (print_aff): Use wide-int interfaces.
20296 (get_inner_reference_aff): Take a widest_int pointer
20297 instead of a double_int pointer.
20298 (aff_comb_cannot_overlap_p): Take widest_ints instead of double_ints.
20299 * tree-affine.h: Include wide-int.h.
20300 (struct aff_comb_elt): Change type of coef to widest_int.
20301 (struct affine_tree_combination): Change type of offset to widest_int.
20302 (double_int_ext_for_comb): Delete.
20303 (wide_int_ext_for_comb): New.
20304 (aff_combination_const): Use widest_int instead of double_int.
20305 (aff_combination_scale): Likewise.
20306 (aff_combination_add_elt): Likewise.
20307 (aff_combination_constant_multiple_p): Likewise.
20308 (get_inner_reference_aff): Likewise.
20309 (aff_comb_cannot_overlap_p): Likewise.
20310 (aff_combination_zero_p): Use wide-int interfaces.
20311 * tree.c: Include tree.h.
20312 (init_ttree): Use make_int_cst.
20313 (tree_code_size): Removed code for INTEGER_CST case.
20314 (tree_size): Add INTEGER_CST case.
20315 (make_node_stat): Update comment.
20316 (get_int_cst_ext_nunits, build_new_int_cst, build_int_cstu): New.
20317 (build_int_cst_type): Use wide-int interfaces.
20318 (double_int_to_tree): Likewise.
20319 (double_int_fits_to_tree_p): Delete.
20320 (force_fit_type_double): Delete.
20321 (force_fit_type): New.
20322 (int_cst_hash_hash): Use wide-int interfaces.
20323 (int_cst_hash_eq): Likewise.
20324 (build_int_cst_wide): Delete.
20325 (wide_int_to_tree): New.
20326 (cache_integer_cst): Use wide-int interfaces.
20327 (build_low_bits_mask): Likewise.
20328 (cst_and_fits_in_hwi): Likewise.
20329 (real_value_from_int_cst): Likewise.
20330 (make_int_cst_stat): New.
20331 (integer_zerop): Use wide_int interfaces.
20332 (integer_onep): Likewise.
20333 (integer_all_onesp): Likewise.
20334 (integer_pow2p): Likewise.
20335 (integer_nonzerop): Likewise.
20336 (tree_log2): Likewise.
20337 (tree_floor_log2): Likewise.
20338 (tree_ctz): Likewise.
20339 (int_size_in_bytes): Likewise.
20340 (mem_ref_offset): Return an offset_int rather than a double_int.
20341 (build_type_attribute_qual_variant): Use wide_int interfaces.
20342 (type_hash_eq): Likewise
20343 (tree_int_cst_equal): Likewise.
20344 (tree_int_cst_lt): Delete.
20345 (tree_int_cst_compare): Likewise.
20346 (tree_fits_shwi_p): Use wide_int interfaces.
20347 (tree_fits_uhwi_p): Likewise.
20348 (tree_int_cst_sign_bit): Likewise.
20349 (tree_int_cst_sgn): Likewise.
20350 (tree_int_cst_min_precision): Take a signop rather than a bool.
20351 (simple_cst_equal): Use wide_int interfaces.
20352 (compare_tree_int): Likewise.
20353 (iterative_hash_expr): Likewise.
20354 (int_fits_type_p): Likewise. Use tree_int_cst_lt rather than
20355 INT_CST_LT.
20356 (get_type_static_bounds): Use wide_int interfaces.
20357 (tree_int_cst_elt_check_failed): New.
20358 (build_common_tree_nodes): Reordered to set prec before filling in
20359 value.
20360 (int_cst_value): Check cst_and_fits_in_hwi.
20361 (widest_int_cst_value): Use wide_int interfaces.
20362 (upper_bound_in_type): Likewise.
20363 (lower_bound_in_type): Likewise.
20364 (num_ending_zeros): Likewise.
20365 (drop_tree_overflow): Likewise.
20366 * tree-call-cdce.c (check_pow): Update call to real_from_integer.
20367 (gen_conditions_for_pow_cst_base): Likewise.
20368 * tree-cfg.c: Include wide-int.h and wide-int-print.h.
20369 (group_case_labels_stmt): Use wide-int interfaces.
20370 (verify_gimple_assign_binary): Likewise.
20371 (print_loop): Likewise.
20372 * tree-chrec.c (tree_fold_binomial): Likewise.
20373 * tree-core.h (struct tree_base): Add int_length.
20374 (struct tree_int_cst): Change rep of value.
20375 * tree-data-ref.c (dr_analyze_innermost): Use wide-int interfaces.
20376 (dr_may_alias_p): Likewise.
20377 (max_stmt_executions_tree): Likewise.
20378 * tree.def (INTEGER_CST): Update comment.
20379 * tree-dfa.c (get_ref_base_and_extent): Use wide-int interfaces.
20380 * tree-dfa.h (get_addr_base_and_unit_offset_1): Likewise.
20381 * tree-dump.c: Include wide-int.h and wide-int-print.h.
20382 (dequeue_and_dump): Use wide-int interfaces.
20383 * tree.h: Include wide-int.h.
20384 (NULL_TREE): Moved to earlier loc in file.
20385 (TREE_INT_CST_ELT_CHECK): New.
20386 (tree_int_cst_elt_check_failed): New.
20387 (TYPE_SIGN): New.
20388 (TREE_INT_CST): Delete.
20389 (TREE_INT_CST_LOW): Use wide-int interfaces.
20390 (TREE_INT_CST_HIGH): Delete.
20391 (TREE_INT_CST_NUNITS): New.
20392 (TREE_INT_CST_EXT_NUNITS): Likewise.
20393 (TREE_INT_CST_OFFSET_NUNITS): Likewise.
20394 (TREE_INT_CST_ELT): Likewise.
20395 (INT_CST_LT): Delete.
20396 (tree_int_cst_elt_check): New (two forms).
20397 (type_code_size): Update comment.
20398 (make_int_cst_stat, make_int_cst): New.
20399 (tree_to_double_int): Delete.
20400 (double_int_fits_to_tree_p): Delete.
20401 (force_fit_type_double): Delete.
20402 (build_int_cstu): Replace with out-of-line function.
20403 (build_int_cst_wide): Delete.
20404 (tree_int_cst_lt): Define inline.
20405 (tree_int_cst_le): New.
20406 (tree_int_cst_compare): Define inline.
20407 (tree_int_cst_min_precision): Take a signop rather than a bool.
20408 (wi::int_traits <const_tree>): New.
20409 (wi::int_traits <tree>): New.
20410 (wi::extended_tree): New.
20411 (wi::int_traits <wi::extended_tree>): New.
20412 (wi::to_widest): New.
20413 (wi::to_offset): New.
20414 (wi::fits_to_tree_p): New.
20415 (wi::min_value): New.
20416 (wi::max_value): New.
20417 * tree-inline.c (remap_gimple_op_r): Use wide-int interfaces.
20418 (copy_tree_body_r): Likewise.
20419 * tree-object-size.c (compute_object_offset): Likewise.
20420 (addr_object_size): Likewise.
20421 * tree-predcom.c: Include wide-int-print.h.
20422 (struct dref_d): Change type of offset to widest_int.
20423 (dump_dref): Call wide-int printer.
20424 (aff_combination_dr_offset): Use wide-int interfaces.
20425 (determine_offset): Take a widest_int pointer rather than a
20426 double_int pointer.
20427 (split_data_refs_to_components): Use wide-int interfaces.
20428 (suitable_component_p): Likewise.
20429 (order_drefs): Likewise.
20430 (add_ref_to_chain): Likewise.
20431 (valid_initializer_p): Likewise.
20432 (determine_roots_comp): Likewise.
20433 * tree-pretty-print.c: Include wide-int-print.h.
20434 (dump_generic_node): Use wide-int interfaces.
20435 * tree-sra.c (sra_ipa_modify_expr): Likewise.
20436 * tree-ssa-address.c (addr_for_mem_ref): Likewise.
20437 (move_fixed_address_to_symbol): Likewise.
20438 (move_hint_to_base): Likewise.
20439 (move_pointer_to_base): Likewise.
20440 (move_variant_to_index): Likewise.
20441 (most_expensive_mult_to_index): Likewise.
20442 (addr_to_parts): Likewise.
20443 (copy_ref_info): Likewise.
20444 * tree-ssa-alias.c (indirect_ref_may_alias_decl_p): Likewise.
20445 (indirect_refs_may_alias_p): Likewise.
20446 (stmt_kills_ref_p_1): Likewise.
20447 * tree-ssa.c (non_rewritable_mem_ref_base): Likewise.
20448 * tree-ssa-ccp.c: Update comment at top of file. Include
20449 wide-int-print.h.
20450 (struct prop_value_d): Change type of mask to widest_int.
20451 (extend_mask): New function.
20452 (dump_lattice_value): Use wide-int interfaces.
20453 (get_default_value): Likewise.
20454 (set_constant_value): Likewise.
20455 (set_value_varying): Likewise.
20456 (valid_lattice_transition): Likewise.
20457 (set_lattice_value): Likewise.
20458 (value_to_double_int): Delete.
20459 (value_to_wide_int): New.
20460 (get_value_from_alignment): Use wide-int interfaces.
20461 (get_value_for_expr): Likewise.
20462 (do_dbg_cnt): Likewise.
20463 (ccp_finalize): Likewise.
20464 (ccp_lattice_meet): Likewise.
20465 (bit_value_unop_1): Use widest_ints rather than double_ints.
20466 (bit_value_binop_1): Likewise.
20467 (bit_value_unop): Use wide-int interfaces.
20468 (bit_value_binop): Likewise.
20469 (bit_value_assume_aligned): Likewise.
20470 (evaluate_stmt): Likewise.
20471 (ccp_fold_stmt): Likewise.
20472 (visit_cond_stmt): Likewise.
20473 (ccp_visit_stmt): Likewise.
20474 * tree-ssa-forwprop.c (forward_propagate_addr_expr_1): Likewise.
20475 (constant_pointer_difference): Likewise.
20476 (associate_pointerplus): Likewise.
20477 (combine_conversions): Likewise.
20478 * tree-ssa-loop.h: Include wide-int.h.
20479 (struct tree_niter_desc): Change type of max to widest_int.
20480 * tree-ssa-loop-im.c (mem_refs_may_alias_p): Use wide-int interfaces.
20481 * tree-ssa-loop-ivcanon.c (remove_exits_and_undefined_stmts): Likewise.
20482 (remove_redundant_iv_tests): Likewise.
20483 (canonicalize_loop_induction_variables): Likewise.
20484 * tree-ssa-loop-ivopts.c (alloc_iv): Likewise.
20485 (constant_multiple_of): Take a widest_int pointer instead of
20486 a double_int pointer.
20487 (get_computation_aff): Use wide-int interfaces.
20488 (ptr_difference_cost): Likewise.
20489 (difference_cost): Likewise.
20490 (get_loop_invariant_expr_id): Likewise.
20491 (get_computation_cost_at): Likewise.
20492 (iv_elimination_compare_lt): Likewise.
20493 (may_eliminate_iv): Likewise.
20494 * tree-ssa-loop-niter.h (estimated_loop_iterations): Use widest_int
20495 instead of double_int.
20496 (max_loop_iterations): Likewise.
20497 (max_stmt_executions): Likewise.
20498 (estimated_stmt_executions): Likewise.
20499 * tree-ssa-loop-niter.c: Include wide-int-print.h.
20500 (split_to_var_and_offset): Use wide-int interfaces.
20501 (determine_value_range): Likewise.
20502 (bound_difference_of_offsetted_base): Likewise.
20503 (bounds_add): Take a widest_int instead of a double_int.
20504 (number_of_iterations_ne_max): Use wide-int interfaces.
20505 (number_of_iterations_ne): Likewise.
20506 (number_of_iterations_lt_to_ne): Likewise.
20507 (assert_loop_rolls_lt): Likewise.
20508 (number_of_iterations_lt): Likewise.
20509 (number_of_iterations_le): Likewise.
20510 (number_of_iterations_cond): Likewise.
20511 (number_of_iterations_exit): Likewise.
20512 (finite_loop_p): Likewise.
20513 (derive_constant_upper_bound_assign): Likewise.
20514 (derive_constant_upper_bound): Return a widest_int.
20515 (derive_constant_upper_bound_ops): Likewise.
20516 (do_warn_aggressive_loop_optimizations): Use wide-int interfaces.
20517 (record_estimate): Take a widest_int rather than a double_int.
20518 (record_nonwrapping_iv): Use wide-int interfaces.
20519 (double_int_cmp): Delete.
20520 (wide_int_cmp): New.
20521 (bound_index): Take a widest_int rather than a double_int.
20522 (discover_iteration_bound_by_body_walk): Use wide-int interfaces.
20523 (maybe_lower_iteration_bound): Likewise.
20524 (estimate_numbers_of_iterations_loop): Likewise.
20525 (estimated_loop_iterations): Take a widest_int pointer than than
20526 a double_int pointer.
20527 (estimated_loop_iterations_int): Use wide-int interfaces.
20528 (max_loop_iterations): Take a widest_int pointer than than
20529 a double_int pointer.
20530 (max_loop_iterations_int): Use wide-int interfaces.
20531 (max_stmt_executions): Take a widest_int pointer than than
20532 a double_int pointer.
20533 (estimated_stmt_executions): Likewise.
20534 (n_of_executions_at_most): Use wide-int interfaces.
20535 (scev_probably_wraps_p): Likewise.
20536 * tree-ssa-math-opts.c (gimple_expand_builtin_pow): Update calls
20537 to real_to_integer.
20538 * tree-scalar-evolution.c (simplify_peeled_chrec): Use wide-int
20539 interfaces.
20540 * tree-ssanames.c (set_range_info): Use wide_int_refs rather than
20541 double_ints. Adjust for trailing_wide_ints <3> representation.
20542 (set_nonzero_bits): Likewise.
20543 (get_range_info): Return wide_ints rather than double_ints.
20544 Adjust for trailing_wide_ints <3> representation.
20545 (get_nonzero_bits): Likewise.
20546 (duplicate_ssa_name_range_info): Adjust for trailing_wide_ints <3>
20547 representation.
20548 * tree-ssanames.h (struct range_info_def): Replace min, max and
20549 nonzero_bits with a trailing_wide_ints <3>.
20550 (set_range_info): Use wide_int_refs rather than double_ints.
20551 (set_nonzero_bits): Likewise.
20552 (get_range_info): Return wide_ints rather than double_ints.
20553 (get_nonzero_bits): Likewise.
20554 * tree-ssa-phiopt.c (jump_function_from_stmt): Use wide-int interfaces.
20555 * tree-ssa-pre.c (phi_translate_1): Likewise.
20556 * tree-ssa-reassoc.c (decrement_power): Use calls to real_from_integer.
20557 (acceptable_pow_call): Likewise.
20558 * tree-ssa-sccvn.c (copy_reference_ops_from_ref): Use wide-int
20559 interfaces.
20560 (vn_reference_fold_indirect): Likewise.
20561 (vn_reference_maybe_forwprop_address): Likewise.
20562 (valueize_refs_1): Likewise.
20563 * tree-ssa-structalias.c (get_constraint_for_ptr_offset): Likewise.
20564 * tree-ssa-uninit.c (is_value_included_in): Use wide-int interfaces,
20565 tree_int_cst_lt and tree_int_cst_le.
20566 * tree-streamer-in.c (unpack_ts_base_value_fields): Use wide-int
20567 interfaces.
20568 (streamer_alloc_tree): Likewise.
20569 * tree-streamer-out.c (pack_ts_int_cst_value_fields): Likewise.
20570 (streamer_write_tree_header): Likewise.
20571 (streamer_write_integer_cst): Likewise.
20572 * tree-switch-conversion.c (emit_case_bit_tests): Likewise.
20573 (build_constructors): Likewise.
20574 (array_value_type): Likewise.
20575 * tree-vect-data-refs.c (vect_prune_runtime_alias_test_list): Likewise.
20576 (vect_check_gather): Likewise.
20577 * tree-vect-generic.c (build_replicated_const): Likewise.
20578 (expand_vector_divmod): Likewise.
20579 * tree-vect-loop.c (vect_transform_loop): Likewise.
20580 * tree-vect-loop-manip.c (vect_do_peeling_for_loop_bound): Likewise.
20581 (vect_do_peeling_for_alignment): Likewise.
20582 * tree-vect-patterns.c (vect_recog_divmod_pattern): Likewise.
20583 * tree-vrp.c: Include wide-int.h.
20584 (operand_less_p): Use wide-int interfaces and tree_int_cst_lt.
20585 (extract_range_from_assert): Use wide-int interfaces.
20586 (vrp_int_const_binop): Likewise.
20587 (zero_nonzero_bits_from_vr): Take wide_int pointers rather than
20588 double_int pointers.
20589 (ranges_from_anti_range): Use wide-int interfaces.
20590 (quad_int_cmp): Delete.
20591 (quad_int_pair_sort): Likewise.
20592 (extract_range_from_binary_expr_1): Use wide-int interfaces.
20593 (extract_range_from_unary_expr_1): Likewise.
20594 (adjust_range_with_scev): Likewise.
20595 (masked_increment): Take and return wide_ints rather than double_ints.
20596 (register_edge_assert_for_2): Use wide-int interfaces.
20597 (check_array_ref): Likewise.
20598 (search_for_addr_array): Likewise.
20599 (maybe_set_nonzero_bits): Likewise.
20600 (union_ranges): Pass an integer of the correct type instead of
20601 using integer_one_node.
20602 (intersect_ranges): Likewise.
20603 (simplify_truth_ops_using_ranges): Likewise.
20604 (simplify_bit_ops_using_ranges): Use wide-int interfaces.
20605 (range_fits_type_p): Likewise.
20606 (simplify_cond_using_ranges): Likewise. Take a signop rather than
20607 a bool.
20608 (simplify_conversion_using_ranges): Use wide-int interfaces.
20609 (simplify_float_conversion_using_ranges): Likewise.
20610 (vrp_finalize): Likewise.
20611 * value-prof.c (gimple_divmod_fixed_value_transform): Likewise.
20612 (gimple_stringops_transform): Likewise.
20613 * varasm.c (decode_addr_const): Likewise.
20614 (const_hash_1): Likewise.
20615 (const_rtx_hash_1): Likewise
20616 (output_constant): Likewise.
20617 (array_size_for_constructor): Likewise.
20618 (output_constructor_regular_field): Likewise.
20619 (output_constructor_bitfield): Likewise.
20620 * var-tracking.c (loc_cmp): Handle CONST_WIDE_INT.
20621 * mkconfig.sh: Include machmode.h to pick up BITS_PER_UNIT for
20622 GENERATOR_FILEs.
20623 * gencheck.c: Define BITS_PER_UNIT.
20624 * wide-int.cc: New.
20625 * wide-int.h: New.
20626 * wide-int-print.cc: New.
20627 * wide-int-print.h: New.
20628
20629 2014-05-06 Jan-Benedict Glaw <jbglaw@lug-owl.de>
20630
20631 * config/avr/avr.c (avr_can_eliminate): Mark unused argument.
20632
20633 2014-05-06 Richard Biener <rguenther@suse.de>
20634
20635 * tree-pass.h (TODO_verify_ssa, TODO_verify_flow,
20636 TODO_verify_stmts, TODO_verify_rtl_sharing): Remove.
20637 (TODO_verify_all): Adjust.
20638 * asan.c: Remove references to TODO_verify_ssa, TODO_verify_flow,
20639 TODO_verify_stmts and TODO_verify_rtl_sharing.
20640 * bb-reorder.c: Likewise.
20641 * cfgexpand.c: Likewise.
20642 * cprop.c: Likewise.
20643 * cse.c: Likewise.
20644 * function.c: Likewise.
20645 * fwprop.c: Likewise.
20646 * gcse.c: Likewise.
20647 * gimple-ssa-isolate-paths.c: Likewise.
20648 * gimple-ssa-strength-reduction.c: Likewise.
20649 * ipa-split.c: Likewise.
20650 * loop-init.c: Likewise.
20651 * loop-unroll.c: Likewise.
20652 * lower-subreg.c: Likewise.
20653 * modulo-sched.c: Likewise.
20654 * postreload-gcse.c: Likewise.
20655 * predict.c: Likewise.
20656 * recog.c: Likewise.
20657 * sched-rgn.c: Likewise.
20658 * store-motion.c: Likewise.
20659 * tracer.c: Likewise.
20660 * trans-mem.c: Likewise.
20661 * tree-call-cdce.c: Likewise.
20662 * tree-cfg.c: Likewise.
20663 * tree-cfgcleanup.c: Likewise.
20664 * tree-complex.c: Likewise.
20665 * tree-eh.c: Likewise.
20666 * tree-emutls.c: Likewise.
20667 * tree-if-conv.c: Likewise.
20668 * tree-into-ssa.c: Likewise.
20669 * tree-loop-distribution.c: Likewise.
20670 * tree-object-size.c: Likewise.
20671 * tree-parloops.c: Likewise.
20672 * tree-pass.h: Likewise.
20673 * tree-sra.c: Likewise.
20674 * tree-ssa-ccp.c: Likewise.
20675 * tree-ssa-copy.c: Likewise.
20676 * tree-ssa-copyrename.c: Likewise.
20677 * tree-ssa-dce.c: Likewise.
20678 * tree-ssa-dom.c: Likewise.
20679 * tree-ssa-dse.c: Likewise.
20680 * tree-ssa-forwprop.c: Likewise.
20681 * tree-ssa-ifcombine.c: Likewise.
20682 * tree-ssa-loop-ch.c: Likewise.
20683 * tree-ssa-loop-ivcanon.c: Likewise.
20684 * tree-ssa-loop.c: Likewise.
20685 * tree-ssa-math-opts.c: Likewise.
20686 * tree-ssa-phiopt.c: Likewise.
20687 * tree-ssa-phiprop.c: Likewise.
20688 * tree-ssa-pre.c: Likewise.
20689 * tree-ssa-reassoc.c: Likewise.
20690 * tree-ssa-sink.c: Likewise.
20691 * tree-ssa-strlen.c: Likewise.
20692 * tree-ssa-tail-merge.c: Likewise.
20693 * tree-ssa-uncprop.c: Likewise.
20694 * tree-switch-conversion.c: Likewise.
20695 * tree-tailcall.c: Likewise.
20696 * tree-vect-generic.c: Likewise.
20697 * tree-vectorizer.c: Likewise.
20698 * tree-vrp.c: Likewise.
20699 * tsan.c: Likewise.
20700 * var-tracking.c: Likewise.
20701 * bt-load.c: Likewise.
20702 * cfgcleanup.c: Likewise.
20703 * combine-stack-adj.c: Likewise.
20704 * combine.c: Likewise.
20705 * compare-elim.c: Likewise.
20706 * config/epiphany/resolve-sw-modes.c: Likewise.
20707 * config/i386/i386.c: Likewise.
20708 * config/mips/mips.c: Likewise.
20709 * config/s390/s390.c: Likewise.
20710 * config/sh/sh_treg_combine.cc: Likewise.
20711 * config/sparc/sparc.c: Likewise.
20712 * dce.c: Likewise.
20713 * dse.c: Likewise.
20714 * final.c: Likewise.
20715 * ifcvt.c: Likewise.
20716 * mode-switching.c: Likewise.
20717 * passes.c: Likewise.
20718 * postreload.c: Likewise.
20719 * ree.c: Likewise.
20720 * reg-stack.c: Likewise.
20721 * regcprop.c: Likewise.
20722 * regrename.c: Likewise.
20723 * web.c: Likewise.
20724
20725 2014-05-06 Richard Biener <rguenther@suse.de>
20726
20727 PR middle-end/61070
20728 * bitmap.c (debug_bitmap): Dump to stderr, not stdout.
20729 * tree-ssa-structalias.c (dump_solution_for_var): Likewise.
20730
20731 2014-05-05 Jan Hubicka <hubicka@ucw.cz>
20732
20733 PR ipa/60965
20734 * ipa-devirt.c (get_class_context): Allow POD to change to non-POD.
20735
20736 2014-05-05 Radovan Obradovic <robradovic@mips.com>
20737 Tom de Vries <tom@codesourcery.com>
20738
20739 * target.def (call_fusage_contains_non_callee_clobbers): New
20740 DEFHOOKPOD.
20741 * doc/tm.texi.in (@node Stack and Calling): Add Miscellaneous Register
20742 Hooks to @menu.
20743 (@node Miscellaneous Register Hooks): New node.
20744 (@hook TARGET_CALL_FUSAGE_CONTAINS_NON_CALLEE_CLOBBERS): New hook.
20745 * doc/tm.texi: Regenerate.
20746
20747 2014-05-05 Marek Polacek <polacek@redhat.com>
20748
20749 PR driver/61065
20750 * opts.c (common_handle_option): Call error_at instead of warning_at.
20751
20752 2014-05-05 Richard Biener <rguenther@suse.de>
20753
20754 * passes.c (execute_function_todo): Don't reset TODO_verify_ssa
20755 from last_verified if update_ssa ran. Move TODO_verify_rtl_sharing
20756 under the TODO_verify_il umbrella.
20757
20758 2014-05-05 Richard Biener <rguenther@suse.de>
20759
20760 * passes.c (execute_function_todo): Move TODO_verify_flow under
20761 the TODO_verify_ul umbrella.
20762
20763 2014-05-05 Richard Biener <rguenther@suse.de>
20764
20765 PR middle-end/61010
20766 * fold-const.c (fold_binary_loc): Consistently avoid canonicalizing
20767 X & CST away from a CST that is the mask of a mode.
20768
20769 2014-05-05 Jan-Benedict Glaw <jbglaw@lug-owl.de>
20770
20771 * config/picochip/picochip-protos.h (picochip_regno_nregs): Change
20772 int argument to enum machine_mode.
20773 (picochip_class_max_nregs): Ditto.
20774 * config/picochip/picochip.c (picochip_regno_nregs): Ditto.
20775 (picochip_class_max_nregs): Ditto.
20776
20777 2014-05-05 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
20778
20779 * target.def: Add new target hook.
20780 * doc/tm.texi: Regenerate.
20781 * targhooks.h (default_keep_leaf_when_profiled): Add prototype.
20782 * targhooks.c (default_keep_leaf_when_profiled): New function.
20783
20784 * config/s390/s390.c (s390_keep_leaf_when_profiled): New function.
20785 (TARGET_KEEP_LEAF_WHEN_PROFILED): Define.
20786
20787 2014-05-05 Bin Cheng <bin.cheng@arm.com>
20788
20789 PR tree-optimization/60363
20790 * gcc/tree-ssa-threadupdate.c (get_value_locus_in_path): New.
20791 (copy_phi_args): New parameters. Call get_value_locus_in_path.
20792 (update_destination_phis): New parameter.
20793 (create_edge_and_update_destination_phis): Ditto.
20794 (ssa_fix_duplicate_block_edges): Pass new arguments.
20795 (thread_single_edge): Ditto.
20796
20797 2014-05-04 Peter Bergner <bergner@vnet.ibm.com>
20798
20799 * config/rs6000/rs6000.h (RS6000_BTM_HARD_FLOAT): New define.
20800 (RS6000_BTM_COMMON): Add RS6000_BTM_HARD_FLOAT.
20801 (TARGET_EXTRA_BUILTINS): Add TARGET_HARD_FLOAT.
20802 * config/rs6000/rs6000-builtin.def (BU_MISC_1):
20803 Use RS6000_BTM_HARD_FLOAT.
20804 (BU_MISC_2): Likewise.
20805 * config/rs6000/rs6000.c (rs6000_builtin_mask_calculate): Handle
20806 RS6000_BTM_HARD_FLOAT.
20807 (rs6000_option_override_internal): Enforce -mhard-float if -mhard-dfp
20808 is explicitly used.
20809 (rs6000_invalid_builtin): Add hard floating builtin support.
20810 (rs6000_expand_builtin): Relax the gcc_assert to allow the new
20811 hard float builtins.
20812 (rs6000_builtin_mask_names): Add RS6000_BTM_HARD_FLOAT.
20813
20814 2014-05-03 Oleg Endo <olegendo@gcc.gnu.org>
20815
20816 * config/sh/sh_optimize_sett_clrt.cc (sh_optimize_sett_clrt::execute):
20817 Add missing function* argument.
20818
20819 2014-05-03 Richard Sandiford <rdsandiford@googlemail.com>
20820
20821 * lra-constraints.c (valid_address_p): Move earlier in file.
20822 Add a constraint argument to the address_info version.
20823 (satisfies_memory_constraint_p): New function.
20824 (satisfies_address_constraint_p): Likewise.
20825 (process_alt_operands, curr_insn_transform): Use them.
20826 (process_address): Pass the constraint to valid_address_p when
20827 checking address operands.
20828
20829 2014-05-03 Richard Sandiford <rdsandiford@googlemail.com>
20830
20831 * config/mips/mips.c (mips_isa_rev): New variable.
20832 (mips_set_architecture): Set it.
20833 * config/mips/mips.h (TARGET_CPU_CPP_BUILTINS): Set __mips_isa_rev
20834 from mips_isa_rev.
20835 (ISA_HAS_MUL3, ISA_HAS_FP_CONDMOVE, ISA_HAS_8CC, ISA_HAS_FP4)
20836 (ISA_HAS_PAIRED_SINGLE, ISA_HAS_MADD_MSUB, ISA_HAS_FP_RECIP_RSQRT)
20837 (ISA_HAS_CLZ_CLO, ISA_HAS_ROR, ISA_HAS_WSBH, ISA_HAS_PREFETCH)
20838 (ISA_HAS_SEB_SEH, ISA_HAS_EXT_INS, ISA_HAS_MXHC1)
20839 (ISA_HAS_HILO_INTERLOCKS, ISA_HAS_SYNCI, MIN_FPRS_PER_FMT): Reexpress
20840 conditions in terms of mips_isa_rev.
20841 (mips_isa_rev): Declare.
20842
20843 2014-05-03 Oleg Endo <olegendo@gcc.gnu.org>
20844
20845 * config/sh/sh-mem.cc: Use tabs instead of spaces.
20846 (prob_unlikely, prob_likely): Make variables const.
20847
20848 2014-05-03 Denis Chertykov <chertykov@gmail.com>
20849
20850 * config/avr/avr.c (avr_adjust_insn_length): Handle JUMP_TABLE_DATA.
20851
20852 2014-05-03 Oleg Endo <olegendo@gcc.gnu.org>
20853
20854 * config/sh/sh.h (SH_ASM_SPEC): Handle m1, m2*, m3* and m4* cases.
20855
20856 2014-05-03 Oleg Endo <olegendo@gcc.gnu.org>
20857
20858 * config/sh/sh.h (ROUND_ADVANCE): Delete macro.
20859 (ROUND_REG, PASS_IN_REG_P): Move and rename macros to ...
20860 * config/sh/sh.c (sh_round_reg, sh_pass_in_reg_p): ... these new
20861 functions.
20862 (sh_arg_partial_bytes, sh_function_arg, sh_function_arg_advance,
20863 sh_setup_incoming_varargs): Replace usage of PASS_IN_REG_P with
20864 sh_pass_in_reg_p.
20865 Replace usage of ROUND_REG with sh_round_reg.
20866 Use CEIL instead of ROUND_ADVANCE.
20867
20868 2014-05-03 Oleg Endo <olegendo@gcc.gnu.org>
20869
20870 PR target/61026
20871 * config/sh/sh.c: Include stdlib headers before everything else.
20872
20873 2014-05-02 Jakub Jelinek <jakub@redhat.com>
20874
20875 * gimplify.c (gimplify_adjust_omp_clauses_1): Handle
20876 GOVD_FIRSTPRIVATE | GOVD_LASTPRIVATE.
20877 (gimplify_adjust_omp_clauses): Simd region is never
20878 directly nested in combined parallel. Instead, for linear
20879 with copyin/copyout, if in combined for simd loop, make decl
20880 firstprivate/lastprivate on OMP_FOR.
20881 * omp-low.c (expand_omp_for_generic, expand_omp_for_static_nochunk,
20882 expand_omp_for_static_chunk): When setting endvar, also set
20883 fd->loop.v to the same value.
20884
20885 2014-05-02 Richard Sandiford <rsandifo@linux.vnet.ibm.com>
20886
20887 * hwint.h (zext_hwi): Fix signed overflow for prec == 63.
20888
20889 2014-05-02 Alan Lawrence <alan.lawrence@arm.com>
20890
20891 * config/aarch64/aarch64.c (aarch64_expand_vec_perm_1): Tidy bit-flip
20892 expression.
20893
20894 2014-05-02 Marek Polacek <polacek@redhat.com>
20895
20896 * doc/invoke.texi: Describe -fsanitize=float-divide-by-zero.
20897
20898 2014-05-02 Kito Cheng <kito@0xlab.org>
20899
20900 * defaults.h (HONOR_REG_ALLOC_ORDER): Change HONOR_REG_ALLOC_ORDER
20901 to a C expression marco.
20902 * ira-color.c (HONOR_REG_ALLOC_ORDER) : Ditto.
20903 * config/arm/arm.h (HONOR_REG_ALLOC_ORDER): Ditto.
20904 * config/nds32/nds32.h (HONOR_REG_ALLOC_ORDER): Ditto.
20905 * doc/tm.texi (HONOR_REG_ALLOC_ORDER): Update document for
20906 HONOR_REG_ALLOC_ORDER.
20907 * doc/tm.texi.in (HONOR_REG_ALLOC_ORDER): Ditto.
20908
20909 2014-05-01 Jan-Benedict Glaw <jbglaw@lug-owl.de>
20910
20911 * config/arc/arc.c (TARGET_LRA_P): Undef before redefine.
20912
20913 2014-05-01 Jan-Benedict Glaw <jbglaw@lug-owl.de>
20914
20915 * config/arc/arc.c (arc_select_cc_mode): Fix typo.
20916
20917 2014-05-01 Yuri Rumyantsev <ysrumyan@gmail.com>
20918
20919 * tree-if-conv.c (is_cond_scalar_reduction): New function.
20920 (convert_scalar_cond_reduction): Likewise.
20921 (predicate_scalar_phi): Add recognition and transformation
20922 of simple conditioanl reduction to be vectorizable.
20923
20924 2014-05-01 Marek Polacek <polacek@redhat.com>
20925
20926 PR c/43245
20927 * doc/invoke.texi: Document -Wdiscarded-qualifiers.
20928
20929 2014-04-30 Alan Lawrence <alan.lawrence@arm.com>
20930
20931 * config/aarch64/arm_neon.h (vuzp1_f32, vuzp1_p8, vuzp1_p16, vuzp1_s8,
20932 vuzp1_s16, vuzp1_s32, vuzp1_u8, vuzp1_u16, vuzp1_u32, vuzp1q_f32,
20933 vuzp1q_f64, vuzp1q_p8, vuzp1q_p16, vuzp1q_s8, vuzp1q_s16, vuzp1q_s32,
20934 vuzp1q_s64, vuzp1q_u8, vuzp1q_u16, vuzp1q_u32, vuzp1q_u64, vuzp2_f32,
20935 vuzp2_p8, vuzp2_p16, vuzp2_s8, vuzp2_s16, vuzp2_s32, vuzp2_u8,
20936 vuzp2_u16, vuzp2_u32, vuzp2q_f32, vuzp2q_f64, vuzp2q_p8, vuzp2q_p16,
20937 vuzp2q_s8, vuzp2q_s16, vuzp2q_s32, vuzp2q_s64, vuzp2q_u8, vuzp2q_u16,
20938 vuzp2q_u32, vuzp2q_u64): Replace temporary asm with __builtin_shuffle.
20939
20940 2014-04-30 Joern Rennecke <joern.rennecke@embecosm.com>
20941
20942 * config/arc/arc.opt (mlra): Move comment above option name
20943 to avoid mis-parsing as language options.
20944
20945 2014-04-30 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
20946
20947 * config/sol2-10.h (TARGET_LIBC_HAS_FUNCTION): Move ...
20948 * config/sol2.h: ... here.
20949 * config/sol2-10.h: Remove.
20950
20951 * config/sol2-bi.h (WCHAR_TYPE, WCHAR_TYPE_SIZE, WINT_TYPE)
20952 (WINT_TYPE_SIZE, MULTILIB_DEFAULTS, DEF_ARCH32_SPEC)
20953 (DEF_ARCH64_SPEC, ASM_CPU_DEFAULT_SPEC, LINK_ARCH64_SPEC_BASE)
20954 (LINK_ARCH64_SPEC, ARCH_DEFAULT_EMULATION, TARGET_LD_EMULATION)
20955 (LINK_ARCH_SPEC, SUBTARGET_EXTRA_SPECS): Move ...
20956 * config/sol2.h: ... here.
20957 (SECTION_NAME_FORMAT): Don't redefine.
20958 (STARTFILE_ARCH32_SPEC): Rename to ...
20959 (STARTFILE_ARCH_SPEC): ... this.
20960 (ASM_OUTPUT_ALIGNED_COMMON): Move ...
20961 * config/sparc/sol2.h: ... here.
20962 (SECTION_NAME_FORMAT): Don't undef.
20963 * config/i386/sol2.h (ASM_CPU_DEFAULT_SPEC)
20964 (SUBTARGET_EXTRA_SPECS): Remove.
20965 * config/sparc/sol2.h (ASM_CPU_DEFAULT_SPEC): Remove.
20966
20967 * config/i386/sol2-bi.h (TARGET_SUBTARGET_DEFAULT)
20968 (MD_STARTFILE_PREFIX): Remove.
20969 (SUBTARGET_OPTIMIZATION_OPTIONS, ASM_CPU32_DEFAULT_SPEC)
20970 (ASM_CPU64_DEFAULT_SPEC, ASM_CPU_SPEC, ASM_SPEC, DEFAULT_ARCH32_P)
20971 (ARCH64_SUBDIR, ARCH32_EMULATION, ARCH64_EMULATION)
20972 (ASM_COMMENT_START, JUMP_TABLES_IN_TEXT_SECTION)
20973 (ASM_OUTPUT_DWARF_PCREL, ASM_OUTPUT_ALIGNED_COMMON)
20974 (USE_IX86_FRAME_POINTER, USE_X86_64_FRAME_POINTER): Move ...
20975 * config/i386/sol2.h: ... here.
20976 (TARGET_SUBTARGET_DEFAULT, SIZE_TYPE, PTRDIFF_TYPE): Remove.
20977 * config/i386/sol2-bi.h: Remove.
20978 * config/sol2.h (MD_STARTFILE_PREFIX): Remove.
20979 (LINK_ARCH32_SPEC_BASE): Remove /usr/ccs/lib/libp, /usr/ccs/lib.
20980
20981 * config/i386/t-sol2-64: Rename to ...
20982 * config/i386/t-sol2: ... this.
20983 * config/sparc/t-sol2-64: Rename to ...
20984 * config/sparc/t-sol2: ... this.
20985
20986 * config.gcc (*-*-solaris2*): Split sol2_tm_file into
20987 sol2_tm_file_head, sol2_tm_file_tail.
20988 Include ${cpu_type}/sol2.h before sol2.h.
20989 Remove sol2-10.h.
20990 (i[34567]86-*-solaris2* | x86_64-*-solaris2.1[0-9]*): Include
20991 i386/x86-64.h between sol2_tm_file_head and sol2_tm_file_tail.
20992 Remove i386/sol2-bi.h, sol2-bi.h from tm_file.
20993 Reflect i386/t-sol2-64 renaming.
20994 (sparc*-*-solaris2*): Remove sol2-bi.h from tm_file.
20995 Reflect sparc/t-sol2-64 renaming.
20996
20997 2014-04-30 Richard Biener <rguenther@suse.de>
20998
20999 * passes.c (execute_function_todo): Move TODO_verify_stmts
21000 and TODO_verify_ssa under the TODO_verify_il umbrella.
21001 * tree-ssa.h (verify_ssa): Adjust prototype.
21002 * tree-ssa.c (verify_ssa): Add parameter to tell whether
21003 we should verify SSA operands.
21004 * tree-cfg.h (verify_gimple_in_cfg): Adjust prototype.
21005 * tree-cfg.c (verify_gimple_in_cfg): Add parameter to tell
21006 whether we should verify whether not throwing stmts have EH info.
21007 * graphite-scop-detection.c (create_sese_edges): Adjust.
21008 * tree-ssa-loop-manip.c (verify_loop_closed_ssa): Likewise.
21009 * tree-eh.c (lower_try_finally_switch): Do not add the
21010 default case label twice.
21011
21012 2014-04-30 Marek Polacek <polacek@redhat.com>
21013
21014 * gcc.c (sanitize_spec_function): Handle SANITIZE_FLOAT_DIVIDE.
21015 * builtins.def: Initialize builtins even for SANITIZE_FLOAT_DIVIDE.
21016 * flag-types.h (enum sanitize_code): Add SANITIZE_FLOAT_DIVIDE.
21017 * opts.c (common_handle_option): Add -fsanitize=float-divide-by-zero.
21018
21019 2014-04-29 Alan Lawrence <alan.lawrence@arm.com>
21020
21021 * config/aarch64/arm_neon.h (vzip1_f32, vzip1_p8, vzip1_p16, vzip1_s8,
21022 vzip1_s16, vzip1_s32, vzip1_u8, vzip1_u16, vzip1_u32, vzip1q_f32,
21023 vzip1q_f64, vzip1q_p8, vzip1q_p16, vzip1q_s8, vzip1q_s16, vzip1q_s32,
21024 vzip1q_s64, vzip1q_u8, vzip1q_u16, vzip1q_u32, vzip1q_u64, vzip2_f32,
21025 vzip2_p8, vzip2_p16, vzip2_s8, vzip2_s16, vzip2_s32, vzip2_u8,
21026 vzip2_u16, vzip2_u32, vzip2q_f32, vzip2q_f64, vzip2q_p8, vzip2q_p16,
21027 vzip2q_s8, vzip2q_s16, vzip2q_s32, vzip2q_s64, vzip2q_u8, vzip2q_u16,
21028 vzip2q_u32, vzip2q_u64): Replace inline __asm__ with __builtin_shuffle.
21029
21030 2014-04-29 David Malcolm <dmalcolm@redhat.com>
21031
21032 * tree-cfg.c (dump_function_to_file): Dump the return type of
21033 functions, in a line to itself before the function body, mimicking
21034 the layout of a C function.
21035
21036 2014-04-29 Jakub Jelinek <jakub@redhat.com>
21037
21038 PR tree-optimization/60971
21039 * tree-tailcall.c (process_assignment): Reject conversions which
21040 reduce precision.
21041
21042 2014-04-29 James Greenhalgh <james.greenhalgh@arm.com>
21043
21044 * calls.c (initialize_argument_information): Always treat
21045 PUSH_ARGS_REVERSED as 1, simplify code accordingly.
21046 (expand_call): Likewise.
21047 (emit_library_call_calue_1): Likewise.
21048 * expr.c (PUSH_ARGS_REVERSED): Do not define.
21049 (emit_push_insn): Always treat PUSH_ARGS_REVERSED as 1, simplify
21050 code accordingly.
21051
21052 2014-04-29 Nick Clifton <nickc@redhat.com>
21053
21054 * config/msp430/msp430.md (umulsidi): Fix typo.
21055 (mulhisi3): Enable even inside interrupt handlers.
21056 * config/msp430/msp430.c (msp430_print_operand): %O: Allow for the
21057 bigger return address pushed in large mode.
21058
21059 2014-04-29 Nick Clifton <nickc@redhat.com>
21060
21061 * config/arc/arc.c (arc_select_cc_mode): Fix parentheses.
21062 (arc_init_reg_tables): Use a machine_mode enum to iterate over
21063 available modes.
21064 * config/m32r/m32r.c (init_reg_tables): Likewise.
21065 * config/m32c/m32c.c (m32c_illegal_subreg_p): Use a machine_mode
21066 enum to hold the modes.
21067
21068 2014-04-29 Richard Biener <rguenther@suse.de>
21069
21070 * dominance.c (free_dominance_info): Add overload with
21071 function parameter.
21072 (dom_info_state): Likewise.
21073 (dom_info_available_p): Likewise.
21074 * basic-block.h (free_dominance_info, dom_info_state,
21075 dom_info_available_p): Declare overloads.
21076 * passes.c (execute_function_todo): Verify that verifiers
21077 don't change dominator info state. Drop dominator info
21078 for IPA pass invocations.
21079 * cgraph.c (release_function_body): Restore asserts that
21080 dominator information is released.
21081
21082 2014-04-29 Patrick Palka <patrick@parcs.ath.cx>
21083
21084 * doc/invoke.texi: Fix typo.
21085 * tree-vrp.c: Fix typos.
21086 * gimple.c (infer_nonnull_range): Reorder operands of an && condition.
21087
21088 2014-04-29 Zhenqiang Chen <zhenqiang.chen@linaro.org>
21089
21090 * config/aarch64/aarch64.md (mov<mode>cc): New for GPF.
21091
21092 2014-04-28 James Greenhalgh <james.greenhalgh@arm.com>
21093
21094 * config/aarch64/aarch64-builtins.c
21095 (aarch64_types_storestruct_lane_qualifiers): New.
21096 (TYPES_STORESTRUCT_LANE): Likewise.
21097 * config/aarch64/aarch64-simd-builtins.def (st2_lane): New.
21098 (st3_lane): Likewise.
21099 (st4_lane): Likewise.
21100 * config/aarch64/aarch64-simd.md (vec_store_lanesoi_lane<mode>): New.
21101 (vec_store_lanesci_lane<mode>): Likewise.
21102 (vec_store_lanesxi_lane<mode>): Likewise.
21103 (aarch64_st2_lane<VQ:mode>): Likewise.
21104 (aarch64_st3_lane<VQ:mode>): Likewise.
21105 (aarch64_st4_lane<VQ:mode>): Likewise.
21106 * config/aarch64/aarch64.md (unspec): Add UNSPEC_ST{2,3,4}_LANE.
21107 * config/aarch64/arm_neon.h
21108 (__ST2_LANE_FUNC): Rewrite using builtins, update use points to
21109 use new macro arguments.
21110 (__ST3_LANE_FUNC): Likewise.
21111 (__ST4_LANE_FUNC): Likewise.
21112 * config/aarch64/iterators.md (V_TWO_ELEM): New.
21113 (V_THREE_ELEM): Likewise.
21114 (V_FOUR_ELEM): Likewise.
21115
21116 2014-04-28 David Malcolm <dmalcolm@redhat.com>
21117
21118 * doc/gimple.texi: Replace the description of the now-defunct
21119 union gimple_statement_d with a diagram showing the
21120 gimple_statement_base class hierarchy and its relationships to
21121 the GSS_ and GIMPLE_ enums.
21122
21123 2014-04-28 James Greenhalgh <james.greenhalgh@arm.com>
21124
21125 * config/aarch64/aarch64-protos.h (aarch64_modes_tieable_p): New.
21126 * config/aarch64/aarch64.c
21127 (aarch64_cannot_change_mode_class): Weaken conditions.
21128 (aarch64_modes_tieable_p): New.
21129 * config/aarch64/aarch64.h (MODES_TIEABLE_P): Use it.
21130
21131 2014-04-28 Pat Haugen <pthaugen@us.ibm.com>
21132
21133 * config/rs6000/sync.md (AINT mode_iterator): Move definition.
21134 (loadsync_<mode>): Change mode.
21135 (load_quadpti, store_quadpti): New.
21136 (atomic_load<mode>, atomic_store<mode>): Add support for TI mode.
21137 * config/rs6000/rs6000.md (unspec enum): Add UNSPEC_LSQ.
21138
21139 2014-04-28 Martin Jambor <mjambor@suse.cz>
21140
21141 * tree-sra.c (sra_modify_expr): Generate new memory accesses with
21142 same alias type as the original statement.
21143 (subreplacement_assignment_data): New type.
21144 (handle_unscalarized_data_in_subtree): New type of parameter,
21145 generate new memory accesses with same alias type as the original
21146 statement.
21147 (load_assign_lhs_subreplacements): Likewise.
21148 (sra_modify_constructor_assign): Generate new memory accesses with
21149 same alias type as the original statement.
21150
21151 2014-04-28 Richard Biener <rguenther@suse.de>
21152
21153 * tree-pass.h (TODO_verify_il): Define.
21154 (TODO_verify_all): Complete properly.
21155 * passes.c (execute_function_todo): Move existing loop-closed
21156 SSA verification under TODO_verify_il.
21157 (execute_one_pass): Trigger TODO_verify_il at todo-after time.
21158 * graphite-sese-to-poly.c (rewrite_cross_bb_scalar_deps):
21159 Fix tree sharing issue.
21160
21161 2014-04-28 Richard Biener <rguenther@suse.de>
21162
21163 PR middle-end/60092
21164 * builtins.def (DEF_C11_BUILTIN): Add.
21165 (BUILT_IN_ALIGNED_ALLOC): Likewise.
21166 * coretypes.h (enum function_class): Add function_c11_misc.
21167 * tree-ssa-alias.c (ref_maybe_used_by_call_p_1): Handle
21168 BUILT_IN_ALIGNED_ALLOC like BUILT_IN_MALLOC.
21169 (call_may_clobber_ref_p_1): Likewise.
21170 * tree-ssa-dce.c (mark_stmt_if_obviously_necessary): Likewise.
21171 (mark_all_reaching_defs_necessary_1): Likewise.
21172 (propagate_necessity): Likewise.
21173 (eliminate_unnecessary_stmts): Likewise.
21174 * tree-ssa-ccp.c (evaluate_stmt): Handle BUILT_IN_ALIGNED_ALLOC.
21175
21176 2014-04-28 Richard Biener <rguenther@suse.de>
21177
21178 * tree-vrp.c (vrp_var_may_overflow): Remove.
21179 (vrp_visit_phi_node): Rather than bumping to +-INF possibly
21180 with overflow immediately bump to one before that value and
21181 let iteration figure out overflow status.
21182
21183 2014-04-28 Richard Biener <rguenther@suse.de>
21184
21185 * configure.ac: Do valgrind header checks unconditionally.
21186 Add --enable-valgrind-annotations.
21187 * system.h: Guard valgrind header inclusion with
21188 ENABLE_VALGRIND_ANNOTATIONS instead of ENABLE_VALGRIND_CHECKING.
21189 * alloc-pool.c (pool_alloc, pool_free): Use
21190 ENABLE_VALGRIND_ANNOTATIONS instead of ENABLE_VALGRIND_CHECKING
21191 to guard possibly dead code.
21192 * config.in: Regenerated.
21193 * configure: Likewise.
21194
21195 2014-04-28 Jeff Law <law@redhat.com>
21196
21197 PR tree-optimization/60902
21198 * tree-ssa-threadedge.c
21199 (record_temporary_equivalences_from_stmts_at_dest): Only iterate
21200 over real defs when invalidating outputs from statements that do not
21201 produce useful outputs for threading.
21202
21203 2014-04-28 Richard Biener <rguenther@suse.de>
21204
21205 PR tree-optimization/60979
21206 * graphite-scop-detection.c (scopdet_basic_block_info): Reject
21207 SCOPs that end in a block with a successor with abnormal
21208 predecessors.
21209
21210 2014-04-28 Richard Biener <rguenther@suse.de>
21211
21212 * tree-pass.h (execute_pass_list): Adjust prototype.
21213 * passes.c (pass_manager::execute_early_local_passes): Adjust.
21214 (do_per_function): Change callback signature, push all actual
21215 work to the callbals.
21216 (do_per_function_toporder): Likewise.
21217 (execute_function_dump): Adjust.
21218 (execute_function_todo): Likewise.
21219 (clear_last_verified): Likewise.
21220 (verify_curr_properties): Likewise.
21221 (update_properties_after_pass): Likewise.
21222 (execute_pass_list_1): Split out from ...
21223 (execute_pass_list): ... here. Adjust.
21224 (execute_ipa_pass_list): Likewise.
21225 * cgraphunit.c (cgraph_add_new_function): Adjust.
21226 (analyze_function): Likewise.
21227 (expand_function): Likewise.
21228 * cgraph.c (release_function_body): Free dominance info
21229 here instead of asserting it was magically freed elsewhere.
21230
21231 2014-04-28 Eric Botcazou <ebotcazou@adacore.com>
21232
21233 * configure.ac: Tweak GAS check for LEON instructions on SPARC.
21234 * configure: Regenerate.
21235 * config/sparc/sparc.opt (muser-mode): New option.
21236 * config/sparc/sync.md (atomic_compare_and_swap<mode>_1): Do not enable
21237 for LEON3.
21238 (atomic_compare_and_swap_leon3_1): New instruction for LEON3.
21239 * doc/invoke.texi (SPARC options): Document -muser-mode.
21240
21241 2014-04-27 Richard Sandiford <rdsandiford@googlemail.com>
21242
21243 * cselib.c (find_slot_memmode): Delete.
21244 (cselib_hasher): Change compare_type to a struct.
21245 (cselib_hasher::equal): Update accordingly. Don't expect wrapped
21246 constants.
21247 (preserve_constants_and_equivs): Adjust for new compare_type.
21248 (cselib_find_slot): Likewise. Take the mode of the rtx as argument.
21249 (wrap_constant): Delete.
21250 (cselib_lookup_mem, cselib_lookup_1): Update calls to cselib_find_slot.
21251
21252 2014-04-26 Markus Trippelsdorf <markus@trippelsdorf.de>
21253
21254 * doc/install.texi (Building with profile feedback): Remove
21255 outdated sentence.
21256
21257 2014-04-26 Tom de Vries <tom@codesourcery.com>
21258
21259 * config/i386/i386.md (define_expand "ldexpxf3"): Fix out-of-bounds
21260 array accesses.
21261
21262 2014-04-25 Cary Coutant <ccoutant@google.com>
21263
21264 PR debug/60929
21265 * dwarf2out.c (should_move_die_to_comdat): A type definition
21266 can contain a subprogram definition, but don't move it to a
21267 comdat unit.
21268 (clone_as_declaration): Copy DW_AT_abstract_origin attribute.
21269 (generate_skeleton_bottom_up): Remove DW_AT_object_pointer attribute
21270 from original DIE.
21271 (clone_tree_hash): Rename to...
21272 (clone_tree_partial): ...this; change callers. Copy
21273 DW_TAG_subprogram DIEs as declarations.
21274 (copy_decls_walk): Don't copy children of a declaration into a
21275 type unit.
21276
21277 2014-04-25 H.J. Lu <hongjiu.lu@intel.com>
21278
21279 PR target/60969
21280 * config/i386/i386.md (*movsf_internal): Set MODE to SI for
21281 alternative 12.
21282
21283 2014-04-25 Jiong Wang <jiong.wang@arm.com>
21284
21285 * config/arm/predicates.md (call_insn_operand): Add long_call check.
21286 * config/arm/arm.md (sibcall, sibcall_value): Force the address to
21287 reg for long_call.
21288 * config/arm/arm.c (arm_function_ok_for_sibcall): Remove long_call
21289 restriction.
21290
21291 2014-04-25 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
21292
21293 * config/arm/arm.c (arm_cortex_a8_tune): Initialise T16-related fields.
21294
21295 2014-04-25 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
21296
21297 PR tree-optimization/60930
21298 * gimple-ssa-strength-reduction.c (create_mul_imm_cand): Reject
21299 creating a multiply candidate by folding two constant
21300 multiplicands when the result overflows.
21301
21302 2014-04-25 Jakub Jelinek <jakub@redhat.com>
21303
21304 PR tree-optimization/60960
21305 * tree-vect-generic.c (expand_vector_operation): Only call
21306 expand_vector_divmod if type's mode satisfies VECTOR_MODE_P.
21307
21308 2014-04-25 Tom de Vries <tom@codesourcery.com>
21309
21310 * expr.c (clobber_reg_mode): New function.
21311 * expr.h (clobber_reg): New function.
21312
21313 2014-04-25 Tom de Vries <tom@codesourcery.com>
21314
21315 * rtlanal.c (find_all_hard_reg_sets): Note INSN_CALL_FUNCTION_USAGE
21316 clobbers.
21317
21318 2014-04-25 Radovan Obradovic <robradovic@mips.com>
21319 Tom de Vries <tom@codesourcery.com>
21320
21321 * rtlanal.c (find_all_hard_reg_sets): Add bool implicit parameter and
21322 handle.
21323 * rtl.h (find_all_hard_reg_sets): Add bool parameter.
21324 * haifa-sched.c (recompute_todo_spec, check_clobbered_conditions): Add
21325 new argument to find_all_hard_reg_sets call.
21326
21327 2014-04-25 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
21328
21329 * config/arm/aarch-common.c (aarch_rev16_shright_mask_imm_p):
21330 Use HOST_WIDE_INT_C for mask literal.
21331 (aarch_rev16_shleft_mask_imm_p): Likewise.
21332
21333 2014-04-25 Eric Botcazou <ebotcazou@adacore.com>
21334
21335 PR target/60941
21336 * config/sparc/sparc.md (ashlsi3_extend): Delete.
21337
21338 2014-04-25 Marc Glisse <marc.glisse@inria.fr>
21339
21340 PR preprocessor/56540
21341 * config/i386/i386-c.c (ix86_target_macros): Define
21342 __SIZEOF_FLOAT80__ and __SIZEOF_FLOAT128__.
21343
21344 2014-04-25 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
21345
21346 * configure.ac (tga_func): Remove.
21347 (LIB_TLS_SPEC): Remove.
21348 * configure: Regenerate.
21349 * config.in: Regenerate.
21350 * config/sol2.h (LIB_SPEC): Don't use LIB_TLS_SPEC.
21351
21352 2014-04-25 Richard Biener <rguenther@suse.de>
21353
21354 PR ipa/60912
21355 * tree-ssa-structalias.c (ipa_pta_execute): Compute direct
21356 call stmt use/clobber sets during stmt walk instead of
21357 walking the possibly incomplete set of caller edges.
21358
21359 2014-04-25 Richard Biener <rguenther@suse.de>
21360
21361 PR ipa/60911
21362 * passes.c (apply_ipa_transforms): Inline into only caller ...
21363 (execute_one_pass): ... here. Properly bring in function
21364 bodies for nodes we want to apply IPA transforms to.
21365
21366 2014-04-24 Cong Hou <congh@google.com>
21367
21368 PR tree-optimization/60896
21369 * tree-vect-patterns.c (vect_recog_dot_prod_pattern): Pick up
21370 all statements in PATTERN_DEF_SEQ in recognized widen-mult pattern.
21371 (vect_mark_pattern_stmts): Set the def type of all statements in
21372 PATTERN_DEF_SEQ as vect_internal_def.
21373
21374 2014-04-24 Michael Meissner <meissner@linux.vnet.ibm.com>
21375
21376 * doc/extend.texi (PowerPC Built-in Functions): Document new
21377 powerpc extended divide, bcd, pack/unpack 128-bit, builtin functions.
21378 (PowerPC AltiVec/VSX Built-in Functions): Likewise.
21379
21380 * config/rs6000/predicates.md (const_0_to_3_operand): New
21381 predicate to match 0..3 integer constants.
21382
21383 * config/rs6000/rs6000-builtin.def (BU_DFP_MISC_1): Add new macros
21384 to support adding miscellaneous builtin functions.
21385 (BU_DFP_MISC_2): Likewise.
21386 (BU_P7_MISC_1): Likewise.
21387 (BU_P7_MISC_2): Likewise.
21388 (BU_P8V_MISC_3): Likewise.
21389 (BU_MISC_1): Likewise.
21390 (BU_MISC_2): Likewise.
21391 (DIVWE): Add extended divide builtin functions.
21392 (DIVWEO): Likewise.
21393 (DIVWEU): Likewise.
21394 (DIVWEUO): Likewise.
21395 (DIVDE): Likewise.
21396 (DIVDEO): Likewise.
21397 (DIVDEU): Likewise.
21398 (DIVDEUO): Likewise.
21399 (DXEX): Add decimal floating-point builtin functions.
21400 (DXEXQ): Likewise.
21401 (DDEDPD): Likewise.
21402 (DDEDPDQ): Likewise.
21403 (DENBCD): Likewise.
21404 (DENBCDQ): Likewise.
21405 (DIEX): Likewise.
21406 (DIEXQ): Likewise.
21407 (DSCLI): Likewise.
21408 (DSCLIQ): Likewise.
21409 (DSCRI): Likewise.
21410 (DSCRIQ): Likewise.
21411 (CDTBCD): Add new BCD builtin functions.
21412 (CBCDTD): Likewise.
21413 (ADDG6S): Likewise.
21414 (BCDADD): Likewise.
21415 (BCDADD_LT): Likewise.
21416 (BCDADD_EQ): Likewise.
21417 (BCDADD_GT): Likewise.
21418 (BCDADD_OV): Likewise.
21419 (BCDSUB): Likewise.
21420 (BCDSUB_LT): Likewise.
21421 (BCDSUB_EQ): Likewise.
21422 (BCDSUB_GT): Likewise.
21423 (BCDSUB_OV): Likewise.
21424 (PACK_TD): Add new pack/unpack 128-bit type builtin functions.
21425 (UNPACK_TD): Likewise.
21426 (PACK_TF): Likewise.
21427 (UNPACK_TF): Likewise.
21428 (UNPACK_TF_0): Likewise.
21429 (UNPACK_TF_1): Likewise.
21430 (PACK_V1TI): Likewise.
21431 (UNPACK_V1TI): Likewise.
21432
21433 * config/rs6000/rs6000.c (rs6000_builtin_mask_calculate): Add
21434 support for decimal floating point builtin functions.
21435 (rs6000_expand_ternop_builtin): Add checks for the new builtin
21436 functions that take constant arguments.
21437 (rs6000_invalid_builtin): Add decimal floating point builtin support.
21438 (rs6000_init_builtins): Setup long double, _Decimal64, and
21439 _Decimal128 types for new builtin functions.
21440 (builtin_function_type): Set the unsigned flags appropriately for
21441 the new builtin functions.
21442 (rs6000_opt_masks): Add support for decimal floating point builtin
21443 functions.
21444
21445 * config/rs6000/rs6000.h (RS6000_BTM_DFP): Add support for decimal
21446 floating point builtin functions.
21447 (RS6000_BTM_COMMON): Likewise.
21448 (RS6000_BTI_long_double): Likewise.
21449 (RS6000_BTI_dfloat64): Likewise.
21450 (RS6000_BTI_dfloat128): Likewise.
21451 (long_double_type_internal_node): Likewise.
21452 (dfloat64_type_internal_node): Likewise.
21453 (dfloat128_type_internal_node): Likewise.
21454
21455 * config/rs6000/altivec.h (UNSPEC_BCDADD): Add support for ISA
21456 2.07 bcd arithmetic instructions.
21457 (UNSPEC_BCDSUB): Likewise.
21458 (UNSPEC_BCD_OVERFLOW): Likewise.
21459 (UNSPEC_BCD_ADD_SUB): Likewise.
21460 (bcd_add_sub): Likewise.
21461 (BCD_TEST): Likewise.
21462 (bcd<bcd_add_sub>): Likewise.
21463 (bcd<bcd_add_sub>_test): Likewise.
21464 (bcd<bcd_add_sub>_test2): Likewise.
21465 (bcd<bcd_add_sub>_<code>): Likewise.
21466 (peephole2 for combined bcd ops): Likewise.
21467
21468 * config/rs6000/dfp.md (UNSPEC_DDEDPD): Add support for new
21469 decimal floating point builtin functions.
21470 (UNSPEC_DENBCD): Likewise.
21471 (UNSPEC_DXEX): Likewise.
21472 (UNSPEC_DIEX): Likewise.
21473 (UNSPEC_DSCLI): Likewise.
21474 (UNSPEC_DSCRI): Likewise.
21475 (D64_D128): Likewise.
21476 (dfp_suffix): Likewise.
21477 (dfp_ddedpd_<mode>): Likewise.
21478 (dfp_denbcd_<mode>): Likewise.
21479 (dfp_dxex_<mode>): Likewise.
21480 (dfp_diex_<mode>): Likewise.
21481 (dfp_dscli_<mode>): Likewise.
21482 (dfp_dscri_<mode>): Likewise.
21483
21484 * config/rs6000/rs6000.md (UNSPEC_ADDG6S): Add support for new BCD
21485 builtin functions.
21486 (UNSPEC_CDTBCD): Likewise.
21487 (UNSPEC_CBCDTD): Likewise.
21488 (UNSPEC_DIVE): Add support for new extended divide builtin functions.
21489 (UNSPEC_DIVEO): Likewise.
21490 (UNSPEC_DIVEU): Likewise.
21491 (UNSPEC_DIVEUO): Likewise.
21492 (UNSPEC_UNPACK_128BIT): Add support for new builtin functions to
21493 pack/unpack 128-bit types.
21494 (UNSPEC_PACK_128BIT): Likewise.
21495 (idiv_ldiv): New mode attribute to set the 32/64-bit divide type.
21496 (udiv<mode>3): Use idiv_ldiv mode attribute.
21497 (div<mode>3): Likewise.
21498 (addg6s): Add new BCD builtin functions.
21499 (cdtbcd): Likewise.
21500 (cbcdtd): Likewise.
21501 (UNSPEC_DIV_EXTEND): Add support for new extended divide instructions.
21502 (div_extend): Likewise.
21503 (div<div_extend>_<mode>"): Likewise.
21504 (FP128_64): Add support for new builtin functions to pack/unpack
21505 128-bit types.
21506 (unpack<mode>): Likewise.
21507 (unpacktf_0): Likewise.
21508 (unpacktf_1): Likewise.
21509 (unpack<mode>_dm): Likewise.
21510 (unpack<mode>_nodm): Likewise.
21511 (pack<mode>): Likewise.
21512 (unpackv1ti): Likewise.
21513 (packv1ti): Likewise.
21514
21515 2014-04-24 Vishnu K S <Vishnu.k_s@atmel.com>
21516
21517 * gcc/config/avr/avr.c: Add comment on why -fdelete-null-pointer-checks
21518 is disabled.
21519
21520 2014-04-24 Jakub Jelinek <jakub@redhat.com>
21521
21522 * tree.h (OMP_CLAUSE_LINEAR_GIMPLE_SEQ): Define.
21523 * gimplify.c (omp_is_private): Change last argument's type to int.
21524 Only diagnose lastprivate if the simd argument is 1, only diagnose
21525 linear if the simd argument is 2.
21526 (gimplify_omp_for): Adjust omp_is_private callers. When adding
21527 lastprivate or private, add the clause to OMP_FOR_CLAUSES. Pass
21528 GOVD_EXPLICIT to omp_add_variable. For simd with collapse == 1
21529 create OMP_CLAUSE_LINEAR rather than OMP_CLAUSE_PRIVATE for var.
21530 If var != decl and decl is in OMP_CLAUSE_LINEAR, gimplify decl
21531 increment to OMP_CLAUSE_LINEAR_GIMPLE_SEQ.
21532 * omp-low.c (scan_sharing_clauses, lower_lastprivate_clauses): Handle
21533 OMP_CLAUSE_LINEAR_GIMPLE_SEQ.
21534 * tree-nested.c (convert_nonlocal_omp_clauses,
21535 convert_local_omp_clauses): Handle OMP_CLAUSE_LINEAR.
21536
21537 2014-04-24 Segher Boessenkool <segher@kernel.crashing.org>
21538
21539 PR target/60822
21540 * config/m68k/m68k.md (extendplussidi): Don't allow memory for
21541 operand 1.
21542
21543 2014-04-24 Dimitris Papavasiliou <dpapavas@gmail.com>
21544
21545 * flag-types.h (enum ivar_visibility): Add.
21546
21547 2014-04-24 Trevor Saunders <tsaunders@mozilla.com>
21548
21549 * config/sh/sh_treg_combine.c (sh_treg_combine::execute): Take
21550 function * argument.
21551
21552 2014-04-24 Alan Lawrence <alan.lawrence@arm.com>
21553
21554 * config/aarch64/aarch64.c (aarch64_evpc_tbl): Enable for bigendian.
21555
21556 2014-04-24 Radovan Obradovic <robradovic@mips.com>
21557 Tom de Vries <tom@codesourcery.com>
21558
21559 * reg-notes.def (REG_NOTE (CALL_DECL)): New reg-note REG_CALL_DECL.
21560 * calls.c (expand_call, emit_library_call_value_1): Add REG_CALL_DECL
21561 reg-note.
21562 * combine.c (distribute_notes): Handle REG_CALL_DECL reg-note.
21563 * emit-rtl.c (try_split): Same.
21564
21565 2014-04-24 Radovan Obradovic <robradovic@mips.com>
21566 Tom de Vries <tom@codesourcery.com>
21567
21568 * common.opt (fuse-caller-save): New option.
21569
21570 2014-04-24 Tejas Belagod <tejas.belagod@arm.com>
21571
21572 * config/aarch64/aarch64.c (aarch64_evpc_tbl): Reverse order of
21573 elements for big-endian.
21574
21575 2014-04-24 Richard Biener <rguenther@suse.de>
21576
21577 * expr.c (expand_expr_real_1): Avoid gimple_assign_rhs_to_tree
21578 during TER and instead use the sepops interface for expanding
21579 non-GIMPLE_SINGLE_RHS.
21580
21581 2014-04-24 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
21582
21583 * config/i386/sol2.h (ASM_PREFERRED_EH_DATA_FORMAT): Only redefine
21584 if not HAVE_AS_IX86_DIFF_SECT_DELTA.
21585
21586 2014-04-24 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
21587
21588 * configure.ac (gcc_cv_as_cfi_directive): Support Solaris/x86
21589 assembler 64-bit option.
21590 * configure: Regenerate.
21591
21592 2014-04-24 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
21593
21594 * config/aarch64/aarch64.h (TARGET_CPU_CPP_BUILTINS): Check
21595 TARGET_SIMD rather than TARGET_GENERAL_REGS_ONLY.
21596 (TARGET_SIMD): Take AARCH64_ISA_SIMD into account.
21597 (TARGET_FLOAT): Take AARCH64_ISA_FP into account.
21598 (TARGET_CRYPTO): Take TARGET_SIMD into account.
21599
21600 2014-04-24 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
21601
21602 * config/aarch64/aarch64-builtins.c
21603 (aarch64_builtin_vectorized_function): Handle BUILT_IN_BSWAP16,
21604 BUILT_IN_BSWAP32, BUILT_IN_BSWAP64.
21605 * config/aarch64/aarch64-simd.md (bswap<mode>): New pattern.
21606 * config/aarch64/aarch64-simd-builtins.def: Define vector bswap
21607 builtins.
21608 * config/aarch64/iterator.md (VDQHSD): New mode iterator.
21609 (Vrevsuff): New mode attribute.
21610
21611 2014-04-24 Terry Guo <terry.guo@arm.com>
21612
21613 * config/arm/arm.h (machine_function): Define variable
21614 after_arm_reorg here.
21615 * config/arm/arm.c (after_arm_reorg): Remove the definition.
21616 (arm_split_constant): Update the way to access variable
21617 after_arm_reorg.
21618 (arm_reorg): Ditto.
21619 (arm_output_function_epilogue): Remove the reset of after_arm_reorg.
21620
21621 2014-04-23 Tom de Vries <tom@codesourcery.com>
21622
21623 * target-hooks-macros.h: Fix DEFHOOKPOD argument order in comment.
21624
21625 2014-04-23 David Malcolm <dmalcolm@redhat.com>
21626
21627 * is-a.h: Update comments to reflect the following changes to the
21628 "pointerness" of the API, making the template parameter match the
21629 return type, allowing use of is-a.h with typedefs of pointers.
21630 (is_a_helper::cast): Return a T rather then a pointer to a T, so
21631 that the return type matches the parameter to the is_a_helper.
21632 (as_a): Likewise.
21633 (dyn_cast): Likewise.
21634
21635 * cgraph.c (cgraph_node_for_asm): Update for removal of implicit
21636 pointer from the is-a.h API.
21637
21638 * cgraph.h (is_a_helper <cgraph_node>::test): Convert to...
21639 (is_a_helper <cgraph_node *>::test): ...this, matching change to
21640 is-a.h API.
21641 (is_a_helper <varpool_node>::test): Likewise, convert to...
21642 (is_a_helper <varpool_node *>::test): ...this.
21643
21644 (varpool_first_variable): Update for removal of implicit pointer
21645 from the is-a.h API.
21646 (varpool_next_variable): Likewise.
21647 (varpool_first_static_initializer): Likewise.
21648 (varpool_next_static_initializer): Likewise.
21649 (varpool_first_defined_variable): Likewise.
21650 (varpool_next_defined_variable): Likewise.
21651 (cgraph_first_defined_function): Likewise.
21652 (cgraph_next_defined_function): Likewise.
21653 (cgraph_first_function): Likewise.
21654 (cgraph_next_function): Likewise.
21655 (cgraph_first_function_with_gimple_body): Likewise.
21656 (cgraph_next_function_with_gimple_body): Likewise.
21657 (cgraph_alias_target): Likewise.
21658 (varpool_alias_target): Likewise.
21659 (cgraph_function_or_thunk_node): Likewise.
21660 (varpool_variable_node): Likewise.
21661 (symtab_real_symbol_p): Likewise.
21662 * cgraphunit.c (referred_to_p): Likewise.
21663 (analyze_functions): Likewise.
21664 (handle_alias_pairs): Likewise.
21665 * gimple-fold.c (can_refer_decl_in_current_unit_p): Likewise.
21666 * gimple-ssa.h (gimple_vuse_op): Likewise.
21667 (gimple_vdef_op): Likewise.
21668 * gimple-streamer-in.c (input_gimple_stmt): Likewise.
21669 * gimple.c (gimple_build_asm_1): Likewise.
21670 (gimple_build_try): Likewise.
21671 (gimple_build_resx): Likewise.
21672 (gimple_build_eh_dispatch): Likewise.
21673 (gimple_build_omp_for): Likewise.
21674 (gimple_omp_for_set_clauses): Likewise.
21675
21676 * gimple.h (is_a_helper <gimple_statement_asm>::test): Convert to...
21677 (is_a_helper <gimple_statement_asm *>::test): ...this.
21678 (is_a_helper <gimple_statement_bind>::test): Convert to...
21679 (is_a_helper <gimple_statement_bind *>::test): ...this.
21680 (is_a_helper <gimple_statement_call>::test): Convert to...
21681 (is_a_helper <gimple_statement_call *>::test): ...this.
21682 (is_a_helper <gimple_statement_catch>::test): Convert to...
21683 (is_a_helper <gimple_statement_catch *>::test): ...this.
21684 (is_a_helper <gimple_statement_resx>::test): Convert to...
21685 (is_a_helper <gimple_statement_resx *>::test): ...this.
21686 (is_a_helper <gimple_statement_eh_dispatch>::test): Convert to...
21687 (is_a_helper <gimple_statement_eh_dispatch *>::test): ...this.
21688 (is_a_helper <gimple_statement_eh_else>::test): Convert to...
21689 (is_a_helper <gimple_statement_eh_else *>::test): ...this.
21690 (is_a_helper <gimple_statement_eh_filter>::test): Convert to...
21691 (is_a_helper <gimple_statement_eh_filter *>::test): ...this.
21692 (is_a_helper <gimple_statement_eh_mnt>::test): Convert to...
21693 (is_a_helper <gimple_statement_eh_mnt *>::test): ...this.
21694 (is_a_helper <gimple_statement_omp_atomic_load>::test): Convert to...
21695 (is_a_helper <gimple_statement_omp_atomic_load *>::test): ...this.
21696 (is_a_helper <gimple_statement_omp_atomic_store>::test): Convert to...
21697 (is_a_helper <gimple_statement_omp_atomic_store *>::test): ...this.
21698 (is_a_helper <gimple_statement_omp_return>::test): Convert to...
21699 (is_a_helper <gimple_statement_omp_return *>::test): ...this.
21700 (is_a_helper <gimple_statement_omp_continue>::test): Convert to...
21701 (is_a_helper <gimple_statement_omp_continue *>::test): ...this.
21702 (is_a_helper <gimple_statement_omp_critical>::test): Convert to...
21703 (is_a_helper <gimple_statement_omp_critical *>::test): ...this.
21704 (is_a_helper <gimple_statement_omp_for>::test): Convert to...
21705 (is_a_helper <gimple_statement_omp_for *>::test): ...this.
21706 (is_a_helper <gimple_statement_omp_taskreg>::test): Convert to...
21707 (is_a_helper <gimple_statement_omp_taskreg *>::test): ...this.
21708 (is_a_helper <gimple_statement_omp_parallel>::test): Convert to...
21709 (is_a_helper <gimple_statement_omp_parallel *>::test): ...this.
21710 (is_a_helper <gimple_statement_omp_target>::test): Convert to...
21711 (is_a_helper <gimple_statement_omp_target *>::test): ...this.
21712 (is_a_helper <gimple_statement_omp_sections>::test): Convert to...
21713 (is_a_helper <gimple_statement_omp_sections *>::test): ...this.
21714 (is_a_helper <gimple_statement_omp_single>::test): Convert to...
21715 (is_a_helper <gimple_statement_omp_single *>::test): ...this.
21716 (is_a_helper <gimple_statement_omp_teams>::test): Convert to...
21717 (is_a_helper <gimple_statement_omp_teams *>::test): ...this.
21718 (is_a_helper <gimple_statement_omp_task>::test): Convert to...
21719 (is_a_helper <gimple_statement_omp_task *>::test): ...this.
21720 (is_a_helper <gimple_statement_phi>::test): Convert to...
21721 (is_a_helper <gimple_statement_phi *>::test): ...this.
21722 (is_a_helper <gimple_statement_transaction>::test): Convert to...
21723 (is_a_helper <gimple_statement_transaction *>::test): ...this.
21724 (is_a_helper <gimple_statement_try>::test): Convert to...
21725 (is_a_helper <gimple_statement_try *>::test): ...this.
21726 (is_a_helper <gimple_statement_wce>::test): Convert to...
21727 (is_a_helper <gimple_statement_wce *>::test): ...this.
21728 (is_a_helper <const gimple_statement_asm>::test): Convert to...
21729 (is_a_helper <const gimple_statement_asm *>::test): ...this.
21730 (is_a_helper <const gimple_statement_bind>::test): Convert to...
21731 (is_a_helper <const gimple_statement_bind *>::test): ...this.
21732 (is_a_helper <const gimple_statement_call>::test): Convert to...
21733 (is_a_helper <const gimple_statement_call *>::test): ...this.
21734 (is_a_helper <const gimple_statement_catch>::test): Convert to...
21735 (is_a_helper <const gimple_statement_catch *>::test): ...this.
21736 (is_a_helper <const gimple_statement_resx>::test): Convert to...
21737 (is_a_helper <const gimple_statement_resx *>::test): ...this.
21738 (is_a_helper <const gimple_statement_eh_dispatch>::test): Convert to...
21739 (is_a_helper <const gimple_statement_eh_dispatch *>::test): ...this.
21740 (is_a_helper <const gimple_statement_eh_filter>::test): Convert to...
21741 (is_a_helper <const gimple_statement_eh_filter *>::test): ...this.
21742 (is_a_helper <const gimple_statement_omp_atomic_load>::test):
21743 Convert to...
21744 (is_a_helper <const gimple_statement_omp_atomic_load *>::test):
21745 ...this.
21746 (is_a_helper <const gimple_statement_omp_atomic_store>::test):
21747 Convert to...
21748 (is_a_helper <const gimple_statement_omp_atomic_store *>::test):
21749 ...this.
21750 (is_a_helper <const gimple_statement_omp_return>::test): Convert to...
21751 (is_a_helper <const gimple_statement_omp_return *>::test): ...this.
21752 (is_a_helper <const gimple_statement_omp_continue>::test): Convert
21753 to...
21754 (is_a_helper <const gimple_statement_omp_continue *>::test): ...this.
21755 (is_a_helper <const gimple_statement_omp_critical>::test): Convert
21756 to...
21757 (is_a_helper <const gimple_statement_omp_critical *>::test): ...this.
21758 (is_a_helper <const gimple_statement_omp_for>::test): Convert to...
21759 (is_a_helper <const gimple_statement_omp_for *>::test): ...this.
21760 (is_a_helper <const gimple_statement_omp_taskreg>::test): Convert to...
21761 (is_a_helper <const gimple_statement_omp_taskreg *>::test): ...this.
21762 (is_a_helper <const gimple_statement_omp_parallel>::test): Convert
21763 to...
21764 (is_a_helper <const gimple_statement_omp_parallel *>::test): ...this.
21765 (is_a_helper <const gimple_statement_omp_target>::test): Convert to...
21766 (is_a_helper <const gimple_statement_omp_target *>::test): ...this.
21767 (is_a_helper <const gimple_statement_omp_sections>::test): Convert
21768 to...
21769 (is_a_helper <const gimple_statement_omp_sections *>::test): ...this.
21770 (is_a_helper <const gimple_statement_omp_single>::test): Convert to...
21771 (is_a_helper <const gimple_statement_omp_single *>::test): ...this.
21772 (is_a_helper <const gimple_statement_omp_teams>::test): Convert to...
21773 (is_a_helper <const gimple_statement_omp_teams *>::test): ...this.
21774 (is_a_helper <const gimple_statement_omp_task>::test): Convert to...
21775 (is_a_helper <const gimple_statement_omp_task *>::test): ...this.
21776 (is_a_helper <const gimple_statement_phi>::test): Convert to...
21777 (is_a_helper <const gimple_statement_phi *>::test): ...this.
21778 (is_a_helper <const gimple_statement_transaction>::test): Convert to...
21779 (is_a_helper <const gimple_statement_transaction *>::test): ...this.
21780 (is_a_helper <const gimple_statement_with_ops>::test): Convert to...
21781 (is_a_helper <const gimple_statement_with_ops *>::test): ...this.
21782 (is_a_helper <gimple_statement_with_ops>::test): Convert to...
21783 (is_a_helper <gimple_statement_with_ops *>::test): ...this.
21784 (is_a_helper <const gimple_statement_with_memory_ops>::test): Convert
21785 to...
21786 (is_a_helper <const gimple_statement_with_memory_ops *>::test):
21787 ...this.
21788 (is_a_helper <gimple_statement_with_memory_ops>::test): Convert to...
21789 (is_a_helper <gimple_statement_with_memory_ops *>::test): ...this.
21790
21791 (gimple_use_ops): Update for removal of implicit pointer from the
21792 is-a.h API.
21793 (gimple_set_use_ops): Likewise.
21794 (gimple_vuse): Likewise.
21795 (gimple_vdef): Likewise.
21796 (gimple_vuse_ptr): Likewise.
21797 (gimple_vdef_ptr): Likewise.
21798 (gimple_set_vuse): Likewise.
21799 (gimple_set_vdef): Likewise.
21800 (gimple_omp_return_set_lhs): Likewise.
21801 (gimple_omp_return_lhs): Likewise.
21802 (gimple_omp_return_lhs_ptr): Likewise.
21803 (gimple_call_fntype): Likewise.
21804 (gimple_call_set_fntype): Likewise.
21805 (gimple_call_set_internal_fn): Likewise.
21806 (gimple_call_use_set): Likewise.
21807 (gimple_call_clobber_set): Likewise.
21808 (gimple_bind_vars): Likewise.
21809 (gimple_bind_set_vars): Likewise.
21810 (gimple_bind_body_ptr): Likewise.
21811 (gimple_bind_set_body): Likewise.
21812 (gimple_bind_add_stmt): Likewise.
21813 (gimple_bind_block): Likewise.
21814 (gimple_bind_set_block): Likewise.
21815 (gimple_asm_ninputs): Likewise.
21816 (gimple_asm_noutputs): Likewise.
21817 (gimple_asm_nclobbers): Likewise.
21818 (gimple_asm_nlabels): Likewise.
21819 (gimple_asm_input_op): Likewise.
21820 (gimple_asm_input_op_ptr): Likewise.
21821 (gimple_asm_output_op): Likewise.
21822 (gimple_asm_output_op_ptr): Likewise.
21823 (gimple_asm_set_output_op): Likewise.
21824 (gimple_asm_clobber_op): Likewise.
21825 (gimple_asm_set_clobber_op): Likewise.
21826 (gimple_asm_label_op): Likewise.
21827 (gimple_asm_set_label_op): Likewise.
21828 (gimple_asm_string): Likewise.
21829 (gimple_catch_types): Likewise.
21830 (gimple_catch_types_ptr): Likewise.
21831 (gimple_catch_handler_ptr): Likewise.
21832 (gimple_catch_set_types): Likewise.
21833 (gimple_catch_set_handler): Likewise.
21834 (gimple_eh_filter_types): Likewise.
21835 (gimple_eh_filter_types_ptr): Likewise.
21836 (gimple_eh_filter_failure_ptr): Likewise.
21837 (gimple_eh_filter_set_types): Likewise.
21838 (gimple_eh_filter_set_failure): Likewise.
21839 (gimple_eh_must_not_throw_fndecl): Likewise.
21840 (gimple_eh_must_not_throw_set_fndecl): Likewise.
21841 (gimple_eh_else_n_body_ptr): Likewise.
21842 (gimple_eh_else_e_body_ptr): Likewise.
21843 (gimple_eh_else_set_n_body): Likewise.
21844 (gimple_eh_else_set_e_body): Likewise.
21845 (gimple_try_eval_ptr): Likewise.
21846 (gimple_try_cleanup_ptr): Likewise.
21847 (gimple_try_set_eval): Likewise.
21848 (gimple_try_set_cleanup): Likewise.
21849 (gimple_wce_cleanup_ptr): Likewise.
21850 (gimple_wce_set_cleanup): Likewise.
21851 (gimple_phi_capacity): Likewise.
21852 (gimple_phi_num_args): Likewise.
21853 (gimple_phi_result): Likewise.
21854 (gimple_phi_result_ptr): Likewise.
21855 (gimple_phi_set_result): Likewise.
21856 (gimple_phi_arg): Likewise.
21857 (gimple_phi_set_arg): Likewise.
21858 (gimple_resx_region): Likewise.
21859 (gimple_resx_set_region): Likewise.
21860 (gimple_eh_dispatch_region): Likewise.
21861 (gimple_eh_dispatch_set_region): Likewise.
21862 (gimple_omp_critical_name): Likewise.
21863 (gimple_omp_critical_name_ptr): Likewise.
21864 (gimple_omp_critical_set_name): Likewise.
21865 (gimple_omp_for_clauses): Likewise.
21866 (gimple_omp_for_clauses_ptr): Likewise.
21867 (gimple_omp_for_set_clauses): Likewise.
21868 (gimple_omp_for_collapse): Likewise.
21869 (gimple_omp_for_index): Likewise.
21870 (gimple_omp_for_index_ptr): Likewise.
21871 (gimple_omp_for_set_index): Likewise.
21872 (gimple_omp_for_initial): Likewise.
21873 (gimple_omp_for_initial_ptr): Likewise.
21874 (gimple_omp_for_set_initial): Likewise.
21875 (gimple_omp_for_final): Likewise.
21876 (gimple_omp_for_final_ptr): Likewise.
21877 (gimple_omp_for_set_final): Likewise.
21878 (gimple_omp_for_incr): Likewise.
21879 (gimple_omp_for_incr_ptr): Likewise.
21880 (gimple_omp_for_set_incr): Likewise.
21881 (gimple_omp_for_pre_body_ptr): Likewise.
21882 (gimple_omp_for_set_pre_body): Likewise.
21883 (gimple_omp_parallel_clauses): Likewise.
21884 (gimple_omp_parallel_clauses_ptr): Likewise.
21885 (gimple_omp_parallel_set_clauses): Likewise.
21886 (gimple_omp_parallel_child_fn): Likewise.
21887 (gimple_omp_parallel_child_fn_ptr): Likewise.
21888 (gimple_omp_parallel_set_child_fn): Likewise.
21889 (gimple_omp_parallel_data_arg): Likewise.
21890 (gimple_omp_parallel_data_arg_ptr): Likewise.
21891 (gimple_omp_parallel_set_data_arg): Likewise.
21892 (gimple_omp_task_clauses): Likewise.
21893 (gimple_omp_task_clauses_ptr): Likewise.
21894 (gimple_omp_task_set_clauses): Likewise.
21895 (gimple_omp_task_child_fn): Likewise.
21896 (gimple_omp_task_child_fn_ptr): Likewise.
21897 (gimple_omp_task_set_child_fn): Likewise.
21898 (gimple_omp_task_data_arg): Likewise.
21899 (gimple_omp_task_data_arg_ptr): Likewise.
21900 (gimple_omp_task_set_data_arg): Likewise.
21901 (gimple_omp_taskreg_clauses): Likewise.
21902 (gimple_omp_taskreg_clauses_ptr): Likewise.
21903 (gimple_omp_taskreg_set_clauses): Likewise.
21904 (gimple_omp_taskreg_child_fn): Likewise.
21905 (gimple_omp_taskreg_child_fn_ptr): Likewise.
21906 (gimple_omp_taskreg_set_child_fn): Likewise.
21907 (gimple_omp_taskreg_data_arg): Likewise.
21908 (gimple_omp_taskreg_data_arg_ptr): Likewise.
21909 (gimple_omp_taskreg_set_data_arg): Likewise.
21910 (gimple_omp_task_copy_fn): Likewise.
21911 (gimple_omp_task_copy_fn_ptr): Likewise.
21912 (gimple_omp_task_set_copy_fn): Likewise.
21913 (gimple_omp_task_arg_size): Likewise.
21914 (gimple_omp_task_arg_size_ptr): Likewise.
21915 (gimple_omp_task_set_arg_size): Likewise.
21916 (gimple_omp_task_arg_align): Likewise.
21917 (gimple_omp_task_arg_align_ptr): Likewise.
21918 (gimple_omp_task_set_arg_align): Likewise.
21919 (gimple_omp_single_clauses): Likewise.
21920 (gimple_omp_single_clauses_ptr): Likewise.
21921 (gimple_omp_single_set_clauses): Likewise.
21922 (gimple_omp_target_clauses): Likewise.
21923 (gimple_omp_target_clauses_ptr): Likewise.
21924 (gimple_omp_target_set_clauses): Likewise.
21925 (gimple_omp_target_child_fn): Likewise.
21926 (gimple_omp_target_child_fn_ptr): Likewise.
21927 (gimple_omp_target_set_child_fn): Likewise.
21928 (gimple_omp_target_data_arg): Likewise.
21929 (gimple_omp_target_data_arg_ptr): Likewise.
21930 (gimple_omp_target_set_data_arg): Likewise.
21931 (gimple_omp_teams_clauses): Likewise.
21932 (gimple_omp_teams_clauses_ptr): Likewise.
21933 (gimple_omp_teams_set_clauses): Likewise.
21934 (gimple_omp_sections_clauses): Likewise.
21935 (gimple_omp_sections_clauses_ptr): Likewise.
21936 (gimple_omp_sections_set_clauses): Likewise.
21937 (gimple_omp_sections_control): Likewise.
21938 (gimple_omp_sections_control_ptr): Likewise.
21939 (gimple_omp_sections_set_control): Likewise.
21940 (gimple_omp_for_set_cond): Likewise.
21941 (gimple_omp_for_cond): Likewise.
21942 (gimple_omp_atomic_store_set_val): Likewise.
21943 (gimple_omp_atomic_store_val): Likewise.
21944 (gimple_omp_atomic_store_val_ptr): Likewise.
21945 (gimple_omp_atomic_load_set_lhs): Likewise.
21946 (gimple_omp_atomic_load_lhs): Likewise.
21947 (gimple_omp_atomic_load_lhs_ptr): Likewise.
21948 (gimple_omp_atomic_load_set_rhs): Likewise.
21949 (gimple_omp_atomic_load_rhs): Likewise.
21950 (gimple_omp_atomic_load_rhs_ptr): Likewise.
21951 (gimple_omp_continue_control_def): Likewise.
21952 (gimple_omp_continue_control_def_ptr): Likewise.
21953 (gimple_omp_continue_set_control_def): Likewise.
21954 (gimple_omp_continue_control_use): Likewise.
21955 (gimple_omp_continue_control_use_ptr): Likewise.
21956 (gimple_omp_continue_set_control_use): Likewise.
21957 (gimple_transaction_body_ptr): Likewise.
21958 (gimple_transaction_label): Likewise.
21959 (gimple_transaction_label_ptr): Likewise.
21960 (gimple_transaction_set_body): Likewise.
21961 (gimple_transaction_set_label): Likewise.
21962
21963 * ipa-devirt.c (build_type_inheritance_graph): Likewise.
21964 * ipa-inline-analysis.c (inline_write_summary): Likewise.
21965 * ipa-ref.c (ipa_record_reference): Likewise.
21966 * ipa-reference.c (analyze_function): Likewise.
21967 (ipa_reference_write_optimization_summary): Likewise.
21968 * ipa.c (symtab_remove_unreachable_nodes): Likewise.
21969 (address_taken_from_non_vtable_p): Likewise.
21970 (comdat_can_be_unshared_p_1): Likewise.
21971 * lto-cgraph.c (lto_output_ref): Likewise.
21972 (add_references): Likewise.
21973 (compute_ltrans_boundary): Likewise.
21974 (output_symtab): Likewise.
21975 (input_ref): Likewise.
21976 (input_cgraph_1): Likewise.
21977 (output_cgraph_opt_summary): Likewise.
21978 * lto-streamer-out.c (lto_output): Likewise.
21979 (output_symbol_p): Likewise.
21980 * lto-streamer.h (lsei_next_function_in_partition): Likewise.
21981 (lsei_start_function_in_partition): Likewise.
21982 (lsei_next_variable_in_partition): Likewise.
21983 (lsei_start_variable_in_partition): Likewise.
21984 * symtab.c (insert_to_assembler_name_hash): Likewise.
21985 (unlink_from_assembler_name_hash): Likewise.
21986 (symtab_unregister_node): Likewise.
21987 (symtab_remove_node): Likewise.
21988 (dump_symtab_node): Likewise.
21989 (verify_symtab_base): Likewise.
21990 (verify_symtab_node): Likewise.
21991 (symtab_make_decl_local): Likewise.
21992 (symtab_alias_ultimate_target): Likewise.
21993 (symtab_resolve_alias): Likewise.
21994 (symtab_get_symbol_partitioning_class): Likewise.
21995 * tree-phinodes.c (allocate_phi_node): Likewise.
21996 (reserve_phi_args_for_new_edge): Likewise.
21997 (remove_phi_args): Likewise.
21998 * varpool.c (varpool_node_for_asm): Likewise.
21999 (varpool_remove_unreferenced_decls): Likewise.
22000
22001 2014-04-23 Jeff Law <law@redhat.com>
22002
22003 PR tree-optimization/60902
22004 * tree-ssa-threadedge.c
22005 (record_temporary_equivalences_from_stmts_at_dest): Make sure to
22006 invalidate outputs from statements that do not produce useful
22007 outputs for threading.
22008
22009 2014-04-23 Venkataramanan Kumar <venkataramanan.kumar@linaro.org>
22010
22011 * config/aarch64/aarch64.md (stack_protect_set, stack_protect_test)
22012 (stack_protect_set_<mode>, stack_protect_test_<mode>): Add
22013 machine descriptions for Stack Smashing Protector.
22014
22015 2014-04-23 Richard Earnshaw <rearnsha@arm.com>
22016
22017 * aarch64.md (<optab>_rol<mode>3): New pattern.
22018 (<optab>_rolsi3_uxtw): Likewise.
22019 * aarch64.c (aarch64_strip_shift): Handle ROTATE and ROTATERT.
22020
22021 2014-04-23 James Greenhalgh <james.greenhalgh@arm.com>
22022
22023 * config/arm/arm.c (arm_cortex_a57_tune): Initialize all fields.
22024 (arm_cortex_a12_tune): Likewise.
22025
22026 2014-04-23 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
22027
22028 * config/aarch64/aarch64.c (aarch64_rtx_costs): Handle BSWAP.
22029
22030 2014-04-23 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
22031
22032 * config/arm/arm.md (arm_rev16si2): New pattern.
22033 (arm_rev16si2_alt): Likewise.
22034 * config/arm/arm.c (arm_new_rtx_costs): Handle rev16 case.
22035
22036 2014-04-23 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
22037
22038 * config/aarch64/aarch64.md (rev16<mode>2): New pattern.
22039 (rev16<mode>2_alt): Likewise.
22040 * config/aarch64/aarch64.c (aarch64_rtx_costs): Handle rev16 case.
22041 * config/arm/aarch-common.c (aarch_rev16_shright_mask_imm_p): New.
22042 (aarch_rev16_shleft_mask_imm_p): Likewise.
22043 (aarch_rev16_p_1): Likewise.
22044 (aarch_rev16_p): Likewise.
22045 * config/arm/aarch-common-protos.h (aarch_rev16_p): Declare extern.
22046 (aarch_rev16_shright_mask_imm_p): Likewise.
22047 (aarch_rev16_shleft_mask_imm_p): Likewise.
22048
22049 2014-04-23 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
22050
22051 * config/arm/aarch-common-protos.h (alu_cost_table): Add rev field.
22052 * config/arm/aarch-cost-tables.h (generic_extra_costs): Specify
22053 rev cost.
22054 (cortex_a53_extra_costs): Likewise.
22055 (cortex_a57_extra_costs): Likewise.
22056 * config/arm/arm.c (cortexa9_extra_costs): Likewise.
22057 (cortexa7_extra_costs): Likewise.
22058 (cortexa8_extra_costs): Likewise.
22059 (cortexa12_extra_costs): Likewise.
22060 (cortexa15_extra_costs): Likewise.
22061 (v7m_extra_costs): Likewise.
22062 (arm_new_rtx_costs): Handle BSWAP.
22063
22064 2013-04-23 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
22065
22066 * config/arm/arm.c (cortexa8_extra_costs): New table.
22067 (arm_cortex_a8_tune): New tuning struct.
22068 * config/arm/arm-cores.def (cortex-a8): Use cortex_a8 tuning struct.
22069
22070 2014-04-23 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
22071
22072 * config/arm/arm.c (arm_new_rtx_costs): Handle FMA.
22073
22074 2014-04-23 Richard Biener <rguenther@suse.de>
22075
22076 * Makefile.in (OBJS): Remove loop-unswitch.o.
22077 * tree-pass.h (make_pass_rtl_unswitch): Remove.
22078 * passes.def (pass_rtl_unswitch): Likewise.
22079 * loop-init.c (gate_rtl_unswitch): Likewise.
22080 (rtl_unswitch): Likewise.
22081 (pass_data_rtl_unswitch): Likewise.
22082 (pass_rtl_unswitch): Likewise.
22083 (make_pass_rtl_unswitch): Likewise.
22084 * rtl.h (reversed_condition): Likewise.
22085 (compare_and_jump_seq): Likewise.
22086 * loop-iv.c (reversed_condition): Move here from loop-unswitch.c
22087 and make static.
22088 * loop-unroll.c (compare_and_jump_seq): Likewise.
22089
22090 2014-04-23 Richard Biener <rguenther@suse.de>
22091
22092 PR tree-optimization/60903
22093 * tree-ssa-loop-im.c (analyze_memory_references): Remove
22094 commented code block.
22095 (execute_sm_if_changed): Properly apply IRREDUCIBLE_LOOP
22096 loop flags to newly created BBs and edges.
22097
22098 2014-04-23 Nick Clifton <nickc@redhat.com>
22099
22100 * config/msp430/msp430.c (msp430_handle_option): Move function
22101 to msp430-common.c
22102 (msp430_option_override): Simplify mcu and mcpu option handling.
22103 (msp430_is_f5_mcu): Rename to msp430_use_f5_series_hwmult. Add
22104 support for -mhwmult command line option.
22105 (has_32bit_hwmult): Rename to use_32bit_hwmult. Add support for
22106 -mhwmult command line option.
22107 (msp430_hwmult_enabled): Delete.
22108 (msp43o_output_labelref): Add support for -mhwmult command line option.
22109 * config/msp430/msp430.md (mulhisi3, umulhisi3, mulsidi3)
22110 (umulsidi3): Likewise.
22111 * config/msp430/msp430.opt (mmcu): Add Report attribute.
22112 (mcpu, mlarge, msmall): Likewise.
22113 (mhwmult): New option.
22114 * config/msp430/msp430-protos.h (msp430_hwmult_enabled): Remove
22115 prototype.
22116 (msp430_is_f5_mcu): Remove prototype.
22117 (msp430_use_f5_series_hwmult): Add prototype.
22118 * config/msp430/msp430-opts.h: New file.
22119 * common/config/msp430: New directory.
22120 * common/config/msp430/msp430-common.c: New file.
22121 * config.gcc (msp430): Remove target_has_targetm_common.
22122 * doc/invoke.texi: Document -mhwmult command line option.
22123
22124 2014-04-23 Nick Clifton <nickc@redhat.com>
22125
22126 * config/i386/cygwin.h (ENDFILE_SPEC): Include
22127 default-manifest.o if it can be found in the search path.
22128 * config/i386/mingw32.h (ENDFILE_SPEC): Likewise.
22129
22130 2014-04-23 Terry Guo <terry.guo@arm.com>
22131
22132 * config/arm/arm.h (ASM_APP_OFF): Re-define it in a cleaner way.
22133
22134 2014-04-23 Richard Biener <rguenther@suse.de>
22135
22136 PR middle-end/60895
22137 * tree-inline.c (declare_return_variable): Use mark_addressable.
22138
22139 2014-04-23 Richard Biener <rguenther@suse.de>
22140
22141 PR middle-end/60891
22142 * loop-init.c (loop_optimizer_init): Make sure to apply
22143 LOOPS_MAY_HAVE_MULTIPLE_LATCHES before fixing up loops.
22144
22145 2014-04-22 Jakub Jelinek <jakub@redhat.com>
22146
22147 PR sanitizer/60275
22148 * common.opt (fsanitize-recover, fsanitize-undefined-trap-on-error):
22149 New options.
22150 * gcc.c (sanitize_spec_function): Don't return "" for "undefined"
22151 if flag_sanitize_undefined_trap_on_error.
22152 * sanitizer.def (BUILT_IN_UBSAN_HANDLE_DIVREM_OVERFLOW_ABORT,
22153 BUILT_IN_UBSAN_HANDLE_SHIFT_OUT_OF_BOUNDS_ABORT,
22154 BUILT_IN_UBSAN_HANDLE_VLA_BOUND_NOT_POSITIVE_ABORT,
22155 BUILT_IN_UBSAN_HANDLE_TYPE_MISMATCH_ABORT,
22156 BUILT_IN_UBSAN_HANDLE_ADD_OVERFLOW_ABORT,
22157 BUILT_IN_UBSAN_HANDLE_SUB_OVERFLOW_ABORT,
22158 BUILT_IN_UBSAN_HANDLE_MUL_OVERFLOW_ABORT,
22159 BUILT_IN_UBSAN_HANDLE_NEGATE_OVERFLOW_ABORT,
22160 BUILT_IN_UBSAN_HANDLE_LOAD_INVALID_VALUE_ABORT): New builtins.
22161 * ubsan.c (ubsan_instrument_unreachable): Return
22162 __builtin_trap () if flag_sanitize_undefined_trap_on_error.
22163 (ubsan_expand_null_ifn): Emit __builtin_trap ()
22164 if flag_sanitize_undefined_trap_on_error and
22165 __ubsan_handle_type_mismatch_abort if !flag_sanitize_recover.
22166 (ubsan_expand_null_ifn, ubsan_build_overflow_builtin,
22167 instrument_bool_enum_load): Emit __builtin_trap () if
22168 flag_sanitize_undefined_trap_on_error and
22169 __builtin_handle_*_abort () if !flag_sanitize_recover.
22170 * doc/invoke.texi (-fsanitize-recover,
22171 -fsanitize-undefined-trap-on-error): Document.
22172
22173 2014-04-22 Christian Bruel <christian.bruel@st.com>
22174
22175 * config/sh/sh.md (mov<mode>): Replace movQIHI.
22176 Force immediates to SImode.
22177
22178 2014-04-22 Sandra Loosemore <sandra@codesourcery.com>
22179
22180 * config/nios2/nios2.md (UNSPEC_ROUND): New.
22181 (lroundsfsi2): New.
22182 * config/nios2/nios2.opt (mno-custom-round, mcustom-round=): New.
22183 * config/nios2/nios2-opts.h (N2FPU_ALL_CODES): Add round.
22184 * config/nios2/nios2.c (N2F_NO_ERRNO): Define.
22185 (nios2_fpu_insn): Add entry for round.
22186 (N2FPU_NO_ERRNO_P): Define.
22187 (nios2_custom_check_insns): Add check for N2F_NO_ERRNO and
22188 flag_errno_math.
22189 * doc/invoke.texi (Nios II Options): Document -mcustom-round.
22190
22191 2014-04-22 Richard Henderson <rth@redhat.com>
22192
22193 * config/aarch64/aarch64 (addti3, subti3): New expanders.
22194 (add<GPI>3_compare0): Remove leading * from name.
22195 (add<GPI>3_carryin): Likewise.
22196 (sub<GPI>3_compare0): Likewise.
22197 (sub<GPI>3_carryin): Likewise.
22198 (<su_optab>mulditi3): New expander.
22199 (multi3): New expander.
22200 (madd<GPI>): Remove leading * from name.
22201
22202 2014-04-22 Martin Jambor <mjambor@suse.cz>
22203
22204 * cgraphclones.c (cgraph_function_versioning): Copy
22205 ipa_transforms_to_apply instead of asserting it is empty.
22206
22207 2014-04-22 H.J. Lu <hongjiu.lu@intel.com>
22208
22209 PR target/60868
22210 * config/i386/i386.c (ix86_expand_set_or_movmem): Call counter_mode
22211 on count_exp to get mode.
22212
22213 2014-04-22 Andrew Pinski <apinski@cavium.com>
22214
22215 * config/aarch64/aarch64.c (aarch64_load_symref_appropriately):
22216 Handle TLS for ILP32.
22217 * config/aarch64/aarch64.md (tlsie_small): Rename to ...
22218 (tlsie_small_<mode>): this and handle PTR.
22219 (tlsie_small_sidi): New pattern.
22220 (tlsle_small): Change to an expand to handle ILP32.
22221 (tlsle_small_<mode>): New pattern.
22222 (tlsdesc_small): Rename to ...
22223 (tlsdesc_small_<mode>): this and handle PTR.
22224
22225 2014-04-22 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
22226
22227 * config/aarch64/aarch64.c (TARGET_FLAGS_REGNUM): Define.
22228
22229 2014-04-22 Alex Velenko <Alex.Velenko@arm.com>
22230
22231 * config/aarch64/aarch64-builtins.c (TYPES_REINTERP): Removed.
22232 (aarch64_types_signed_unsigned_qualifiers): Qualifier added.
22233 (aarch64_types_signed_poly_qualifiers): Likewise.
22234 (aarch64_types_unsigned_signed_qualifiers): Likewise.
22235 (aarch64_types_poly_signed_qualifiers): Likewise.
22236 (TYPES_REINTERP_SS): Type macro added.
22237 (TYPES_REINTERP_SU): Likewise.
22238 (TYPES_REINTERP_SP): Likewise.
22239 (TYPES_REINTERP_US): Likewise.
22240 (TYPES_REINTERP_PS): Likewise.
22241 (aarch64_fold_builtin): New expression folding added.
22242 * config/aarch64/aarch64-simd-builtins.def (REINTERP):
22243 Declarations removed.
22244 (REINTERP_SS): Declarations added.
22245 (REINTERP_US): Likewise.
22246 (REINTERP_PS): Likewise.
22247 (REINTERP_SU): Likewise.
22248 (REINTERP_SP): Likewise.
22249 * config/aarch64/arm_neon.h (vreinterpret_p8_f64): Implemented.
22250 (vreinterpretq_p8_f64): Likewise.
22251 (vreinterpret_p16_f64): Likewise.
22252 (vreinterpretq_p16_f64): Likewise.
22253 (vreinterpret_f32_f64): Likewise.
22254 (vreinterpretq_f32_f64): Likewise.
22255 (vreinterpret_f64_f32): Likewise.
22256 (vreinterpret_f64_p8): Likewise.
22257 (vreinterpret_f64_p16): Likewise.
22258 (vreinterpret_f64_s8): Likewise.
22259 (vreinterpret_f64_s16): Likewise.
22260 (vreinterpret_f64_s32): Likewise.
22261 (vreinterpret_f64_s64): Likewise.
22262 (vreinterpret_f64_u8): Likewise.
22263 (vreinterpret_f64_u16): Likewise.
22264 (vreinterpret_f64_u32): Likewise.
22265 (vreinterpret_f64_u64): Likewise.
22266 (vreinterpretq_f64_f32): Likewise.
22267 (vreinterpretq_f64_p8): Likewise.
22268 (vreinterpretq_f64_p16): Likewise.
22269 (vreinterpretq_f64_s8): Likewise.
22270 (vreinterpretq_f64_s16): Likewise.
22271 (vreinterpretq_f64_s32): Likewise.
22272 (vreinterpretq_f64_s64): Likewise.
22273 (vreinterpretq_f64_u8): Likewise.
22274 (vreinterpretq_f64_u16): Likewise.
22275 (vreinterpretq_f64_u32): Likewise.
22276 (vreinterpretq_f64_u64): Likewise.
22277 (vreinterpret_s64_f64): Likewise.
22278 (vreinterpretq_s64_f64): Likewise.
22279 (vreinterpret_u64_f64): Likewise.
22280 (vreinterpretq_u64_f64): Likewise.
22281 (vreinterpret_s8_f64): Likewise.
22282 (vreinterpretq_s8_f64): Likewise.
22283 (vreinterpret_s16_f64): Likewise.
22284 (vreinterpretq_s16_f64): Likewise.
22285 (vreinterpret_s32_f64): Likewise.
22286 (vreinterpretq_s32_f64): Likewise.
22287 (vreinterpret_u8_f64): Likewise.
22288 (vreinterpretq_u8_f64): Likewise.
22289 (vreinterpret_u16_f64): Likewise.
22290 (vreinterpretq_u16_f64): Likewise.
22291 (vreinterpret_u32_f64): Likewise.
22292 (vreinterpretq_u32_f64): Likewise.
22293
22294 2014-04-22 Alex Velenko <Alex.Velenko@arm.com>
22295
22296 * config/aarch64/aarch64/aarch64-builtins.c (TYPES_REINTERP): Removed.
22297 * config/aarch64/aarch64/aarch64-simd-builtins.def (REINTERP): Removed.
22298 (vreinterpret_p8_s8): Likewise.
22299 * config/aarch64/aarch64/arm_neon.h (vreinterpret_p8_s8): Uses cast.
22300 (vreinterpret_p8_s16): Likewise.
22301 (vreinterpret_p8_s32): Likewise.
22302 (vreinterpret_p8_s64): Likewise.
22303 (vreinterpret_p8_f32): Likewise.
22304 (vreinterpret_p8_u8): Likewise.
22305 (vreinterpret_p8_u16): Likewise.
22306 (vreinterpret_p8_u32): Likewise.
22307 (vreinterpret_p8_u64): Likewise.
22308 (vreinterpret_p8_p16): Likewise.
22309 (vreinterpretq_p8_s8): Likewise.
22310 (vreinterpretq_p8_s16): Likewise.
22311 (vreinterpretq_p8_s32): Likewise.
22312 (vreinterpretq_p8_s64): Likewise.
22313 (vreinterpretq_p8_f32): Likewise.
22314 (vreinterpretq_p8_u8): Likewise.
22315 (vreinterpretq_p8_u16): Likewise.
22316 (vreinterpretq_p8_u32): Likewise.
22317 (vreinterpretq_p8_u64): Likewise.
22318 (vreinterpretq_p8_p16): Likewise.
22319 (vreinterpret_p16_s8): Likewise.
22320 (vreinterpret_p16_s16): Likewise.
22321 (vreinterpret_p16_s32): Likewise.
22322 (vreinterpret_p16_s64): Likewise.
22323 (vreinterpret_p16_f32): Likewise.
22324 (vreinterpret_p16_u8): Likewise.
22325 (vreinterpret_p16_u16): Likewise.
22326 (vreinterpret_p16_u32): Likewise.
22327 (vreinterpret_p16_u64): Likewise.
22328 (vreinterpret_p16_p8): Likewise.
22329 (vreinterpretq_p16_s8): Likewise.
22330 (vreinterpretq_p16_s16): Likewise.
22331 (vreinterpretq_p16_s32): Likewise.
22332 (vreinterpretq_p16_s64): Likewise.
22333 (vreinterpretq_p16_f32): Likewise.
22334 (vreinterpretq_p16_u8): Likewise.
22335 (vreinterpretq_p16_u16): Likewise.
22336 (vreinterpretq_p16_u32): Likewise.
22337 (vreinterpretq_p16_u64): Likewise.
22338 (vreinterpretq_p16_p8): Likewise.
22339 (vreinterpret_f32_s8): Likewise.
22340 (vreinterpret_f32_s16): Likewise.
22341 (vreinterpret_f32_s32): Likewise.
22342 (vreinterpret_f32_s64): Likewise.
22343 (vreinterpret_f32_u8): Likewise.
22344 (vreinterpret_f32_u16): Likewise.
22345 (vreinterpret_f32_u32): Likewise.
22346 (vreinterpret_f32_u64): Likewise.
22347 (vreinterpret_f32_p8): Likewise.
22348 (vreinterpret_f32_p16): Likewise.
22349 (vreinterpretq_f32_s8): Likewise.
22350 (vreinterpretq_f32_s16): Likewise.
22351 (vreinterpretq_f32_s32): Likewise.
22352 (vreinterpretq_f32_s64): Likewise.
22353 (vreinterpretq_f32_u8): Likewise.
22354 (vreinterpretq_f32_u16): Likewise.
22355 (vreinterpretq_f32_u32): Likewise.
22356 (vreinterpretq_f32_u64): Likewise.
22357 (vreinterpretq_f32_p8): Likewise.
22358 (vreinterpretq_f32_p16): Likewise.
22359 (vreinterpret_s64_s8): Likewise.
22360 (vreinterpret_s64_s16): Likewise.
22361 (vreinterpret_s64_s32): Likewise.
22362 (vreinterpret_s64_f32): Likewise.
22363 (vreinterpret_s64_u8): Likewise.
22364 (vreinterpret_s64_u16): Likewise.
22365 (vreinterpret_s64_u32): Likewise.
22366 (vreinterpret_s64_u64): Likewise.
22367 (vreinterpret_s64_p8): Likewise.
22368 (vreinterpret_s64_p16): Likewise.
22369 (vreinterpretq_s64_s8): Likewise.
22370 (vreinterpretq_s64_s16): Likewise.
22371 (vreinterpretq_s64_s32): Likewise.
22372 (vreinterpretq_s64_f32): Likewise.
22373 (vreinterpretq_s64_u8): Likewise.
22374 (vreinterpretq_s64_u16): Likewise.
22375 (vreinterpretq_s64_u32): Likewise.
22376 (vreinterpretq_s64_u64): Likewise.
22377 (vreinterpretq_s64_p8): Likewise.
22378 (vreinterpretq_s64_p16): Likewise.
22379 (vreinterpret_u64_s8): Likewise.
22380 (vreinterpret_u64_s16): Likewise.
22381 (vreinterpret_u64_s32): Likewise.
22382 (vreinterpret_u64_s64): Likewise.
22383 (vreinterpret_u64_f32): Likewise.
22384 (vreinterpret_u64_u8): Likewise.
22385 (vreinterpret_u64_u16): Likewise.
22386 (vreinterpret_u64_u32): Likewise.
22387 (vreinterpret_u64_p8): Likewise.
22388 (vreinterpret_u64_p16): Likewise.
22389 (vreinterpretq_u64_s8): Likewise.
22390 (vreinterpretq_u64_s16): Likewise.
22391 (vreinterpretq_u64_s32): Likewise.
22392 (vreinterpretq_u64_s64): Likewise.
22393 (vreinterpretq_u64_f32): Likewise.
22394 (vreinterpretq_u64_u8): Likewise.
22395 (vreinterpretq_u64_u16): Likewise.
22396 (vreinterpretq_u64_u32): Likewise.
22397 (vreinterpretq_u64_p8): Likewise.
22398 (vreinterpretq_u64_p16): Likewise.
22399 (vreinterpret_s8_s16): Likewise.
22400 (vreinterpret_s8_s32): Likewise.
22401 (vreinterpret_s8_s64): Likewise.
22402 (vreinterpret_s8_f32): Likewise.
22403 (vreinterpret_s8_u8): Likewise.
22404 (vreinterpret_s8_u16): Likewise.
22405 (vreinterpret_s8_u32): Likewise.
22406 (vreinterpret_s8_u64): Likewise.
22407 (vreinterpret_s8_p8): Likewise.
22408 (vreinterpret_s8_p16): Likewise.
22409 (vreinterpretq_s8_s16): Likewise.
22410 (vreinterpretq_s8_s32): Likewise.
22411 (vreinterpretq_s8_s64): Likewise.
22412 (vreinterpretq_s8_f32): Likewise.
22413 (vreinterpretq_s8_u8): Likewise.
22414 (vreinterpretq_s8_u16): Likewise.
22415 (vreinterpretq_s8_u32): Likewise.
22416 (vreinterpretq_s8_u64): Likewise.
22417 (vreinterpretq_s8_p8): Likewise.
22418 (vreinterpretq_s8_p16): Likewise.
22419 (vreinterpret_s16_s8): Likewise.
22420 (vreinterpret_s16_s32): Likewise.
22421 (vreinterpret_s16_s64): Likewise.
22422 (vreinterpret_s16_f32): Likewise.
22423 (vreinterpret_s16_u8): Likewise.
22424 (vreinterpret_s16_u16): Likewise.
22425 (vreinterpret_s16_u32): Likewise.
22426 (vreinterpret_s16_u64): Likewise.
22427 (vreinterpret_s16_p8): Likewise.
22428 (vreinterpret_s16_p16): Likewise.
22429 (vreinterpretq_s16_s8): Likewise.
22430 (vreinterpretq_s16_s32): Likewise.
22431 (vreinterpretq_s16_s64): Likewise.
22432 (vreinterpretq_s16_f32): Likewise.
22433 (vreinterpretq_s16_u8): Likewise.
22434 (vreinterpretq_s16_u16): Likewise.
22435 (vreinterpretq_s16_u32): Likewise.
22436 (vreinterpretq_s16_u64): Likewise.
22437 (vreinterpretq_s16_p8): Likewise.
22438 (vreinterpretq_s16_p16): Likewise.
22439 (vreinterpret_s32_s8): Likewise.
22440 (vreinterpret_s32_s16): Likewise.
22441 (vreinterpret_s32_s64): Likewise.
22442 (vreinterpret_s32_f32): Likewise.
22443 (vreinterpret_s32_u8): Likewise.
22444 (vreinterpret_s32_u16): Likewise.
22445 (vreinterpret_s32_u32): Likewise.
22446 (vreinterpret_s32_u64): Likewise.
22447 (vreinterpret_s32_p8): Likewise.
22448 (vreinterpret_s32_p16): Likewise.
22449 (vreinterpretq_s32_s8): Likewise.
22450 (vreinterpretq_s32_s16): Likewise.
22451 (vreinterpretq_s32_s64): Likewise.
22452 (vreinterpretq_s32_f32): Likewise.
22453 (vreinterpretq_s32_u8): Likewise.
22454 (vreinterpretq_s32_u16): Likewise.
22455 (vreinterpretq_s32_u32): Likewise.
22456 (vreinterpretq_s32_u64): Likewise.
22457 (vreinterpretq_s32_p8): Likewise.
22458 (vreinterpretq_s32_p16): Likewise.
22459 (vreinterpret_u8_s8): Likewise.
22460 (vreinterpret_u8_s16): Likewise.
22461 (vreinterpret_u8_s32): Likewise.
22462 (vreinterpret_u8_s64): Likewise.
22463 (vreinterpret_u8_f32): Likewise.
22464 (vreinterpret_u8_u16): Likewise.
22465 (vreinterpret_u8_u32): Likewise.
22466 (vreinterpret_u8_u64): Likewise.
22467 (vreinterpret_u8_p8): Likewise.
22468 (vreinterpret_u8_p16): Likewise.
22469 (vreinterpretq_u8_s8): Likewise.
22470 (vreinterpretq_u8_s16): Likewise.
22471 (vreinterpretq_u8_s32): Likewise.
22472 (vreinterpretq_u8_s64): Likewise.
22473 (vreinterpretq_u8_f32): Likewise.
22474 (vreinterpretq_u8_u16): Likewise.
22475 (vreinterpretq_u8_u32): Likewise.
22476 (vreinterpretq_u8_u64): Likewise.
22477 (vreinterpretq_u8_p8): Likewise.
22478 (vreinterpretq_u8_p16): Likewise.
22479 (vreinterpret_u16_s8): Likewise.
22480 (vreinterpret_u16_s16): Likewise.
22481 (vreinterpret_u16_s32): Likewise.
22482 (vreinterpret_u16_s64): Likewise.
22483 (vreinterpret_u16_f32): Likewise.
22484 (vreinterpret_u16_u8): Likewise.
22485 (vreinterpret_u16_u32): Likewise.
22486 (vreinterpret_u16_u64): Likewise.
22487 (vreinterpret_u16_p8): Likewise.
22488 (vreinterpret_u16_p16): Likewise.
22489 (vreinterpretq_u16_s8): Likewise.
22490 (vreinterpretq_u16_s16): Likewise.
22491 (vreinterpretq_u16_s32): Likewise.
22492 (vreinterpretq_u16_s64): Likewise.
22493 (vreinterpretq_u16_f32): Likewise.
22494 (vreinterpretq_u16_u8): Likewise.
22495 (vreinterpretq_u16_u32): Likewise.
22496 (vreinterpretq_u16_u64): Likewise.
22497 (vreinterpretq_u16_p8): Likewise.
22498 (vreinterpretq_u16_p16): Likewise.
22499 (vreinterpret_u32_s8): Likewise.
22500 (vreinterpret_u32_s16): Likewise.
22501 (vreinterpret_u32_s32): Likewise.
22502 (vreinterpret_u32_s64): Likewise.
22503 (vreinterpret_u32_f32): Likewise.
22504 (vreinterpret_u32_u8): Likewise.
22505 (vreinterpret_u32_u16): Likewise.
22506 (vreinterpret_u32_u64): Likewise.
22507 (vreinterpret_u32_p8): Likewise.
22508 (vreinterpret_u32_p16): Likewise.
22509 (vreinterpretq_u32_s8): Likewise.
22510 (vreinterpretq_u32_s16): Likewise.
22511 (vreinterpretq_u32_s32): Likewise.
22512 (vreinterpretq_u32_s64): Likewise.
22513 (vreinterpretq_u32_f32): Likewise.
22514 (vreinterpretq_u32_u8): Likewise.
22515 (vreinterpretq_u32_u16): Likewise.
22516 (vreinterpretq_u32_u64): Likewise.
22517 (vreinterpretq_u32_p8): Likewise.
22518 (vreinterpretq_u32_p16): Likewise.
22519
22520 2014-04-22 Alex Velenko <Alex.Velenko@arm.com>
22521
22522 * gcc/config/aarch64/aarch64-simd.md (aarch64_s<optab><mode>):
22523 Pattern extended.
22524 * config/aarch64/aarch64-simd-builtins.def (sqneg): Iterator extended.
22525 (sqabs): Likewise.
22526 * config/aarch64/arm_neon.h (vqneg_s64): New intrinsic.
22527 (vqnegd_s64): Likewise.
22528 (vqabs_s64): Likewise.
22529 (vqabsd_s64): Likewise.
22530
22531 2014-04-22 Richard Henderson <rth@redhat.com>
22532
22533 * config/sparc/sparc.c (sparc_init_modes): Hoist GET_MODE_SIZE
22534 computation to the top of the loop.
22535
22536 2014-04-22 Renlin <renlin.li@arm.com>
22537 Jiong Wang <jiong.wang@arm.com>
22538
22539 * config/aarch64/aarch64.h (aarch64_frame): Delete "fp_lr_offset".
22540 * config/aarch64/aarch64.c (aarch64_layout_frame)
22541 (aarch64_initial_elimination_offset): Likewise.
22542
22543 2014-04-22 Marcus Shawcroft <marcus.shawcroft@arm.com>
22544
22545 * config/aarch64/aarch64.c (aarch64_initial_elimination_offset):
22546 Fix indentation.
22547
22548 2014-04-22 Richard Sandiford <rdsandiford@googlemail.com>
22549
22550 * machmode.h (bitwise_mode_for_mode): Declare.
22551 * stor-layout.h (bitwise_type_for_mode): Likewise.
22552 * stor-layout.c (bitwise_mode_for_mode): New function.
22553 (bitwise_type_for_mode): Likewise.
22554 * builtins.c (fold_builtin_memory_op): Use it instead of
22555 int_mode_for_mode and build_nonstandard_integer_type.
22556
22557 2014-04-22 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
22558
22559 * config.gcc (enable_obsolete): Remove *-*-solaris2.9*.
22560 (*-*-solaris2.[0-9] | *-*-solaris2.[0-9].*): Mark unsupported.
22561 (*-*-solaris2*): Simplify.
22562 (i[34567]86-*-solaris2* | x86_64-*-solaris2.1[0-9]*): Likewise.
22563 (i[34567]86-*-solaris2* | x86_64-*-solaris2.1[0-9]*): Remove
22564 *-*-solaris2.9* handling.
22565
22566 * configure.ac (gcc_cv_as_hidden): Remove test for Solaris 9/x86
22567 as bug.
22568 (gcc_cv_ld_hidden): Remove *-*-solaris2.9* handling.
22569 (ld_tls_support): Remove i?86-*-solaris2.9, sparc*-*-solaris2.9
22570 handling, simplify.
22571 (gcc_cv_as_gstabs_flag): Remove workaround for Solaris 9/x86 as bug.
22572 * configure: Regenerate.
22573
22574 * config/i386/sol2-9.h: Remove.
22575
22576 * doc/install.texi (Specific, i?86-*-solaris2.9): Remove.
22577 (Specific, *-*-solaris2*): Mention Solaris 9 support removal.
22578 Remove Solaris 9 references.
22579
22580 2014-04-22 Vidya Praveen <vidyapraveen@arm.com>
22581
22582 * aarch64.md (float<GPI:mode><GPF:mode>2): Remove.
22583 (floatuns<GPI:mode><GPF:mode>2): Remove.
22584 (<optab><fcvt_target><GPF:mode>2): New pattern for equal width float
22585 and floatuns conversions.
22586 (<optab><fcvt_iesize><GPF:mode>2): New pattern for inequal width float
22587 and floatuns conversions.
22588 * iterators.md (fcvt_target, FCVT_TARGET): Support SF and DF modes.
22589 (w1,w2): New mode attributes for inequal width conversions.
22590
22591 2014-04-22 Renlin Li <Renlin.Li@arm.com>
22592
22593 * config/aarch64/aarch64.c (aarch64_print_operand_address): Adjust
22594 the output asm format.
22595
22596 2014-04-22 James Greenhalgh <james.greenhalgh@arm.com>
22597
22598 * config/aarch64/aarch64-simd.md
22599 (aarch64_cm<optab>di): Always split.
22600 (*aarch64_cm<optab>di): New.
22601 (aarch64_cmtstdi): Always split.
22602 (*aarch64_cmtstdi): New.
22603
22604 2014-04-22 Jakub Jelinek <jakub@redhat.com>
22605
22606 PR tree-optimization/60823
22607 * omp-low.c (ipa_simd_modify_function_body): Go through
22608 all SSA_NAMEs and for those refering to vector arguments
22609 which are going to be replaced adjust SSA_NAME_VAR and,
22610 if it is a default definition, change it into a non-default
22611 definition assigned at the beginning of function from new_decl.
22612 (ipa_simd_modify_stmt_ops): Rewritten.
22613 * tree-dfa.c (set_ssa_default_def): When removing default def,
22614 check for NULL loc instead of NULL *loc.
22615
22616 2014-04-22 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
22617
22618 * config/arm/arm.c (arm_hard_regno_mode_ok): Loosen
22619 restrictions on core registers for DImode values in Thumb2.
22620
22621 2014-04-22 Ian Bolton <ian.bolton@arm.com>
22622
22623 * config/arm/arm.md (*anddi_notdi_zesidi): New pattern.
22624 * config/arm/thumb2.md (*iordi_notdi_zesidi): New pattern.
22625
22626 2014-04-22 Ian Bolton <ian.bolton@arm.com>
22627
22628 * config/arm/thumb2.md (*iordi_notdi_di): New pattern.
22629 (*iordi_notzesidi_di): Likewise.
22630 (*iordi_notsesidi_di): Likewise.
22631
22632 2014-04-22 Ian Bolton <ian.bolton@arm.com>
22633
22634 * config/arm/arm-protos.h (tune_params): New struct members.
22635 * config/arm/arm.c: Initialise tune_params per processor.
22636 (thumb2_reorg): Suppress conversion from t32 to t16 when optimizing
22637 for speed, based on new tune_params.
22638
22639 2014-04-22 Alex Velenko <Alex.Velenko@arm.com>
22640
22641 * config/aarch64/aarch64-builtins.c (BUILTIN_VDQF_DF): Macro added.
22642 * config/aarch64/aarch64-simd-builtins.def (frintn): Use added macro.
22643 * config/aarch64/aarch64-simd.md (<frint_pattern>): Comment corrected.
22644 * config/aarch64/aarch64.md (<frint_pattern>): Likewise.
22645 * config/aarch64/arm_neon.h (vrnd_f64): Added.
22646 (vrnda_f64): Likewise.
22647 (vrndi_f64): Likewise.
22648 (vrndm_f64): Likewise.
22649 (vrndn_f64): Likewise.
22650 (vrndp_f64): Likewise.
22651 (vrndx_f64): Likewise.
22652
22653 2014-04-22 Zhenqiang Chen <zhenqiang.chen@linaro.org>
22654
22655 * config/arm/arm.c (arm_print_operand, thumb_exit): Make sure
22656 GET_MODE_SIZE argument is enum machine_mode.
22657
22658 2014-04-22 Jakub Jelinek <jakub@redhat.com>
22659
22660 PR target/60910
22661 * config/sparc/sparc.c (sparc_init_modes): Pass enum machine_mode
22662 value instead of int to GET_MODE_CLASS and GET_MODE_SIZE macros.
22663
22664 2014-04-22 Lin Zuojian <manjian2006@gmail.com>
22665
22666 PR middle-end/60281
22667 * asan.c (asan_emit_stack_protection): Force the base to align to
22668 appropriate bits if STRICT_ALIGNMENT. Set shadow_mem align to
22669 appropriate bits if STRICT_ALIGNMENT.
22670 * cfgexpand.c (expand_stack_vars): Set base_align appropriately
22671 when asan is on.
22672 (expand_used_vars): Leave a space in the stack frame for alignment
22673 if STRICT_ALIGNMENT.
22674
22675 2014-04-21 David Malcolm <dmalcolm@redhat.com>
22676
22677 * gimple.h (gimple_assign_single_p): Accept a const_gimple rather
22678 than a gimple.
22679 (gimple_store_p): Likewise.
22680 (gimple_assign_load_p): Likewise.
22681 (gimple_assign_cast_p): Likewise.
22682 (gimple_clobber_p): Likewise.
22683
22684 * doc/gimple.texi (gimple_assign_cast_p): Accept a const_gimple
22685 rather than a gimple.
22686 (gimple_assign_cast_p): Likewise.
22687
22688 2014-04-21 Michael Meissner <meissner@linux.vnet.ibm.com>
22689
22690 PR target/60735
22691 * config/rs6000/rs6000.md (mov<mode>_softfloat32, FMOVE64 case):
22692 If mode is DDmode and TARGET_E500_DOUBLE allow move.
22693
22694 * config/rs6000/rs6000.c (rs6000_debug_reg_global): Print some
22695 more debug information for E500 if -mdebug=reg.
22696
22697 2014-04-21 Uros Bizjak <ubizjak@gmail.com>
22698
22699 PR target/60909
22700 * config/i386/i386.c (ix86_expand_builtin)
22701 <case IX86_BUILTIN_RDRAND{16,32,64}_STEP>: Use temporary
22702 register for target RTX.
22703 <case IX86_BUILTIN_RDSEED{16,32,64}_STEP>: Ditto.
22704
22705 2014-04-18 Cong Hou <congh@google.com>
22706
22707 * tree-vect-patterns.c (vect_recog_widen_mult_pattern): Enhance
22708 the widen-mult pattern by handling two operands with different sizes,
22709 and operands whose size is smaller than half of the result type.
22710
22711 2014-04-18 Jan Hubicka <hubicka@ucw.cz>
22712
22713 * ipa-inline.h (INLINE_HINT_known_hot): New hint.
22714 * ipa-inline-analysis.c (dump_inline_hints): Dump it.
22715 (do_estimate_edge_time): Compute it.
22716 * ipa-inline.c (want_inline_small_function_p): Bypass
22717 INLINE_INSNS_AUTO/SINGLE limits for calls that are known to be hot.
22718
22719 2014-04-18 Jan Hubicka <hubicka@ucw.cz>
22720
22721 * ipa-inline.c (spec_rem): New static variable.
22722 (dump_overall_stats): New function.
22723 (dump_inline_stats): New function.
22724
22725 2014-04-18 Richard Henderson <rth@redhat.com>
22726
22727 * config/aarch64/aarch64.c (aarch64_register_move_cost): Pass a mode
22728 to GET_MODE_SIZE, not a reg_class_t.
22729
22730 2014-04-18 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
22731
22732 * config/rs6000/vsx.md (vsx_xxmrghw_<mode>): Adjust for little-endian.
22733 (vsx_xxmrglw_<mode>): Likewise.
22734
22735 2014-04-17 Michael Meissner <meissner@linux.vnet.ibm.com>
22736
22737 PR target/60876
22738 * config/rs6000/rs6000.c (rs6000_setup_reg_addr_masks): Make sure
22739 GET_MODE_SIZE gets passed an enum machine_mode type and not integer.
22740 (rs6000_init_hard_regno_mode_ok): Likewise.
22741
22742 2014-04-17 Jan Hubicka <hubicka@ucw.cz>
22743
22744 * ipa-inline.c (inline_small_functions): Account only non-cold
22745 functions.
22746 * doc/invoke.texi (inline-unit-growth): Update documentation.
22747
22748 2014-04-17 Pat Haugen <pthaugen@us.ibm.com>
22749
22750 * config/rs6000/rs6000.md (addti3, subti3): New.
22751
22752 2014-04-17 H.J. Lu <hongjiu.lu@intel.com>
22753
22754 PR target/60863
22755 * config/i386/i386.c (ix86_expand_clear): Remove outdated
22756 comment. Check optimize_insn_for_size_p instead of
22757 optimize_insn_for_speed_p.
22758
22759 2014-04-17 Martin Jambor <mjambor@suse.cz>
22760
22761 * gimple-iterator.c (gsi_start_edge): New function.
22762 * gimple-iterator.h (gsi_start_edge): Declare.
22763 * tree-sra.c (single_non_eh_succ): New function.
22764 (disqualify_ops_if_throwing_stmt): Renamed to
22765 disqualify_if_bad_bb_terminating_stmt. Allow throwing statements
22766 having one non-EH successor BB.
22767 (sra_modify_expr): If stmt ends bb, use single non-EH successor to
22768 generate loads into replacements.
22769 (sra_modify_assign): Likewise and and also use the simple path for
22770 such statements.
22771 (sra_modify_function_body): Commit statements on edges.
22772
22773 2014-04-17 Richard Biener <rguenther@suse.de>
22774
22775 PR middle-end/60849
22776 * tree-ssa-propagate.c (valid_gimple_rhs_p): Allow vector
22777 comparison results and add clarifying comment.
22778
22779 2014-04-17 Jakub Jelinek <jakub@redhat.com>
22780
22781 * genmodes.c (struct mode_data): Add need_bytesize_adj field.
22782 (blank_mode): Initialize it.
22783 (emit_mode_size_inline, emit_mode_nunits_inline,
22784 emit_mode_inner_inline): New functions.
22785 (emit_insn_modes_h): Call them and surround their output with
22786 #if GCC_VERSION >= 4001 ... #endif.
22787 * machmode.h (GET_MODE_SIZE, GET_MODE_NUNITS, GET_MODE_INNER):
22788 For GCC_VERSION >= 4001 use mode_*_inline routines instead of
22789 mode_* arrays if the argument is __builtin_constant_p.
22790 * lower-subreg.c (dump_choices): Make sure GET_MODE_SIZE argument
22791 is enum machine_mode.
22792
22793 2014-04-17 Trevor Saunders <tsaunders@mozilla.com>
22794
22795 * passes.c (opt_pass::execute): Adjust.
22796 (pass_manager::execute_pass_mode_switching): Likewise.
22797 (early_local_passes::execute): Likewise.
22798 (execute_one_pass): Pass cfun to the pass's execute method.
22799 * tree-pass.h (opt_pass::execute): Add function * argument.
22800 * asan.c, auto-inc-dec.c, bb-reorder.c, bt-load.c, cfgcleanup.c,
22801 cfgexpand.c, cfgrtl.c, cgraphbuild.c, combine-stack-adj.c, combine.c,
22802 compare-elim.c, config/arc/arc.c, config/epiphany/mode-switch-use.c,
22803 config/epiphany/resolve-sw-modes.c, config/i386/i386.c,
22804 config/mips/mips.c, config/rl78/rl78.c, config/s390/s390.c,
22805 config/sparc/sparc.c, cprop.c, dce.c, df-core.c, dse.c, dwarf2cfi.c,
22806 except.c, final.c, function.c, fwprop.c, gcse.c, gimple-low.c,
22807 gimple-ssa-isolate-paths.c, gimple-ssa-strength-reduction.c,
22808 graphite.c, ifcvt.c, init-regs.c, ipa-cp.c, ipa-devirt.c,
22809 ipa-inline-analysis.c, ipa-inline.c, ipa-profile.c, ipa-pure-const.c,
22810 ipa-reference.c, ipa-split.c, ipa.c, ira.c, jump.c, loop-init.c,
22811 lower-subreg.c, mode-switching.c, omp-low.c, postreload-gcse.c,
22812 postreload.c, predict.c, recog.c, ree.c, reg-stack.c, regcprop.c,
22813 reginfo.c, regrename.c, reorg.c, sched-rgn.c, stack-ptr-mod.c,
22814 store-motion.c, tracer.c, trans-mem.c, tree-call-cdce.c, tree-cfg.c,
22815 tree-cfgcleanup.c, tree-complex.c, tree-eh.c, tree-emutls.c,
22816 tree-if-conv.c, tree-into-ssa.c, tree-loop-distribution.c, tree-nrv.c,
22817 tree-object-size.c, tree-parloops.c, tree-predcom.c, tree-ssa-ccp.c,
22818 tree-ssa-copy.c, tree-ssa-copyrename.c, tree-ssa-dce.c,
22819 tree-ssa-dom.c, tree-ssa-dse.c, tree-ssa-forwprop.c,
22820 tree-ssa-ifcombine.c, tree-ssa-loop-ch.c, tree-ssa-loop-im.c,
22821 tree-ssa-loop-ivcanon.c, tree-ssa-loop-prefetch.c,
22822 tree-ssa-loop-unswitch.c, tree-ssa-loop.c, tree-ssa-math-opts.c,
22823 tree-ssa-phiopt.c, tree-ssa-phiprop.c, tree-ssa-pre.c,
22824 tree-ssa-reassoc.c, tree-ssa-sink.c, tree-ssa-strlen.c,
22825 tree-ssa-structalias.c, tree-ssa-uncprop.c, tree-ssa-uninit.c,
22826 tree-ssa.c, tree-ssanames.c, tree-stdarg.c, tree-switch-conversion.c,
22827 tree-tailcall.c, tree-vect-generic.c, tree-vectorizer.c, tree-vrp.c,
22828 tree.c, tsan.c, ubsan.c, var-tracking.c, vtable-verify.c, web.c:
22829 Adjust.
22830
22831 2014-04-17 Trevor Saunders <tsaunders@mozilla.com>
22832
22833 * passes.c (opt_pass::gate): Take function * argument.
22834 (gate_all_early_local_passes): Merge into
22835 (early_local_passes::gate): this.
22836 (gate_all_early_optimizations): Merge into
22837 (all_early_optimizations::gate): this.
22838 (gate_all_optimizations): Mege into
22839 (all_optimizations::gate): this.
22840 (gate_all_optimizations_g): Merge into
22841 (all_optimizations_g::gate): this.
22842 (gate_rest_of_compilation): Mege into
22843 (rest_of_compilation::gate): this.
22844 (gate_postreload): Merge into
22845 (postreload::gate): this.
22846 (dump_one_pass): Pass cfun to the pass's gate method.
22847 (execute_ipa_summary_passes): Likewise.
22848 (execute_one_pass): Likewise.
22849 (ipa_write_summaries_2): Likewise.
22850 (ipa_write_optimization_summaries_1): Likewise.
22851 (ipa_read_summaries_1): Likewise.
22852 (ipa_read_optimization_summaries_1): Likewise.
22853 (execute_ipa_stmt_fixups): Likewise.
22854 * tree-pass.h (opt_pass::gate): Add function * argument.
22855 * asan.c, auto-inc-dec.c, bb-reorder.c, bt-load.c,
22856 combine-stack-adj.c, combine.c, compare-elim.c,
22857 config/epiphany/resolve-sw-modes.c, config/i386/i386.c,
22858 config/rl78/rl78.c, config/sh/sh_optimize_sett_clrt.cc,
22859 config/sh/sh_treg_combine.cc, config/sparc/sparc.c, cprop.c, cse.c,
22860 dce.c, df-core.c, dse.c, dwarf2cfi.c, except.c, fwprop.c, gcse.c,
22861 gimple-ssa-isolate-paths.c, gimple-ssa-strength-reduction.c,
22862 graphite.c, ifcvt.c, init-regs.c, ipa-cp.c, ipa-devirt.c,
22863 ipa-profile.c, ipa-pure-const.c, ipa-reference.c, ipa-split.c, ipa.c,
22864 loop-init.c, lower-subreg.c, mode-switching.c, modulo-sched.c,
22865 omp-low.c, postreload-gcse.c, postreload.c, predict.c, recog.c, ree.c,
22866 reg-stack.c, regcprop.c, regrename.c, reorg.c, sched-rgn.c,
22867 store-motion.c, tracer.c, trans-mem.c, tree-call-cdce.c, tree-cfg.c,
22868 tree-cfgcleanup.c, tree-complex.c, tree-eh.c, tree-emutls.c,
22869 tree-if-conv.c, tree-into-ssa.c, tree-loop-distribution.c,
22870 tree-nrv.c, tree-parloops.c, tree-predcom.c, tree-profile.c,
22871 tree-sra.c, tree-ssa-ccp.c, tree-ssa-copy.c, tree-ssa-copyrename.c,
22872 tree-ssa-dce.c, tree-ssa-dom.c, tree-ssa-dse.c, tree-ssa-forwprop.c,
22873 tree-ssa-ifcombine.c, tree-ssa-loop-ch.c, tree-ssa-loop-im.c,
22874 tree-ssa-loop-ivcanon.c, tree-ssa-loop-prefetch.c,
22875 tree-ssa-loop-unswitch.c, tree-ssa-loop.c, tree-ssa-math-opts.c,
22876 tree-ssa-phiopt.c, tree-ssa-phiprop.c, tree-ssa-pre.c,
22877 tree-ssa-reassoc.c, tree-ssa-sink.c, tree-ssa-strlen.c,
22878 tree-ssa-structalias.c, tree-ssa-uncprop.c, tree-ssa-uninit.c,
22879 tree-ssa.c, tree-stdarg.c, tree-switch-conversion.c, tree-tailcall.c,
22880 tree-vect-generic.c, tree-vectorizer.c, tree-vrp.c, tsan.c, ubsan.c,
22881 var-tracking.c, vtable-verify.c, web.c: Adjust.
22882
22883 2014-04-17 Trevor Saunders <tsaunders@mozilla.com>
22884
22885 * configure.ac: Check for -Woverloaded-virtual and enable it if found.
22886 * configure: Regenerate.
22887
22888 2014-04-17 Trevor Saunders <tsaunders@mozilla.com>
22889
22890 * passes.c (dump_one_pass): don't check pass->has_gate.
22891 (execute_ipa_summary_passes): Likewise.
22892 (execute_one_pass): Likewise.
22893 (ipa_write_summaries_2): Likewise.
22894 (ipa_write_optimization_summaries_1): Likewise.
22895 (ipa_read_optimization_summaries_1): Likewise.
22896 (execute_ipa_stmt_fixups): Likewise.
22897 * tree-pass.h (pass_data::has_gate): Remove.
22898 * asan.c, auto-inc-dec.c, bb-reorder.c, bt-load.c, cfgcleanup.c,
22899 cfgexpand.c, cfgrtl.c, cgraphbuild.c, combine-stack-adj.c, combine.c,
22900 compare-elim.c, config/arc/arc.c, config/epiphany/mode-switch-use.c,
22901 config/epiphany/resolve-sw-modes.c, config/i386/i386.c,
22902 config/mips/mips.c, config/rl78/rl78.c, config/s390/s390.c,
22903 config/sh/sh_optimize_sett_clrt.cc, config/sh/sh_treg_combine.cc,
22904 config/sparc/sparc.c, cprop.c, cse.c, dce.c, df-core.c, dse.c,
22905 dwarf2cfi.c, except.c, final.c, function.c, fwprop.c, gcse.c,
22906 gimple-low.c, gimple-ssa-isolate-paths.c,
22907 gimple-ssa-strength-reduction.c, graphite.c, ifcvt.c, init-regs.c,
22908 ipa-cp.c, ipa-devirt.c, ipa-inline-analysis.c, ipa-inline.c,
22909 ipa-profile.c, ipa-pure-const.c, ipa-reference.c, ipa-split.c, ipa.c,
22910 ira.c, jump.c, loop-init.c, lower-subreg.c, mode-switching.c,
22911 modulo-sched.c, omp-low.c, postreload-gcse.c, postreload.c, predict.c,
22912 recog.c, ree.c, reg-stack.c, regcprop.c, reginfo.c, regrename.c,
22913 reorg.c, sched-rgn.c, stack-ptr-mod.c, store-motion.c, tracer.c,
22914 trans-mem.c, tree-call-cdce.c, tree-cfg.c, tree-cfgcleanup.c,
22915 tree-complex.c, tree-eh.c, tree-emutls.c, tree-if-conv.c,
22916 tree-into-ssa.c, tree-loop-distribution.c, tree-nrv.c,
22917 tree-object-size.c, tree-parloops.c, tree-predcom.c, tree-profile.c,
22918 tree-sra.c, tree-ssa-ccp.c, tree-ssa-copy.c, tree-ssa-copyrename.c,
22919 tree-ssa-dce.c, tree-ssa-dom.c, tree-ssa-dse.c, tree-ssa-forwprop.c,
22920 tree-ssa-ifcombine.c, tree-ssa-loop-ch.c, tree-ssa-loop-im.c,
22921 tree-ssa-loop-ivcanon.c, tree-ssa-loop-prefetch.c,
22922 tree-ssa-loop-unswitch.c, tree-ssa-loop.c, tree-ssa-math-opts.c,
22923 tree-ssa-phiopt.c, tree-ssa-phiprop.c, tree-ssa-pre.c,
22924 tree-ssa-reassoc.c, tree-ssa-sink.c, tree-ssa-strlen.c,
22925 tree-ssa-structalias.c, tree-ssa-uncprop.c, tree-ssa-uninit.c,
22926 tree-ssa.c, tree-ssanames.c, tree-stdarg.c, tree-switch-conversion.c,
22927 tree-tailcall.c, tree-vect-generic.c, tree-vectorizer.c, tree-vrp.c,
22928 tree.c, tsan.c, ubsan.c, var-tracking.c, vtable-verify.c, web.c:
22929 Adjust.
22930
22931 2014-04-17 Trevor Saunders <tsaunders@mozilla.com>
22932
22933 * pass_manager.h (pass_manager::register_dump_files_1): Remove
22934 declaration.
22935 * passes.c (pass_manager::register_dump_files_1): Merge into
22936 (pass_manager::register_dump_files): this, and remove its handling of
22937 properties since the pass always has the properties anyway.
22938 (pass_manager::pass_manager): Adjust.
22939
22940 2014-04-17 Trevor Saunders <tsaunders@mozilla.com>
22941
22942 * pass_manager.h (pass_manager::register_dump_files_1): Adjust.
22943 * passes.c (pass_manager::register_dump_files_1): Remove dead code
22944 dealing with properties.
22945 (pass_manager::register_dump_files): Adjust.
22946
22947 2014-03-20 Mark Wielaard <mjw@redhat.com>
22948
22949 * dwarf2out.c (add_bound_info): If HOST_WIDE_INT is big enough,
22950 then represent the bound as normal constant value.
22951
22952 2014-04-17 Jakub Jelinek <jakub@redhat.com>
22953
22954 PR target/60847
22955 Forward port from 4.8 branch
22956 2013-07-19 Kirill Yukhin <kirill.yukhin@intel.com>
22957
22958 * config/i386/bmiintrin.h (_blsi_u32): New.
22959 (_blsi_u64): Ditto.
22960 (_blsr_u32): Ditto.
22961 (_blsr_u64): Ditto.
22962 (_blsmsk_u32): Ditto.
22963 (_blsmsk_u64): Ditto.
22964 (_tzcnt_u32): Ditto.
22965 (_tzcnt_u64): Ditto.
22966
22967 2014-04-17 Kito Cheng <kito@0xlab.org>
22968
22969 * gcc.c (used_arg): Prevent out of bound access for multilib_options.
22970
22971 2014-04-17 Richard Biener <rguenther@suse.de>
22972
22973 PR middle-end/60849
22974 * tree-ssa-propagate.c (valid_gimple_rhs_p): Only allow effective
22975 boolean results for comparisons.
22976
22977 2014-04-17 Richard Biener <rguenther@suse.de>
22978
22979 PR tree-optimization/60836
22980 * tree-vect-loop.c (vect_create_epilog_for_reduction): Force
22981 initial PHI args to be gimple values.
22982
22983 2014-04-17 Richard Biener <rguenther@suse.de>
22984
22985 PR tree-optimization/60841
22986 * tree-vect-data-refs.c (vect_analyze_data_refs): Count stmts.
22987 * tree-vect-loop.c (vect_analyze_loop_2): Pass down number
22988 of stmts to SLP build.
22989 * tree-vect-slp.c (vect_slp_analyze_bb_1): Likewise.
22990 (vect_analyze_slp): Likewise.
22991 (vect_analyze_slp_instance): Likewise.
22992 (vect_build_slp_tree): Limit overall SLP tree growth.
22993 * tree-vectorizer.h (vect_analyze_data_refs,
22994 vect_analyze_slp): Adjust prototypes.
22995
22996 2014-04-17 Evgeny Stupachenko <evstupac@gmail.com>
22997
22998 * config/i386/i386.c (x86_add_stmt_cost): Fix vector cost model for
22999 Silvermont.
23000
23001 2014-04-17 Evgeny Stupachenko <evstupac@gmail.com>
23002
23003 * config/i386/x86-tune.def (TARGET_SLOW_PSHUFB): New tune definition.
23004 * config/i386/i386.h (TARGET_SLOW_PSHUFB): New tune flag.
23005 * config/i386/i386.c (expand_vec_perm_even_odd_1): Avoid byte shuffles
23006 for TARGET_SLOW_PSHUFB
23007
23008 2014-04-17 Evgeny Stupachenko <evstupac@gmail.com>
23009
23010 * config/i386/i386.c (slm_cost): Adjust vec_to_scalar_cost.
23011 * config/i386/i386.c (intel_cost): Ditto.
23012
23013 2014-04-17 Joey Ye <joey.ye@arm.com>
23014
23015 * opts.c (OPT_fif_conversion, OPT_fif_conversion2): Disable for Og.
23016
23017 2014-04-16 Jan Hubicka <hubicka@ucw.cz>
23018
23019 * opts.c (common_handle_option): Disable -fipa-reference coorectly
23020 with -fuse-profile.
23021
23022 2014-04-16 Jan Hubicka <hubicka@ucw.cz>
23023
23024 * ipa-devirt.c (odr_type_d): Add field all_derivations_known.
23025 (type_all_derivations_known_p): New predicate.
23026 (type_all_ctors_visible_p): New predicate.
23027 (type_possibly_instantiated_p): New predicate.
23028 (get_odr_type): Compute all_derivations_known.
23029 (dump_odr_type): Dump the flag.
23030 (maybe_record_type): Cleanup.
23031 (record_target_from_binfo): Add bases_to_consider array;
23032 record bases for types w/o instances and skip CXX destructor.
23033 (possible_polymorphic_call_targets_1): Add bases_to_consider
23034 and consider_construction parameters; check if type may have instance.
23035 (get_polymorphic_call_info): Set maybe_in_construction to true
23036 when we know nothing.
23037 (record_targets_from_bases): Skip CXX destructors; they are
23038 never called for types in construction.
23039 (possible_polymorphic_call_targets): Do not record target when
23040 type may not have instance.
23041
23042 2014-04-16 Jan Hubicka <hubicka@ucw.cz>
23043
23044 PR ipa/60854
23045 * ipa.c (symtab_remove_unreachable_nodes): Mark targets of
23046 external aliases alive, too.
23047
23048 2014-04-16 Andrew Pinski <apinski@cavium.com>
23049
23050 * config/host-linux.c (TRY_EMPTY_VM_SPACE): Change aarch64 ilp32
23051 definition.
23052
23053 2014-04-16 Eric Botcazou <ebotcazou@adacore.com>
23054
23055 * final.c (compute_alignments): Do not apply loop alignment to a block
23056 falling through to the exit.
23057
23058 2014-04-16 Catherine Moore <clm@codesourcery.com>
23059
23060 * mips.md (*mov<mode>_internal, *movhi_internal, *movqi_internal):
23061 Adjust constraints for microMIPS store patterns.
23062
23063 2014-04-16 Pitchumani Sivanupandi <Pitchumani.S@atmel.com>
23064
23065 * config/avr/avr-mcus.def: Correct typo for atxmega256a3bu macro.
23066
23067 2014-04-16 Eric Botcazou <ebotcazou@adacore.com>
23068
23069 * tree-ssa-operands.c (create_vop_var): Set DECL_IGNORED_P.
23070 (append_use): Run at -O0.
23071 (append_vdef): Likewise.
23072 * tree-ssa-ter.c (ter_is_replaceable_p): Do not special-case -O0.
23073 * tree-ssa-uninit.c (warn_uninitialized_vars): Remove obsolete comment.
23074
23075 2014-04-16 Jakub Jelinek <jakub@redhat.com>
23076
23077 PR tree-optimization/60844
23078 * tree-ssa-reassoc.c (reassoc_remove_stmt): New function.
23079 (propagate_op_to_single_use, remove_visited_stmt_chain,
23080 linearize_expr, repropagate_negates, reassociate_bb): Use it
23081 instead of gsi_remove.
23082
23083 2014-04-16 Martin Jambor <mjambor@suse.cz>
23084
23085 * cgraphclones.c (cgraph_create_virtual_clone): Duplicate
23086 ipa_transforms_to_apply.
23087 (cgraph_function_versioning): Assert that old_node has empty
23088 ipa_transforms_to_apply.
23089 * trans-mem.c (ipa_tm_create_version): Likewise.
23090 * tree-inline.c (tree_function_versioning): Do not duplicate
23091 ipa_transforms_to_apply.
23092
23093 2014-04-16 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
23094
23095 PR target/60817
23096 * configure.ac (set_have_as_tls): Merge i[34567]86-*-* and
23097 x86_64-*-* cases.
23098 Pass necessary as flags on 64-bit Solaris/x86.
23099 Use lowercase relocs for x86_64-*-*.
23100 * configure: Regenerate.
23101
23102 2014-04-15 Jan Hubicka <jh@suse.cz>
23103
23104 * ipa-devirt.c (referenced_from_vtable_p): New predicate.
23105 (maybe_record_node, likely_target_p): Use it.
23106
23107 2014-04-15 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
23108
23109 PR target/60839
23110 Revert following patch
23111
23112 2014-04-02 Michael Meissner <meissner@linux.vnet.ibm.com>
23113
23114 PR target/60735
23115 * config/rs6000/rs6000.c (rs6000_hard_regno_mode_ok): If we have
23116 software floating point or no floating point registers, do not
23117 allow any type in the FPRs. Eliminate a test for SPE SIMD types
23118 in GPRs that occurs after we tested for GPRs that would never be
23119 true.
23120
23121 * config/rs6000/rs6000.md (mov<mode>_softfloat32, FMOVE64):
23122 Rewrite tests to use TARGET_DOUBLE_FLOAT and TARGET_E500_DOUBLE,
23123 since the FMOVE64 type is DFmode/DDmode. If TARGET_E500_DOUBLE,
23124 specifically allow DDmode, since that does not use the SPE SIMD
23125 instructions.
23126
23127 2014-03-21 Mark Wielaard <mjw@redhat.com>
23128
23129 * dwarf2out.c (gen_enumeration_type_die): Add DW_AT_const_value
23130 as unsigned or int depending on type and value used.
23131
23132 2014-04-15 Richard Biener <rguenther@suse.de>
23133
23134 PR rtl-optimization/56965
23135 * alias.c (ncr_compar, nonoverlapping_component_refs_p): Move ...
23136 * tree-ssa-alias.c (ncr_compar, nonoverlapping_component_refs_p):
23137 ... here.
23138 * alias.c (true_dependence_1): Do not call
23139 nonoverlapping_component_refs_p.
23140 * tree-ssa-alias.c (indirect_ref_may_alias_decl_p): Call
23141 nonoverlapping_component_refs_p.
23142 (indirect_refs_may_alias_p): Likewise.
23143
23144 2014-04-15 Teresa Johnson <tejohnson@google.com>
23145
23146 * cfg.c (dump_bb_info): Fix flags check.
23147 * tree-cfg.c (remove_bb): Only dump TDF_BLOCKS when removing.
23148
23149 2014-04-15 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
23150
23151 PR rtl-optimization/60663
23152 * config/arm/arm.c (arm_new_rtx_costs): Improve ASM_OPERANDS case,
23153 avoid 0 cost.
23154
23155 2014-04-15 Richard Biener <rguenther@suse.de>
23156
23157 * lto-streamer.h (LTO_major_version): Bump to 4.
23158
23159 2014-04-15 Richard Biener <rguenther@suse.de>
23160
23161 * common.opt (lto_partition_model): New enum.
23162 (flto-partition=): Merge separate options with a single with argument,
23163 add -flto-partition=one support.
23164 * flag-types.h (enum lto_partition_model): Declare.
23165 * opts.c (finish_options): Remove duplicate -flto-partition=
23166 option check.
23167 * lto-wrapper.c (run_gcc): Adjust.
23168
23169 2014-04-15 Richard Biener <rguenther@suse.de>
23170
23171 * alias.c (ncr_compar): New function.
23172 (nonoverlapping_component_refs_p): Re-implement in O (n log n).
23173
23174 2014-04-15 Richard Biener <rguenther@suse.de>
23175
23176 * alias.c (record_component_aliases): Do not walk BINFOs.
23177
23178 2014-04-15 Richard Biener <rguenther@suse.de>
23179
23180 * tree-ssa-structalias.c (find_func_aliases_for_builtin_call):
23181 Add struct function argument and adjust.
23182 (find_func_aliases_for_call): Likewise.
23183 (find_func_aliases): Likewise.
23184 (find_func_clobbers): Likewise.
23185 (intra_create_variable_infos): Likewise.
23186 (compute_points_to_sets): Likewise.
23187 (ipa_pta_execute): Adjust. Do not push/pop cfun.
23188
23189 2014-04-15 Richard Biener <rguenther@suse.de>
23190
23191 * tree.c (iterative_hash_expr): Use enum tree_code_class
23192 to store TREE_CODE_CLASS.
23193 (tree_block): Likewise.
23194 (tree_set_block): Likewise.
23195 * tree.h (fold_build_pointer_plus_loc): Use
23196 convert_to_ptrofftype_loc.
23197
23198 2014-04-15 Jakub Jelinek <jakub@redhat.com>
23199
23200 PR plugins/59335
23201 * Makefile.in (PLUGIN_HEADERS): Add various headers that have been
23202 added in 4.9.
23203
23204 2014-04-15 Eric Botcazou <ebotcazou@adacore.com>
23205
23206 * cfgloop.h (struct loop): Move force_vectorize down.
23207 * gimplify.c (gimple_boolify) <ANNOTATE_EXPR>: Handle new kinds.
23208 (gimplify_expr) <ANNOTATE_EXPR>: Minor tweak.
23209 * lto-streamer-in.c (input_cfg): Read dont_vectorize field.
23210 * lto-streamer-out.c (output_cfg): Write dont_vectorize field.
23211 * tree-cfg.c (replace_loop_annotate): Revamp and handle new kinds.
23212 * tree-core.h (enum annot_expr_kind): Add new kind values.
23213 * tree-inline.c (copy_loops): Copy dont_vectorize field and reorder.
23214 * tree-pretty-print.c (dump_generic_node) <ANNOTATE_EXPR>: Handle new
23215 kinds.
23216 * tree.def (ANNOTATE_EXPR): Tweak comment.
23217
23218 2014-04-14 Jan Hubicka <hubicka@ucw.cz>
23219
23220 * ipa-devirt.c (maybe_record_node): Ignore all non-methods (including
23221 cxa_pure_virtual).
23222
23223 2014-04-14 Paolo Carlini <paolo.carlini@oracle.com>
23224
23225 * tree.h (TYPE_IDENTIFIER): Declare.
23226 * tree.c (subrange_type_for_debug_p): Use it.
23227 * godump.c (go_format_type): Likewise.
23228 * dwarf2out.c (is_cxx_auto, modified_type_die,
23229 gen_type_die_with_usage, gen_type_die_with_usage): Likewise.
23230 * dbxout.c (dbxout_type, dbxout_symbol): Likewise.
23231
23232 2014-04-14 Jan Hubicka <hubicka@ucw.cz>
23233
23234 PR lto/60820
23235 * varpool.c (varpool_remove_node): Do not alter decls when streaming.
23236
23237 2014-04-14 Uros Bizjak <ubizjak@gmail.com>
23238
23239 * config/i386/i386.c (examine_argument): Return bool. Return true if
23240 parameter should be passed in memory.
23241 <case X86_64_COMPLEX_X87_CLASS>: Adjust.
23242 (construct_container): Update calls to examine_argument.
23243 (function_arg_advance_64): Ditto.
23244 (return_in_memory_32): Merge with ix86_return_in_memory.
23245 (return_in_memory_64): Ditto.
23246 (return_in_memory_ms_64): Ditto.
23247
23248 2014-04-14 Jan Hubicka <hubicka@ucw.cz>
23249
23250 * ipa-utils.c (ipa_merge_profiles): Merge profile_id.
23251 * coverage.c (coverage_compute_profile_id): Handle externally visible
23252 symbols.
23253
23254 2014-04-14 Martin Jambor <mjambor@suse.cz>
23255
23256 * tree-sra.c (ipa_sra_preliminary_function_checks): Skip
23257 DECL_DISREGARD_INLINE_LIMITS functions.
23258
23259 2014-04-14 H.J. Lu <hongjiu.lu@intel.com>
23260
23261 PR target/60827
23262 * config/i386/i386.md (*fixuns_trunc<mode>_1): Revert the last change.
23263
23264 2014-04-14 H.J. Lu <hongjiu.lu@intel.com>
23265
23266 PR target/60827
23267 * config/i386/i386.md (*fixuns_trunc<mode>_1): Check
23268 optimize_insn_for_speed_p instead of
23269 optimize_function_for_speed_p.
23270
23271 2014-04-14 Yufeng Zhang <yufeng.zhang@arm.com>
23272
23273 * doc/invoke.texi (free): Document AArch64.
23274
23275 2014-04-14 Richard Biener <rguenther@suse.de>
23276
23277 PR tree-optimization/60042
23278 * tree-ssa-pre.c (inhibit_phi_insertion): Remove.
23279 (insert_into_preds_of_block): Do not prevent PHI insertion
23280 for REFERENCE exprs here ...
23281 (eliminate_dom_walker::before_dom_children): ... but prevent
23282 their use here under similar conditions when applied to the
23283 IL after PRE optimizations.
23284
23285 2014-04-14 Richard Biener <rguenther@suse.de>
23286
23287 * passes.def: Move early points-to after early SRA.
23288
23289 2014-04-14 Richard Biener <rguenther@suse.de>
23290
23291 * tree-ssa-forwprop.c (simplify_gimple_switch): Enhance
23292 check for which sign-changes we allow when forwarding
23293 a converted value into a switch.
23294
23295 2014-04-14 Eric Botcazou <ebotcazou@adacore.com>
23296
23297 * stor-layout.c (place_field): Finalize non-constant offset for the
23298 field, if any.
23299
23300 2014-04-14 Richard Biener <rguenther@suse.de>
23301
23302 * tree-switch-conversion.c (lshift_cheap_p): Get speed_p
23303 as argument.
23304 (expand_switch_using_bit_tests_p): Likewise.
23305 (process_switch): Compute and pass on speed_p based on the
23306 switch stmt.
23307 * tree-ssa-math-opts.c (gimple_expand_builtin_pow): Use
23308 optimize_bb_for_speed_p.
23309
23310 2014-04-14 Eric Botcazou <ebotcazou@adacore.com>
23311
23312 * cfgloop.h (struct loop): Rename force_vect into force_vectorize.
23313 * function.h (struct function): Rename has_force_vect_loops into
23314 has_force_vectorize_loops.
23315 * lto-streamer-in.c (input_cfg): Adjust for renaming.
23316 (input_struct_function_base): Likewise.
23317 * lto-streamer-out.c (output_cfg): Likewise.
23318 (output_struct_function_base): Likewise.
23319 * omp-low.c (expand_omp_simd): Likewise.
23320 * tree-cfg.c (move_sese_region_to_fn): Likewise.
23321 * tree-if-conv.c (ifcvt_can_use_mask_load_store): Likewise.
23322 (version_loop_for_if_conversion): Likewise.
23323 (tree_if_conversion): Likewise.
23324 (main_tree_if_conversion): Likewise.
23325 (gate_tree_if_conversion): Likewise.
23326 * tree-inline.c (copy_loops): Likewise.
23327 * tree-ssa-loop-ivcanon.c (tree_unroll_loops_completely_1): Likewise.
23328 * tree-ssa-loop.c (tree_loop_vectorize): Likewise.
23329 * tree-ssa-phiopt.c (tree_ssa_phiopt_worker): Likewise.
23330 * tree-vect-loop.c (vect_estimate_min_profitable_iters): Likewise.
23331 * tree-vectorizer.c (vectorize_loops): Likewise.
23332 * tree-vectorizer.h (unlimited_cost_model): Likewise.
23333
23334 2014-04-14 Richard Biener <rguenther@suse.de>
23335
23336 PR lto/60720
23337 * lto-streamer-out.c (wrap_refs): New function.
23338 (lto_output): Wrap symbol references in global initializes in
23339 type-preserving MEM_REFs.
23340
23341 2014-04-14 Christian Bruel <christian.bruel@st.com>
23342
23343 * config/sh/sh-mem.cc (sh_expand_strlen): Unroll last word.
23344
23345 2014-04-14 Christian Bruel <christian.bruel@st.com>
23346
23347 * config/sh/sh.md (setmemqi): New expand pattern.
23348 * config/sh/sh.h (CLEAR_RATIO): Define.
23349 * config/sh/sh-mem.cc (sh_expand_setmem): Define.
23350 * config/sh/sh-protos.h (sh_expand_setmem): Declare.
23351
23352 2014-04-14 Richard Biener <rguenther@suse.de>
23353
23354 PR middle-end/55022
23355 * fold-const.c (negate_expr_p): Don't negate directional rounding
23356 division.
23357 (fold_negate_expr): Likewise.
23358
23359 2014-04-14 Richard Biener <rguenther@suse.de>
23360
23361 PR tree-optimization/59817
23362 PR tree-optimization/60453
23363 * graphite-scop-detection.c (graphite_can_represent_scev): Complete
23364 recursion to catch all CHRECs in the scalar evolution and restrict
23365 the predicate for the remains appropriately.
23366
23367 2014-04-12 Catherine Moore <clm@codesourcery.com>
23368
23369 * config/mips/constraints.md: Add new register constraint "kb".
23370 * config/mips/mips.md (*mov<mode>_internal): Use constraint "kb".
23371 (*movhi_internal): Likewise.
23372 (*movqi_internal): Likewise.
23373 * config/mips/mips.h (M16_STORE_REGS): New register class.
23374 (REG_CLASS_NAMES): Add M16_STORE_REGS.
23375 (REG_CLASS_CONTENTS): Likewise.
23376 * config/mips/mips.c (mips_regno_to_class): Add M16_STORE_REGS.
23377
23378 2014-04-11 Tobias Burnus <burnus@net-b.de>
23379
23380 PR c/60194
23381 * doc/invoke.texi (-Wformat-signedness): Document it.
23382 (Wformat=2): Mention that this enables -Wformat-signedness.
23383
23384 2014-04-11 Joern Rennecke <joern.rennecke@embecosm.com>
23385
23386 * common/config/epiphany/epiphany-common.c
23387 (epiphany_option_optimization_table): Enable section anchors by
23388 default at -O1 or higher.
23389 * config/epiphany/epiphany.c (TARGET_MAX_ANCHOR_OFFSET): Define.
23390 (TARGET_MIN_ANCHOR_OFFSET): Likewise.
23391 (epiphany_rtx_costs) <SET>: For binary operators, the set as such
23392 carries no extra cost.
23393 (epiphany_legitimate_address_p): For BLKmode, apply SImode check.
23394 * config/epiphany/epiphany.h (ASM_OUTPUT_DEF): Define.
23395 * config/epiphany/predicates.md (memclob_operand): New predicate.
23396 * config/epiphany/epiphany.md (stack_adjust_add, stack_adjust_str):
23397 Use memclob_operand predicate and X constraint for operand 3.
23398
23399 2014-04-11 Joern Rennecke <joern.rennecke@embecosm.com>
23400
23401 * config/epiphany/epiphany.c (epiphany_rtx_cost): Compare
23402 with CC_N_NE / CC_C_LTU / CC_C_GTU carries no extra cost for
23403 its operands.
23404
23405 2014-04-11 Joern Rennecke <joern.rennecke@embecosm.com>
23406
23407 PR rtl-optimization/60651
23408 * mode-switching.c (optimize_mode_switching): Make sure to emit
23409 sets of a lower numbered entity before sets of a higher numbered
23410 entity to a mode of the same or lower priority.
23411 When creating a seginfo for a basic block that starts with a code
23412 label, move the insertion point past the code label.
23413 (new_seginfo): Document and enforce requirement that
23414 NOTE_INSN_BASIC_BLOCK only appears for empty blocks.
23415 * doc/tm.texi.in: Document ordering constraint for emitted mode sets.
23416 * doc/tm.texi: Regenerate.
23417
23418 2014-01-11 Joern Rennecke <joern.rennecke@embecosm.com>
23419
23420 PR target/60811
23421 * config/arc/arc.c (arc_save_restore): Fix assert typo.
23422
23423 2013-04-11 Jakub Jelinek <jakub@redhat.com>
23424
23425 * BASE-VER: Set to 4.10.0.
23426
23427 2014-04-11 Tobias Burnus <burnus@net-b.de>
23428
23429 PR other/59055
23430 * doc/bugreport.texi (Bugs): Remove nodes pointing to the nirvana.
23431 * doc/gcc.texi (Service): Update description in the @menu
23432 * doc/invoke.texi (Option Summary): Remove misplaced and
23433 duplicated @menu.
23434
23435 2014-04-11 Steve Ellcey <sellcey@mips.com>
23436 Jakub Jelinek <jakub@redhat.com>
23437
23438 PR middle-end/60556
23439 * expr.c (convert_move): Use emit_store_flag_force instead of
23440 emit_store_flag. Pass lowpart_mode instead of VOIDmode as 5th
23441 argument to it.
23442
23443 2014-04-11 Richard Biener <rguenther@suse.de>
23444
23445 PR middle-end/60797
23446 * varasm.c (assemble_alias): Avoid endless error reporting
23447 recursion by setting TREE_ASM_WRITTEN.
23448
23449 2014-04-11 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
23450
23451 * config/s390/s390.md: Add a splitter for NOT rtx.
23452
23453 2014-04-11 Jakub Jelinek <jakub@redhat.com>
23454
23455 PR rtl-optimization/60663
23456 * cse.c (cse_insn): Set src_volatile on ASM_OPERANDS in PARALLEL.
23457
23458 2014-04-10 Jan Hubicka <hubicka@ucw.cz>
23459 Jakub Jelinek <jakub@redhat.com>
23460
23461 PR lto/60567
23462 * ipa.c (function_and_variable_visibility): Copy forced_by_abi
23463 flag from decl_node to node.
23464
23465 2014-04-10 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
23466
23467 PR debug/60655
23468 * config/arm/arm.c (TARGET_CONST_NOT_OK_FOR_DEBUG_P): Define
23469 (arm_const_not_ok_for_debug_p): Reject MINUS with SYM_REF's
23470 ameliorating the cases where it can be.
23471
23472 2014-04-09 David Edelsohn <dje.gcc@gmail.com>
23473
23474 Revert
23475 2014-04-08 Pat Haugen <pthaugen@us.ibm.com>
23476
23477 * config/rs6000/sync.md (AINT mode_iterator): Move definition.
23478 (loadsync_<mode>): Change mode.
23479 (load_quadpti, store_quadpti): New.
23480 (atomic_load<mode>, atomic_store<mode>): Add support for TI mode.
23481 * config/rs6000/rs6000.md (unspec enum): Add UNSPEC_LSQ.
23482 * config/rs6000/predicates.md (quad_memory_operand): !TARGET_SYNC_TI.
23483
23484 2014-04-09 Cong Hou <congh@google.com>
23485
23486 PR testsuite/60773
23487 * doc/sourcebuild.texi (vect_widen_mult_si_to_di_pattern): Add
23488 documentation.
23489
23490 2014-04-08 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
23491
23492 * config/rs6000/rs6000.c (rs6000_expand_vector_set): Use vnand
23493 instead of vnor to exploit possible fusion opportunity in the
23494 future.
23495 (altivec_expand_vec_perm_const_le): Likewise.
23496
23497 2014-04-08 Pat Haugen <pthaugen@us.ibm.com>
23498
23499 * config/rs6000/sync.md (AINT mode_iterator): Move definition.
23500 (loadsync_<mode>): Change mode.
23501 (load_quadpti, store_quadpti): New.
23502 (atomic_load<mode>, atomic_store<mode>): Add support for TI mode.
23503 * config/rs6000/rs6000.md (unspec enum): Add UNSPEC_LSQ.
23504
23505 2014-04-08 Richard Sandiford <rdsandiford@googlemail.com>
23506
23507 PR target/60763
23508 * config/rs6000/vsx.md (vsx_xscvdpspn_scalar): Change input to DImode.
23509 * config/rs6000/rs6000.md (reload_vsx_from_gprsf): Update accordingly.
23510 Use gen_rtx_REG rather than simplify_gen_subreg for op0_di.
23511
23512 2014-04-08 Richard Biener <rguenther@suse.de>
23513
23514 PR middle-end/60706
23515 * tree-pretty-print.c (pp_double_int): For HWI32 hosts with
23516 a 64bit widest int print double-int similar to on HWI64 hosts.
23517
23518 2014-04-08 Richard Biener <rguenther@suse.de>
23519
23520 PR tree-optimization/60785
23521 * graphite-sese-to-poly.c (rewrite_phi_out_of_ssa): Treat
23522 default defs properly.
23523
23524 2014-04-08 Nathan Sidwell <nathan@codesourcery.com>
23525
23526 * doc/invoke (Wnon-virtual-dtor): Update to match implementation.
23527 (Weffc++): Likewise.
23528
23529 2014-04-07 Jan Hubicka <hubcika@ucw.cz>
23530
23531 * ipa-devirt.c (maybe_record_node): When node is not recorded,
23532 set completep to false rather than true.
23533
23534 2014-04-07 Douglas B Rupp <rupp@adacore.com>
23535
23536 PR target/60504
23537 * config/arm/arm.h (ASM_PREFERRED_EH_DATA_FORMAT): Expose from
23538 ARM_TARGET2_DWARF_FORMAT.
23539
23540 2014-04-07 Charles Baylis <charles.baylis@linaro.org>
23541
23542 PR target/60609
23543 * config/arm/arm.h (ASM_OUTPUT_CASE_END): Remove.
23544 (LABEL_ALIGN_AFTER_BARRIER): Align barriers which occur after
23545 ADDR_DIFF_VEC.
23546
23547 2014-04-07 Richard Biener <rguenther@suse.de>
23548
23549 PR tree-optimization/60766
23550 * tree-ssa-loop-ivopts.c (cand_value_at): Compute in an unsigned type.
23551 (may_eliminate_iv): Convert cand_value_at result to desired type.
23552
23553 2014-04-07 Jason Merrill <jason@redhat.com>
23554
23555 PR c++/60731
23556 * common.opt (-fno-gnu-unique): Add.
23557 * config/elfos.h (USE_GNU_UNIQUE_OBJECT): Check it.
23558
23559 2014-04-07 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
23560
23561 * haifa-sched.c: Fix outdated function reference and minor
23562 grammar errors in introductory comment.
23563
23564 2014-04-07 Richard Biener <rguenther@suse.de>
23565
23566 PR middle-end/60750
23567 * tree-ssa-operands.c (maybe_add_call_vops): Also add VDEFs
23568 for noreturn calls.
23569 * tree-cfgcleanup.c (fixup_noreturn_call): Do not remove VDEFs.
23570
23571 2014-04-06 John David Anglin <danglin@gcc.gnu.org>
23572
23573 PR debug/55794
23574 * config/pa/pa.c (pa_output_function_epilogue): Skip address and code
23575 size accounting for thunks.
23576 (pa_asm_output_mi_thunk): Use final_start_function() and
23577 final_end_function() to output function start and end directives.
23578
23579 2014-04-05 Pitchumani Sivanupandi <Pitchumani.S@atmel.com>
23580
23581 * config/avr/avr-arch.h (avr_mcu_t): Add dev_attribute field to have
23582 device specific ISA/ feature information. Remove short_sp and
23583 errata_skip ds. Add avr_device_specific_features enum to have device
23584 specific info.
23585 * config/avr/avr-c.c (avr_cpu_cpp_builtins): use dev_attribute to check
23586 errata_skip. Add __AVR_ISA_RMW__ builtin macro if RMW ISA available.
23587 * config/avr/avr-devices.c (avr_mcu_types): Update AVR_MCU macro for
23588 updated device specific info.
23589 * config/avr/avr-mcus.def: Merge device specific details to
23590 dev_attribute field.
23591 * config/avr/avr.c (avr_2word_insn_p): use dev_attribute field to check
23592 errata_skip.
23593 * config/avr/avr.h (AVR_HAVE_8BIT_SP): same for short sp info.
23594 * config/avr/driver-avr.c (avr_device_to_as): Pass -mrmw option to
23595 assembler if RMW isa supported by current device.
23596 * config/avr/genmultilib.awk: Update as device info structure changed.
23597 * doc/invoke.texi: Add info for __AVR_ISA_RMW__ builtin macro
23598
23599 2014-04-04 Cong Hou <congh@google.com>
23600
23601 PR tree-optimization/60656
23602 * tree-vect-stmts.c (supportable_widening_operation):
23603 Fix a bug that elements in a vector with vect_used_by_reduction
23604 property are incorrectly reordered when the operation on it is not
23605 consistant with the one in reduction operation.
23606
23607 2014-04-04 John David Anglin <danglin@gcc.gnu.org>
23608
23609 PR rtl-optimization/60155
23610 * gcse.c (record_set_data): New function.
23611 (single_set_gcse): New function.
23612 (gcse_emit_move_after): Use single_set_gcse instead of single_set.
23613 (hoist_code): Likewise.
23614 (get_pressure_class_and_nregs): Likewise.
23615
23616 2014-04-04 Eric Botcazou <ebotcazou@adacore.com>
23617
23618 * explow.c (probe_stack_range): Emit a final optimization blockage.
23619
23620 2014-04-04 Anthony Green <green@moxielogic.com>
23621
23622 * config/moxie/moxie.md (zero_extendqisi2, zero_extendhisi2): Fix
23623 typos.
23624
23625 2014-04-04 Jan Hubicka <hubicka@ucw.cz>
23626
23627 PR ipa/59626
23628 * lto-cgraph.c (input_overwrite_node): Check that partitioning
23629 flags are set only during streaming.
23630 * ipa.c (process_references, walk_polymorphic_call_targets,
23631 symtab_remove_unreachable_nodes): Drop bodies of always inline
23632 after early inlining.
23633 (symtab_remove_unreachable_nodes): Remove always_inline attribute.
23634
23635 2014-04-04 Jakub Jelinek <jakub@redhat.com>
23636 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
23637
23638 PR debug/60655
23639 * dwarf2out.c (const_ok_for_output_1): Reject expressions
23640 containing a NOT.
23641
23642 2014-04-04 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
23643
23644 PR bootstrap/60743
23645 * config/arm/cortex-a53.md (cortex_a53_fdivs): Reduce reservation
23646 duration.
23647 (cortex_a53_fdivd): Likewise.
23648
23649 2014-04-04 Martin Jambor <mjambor@suse.cz>
23650
23651 PR ipa/60640
23652 * cgraph.h (cgraph_clone_node): New parameter added to declaration.
23653 Adjust all callers.
23654 * cgraph.c (clone_of_p): Also return true if thunks match.
23655 (verify_edge_corresponds_to_fndecl): Removed extraneous call to
23656 cgraph_function_or_thunk_node and an obsolete comment.
23657 * cgraphclones.c (build_function_type_skip_args): Moved upwards in the
23658 file.
23659 (build_function_decl_skip_args): Likewise.
23660 (set_new_clone_decl_and_node_flags): New function.
23661 (duplicate_thunk_for_node): Likewise.
23662 (redirect_edge_duplicating_thunks): Likewise.
23663 (cgraph_clone_node): New parameter args_to_skip, pass it to
23664 redirect_edge_duplicating_thunks which is called instead of
23665 cgraph_redirect_edge_callee.
23666 (cgraph_create_virtual_clone): Pass args_to_skip to cgraph_clone_node,
23667 moved setting of a lot of flags to set_new_clone_decl_and_node_flags.
23668
23669 2014-04-04 Jeff Law <law@redhat.com>
23670
23671 PR target/60657
23672 * config/arm/predicates.md (const_int_I_operand): New predicate.
23673 (const_int_M_operand): Similarly.
23674 * config/arm/arm.md (insv_zero): Use const_int_M_operand instead of
23675 const_int_operand.
23676 (insv_t2, extv_reg, extzv_t2): Likewise.
23677 (load_multiple_with_writeback): Similarly for const_int_I_operand.
23678 (pop_multiple_with_writeback_and_return): Likewise.
23679 (vfp_pop_multiple_with_writeback): Likewise
23680
23681 2014-04-04 Richard Biener <rguenther@suse.de>
23682
23683 PR ipa/60746
23684 * tree-ssanames.c (make_ssa_name_fn): Fix assert.
23685 * gimple.c (gimple_set_bb): Avoid ICEing for NULL cfun for
23686 non-GIMPLE_LABELs.
23687 * gimplify.h (gimple_add_tmp_var_fn): Declare.
23688 * gimplify.c (gimple_add_tmp_var_fn): New function.
23689 * gimple-expr.h (create_tmp_reg_fn): Declare.
23690 * gimple-expr.c (create_tmp_reg_fn): New function.
23691 * gimple-low.c (record_vars_into): Don't change cfun.
23692 * cgraph.c (cgraph_redirect_edge_call_stmt_to_callee): Fix
23693 code generation without cfun.
23694
23695 2014-04-04 Thomas Schwinge <thomas@codesourcery.com>
23696
23697 PR bootstrap/60719
23698 * Makefile.in (install-driver): Fix shell scripting.
23699
23700 2014-04-03 Cong Hou <congh@google.com>
23701
23702 PR tree-optimization/60505
23703 * tree-vectorizer.h (struct _stmt_vec_info): Add th field as the
23704 threshold of number of iterations below which no vectorization
23705 will be done.
23706 * tree-vect-loop.c (new_loop_vec_info):
23707 Initialize LOOP_VINFO_COST_MODEL_THRESHOLD.
23708 * tree-vect-loop.c (vect_analyze_loop_operations):
23709 Set LOOP_VINFO_COST_MODEL_THRESHOLD.
23710 * tree-vect-loop.c (vect_transform_loop):
23711 Use LOOP_VINFO_COST_MODEL_THRESHOLD.
23712 * tree-vect-loop.c (vect_analyze_loop_2): Check the maximum number
23713 of iterations of the loop and see if we should build the epilogue.
23714
23715 2014-04-03 Richard Biener <rguenther@suse.de>
23716
23717 * tree-streamer.h (struct streamer_tree_cache_d): Add next_idx member.
23718 (streamer_tree_cache_create): Adjust.
23719 * tree-streamer.c (streamer_tree_cache_add_to_node_array): Adjust
23720 to allow optional nodes array.
23721 (streamer_tree_cache_insert_1): Use next_idx to assign idx.
23722 (streamer_tree_cache_append): Likewise.
23723 (streamer_tree_cache_create): Create nodes array optionally
23724 as specified by parameter.
23725 * lto-streamer-out.c (create_output_block): Avoid maintaining
23726 the node array in the writer cache.
23727 (DFS_write_tree): Remove assertion.
23728 (produce_asm_for_decls): Free the out decl state hash table early.
23729 * lto-streamer-in.c (lto_data_in_create): Adjust for
23730 streamer_tree_cache_create prototype change.
23731
23732 2014-04-03 Richard Biener <rguenther@suse.de>
23733
23734 * tree-streamer-out.c (streamer_write_chain): Do not temporarily
23735 set TREE_CHAIN to NULL_TREE.
23736
23737 2014-04-03 Richard Biener <rguenther@suse.de>
23738
23739 PR tree-optimization/60740
23740 * graphite-scop-detection.c (stmt_simple_for_scop_p): Iterate
23741 over all GIMPLE_COND operands.
23742
23743 2014-04-03 Nathan Sidwell <nathan@codesourcery.com>
23744
23745 * doc/invoke.texi (Wnon-virtual-dtor): Adjust documentation.
23746 (Weffc++): Remove Scott's numbering, merge lists and reference
23747 Wnon-virtual-dtor.
23748
23749 2014-04-03 Nick Clifton <nickc@redhat.com>
23750
23751 * config/rl78/rl78-expand.md (movqi): Handle (SUBREG (SYMBOL_REF))
23752 properly.
23753
23754 2014-04-03 Martin Jambor <mjambor@suse.cz>
23755
23756 * ipa-cp.c (ipcp_verify_propagated_values): Also dump symtab and
23757 mention gcc_unreachable before failing.
23758 * ipa.c (symtab_remove_unreachable_nodes): Also print order of
23759 removed symbols.
23760
23761 2014-04-02 Jan Hubicka <hubicka@ucw.cz>
23762
23763 PR ipa/60659
23764 * ipa-devirt.c (get_polymorphic_call_info): Do not ICE on type
23765 inconsistent code and instead mark the context inconsistent.
23766 (possible_polymorphic_call_targets): For inconsistent contexts
23767 return empty complete list.
23768
23769 2014-04-02 Anthony Green <green@moxielogic.com>
23770
23771 * config/moxie/moxie.md (zero_extendqisi2, zero_extendhisi2)
23772 (extendqisi2, extendhisi2): Define.
23773 * config/moxie/moxie.h (DEFAULT_SIGNED_CHAR): Change to 0.
23774 (WCHAR_TYPE): Change to unsigned int.
23775
23776 2014-04-02 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
23777
23778 PR tree-optimization/60733
23779 * gimple-ssa-strength-reduction.c (ncd_with_phi): Change required
23780 insertion point for PHI candidates to be the end of the feeding
23781 block for the PHI argument.
23782
23783 2014-04-02 Vladimir Makarov <vmakarov@redhat.com>
23784
23785 PR rtl-optimization/60650
23786 * lra-constraints.c (process_alt_operands): Decrease reject for
23787 earlyclobber matching.
23788
23789 2014-04-02 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
23790
23791 * config/s390/s390.c (s390_expand_insv): Use GET_MODE_BITSIZE.
23792
23793 2014-04-02 Ulrich Weigand <Ulrich.Weigand@de.ibm.com>
23794
23795 * config/spu/spu.c (pad_bb): Do not crash when the last
23796 insn is CODE_FOR_blockage.
23797
23798 2014-04-02 Ulrich Weigand <Ulrich.Weigand@de.ibm.com>
23799
23800 * config/spu/spu.md ("insv"): Fail if bitoffset+bitsize
23801 lies outside the target mode.
23802
23803 2014-04-02 Michael Meissner <meissner@linux.vnet.ibm.com>
23804
23805 PR target/60735
23806 * config/rs6000/rs6000.c (rs6000_hard_regno_mode_ok): If we have
23807 software floating point or no floating point registers, do not
23808 allow any type in the FPRs. Eliminate a test for SPE SIMD types
23809 in GPRs that occurs after we tested for GPRs that would never be
23810 true.
23811
23812 * config/rs6000/rs6000.md (mov<mode>_softfloat32, FMOVE64):
23813 Rewrite tests to use TARGET_DOUBLE_FLOAT and TARGET_E500_DOUBLE,
23814 since the FMOVE64 type is DFmode/DDmode. If TARGET_E500_DOUBLE,
23815 specifically allow DDmode, since that does not use the SPE SIMD
23816 instructions.
23817
23818 2014-04-02 Richard Biener <rguenther@suse.de>
23819
23820 PR middle-end/60729
23821 * optabs.c (expand_abs_nojump): Honor flag_trapv only for
23822 MODE_INTs. Properly use negv_optab.
23823 (expand_abs): Likewise.
23824
23825 2014-04-02 Richard Biener <rguenther@suse.de>
23826
23827 PR bootstrap/60719
23828 * Makefile.in (install-driver): Guard extra installs with special
23829 names properly.
23830
23831 2014-04-01 Michael Meissner <meissner@linux.vnet.ibm.com>
23832
23833 * doc/extend.texi (PowerPC AltiVec/VSX Built-in Functions):
23834 Document vec_vgbbd.
23835
23836 2014-04-01 Richard Henderson <rth@redhat.com>
23837
23838 PR target/60704
23839 * config/i386/i386.md (*float<SWI48><MODEF>2_sse): Leave the second
23840 alternative enabled before register allocation.
23841
23842 2014-04-01 Chung-Lin Tang <cltang@codesourcery.com>
23843
23844 * config/nios2/nios2.md (unspec): Remove UNSPEC_TLS, UNSPEC_TLS_LDM.
23845 * config/nios2/nios2.c (nios2_function_profiler): Fix addi operand
23846 typo.
23847 (nios2_large_got_address): Remove unneeded 'sym' parameter.
23848 (nios2_got_address): Update nios2_large_got_address call site.
23849 (nios2_delegitimize_address): New function.
23850 (TARGET_DELEGITIMIZE_ADDRESS): Define to nios2_delegitimize_address.
23851 * config/nios2/linux.h (GLIBC_DYNAMIC_LINKER): Define.
23852 (LINK_SPEC): Specify dynamic linker using GNU_USER_DYNAMIC_LINKER.
23853
23854 2014-04-01 Martin Husemann <martin@duskware.de>
23855
23856 * config/mips/netbsd.h (TARGET_OS_CPP_BUILTINS): Define __mips_o32
23857 for -mabi=32.
23858
23859 2014-04-01 Richard Sandiford <rdsandiford@googlemail.com>
23860
23861 PR rtl-optimization/60604
23862 * recog.c (general_operand): Incorporate REG_CANNOT_CHANGE_MODE_P
23863 check from register_operand.
23864 (register_operand): Redefine in terms of general_operand.
23865 (nonmemory_operand): Use register_operand for the non-constant cases.
23866
23867 2014-04-01 Richard Biener <rguenther@suse.de>
23868
23869 * gimple.h (struct gimple_statement_base): Align subcode to 16 bits.
23870
23871 2014-04-01 Sebastian Huber <sebastian.huber@embedded-brains.de>
23872
23873 * doc/invoke.texi (mapp-regs): Clarify.
23874
23875 2014-03-31 Ulrich Drepper <drepper@gmail.com>
23876
23877 * config/i386/avx512fintrin.h (__v32hi): Define type.
23878 (__v64qi): Likewise.
23879 (_mm512_set1_epi8): Define.
23880 (_mm512_set1_epi16): Define.
23881 (_mm512_set4_epi32): Define.
23882 (_mm512_set4_epi64): Define.
23883 (_mm512_set4_pd): Define.
23884 (_mm512_set4_ps): Define.
23885 (_mm512_setr4_epi64): Define.
23886 (_mm512_setr4_epi32): Define.
23887 (_mm512_setr4_pd): Define.
23888 (_mm512_setr4_ps): Define.
23889 (_mm512_setzero_epi32): Define.
23890
23891 2014-03-31 Martin Jambor <mjambor@suse.cz>
23892
23893 PR middle-end/60647
23894 * tree-sra.c (callsite_has_enough_arguments_p): Renamed to
23895 callsite_arguments_match_p. Updated all callers. Also check types of
23896 corresponding formal parameters and actual arguments.
23897 (not_all_callers_have_enough_arguments_p) Renamed to
23898 some_callers_have_mismatched_arguments_p.
23899
23900 2014-03-31 Yuri Rumyantsev <ysrumyan@gmail.com>
23901
23902 * tree-inline.c (copy_loops): Add missed copy of 'safelen'.
23903
23904 2014-03-31 Kugan Vivekanandarajah <kuganv@linaro.org>
23905
23906 PR target/60034
23907 * aarch64/aarch64.c (aarch64_classify_address): Fix alignment for
23908 section anchor.
23909
23910 2014-03-30 Uros Bizjak <ubizjak@gmail.com>
23911
23912 * config/i386/sse.md (FMAMODE_NOVF512): New mode iterator.
23913 (<sd_mask_codefor>fma_fmadd_<mode><sd_maskz_name><round_name>):
23914 Split out
23915 <sd_mask_codefor>fma_fmadd_<VF_512:mode><sd_maskz_name><round_name>.
23916 Use FMAMODE_NOVF512 mode iterator.
23917 (<sd_mask_codefor>fma_fmsub_<mode><sd_maskz_name><round_name>): Ditto.
23918 (<sd_mask_codefor>fma_fnmadd_<mode><sd_maskz_name><round_name>): Ditto.
23919 (<sd_mask_codefor>fma_fnmsub_<mode><sd_maskz_name><round_name>): Ditto.
23920 (<sd_mask_codefor>fma_fmaddsub_<mode><sd_maskz_name><round_name>):
23921 Split out
23922 <sd_mask_codefor>fma_fmaddsub_<VF_512:mode><sd_maskz_name><round_name>.
23923 Use VF_128_256 mode iterator.
23924 (<sd_mask_codefor>fma_fmsubadd_<mode><sd_maskz_name><round_name>):
23925 Ditto.
23926
23927 2014-03-28 Jan Hubicka <hubicka@ucw.cz>
23928
23929 * cgraph.c (cgraph_redirect_edge_call_stmt_to_callee): Clear
23930 static chain if needed.
23931
23932 2014-03-28 Vladimir Makarov <vmakarov@redhat.com>
23933
23934 PR target/60697
23935 * lra-constraints.c (index_part_to_reg): New.
23936 (process_address): Use it.
23937
23938 2014-03-27 Jeff Law <law@redhat.com>
23939 Jakub Jelinek <jakub@redhat.com>
23940
23941 PR target/60648
23942 * expr.c (do_tablejump): Use simplify_gen_binary rather than
23943 gen_rtx_{PLUS,MULT} to build up the address expression.
23944
23945 * i386/i386.c (ix86_legitimize_address): Use copy_addr_to_reg to avoid
23946 creating non-canonical RTL.
23947
23948 2014-03-28 Jan Hubicka <hubicka@ucw.cz>
23949
23950 PR ipa/60243
23951 * ipa-inline.c (want_inline_small_function_p): Short circuit large
23952 functions; reorganize to make cheap checks first.
23953 (inline_small_functions): Do not estimate growth when dumping;
23954 it is expensive.
23955 * ipa-inline.h (inline_summary): Add min_size.
23956 (growth_likely_positive): New function.
23957 * ipa-inline-analysis.c (dump_inline_summary): Add min_size.
23958 (set_cond_stmt_execution_predicate): Cleanup.
23959 (estimate_edge_size_and_time): Compute min_size.
23960 (estimate_calls_size_and_time): Likewise.
23961 (estimate_node_size_and_time): Likewise.
23962 (inline_update_overall_summary): Update min_size.
23963 (do_estimate_edge_time): Likewise.
23964 (do_estimate_edge_size): Update.
23965 (do_estimate_edge_hints): Update.
23966 (growth_likely_positive): New function.
23967
23968 2014-03-28 Jakub Jelinek <jakub@redhat.com>
23969
23970 PR target/60693
23971 * config/i386/i386.c (ix86_copy_addr_to_reg): Call copy_addr_to_reg
23972 also if addr has VOIDmode.
23973
23974 2014-03-28 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
23975
23976 * config/arm/aarch-common.c (aarch_crypto_can_dual_issue): New.
23977 * config/arm/aarch-common-protos.h (aarch_crypto_can_dual_issue):
23978 Declare extern.
23979 * config/arm/cortex-a53.md: Add reservations and bypass for crypto
23980 instructions as well as AdvancedSIMD loads.
23981
23982 2014-03-28 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
23983
23984 * config/aarch64/aarch64-simd.md (aarch64_crypto_aes<aes_op>v16qi):
23985 Use crypto_aese type.
23986 (aarch64_crypto_aes<aesmc_op>v16qi): Use crypto_aesmc type.
23987 * config/arm/arm.md (is_neon_type): Replace crypto_aes with
23988 crypto_aese, crypto_aesmc. Move to types.md.
23989 * config/arm/types.md (crypto_aes): Split into crypto_aese,
23990 crypto_aesmc.
23991 * config/arm/iterators.md (crypto_type): Likewise.
23992
23993 2014-03-28 Jan Hubicka <hubicka@ucw.cz>
23994
23995 * cgraph.c: Include expr.h and tree-dfa.h.
23996 (cgraph_redirect_edge_call_stmt_to_callee): If call in noreturn;
23997 remove LHS.
23998
23999 2014-03-28 Vladimir Makarov <vmakarov@redhat.com>
24000
24001 PR target/60675
24002 * lra-assigns.c (find_hard_regno_for): Remove unavailable hard
24003 regs from checking multi-reg pseudos.
24004
24005 2014-03-28 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
24006
24007 * config/arm/t-aprofile (MULTILIB_MATCHES): Correct A12 rule.
24008
24009 2014-03-28 Ulrich Weigand <Ulrich.Weigand@de.ibm.com>
24010
24011 * config/rs6000/rs6000.c (fusion_gpr_load_p): Refuse optimization
24012 if it would clobber the stack pointer, even temporarily.
24013
24014 2014-03-28 Eric Botcazou <ebotcazou@adacore.com>
24015
24016 * mode-switching.c: Make small adjustments to the top comment.
24017
24018 2014-03-27 Michael Meissner <meissner@linux.vnet.ibm.com>
24019
24020 * config/rs6000/constraints.md (wD constraint): New constraint to
24021 match the constant integer to get the top DImode/DFmode out of a
24022 vector in a VSX register.
24023
24024 * config/rs6000/predicates.md (vsx_scalar_64bit): New predicate to
24025 match the constant integer to get the top DImode/DFmode out of a
24026 vector in a VSX register.
24027
24028 * config/rs6000/rs6000-builtins.def (VBPERMQ): Add vbpermq builtin
24029 for ISA 2.07.
24030
24031 * config/rs6000/rs6000-c.c (altivec_overloaded_builtins): Add
24032 vbpermq builtins.
24033
24034 * config/rs6000/rs6000.c (rs6000_debug_reg_global): If
24035 -mdebug=reg, print value of VECTOR_ELEMENT_SCALAR_64BIT.
24036
24037 * config/rs6000/vsx.md (vsx_extract_<mode>, V2DI/V2DF modes):
24038 Optimize vec_extract of 64-bit values, where the value being
24039 extracted is in the top word, where we can use scalar
24040 instructions. Add direct move and store support. Combine the big
24041 endian/little endian vector select load support into a single insn.
24042 (vsx_extract_<mode>_internal1): Likewise.
24043 (vsx_extract_<mode>_internal2): Likewise.
24044 (vsx_extract_<mode>_load): Likewise.
24045 (vsx_extract_<mode>_store): Likewise.
24046 (vsx_extract_<mode>_zero): Delete, big and little endian insns are
24047 combined into vsx_extract_<mode>_load.
24048 (vsx_extract_<mode>_one_le): Likewise.
24049
24050 * config/rs6000/rs6000.h (VECTOR_ELEMENT_SCALAR_64BIT): Macro to
24051 define the top 64-bit vector element.
24052
24053 * doc/md.texi (PowerPC and IBM RS6000 constraints): Document wD
24054 constraint.
24055
24056 * doc/extend.texi (PowerPC AltiVec/VSX Built-in Functions):
24057 Document vec_vbpermq builtin.
24058
24059 PR target/60672
24060 * config/rs6000/altivec.h (vec_xxsldwi): Add missing define to
24061 enable use of xxsldwi and xxpermdi builtin functions.
24062 (vec_xxpermdi): Likewise.
24063
24064 * doc/extend.texi (PowerPC AltiVec/VSX Built-in Functions):
24065 Document use of vec_xxsldwi and vec_xxpermdi builtins.
24066
24067 2014-03-27 Vladimir Makarov <vmakarov@redhat.com>
24068
24069 PR rtl-optimization/60650
24070 * lra-assign.c (find_hard_regno_for, spill_for): Add parameter
24071 first_p. Use it.
24072 (find_spills_for): New.
24073 (assign_by_spills): Pass the new parameter to find_hard_regno_for.
24074 Spill all pseudos on the second iteration.
24075
24076 2014-03-27 Marek Polacek <polacek@redhat.com>
24077
24078 PR c/50347
24079 * doc/extend.texi (ffs Builtins): Change unsigned types to signed
24080 types.
24081
24082 2014-03-27 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
24083
24084 * config/s390/s390.c (s390_can_use_return_insn): Check for
24085 call-saved FPRs on 31 bit.
24086
24087 2014-03-27 Jakub Jelinek <jakub@redhat.com>
24088
24089 PR middle-end/60682
24090 * omp-low.c (lower_omp_1): For gimple_clobber_p stmts,
24091 if they need regimplification, just drop them instead of
24092 calling gimple_regimplify_operands on them.
24093
24094 2014-03-27 Marcus Shawcroft <marcus.shawcroft@arm.com>
24095
24096 PR target/60580
24097 * config/aarch64/aarch64.c (faked_omit_frame_pointer): Remove.
24098 (aarch64_frame_pointer_required): Adjust logic.
24099 (aarch64_can_eliminate): Adjust logic.
24100 (aarch64_override_options_after_change): Adjust logic.
24101
24102 2014-03-27 Dehao Chen <dehao@google.com>
24103
24104 * ipa-inline.c (early_inliner): Update node's inline info.
24105
24106 2014-03-26 Dehao Chen <dehao@google.com>
24107
24108 * dojump.c (do_compare_rtx_and_jump): Sets correct probability for
24109 compiler inserted conditional jumps for NAN float check.
24110
24111 2014-03-26 Jakub Jelinek <jakub@redhat.com>
24112
24113 * ubsan.h (ubsan_create_data): Change second argument's type
24114 to const location_t *.
24115 * ubsan.c (ubsan_source_location): If xloc.file is NULL, set it to
24116 _("<unknown>").
24117 (ubsan_create_data): Change second argument to const location_t *PLOC.
24118 Create Loc field whenever PLOC is non-NULL.
24119 (ubsan_instrument_unreachable, ubsan_expand_null_ifn,
24120 ubsan_build_overflow_builtin, instrument_bool_enum_load): Adjust
24121 callers.
24122
24123 PR other/59545
24124 * real.c (real_to_integer2): Change type of low to UHWI.
24125
24126 2014-03-26 Tobias Burnus <burnus@net-b.de>
24127
24128 * gcc.c (LINK_COMMAND_SPEC): Use libcilkrts.spec for -fcilkplus.
24129 (CILK_SELF_SPECS): New define.
24130 (driver_self_specs): Use it.
24131
24132 2014-03-26 Richard Biener <rguenther@suse.de>
24133
24134 * tree-pretty-print.c (percent_K_format): Implement special
24135 case for LTO and its stripped down BLOCK tree.
24136
24137 2014-03-26 Jakub Jelinek <jakub@redhat.com>
24138
24139 PR sanitizer/60636
24140 * ubsan.c (instrument_si_overflow): Instrument ABS_EXPR.
24141
24142 * tree-vrp.c (simplify_internal_call_using_ranges): If only
24143 one range is range_int_cst_p, but not both, at least optimize
24144 addition/subtraction of 0 and multiplication by 0 or 1.
24145 * gimple-fold.c (gimple_fold_call): Fold
24146 IFN_UBSAN_CHECK_{ADD,SUB,MUL}.
24147 (gimple_fold_stmt_to_constant_1): If both op0 and op1 aren't
24148 INTEGER_CSTs, try to fold at least x * 0 and y - y.
24149
24150 2014-03-26 Eric Botcazou <ebotcazou@adacore.com>
24151
24152 PR rtl-optimization/60452
24153 * rtlanal.c (rtx_addr_can_trap_p_1): Fix head comment.
24154 <case REG>: Return 1 for invalid offsets from the frame pointer.
24155
24156 2014-03-26 Marek Polacek <polacek@redhat.com>
24157
24158 PR c/37428
24159 * doc/extend.texi (C Extensions): Mention variable-length arrays in
24160 a structure/union.
24161
24162 2014-03-26 Marek Polacek <polacek@redhat.com>
24163
24164 PR c/39525
24165 * doc/extend.texi (Designated Inits): Describe what happens to omitted
24166 field members.
24167
24168 2014-03-26 Marek Polacek <polacek@redhat.com>
24169
24170 PR other/59545
24171 * ira-color.c (update_conflict_hard_regno_costs): Perform the
24172 multiplication in unsigned type.
24173
24174 2014-03-26 Chung-Ju Wu <jasonwucj@gmail.com>
24175
24176 * doc/install.texi: Document nds32le-*-elf and nds32be-*-elf.
24177
24178 2014-03-26 Chung-Ju Wu <jasonwucj@gmail.com>
24179
24180 * doc/contrib.texi: Add myself as Andes nds32 port contributor.
24181
24182 2014-03-25 Jan Hubicka <hubicka@ucw.cz>
24183
24184 PR ipa/60315
24185 * cif-code.def (UNREACHABLE) New code.
24186 * ipa-inline.c (inline_small_functions): Skip edges to
24187 __builtlin_unreachable.
24188 (estimate_edge_growth): Allow edges to __builtlin_unreachable.
24189 * ipa-inline-analysis.c (edge_set_predicate): Redirect edges with false
24190 predicate to __bulitin_unreachable.
24191 (set_cond_stmt_execution_predicate): Fix issue when
24192 invert_tree_comparison returns ERROR_MARK.
24193 * ipa-pure-const.c (propagate_pure_const, propagate_nothrow): Do not
24194 propagate to inline clones.
24195 * cgraph.c (verify_edge_corresponds_to_fndecl): Allow redirection
24196 to unreachable.
24197 * ipa-cp.c (create_specialized_node): Be ready for new node to appear.
24198 * cgraphclones.c (cgraph_clone_node): If call destination is already
24199 ureachable, do not redirect it back.
24200 * tree-inline.c (fold_marked_statements): Hanlde calls becoming
24201 unreachable.
24202
24203 2014-03-25 Jan Hubicka <hubicka@ucw.cz>
24204
24205 * ipa-pure-const.c (propagate_pure_const, propagate_nothrow):
24206 Do not modify inline clones.
24207
24208 2014-03-25 Jakub Jelinek <jakub@redhat.com>
24209
24210 * config/i386/i386.md (general_sext_operand): New mode attr.
24211 (addv<mode>4, subv<mode>4, mulv<mode>4): If operands[2] is CONST_INT,
24212 don't generate (sign_extend (const_int)).
24213 (*addv<mode>4, *subv<mode>4, *mulv<mode>4): Disallow CONST_INT_P
24214 operands[2]. Use We constraint instead of <i> and
24215 <general_sext_operand> predicate instead of <general_operand>.
24216 (*addv<mode>4_1, *subv<mode>4_1, *mulv<mode>4_1): New insns.
24217 * config/i386/constraints.md (We): New constraint.
24218 * config/i386/predicates.md (x86_64_sext_operand,
24219 sext_operand): New predicates.
24220
24221 2014-03-25 Martin Jambor <mjambor@suse.cz>
24222
24223 PR ipa/60600
24224 * ipa-cp.c (ipa_get_indirect_edge_target_1): Redirect type
24225 inconsistent devirtualizations to __builtin_unreachable.
24226
24227 2014-03-25 Marek Polacek <polacek@redhat.com>
24228
24229 PR c/35449
24230 * doc/extend.texi (Example of asm with clobbered asm reg): Fix typo.
24231
24232 2014-03-25 Alan Lawrence <alan.lawrence@arm.com>
24233
24234 * config/aarch64/aarch64.c (aarch64_simd_valid_immediate): Reverse
24235 order of elements for big-endian.
24236
24237 2014-03-25 Richard Biener <rguenther@suse.de>
24238
24239 PR middle-end/60635
24240 * gimplify-me.c (gimple_regimplify_operands): Update the
24241 re-gimplifed stmt.
24242
24243 2014-03-25 Martin Jambor <mjambor@suse.cz>
24244
24245 PR ipa/59176
24246 * lto-cgraph.c (lto_output_node): Stream body_removed flag.
24247 (lto_output_varpool_node): Likewise.
24248 (input_overwrite_node): Likewise.
24249 (input_varpool_node): Likewise.
24250
24251 2014-03-25 Richard Biener <rguenther@suse.de>
24252
24253 * lto-wrapper.c (merge_and_complain): Handle OPT_fPIE like OPT_fpie.
24254 (run_gcc): Likewise.
24255
24256 2014-03-25 Jakub Jelinek <jakub@redhat.com>
24257
24258 * combine.c (simplify_compare_const): Add MODE argument.
24259 Handle mode_width 0 as very large mode_width.
24260 (try_combine, simplify_comparison): Adjust callers.
24261
24262 * cselib.c (cselib_hash_rtx): Perform addition in unsigned
24263 type to avoid signed integer overflow.
24264 * explow.c (plus_constant): Likewise.
24265
24266 2014-03-25 Dominik Vogt <vogt@linux.vnet.ibm.com>
24267
24268 * doc/generic.texi: Correct typos.
24269
24270 2014-03-24 Tobias Burnus <burnus@net-b.de>
24271
24272 * doc/invoke.texi (-flto): Expand section about
24273 using static libraries with LTO.
24274
24275 2014-03-24 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
24276
24277 PR rtl-optimization/60501
24278 * optabs.def (addptr3_optab): New optab.
24279 * optabs.c (gen_addptr3_insn, have_addptr3_insn): New function.
24280 * doc/md.texi ("addptrm3"): Document new RTL standard expander.
24281 * expr.h (gen_addptr3_insn, have_addptr3_insn): Add prototypes.
24282
24283 * lra.c (emit_add3_insn): Use the addptr pattern if available.
24284
24285 * config/s390/s390.md ("addptrdi3", "addptrsi3"): New expanders.
24286
24287 2014-03-24 Ulrich Drepper <drepper@gmail.com>
24288
24289 * config/i386/avx512fintrin.h: Define _mm512_set1_ps and
24290 _mm512_set1_pd.
24291
24292 * config/i386/avxintrin.h (_mm256_undefined_si256): Define.
24293 (_mm256_undefined_ps): Define.
24294 (_mm256_undefined_pd): Define.
24295 * config/i386/emmintrin.h (_mm_undefined_si128): Define.
24296 (_mm_undefined_pd): Define.
24297 * config/i386/xmmintrin.h (_mm_undefined_ps): Define.
24298 * config/i386/avx512fintrin.h (_mm512_undefined_si512): Define.
24299 (_mm512_undefined_ps): Define.
24300 (_mm512_undefined_pd): Define.
24301 Use _mm*_undefined_*.
24302 * config/i386/avx2intrin.h: Use _mm*_undefined_*.
24303
24304 2014-03-24 Alex Velenko <Alex.Velenko@arm.com>
24305
24306 * config/aarch64/aarch64-simd-builtins.def (lshr): DI mode excluded.
24307 (lshr_simd): DI mode added.
24308 * config/aarch64/aarch64-simd.md (aarch64_lshr_simddi): New pattern.
24309 (aarch64_ushr_simddi): Likewise.
24310 * config/aarch64/aarch64.md (UNSPEC_USHR64): New unspec.
24311 * config/aarch64/arm_neon.h (vshr_n_u64): Intrinsic fixed.
24312 (vshrd_n_u64): Likewise.
24313
24314 2014-03-24 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
24315
24316 * Makefile.in (s-macro_list): Depend on cc1.
24317
24318 2014-03-23 Teresa Johnson <tejohnson@google.com>
24319
24320 * ipa-utils.c (ipa_print_order): Use specified dump file.
24321
24322 2014-03-23 Eric Botcazou <ebotcazou@adacore.com>
24323
24324 PR rtl-optimization/60601
24325 * bb-reorder.c (fix_up_fall_thru_edges): Test EDGE_FALLTHRU everywhere.
24326
24327 * gcc.c (eval_spec_function): Initialize save_growing_value.
24328
24329 2014-03-22 Jakub Jelinek <jakub@redhat.com>
24330
24331 PR sanitizer/60613
24332 * internal-fn.c (ubsan_expand_si_overflow_addsub_check): For
24333 code == MINUS_EXPR, never swap op0 with op1.
24334
24335 * toplev.c (init_local_tick): Avoid signed integer multiplication
24336 overflow.
24337 * genautomata.c (reserv_sets_hash_value): Fix rotate idiom, avoid
24338 shift by first operand's bitsize.
24339
24340 2014-03-21 Jakub Jelinek <jakub@redhat.com>
24341
24342 PR target/60610
24343 * config/i386/i386.h (TARGET_64BIT_P): If not TARGET_BI_ARCH,
24344 redefine to 1 or 0.
24345 * config/i386/darwin.h (TARGET_64BIT_P): Redefine to
24346 TARGET_ISA_64BIT_P(x).
24347
24348 2014-03-21 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
24349
24350 * config/rs6000/rs6000.c (rs6000_expand_vector_set): Generate a
24351 pattern for vector nor instead of subtract from splat(-1).
24352 (altivec_expand_vec_perm_const_le): Likewise.
24353
24354 2014-03-21 Richard Henderson <rth@twiddle.net>
24355
24356 PR target/60598
24357 * ifcvt.c (dead_or_predicable): Return FALSE if there are any frame
24358 related insns after epilogue_completed.
24359
24360 2014-03-21 Martin Jambor <mjambor@suse.cz>
24361
24362 PR ipa/59176
24363 * cgraph.h (symtab_node): New flag body_removed.
24364 * ipa.c (symtab_remove_unreachable_nodes): Set body_removed flag
24365 when removing bodies.
24366 * symtab.c (dump_symtab_base): Dump body_removed flag.
24367 * cgraph.c (verify_edge_corresponds_to_fndecl): Skip nodes which
24368 had their bodies removed.
24369
24370 2014-03-21 Martin Jambor <mjambor@suse.cz>
24371
24372 PR ipa/60419
24373 * ipa.c (symtab_remove_unreachable_nodes): Clear thunk flag of nodes
24374 in the border.
24375
24376 2014-03-21 Richard Biener <rguenther@suse.de>
24377
24378 PR tree-optimization/60577
24379 * tree-core.h (struct tree_base): Document nothrow_flag use
24380 in DECL_NONALIASED.
24381 * tree.h (DECL_NONALIASED): New.
24382 (may_be_aliased): Adjust.
24383 * coverage.c (build_var): Set DECL_NONALIASED.
24384
24385 2014-03-20 Eric Botcazou <ebotcazou@adacore.com>
24386
24387 * expr.c (expand_expr_real_1): Remove outdated comment.
24388
24389 2014-03-20 Jakub Jelinek <jakub@redhat.com>
24390
24391 PR middle-end/60597
24392 * ira.c (adjust_cleared_regs): Call copy_rtx on
24393 *reg_equiv[REGNO (loc)].src_p before passing it to
24394 simplify_replace_fn_rtx.
24395
24396 PR target/60568
24397 * config/i386/i386.c (x86_output_mi_thunk): Surround UNSPEC_GOT
24398 into CONST, put pic register as first operand of PLUS. Use
24399 gen_const_mem for both 32-bit and 64-bit PIC got loads.
24400
24401 2014-03-20 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
24402
24403 * config/aarch64/aarch64.c (MEMORY_MOVE_COST): Delete.
24404
24405 2014-03-20 Eric Botcazou <ebotcazou@adacore.com>
24406
24407 * config/sparc/sparc.c (sparc_do_work_around_errata): Implement work
24408 around for store forwarding issue in the FPU on the UT699.
24409 * config/sparc/sparc.md (in_branch_delay): Return false for single FP
24410 loads and operations if -mfix-ut699 is specified.
24411 (divtf3_hq): Tweak attribute.
24412 (sqrttf2_hq): Likewise.
24413
24414 2014-03-20 Eric Botcazou <ebotcazou@adacore.com>
24415
24416 * calls.c (store_one_arg): Remove incorrect const qualification on the
24417 type of the temporary.
24418 * cfgexpand.c (expand_return): Likewise.
24419 * expr.c (expand_constructor): Likewise.
24420 (expand_expr_real_1): Likewise.
24421
24422 2014-03-20 Zhenqiang Chen <zhenqiang.chen@linaro.org>
24423
24424 * config/arm/arm.c (arm_dwarf_register_span): Update the element number
24425 of parts.
24426
24427 2014-03-19 Kaz Kojima <kkojima@gcc.gnu.org>
24428
24429 PR target/60039
24430 * config/sh/sh.md (udivsi3_i1): Clobber R1 register.
24431
24432 2014-03-19 James Greenhalgh <james.greenhalgh@arm.com>
24433
24434 * config/arm/aarch-common-protos.h
24435 (alu_cost_table): Fix spelling of "extend".
24436 * config/arm/arm.c (arm_new_rtx_costs): Fix spelling of "extend".
24437
24438 2014-03-19 Richard Biener <rguenther@suse.de>
24439
24440 PR middle-end/60553
24441 * tree-core.h (tree_type_common): Re-order pointer members
24442 to reduce recursion depth during GC walks.
24443
24444 2014-03-19 Marek Polacek <polacek@redhat.com>
24445
24446 PR sanitizer/60569
24447 * ubsan.c (ubsan_type_descriptor): Check that DECL_NAME is nonnull
24448 before accessing it.
24449
24450 2014-03-19 Richard Biener <rguenther@suse.de>
24451
24452 PR lto/59543
24453 * lto-streamer-in.c (input_function): In WPA stage do not drop
24454 debug stmts.
24455
24456 2014-03-19 Jakub Jelinek <jakub@redhat.com>
24457
24458 PR tree-optimization/60559
24459 * vectorizable_mask_load_store): Replace scalar MASK_LOAD
24460 with build_zero_cst assignment.
24461
24462 2014-03-18 Kai Tietz <ktietz@redhat.com>
24463
24464 PR rtl-optimization/56356
24465 * sdbout.c (sdbout_parms): Verify that parms'
24466 incoming argument is valid.
24467 (sdbout_reg_parms): Likewise.
24468
24469 2014-03-18 Richard Henderson <rth@redhat.com>
24470
24471 PR target/60562
24472 * config/i386/i386.md (*float<SWI48x><MODEF>2_i387): Move down to
24473 be shadowed by *float<SWI48><MODEF>2_sse. Test X87_ENABLE_FLOAT.
24474 (*float<SWI48><MODEF>2_sse): Check X87_ENABLE_FLOAT for alternative 0.
24475
24476 2014-03-18 Basile Starynkevitch <basile@starynkevitch.net>
24477
24478 * plugin.def: Improve comment for PLUGIN_INCLUDE_FILE.
24479 * doc/plugins.texi (Plugin callbacks): Mention PLUGIN_INCLUDE_FILE.
24480 Italicize plugin event names in description. Explain that
24481 PLUGIN_PRAGMAS has no sense for lto1. Explain PLUGIN_INCLUDE_FILE.
24482 Remind that no GCC functions should be called after PLUGIN_FINISH.
24483 Explain what pragmas with expansion are.
24484
24485 2014-03-18 Martin Liska <mliska@suse.cz>
24486
24487 * cgraph.c (cgraph_update_edges_for_call_stmt_node): Added case when
24488 gimple call statement is update.
24489 * gimple-fold.c (gimple_fold_call): Changed order for GIMPLE_ASSIGN and
24490 GIMPLE_CALL, where gsi iterator still points to GIMPLE CALL.
24491
24492 2014-03-18 Jakub Jelinek <jakub@redhat.com>
24493
24494 PR sanitizer/60557
24495 * ubsan.c (ubsan_instrument_unreachable): Call
24496 initialize_sanitizer_builtins.
24497 (ubsan_pass): Likewise.
24498
24499 PR sanitizer/60535
24500 * ubsan.c (ubsan_type_descriptor, ubsan_create_data): Call
24501 varpool_finalize_decl instead of rest_of_decl_compilation.
24502
24503 2014-03-18 Richard Biener <rguenther@suse.de>
24504
24505 * df-problems.c (df_rd_confluence_n): Avoid bitmap_copy
24506 by using bitmap_and_compl instead of bitmap_and_compl_into.
24507 (df_rd_transfer_function): Likewise.
24508
24509 2014-03-18 Richard Biener <rguenther@suse.de>
24510
24511 * doc/lto.texi (fresolution): Fix typo.
24512
24513 2014-03-18 Richard Biener <rguenther@suse.de>
24514
24515 * doc/invoke.texi (flto): Update for changes in 4.9.
24516
24517 2014-03-18 Richard Biener <rguenther@suse.de>
24518
24519 * doc/loop.texi: Remove section on the removed lambda framework.
24520 Update loop docs with recent changes in preserving loop structure.
24521
24522 2014-03-18 Richard Biener <rguenther@suse.de>
24523
24524 * doc/lto.texi (-fresolution): Document.
24525
24526 2014-03-18 Richard Biener <rguenther@suse.de>
24527
24528 * doc/contrib.texi: Adjust my name.
24529
24530 2014-03-18 Jakub Jelinek <jakub@redhat.com>
24531
24532 PR ipa/58721
24533 * internal-fn.c: Include diagnostic-core.h.
24534 (expand_BUILTIN_EXPECT): New function.
24535 * gimplify.c (gimplify_call_expr): Use false instead of FALSE.
24536 (gimplify_modify_expr): Gimplify 3 argument __builtin_expect into
24537 IFN_BUILTIN_EXPECT call instead of __builtin_expect builtin call.
24538 * ipa-inline-analysis.c (find_foldable_builtin_expect): Handle
24539 IFN_BUILTIN_EXPECT.
24540 * predict.c (expr_expected_value_1): Handle IFN_BUILTIN_EXPECT.
24541 Revert 3 argument __builtin_expect code.
24542 (strip_predict_hints): Handle IFN_BUILTIN_EXPECT.
24543 * gimple-fold.c (gimple_fold_call): Likewise.
24544 * tree.h (fold_builtin_expect): New prototype.
24545 * builtins.c (build_builtin_expect_predicate): Add predictor
24546 argument, if non-NULL, create 3 argument __builtin_expect.
24547 (fold_builtin_expect): No longer static. Add ARG2 argument,
24548 pass it through to build_builtin_expect_predicate.
24549 (fold_builtin_2): Adjust caller.
24550 (fold_builtin_3): Handle BUILT_IN_EXPECT.
24551 * internal-fn.def (BUILTIN_EXPECT): New.
24552
24553 2014-03-18 Tobias Burnus <burnus@net-b.de>
24554
24555 PR ipa/58721
24556 * predict.def (PRED_FORTRAN_OVERFLOW, PRED_FORTRAN_FAIL_ALLOC,
24557 PRED_FORTRAN_FAIL_IO, PRED_FORTRAN_WARN_ONCE, PRED_FORTRAN_SIZE_ZERO,
24558 PRED_FORTRAN_INVALID_BOUND, PRED_FORTRAN_ABSENT_DUMMY): Add.
24559
24560 2014-03-18 Jan Hubicka <hubicka@ucw.cz>
24561
24562 PR ipa/58721
24563 * predict.c (combine_predictions_for_bb): Fix up formatting.
24564 (expr_expected_value_1, expr_expected_value): Add predictor argument,
24565 fill what it points to if non-NULL.
24566 (tree_predict_by_opcode): Adjust caller, use the predictor.
24567 * predict.def (PRED_COMPARE_AND_SWAP): Add.
24568
24569 2014-03-18 Eric Botcazou <ebotcazou@adacore.com>
24570
24571 * config/sparc/sparc.c (sparc_do_work_around_errata): Speed up and use
24572 proper constant for the store mode.
24573
24574 2014-03-18 Ilya Enkovich <ilya.enkovich@intel.com>
24575
24576 * symtab.c (change_decl_assembler_name): Fix transparent alias
24577 chain construction.
24578
24579 2014-03-16 Renlin Li <Renlin.Li@arm.com>
24580
24581 * config/aarch64/aarch64.c: Correct the comments about the
24582 aarch64 stack layout.
24583
24584 2014-03-18 Thomas Schwinge <thomas@codesourcery.com>
24585
24586 * omp-low.c (lower_rec_input_clauses) <build_omp_barrier>: Restore
24587 check for GF_OMP_FOR_KIND_FOR.
24588
24589 2013-03-18 Kirill Yukhin <kirill.yukhin@intel.com>
24590
24591 * config/i386/i386.h (ADDITIONAL_REGISTER_NAMES): Add
24592 ymm and zmm register names.
24593
24594 2014-03-17 Jakub Jelinek <jakub@redhat.com>
24595
24596 PR target/60516
24597 * config/i386/i386.c (ix86_expand_epilogue): Adjust REG_CFA_ADJUST_CFA
24598 note creation for the 2010-08-31 changes.
24599
24600 2014-03-17 Marek Polacek <polacek@redhat.com>
24601
24602 PR middle-end/60534
24603 * omp-low.c (omp_max_vf): Treat -fno-tree-loop-optimize the same
24604 as -fno-tree-loop-vectorize.
24605 (expand_omp_simd): Likewise.
24606
24607 2014-03-15 Eric Botcazou <ebotcazou@adacore.com>
24608
24609 * config/sparc/sparc-protos.h (tls_call_delay): Delete.
24610 (eligible_for_call_delay): New prototype.
24611 * config/sparc/sparc.c (tls_call_delay): Rename into...
24612 (eligible_for_call_delay): ...this. Return false if the instruction
24613 cannot be put in the delay slot of a branch.
24614 (eligible_for_restore_insn): Simplify.
24615 (eligible_for_return_delay): Return false if the instruction cannot be
24616 put in the delay slot of a branch and simplify.
24617 (eligible_for_sibcall_delay): Return false if the instruction cannot be
24618 put in the delay slot of a branch.
24619 * config/sparc/sparc.md (fix_ut699): New attribute.
24620 (tls_call_delay): Delete.
24621 (in_call_delay): Reimplement.
24622 (eligible_for_sibcall_delay): Rename into...
24623 (in_sibcall_delay): ...this.
24624 (eligible_for_return_delay): Rename into...
24625 (in_return_delay): ...this.
24626 (in_branch_delay): Reimplement.
24627 (in_uncond_branch_delay): Delete.
24628 (in_annul_branch_delay): Delete.
24629
24630 2014-03-14 Richard Henderson <rth@redhat.com>
24631
24632 PR target/60525
24633 * config/i386/i386.md (floathi<X87MODEF>2): Delete expander; rename
24634 define_insn from *floathi<X87MODEF>2_i387; allow nonimmediate_operand.
24635 (*floathi<X87MODEF>2_i387_with_temp): Remove.
24636 (floathi splitters): Remove.
24637 (float<SWI48x>xf2): New pattern.
24638 (float<SWI48><MODEF>2): Rename from float<SWI48x><X87MODEF>2. Drop
24639 code that tried to handle DImode for 32-bit, but which was excluded
24640 by the pattern's condition. Drop allocation of stack temporary.
24641 (*floatsi<MODEF>2_vector_mixed_with_temp): Remove.
24642 (*float<SWI48><MODEF>2_mixed_with_temp): Remove.
24643 (*float<SWI48><MODEF>2_mixed_interunit): Remove.
24644 (*float<SWI48><MODEF>2_mixed_nointerunit): Remove.
24645 (*floatsi<MODEF>2_vector_sse_with_temp): Remove.
24646 (*float<SWI48><MODEF>2_sse_with_temp): Remove.
24647 (*float<SWI48><MODEF>2_sse_interunit): Remove.
24648 (*float<SWI48><MODEF>2_sse_nointerunit): Remove.
24649 (*float<SWI48x><X87MODEF>2_i387_with_temp): Remove.
24650 (*float<SWI48x><X87MODEF>2_i387): Remove.
24651 (all float _with_temp splitters): Remove.
24652 (*float<SWI48x><MODEF>2_i387): New pattern.
24653 (*float<SWI48><MODEF>2_sse): New pattern.
24654 (float TARGET_USE_VECTOR_CONVERTS splitters): Merge them.
24655 (float TARGET_SSE_PARTIAL_REG_DEPENDENCY splitters): Merge them.
24656
24657 2014-03-14 Jakub Jelinek <jakub@redhat.com>
24658 Marek Polacek <polacek@redhat.com>
24659
24660 PR middle-end/60484
24661 * common.opt (dump_base_name_prefixed): New Variable.
24662 * opts.c (finish_options): Don't prepend directory to x_dump_base_name
24663 if x_dump_base_name_prefixed is already set, set it at the end.
24664
24665 2014-03-14 Vladimir Makarov <vmakarov@redhat.com>
24666
24667 PR rtl-optimization/60508
24668 * lra-constraints.c (get_reload_reg): Add new parameter
24669 in_subreg_p.
24670 (process_addr_reg, simplify_operand_subreg, curr_insn_transform):
24671 Pass the new parameter values.
24672
24673 2014-03-14 Richard Biener <rguenther@suse.de>
24674
24675 * common.opt: Revert unintented changes from r205065.
24676 * opts.c: Likewise.
24677
24678 2014-03-14 Richard Biener <rguenther@suse.de>
24679
24680 PR middle-end/60518
24681 * cfghooks.c (split_block): Properly adjust all loops the
24682 block was a latch of.
24683
24684 2014-03-14 Martin Jambor <mjambor@suse.cz>
24685
24686 PR lto/60461
24687 * ipa-prop.c (ipa_modify_call_arguments): Fix iteration condition
24688 and simplify it.
24689
24690 2014-03-14 Georg-Johann Lay <avr@gjlay.de>
24691
24692 PR target/59396
24693 * config/avr/avr.c (avr_set_current_function): Pass function name
24694 through default_strip_name_encoding before sanity checking instead
24695 of skipping the first char of the assembler name.
24696
24697 2014-03-13 Richard Henderson <rth@redhat.com>
24698
24699 PR debug/60438
24700 * config/i386/i386.c (ix86_split_fp_branch): Remove pushed argument.
24701 (ix86_force_to_memory, ix86_free_from_memory): Remove.
24702 * config/i386/i386-protos.h: Likewise.
24703 * config/i386/i386.md (floathi<X87MODEF>2): Use assign_386_stack_local
24704 in the expander instead of a splitter.
24705 (float<SWI48x><X87MODEF>2): Use assign_386_stack_local if there is
24706 any possibility of requiring a memory.
24707 (*floatsi<MODEF>2_vector_mixed): Remove, and the splitters.
24708 (*floatsi<MODEF>2_vector_sse): Remove, and the splitters.
24709 (fp branch splitters): Update for ix86_split_fp_branch.
24710 (*jcc<X87MODEF>_<SWI24>_i387): Remove r/f alternative.
24711 (*jcc<X87MODEF>_<SWI24>_r_i387): Likewise.
24712 (splitter for jcc<X87MODEF>_<SWI24>_i387 r/f): Remove.
24713 (*fop_<MODEF>_2_i387): Remove f/r alternative.
24714 (*fop_<MODEF>_3_i387): Likewise.
24715 (*fop_xf_2_i387, *fop_xf_3_i387): Likewise.
24716 (splitters for the fop_* register patterns): Remove.
24717 (fscalexf4_i387): Rename from *fscalexf4_i387.
24718 (ldexpxf3): Use gen_floatsixf2 and gen_fscalexf4_i387.
24719
24720 2014-03-13 Jakub Jelinek <jakub@redhat.com>
24721
24722 PR tree-optimization/59779
24723 * tree-dfa.c (get_ref_base_and_extent): Use double_int
24724 type for bitsize and maxsize instead of HOST_WIDE_INT.
24725
24726 2014-03-13 Steven Bosscher <steven@gcc.gnu.org>
24727
24728 PR rtl-optimization/57320
24729 * function.c (rest_of_handle_thread_prologue_and_epilogue): Cleanup
24730 the CFG after thread_prologue_and_epilogue_insns.
24731
24732 2014-03-13 Vladimir Makarov <vmakarov@redhat.com>
24733
24734 PR rtl-optimization/57189
24735 * lra-constraints.c (process_alt_operands): Disfavor spilling
24736 vector pseudos.
24737
24738 2014-03-13 Cesar Philippidis <cesar@codesourcery.com>
24739
24740 * lto-wrapper.c (maybe_unlink_file): Suppress diagnostic messages.
24741
24742 2014-03-13 Jakub Jelinek <jakub@redhat.com>
24743
24744 PR tree-optimization/59025
24745 PR middle-end/60418
24746 * tree-ssa-reassoc.c (sort_by_operand_rank): For SSA_NAMEs with the
24747 same rank, sort by bb_rank and gimple_uid of SSA_NAME_DEF_STMT first.
24748
24749 2014-03-13 Georg-Johann Lay <avr@gjlay.de>
24750
24751 PR target/60486
24752 * config/avr/avr.c (avr_out_plus): Swap cc_plus and cc_minus in
24753 calls of avr_out_plus_1.
24754
24755 2014-03-13 Bin Cheng <bin.cheng@arm.com>
24756
24757 * tree-cfgcleanup.c (remove_forwarder_block_with_phi): Record
24758 BB's single pred and update the father loop's latch info later.
24759
24760 2014-03-12 Michael Meissner <meissner@linux.vnet.ibm.com>
24761
24762 * config/rs6000/vector.md (VEC_L): Add V1TI mode to vector types.
24763 (VEC_M): Likewise.
24764 (VEC_N): Likewise.
24765 (VEC_R): Likewise.
24766 (VEC_base): Likewise.
24767 (mov<MODE>, VEC_M modes): If we are loading TImode into VSX
24768 registers, we need to swap double words in little endian mode.
24769
24770 * config/rs6000/rs6000-modes.def (V1TImode): Add new vector mode
24771 to be a container mode for 128-bit integer operations added in ISA
24772 2.07. Unlike TImode and PTImode, the preferred register set is
24773 the Altivec/VMX registers for the 128-bit operations.
24774
24775 * config/rs6000/rs6000-protos.h (rs6000_move_128bit_ok_p): Add
24776 declarations.
24777 (rs6000_split_128bit_ok_p): Likewise.
24778
24779 * config/rs6000/rs6000-builtin.def (BU_P8V_AV_3): Add new support
24780 macros for creating ISA 2.07 normal and overloaded builtin
24781 functions with 3 arguments.
24782 (BU_P8V_OVERLOAD_3): Likewise.
24783 (VPERM_1T): Add support for V1TImode in 128-bit vector operations
24784 for use as overloaded functions.
24785 (VPERM_1TI_UNS): Likewise.
24786 (VSEL_1TI): Likewise.
24787 (VSEL_1TI_UNS): Likewise.
24788 (ST_INTERNAL_1ti): Likewise.
24789 (LD_INTERNAL_1ti): Likewise.
24790 (XXSEL_1TI): Likewise.
24791 (XXSEL_1TI_UNS): Likewise.
24792 (VPERM_1TI): Likewise.
24793 (VPERM_1TI_UNS): Likewise.
24794 (XXPERMDI_1TI): Likewise.
24795 (SET_1TI): Likewise.
24796 (LXVD2X_V1TI): Likewise.
24797 (STXVD2X_V1TI): Likewise.
24798 (VEC_INIT_V1TI): Likewise.
24799 (VEC_SET_V1TI): Likewise.
24800 (VEC_EXT_V1TI): Likewise.
24801 (EQV_V1TI): Likewise.
24802 (NAND_V1TI): Likewise.
24803 (ORC_V1TI): Likewise.
24804 (VADDCUQ): Add support for 128-bit integer arithmetic instructions
24805 added in ISA 2.07. Add both normal 'altivec' builtins, and the
24806 overloaded builtin.
24807 (VADDUQM): Likewise.
24808 (VSUBCUQ): Likewise.
24809 (VADDEUQM): Likewise.
24810 (VADDECUQ): Likewise.
24811 (VSUBEUQM): Likewise.
24812 (VSUBECUQ): Likewise.
24813
24814 * config/rs6000/rs6000-c.c (__int128_type): New static to hold
24815 __int128_t and __uint128_t types.
24816 (__uint128_type): Likewise.
24817 (altivec_categorize_keyword): Add support for vector __int128_t,
24818 vector __uint128_t, vector __int128, and vector unsigned __int128
24819 as a container type for TImode operations that need to be done in
24820 VSX/Altivec registers.
24821 (rs6000_macro_to_expand): Likewise.
24822 (altivec_overloaded_builtins): Add ISA 2.07 overloaded functions
24823 to support 128-bit integer instructions vaddcuq, vadduqm,
24824 vaddecuq, vaddeuqm, vsubcuq, vsubuqm, vsubecuq, vsubeuqm.
24825 (altivec_resolve_overloaded_builtin): Add support for V1TImode.
24826
24827 * config/rs6000/rs6000.c (rs6000_hard_regno_mode_ok): Add support
24828 for V1TImode, and set up preferences to use VSX/Altivec registers.
24829 Setup VSX reload handlers.
24830 (rs6000_debug_reg_global): Likewise.
24831 (rs6000_init_hard_regno_mode_ok): Likewise.
24832 (rs6000_preferred_simd_mode): Likewise.
24833 (vspltis_constant): Do not allow V1TImode as easy altivec constants.
24834 (easy_altivec_constant): Likewise.
24835 (output_vec_const_move): Likewise.
24836 (rs6000_expand_vector_set): Convert V1TImode set and extract to
24837 simple move.
24838 (rs6000_expand_vector_extract): Likewise.
24839 (reg_offset_addressing_ok_p): Setup V1TImode to use VSX reg+reg
24840 addressing.
24841 (rs6000_const_vec): Add support for V1TImode.
24842 (rs6000_emit_le_vsx_load): Swap double words when loading or
24843 storing TImode/V1TImode.
24844 (rs6000_emit_le_vsx_store): Likewise.
24845 (rs6000_emit_le_vsx_move): Likewise.
24846 (rs6000_emit_move): Add support for V1TImode.
24847 (altivec_expand_ld_builtin): Likewise.
24848 (altivec_expand_st_builtin): Likewise.
24849 (altivec_expand_vec_init_builtin): Likewise.
24850 (altivec_expand_builtin): Likewise.
24851 (rs6000_init_builtins): Add support for V1TImode type. Add
24852 support for ISA 2.07 128-bit integer builtins. Define type names
24853 for the VSX/Altivec vector types.
24854 (altivec_init_builtins): Add support for overloaded vector
24855 functions with V1TImode type.
24856 (rs6000_preferred_reload_class): Prefer Altivec registers for V1TImode.
24857 (rs6000_move_128bit_ok_p): Move 128-bit move/split validation to
24858 external function.
24859 (rs6000_split_128bit_ok_p): Likewise.
24860 (rs6000_handle_altivec_attribute): Create V1TImode from vector
24861 __int128_t and vector __uint128_t.
24862
24863 * config/rs6000/vsx.md (VSX_L): Add V1TImode to vector iterators
24864 and mode attributes.
24865 (VSX_M): Likewise.
24866 (VSX_M2): Likewise.
24867 (VSm): Likewise.
24868 (VSs): Likewise.
24869 (VSr): Likewise.
24870 (VSv): Likewise.
24871 (VS_scalar): Likewise.
24872 (VS_double): Likewise.
24873 (vsx_set_v1ti): New builtin function to create V1TImode from TImode.
24874
24875 * config/rs6000/rs6000.h (TARGET_VADDUQM): New macro to say whether
24876 we support the ISA 2.07 128-bit integer arithmetic instructions.
24877 (ALTIVEC_OR_VSX_VECTOR_MODE): Add V1TImode.
24878 (enum rs6000_builtin_type_index): Add fields to hold V1TImode
24879 and TImode types for use with the builtin functions.
24880 (V1TI_type_node): Likewise.
24881 (unsigned_V1TI_type_node): Likewise.
24882 (intTI_type_internal_node): Likewise.
24883 (uintTI_type_internal_node): Likewise.
24884
24885 * config/rs6000/altivec.md (UNSPEC_VADDCUQ): New unspecs for ISA 2.07
24886 128-bit builtin functions.
24887 (UNSPEC_VADDEUQM): Likewise.
24888 (UNSPEC_VADDECUQ): Likewise.
24889 (UNSPEC_VSUBCUQ): Likewise.
24890 (UNSPEC_VSUBEUQM): Likewise.
24891 (UNSPEC_VSUBECUQ): Likewise.
24892 (VM): Add V1TImode to vector mode iterators.
24893 (VM2): Likewise.
24894 (VI_unit): Likewise.
24895 (altivec_vadduqm): Add ISA 2.07 128-bit binary builtins.
24896 (altivec_vaddcuq): Likewise.
24897 (altivec_vsubuqm): Likewise.
24898 (altivec_vsubcuq): Likewise.
24899 (altivec_vaddeuqm): Likewise.
24900 (altivec_vaddecuq): Likewise.
24901 (altivec_vsubeuqm): Likewise.
24902 (altivec_vsubecuq): Likewise.
24903
24904 * config/rs6000/rs6000.md (FMOVE128_GPR): Add V1TImode to vector
24905 mode iterators.
24906 (BOOL_128): Likewise.
24907 (BOOL_REGS_OUTPUT): Likewise.
24908 (BOOL_REGS_OP1): Likewise.
24909 (BOOL_REGS_OP2): Likewise.
24910 (BOOL_REGS_UNARY): Likewise.
24911 (BOOL_REGS_AND_CR0): Likewise.
24912
24913 * config/rs6000/altivec.h (vec_vaddcuq): Add support for ISA 2.07
24914 128-bit integer builtin support.
24915 (vec_vadduqm): Likewise.
24916 (vec_vaddecuq): Likewise.
24917 (vec_vaddeuqm): Likewise.
24918 (vec_vsubecuq): Likewise.
24919 (vec_vsubeuqm): Likewise.
24920 (vec_vsubcuq): Likewise.
24921 (vec_vsubuqm): Likewise.
24922
24923 * doc/extend.texi (PowerPC AltiVec/VSX Built-in Functions):
24924 Document vec_vaddcuq, vec_vadduqm, vec_vaddecuq, vec_vaddeuqm,
24925 vec_subecuq, vec_subeuqm, vec_vsubcuq, vec_vsubeqm builtins adding
24926 128-bit integer add/subtract to ISA 2.07.
24927
24928 2014-03-12 Joern Rennecke <joern.rennecke@embecosm.com>
24929
24930 * config/arc/arc.c (arc_predicate_delay_insns):
24931 Fix third argument passed to conditionalize_nonjump.
24932
24933 2014-03-12 Yufeng Zhang <yufeng.zhang@arm.com>
24934
24935 * config/aarch64/aarch64-builtins.c
24936 (aarch64_builtin_vectorized_function): Add BUILT_IN_LFLOORF,
24937 BUILT_IN_LLFLOOR, BUILT_IN_LCEILF and BUILT_IN_LLCEIL.
24938 * config/aarch64/arm_neon.h (vcvtaq_u64_f64): Call __builtin_llfloor
24939 instead of __builtin_lfloor.
24940 (vcvtnq_u64_f64): Call __builtin_llceil instead of __builtin_lceil.
24941
24942 2014-03-12 Jakub Jelinek <jakub@redhat.com>
24943
24944 * tree-ssa-ifcombine.c (forwarder_block_to): New function.
24945 (tree_ssa_ifcombine_bb_1): New function.
24946 (tree_ssa_ifcombine_bb): Use it. Handle also cases where else_bb
24947 is an empty forwarder block to then_bb or vice versa and then_bb
24948 and else_bb are effectively swapped.
24949
24950 2014-03-12 Christian Bruel <christian.bruel@st.com>
24951
24952 PR target/60264
24953 * config/arm/arm.c (arm_emit_vfp_multi_reg_pop): Emit a
24954 REG_CFA_DEF_CFA note.
24955 (arm_expand_epilogue_apcs_frame): call arm_add_cfa_adjust_cfa_note.
24956 (arm_unwind_emit): Allow REG_CFA_DEF_CFA.
24957
24958 2014-03-12 Thomas Preud'homme <thomas.preudhomme@arm.com>
24959
24960 PR tree-optimization/60454
24961 * tree-ssa-math-opts.c (find_bswap_1): Fix bswap detection.
24962
24963 2014-03-12 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
24964
24965 * config.gcc (aarch64*-*-*): Use ISA flags from aarch64-arches.def.
24966 Do not define target_cpu_default2 to generic.
24967 * config/aarch64/aarch64.h (TARGET_CPU_DEFAULT): Use generic cpu.
24968 * config/aarch64/aarch64.c (aarch64_override_options): Update comment.
24969 * config/aarch64/aarch64-arches.def (armv8-a): Use generic cpu.
24970
24971 2014-03-12 Jakub Jelinek <jakub@redhat.com>
24972 Marc Glisse <marc.glisse@inria.fr>
24973
24974 PR tree-optimization/60502
24975 * tree-ssa-reassoc.c (eliminate_not_pairs): Use build_all_ones_cst
24976 instead of build_low_bits_mask.
24977
24978 2014-03-12 Jakub Jelinek <jakub@redhat.com>
24979
24980 PR middle-end/60482
24981 * tree-vrp.c (register_edge_assert_for_1): Don't add assert
24982 if there are multiple uses, but op doesn't live on E edge.
24983 * tree-cfg.c (assert_unreachable_fallthru_edge_p): Also ignore
24984 clobber stmts before __builtin_unreachable.
24985
24986 2014-03-11 Richard Sandiford <rdsandiford@googlemail.com>
24987
24988 * builtins.c (expand_builtin_setjmp_receiver): Use and clobber
24989 hard_frame_pointer_rtx.
24990 * cse.c (cse_insn): Remove volatile check.
24991 * cselib.c (cselib_process_insn): Likewise.
24992 * dse.c (scan_insn): Likewise.
24993
24994 2014-03-11 Joern Rennecke <joern.rennecke@embecosm.com>
24995
24996 * config/arc/arc.c (conditionalize_nonjump): New function,
24997 broken out of ...
24998 (arc_ifcvt): ... this.
24999 (arc_predicate_delay_insns): Use it.
25000
25001 2014-03-11 Joern Rennecke <joern.rennecke@embecosm.com>
25002
25003 * config/arc/predicates.md (extend_operand): During/after reload,
25004 allow const_int_operand.
25005 * config/arc/arc.md (mulsidi3_700): Use extend_operand predicate.
25006 (umulsidi3_700): Likewise. Change operand 2 constraint back to "cL".
25007 (mulsi3_highpart): Change operand 2 constraint alternatives 2 and 3
25008 to "i".
25009 (umulsi3_highpart_i): Likewise.
25010
25011 2014-03-11 Richard Biener <rguenther@suse.de>
25012
25013 * tree-ssa-structalias.c (get_constraint_for_ptr_offset):
25014 Add asserts to guard possible wrong-code bugs.
25015
25016 2014-03-11 Richard Biener <rguenther@suse.de>
25017
25018 PR tree-optimization/60429
25019 PR tree-optimization/60485
25020 * tree-ssa-structalias.c (set_union_with_increment): Properly
25021 take into account all fields that overlap the shifted vars.
25022 (do_sd_constraint): Likewise.
25023 (do_ds_constraint): Likewise.
25024 (get_constraint_for_ptr_offset): Likewise.
25025
25026 2014-03-11 Chung-Lin Tang <cltang@codesourcery.com>
25027
25028 * config/nios2/nios2.c (machine_function): Add fp_save_offset field.
25029 (nios2_compute_frame_layout):
25030 Add calculation of cfun->machine->fp_save_offset.
25031 (nios2_expand_prologue): Correct setting of frame pointer register
25032 in prologue.
25033 (nios2_expand_epilogue): Update recovery of stack pointer from
25034 frame pointer accordingly.
25035 (nios2_initial_elimination_offset): Update calculation of offset
25036 for eliminating to HARD_FRAME_POINTER_REGNUM.
25037
25038 2014-03-10 Jakub Jelinek <jakub@redhat.com>
25039
25040 PR ipa/60457
25041 * ipa.c (symtab_remove_unreachable_nodes): Don't call
25042 cgraph_get_create_node on VAR_DECLs.
25043
25044 2014-03-10 Richard Biener <rguenther@suse.de>
25045
25046 PR middle-end/60474
25047 * tree.c (signed_or_unsigned_type_for): Handle OFFSET_TYPEs.
25048
25049 2014-03-08 Douglas B Rupp <rupp@gnat.com>
25050
25051 * config/vms/vms.opt (vms_float_format): New variable.
25052
25053 2014-03-08 Tobias Burnus <burnus@net-b.de>
25054
25055 * doc/invoke.texi (-fcilkplus): Update implementation status.
25056
25057 2014-03-08 Paulo Matos <paulo@matos-sorge.com>
25058 Richard Biener <rguenther@suse.de>
25059
25060 * lto-wrapper.c (merge_and_complain): Ensure -fshort-double is used
25061 consistently accross all TUs.
25062 (run_gcc): Enable -fshort-double automatically at link at link-time
25063 and disallow override.
25064
25065 2014-03-08 Richard Sandiford <rdsandiford@googlemail.com>
25066
25067 PR target/58271
25068 * config/mips/mips.c (mips_option_override): Promote -mpaired-single
25069 warning to an error. Disable TARGET_PAIRED_SINGLE and TARGET_MIPS3D
25070 if they can't be used.
25071
25072 2014-03-07 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
25073
25074 * configure.ac (HAVE_AS_IX86_TLSLDMPLT): Improve test
25075 for Solaris 11/x86 ld.
25076 * configure: Regenerate.
25077
25078 2014-03-07 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
25079
25080 * configure.ac (TLS_SECTION_ASM_FLAG): Save as tls_section_flag.
25081 (LIB_TLS_SPEC): Save as ld_tls_libs.
25082 (HAVE_AS_IX86_TLSLDMPLT): Define as 1/0.
25083 (HAVE_AS_IX86_TLSLDM): New test.
25084 * configure, config.in: Regenerate.
25085 * config/i386/i386.c (legitimize_tls_address): Fall back to
25086 TLS_MODEL_GLOBAL_DYNAMIC on 32-bit Solaris/x86 if tool chain
25087 cannot support TLS_MODEL_LOCAL_DYNAMIC.
25088 * config/i386/i386.md (*tls_local_dynamic_base_32_gnu): Use if
25089 instead of #ifdef in HAVE_AS_IX86_TLSLDMPLT test.
25090
25091 2014-03-07 Paulo Matos <paulo@matos-sorge.com>
25092
25093 * common.opt (fira-loop-pressure): Mark as optimization.
25094
25095 2014-03-07 Thomas Schwinge <thomas@codesourcery.com>
25096
25097 * langhooks.c (lhd_omp_mappable_type): The error_mark_node is not
25098 an OpenMP mappable type.
25099
25100 2014-03-06 Matthias Klose <doko@ubuntu.com>
25101
25102 * Makefile.in (s-mlib): Only pass MULTIARCH_DIRNAME if
25103 MULTILIB_OSDIRNAMES is not defined.
25104
25105 2014-03-06 Jakub Jelinek <jakub@redhat.com>
25106 Meador Inge <meadori@codesourcery.com>
25107
25108 PR target/58595
25109 * config/arm/arm.c (arm_tls_symbol_p): Remove.
25110 (arm_legitimize_address): Call legitimize_tls_address for any
25111 arm_tls_referenced_p expression, handle constant addend. Call it
25112 before testing for !TARGET_ARM.
25113 (thumb_legitimize_address): Don't handle arm_tls_symbol_p here.
25114
25115 2014-03-06 Richard Biener <rguenther@suse.de>
25116
25117 PR middle-end/60445
25118 PR lto/60424
25119 PR lto/60427
25120 Revert
25121 2014-03-04 Paulo Matos <paulo@matos-sorge.com>
25122
25123 * tree-streamer.c (record_common_node): Assert we don't record
25124 nodes with type double.
25125 (preload_common_node): Skip type double, complex double and double
25126 pointer since it is now frontend dependent due to fshort-double option.
25127
25128 2014-03-06 Richard Biener <rguenther@suse.de>
25129
25130 * gcc.c (PLUGIN_COND): Always enable unless -fno-use-linker-plugin
25131 or -fno-lto is specified and the linker has full plugin support.
25132 * collect2.c (lto_mode): Default to LTO_MODE_WHOPR if LTO is enabled.
25133 (main): Remove -flto processing, adjust lto_mode using use_plugin late.
25134 * lto-wrapper.c (merge_and_complain): Merge compile-time
25135 optimization levels.
25136 (run_gcc): And pass it through to the link options.
25137
25138 2014-03-06 Alexandre Oliva <aoliva@redhat.com>
25139
25140 PR debug/60381
25141 Revert:
25142 2014-02-28 Alexandre Oliva <aoliva@redhat.com>
25143 PR debug/59992
25144 * cselib.c (remove_useless_values): Skip to avoid quadratic
25145 behavior if the condition moved from...
25146 (cselib_process_insn): ... here holds.
25147
25148 2014-03-05 Jakub Jelinek <jakub@redhat.com>
25149
25150 PR plugins/59335
25151 * Makefile.in (PLUGIN_HEADERS): Add tree-phinodes.h, stor-layout.h,
25152 ssa-iterators.h, $(RESOURCE_H) and tree-cfgcleanup.h.
25153
25154 PR plugins/59335
25155 * config/i386/t-i386 (OPTIONS_H_EXTRA): Add stringop.def.
25156 (TM_H): Add x86-tune.def.
25157
25158 2014-03-05 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
25159
25160 * config/aarch64/aarch64.c (generic_tunings):
25161 Use cortexa57_extra_costs.
25162
25163 2014-03-05 Jakub Jelinek <jakub@redhat.com>
25164
25165 PR lto/60404
25166 * cfgexpand.c (expand_used_vars): Do not assume all SSA_NAMEs
25167 of PARM/RESULT_DECLs must be coalesced with optimize && in_lto_p.
25168 * tree-ssa-coalesce.c (coalesce_ssa_name): Use MUST_COALESCE_COST - 1
25169 cost for in_lto_p.
25170
25171 2014-03-04 Heiher <r@hev.cc>
25172
25173 * config/mips/mips-cpus.def (loongson3a): Mark as a MIPS64r2 processor.
25174 * config/mips/mips.h (MIPS_ISA_LEVEL_SPEC): Adjust accordingly.
25175
25176 2014-03-04 Uros Bizjak <ubizjak@gmail.com>
25177
25178 * config/i386/predicates.md (const2356_operand): Change to ...
25179 (const2367_operand): ... this.
25180 * config/i386/sse.md (avx512pf_scatterpf<mode>sf): Use
25181 const2367_operand.
25182 (*avx512pf_scatterpf<mode>sf_mask): Ditto.
25183 (*avx512pf_scatterpf<mode>sf): Ditto.
25184 (avx512pf_scatterpf<mode>df): Ditto.
25185 (*avx512pf_scatterpf<mode>df_mask): Ditto.
25186 (*avx512pf_scatterpf<mode>df): Ditto.
25187 * config/i386/i386.c (ix86_expand_builtin): Update
25188 incorrect hint operand error message.
25189
25190 2014-03-04 Richard Biener <rguenther@suse.de>
25191
25192 * lto-section-in.c (lto_get_section_data): Fix const cast.
25193
25194 2014-03-04 Paulo Matos <paulo@matos-sorge.com>
25195
25196 * tree-streamer.c (record_common_node): Assert we don't record
25197 nodes with type double.
25198 (preload_common_node): Skip type double, complex double and double
25199 pointer since it is now frontend dependent due to fshort-double option.
25200
25201 2014-03-04 Richard Biener <rguenther@suse.de>
25202
25203 PR lto/60405
25204 * lto-streamer-in.c (lto_read_body): Remove LTO bytecode version check.
25205 (lto_input_toplevel_asms): Likewise.
25206 * lto-section-in.c (lto_get_section_data): Instead do it here
25207 for every section.
25208
25209 2014-03-04 Richard Biener <rguenther@suse.de>
25210
25211 PR tree-optimization/60382
25212 * tree-vect-loop.c (vect_is_simple_reduction_1): Do not consider
25213 dead PHIs a reduction.
25214
25215 2014-03-03 Uros Bizjak <ubizjak@gmail.com>
25216
25217 * config/i386/xmmintrin.h (enum _mm_hint) <_MM_HINT_ET0>: Correct
25218 hint value.
25219 (_mm_prefetch): Move out of GCC target("sse") pragma.
25220 * config/i386/prfchwintrin.h (_m_prefetchw): Move out of
25221 GCC target("prfchw") pragma.
25222 * config/i386/i386.md (prefetch): Emit prefetchwt1 only
25223 for locality <= 2.
25224 * config/i386/i386.c (ix86_option_override_internal): Enable
25225 -mprfchw with -mprefetchwt1.
25226
25227 2014-03-03 Joern Rennecke <joern.rennecke@embecosm.com>
25228
25229 * config/arc/arc.md (casesi_load) <length attribute alternative 0>:
25230 Mark as varying.
25231
25232 2014-03-03 Joern Rennecke <joern.rennecke@embecosm.com>
25233
25234 * opts.h (CL_PCH_IGNORE): Define.
25235 * targhooks.c (option_affects_pch_p):
25236 Return false for options that have CL_PCH_IGNORE set.
25237 * opt-functions.awk: Process PchIgnore.
25238 * doc/options.texi: Document PchIgnore.
25239
25240 * config/arc/arc.opt (misize): Add PchIgnore property.
25241
25242 2014-03-03 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
25243
25244 * config/rs6000/rs6000.c (rs6000_preferred_reload_class): Disallow
25245 reload of PLUS rtx's outside of GENERAL_REGS or BASE_REGS; relax
25246 constraint on constants to permit them being loaded into
25247 GENERAL_REGS or BASE_REGS.
25248
25249 2014-03-03 Nick Clifton <nickc@redhat.com>
25250
25251 * config/rl78/rl78-real.md (cbranchsi4_real_signed): Add
25252 anti-cacnonical alternatives.
25253 (negandhi3_real): New pattern.
25254 * config/rl78/rl78-virt.md (negandhi3_virt): New pattern.
25255
25256 2014-03-03 Senthil Kumar Selvaraj <senthil_kumar.selvaraj@atmel.com>
25257
25258 * config/avr/avr-mcus.def: Remove atxmega16x1.
25259 * config/avr/avr-tables.opt: Regenerate.
25260 * config/avr/t-multilib: Regenerate.
25261 * doc/avr-mmcu.texi: Regenerate.
25262
25263 2014-03-03 Tobias Grosser <tobias@grosser.es>
25264 Mircea Namolaru <mircea.namolaru@inria.fr>
25265
25266 PR tree-optimization/58028
25267 * graphite-clast-to-gimple.c (set_cloog_options): Don't remove
25268 scalar dimensions.
25269
25270 2014-03-03 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
25271
25272 * config/arm/neon.md (*movmisalign<mode>): Legitimize addresses
25273 not handled by recognizers.
25274
25275 2014-03-03 Jakub Jelinek <jakub@redhat.com>
25276
25277 PR middle-end/60175
25278 * function.c (expand_function_end): Don't emit
25279 clobber_return_register sequence if clobber_after is a BARRIER.
25280 * cfgexpand.c (construct_exit_block): Append instructions before
25281 return_label to prev_bb.
25282
25283 2014-03-02 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
25284
25285 * config/rs6000/constraints.md: Document reserved use of "wc".
25286
25287 2014-03-02 Jan Hubicka <hubicka@ucw.cz>
25288
25289 PR ipa/60150
25290 * ipa.c (function_and_variable_visibility): When dissolving comdat
25291 group, also set all symbols to local.
25292
25293 2014-03-02 Jan Hubicka <hubicka@ucw.cz>
25294
25295 PR ipa/60306
25296
25297 Revert:
25298 2013-12-14 Jan Hubicka <jh@suse.cz>
25299 PR middle-end/58477
25300 * ipa-prop.c (stmt_may_be_vtbl_ptr_store): Skip clobbers.
25301
25302 2014-03-02 Jon Beniston <jon@beniston.com>
25303
25304 PR bootstrap/48230
25305 PR bootstrap/50927
25306 PR bootstrap/52466
25307 PR target/46898
25308 * config/lm32/lm32.c (lm32_legitimate_constant_p): Remove, as incorrect.
25309 (TARGET_LEGITIMATE_CONSTANT_P): Undefine, as not needed.
25310 * config/lm32/lm32.md (movsi_insn): Add 32-bit immediate support.
25311 (simple_return, *simple_return): New patterns
25312 * config/lm32/predicates.md (movsi_rhs_operand): Remove as obsolete.
25313 * configure.ac (force_sjlj_exceptions): Force sjlj exceptions for lm32.
25314
25315 2014-03-01 Paolo Carlini <paolo.carlini@oracle.com>
25316
25317 * dwarf2out.c (gen_subprogram_die): Tidy.
25318
25319 2014-03-01 Oleg Endo <olegendo@gcc.gnu.org>
25320
25321 PR target/60071
25322 * config/sh/sh.md (*mov_t_msb_neg): Split into ...
25323 (*mov_t_msb_neg_negc): ... this new insn.
25324
25325 2014-02-28 Jason Merrill <jason@redhat.com>
25326
25327 PR c++/58678
25328 * ipa-devirt.c (ipa_devirt): Don't choose an implicitly-declared
25329 function.
25330
25331 2014-02-28 Paolo Carlini <paolo.carlini@oracle.com>
25332
25333 PR c++/60314
25334 * dwarf2out.c (decltype_auto_die): New static.
25335 (gen_subprogram_die): Handle 'decltype(auto)' like 'auto'.
25336 (gen_type_die_with_usage): Handle 'decltype(auto)'.
25337 (is_cxx_auto): Likewise.
25338
25339 2014-02-28 Ian Bolton <ian.bolton@arm.com>
25340
25341 * config/aarch64/aarch64.h: Define __ARM_NEON by default if
25342 we are not using general regs only.
25343
25344 2014-02-28 Richard Biener <rguenther@suse.de>
25345
25346 PR target/60280
25347 * tree-cfgcleanup.c (tree_forwarder_block_p): Restrict
25348 previous fix and only allow to remove trivial pre-headers
25349 and latches. Also honor LOOPS_MAY_HAVE_MULTIPLE_LATCHES.
25350 (remove_forwarder_block): Properly update the latch of a loop.
25351
25352 2014-02-28 Alexandre Oliva <aoliva@redhat.com>
25353
25354 PR debug/59992
25355 * cselib.c (cselib_hasher::equal): Special-case VALUE lookup.
25356 (cselib_preserved_hash_table): New.
25357 (preserve_constants_and_equivs): Move preserved vals to it.
25358 (cselib_find_slot): Look it up first.
25359 (cselib_init): Initialize it.
25360 (cselib_finish): Release it.
25361 (dump_cselib_table): Dump it.
25362
25363 2014-02-28 Alexandre Oliva <aoliva@redhat.com>
25364
25365 PR debug/59992
25366 * cselib.c (remove_useless_values): Skip to avoid quadratic
25367 behavior if the condition moved from...
25368 (cselib_process_insn): ... here holds.
25369
25370 2014-02-28 Alexandre Oliva <aoliva@redhat.com>
25371
25372 PR debug/57232
25373 * var-tracking.c (vt_initialize): Apply the same condition to
25374 preserve the CFA base value.
25375
25376 2014-02-28 Joey Ye <joey.ye@arm.com>
25377
25378 PR target/PR60169
25379 * config/arm/arm.c (thumb_far_jump_used_p): Don't change
25380 if reload in progress or completed.
25381
25382 2014-02-28 Tobias Burnus <burnus@net-b.de>
25383
25384 PR middle-end/60147
25385 * tree-pretty-print.c (dump_generic_node, print_declaration): Handle
25386 NAMELIST_DECL.
25387
25388 2014-02-27 H.J. Lu <hongjiu.lu@intel.com>
25389
25390 * doc/tm.texi.in (Condition Code Status): Update documention for
25391 relative locations of cc0-setter and cc0-user.
25392
25393 2014-02-27 Jeff Law <law@redhat.com>
25394
25395 PR rtl-optimization/52714
25396 * combine.c (try_combine): When splitting an unrecognized PARALLEL
25397 into two independent simple sets, if I3 is a jump, ensure the
25398 pattern we place into I3 is a (set (pc) ...).
25399
25400 2014-02-27 Mikael Pettersson <mikpe@it.uu.se>
25401 Jeff Law <law@redhat.com>
25402
25403 PR rtl-optimization/49847
25404 * cse.c (fold_rtx) Handle case where cc0 setter and cc0 user
25405 are in different blocks.
25406 * doc/tm.texi (Condition Code Status): Update documention for
25407 relative locations of cc0-setter and cc0-user.
25408
25409 2014-02-27 Vladimir Makarov <vmakarov@redhat.com>
25410
25411 PR target/59222
25412 * lra.c (lra_emit_add): Check SUBREG too.
25413
25414 2014-02-27 Andreas Schwab <schwab@suse.de>
25415
25416 * config/m68k/m68k.c (m68k_option_override): Disable
25417 -flive-range-shrinkage for classic m68k.
25418 (m68k_override_options_after_change): Likewise.
25419
25420 2014-02-27 Marek Polacek <polacek@redhat.com>
25421
25422 PR middle-end/59223
25423 * tree-ssa-uninit.c (gate_warn_uninitialized): Run the pass even for
25424 -Wmaybe-uninitialized.
25425
25426 2014-02-27 Alan Modra <amodra@gmail.com>
25427
25428 PR target/57936
25429 * reload1.c (emit_input_reload_insns): When reload_override_in,
25430 set old to rl->in_reg when rl->in_reg is a subreg.
25431
25432 2014-02-26 Richard Biener <rguenther@suse.de>
25433
25434 PR bootstrap/60343
25435 * lra-assigns.c (spill_for): Avoid mixed-sign comparison.
25436
25437 2014-02-25 Ilya Tocar <ilya.tocar@intel.com>
25438
25439 * common/config/i386/predicates.md (const1256_operand): Remove.
25440 (const2356_operand): New.
25441 (const_1_to_2_operand): Remove.
25442 * config/i386/sse.md (avx512pf_gatherpf<mode>sf): Change hint value.
25443 (*avx512pf_gatherpf<mode>sf_mask): Ditto.
25444 (*avx512pf_gatherpf<mode>sf): Ditto.
25445 (avx512pf_gatherpf<mode>df): Ditto.
25446 (*avx512pf_gatherpf<mode>df_mask): Ditto.
25447 (*avx512pf_gatherpf<mode>df): Ditto.
25448 (avx512pf_scatterpf<mode>sf): Ditto.
25449 (*avx512pf_scatterpf<mode>sf_mask): Ditto.
25450 (*avx512pf_scatterpf<mode>sf): Ditto.
25451 (avx512pf_scatterpf<mode>df): Ditto.
25452 (*avx512pf_scatterpf<mode>df_mask): Ditto.
25453 (*avx512pf_scatterpf<mode>df): Ditto.
25454 * common/config/i386/xmmintrin.h (_mm_hint): Add _MM_HINT_ET0.
25455
25456 2014-02-26 Ilya Tocar <ilya.tocar@intel.com>
25457
25458 * config/i386/avx512fintrin.h (_mm512_testn_epi32_mask),
25459 (_mm512_mask_testn_epi32_mask), (_mm512_testn_epi64_mask),
25460 (_mm512_mask_testn_epi64_mask): Move to ...
25461 * config/i386/avx512cdintrin.h: Here.
25462 * config/i386/i386.c (bdesc_args): Change MASK_ISA for testnm.
25463 * config/i386/sse.md (avx512f_vmscalef<mode><round_name>): Remove %.
25464 (avx512f_scalef<mode><mask_name><round_name>): Ditto.
25465 (avx512f_testnm<mode>3<mask_scalar_merge_name>): Change conditon to
25466 TARGET_AVX512F from TARGET_AVX512CD.
25467
25468 2014-02-26 Richard Biener <rguenther@suse.de>
25469
25470 PR ipa/60327
25471 * ipa.c (walk_polymorphic_call_targets): Properly guard
25472 call to inline_update_overall_summary.
25473
25474 2014-02-26 Bin Cheng <bin.cheng@arm.com>
25475
25476 PR target/60280
25477 * tree-cfgcleanup.c (tree_forwarder_block_p): Protect loop preheaders
25478 and latches only if requested. Fix latch if it is removed.
25479 * tree-ssa-dom.c (tree_ssa_dominator_optimize): Set
25480 LOOPS_HAVE_PREHEADERS.
25481
25482 2014-02-25 Andrew Pinski <apinski@cavium.com>
25483
25484 * builtins.c (expand_builtin_thread_pointer): Create a new target
25485 when the target is NULL.
25486
25487 2014-02-25 Vladimir Makarov <vmakarov@redhat.com>
25488
25489 PR rtl-optimization/60317
25490 * params.def (PARAM_LRA_MAX_CONSIDERED_RELOAD_PSEUDOS): New.
25491 * params.h (LRA_MAX_CONSIDERED_RELOAD_PSEUDOS): New.
25492 * lra-assigns.c: Include params.h.
25493 (spill_for): Use LRA_MAX_CONSIDERED_RELOAD_PSEUDOS as guard for
25494 other reload pseudos considerations.
25495
25496 2014-02-25 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
25497
25498 * config/rs6000/vector.md (*vector_unordered<mode>): Change split
25499 to use canonical form for nor<mode>3.
25500
25501 2014-02-25 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
25502
25503 PR target/55426
25504 * config/arm/arm.h (CANNOT_CHANGE_MODE_CLASS): Allow 128 to 64-bit
25505 conversions.
25506
25507 2014-02-25 Ilya Tocar <ilya.tocar@intel.com>
25508
25509 * common/config/i386/i386-common.c (OPTION_MASK_ISA_PREFETCHWT1_SET),
25510 (OPTION_MASK_ISA_PREFETCHWT1_UNSET): New.
25511 (ix86_handle_option): Handle OPT_mprefetchwt1.
25512 * config/i386/cpuid.h (bit_PREFETCHWT1): New.
25513 * config/i386/driver-i386.c (host_detect_local_cpu): Detect
25514 PREFETCHWT1 CPUID.
25515 * config/i386/i386-c.c (ix86_target_macros_internal): Handle
25516 OPTION_MASK_ISA_PREFETCHWT1.
25517 * config/i386/i386.c (ix86_target_string): Handle mprefetchwt1.
25518 (PTA_PREFETCHWT1): New.
25519 (ix86_option_override_internal): Handle PTA_PREFETCHWT1.
25520 (ix86_valid_target_attribute_inner_p): Handle OPT_mprefetchwt1.
25521 * config/i386/i386.h (TARGET_PREFETCHWT1, TARGET_PREFETCHWT1_P): New.
25522 * config/i386/i386.md (prefetch): Check TARGET_PREFETCHWT1
25523 (*prefetch_avx512pf_<mode>_: Change into ...
25524 (*prefetch_prefetchwt1_<mode>: This.
25525 * config/i386/i386.opt (mprefetchwt1): New.
25526 * config/i386/xmmintrin.h (_mm_hint): Add _MM_HINT_ET1.
25527 (_mm_prefetch): Handle intent to write.
25528 * doc/invoke.texi (mprefetchwt1), (mno-prefetchwt1): Doccument.
25529
25530 2014-02-25 Richard Biener <rguenther@suse.de>
25531
25532 PR middle-end/60291
25533 * emit-rtl.c (mem_attrs_htab): Remove.
25534 (mem_attrs_htab_hash): Likewise.
25535 (mem_attrs_htab_eq): Likewise.
25536 (set_mem_attrs): Always allocate new mem-attrs when something changed.
25537 (init_emit_once): Do not allocate mem_attrs_htab.
25538
25539 2014-02-25 Richard Biener <rguenther@suse.de>
25540
25541 PR lto/60319
25542 * lto-opts.c (lto_write_options): Output non-explicit conservative
25543 -fwrapv, -fno-trapv and -fno-strict-overflow.
25544 * lto-wrapper.c (merge_and_complain): Handle merging those options.
25545 (run_gcc): And pass them through.
25546
25547 2014-02-25 Andrey Belevantsev <abel@ispras.ru>
25548
25549 * sel-sched.c (calculate_new_fences): New parameter ptime.
25550 Calculate it as a maximum over all fence cycles.
25551 (sel_sched_region_2): Adjust the call to calculate_new_fences.
25552 Print the final schedule timing when sched_verbose.
25553
25554 2014-02-25 Andrey Belevantsev <abel@ispras.ru>
25555
25556 PR rtl-optimization/60292
25557 * sel-sched.c (fill_vec_av_set): Do not reset target availability
25558 bit fot the fence instruction.
25559
25560 2014-02-24 Alangi Derick <alangiderick@gmail.com>
25561
25562 * calls.h: Fix typo in comment.
25563
25564 2014-02-24 John David Anglin <danglin@gcc.gnu.org>
25565
25566 * config/pa/pa.c (pa_output_move_double): Don't valididate when
25567 adjusting offsetable addresses.
25568
25569 2014-02-24 Guozhi Wei <carrot@google.com>
25570
25571 * sparseset.h (sparseset_pop): Fix the wrong index.
25572
25573 2014-02-24 Walter Lee <walt@tilera.com>
25574
25575 * config.gcc (tilepro-*-*): Change to tilepro*-*-*.
25576 (tilegx-*-linux*): Change to tilegx*-*-linux*; Support tilegxbe
25577 triplet.
25578 * common/config/tilegx/tilegx-common.c
25579 (TARGET_DEFAULT_TARGET_FLAGS): Define.
25580 * config/tilegx/linux.h (ASM_SPEC): Add endian_spec.
25581 (LINK_SPEC): Ditto.
25582 * config/tilegx/sync.md (atomic_test_and_set): Handle big endian.
25583 * config/tilegx/tilegx.c (tilegx_return_in_msb): New.
25584 (tilegx_gimplify_va_arg_expr): Handle big endian.
25585 (tilegx_expand_unaligned_load): Ditto.
25586 (tilegx_expand_unaligned_store): Ditto.
25587 (TARGET_RETURN_IN_MSB): New.
25588 * config/tilegx/tilegx.h (TARGET_DEFAULT): New.
25589 (TARGET_ENDIAN_DEFAULT): New.
25590 (TARGET_BIG_ENDIAN): Handle big endian.
25591 (BYTES_BIG_ENDIAN): Ditto.
25592 (WORDS_BIG_ENDIAN): Ditto.
25593 (FLOAT_WORDS_BIG_ENDIAN): Ditto.
25594 (ENDIAN_SPEC): New.
25595 (EXTRA_SPECS): New.
25596 * config/tilegx/tilegx.md (extv): Handle big endian.
25597 (extzv): Ditto.
25598 (insn_st<n>): Ditto.
25599 (insn_st<n>_add<bitsuffix>): Ditto.
25600 (insn_stnt<n>): Ditto.
25601 (insn_stnt<n>_add<bitsuffix>):Ditto.
25602 (vec_interleave_highv8qi): Handle big endian.
25603 (vec_interleave_highv8qi_be): New.
25604 (vec_interleave_highv8qi_le): New.
25605 (insn_v1int_h): Handle big endian.
25606 (vec_interleave_lowv8qi): Handle big endian.
25607 (vec_interleave_lowv8qi_be): New.
25608 (vec_interleave_lowv8qi_le): New.
25609 (insn_v1int_l): Handle big endian.
25610 (vec_interleave_highv4hi): Handle big endian.
25611 (vec_interleave_highv4hi_be): New.
25612 (vec_interleave_highv4hi_le): New.
25613 (insn_v2int_h): Handle big endian.
25614 (vec_interleave_lowv4hi): Handle big endian.
25615 (vec_interleave_lowv4hi_be): New.
25616 (vec_interleave_lowv4hi_le): New.
25617 (insn_v2int_l): Handle big endian.
25618 (vec_interleave_highv2si): Handle big endian.
25619 (vec_interleave_highv2si_be): New.
25620 (vec_interleave_highv2si_le): New.
25621 (insn_v4int_h): Handle big endian.
25622 (vec_interleave_lowv2si): Handle big endian.
25623 (vec_interleave_lowv2si_be): New.
25624 (vec_interleave_lowv2si_le): New.
25625 (insn_v4int_l): Handle big endian.
25626 * config/tilegx/tilegx.opt (mbig-endian): New option.
25627 (mlittle-endian): New option.
25628 * doc/install.texi: Document tilegxbe-linux.
25629 * doc/invoke.texi: Document -mbig-endian and -mlittle-endian.
25630
25631 2014-02-24 Martin Jambor <mjambor@suse.cz>
25632
25633 PR ipa/60266
25634 * ipa-cp.c (propagate_constants_accross_call): Bail out early if
25635 there are no parameter descriptors.
25636
25637 2014-02-24 Andrey Belevantsev <abel@ispras.ru>
25638
25639 PR rtl-optimization/60268
25640 * sched-rgn.c (haifa_find_rgns): Move the nr_regions_initial variable
25641 initialization to ...
25642 (sched_rgn_init): ... here.
25643 (schedule_region): Check for SCHED_PRESSURE_NONE earlier.
25644
25645 2014-02-23 David Holsgrove <david.holsgrove@xilinx.com>
25646
25647 * config/microblaze/microblaze.md: Correct ashrsi_reg / lshrsi_reg
25648 names.
25649
25650 2014-02-23 Edgar E. Iglesias <edgar.iglesias@xilinx.com>
25651
25652 * config/microblaze/microblaze.h: Remove SECONDARY_MEMORY_NEEDED
25653 definition.
25654
25655 2014-02-23 David Holsgrove <david.holsgrove@xilinx.com>
25656
25657 * /config/microblaze/microblaze.c: Add microblaze_asm_output_mi_thunk,
25658 define TARGET_ASM_OUTPUT_MI_THUNK and TARGET_ASM_CAN_OUTPUT_MI_THUNK.
25659
25660 2014-02-23 David Holsgrove <david.holsgrove@xilinx.com>
25661
25662 * config/microblaze/predicates.md: Add cmp_op predicate.
25663 * config/microblaze/microblaze.md: Add branch_compare instruction
25664 which uses cmp_op predicate and emits cmp insn before branch.
25665 * config/microblaze/microblaze.c (microblaze_emit_compare): Rename
25666 to microblaze_expand_conditional_branch and consolidate logic.
25667 (microblaze_expand_conditional_branch): emit branch_compare
25668 insn instead of handling cmp op separate from branch insn.
25669
25670 2014-02-23 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
25671
25672 * config/rs6000/rs6000.c (rs6000_emit_le_vsx_move): Relax assert
25673 to permit subregs.
25674
25675 2014-02-23 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
25676
25677 * config/rs6000/altivec.md (altivec_lve<VI_char>x): Replace
25678 define_insn with define_expand and new define_insn
25679 *altivec_lve<VI_char>x_internal.
25680 (altivec_stve<VI_char>x): Replace define_insn with define_expand
25681 and new define_insn *altivec_stve<VI_char>x_internal.
25682 * config/rs6000/rs6000-protos.h (altivec_expand_stvex_be): New
25683 prototype.
25684 * config/rs6000/rs6000.c (altivec_expand_lvx_be): Document use by
25685 lve*x built-ins.
25686 (altivec_expand_stvex_be): New function.
25687
25688 2014-02-22 Joern Rennecke <joern.rennecke@embecosm.com>
25689
25690 * config/avr/avr.c (avr_can_eliminate): Allow elimination from
25691 ARG_POINTER_REGNUM to STACK_POINTER_REGNUM if !frame_pointer_needed.
25692 * config/avr/avr.c (ELIMINABLE_REGS): Add elimination from
25693 ARG_POINTER_REGNUM to STACK_POINTER_REGNUM.
25694
25695 2014-02-21 Vladimir Makarov <vmakarov@redhat.com>
25696
25697 PR target/60298
25698 * lra-constraints.c (inherit_reload_reg): Use lra_emit_move
25699 instead of emit_move_insn.
25700
25701 2014-02-21 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
25702
25703 * config/rs6000/altivec.md (altivec_vsumsws): Replace second
25704 vspltw with vsldoi.
25705 (reduc_uplus_v16qi): Use gen_altivec_vsumsws_direct instead of
25706 gen_altivec_vsumsws.
25707
25708 2014-02-21 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
25709
25710 * config/rs6000/altivec.md (altivec_lvxl): Rename as
25711 *altivec_lvxl_<mode>_internal and use VM2 iterator instead of V4SI.
25712 (altivec_lvxl_<mode>): New define_expand incorporating
25713 -maltivec=be semantics where needed.
25714 (altivec_lvx): Rename as *altivec_lvx_<mode>_internal.
25715 (altivec_lvx_<mode>): New define_expand incorporating -maltivec=be
25716 semantics where needed.
25717 (altivec_stvx): Rename as *altivec_stvx_<mode>_internal.
25718 (altivec_stvx_<mode>): New define_expand incorporating
25719 -maltivec=be semantics where needed.
25720 (altivec_stvxl): Rename as *altivec_stvxl_<mode>_internal and use
25721 VM2 iterator instead of V4SI.
25722 (altivec_stvxl_<mode>): New define_expand incorporating
25723 -maltivec=be semantics where needed.
25724 * config/rs6000/rs6000-builtin.def: Add new built-in definitions
25725 LVXL_V2DF, LVXL_V2DI, LVXL_V4SF, LVXL_V4SI, LVXL_V8HI, LVXL_V16QI,
25726 LVX_V2DF, LVX_V2DI, LVX_V4SF, LVX_V4SI, LVX_V8HI, LVX_V16QI, STVX_V2DF,
25727 STVX_V2DI, STVX_V4SF, STVX_V4SI, STVX_V8HI, STVX_V16QI, STVXL_V2DF,
25728 STVXL_V2DI, STVXL_V4SF, STVXL_V4SI, STVXL_V8HI, STVXL_V16QI.
25729 * config/rs6000/rs6000-c.c (altivec_overloaded_builtins): Replace
25730 ALTIVEC_BUILTIN_LVX with ALTIVEC_BUILTIN_LVX_<MODE> throughout;
25731 similarly for ALTIVEC_BUILTIN_LVXL, ALTIVEC_BUILTIN_STVX, and
25732 ALTIVEC_BUILTIN_STVXL.
25733 * config/rs6000/rs6000-protos.h (altivec_expand_lvx_be): New prototype.
25734 (altivec_expand_stvx_be): Likewise.
25735 * config/rs6000/rs6000.c (swap_selector_for_mode): New function.
25736 (altivec_expand_lvx_be): Likewise.
25737 (altivec_expand_stvx_be): Likewise.
25738 (altivec_expand_builtin): Add cases for
25739 ALTIVEC_BUILTIN_STVX_<MODE>, ALTIVEC_BUILTIN_STVXL_<MODE>,
25740 ALTIVEC_BUILTIN_LVXL_<MODE>, and ALTIVEC_BUILTIN_LVX_<MODE>.
25741 (altivec_init_builtins): Add definitions for
25742 __builtin_altivec_lvxl_<mode>, __builtin_altivec_lvx_<mode>,
25743 __builtin_altivec_stvx_<mode>, and __builtin_altivec_stvxl_<mode>.
25744
25745 2014-02-21 Catherine Moore <clm@codesourcery.com>
25746
25747 * doc/invoke.texi (mvirt, mno-virt): Document.
25748 * config/mips/mips.opt (mvirt): New option.
25749 * config/mips/mips.h (ASM_SPEC): Pass mvirt to the assembler.
25750
25751 2014-02-21 Richard Biener <rguenther@suse.de>
25752
25753 PR tree-optimization/60276
25754 * tree-vectorizer.h (struct _stmt_vec_info): Add min_neg_dist field.
25755 (STMT_VINFO_MIN_NEG_DIST): New macro.
25756 * tree-vect-data-refs.c (vect_analyze_data_ref_dependence): Record
25757 STMT_VINFO_MIN_NEG_DIST.
25758 * tree-vect-stmts.c (vectorizable_load): Verify if assumptions
25759 made for negative dependence distances still hold.
25760
25761 2014-02-21 Richard Biener <rguenther@suse.de>
25762
25763 PR middle-end/60291
25764 * tree-ssa-live.c (mark_all_vars_used_1): Do not walk
25765 DECL_INITIAL for globals not in the current function context.
25766
25767 2014-02-21 Jakub Jelinek <jakub@redhat.com>
25768
25769 PR tree-optimization/56490
25770 * params.def (PARAM_UNINIT_CONTROL_DEP_ATTEMPTS): New param.
25771 * tree-ssa-uninit.c: Include params.h.
25772 (compute_control_dep_chain): Add num_calls argument, return false
25773 if it exceed PARAM_UNINIT_CONTROL_DEP_ATTEMPTS param, pass
25774 num_calls to recursive call.
25775 (find_predicates): Change dep_chain into normal array,
25776 cur_chain into auto_vec<edge, MAX_CHAIN_LEN + 1>, add num_calls
25777 variable and adjust compute_control_dep_chain caller.
25778 (find_def_preds): Likewise.
25779
25780 2014-02-21 Thomas Schwinge <thomas@codesourcery.com>
25781
25782 * gimple-pretty-print.c (dump_gimple_omp_for) [flags & TDF_RAW]
25783 <case GF_OMP_FOR_KIND_CILKSIMD>: Add missing break statement.
25784
25785 2014-02-21 Nick Clifton <nickc@redhat.com>
25786
25787 * config/stormy16/stormy16.md (pushdqi1): Add mode to post_inc.
25788 (pushhi1): Likewise.
25789 (popqi1): Add mode to pre_dec.
25790 (pophi1): Likewise.
25791
25792 2014-02-21 Jakub Jelinek <jakub@redhat.com>
25793
25794 * config/i386/i386.c (ix86_expand_vec_perm): Use V8SImode
25795 mode for mask of V8SFmode permutation.
25796
25797 2014-02-20 Richard Henderson <rth@redhat.com>
25798
25799 PR c++/60272
25800 * builtins.c (expand_builtin_atomic_compare_exchange): Always make
25801 a new pseudo for OLDVAL.
25802
25803 2014-02-20 Jakub Jelinek <jakub@redhat.com>
25804
25805 PR target/57896
25806 * config/i386/i386.c (expand_vec_perm_interleave2): Don't call
25807 gen_reg_rtx if d->testing_p.
25808 (expand_vec_perm_pshufb2, expand_vec_perm_broadcast_1): Return early
25809 if d->testing_p and we will certainly return true.
25810 (expand_vec_perm_even_odd_1): Likewise. Don't call gen_reg_rtx
25811 if d->testing_p.
25812
25813 2014-02-20 Uros Bizjak <ubizjak@gmail.com>
25814
25815 * emit-rtl.c (gen_reg_rtx): Assert that
25816 crtl->emit.regno_pointer_align_length is non-zero.
25817
25818 2014-02-20 Richard Henderson <rth@redhat.com>
25819
25820 PR c++/60272
25821 * builtins.c (expand_builtin_atomic_compare_exchange): Conditionalize
25822 on failure the store back into EXPECT.
25823
25824 2014-02-20 Chung-Lin Tang <cltang@codesourcery.com>
25825 Sandra Loosemore <sandra@codesourcery.com>
25826
25827 * config/nios2/nios2.md (unspec): Add UNSPEC_PIC_GOTOFF_SYM enum.
25828 * config/nios2/nios2.c (nios2_function_profiler): Add
25829 -fPIC (flag_pic == 2) support.
25830 (nios2_handle_custom_fpu_cfg): Fix warning parameter.
25831 (nios2_large_offset_p): New function.
25832 (nios2_unspec_reloc_p): Move up position, update to use
25833 nios2_large_offset_p.
25834 (nios2_unspec_address): Remove function.
25835 (nios2_unspec_offset): New function.
25836 (nios2_large_got_address): New function.
25837 (nios2_got_address): Add large offset support.
25838 (nios2_legitimize_tls_address): Update usage of removed and new
25839 functions.
25840 (nios2_symbol_binds_local_p): New function.
25841 (nios2_load_pic_address): Add -fPIC (flag_pic == 2) support.
25842 (nios2_legitimize_address): Update to use nios2_large_offset_p.
25843 (nios2_emit_move_sequence): Avoid legitimizing (const (unspec ...)).
25844 (nios2_print_operand): Merge H/L processing, add hiadj/lo
25845 processing for (const (unspec ...)).
25846 (nios2_unspec_reloc_name): Add UNSPEC_PIC_GOTOFF_SYM case.
25847
25848 2014-02-20 Richard Biener <rguenther@suse.de>
25849
25850 * tree-cfg.c (replace_uses_by): Mark altered BBs before
25851 doing the substitution.
25852 (verify_gimple_assign_single): Also verify bare MEM_REFs on the lhs.
25853
25854 2014-02-20 Martin Jambor <mjambor@suse.cz>
25855
25856 PR ipa/55260
25857 * ipa-cp.c (cgraph_edge_brings_all_agg_vals_for_node): Uce correct
25858 info when checking whether lattices are bottom.
25859
25860 2014-02-20 Richard Biener <rguenther@suse.de>
25861
25862 PR middle-end/60221
25863 * tree-eh.c (execute_cleanup_eh_1): Also cleanup empty EH
25864 regions at -O0.
25865
25866 2014-02-20 Jan Hubicka <hubicka@ucw.cz>
25867
25868 PR ipa/58555
25869 * ipa-inline-transform.c (clone_inlined_nodes): Add freq_scale
25870 parameter specifying the scaling.
25871 (inline_call): Update.
25872 (want_inline_recursively): Guard division by zero.
25873 (recursive_inlining): Update.
25874 * ipa-inline.h (clone_inlined_nodes): Update.
25875
25876 2014-02-20 Ilya Tocar <ilya.tocar@intel.com>
25877
25878 PR target/60204
25879 * config/i386/i386.c (classify_argument): Pass structures of size
25880 64 bytes or less in register.
25881
25882 2014-02-20 Ilya Tocar <ilya.tocar@intel.com>
25883 Kirill Yukhin <kirill.yukhin@intel.com>
25884
25885 * config/i386/avx512erintrin.h (_mm_rcp28_round_sd): Swap operands.
25886 (_mm_rcp28_round_ss): Ditto.
25887 (_mm_rsqrt28_round_sd): Ditto.
25888 (_mm_rsqrt28_round_ss): Ditto.
25889 * config/i386/avx512erintrin.h (_mm_rcp14_round_sd): Ditto.
25890 (_mm_rcp14_round_ss): Ditto.
25891 (_mm_rsqrt14_round_sd): Ditto.
25892 (_mm_rsqrt14_round_ss): Ditto.
25893 * config/i386/sse.md (rsqrt14<mode>): Put nonimmediate operand as
25894 the first input operand, get rid of match_dup.
25895 (avx512er_exp2<mode><mask_name><round_saeonly_name>): Set type
25896 attribute to sse.
25897 (<mask_codefor>avx512er_rcp28<mode><mask_name><round_saeonly_name>):
25898 Ditto.
25899 (avx512er_vmrcp28<mode><round_saeonly_name>): Put nonimmediate
25900 operand as the first input operand, set type attribute.
25901 (<mask_codefor>avx512er_rsqrt28<mode><mask_name><round_saeonly_name>):
25902 Set type attribute.
25903 (avx512er_vmrsqrt28<mode><round_saeonly_name>): Put nonimmediate
25904 operand as the first input operand, set type attribute.
25905
25906 2014-02-19 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
25907
25908 * config/rs6000/rs6000.c (vspltis_constant): Fix most significant
25909 bit of zero.
25910
25911 2014-02-19 H.J. Lu <hongjiu.lu@intel.com>
25912
25913 PR target/60207
25914 * config/i386/i386.c (construct_container): Remove TFmode check
25915 for X86_64_INTEGER_CLASS.
25916
25917 2014-02-19 Uros Bizjak <ubizjak@gmail.com>
25918
25919 PR target/59794
25920 * config/i386/i386.c (type_natural_mode): Warn for ABI changes
25921 only when -Wpsabi is enabled.
25922
25923 2014-02-19 Michael Hudson-Doyle <michael.hudson@linaro.org>
25924
25925 PR target/59799
25926 * config/aarch64/aarch64.c (aarch64_pass_by_reference): The rules for
25927 passing arrays in registers are the same as for structs, so remove the
25928 special case for them.
25929
25930 2014-02-19 Eric Botcazou <ebotcazou@adacore.com>
25931
25932 * expr.c (expand_expr_real_1) <case VIEW_CONVERT_EXPR>: For a bit-field
25933 destination type, extract only the valid bits if the source type is not
25934 integral and has a different mode.
25935
25936 2014-02-19 Richard Biener <rguenther@suse.de>
25937
25938 PR ipa/60243
25939 * tree-inline.c (estimate_num_insns): Avoid calling cgraph_get_node
25940 for all calls.
25941
25942 2014-02-19 Richard Biener <rguenther@suse.de>
25943
25944 PR ipa/60243
25945 * ipa-prop.c: Include stringpool.h and tree-ssanames.h.
25946 (ipa_modify_call_arguments): Emit an argument load explicitely and
25947 preserve virtual SSA form there and for the replacement call.
25948 Do not update SSA form nor free dominance info.
25949
25950 2014-02-18 Jan Hubicka <hubicka@ucw.cz>
25951
25952 * ipa.c (function_and_variable_visibility): Also clear WEAK
25953 flag when disolving COMDAT_GROUP.
25954
25955 2014-02-18 Jan Hubicka <hubicka@ucw.cz>
25956
25957 * ipa-prop.h (ipa_ancestor_jf_data): Update ocmment.
25958 * ipa-prop.c (ipa_set_jf_known_type): Return early when
25959 not devirtualizing.
25960 (ipa_set_ancestor_jf): Set type to NULL hwen it is not preserved;
25961 do more sanity checks.
25962 (detect_type_change): Return true when giving up early.
25963 (compute_complex_assign_jump_func): Fix type parameter of
25964 ipa_set_ancestor_jf.
25965 (compute_complex_ancestor_jump_func): Likewise.
25966 (update_jump_functions_after_inlining): Fix updating of
25967 ancestor function.
25968 * ipa-cp.c (ipa_get_jf_ancestor_result): Be ready for type to be NULL.
25969
25970 2014-02-18 Jan Hubicka <hubicka@ucw.cz>
25971
25972 * cgraph.c (cgraph_update_edges_for_call_stmt_node): Also remove
25973 inline clones when edge disappears.
25974
25975 2014-02-18 Michael Meissner <meissner@linux.vnet.ibm.com>
25976
25977 PR target/60203
25978 * config/rs6000/rs6000.md (mov<mode>_64bit, TF/TDmode moves):
25979 Split 64-bit moves into 2 patterns. Do not allow the use of
25980 direct move for TDmode in little endian, since the decimal value
25981 has little endian bytes within a word, but the 64-bit pieces are
25982 ordered in a big endian fashion, and normal subreg's of TDmode are
25983 not allowed.
25984 (mov<mode>_64bit_dm): Likewise.
25985 (movtd_64bit_nodm): Likewise.
25986
25987 2014-02-18 Eric Botcazou <ebotcazou@adacore.com>
25988
25989 PR tree-optimization/60174
25990 * tree-ssa-reassoc.c (init_range_entry): Do not look into the defining
25991 statement of an SSA_NAME that occurs in an abnormal PHI node.
25992
25993 2014-02-18 Jakub Jelinek <jakub@redhat.com>
25994
25995 PR sanitizer/60142
25996 * final.c (SEEN_BB): Remove.
25997 (SEEN_NOTE, SEEN_EMITTED): Renumber.
25998 (final_scan_insn): Don't force_source_line on second
25999 NOTE_INSN_BASIC_BLOCK.
26000
26001 2014-02-18 Uros Bizjak <ubizjak@gmail.com>
26002
26003 PR target/60205
26004 * config/i386/i386.h (struct ix86_args): Add warn_avx512f.
26005 * config/i386/i386.c (init_cumulative_args): Initialize warn_avx512f.
26006 (type_natural_mode): Warn ABI change when %zmm register is not
26007 available for AVX512F vector value passing.
26008
26009 2014-02-18 Kai Tietz <ktietz@redhat.com>
26010
26011 PR target/60193
26012 * config/i386/i386.c (ix86_expand_prologue): Use value in
26013 rax register as displacement when restoring %r10 or %rax.
26014 Fix wrong offset when restoring both registers.
26015
26016 2014-02-18 Eric Botcazou <ebotcazou@adacore.com>
26017
26018 * ipa-prop.c (compute_complex_ancestor_jump_func): Replace overzealous
26019 assertion with conditional return.
26020
26021 2014-02-18 Jakub Jelinek <jakub@redhat.com>
26022 Uros Bizjak <ubizjak@gmail.com>
26023
26024 PR driver/60233
26025 * config/i386/driver-i386.c (host_detect_local_cpu): If
26026 YMM state is not saved by the OS, also clear has_f16c. Move
26027 CPUID 0x80000001 handling before YMM state saving checking.
26028
26029 2014-02-18 Andrey Belevantsev <abel@ispras.ru>
26030
26031 PR rtl-optimization/58960
26032 * haifa-sched.c (alloc_global_sched_pressure_data): New,
26033 factored out from ...
26034 (sched_init): ... here.
26035 (free_global_sched_pressure_data): New, factored out from ...
26036 (sched_finish): ... here.
26037 * sched-int.h (free_global_sched_pressure_data): Declare.
26038 * sched-rgn.c (nr_regions_initial): New static global.
26039 (haifa_find_rgns): Initialize it.
26040 (schedule_region): Disable sched-pressure for the newly
26041 generated regions.
26042
26043 2014-02-17 Richard Biener <rguenther@suse.de>
26044
26045 * tree-vect-stmts.c (free_stmt_vec_info): Clear BB and
26046 release SSA defs of pattern stmts.
26047
26048 2014-02-17 Richard Biener <rguenther@suse.de>
26049
26050 * tree-inline.c (expand_call_inline): Release the virtual
26051 operand defined by the call we are about to inline.
26052
26053 2014-02-17 Richard Biener <rguenther@suse.de>
26054
26055 * tree-ssa.c (verify_ssa): If verify_def found an error, ICE.
26056
26057 2014-02-17 Kirill Yukhin <kirill.yukhin@intel.com>
26058 Ilya Tocar <ilya.tocar@intel.com>
26059
26060 * config/i386/avx512fintrin.h (_mm512_maskz_permutexvar_epi64): Swap
26061 arguments order in builtin.
26062 (_mm512_permutexvar_epi64): Ditto.
26063 (_mm512_mask_permutexvar_epi64): Ditto
26064 (_mm512_maskz_permutexvar_epi32): Ditto
26065 (_mm512_permutexvar_epi32): Ditto
26066 (_mm512_mask_permutexvar_epi32): Ditto
26067
26068 2014-02-16 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
26069
26070 * config/rs6000/altivec.md (p8_vmrgew): Handle little endian targets.
26071 (p8_vmrgow): Likewise.
26072
26073 2014-02-16 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
26074
26075 * config/rs6000/vsx.md (vsx_xxpermdi_<mode>): Handle little
26076 endian targets.
26077
26078 2014-02-15 Michael Meissner <meissner@linux.vnet.ibm.com>
26079
26080 PR target/60203
26081 * config/rs6000/rs6000.md (rreg): Add TFmode, TDmode constraints.
26082 (mov<mode>_internal, TFmode/TDmode): Split TFmode/TDmode moves
26083 into 64-bit and 32-bit moves. On 64-bit moves, add support for
26084 using direct move instructions on ISA 2.07. Also adjust
26085 instruction length for 64-bit.
26086 (mov<mode>_64bit, TFmode/TDmode): Likewise.
26087 (mov<mode>_32bit, TFmode/TDmode): Likewise.
26088
26089 2014-02-15 Alan Modra <amodra@gmail.com>
26090
26091 PR target/58675
26092 PR target/57935
26093 * config/rs6000/rs6000.c (rs6000_secondary_reload_inner): Use
26094 find_replacement on parts of insn rtl that might be reloaded.
26095
26096 2014-02-15 Richard Biener <rguenther@suse.de>
26097
26098 PR tree-optimization/60183
26099 * tree-ssa-phiprop.c (propagate_with_phi): Avoid speculating loads.
26100 (tree_ssa_phiprop): Calculate and free post-dominators.
26101
26102 2014-02-14 Jeff Law <law@redhat.com>
26103
26104 PR rtl-optimization/60131
26105 * ree.c (get_extended_src_reg): New function.
26106 (combine_reaching_defs): Use it rather than assuming location of REG.
26107 (find_and_remove_re): Verify first operand of extension is
26108 a REG before adding the insns to the copy list.
26109
26110 2014-02-14 Roland McGrath <mcgrathr@google.com>
26111
26112 * configure.ac (HAVE_AS_IX86_UD2): New test for 'ud2' mnemonic.
26113 * configure: Regenerated.
26114 * config.in: Regenerated.
26115 * config/i386/i386.md (trap) [HAVE_AS_IX86_UD2]: Use the mnemonic
26116 instead of ASM_SHORT.
26117
26118 2014-02-14 Vladimir Makarov <vmakarov@redhat.com>
26119 Richard Earnshaw <rearnsha@arm.com>
26120
26121 PR rtl-optimization/59535
26122 * lra-constraints.c (process_alt_operands): Encourage alternative
26123 when unassigned pseudo class is superset of the alternative class.
26124 (inherit_reload_reg): Don't inherit when optimizing for code size.
26125 * config/arm/arm.h (MODE_BASE_REG_CLASS): Add version for LRA
26126 returning CORE_REGS for anything but Thumb1 and BASE_REGS for
26127 modes not less than 4 for Thumb1.
26128
26129 2014-02-14 Kyle McMartin <kyle@redhat.com>
26130
26131 PR pch/60010
26132 * config/host-linux.c (TRY_EMPTY_VM_SPACE): Define for AArch64.
26133
26134 2014-02-14 Richard Biener <rguenther@suse.de>
26135
26136 * cilk-common.c (cilk_arrow): Build a MEM_REF, not an INDIRECT_REF.
26137 (get_frame_arg): Drop the assert with langhook types_compatible_p.
26138 Do not strip INDIRECT_REFs.
26139
26140 2014-02-14 Richard Biener <rguenther@suse.de>
26141
26142 PR lto/60179
26143 * lto-streamer-out.c (DFS_write_tree_body): Do not follow
26144 DECL_FUNCTION_SPECIFIC_TARGET.
26145 (hash_tree): Do not hash DECL_FUNCTION_SPECIFIC_TARGET.
26146 * tree-streamer-out.c (pack_ts_target_option): Remove.
26147 (streamer_pack_tree_bitfields): Do not stream TS_TARGET_OPTION.
26148 (write_ts_function_decl_tree_pointers): Do not stream
26149 DECL_FUNCTION_SPECIFIC_TARGET.
26150 * tree-streamer-in.c (unpack_ts_target_option): Remove.
26151 (unpack_value_fields): Do not stream TS_TARGET_OPTION.
26152 (lto_input_ts_function_decl_tree_pointers): Do not stream
26153 DECL_FUNCTION_SPECIFIC_TARGET.
26154
26155 2014-02-14 Jakub Jelinek <jakub@redhat.com>
26156
26157 * tree-vect-loop.c (vect_is_slp_reduction): Don't set use_stmt twice.
26158 (get_initial_def_for_induction, vectorizable_induction): Ignore
26159 debug stmts when looking for exit_phi.
26160 (vectorizable_live_operation): Fix up condition.
26161
26162 2014-02-14 Chung-Ju Wu <jasonwucj@gmail.com>
26163
26164 * config/nds32/nds32.c (nds32_asm_function_prologue): Do not use
26165 nreverse() because it changes the content of original tree list.
26166
26167 2014-02-14 Chung-Ju Wu <jasonwucj@gmail.com>
26168
26169 * config/nds32/t-mlibs (MULTILIB_OPTIONS): Fix typo in comment.
26170 * config/nds32/nds32.c (nds32_merge_decl_attributes): Likewise.
26171
26172 2014-02-14 Chung-Ju Wu <jasonwucj@gmail.com>
26173
26174 * config/nds32/nds32.c (nds32_naked_function_p): Follow the
26175 GNU coding standards.
26176
26177 2014-02-13 Jakub Jelinek <jakub@redhat.com>
26178
26179 PR debug/60152
26180 * dwarf2out.c (gen_subprogram_die): Don't call
26181 add_calling_convention_attribute if subr_die is old_die.
26182
26183 2014-02-13 Sharad Singhai <singhai@google.com>
26184
26185 * doc/optinfo.texi: Fix order of nodes.
26186
26187 2014-02-13 Uros Bizjak <ubizjak@gmail.com>
26188
26189 * config/i386/sse.md (xop_vmfrcz<mode>2): Generate const0 in
26190 operands[2], not operands[3].
26191
26192 2014-02-13 Richard Biener <rguenther@suse.de>
26193
26194 PR bootstrap/59878
26195 * doc/install.texi (ISL): Update recommended version to 0.12.2,
26196 mention the possibility of an in-tree build.
26197 (CLooG): Update recommended version to 0.18.1, mention the
26198 possibility of an in-tree build and clarify that the ISL
26199 bundled with CLooG does not work.
26200
26201 2014-02-13 Jakub Jelinek <jakub@redhat.com>
26202
26203 PR target/43546
26204 * expr.c (compress_float_constant): If x is a hard register,
26205 extend into a pseudo and then move to x.
26206
26207 2014-02-13 Dominik Vogt <vogt@linux.vnet.ibm.com>
26208
26209 * config/s390/s390.c (s390_asm_output_function_label): Fix crash
26210 caused by bad second argument to warning_at() with -mhotpatch and
26211 nested functions (e.g. with gfortran).
26212
26213 2014-02-13 Richard Sandiford <rdsandiford@googlemail.com>
26214
26215 * opts.c (option_name): Remove "enabled by default" rider.
26216
26217 2014-02-12 John David Anglin <danglin@gcc.gnu.org>
26218
26219 * config/pa/pa.c (pa_option_override): Remove auto increment FIXME.
26220
26221 2014-02-12 H.J. Lu <hongjiu.lu@intel.com>
26222 Uros Bizjak <ubizjak@gmail.com>
26223
26224 PR target/60151
26225 * configure.ac (HAVE_AS_GOTOFF_IN_DATA): Pass --32 to GNU assembler.
26226 * configure: Regenerated.
26227
26228 2014-02-12 Richard Biener <rguenther@suse.de>
26229
26230 * vec.c (vec_prefix::calculate_allocation): Move as
26231 inline variant to vec.h.
26232 (vec_prefix::calculate_allocation_1): New out-of-line version.
26233 * vec.h (vec_prefix::calculate_allocation_1): Declare.
26234 (vec_prefix::m_has_auto_buf): Rename to ...
26235 (vec_prefix::m_using_auto_storage): ... this.
26236 (vec_prefix::calculate_allocation): Inline the easy cases
26237 and dispatch to calculate_allocation_1 which doesn't need the
26238 prefix address.
26239 (va_heap::reserve): Use gcc_checking_assert.
26240 (vec<T, A, vl_embed>::embedded_init): Add argument to initialize
26241 m_using_auto_storage.
26242 (auto_vec): Change m_vecpfx member to a vec<T, va_heap, vl_embed>
26243 member and adjust.
26244 (vec<T, va_heap, vl_ptr>::reserve): Remove redundant check.
26245 (vec<T, va_heap, vl_ptr>::release): Avoid casting.
26246 (vec<T, va_heap, vl_ptr>::using_auto_storage): Simplify.
26247
26248 2014-02-12 Richard Biener <rguenther@suse.de>
26249
26250 * gcse.c (compute_transp): break from loop over canon_modify_mem_list
26251 when we found a dependence.
26252
26253 2014-02-12 Thomas Schwinge <thomas@codesourcery.com>
26254
26255 * gimplify.c (gimplify_call_expr, gimplify_modify_expr): Move
26256 common code...
26257 (maybe_fold_stmt): ... into this new function.
26258 * omp-low.c (lower_omp): Update comment.
26259
26260 * omp-low.c (lower_omp_target): Add clobber for sizes array, after
26261 last use.
26262
26263 * omp-low.c (diagnose_sb_0): Make sure label_ctx is valid to
26264 dereference.
26265
26266 2014-02-12 James Greenhalgh <james.greenhalgh@arm.com>
26267
26268 * config/arm/aarch-cost-tables.h (generic_extra_costs): Fix
26269 identifiers in comments.
26270 (cortexa53_extra_costs): Likewise.
26271 * config/arm/arm.c (cortexa9_extra_costs): Fix identifiers in comments.
26272 (cortexa7_extra_costs): Likewise.
26273 (cortexa12_extra_costs): Likewise.
26274 (cortexa15_extra_costs): Likewise.
26275 (v7m_extra_costs): Likewise.
26276
26277 2014-02-12 Richard Biener <rguenther@suse.de>
26278
26279 PR middle-end/60092
26280 * gimple-low.c (lower_builtin_posix_memalign): Lower conditional
26281 of posix_memalign being successful.
26282 (lower_stmt): Restrict lowering of posix_memalign to when
26283 -ftree-bit-ccp is enabled.
26284
26285 2014-02-12 Senthil Kumar Selvaraj <senthil_kumar.selvaraj@atmel.com>
26286
26287 * config/avr/avr-c.c (avr_resolve_overloaded_builtin): Pass vNULL for
26288 arg_loc.
26289 * config/spu/spu-c.c (spu_resolve_overloaded_builtin): Likewise.
26290
26291 2014-02-12 Eric Botcazou <ebotcazou@adacore.com>
26292
26293 PR rtl-optimization/60116
26294 * combine.c (try_combine): Also remove dangling REG_DEAD notes on the
26295 other_insn once the combination has been validated.
26296
26297 2014-02-11 Jan Hubicka <hubicka@ucw.cz>
26298
26299 PR lto/59468
26300 * ipa-utils.h (possible_polymorphic_call_targets): Update prototype
26301 and wrapper.
26302 * ipa-devirt.c: Include demangle.h
26303 (odr_violation_reported): New static variable.
26304 (add_type_duplicate): Update odr_violations.
26305 (maybe_record_node): Add completep parameter; update it.
26306 (record_target_from_binfo): Add COMPLETEP parameter;
26307 update it as needed.
26308 (possible_polymorphic_call_targets_1): Likewise.
26309 (struct polymorphic_call_target_d): Add nonconstruction_targets;
26310 rename FINAL to COMPLETE.
26311 (record_targets_from_bases): Sanity check we found the binfo;
26312 fix COMPLETEP updating.
26313 (possible_polymorphic_call_targets): Add NONCONSTRUTION_TARGETSP
26314 parameter, fix computing of COMPLETEP.
26315 (dump_possible_polymorphic_call_targets): Imrove readability of dump;
26316 at LTO time do demangling.
26317 (ipa_devirt): Use nonconstruction_targets; Improve dumps.
26318 * gimple-fold.c (gimple_get_virt_method_for_vtable): Add can_refer
26319 parameter.
26320 (gimple_get_virt_method_for_binfo): Likewise.
26321 * gimple-fold.h (gimple_get_virt_method_for_binfo,
26322 gimple_get_virt_method_for_vtable): Update prototypes.
26323
26324 2014-02-11 Vladimir Makarov <vmakarov@redhat.com>
26325
26326 PR target/49008
26327 * genautomata.c (add_presence_absence): Fix typo with
26328 {final_}presence_list.
26329
26330 2014-02-11 Michael Meissner <meissner@linux.vnet.ibm.com>
26331
26332 PR target/60137
26333 * config/rs6000/rs6000.md (128-bit GPR splitter): Add a splitter
26334 for VSX/Altivec vectors that land in GPR registers.
26335
26336 2014-02-11 Richard Henderson <rth@redhat.com>
26337 Jakub Jelinek <jakub@redhat.com>
26338
26339 PR debug/59776
26340 * tree-sra.c (load_assign_lhs_subreplacements): Add VIEW_CONVERT_EXPR
26341 around drhs if type conversion to lacc->type is not useless.
26342
26343 2014-02-11 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
26344
26345 * config/aarch64/aarch64-cores.def (cortex-a57): Use cortexa57
26346 tuning struct.
26347 (cortex-a57.cortex-a53): Likewise.
26348 * config/aarch64/aarch64.c (cortexa57_tunings): New tuning struct.
26349
26350 2014-02-11 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
26351
26352 * config/arm/thumb2.md (*thumb2_movhi_insn): Add alternatives for
26353 arm_restrict_it.
26354
26355 2014-02-11 Renlin Li <Renlin.Li@arm.com>
26356
26357 * doc/sourcebuild.texi: Document check_effective_target_arm_vfp3_ok and
26358 add_options_for_arm_vfp3.
26359
26360 2014-02-11 Jeff Law <law@redhat.com>
26361
26362 PR middle-end/54041
26363 * expr.c (expand_expr_addr_expr_1): Handle expand_expr returning an
26364 object with an undesirable mode.
26365
26366 2014-02-11 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
26367
26368 PR libgomp/60107
26369 * config/i386/sol2-9.h: New file.
26370 * config.gcc (i[34567]86-*-solaris2* | x86_64-*-solaris2.1[0-9]*,
26371 *-*-solaris2.9*): Use it.
26372
26373 2014-02-10 Nagaraju Mekala <nagaraju.mekala@xilinx.com>
26374
26375 * config/microblaze/microblaze.md: Add movsi4_rev insn pattern.
26376 * config/microblaze/predicates.md: Add reg_or_mem_operand predicate.
26377
26378 2014-02-10 Nagaraju Mekala <nagaraju.mekala@xilinx.com>
26379
26380 * config/microblaze/microblaze.c: Extend mcpu version format
26381
26382 2014-02-10 David Holsgrove <david.holsgrove@xilinx.com>
26383
26384 * config/microblaze/microblaze.h: Define SIZE_TYPE and PTRDIFF_TYPE.
26385
26386 2014-02-10 Richard Henderson <rth@redhat.com>
26387
26388 PR target/59927
26389 * calls.c (expand_call): Don't double-push for reg_parm_stack_space.
26390 * config/i386/i386.c (init_cumulative_args): Remove sorry for 64-bit
26391 ms-abi vs -mno-accumulate-outgoing-args.
26392 (ix86_expand_prologue): Unconditionally call ix86_eax_live_at_start_p.
26393 * config/i386/i386.h (ACCUMULATE_OUTGOING_ARGS): Fix comment with
26394 respect to ms-abi.
26395
26396 2014-02-10 Bernd Edlinger <bernd.edlinger@hotmail.de>
26397
26398 PR middle-end/60080
26399 * cfgexpand.c (expand_asm_operands): Attach source location to
26400 ASM_INPUT rtx objects.
26401 * print-rtl.c (print_rtx): Check for UNKNOWN_LOCATION.
26402
26403 2014-02-10 Nick Clifton <nickc@redhat.com>
26404
26405 * config/mn10300/mn10300.c (popcount): New function.
26406 (mn10300_expand_prologue): Include saved registers in stack usage
26407 count.
26408
26409 2014-02-10 Jeff Law <law@redhat.com>
26410
26411 PR middle-end/52306
26412 * reload1.c (emit_input_reload_insns): Do not create invalid RTL
26413 when changing the SET_DEST of a prior insn to avoid an input reload.
26414
26415 2014-02-10 Ulrich Weigand <Ulrich.Weigand@de.ibm.com>
26416
26417 * config/rs6000/sysv4.h (ENDIAN_SELECT): Do not attempt to enforce
26418 big-endian mode for -mcall-aixdesc, -mcall-freebsd, -mcall-netbsd,
26419 -mcall-openbsd, or -mcall-linux.
26420 (CC1_ENDIAN_BIG_SPEC): Remove.
26421 (CC1_ENDIAN_LITTLE_SPEC): Remove.
26422 (CC1_ENDIAN_DEFAULT_SPEC): Remove.
26423 (CC1_SPEC): Remove (always empty) %cc1_endian_... spec.
26424 (SUBTARGET_EXTRA_SPECS): Remove %cc1_endian_big, %cc1_endian_little,
26425 and %cc1_endian_default.
26426 * config/rs6000/sysv4le.h (CC1_ENDIAN_DEFAULT_SPEC): Remove.
26427
26428 2014-02-10 Richard Biener <rguenther@suse.de>
26429
26430 PR tree-optimization/60115
26431 * tree-eh.c (tree_could_trap_p): Unify TARGET_MEM_REF and
26432 MEM_REF handling. Properly verify that the accesses are not
26433 out of the objects bound.
26434
26435 2014-02-10 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
26436
26437 * config/aarch64/aarch64.c (aarch64_override_options): Fix typo from
26438 coretex to cortex.
26439
26440 2014-02-10 Eric Botcazou <ebotcazou@adacore.com>
26441
26442 * ipa-devirt.c (get_polymorphic_call_info_from_invariant): Return
26443 proper constants and fix formatting.
26444 (possible_polymorphic_call_targets): Fix formatting.
26445
26446 2014-02-10 Kirill Yukhin <kirill.yukhin@intel.com>
26447 Ilya Tocar <ilya.tocar@intel.com>
26448
26449 * config/i386/avx512fintrin.h (_mm512_storeu_epi64): Removed.
26450 (_mm512_loadu_epi32): Renamed into...
26451 (_mm512_loadu_si512): This.
26452 (_mm512_storeu_epi32): Renamed into...
26453 (_mm512_storeu_si512): This.
26454 (_mm512_maskz_ceil_ps): Removed.
26455 (_mm512_maskz_ceil_pd): Ditto.
26456 (_mm512_maskz_floor_ps): Ditto.
26457 (_mm512_maskz_floor_pd): Ditto.
26458 (_mm512_floor_round_ps): Ditto.
26459 (_mm512_floor_round_pd): Ditto.
26460 (_mm512_ceil_round_ps): Ditto.
26461 (_mm512_ceil_round_pd): Ditto.
26462 (_mm512_mask_floor_round_ps): Ditto.
26463 (_mm512_mask_floor_round_pd): Ditto.
26464 (_mm512_mask_ceil_round_ps): Ditto.
26465 (_mm512_mask_ceil_round_pd): Ditto.
26466 (_mm512_maskz_floor_round_ps): Ditto.
26467 (_mm512_maskz_floor_round_pd): Ditto.
26468 (_mm512_maskz_ceil_round_ps): Ditto.
26469 (_mm512_maskz_ceil_round_pd): Ditto.
26470 (_mm512_expand_pd): Ditto.
26471 (_mm512_expand_ps): Ditto.
26472 * config/i386/i386.c (ix86_builtins): Remove
26473 IX86_BUILTIN_EXPANDPD512_NOMASK, IX86_BUILTIN_EXPANDPS512_NOMASK.
26474 (bdesc_args): Ditto.
26475 * config/i386/predicates.md (const1256_operand): New.
26476 (const_1_to_2_operand): Ditto.
26477 * config/i386/sse.md (avx512pf_gatherpf<mode>sf): Change hint value.
26478 (*avx512pf_gatherpf<mode>sf_mask): Ditto.
26479 (*avx512pf_gatherpf<mode>sf): Ditto.
26480 (avx512pf_gatherpf<mode>df): Ditto.
26481 (*avx512pf_gatherpf<mode>df_mask): Ditto.
26482 (*avx512pf_gatherpf<mode>df): Ditto.
26483 (avx512pf_scatterpf<mode>sf): Ditto.
26484 (*avx512pf_scatterpf<mode>sf_mask): Ditto.
26485 (*avx512pf_scatterpf<mode>sf): Ditto.
26486 (avx512pf_scatterpf<mode>df): Ditto.
26487 (*avx512pf_scatterpf<mode>df_mask): Ditto.
26488 (*avx512pf_scatterpf<mode>df): Ditto.
26489 (avx512f_expand<mode>): Removed.
26490 (<shift_insn><mode>3<mask_name>): Change predicate type.
26491
26492 2014-02-08 Jakub Jelinek <jakub@redhat.com>
26493
26494 * tree-vect-data-refs.c (vect_analyze_data_refs): For clobbers
26495 not at the end of datarefs vector use ordered_remove to avoid
26496 reordering datarefs vector.
26497
26498 PR c/59984
26499 * gimplify.c (gimplify_bind_expr): In ORT_SIMD region
26500 mark local addressable non-static vars as GOVD_PRIVATE
26501 instead of GOVD_LOCAL.
26502 * omp-low.c (lower_omp_for): Move gimple_bind_vars
26503 and BLOCK_VARS of gimple_bind_block to new_stmt rather
26504 than copying them.
26505
26506 PR middle-end/60092
26507 * tree-ssa-ccp.c (surely_varying_stmt_p): Don't return true
26508 if TYPE_ATTRIBUTES (gimple_call_fntype ()) contain
26509 assume_aligned or alloc_align attributes.
26510 (bit_value_assume_aligned): Add ATTR, PTRVAL and ALLOC_ALIGN
26511 arguments. Handle also assume_aligned and alloc_align attributes.
26512 (evaluate_stmt): Adjust bit_value_assume_aligned caller. Handle
26513 calls to functions with assume_aligned or alloc_align attributes.
26514 * doc/extend.texi: Document assume_aligned and alloc_align attributes.
26515
26516 2014-02-08 Terry Guo <terry.guo@arm.com>
26517
26518 * doc/invoke.texi: Document ARM -march=armv7e-m.
26519
26520 2014-02-08 Jakub Jelinek <jakub@redhat.com>
26521
26522 * cilk-common.c (cilk_init_builtins): Clear TREE_NOTHROW
26523 flag on __cilkrts_rethrow builtin.
26524
26525 PR ipa/60026
26526 * ipa-cp.c (determine_versionability): Fail at -O0
26527 or __attribute__((optimize (0))) or -fno-ipa-cp functions.
26528 * tree-sra.c (ipa_sra_preliminary_function_checks): Similarly.
26529
26530 Revert:
26531 2014-02-04 Jakub Jelinek <jakub@redhat.com>
26532
26533 PR ipa/60026
26534 * tree-inline.c (copy_forbidden): Fail for
26535 __attribute__((optimize (0))) functions.
26536
26537 2014-02-07 Jan Hubicka <hubicka@ucw.cz>
26538
26539 * varpool.c: Include pointer-set.h.
26540 (varpool_remove_unreferenced_decls): Variables in other partitions
26541 will not be output; be however careful to not lose information
26542 about partitioning.
26543
26544 2014-02-07 Jan Hubicka <hubicka@ucw.cz>
26545
26546 * gimple-fold.c (gimple_get_virt_method_for_vtable): Do O(1)
26547 lookup in the vtable constructor.
26548
26549 2014-02-07 Jeff Law <law@redhat.com>
26550
26551 PR target/40977
26552 * config/m68k/m68k.md (ashldi_extsi): Turn into a
26553 define_insn_and_split.
26554
26555 * ipa-inline.c (inline_small_functions): Fix typos.
26556
26557 2014-02-07 Richard Sandiford <rsandifo@linux.vnet.ibm.com>
26558
26559 * config/s390/s390-protos.h (s390_can_use_simple_return_insn)
26560 (s390_can_use_return_insn): Declare.
26561 * config/s390/s390.h (EPILOGUE_USES): Define.
26562 * config/s390/s390.c (s390_mainpool_start): Allow two main_pool
26563 instructions.
26564 (s390_chunkify_start): Handle return JUMP_LABELs.
26565 (s390_early_mach): Emit a main_pool instruction on the entry edge.
26566 (s300_set_up_by_prologue, s390_can_use_simple_return_insn)
26567 (s390_can_use_return_insn): New functions.
26568 (s390_fix_long_loop_prediction): Handle conditional returns.
26569 (TARGET_SET_UP_BY_PROLOGUE): Define.
26570 * config/s390/s390.md (ANY_RETURN): New code iterator.
26571 (*creturn, *csimple_return, return, simple_return): New patterns.
26572
26573 2014-02-07 Richard Sandiford <rsandifo@linux.vnet.ibm.com>
26574
26575 * config/s390/s390.c (s390_restore_gprs_from_fprs): Add REG_CFA_RESTORE
26576 notes to each restore. Also add REG_CFA_DEF_CFA when restoring %r15.
26577 (s390_optimize_prologue): Don't clear RTX_FRAME_RELATED_P. Update the
26578 REG_CFA_RESTORE list when deciding not to restore a register.
26579
26580 2014-02-07 Richard Sandiford <rsandifo@linux.vnet.ibm.com>
26581
26582 * config/s390/s390.c: Include tree-pass.h and context.h.
26583 (s390_early_mach): New function, split out from...
26584 (s390_emit_prologue): ...here.
26585 (pass_data_s390_early_mach): New pass structure.
26586 (pass_s390_early_mach): New class.
26587 (s390_option_override): Create and register early_mach pass.
26588 Move to end of file.
26589
26590 2014-02-07 Richard Sandiford <rsandifo@linux.vnet.ibm.com>
26591
26592 * var-tracking.c (vt_stack_adjustments): Don't require stack_adjusts
26593 to match for the exit block.
26594
26595 2014-02-07 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
26596
26597 * config/s390/s390.md ("atomic_load<mode>", "atomic_store<mode>")
26598 ("atomic_compare_and_swap<mode>", "atomic_fetch_<atomic><mode>"):
26599 Reject misaligned operands.
26600
26601 2014-02-07 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
26602
26603 * optabs.c (expand_atomic_compare_and_swap): Allow expander to fail.
26604
26605 2014-02-07 Richard Biener <rguenther@suse.de>
26606
26607 PR middle-end/60092
26608 * gimple-low.c (lower_builtin_posix_memalign): New function.
26609 (lower_stmt): Call it to lower posix_memalign in a way
26610 to make alignment info accessible.
26611
26612 2014-02-07 Jakub Jelinek <jakub@redhat.com>
26613
26614 PR c++/60082
26615 * tree.c (build_common_builtin_nodes): Set ECF_LEAF for
26616 __builtin_setjmp_receiver.
26617
26618 2014-02-07 Richard Biener <rguenther@suse.de>
26619
26620 PR middle-end/60092
26621 * builtin-types.def (BT_FN_INT_PTRPTR_SIZE_SIZE): Add.
26622 * builtins.def (BUILT_IN_POSIX_MEMALIGN): Likewise.
26623 * tree-ssa-structalias.c (find_func_aliases_for_builtin_call):
26624 Handle BUILT_IN_POSIX_MEMALIGN.
26625 (find_func_clobbers): Likewise.
26626 * tree-ssa-alias.c (ref_maybe_used_by_call_p_1): Likewise.
26627 (call_may_clobber_ref_p_1): Likewise.
26628
26629 2014-02-06 Jan Hubicka <hubicka@ucw.cz>
26630
26631 PR ipa/59918
26632 * ipa-devirt.c (record_target_from_binfo): Remove overactive
26633 sanity check.
26634
26635 2014-02-06 Jan Hubicka <hubicka@ucw.cz>
26636
26637 PR ipa/59469
26638 * lto-cgraph.c (lto_output_node): Use
26639 symtab_get_symbol_partitioning_class.
26640 (lto_output_varpool_node): likewise.
26641 (symtab_get_symbol_partitioning_class): Move here from
26642 lto/lto-partition.c
26643 * cgraph.h (symbol_partitioning_class): Likewise.
26644 (symtab_get_symbol_partitioning_class): Declare.
26645
26646 2014-02-06 Jan Hubicka <hubicka@ucw.cz>
26647
26648 * ggc.h (ggc_internal_cleared_alloc): New macro.
26649 * vec.h (vec_safe_copy): Handle memory stats.
26650 * omp-low.c (simd_clone_struct_alloc): Use ggc_internal_cleared_alloc.
26651 * target-globals.c (save_target_globals): Likewise.
26652
26653 2014-02-06 Jan Hubicka <hubicka@ucw.cz>
26654
26655 PR target/60077
26656 * expr.c (emit_move_resolve_push): Export; be bit more selective
26657 on when to clear alias set.
26658 * expr.h (emit_move_resolve_push): Declare.
26659 * function.h (struct function): Add tail_call_marked.
26660 * tree-tailcall.c (optimize_tail_call): Set tail_call_marked.
26661 * config/i386/i386-protos.h (ix86_expand_push): Remove.
26662 * config/i386/i386.md (TImode move expander): De not call
26663 ix86_expand_push.
26664 (FP push expanders): Preserve memory attributes.
26665 * config/i386/sse.md (push<mode>1): Remove.
26666 * config/i386/i386.c (ix86_expand_vector_move): Handle push operation.
26667 (ix86_expand_push): Remove.
26668 * config/i386/mmx.md (push<mode>1): Remove.
26669
26670 2014-02-06 Jakub Jelinek <jakub@redhat.com>
26671
26672 PR rtl-optimization/60030
26673 * internal-fn.c (ubsan_expand_si_overflow_mul_check): Surround
26674 lopart with paradoxical subreg before shifting it up by hprec.
26675
26676 2014-02-06 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
26677
26678 * config/arm/aarch-cost-tables.h (cortexa57_extra_costs): New table.
26679 Remove extra newline at end of file.
26680 * config/arm/arm.c (arm_cortex_a57_tune): New tuning struct.
26681 (arm_issue_rate): Handle cortexa57.
26682 * config/arm/arm-cores.def (cortex-a57): Use cortex_a57 tuning.
26683 (cortex-a57.cortex-a53): Likewise.
26684
26685 2014-02-06 Jakub Jelinek <jakub@redhat.com>
26686
26687 PR target/59575
26688 * config/arm/arm.c (emit_multi_reg_push): Add dwarf_regs_mask argument,
26689 don't record in REG_FRAME_RELATED_EXPR registers not set in that
26690 bitmask.
26691 (arm_expand_prologue): Adjust all callers.
26692 (arm_unwind_emit_sequence): Allow saved, but not important for unwind
26693 info, registers also at the lowest numbered registers side. Use
26694 gcc_assert instead of abort, and SET_SRC/SET_DEST macros instead of
26695 XEXP.
26696
26697 PR debug/59992
26698 * var-tracking.c (adjust_mems): Before adding a SET to
26699 amd->side_effects, adjust it's SET_SRC using simplify_replace_fn_rtx.
26700
26701 2014-02-06 Alan Modra <amodra@gmail.com>
26702
26703 PR target/60032
26704 * config/rs6000/rs6000.c (rs6000_secondary_memory_needed_mode): Only
26705 change SDmode to DDmode when lra_in_progress.
26706
26707 2014-02-06 Jakub Jelinek <jakub@redhat.com>
26708
26709 PR middle-end/59150
26710 * tree-vect-data-refs.c (vect_analyze_data_refs): For clobbers, call
26711 free_data_ref on the dr first, and before goto again also set dr
26712 to the next dr. For simd_lane_access, free old datarefs[i] before
26713 overwriting it. For get_vectype_for_scalar_type failure, don't
26714 free_data_ref if simd_lane_access.
26715
26716 * Makefile.in (prefix.o, cppbuiltin.o): Depend on $(BASEVER).
26717
26718 PR target/60062
26719 * tree.h (opts_for_fn): New inline function.
26720 (opt_for_fn): Define.
26721 * config/i386/i386.c (ix86_function_regparm): Use
26722 opt_for_fn (decl, optimize) instead of optimize.
26723
26724 2014-02-06 Marcus Shawcroft <marcus.shawcroft@arm.com>
26725
26726 * config/aarch64/aarch64.c (aarch64_classify_symbol): Fix logic
26727 for SYMBOL_REF in large memory model.
26728
26729 2014-02-06 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
26730
26731 * config/aarch64/aarch64-cores.def (cortex-a53): Specify CRC32
26732 and crypto support.
26733 (cortex-a57): Likewise.
26734 (cortex-a57.cortex-a53): Likewise.
26735
26736 2014-02-06 Yury Gribov <y.gribov@samsung.com>
26737 Kugan Vivekanandarajah <kuganv@linaro.org>
26738
26739 * config/arm/arm.c (arm_vector_alignment_reachable): Check
26740 unaligned_access.
26741 * config/arm/arm.c (arm_builtin_support_vector_misalignment): Likewise.
26742
26743 2014-02-06 Richard Biener <rguenther@suse.de>
26744
26745 * tree-cfg.c (gimple_duplicate_sese_region): Fix ordering of
26746 set_loop_copy and initialize_original_copy_tables.
26747
26748 2014-02-06 Alex Velenko <Alex.Velenko@arm.com>
26749
26750 * config/aarch64/aarch64-simd.md
26751 (aarch64_ashr_simddi): Change QI to SI.
26752
26753 2014-02-05 Jan Hubicka <hubicka@ucw.cz>
26754 Jakub Jelinek <jakub@redhat.com>
26755
26756 PR middle-end/60013
26757 * ipa-inline-analysis.c (compute_bb_predicates): Ensure monotonicity
26758 of the dataflow.
26759
26760 2014-02-05 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
26761
26762 * config/rs6000/rs6000.c (altivec_expand_vec_perm_const): Change
26763 CODE_FOR_altivec_vpku[hw]um to
26764 CODE_FOR_altivec_vpku[hw]um_direct.
26765 * config/rs6000/altivec.md (vec_unpacks_hi_<VP_small_lc>): Change
26766 UNSPEC_VUNPACK_HI_SIGN to UNSPEC_VUNPACK_HI_SIGN_DIRECT.
26767 (vec_unpacks_lo_<VP_small_lc>): Change UNSPEC_VUNPACK_LO_SIGN to
26768 UNSPEC_VUNPACK_LO_SIGN_DIRECT.
26769
26770 2014-02-05 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
26771
26772 * config/rs6000/altivec.md (altivec_vsum2sws): Adjust code
26773 generation for -maltivec=be.
26774 (altivec_vsumsws): Simplify redundant test.
26775
26776 2014-02-05 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
26777
26778 * altivec.md (UNSPEC_VPACK_UNS_UNS_MOD_DIRECT): New unspec.
26779 (UNSPEC_VUNPACK_HI_SIGN_DIRECT): Likewise.
26780 (UNSPEC_VUNPACK_LO_SIGN_DIRECT): Likewise.
26781 (mulv8hi3): Use gen_altivec_vpkuwum_direct instead of
26782 gen_altivec_vpkuwum.
26783 (altivec_vpkpx): Test for VECTOR_ELT_ORDER_BIG instead of for
26784 BYTES_BIG_ENDIAN.
26785 (altivec_vpks<VI_char>ss): Likewise.
26786 (altivec_vpks<VI_char>us): Likewise.
26787 (altivec_vpku<VI_char>us): Likewise.
26788 (altivec_vpku<VI_char>um): Likewise.
26789 (altivec_vpku<VI_char>um_direct): New (copy of
26790 altivec_vpku<VI_char>um that still relies on BYTES_BIG_ENDIAN, for
26791 internal use).
26792 (altivec_vupkhs<VU_char>): Emit vupkls* instead of vupkhs* when
26793 target is little endian and -maltivec=be is not specified.
26794 (*altivec_vupkhs<VU_char>_direct): New (copy of
26795 altivec_vupkhs<VU_char> that always emits vupkhs*, for internal use).
26796 (altivec_vupkls<VU_char>): Emit vupkhs* instead of vupkls* when
26797 target is little endian and -maltivec=be is not specified.
26798 (*altivec_vupkls<VU_char>_direct): New (copy of
26799 altivec_vupkls<VU_char> that always emits vupkls*, for internal use).
26800 (altivec_vupkhpx): Emit vupklpx instead of vupkhpx when target is
26801 little endian and -maltivec=be is not specified.
26802 (altivec_vupklpx): Emit vupkhpx instead of vupklpx when target is
26803 little endian and -maltivec=be is not specified.
26804
26805 2014-02-05 Richard Henderson <rth@redhat.com>
26806
26807 PR debug/52727
26808 * combine-stack-adj.c: Revert r206943.
26809 * sched-int.h (struct deps_desc): Add last_args_size.
26810 * sched-deps.c (init_deps): Initialize it.
26811 (sched_analyze_insn): Add OUTPUT dependencies between insns that
26812 contain REG_ARGS_SIZE notes.
26813
26814 2014-02-05 Jan Hubicka <hubicka@ucw.cz>
26815
26816 * lto-cgraph.c (asm_nodes_output): Make global.
26817 * lto-wrapper.c (run_gcc): Pass down paralelizm to WPA.
26818 * gcc.c (AS_NEEDS_DASH_FOR_PIPED_INPUT): Allow WPA parameter
26819 (driver_handle_option): Handle OPT_fwpa.
26820
26821 2014-02-05 Jakub Jelinek <jakub@redhat.com>
26822
26823 PR ipa/59947
26824 * ipa-devirt.c (possible_polymorphic_call_targets): Fix
26825 a comment typo and formatting issue. If odr_hash hasn't been
26826 created, return vNULL and set *completep to false.
26827
26828 PR middle-end/57499
26829 * tree-eh.c (cleanup_empty_eh): Bail out on totally empty
26830 bb with no successors.
26831
26832 2014-02-05 James Greenhalgh <james.greenhalgh@arm.com>
26833
26834 PR target/59718
26835 * doc/invoke.texi (-march): Clarify documentation for ARM.
26836 (-mtune): Likewise.
26837 (-mcpu): Likewise.
26838
26839 2014-02-05 Richard Biener <rguenther@suse.de>
26840
26841 * tree-vect-loop.c (vect_analyze_loop_2): Be more informative
26842 when not vectorizing because of too many alias checks.
26843 * tree-vect-data-refs.c (vect_prune_runtime_alias_test_list):
26844 Add more verboseness, avoid duplicate MSG_MISSED_OPTIMIZATION.
26845
26846 2014-02-05 Nick Clifton <nickc@redhat.com>
26847
26848 * config/mn10300/mn10300.c (mn10300_hard_regno_mode_ok): Do not
26849 accept extended registers in any mode when compiling for the MN10300.
26850
26851 2014-02-05 Yury Gribov <y.gribov@samsung.com>
26852
26853 * cif-code.def (ATTRIBUTE_MISMATCH): New CIF code.
26854 * ipa-inline.c (report_inline_failed_reason): Handle mismatched
26855 sanitization attributes.
26856 (can_inline_edge_p): Likewise.
26857 (sanitize_attrs_match_for_inline_p): New function.
26858
26859 2014-02-04 Jan Hubicka <hubicka@ucw.cz>
26860
26861 * ipa-prop.c (detect_type_change): Shor circuit testing of
26862 type changes on THIS pointer.
26863
26864 2014-02-04 John David Anglin <danglin@gcc.gnu.org>
26865
26866 PR target/59777
26867 * config/pa/pa.c (legitimize_tls_address): Return original address
26868 if not passed a SYMBOL_REF rtx.
26869 (hppa_legitimize_address): Call legitimize_tls_address for all TLS
26870 addresses.
26871 (pa_emit_move_sequence): Simplify TLS source operands.
26872 (pa_legitimate_constant_p): Reject all TLS constants.
26873 * config/pa/pa.h (PA_SYMBOL_REF_TLS_P): Correct comment.
26874 (CONSTANT_ADDRESS_P): Reject TLS CONST addresses.
26875
26876 2014-02-04 Jan Hubicka <hubicka@ucw.cz>
26877
26878 * ipa.c (function_and_variable_visibility): Decompose DECL_ONE_ONLY
26879 groups when we know they are controlled by LTO.
26880 * varasm.c (default_binds_local_p_1): If object is in other partition,
26881 it will be resolved locally.
26882
26883 2014-02-04 Bernd Edlinger <bernd.edlinger@hotmail.de>
26884
26885 * config/host-linux.c (linux_gt_pch_use_address): Don't
26886 use SSIZE_MAX because it is not always defined.
26887
26888 2014-02-04 Vladimir Makarov <vmakarov@redhat.com>
26889
26890 PR bootstrap/59913
26891 * lra-constraints.c (need_for_split_p): Use more 3 reloads as
26892 threshold for pseudo splitting.
26893 (update_ebb_live_info): Process call argument hard registers and
26894 hard registers from insn definition too.
26895 (max_small_class_regs_num): New constant.
26896 (inherit_in_ebb): Update live hard regs through EBBs. Update
26897 reloads_num only for small register classes. Don't split for
26898 outputs of jumps.
26899
26900 2014-02-04 Markus Trippelsdorf <markus@trippelsdorf.de>
26901
26902 PR ipa/60058
26903 * ipa-cp.c (ipa_get_indirect_edge_target_1): Check that target
26904 is non-null.
26905
26906 2014-02-04 Jan Hubicka <hubicka@ucw.cz>
26907
26908 * gimple-fold.c (can_refer_decl_in_current_unit_p): Default
26909 visibility is safe.
26910
26911 2014-02-04 Marek Polacek <polacek@redhat.com>
26912
26913 * gdbinit.in (pel): Define.
26914
26915 2014-02-04 Bernd Edlinger <bernd.edlinger@hotmail.de>
26916
26917 * doc/invoke.texi (fstrict-volatile-bitfields): Clarify current
26918 behavior.
26919
26920 2014-02-04 Richard Biener <rguenther@suse.de>
26921
26922 PR lto/59723
26923 * lto-streamer-out.c (tree_is_indexable): Force NAMELIST_DECLs
26924 in function context local.
26925 (lto_output_tree_ref): Do not write trees from lto_output_tree_ref.
26926 * lto-streamer-in.c (lto_input_tree_ref): Handle LTO_namelist_decl_ref
26927 similar to LTO_imported_decl_ref.
26928
26929 2014-02-04 Jakub Jelinek <jakub@redhat.com>
26930
26931 PR tree-optimization/60002
26932 * cgraphclones.c (build_function_decl_skip_args): Clear
26933 DECL_LANG_SPECIFIC.
26934
26935 PR tree-optimization/60023
26936 * tree-if-conv.c (predicate_mem_writes): Pass true instead of
26937 false to gsi_replace.
26938 * tree-vect-stmts.c (vect_finish_stmt_generation): If stmt
26939 has been in some EH region and vec_stmt could throw, add
26940 vec_stmt into the same EH region.
26941 * tree-data-ref.c (get_references_in_stmt): If IFN_MASK_LOAD
26942 has no lhs, ignore it.
26943 * internal-fn.c (expand_MASK_LOAD): Likewise.
26944
26945 PR ipa/60026
26946 * tree-inline.c (copy_forbidden): Fail for
26947 __attribute__((optimize (0))) functions.
26948
26949 PR other/58712
26950 * omp-low.c (simd_clone_struct_copy): If from->inbranch
26951 is set, copy one less argument.
26952 (expand_simd_clones): Don't subtract clone_info->inbranch
26953 from simd_clone_struct_alloc argument.
26954
26955 PR rtl-optimization/57915
26956 * recog.c (simplify_while_replacing): If all unary/binary/relational
26957 operation arguments are constant, attempt to simplify those.
26958
26959 PR middle-end/59261
26960 * expmed.c (expand_mult): For MODE_VECTOR_INT multiplication
26961 if there is no vashl<mode>3 or ashl<mode>3 insn, skip_synth.
26962
26963 2014-02-04 Richard Biener <rguenther@suse.de>
26964
26965 PR tree-optimization/60012
26966 * tree-vect-data-refs.c (vect_analyze_data_ref_dependence): Apply
26967 TBAA disambiguation to all DDRs.
26968
26969 2014-02-04 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
26970
26971 PR target/59788
26972 * config/sol2.h (LINK_LIBGCC_MAPFILE_SPEC): Define.
26973 (LINK_SPEC): Use it for -shared, -shared-libgcc.
26974
26975 2014-02-03 Jan Hubicka <hubicka@ucw.cz>
26976
26977 PR ipa/59882
26978 * tree.c (get_binfo_at_offset): Do not get confused by empty classes;
26979
26980 2014-02-03 Jan Hubicka <hubicka@ucw.cz>
26981
26982 * gimple-fold.c (gimple_extract_devirt_binfo_from_cst): Remove.
26983 * gimple-fold.h (gimple_extract_devirt_binfo_from_cst): Remove.
26984
26985 2014-02-03 Jan Hubicka <hubicka@ucw.cz>
26986
26987 PR ipa/59831
26988 * ipa-cp.c (ipa_get_indirect_edge_target_1): Use ipa-devirt
26989 to figure out targets of polymorphic calls with known decl.
26990 * ipa-prop.c (try_make_edge_direct_virtual_call): Likewise.
26991 * ipa-utils.h (get_polymorphic_call_info_from_invariant): Declare.
26992 * ipa-devirt.c (get_polymorphic_call_info_for_decl): Break out from ...
26993 (get_polymorphic_call_info): ... here.
26994 (get_polymorphic_call_info_from_invariant): New function.
26995
26996 2014-02-03 Jan Hubicka <hubicka@ucw.cz>
26997
26998 * ipa-cp.c (ipa_get_indirect_edge_target_1): Do direct
26999 lookup via vtable pointer; check for type consistency
27000 and turn inconsitent facts into UNREACHABLE.
27001 * ipa-prop.c (try_make_edge_direct_virtual_call): Likewise.
27002 * gimple-fold.c (gimple_get_virt_method_for_vtable): Do not ICE on
27003 type inconsistent querries; return UNREACHABLE instead.
27004
27005 2014-02-03 Richard Henderson <rth@twiddle.net>
27006
27007 PR tree-opt/59924
27008 * tree-ssa-uninit.c (push_to_worklist): Don't re-push if we've
27009 already processed this node.
27010 (normalize_one_pred_1): Pass along mark_set.
27011 (normalize_one_pred): Create and destroy a pointer_set_t.
27012 (normalize_one_pred_chain): Likewise.
27013
27014 2014-02-03 Laurent Aflonsi <laurent.alfonsi@st.com>
27015
27016 PR gcov-profile/58602
27017 * gcc/gcov-io.c (gcov_open): Open with truncation when mode < 0.
27018
27019 2014-02-03 Jan Hubicka <hubicka@ucw.cz>
27020
27021 PR ipa/59831
27022 * ipa-cp.c (ipa_get_indirect_edge_target_1): Give up on
27023 -fno-devirtualize; try to devirtualize by the knowledge of
27024 virtual table pointer given by aggregate propagation.
27025 * ipa-prop.c (try_make_edge_direct_virtual_call): Likewise.
27026 (ipa_print_node_jump_functions): Dump also offset that
27027 is relevant for polymorphic calls.
27028 (determine_known_aggregate_parts): Add arg_type parameter; use it
27029 instead of determining the type from pointer type.
27030 (ipa_compute_jump_functions_for_edge): Update call of
27031 determine_known_aggregate_parts.
27032 * gimple-fold.c (gimple_get_virt_method_for_vtable): Break out from ...
27033 (gimple_get_virt_method_for_binfo): ... here; simplify using
27034 vtable_pointer_value_to_vtable.
27035 * gimple-fold.h (gimple_get_virt_method_for_vtable): Declare.
27036 * ipa-devirt.c (subbinfo_with_vtable_at_offset): Turn OFFSET parameter
27037 to unsigned HOST_WIDE_INT; use vtable_pointer_value_to_vtable.
27038 (vtable_pointer_value_to_vtable): Break out from ...; handle also
27039 POINTER_PLUS_EXPR.
27040 (vtable_pointer_value_to_binfo): ... here.
27041 * ipa-utils.h (vtable_pointer_value_to_vtable): Declare.
27042
27043 2014-02-03 Teresa Johnson <tejohnson@google.com>
27044
27045 * tree-vect-slp.c (vect_supported_load_permutation_p): Avoid
27046 redef of outer loop index variable.
27047
27048 2014-02-03 Marc Glisse <marc.glisse@inria.fr>
27049
27050 PR c++/53017
27051 PR c++/59211
27052 * doc/extend.texi (Function Attributes): Typo.
27053
27054 2014-02-03 Cong Hou <congh@google.com>
27055
27056 PR tree-optimization/60000
27057 * tree-vect-loop.c (vect_transform_loop): Set pattern_def_seq to NULL
27058 if the vectorized statement is a store. A store statement can only
27059 appear at the end of pattern statements.
27060
27061 2014-02-03 H.J. Lu <hongjiu.lu@intel.com>
27062
27063 * config/i386/i386.c (flag_opts): Add -mlong-double-128.
27064 (ix86_option_override_internal): Default long double to 64-bit for
27065 32-bit Bionic and to 128-bit for 64-bit Bionic.
27066
27067 * config/i386/i386.h (LONG_DOUBLE_TYPE_SIZE): Use 128 if
27068 TARGET_LONG_DOUBLE_128 is true.
27069 (LIBGCC2_LONG_DOUBLE_TYPE_SIZE): Likewise.
27070
27071 * config/i386/i386.opt (mlong-double-80): Negate -mlong-double-64.
27072 (mlong-double-64): Negate -mlong-double-128.
27073 (mlong-double-128): New option.
27074
27075 * config/i386/i386-c.c (ix86_target_macros): Define
27076 __LONG_DOUBLE_128__ for TARGET_LONG_DOUBLE_128.
27077
27078 * doc/invoke.texi: Document -mlong-double-128.
27079
27080 2014-02-03 H.J. Lu <hongjiu.lu@intel.com>
27081
27082 PR rtl-optimization/60024
27083 * sel-sched.c (init_regs_for_mode): Check if mode is OK first.
27084
27085 2014-02-03 Markus Trippelsdorf <markus@trippelsdorf.de>
27086
27087 * doc/invoke.texi (fprofile-reorder-functions): Fix typo.
27088
27089 2014-02-03 Andrey Belevantsev <abel@ispras.ru>
27090
27091 PR rtl-optimization/57662
27092 * sel-sched.c (code_motion_path_driver): Do not mark already not
27093 existing blocks in the visiting bitmap.
27094
27095 2014-02-03 Andrey Belevantsev <abel@ispras.ru>
27096
27097 * sel-sched-ir.c (sel_gen_insn_from_expr_after): Reset INSN_DELETED_P
27098 on the insn being emitted.
27099
27100 2014-02-03 James Greenhalgh <james.greenhalgh@arm.com>
27101 Will Deacon <will.deacon@arm.com>
27102
27103 * doc/gimple.texi (gimple_asm_clear_volatile): Remove.
27104
27105 2014-02-03 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
27106
27107 * config/arm/arm-tables.opt: Regenerate.
27108
27109 2014-02-02 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
27110
27111 * config/rs6000/rs6000.c (altivec_expand_vec_perm_le): Generalize
27112 for vector types other than V16QImode.
27113 * config/rs6000/altivec.md (altivec_vperm_<mode>): Change to a
27114 define_expand, and call altivec_expand_vec_perm_le when producing
27115 code with little endian element order.
27116 (*altivec_vperm_<mode>_internal): New insn having previous
27117 behavior of altivec_vperm_<mode>.
27118 (altivec_vperm_<mode>_uns): Change to a define_expand, and call
27119 altivec_expand_vec_perm_le when producing code with little endian
27120 element order.
27121 (*altivec_vperm_<mode>_uns_internal): New insn having previous
27122 behavior of altivec_vperm_<mode>_uns.
27123
27124 2014-02-02 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
27125
27126 * config/rs6000/altivec.md (UNSPEC_VSUMSWS_DIRECT): New unspec.
27127 (altivec_vsumsws): Add handling for -maltivec=be with a little
27128 endian target.
27129 (altivec_vsumsws_direct): New.
27130 (reduc_splus_<mode>): Call gen_altivec_vsumsws_direct instead of
27131 gen_altivec_vsumsws.
27132
27133 2014-02-02 Jan Hubicka <hubicka@ucw.cz>
27134
27135 * ipa-devirt.c (subbinfo_with_vtable_at_offset,
27136 vtable_pointer_value_to_binfo): New functions.
27137 * ipa-utils.h (vtable_pointer_value_to_binfo): Declare.
27138 * ipa-prop.c (extr_type_from_vtbl_ptr_store): Use it.
27139
27140 2014-02-02 Sandra Loosemore <sandra@codesourcery.com>
27141
27142 * config/nios2/nios2.md (load_got_register): Initialize GOT
27143 pointer from _gp_got instead of _GLOBAL_OFFSET_TABLE_.
27144 * config/nios2/nios2.c (nios2_function_profiler): Likewise.
27145
27146 2014-02-02 Jan Hubicka <hubicka@ucw.cz>
27147
27148 * ipa-prop.c (update_jump_functions_after_inlining): When type is not
27149 preserverd by passthrough, do not propagate the type.
27150
27151 2014-02-02 Richard Sandiford <rdsandiford@googlemail.com>
27152
27153 * config/mips/mips.c (MIPS_GET_FCSR, MIPS_SET_FCSR): New macros.
27154 (mips_atomic_assign_expand_fenv): New function.
27155 (TARGET_ATOMIC_ASSIGN_EXPAND_FENV): Define.
27156
27157 2014-02-02 Richard Sandiford <rdsandiford@googlemail.com>
27158
27159 * doc/extend.texi (__builtin_mips_get_fcsr): Document.
27160 (__builtin_mips_set_fcsr): Likewise.
27161 * config/mips/mips-ftypes.def: Add MIPS_VOID_FTYPE_USI and
27162 MIPS_USI_FTYPE_VOID.
27163 * config/mips/mips-protos.h (mips16_expand_get_fcsr): Declare
27164 (mips16_expand_set_fcsr): Likewise.
27165 * config/mips/mips.c (mips16_get_fcsr_stub): New variable.
27166 (mips16_set_fcsr_stub): Likewise.
27167 (mips16_get_fcsr_one_only_stub): New class.
27168 (mips16_set_fcsr_one_only_stub): Likewise.
27169 (mips16_expand_get_fcsr, mips16_expand_set_fcsr): New functions.
27170 (mips_code_end): Output the get_fcsr and set_fcsr stubs, if needed.
27171 (BUILTIN_AVAIL_MIPS16, AVAIL_ALL): New macros.
27172 (hard_float): New availability predicate.
27173 (mips_builtins): Add get_fcsr and set_fcsr.
27174 (mips_expand_builtin): Check BUILTIN_AVAIL_MIPS16.
27175 * config/mips/mips.md (UNSPEC_GET_FCSR, UNSPEC_SET_FCSR): New unspecs.
27176 (GET_FCSR_REGNUM, SET_FCSR_REGNUM): New constants.
27177 (mips_get_fcsr, *mips_get_fcsr, mips_get_fcsr_mips16_<mode>)
27178 (mips_set_fcsr, *mips_set_fcsr, mips_set_fcsr_mips16_<mode>): New
27179 patterns.
27180
27181 2014-02-02 Richard Sandiford <rdsandiford@googlemail.com>
27182
27183 * config/mips/mips.c (mips_one_only_stub): New class.
27184 (mips_need_mips16_rdhwr_p): Replace with...
27185 (mips16_rdhwr_stub): ...this new variable.
27186 (mips16_stub_call_address): New function.
27187 (mips16_rdhwr_one_only_stub): New class.
27188 (mips_expand_thread_pointer): Use mips16_stub_call_address.
27189 (mips_output_mips16_rdhwr): Delete.
27190 (mips_finish_stub): New function.
27191 (mips_code_end): Use it to handle rdhwr stubs.
27192
27193 2014-02-02 Uros Bizjak <ubizjak@gmail.com>
27194
27195 PR target/60017
27196 * config/i386/i386.c (classify_argument): Fix handling of bit_offset
27197 when calculating size of integer atomic types.
27198
27199 2014-02-02 H.J. Lu <hongjiu.lu@intel.com>
27200
27201 * ipa-inline-analysis.c (true_predicate_p): Fix a typo in comments.
27202
27203 2014-02-01 Jakub Jelinek <jakub@redhat.com>
27204
27205 PR tree-optimization/60003
27206 * gimple-low.c (lower_builtin_setjmp): Set cfun->has_nonlocal_label.
27207 * profile.c (branch_prob): Use gimple_call_builtin_p
27208 to check for BUILT_IN_SETJMP_RECEIVER.
27209 * tree-inline.c (copy_bb): Call notice_special_calls.
27210
27211 2014-01-31 Vladimir Makarov <vmakarov@redhat.com>
27212
27213 PR bootstrap/59985
27214 * lra-constraints.c (process_alt_operands): Update reload_sum only
27215 on the first pass.
27216
27217 2014-01-31 Richard Henderson <rth@redhat.com>
27218
27219 PR middle-end/60004
27220 * tree-eh.c (lower_try_finally_switch): Delay lowering finally block
27221 until after else_eh is processed.
27222
27223 2014-01-31 Ilya Tocar <ilya.tocar@intel.com>
27224
27225 * config/i386/avx512fintrin.h (_MM_FROUND_TO_NEAREST_INT),
27226 (_MM_FROUND_TO_NEG_INF), (_MM_FROUND_TO_POS_INF),
27227 (_MM_FROUND_TO_ZERO), (_MM_FROUND_CUR_DIRECTION): Are already defined
27228 in smmintrin.h, remove them.
27229 (_MM_FROUND_NO_EXC): Same as above, bit also wrong value.
27230 * config/i386/i386.c (ix86_print_operand): Split sae and rounding.
27231 * config/i386/i386.md (ROUND_SAE): Fix value.
27232 * config/i386/predicates.md (const_4_or_8_to_11_operand): New.
27233 (const48_operand): New.
27234 * config/i386/subst.md (round), (round_expand): Use
27235 const_4_or_8_to_11_operand.
27236 (round_saeonly), (round_saeonly_expand): Use const48_operand.
27237
27238 2014-01-31 Ilya Tocar <ilya.tocar@intel.com>
27239
27240 * config/i386/constraints.md (Yk): Swap meaning with k.
27241 * config/i386/i386.md (movhi_internal): Change Yk to k.
27242 (movqi_internal): Ditto.
27243 (*k<logic><mode>): Ditto.
27244 (*andhi_1): Ditto.
27245 (*andqi_1): Ditto.
27246 (kandn<mode>): Ditto.
27247 (*<code>hi_1): Ditto.
27248 (*<code>qi_1): Ditto.
27249 (kxnor<mode>): Ditto.
27250 (kortestzhi): Ditto.
27251 (kortestchi): Ditto.
27252 (kunpckhi): Ditto.
27253 (*one_cmplhi2_1): Ditto.
27254 (*one_cmplqi2_1): Ditto.
27255 * config/i386/sse.md (): Change k to Yk.
27256 (avx512f_load<mode>_mask): Ditto.
27257 (avx512f_blendm<mode>): Ditto.
27258 (avx512f_store<mode>_mask): Ditto.
27259 (avx512f_storeu<ssemodesuffix>512_mask): Ditto.
27260 (avx512f_storedqu<mode>_mask): Ditto.
27261 (avx512f_cmp<mode>3<mask_scalar_merge_name><round_saeonly_name>):
27262 Ditto.
27263 (avx512f_ucmp<mode>3<mask_scalar_merge_name>): Ditto.
27264 (avx512f_vmcmp<mode>3<round_saeonly_name>): Ditto.
27265 (avx512f_vmcmp<mode>3_mask<round_saeonly_name>): Ditto.
27266 (avx512f_maskcmp<mode>3): Ditto.
27267 (avx512f_fmadd_<mode>_mask<round_name>): Ditto.
27268 (avx512f_fmadd_<mode>_mask3<round_name>): Ditto.
27269 (avx512f_fmsub_<mode>_mask<round_name>): Ditto.
27270 (avx512f_fmsub_<mode>_mask3<round_name>): Ditto.
27271 (avx512f_fnmadd_<mode>_mask<round_name>): Ditto.
27272 (avx512f_fnmadd_<mode>_mask3<round_name>): Ditto.
27273 (avx512f_fnmsub_<mode>_mask<round_name>): Ditto.
27274 (avx512f_fnmsub_<mode>_mask3<round_name>): Ditto.
27275 (avx512f_fmaddsub_<mode>_mask<round_name>): Ditto.
27276 (avx512f_fmaddsub_<mode>_mask3<round_name>): Ditto.
27277 (avx512f_fmsubadd_<mode>_mask<round_name>): Ditto.
27278 (avx512f_fmsubadd_<mode>_mask3<round_name>): Ditto.
27279 (avx512f_vextract<shuffletype>32x4_1_maskm): Ditto.
27280 (vec_extract_lo_<mode>_maskm): Ditto.
27281 (vec_extract_hi_<mode>_maskm): Ditto.
27282 (avx512f_vternlog<mode>_mask): Ditto.
27283 (avx512f_fixupimm<mode>_mask<round_saeonly_name>): Ditto.
27284 (avx512f_sfixupimm<mode>_mask<round_saeonly_name>): Ditto.
27285 (avx512f_<code><pmov_src_lower><mode>2_mask): Ditto.
27286 (avx512f_<code>v8div16qi2_mask): Ditto.
27287 (avx512f_<code>v8div16qi2_mask_store): Ditto.
27288 (avx512f_eq<mode>3<mask_scalar_merge_name>_1): Ditto.
27289 (avx512f_gt<mode>3<mask_scalar_merge_name>): Ditto.
27290 (avx512f_testm<mode>3<mask_scalar_merge_name>): Ditto.
27291 (avx512f_testnm<mode>3<mask_scalar_merge_name>): Ditto.
27292 (*avx512pf_gatherpf<mode>sf_mask): Ditto.
27293 (*avx512pf_gatherpf<mode>df_mask): Ditto.
27294 (*avx512pf_scatterpf<mode>sf_mask): Ditto.
27295 (*avx512pf_scatterpf<mode>df_mask): Ditto.
27296 (avx512cd_maskb_vec_dupv8di): Ditto.
27297 (avx512cd_maskw_vec_dupv16si): Ditto.
27298 (avx512f_vpermi2var<mode>3_maskz): Ditto.
27299 (avx512f_vpermi2var<mode>3_mask): Ditto.
27300 (avx512f_vpermi2var<mode>3_mask): Ditto.
27301 (avx512f_vpermt2var<mode>3_maskz): Ditto.
27302 (*avx512f_gathersi<mode>): Ditto.
27303 (*avx512f_gathersi<mode>_2): Ditto.
27304 (*avx512f_gatherdi<mode>): Ditto.
27305 (*avx512f_gatherdi<mode>_2): Ditto.
27306 (*avx512f_scattersi<mode>): Ditto.
27307 (*avx512f_scatterdi<mode>): Ditto.
27308 (avx512f_compress<mode>_mask): Ditto.
27309 (avx512f_compressstore<mode>_mask): Ditto.
27310 (avx512f_expand<mode>_mask): Ditto.
27311 * config/i386/subst.md (mask): Change k to Yk.
27312 (mask_scalar_merge): Ditto.
27313 (sd): Ditto.
27314
27315 2014-01-31 Marc Glisse <marc.glisse@inria.fr>
27316
27317 * doc/extend.texi (Vector Extensions): Document ?: in C++.
27318
27319 2014-01-31 Richard Biener <rguenther@suse.de>
27320
27321 PR middle-end/59990
27322 * builtins.c (fold_builtin_memory_op): Make sure to not
27323 use a floating-point mode or a boolean or enumeral type for
27324 the copy operation.
27325
27326 2014-01-30 DJ Delorie <dj@redhat.com>
27327
27328 * config/msp430/msp430.h (LIB_SPEC): Add -lcrt
27329 * config/msp430/msp430.md (msp430_refsym_need_exit): New.
27330 * config/msp430/msp430.c (msp430_expand_epilogue): Call it
27331 whenever main() has an epilogue.
27332
27333 2014-01-30 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
27334
27335 * config/rs6000/rs6000.c (rs6000_expand_vector_init): Remove
27336 unused variable "field".
27337 * config/rs6000/vsx.md (vsx_mergel_<mode>): Add missing DONE.
27338 (vsx_mergeh_<mode>): Likewise.
27339 * config/rs6000/altivec.md (altivec_vmrghb): Likewise.
27340 (altivec_vmrghh): Likewise.
27341 (altivec_vmrghw): Likewise.
27342 (altivec_vmrglb): Likewise.
27343 (altivec_vmrglh): Likewise.
27344 (altivec_vmrglw): Likewise.
27345 (altivec_vspltb): Add missing uses.
27346 (altivec_vsplth): Likewise.
27347 (altivec_vspltw): Likewise.
27348 (altivec_vspltsf): Likewise.
27349
27350 2014-01-30 Jakub Jelinek <jakub@redhat.com>
27351
27352 PR target/59923
27353 * ifcvt.c (cond_exec_process_insns): Don't conditionalize
27354 frame related instructions.
27355
27356 2014-01-30 Vladimir Makarov <vmakarov@redhat.com>
27357
27358 PR rtl-optimization/59959
27359 * lra-constrains.c (simplify_operand_subreg): Assign NO_REGS to
27360 any reload of register whose subreg is invalid.
27361
27362 2014-01-30 Jakub Jelinek <jakub@redhat.com>
27363
27364 * config/i386/f16cintrin.h (_cvtsh_ss): Avoid -Wnarrowing warning.
27365 * config/i386/avx512fintrin.h (_mm512_mask_cvtusepi64_storeu_epi32):
27366 Add missing return type - void.
27367
27368 2014-01-30 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
27369
27370 * gcc/config/rs6000/rs6000.c (rs6000_expand_vector_init): Use
27371 gen_vsx_xxspltw_v4sf_direct instead of gen_vsx_xxspltw_v4sf;
27372 remove element index adjustment for endian (now handled in vsx.md
27373 and altivec.md).
27374 (altivec_expand_vec_perm_const): Use
27375 gen_altivec_vsplt[bhw]_direct instead of gen_altivec_vsplt[bhw].
27376 * gcc/config/rs6000/vsx.md (UNSPEC_VSX_XXSPLTW): New unspec.
27377 (vsx_xxspltw_<mode>): Adjust element index for little endian.
27378 * gcc/config/rs6000/altivec.md (altivec_vspltb): Divide into a
27379 define_expand and a new define_insn *altivec_vspltb_internal;
27380 adjust for -maltivec=be on a little endian target.
27381 (altivec_vspltb_direct): New.
27382 (altivec_vsplth): Divide into a define_expand and a new
27383 define_insn *altivec_vsplth_internal; adjust for -maltivec=be on a
27384 little endian target.
27385 (altivec_vsplth_direct): New.
27386 (altivec_vspltw): Divide into a define_expand and a new
27387 define_insn *altivec_vspltw_internal; adjust for -maltivec=be on a
27388 little endian target.
27389 (altivec_vspltw_direct): New.
27390 (altivec_vspltsf): Divide into a define_expand and a new
27391 define_insn *altivec_vspltsf_internal; adjust for -maltivec=be on
27392 a little endian target.
27393
27394 2014-01-30 Richard Biener <rguenther@suse.de>
27395
27396 PR tree-optimization/59993
27397 * tree-ssa-forwprop.c (associate_pointerplus): Check we
27398 can propagate form the earlier stmt and avoid the transform
27399 when the intermediate result is needed.
27400
27401 2014-01-30 Alangi Derick <alangiderick@gmail.com>
27402
27403 * README.Portability: Fix typo.
27404
27405 2014-01-30 David Holsgrove <david.holsgrove@xilinx.com>
27406
27407 * config/microblaze/microblaze.md(cstoresf4, cbranchsf4): Replace
27408 comparison_operator with ordered_comparison_operator.
27409
27410 2014-01-30 Nick Clifton <nickc@redhat.com>
27411
27412 * config/mn10300/mn10300-protos.h (mn10300_store_multiple_operation_p):
27413 Rename to mn10300_store_multiple_regs.
27414 * config/mn10300/mn10300.c: Likewise.
27415 * config/mn10300/mn10300.md (store_movm): Fix typo: call
27416 store_multiple_regs.
27417 * config/mn10300/predicates.md (mn10300_store_multiple_operation):
27418 Call mn10300_store_multiple_regs.
27419
27420 2014-01-30 Nick Clifton <nickc@redhat.com>
27421 DJ Delorie <dj@redhat.com>
27422
27423 * config/rl78/rl78.c (register_sizes): Make the "upper half" of
27424 %fp 2 to keep registers after it properly word-aligned.
27425 (rl78_alloc_physical_registers_umul): Handle the case where both
27426 input operands are the same.
27427
27428 2014-01-30 Richard Biener <rguenther@suse.de>
27429
27430 PR tree-optimization/59903
27431 * tree-vect-loop.c (vect_transform_loop): Guard multiple-types
27432 check properly.
27433
27434 2014-01-30 Jason Merrill <jason@redhat.com>
27435
27436 PR c++/59633
27437 * tree.c (walk_type_fields): Handle VECTOR_TYPE.
27438
27439 PR c++/59645
27440 * cgraphunit.c (expand_thunk): Copy volatile arg to a temporary.
27441
27442 2014-01-30 Richard Biener <rguenther@suse.de>
27443
27444 PR tree-optimization/59951
27445 * tree-vect-slp.c (vect_bb_slp_scalar_cost): Skip uses in debug insns.
27446
27447 2014-01-30 Savin Zlobec <savin.zlobec@gmail.com>
27448
27449 PR target/59784
27450 * config/nios2/nios2.c (nios2_fpu_insn_asm): Fix asm output of
27451 SFmode to DFmode case.
27452
27453 2014-01-29 DJ Delorie <dj@redhat.com>
27454
27455 * config/msp430/msp430.opt (-minrt): New.
27456 * config/msp430/msp430.h (STARTFILE_SPEC): Link alternate runtime
27457 if -minrt given.
27458 (ENDFILE_SPEC): Likewise.
27459
27460 2014-01-29 Jan Hubicka <hubicka@ucw.cz>
27461
27462 * ipa-inline-analysis.c (clobber_only_eh_bb_p): New function.
27463 (estimate_function_body_sizes): Use it.
27464
27465 2014-01-29 Paolo Carlini <paolo.carlini@oracle.com>
27466
27467 PR c++/58561
27468 * dwarf2out.c (is_cxx_auto): New.
27469 (is_base_type): Use it.
27470 (gen_type_die_with_usage): Likewise.
27471
27472 2014-01-29 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
27473
27474 * config/rs6000/rs6000.c (altivec_expand_vec_perm_const): Use
27475 CODE_FOR_altivec_vmrg*_direct rather than CODE_FOR_altivec_vmrg*.
27476 * config/rs6000/vsx.md (vsx_mergel_<mode>): Adjust for
27477 -maltivec=be with LE targets.
27478 (vsx_mergeh_<mode>): Likewise.
27479 * config/rs6000/altivec.md (UNSPEC_VMRG[HL]_DIRECT): New unspecs.
27480 (mulv8hi3): Use gen_altivec_vmrg[hl]w_direct.
27481 (altivec_vmrghb): Replace with define_expand and new
27482 *altivec_vmrghb_internal insn; adjust for -maltivec=be with LE targets.
27483 (altivec_vmrghb_direct): New define_insn.
27484 (altivec_vmrghh): Replace with define_expand and new
27485 *altivec_vmrghh_internal insn; adjust for -maltivec=be with LE targets.
27486 (altivec_vmrghh_direct): New define_insn.
27487 (altivec_vmrghw): Replace with define_expand and new
27488 *altivec_vmrghw_internal insn; adjust for -maltivec=be with LE targets.
27489 (altivec_vmrghw_direct): New define_insn.
27490 (*altivec_vmrghsf): Adjust for endianness.
27491 (altivec_vmrglb): Replace with define_expand and new
27492 *altivec_vmrglb_internal insn; adjust for -maltivec=be with LE targets.
27493 (altivec_vmrglb_direct): New define_insn.
27494 (altivec_vmrglh): Replace with define_expand and new
27495 *altivec_vmrglh_internal insn; adjust for -maltivec=be with LE targets.
27496 (altivec_vmrglh_direct): New define_insn.
27497 (altivec_vmrglw): Replace with define_expand and new
27498 *altivec_vmrglw_internal insn; adjust for -maltivec=be with LE targets.
27499 (altivec_vmrglw_direct): New define_insn.
27500 (*altivec_vmrglsf): Adjust for endianness.
27501 (vec_widen_umult_hi_v16qi): Use gen_altivec_vmrghh_direct.
27502 (vec_widen_umult_lo_v16qi): Use gen_altivec_vmrglh_direct.
27503 (vec_widen_smult_hi_v16qi): Use gen_altivec_vmrghh_direct.
27504 (vec_widen_smult_lo_v16qi): Use gen_altivec_vmrglh_direct.
27505 (vec_widen_umult_hi_v8hi): Use gen_altivec_vmrghw_direct.
27506 (vec_widen_umult_lo_v8hi): Use gen_altivec_vmrglw_direct.
27507 (vec_widen_smult_hi_v8hi): Use gen_altivec_vmrghw_direct.
27508 (vec_widen_smult_lo_v8hi): Use gen_altivec_vmrglw_direct.
27509
27510 2014-01-29 Marcus Shawcroft <marcus.shawcroft@arm.com>
27511
27512 * config/aarch64/aarch64.c (aarch64_expand_mov_immediate)
27513 (aarch64_legitimate_address_p, aarch64_class_max_nregs): Adjust
27514 whitespace.
27515
27516 2014-01-29 Richard Biener <rguenther@suse.de>
27517
27518 PR tree-optimization/58742
27519 * tree-ssa-forwprop.c (associate_pointerplus): Rename to
27520 associate_pointerplus_align.
27521 (associate_pointerplus_diff): New function.
27522 (associate_pointerplus): Likewise. Call associate_pointerplus_align
27523 and associate_pointerplus_diff.
27524
27525 2014-01-29 Richard Biener <rguenther@suse.de>
27526
27527 * lto-streamer.h (LTO_major_version): Bump to 3.
27528 (LTO_minor_version): Reset to 0.
27529
27530 2014-01-29 Renlin Li <Renlin.Li@arm.com>
27531
27532 * config/arm/arm-arches.def (ARM_ARCH): Add armv7ve arch.
27533 * config/arm/arm.c (FL_FOR_ARCH7VE): New.
27534 (arm_file_start): Generate correct asm header for armv7ve.
27535 * config/arm/bpabi.h: Add multilib support for armv7ve.
27536 * config/arm/driver-arm.c: Change the architectures of cortex-a7
27537 and cortex-a15 to armv7ve.
27538 * config/arm/t-aprofile: Add multilib support for armv7ve.
27539 * doc/invoke.texi: Document -march=armv7ve.
27540
27541 2014-01-29 Richard Biener <rguenther@suse.de>
27542
27543 PR tree-optimization/58742
27544 * tree-ssa-forwprop.c (associate_plusminus): Return true
27545 if we changed sth, defer EH cleanup to ...
27546 (ssa_forward_propagate_and_combine): ... here. Call simplify_mult.
27547 (simplify_mult): New function.
27548
27549 2014-01-29 Jakub Jelinek <jakub@redhat.com>
27550
27551 PR middle-end/59917
27552 PR tree-optimization/59920
27553 * tree.c (build_common_builtin_nodes): Remove
27554 __builtin_setjmp_dispatcher initialization.
27555 * omp-low.h (make_gimple_omp_edges): Add a new int * argument.
27556 * profile.c (branch_prob): Use gsi_start_nondebug_after_labels_bb
27557 instead of gsi_after_labels + manually skipping debug stmts.
27558 Don't ignore bbs with BUILT_IN_SETJMP_DISPATCHER, instead
27559 ignore bbs with IFN_ABNORMAL_DISPATCHER.
27560 * tree-inline.c (copy_edges_for_bb): Remove
27561 can_make_abnormal_goto argument, instead add abnormal_goto_dest
27562 argument. Ignore computed_goto_p stmts. Don't call
27563 make_abnormal_goto_edges. If a call might need abnormal edges
27564 for non-local gotos, see if it already has an edge to
27565 IFN_ABNORMAL_DISPATCHER or if it is IFN_ABNORMAL_DISPATCHER
27566 with true argument, don't do anything then, otherwise add
27567 EDGE_ABNORMAL from the call's bb to abnormal_goto_dest.
27568 (copy_cfg_body): Compute abnormal_goto_dest, adjust copy_edges_for_bb
27569 caller.
27570 * gimple-low.c (struct lower_data): Remove calls_builtin_setjmp.
27571 (lower_function_body): Don't emit __builtin_setjmp_dispatcher.
27572 (lower_stmt): Don't set data->calls_builtin_setjmp.
27573 (lower_builtin_setjmp): Adjust comment.
27574 * builtins.def (BUILT_IN_SETJMP_DISPATCHER): Remove.
27575 * tree-cfg.c (found_computed_goto): Remove.
27576 (factor_computed_gotos): Remove.
27577 (make_goto_expr_edges): Return bool, true for computed gotos.
27578 Don't call make_abnormal_goto_edges.
27579 (build_gimple_cfg): Don't set found_computed_goto, don't call
27580 factor_computed_gotos.
27581 (computed_goto_p): No longer static.
27582 (make_blocks): Don't set found_computed_goto.
27583 (get_abnormal_succ_dispatcher, handle_abnormal_edges): New functions.
27584 (make_edges): If make_goto_expr_edges returns true, push bb
27585 into ab_edge_goto vector, for stmt_can_make_abnormal_goto calls
27586 instead of calling make_abnormal_goto_edges push bb into ab_edge_call
27587 vector. Record mapping between bbs and OpenMP regions if there
27588 are any, adjust make_gimple_omp_edges caller. Call
27589 handle_abnormal_edges.
27590 (make_abnormal_goto_edges): Remove.
27591 * tree-cfg.h (make_abnormal_goto_edges): Remove.
27592 (computed_goto_p, get_abnormal_succ_dispatcher): New prototypes.
27593 * internal-fn.c (expand_ABNORMAL_DISPATCHER): New function.
27594 * builtins.c (expand_builtin): Don't handle BUILT_IN_SETJMP_DISPATCHER.
27595 * internal-fn.def (ABNORMAL_DISPATCHER): New.
27596 * omp-low.c (make_gimple_omp_edges): Add region_idx argument, when
27597 filling *region also set *region_idx to (*region)->entry->index.
27598
27599 PR other/58712
27600 * read-rtl.c (read_rtx_code): Clear all of RTX_CODE_SIZE (code).
27601 For REGs set ORIGINAL_REGNO.
27602
27603 2014-01-29 Bingfeng Mei <bmei@broadcom.com>
27604
27605 * doc/md.texi: Mention that a target shouldn't implement
27606 vec_widen_(s|u)mul_even/odd pair if it is less efficient
27607 than hi/lo pair.
27608
27609 2014-01-29 Jakub Jelinek <jakub@redhat.com>
27610
27611 PR tree-optimization/59594
27612 * tree-vect-data-refs.c (vect_analyze_data_ref_accesses): Sort
27613 a copy of the datarefs vector rather than the vector itself.
27614
27615 2014-01-28 Jason Merrill <jason@redhat.com>
27616
27617 PR c++/53756
27618 * dwarf2out.c (auto_die): New static.
27619 (gen_type_die_with_usage): Handle C++1y 'auto'.
27620 (gen_subprogram_die): If in-class DIE had 'auto', emit type again
27621 on definition.
27622
27623 2014-01-28 H.J. Lu <hongjiu.lu@intel.com>
27624
27625 PR target/59672
27626 * config/i386/gnu-user64.h (SPEC_32): Add "m16|" to "m32".
27627 (SPEC_X32): Likewise.
27628 (SPEC_64): Likewise.
27629 * config/i386/i386.c (ix86_option_override_internal): Turn off
27630 OPTION_MASK_ISA_64BIT, OPTION_MASK_ABI_X32 and OPTION_MASK_ABI_64
27631 for TARGET_16BIT.
27632 (x86_file_start): Output .code16gcc for TARGET_16BIT.
27633 * config/i386/i386.h (TARGET_16BIT): New macro.
27634 (TARGET_16BIT_P): Likewise.
27635 * config/i386/i386.opt: Add m16.
27636 * doc/invoke.texi: Document -m16.
27637
27638 2014-01-28 Jakub Jelinek <jakub@redhat.com>
27639
27640 PR preprocessor/59935
27641 * input.c (location_get_source_line): Bail out on when line number
27642 is zero, and test the return value of lookup_or_add_file_to_cache_tab.
27643
27644 2014-01-28 Richard Biener <rguenther@suse.de>
27645
27646 PR tree-optimization/58742
27647 * tree-ssa-forwprop.c (associate_plusminus): Handle
27648 pointer subtraction of the form (T)(P + A) - (T)P.
27649
27650 2014-01-28 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
27651
27652 * config/arm/arm.c (arm_new_rtx_costs): Remove useless statement
27653 at const_int_cost.
27654
27655 2014-01-28 Richard Biener <rguenther@suse.de>
27656
27657 Revert
27658 2014-01-28 Richard Biener <rguenther@suse.de>
27659
27660 PR rtl-optimization/45364
27661 PR rtl-optimization/59890
27662 * var-tracking.c (local_get_addr_clear_given_value): Handle
27663 already cleared slot.
27664 (val_reset): Handle not allocated local_get_addr_cache.
27665 (vt_find_locations): Use post-order on the inverted CFG.
27666
27667 2014-01-28 Richard Biener <rguenther@suse.de>
27668
27669 * tree-data-ref.h (ddr_is_anti_dependent, ddrs_have_anti_deps): Remove.
27670
27671 2014-01-28 Richard Biener <rguenther@suse.de>
27672
27673 PR rtl-optimization/45364
27674 PR rtl-optimization/59890
27675 * var-tracking.c (local_get_addr_clear_given_value): Handle
27676 already cleared slot.
27677 (val_reset): Handle not allocated local_get_addr_cache.
27678 (vt_find_locations): Use post-order on the inverted CFG.
27679
27680 2014-01-28 Alan Modra <amodra@gmail.com>
27681
27682 * Makefile.in (BUILD_CPPFLAGS): Do not use ALL_CPPFLAGS.
27683 * configure.ac <recursive call for build != host>: Define
27684 GENERATOR_FILE. Comment. Use CXX_FOR_BUILD, CXXFLAGS_FOR_BUILD
27685 and LD_FOR_BUILD too.
27686 * configure: Regenerate.
27687
27688 2014-01-27 Allan Sandfeld Jensen <sandfeld@kde.org>
27689
27690 * config/i386/i386.c (get_builtin_code_for_version): Separate
27691 Westmere from Nehalem, Ivy Bridge from Sandy Bridge and
27692 Broadwell from Haswell.
27693
27694 2014-01-27 Steve Ellcey <sellcey@mips.com>
27695
27696 * common/config/mips/mips-common.c (TARGET_DEFAULT_TARGET_FLAGS):
27697 Remove TARGET_FP_EXCEPTIONS_DEFAULT and MASK_FUSED_MADD.
27698 * config/mips/mips.c (mips_option_override): Change setting
27699 of TARGET_DSP.
27700 * config/mips/mips.h (TARGET_FP_EXCEPTIONS_DEFAULT): Remove.
27701 * config/mips/mips.opt (DSP, DSPR2, FP_EXCEPTIONS, FUSED_MADD, MIPS3D):
27702 Change from Mask to Var.
27703
27704 2014-01-27 Jeff Law <law@redhat.com>
27705
27706 * ipa-inline.c (inline_small_functions): Fix typo.
27707
27708 2014-01-27 Ilya Tocar <ilya.tocar@intel.com>
27709
27710 * config/i386/avx512fintrin.h (_mm512_mask_cvtepi32_storeu_epi8): New.
27711 (_mm512_mask_cvtsepi32_storeu_epi8): Ditto.
27712 (_mm512_mask_cvtusepi32_storeu_epi8): Ditto.
27713 (_mm512_mask_cvtepi32_storeu_epi16): Ditto.
27714 (_mm512_mask_cvtsepi32_storeu_epi16): Ditto.
27715 (_mm512_mask_cvtusepi32_storeu_epi16): Ditto.
27716 (_mm512_mask_cvtepi64_storeu_epi32): Ditto.
27717 (_mm512_mask_cvtsepi64_storeu_epi32): Ditto.
27718 (_mm512_mask_cvtusepi64_storeu_epi32): Ditto.
27719 (_mm512_mask_cvtepi64_storeu_epi16): Ditto.
27720 (_mm512_mask_cvtsepi64_storeu_epi16): Ditto.
27721 (_mm512_mask_cvtusepi64_storeu_epi16): Ditto.
27722 (_mm512_mask_cvtepi64_storeu_epi8): Ditto.
27723 (_mm512_mask_cvtsepi64_storeu_epi8): Ditto.
27724 (_mm512_mask_cvtusepi64_storeu_epi8): Ditto.
27725 (_mm512_storeu_epi64): Ditto.
27726 (_mm512_cmpge_epi32_mask): Ditto.
27727 (_mm512_cmpge_epu32_mask): Ditto.
27728 (_mm512_cmpge_epi64_mask): Ditto.
27729 (_mm512_cmpge_epu64_mask): Ditto.
27730 (_mm512_cmple_epi32_mask): Ditto.
27731 (_mm512_cmple_epu32_mask): Ditto.
27732 (_mm512_cmple_epi64_mask): Ditto.
27733 (_mm512_cmple_epu64_mask): Ditto.
27734 (_mm512_cmplt_epi32_mask): Ditto.
27735 (_mm512_cmplt_epu32_mask): Ditto.
27736 (_mm512_cmplt_epi64_mask): Ditto.
27737 (_mm512_cmplt_epu64_mask): Ditto.
27738 (_mm512_cmpneq_epi32_mask): Ditto.
27739 (_mm512_cmpneq_epu32_mask): Ditto.
27740 (_mm512_cmpneq_epi64_mask): Ditto.
27741 (_mm512_cmpneq_epu64_mask): Ditto.
27742 (_mm512_expand_pd): Ditto.
27743 (_mm512_expand_ps): Ditto.
27744 * config/i386/i386-builtin-types.def: Add PV16QI, PV16QI, PV16HI,
27745 VOID_PV8SI_V8DI_QI, VOID_PV8HI_V8DI_QI, VOID_PV16QI_V8DI_QI,
27746 VOID_PV16QI_V16SI_HI, VOID_PV16HI_V16SI_HI.
27747 * config/i386/i386.c (ix86_builtins): Add
27748 IX86_BUILTIN_EXPANDPD512_NOMASK, IX86_BUILTIN_EXPANDPS512_NOMASK,
27749 IX86_BUILTIN_PMOVDB512_MEM, IX86_BUILTIN_PMOVDW512_MEM,
27750 IX86_BUILTIN_PMOVQB512_MEM, IX86_BUILTIN_PMOVQD512_MEM,
27751 IX86_BUILTIN_PMOVQW512_MEM, IX86_BUILTIN_PMOVSDB512_MEM,
27752 IX86_BUILTIN_PMOVSDW512_MEM, IX86_BUILTIN_PMOVSQB512_MEM,
27753 IX86_BUILTIN_PMOVSQD512_MEM, IX86_BUILTIN_PMOVSQW512_MEM,
27754 IX86_BUILTIN_PMOVUSDB512_MEM, IX86_BUILTIN_PMOVUSDW512_MEM,
27755 IX86_BUILTIN_PMOVUSQB512_MEM, IX86_BUILTIN_PMOVUSQD512_MEM,
27756 IX86_BUILTIN_PMOVUSQW512_MEM.
27757 (bdesc_special_args): Add __builtin_ia32_pmovusqd512mem_mask,
27758 __builtin_ia32_pmovsqd512mem_mask,
27759 __builtin_ia32_pmovqd512mem_mask,
27760 __builtin_ia32_pmovusqw512mem_mask,
27761 __builtin_ia32_pmovsqw512mem_mask,
27762 __builtin_ia32_pmovqw512mem_mask,
27763 __builtin_ia32_pmovusdw512mem_mask,
27764 __builtin_ia32_pmovsdw512mem_mask,
27765 __builtin_ia32_pmovdw512mem_mask,
27766 __builtin_ia32_pmovqb512mem_mask,
27767 __builtin_ia32_pmovusqb512mem_mask,
27768 __builtin_ia32_pmovsqb512mem_mask,
27769 __builtin_ia32_pmovusdb512mem_mask,
27770 __builtin_ia32_pmovsdb512mem_mask,
27771 __builtin_ia32_pmovdb512mem_mask.
27772 (bdesc_args): Add __builtin_ia32_expanddf512,
27773 __builtin_ia32_expandsf512.
27774 (ix86_expand_special_args_builtin): Handle VOID_FTYPE_PV8SI_V8DI_QI,
27775 VOID_FTYPE_PV8HI_V8DI_QI, VOID_FTYPE_PV16HI_V16SI_HI,
27776 VOID_FTYPE_PV16QI_V8DI_QI, VOID_FTYPE_PV16QI_V16SI_HI.
27777 * config/i386/sse.md (unspec): Add UNSPEC_EXPAND_NOMASK.
27778 (avx512f_<code><pmov_src_lower><mode>2_mask_store): New.
27779 (*avx512f_<code>v8div16qi2_store_mask): Renamed to ...
27780 (avx512f_<code>v8div16qi2_mask_store): This.
27781 (avx512f_expand<mode>): New.
27782
27783 2014-01-27 Kirill Yukhin <kirill.yukhin@intel.com>
27784
27785 * config/i386/avx512pfintrin.h (_mm512_mask_prefetch_i32gather_pd):
27786 New.
27787 (_mm512_mask_prefetch_i64gather_pd): Ditto.
27788 (_mm512_prefetch_i32scatter_pd): Ditto.
27789 (_mm512_mask_prefetch_i32scatter_pd): Ditto.
27790 (_mm512_prefetch_i64scatter_pd): Ditto.
27791 (_mm512_mask_prefetch_i64scatter_pd): Ditto.
27792 (_mm512_mask_prefetch_i32gather_ps): Fix operand type.
27793 (_mm512_mask_prefetch_i64gather_ps): Ditto.
27794 (_mm512_prefetch_i32scatter_ps): Ditto.
27795 (_mm512_mask_prefetch_i32scatter_ps): Ditto.
27796 (_mm512_prefetch_i64scatter_ps): Ditto.
27797 (_mm512_mask_prefetch_i64scatter_ps): Ditto.
27798 * config/i386/i386-builtin-types.def: Define
27799 VOID_FTYPE_QI_V8SI_PCINT64_INT_INT
27800 and VOID_FTYPE_QI_V8DI_PCINT64_INT_INT.
27801 * config/i386/i386.c (ix86_builtins): Define IX86_BUILTIN_GATHERPFQPD,
27802 IX86_BUILTIN_GATHERPFDPD, IX86_BUILTIN_SCATTERPFDPD,
27803 IX86_BUILTIN_SCATTERPFQPD.
27804 (ix86_init_mmx_sse_builtins): Define __builtin_ia32_gatherpfdpd,
27805 __builtin_ia32_gatherpfdps, __builtin_ia32_gatherpfqpd,
27806 __builtin_ia32_gatherpfqps, __builtin_ia32_scatterpfdpd,
27807 __builtin_ia32_scatterpfdps, __builtin_ia32_scatterpfqpd,
27808 __builtin_ia32_scatterpfqps.
27809 (ix86_expand_builtin): Expand new built-ins.
27810 * config/i386/sse.md (avx512pf_gatherpf<mode>): Add SF suffix,
27811 fix memory access data type.
27812 (*avx512pf_gatherpf<mode>_mask): Ditto.
27813 (*avx512pf_gatherpf<mode>): Ditto.
27814 (avx512pf_scatterpf<mode>): Ditto.
27815 (*avx512pf_scatterpf<mode>_mask): Ditto.
27816 (*avx512pf_scatterpf<mode>): Ditto.
27817 (GATHER_SCATTER_SF_MEM_MODE): New.
27818 (avx512pf_gatherpf<mode>df): Ditto.
27819 (*avx512pf_gatherpf<mode>df_mask): Ditto.
27820 (*avx512pf_scatterpf<mode>df): Ditto.
27821
27822 2014-01-27 Jakub Jelinek <jakub@redhat.com>
27823
27824 PR bootstrap/59934
27825 * expmed.h (expmed_mode_index): Rework so that analysis and optimziers
27826 know when the MODE_PARTIAL_INT and MODE_VECTOR_INT cases can never be
27827 reached.
27828
27829 2014-01-27 James Greenhalgh <james.greenhalgh@arm.com>
27830
27831 * common/config/arm/arm-common.c
27832 (arm_rewrite_mcpu): Handle multiple names.
27833 * config/arm/arm.h
27834 (BIG_LITTLE_SPEC): Do not discard mcpu switches.
27835
27836 2014-01-27 James Greenhalgh <james.greenhalgh@arm.com>
27837
27838 * gimple-builder.h (create_gimple_tmp): Delete.
27839
27840 2014-01-27 Christian Bruel <christian.bruel@st.com>
27841
27842 * config/sh/sh-mem.cc (sh_expand_cmpnstr): Fix remaining bytes after
27843 words comparisons.
27844
27845 2014-01-26 John David Anglin <danglin@gcc.gnu.org>
27846
27847 * config/pa/pa.md (call): Generate indirect long calls to non-local
27848 functions when outputing 32-bit code.
27849 (call_value): Likewise except for special call to buggy powf function.
27850
27851 * config/pa/pa.c (pa_attr_length_indirect_call): Adjust length of
27852 portable runtime and PIC indirect calls.
27853 (pa_output_indirect_call): Remove unnecessary nop from portable runtime
27854 and PIC call sequences. Use ldo instead of blr to set return register
27855 in PIC call sequence.
27856
27857 2014-01-25 Walter Lee <walt@tilera.com>
27858
27859 * config/tilegx/sync.md (atomic_fetch_sub): Fix negation and
27860 avoid clobbering a live register.
27861
27862 2014-01-25 Walter Lee <walt@tilera.com>
27863
27864 * config/tilegx/tilegx-c.c (tilegx_cpu_cpp_builtins):
27865 Define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_{1,2}.
27866 * config/tilegx/tilepro-c.c (tilepro_cpu_cpp_builtins):
27867 Define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_{1,2,4,8}.
27868
27869 2014-01-25 Walter Lee <walt@tilera.com>
27870
27871 * config/tilegx/tilegx.c (tilegx_function_arg): Start 16-byte
27872 arguments on even registers.
27873 (tilegx_gimplify_va_arg_expr): Align 16-byte var args to
27874 STACK_BOUNDARY.
27875 * config/tilegx/tilegx.h (STACK_BOUNDARY): Change to 16 bytes.
27876 (BIGGEST_ALIGNMENT): Ditto.
27877 (BIGGEST_FIELD_ALIGNMENT): Ditto.
27878
27879 2014-01-25 Walter Lee <walt@tilera.com>
27880
27881 * config/tilegx/tilegx.c (tilegx_gen_bundles): Delete barrier
27882 insns before bundling.
27883 * config/tilegx/tilegx.md (tile_network_barrier): Update comment.
27884
27885 2014-01-25 Walter Lee <walt@tilera.com>
27886
27887 * config/tilegx/tilegx.c (tilegx_expand_builtin): Set
27888 PREFETCH_SCHEDULE_BARRIER_P to true for prefetches.
27889 * config/tilepro/tilepro.c (tilepro_expand_builtin): Ditto.
27890
27891 2014-01-25 Richard Sandiford <rdsandiford@googlemail.com>
27892
27893 * config/mips/constraints.md (kl): Delete.
27894 * config/mips/mips.md (divmod<mode>4, udivmod<mode>4): Turn into
27895 define expands, using...
27896 (divmod<mode>4_mips16, udivmod<mode>4_mips16): ...these new
27897 instructions for MIPS16.
27898 (*divmod<mode>4, *udivmod<mode>4): New patterns, taken from the
27899 non-MIPS16 version of the old divmod<mode>4 and udivmod<mode>4.
27900
27901 2014-01-25 Walter Lee <walt@tilera.com>
27902
27903 * config/tilepro/tilepro.md (ctzdi2): Use register_operand predicate.
27904 (clzdi2): Ditto.
27905 (ffsdi2): Ditto.
27906
27907 2014-01-25 Walter Lee <walt@tilera.com>
27908
27909 * config/tilegx/tilegx.c (tilegx_expand_to_rtl_hook): New.
27910 (TARGET_EXPAND_TO_RTL_HOOK): Define.
27911
27912 2014-01-25 Richard Sandiford <rdsandiford@googlemail.com>
27913
27914 * rtlanal.c (canonicalize_condition): Split out duplicated mode check.
27915 Handle XOR.
27916
27917 2014-01-25 Jakub Jelinek <jakub@redhat.com>
27918
27919 * print-rtl.c (in_call_function_usage): New var.
27920 (print_rtx): When in CALL_INSN_FUNCTION_USAGE, always print
27921 EXPR_LIST mode as mode and not as reg note name.
27922
27923 PR middle-end/59561
27924 * cfgloopmanip.c (copy_loop_info): If
27925 loop->warned_aggressive_loop_optimizations, make sure
27926 the flag is set in target loop too.
27927
27928 2014-01-24 Balaji V. Iyer <balaji.v.iyer@intel.com>
27929
27930 * builtins.c (is_builtin_name): Renamed flag_enable_cilkplus to
27931 flag_cilkplus.
27932 * builtins.def: Likewise.
27933 * cilk.h (fn_contains_cilk_spawn_p): Likewise.
27934 * cppbuiltin.c (define_builtin_macros_for_compilation_flags): Likewise.
27935 * ira.c (ira_setup_eliminable_regset): Likewise.
27936 * omp-low.c (gate_expand_omp): Likewise.
27937 (execute_lower_omp): Likewise.
27938 (diagnose_sb_0): Likewise.
27939 (gate_diagnose_omp_blocks): Likewise.
27940 (simd_clone_clauses_extract): Likewise.
27941 (gate): Likewise.
27942
27943 2014-01-24 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
27944
27945 * config/rs6000/rs6000.c (rs6000_expand_vec_perm_const_1): Remove
27946 correction for little endian...
27947 * config/rs6000/vsx.md (vsx_xxpermdi2_<mode>_1): ...and move it to
27948 here.
27949
27950 2014-01-24 Jeff Law <law@redhat.com>
27951
27952 PR tree-optimization/59919
27953 * tree-vrp.c (find_assert_locations_1): Do not register asserts
27954 for non-returning calls.
27955
27956 2014-01-24 James Greenhalgh <james.greenhalgh@arm.com>
27957
27958 * common/config/aarch64/aarch64-common.c
27959 (aarch64_rewrite_mcpu): Handle multiple names.
27960 * config/aarch64/aarch64.h
27961 (BIG_LITTLE_SPEC): Do not discard mcpu switches.
27962
27963 2014-01-24 Dodji Seketeli <dodji@redhat.com>
27964
27965 * input.c (add_file_to_cache_tab): Handle the case where fopen
27966 returns NULL.
27967
27968 2014-01-23 H.J. Lu <hongjiu.lu@intel.com>
27969
27970 PR target/59929
27971 * config/i386/i386.md (pushsf splitter): Get stack adjustment
27972 from push operand if code of push isn't PRE_DEC.
27973
27974 2014-01-23 Michael Meissner <meissner@linux.vnet.ibm.com>
27975
27976 PR target/59909
27977 * doc/invoke.texi (RS/6000 and PowerPC Options): Document
27978 -mquad-memory-atomic. Update -mquad-memory documentation to say
27979 it is only used for non-atomic loads/stores.
27980
27981 * config/rs6000/predicates.md (quad_int_reg_operand): Allow either
27982 -mquad-memory or -mquad-memory-atomic switches.
27983
27984 * config/rs6000/rs6000-cpus.def (ISA_2_7_MASKS_SERVER): Add
27985 -mquad-memory-atomic to ISA 2.07 support.
27986
27987 * config/rs6000/rs6000.opt (-mquad-memory-atomic): Add new switch
27988 to separate support of normal quad word memory operations (ldq, stq)
27989 from the atomic quad word memory operations.
27990
27991 * config/rs6000/rs6000.c (rs6000_option_override_internal): Add
27992 support to separate non-atomic quad word operations from atomic
27993 quad word operations. Disable non-atomic quad word operations in
27994 little endian mode so that we don't have to swap words after the
27995 load and before the store.
27996 (quad_load_store_p): Add comment about atomic quad word support.
27997 (rs6000_opt_masks): Add -mquad-memory-atomic to the list of
27998 options printed with -mdebug=reg.
27999
28000 * config/rs6000/rs6000.h (TARGET_SYNC_TI): Use
28001 -mquad-memory-atomic as the test for whether we have quad word
28002 atomic instructions.
28003 (TARGET_SYNC_HI_QI): If either -mquad-memory-atomic, -mquad-memory,
28004 or -mp8-vector are used, allow byte/half-word atomic operations.
28005
28006 * config/rs6000/sync.md (load_lockedti): Insure that the address
28007 is a proper indexed or indirect address for the lqarx instruction.
28008 On little endian systems, swap the hi/lo registers after the lqarx
28009 instruction.
28010 (load_lockedpti): Use indexed_or_indirect_operand predicate to
28011 insure the address is valid for the lqarx instruction.
28012 (store_conditionalti): Insure that the address is a proper indexed
28013 or indirect address for the stqcrx. instruction. On little endian
28014 systems, swap the hi/lo registers before doing the stqcrx.
28015 instruction.
28016 (store_conditionalpti): Use indexed_or_indirect_operand predicate to
28017 insure the address is valid for the stqcrx. instruction.
28018
28019 * gcc/config/rs6000/rs6000-c.c (rs6000_target_modify_macros):
28020 Define __QUAD_MEMORY__ and __QUAD_MEMORY_ATOMIC__ based on what
28021 type of quad memory support is available.
28022
28023 2014-01-23 Vladimir Makarov <vmakarov@redhat.com>
28024
28025 PR regression/59915
28026 * lra-constraints.c (simplify_operand_subreg): Spill pseudo if
28027 there is a danger of looping.
28028
28029 2014-01-23 Pat Haugen <pthaugen@us.ibm.com>
28030
28031 * config/rs6000/rs6000.c (rs6000_option_override_internal): Don't
28032 force flag_ira_loop_pressure if set via command line.
28033
28034 2014-01-23 Alex Velenko <Alex.Velenko@arm.com>
28035
28036 * config/aarch64/aarch64-simd-builtins.def (ashr): DI mode removed.
28037 (ashr_simd): New builtin handling DI mode.
28038 * config/aarch64/aarch64-simd.md (aarch64_ashr_simddi): New pattern.
28039 (aarch64_sshr_simddi): New match pattern.
28040 * config/aarch64/arm_neon.h (vshr_n_s32): Builtin call modified.
28041 (vshrd_n_s64): Likewise.
28042 * config/aarch64/predicates.md (aarch64_shift_imm64_di): New predicate.
28043
28044 2014-01-23 Nick Clifton <nickc@redhat.com>
28045
28046 * config/msp430/msp430.h (ASM_SPEC): Pass the -mcpu as -mcpu.
28047 (LIB_SPEC): Drop use of memory.ld and peripherals.ld scripts in
28048 favour of mcu specific scripts.
28049 * config/msp430/t-msp430 (MULTILIB_MATCHES): Add more matches for
28050 430x multilibs.
28051
28052 2014-01-23 James Greenhalgh <james.greenhalgh@arm.com>
28053 Alex Velenko <Alex.Velenko@arm.com>
28054
28055 * config/aarch64/arm_neon.h (vaddv_s8): __LANE0 cleanup.
28056 (vaddv_s16): Likewise.
28057 (vaddv_s32): Likewise.
28058 (vaddv_u8): Likewise.
28059 (vaddv_u16): Likewise.
28060 (vaddv_u32): Likewise.
28061 (vaddvq_s8): Likewise.
28062 (vaddvq_s16): Likewise.
28063 (vaddvq_s32): Likewise.
28064 (vaddvq_s64): Likewise.
28065 (vaddvq_u8): Likewise.
28066 (vaddvq_u16): Likewise.
28067 (vaddvq_u32): Likewise.
28068 (vaddvq_u64): Likewise.
28069 (vaddv_f32): Likewise.
28070 (vaddvq_f32): Likewise.
28071 (vaddvq_f64): Likewise.
28072 (vmaxv_f32): Likewise.
28073 (vmaxv_s8): Likewise.
28074 (vmaxv_s16): Likewise.
28075 (vmaxv_s32): Likewise.
28076 (vmaxv_u8): Likewise.
28077 (vmaxv_u16): Likewise.
28078 (vmaxv_u32): Likewise.
28079 (vmaxvq_f32): Likewise.
28080 (vmaxvq_f64): Likewise.
28081 (vmaxvq_s8): Likewise.
28082 (vmaxvq_s16): Likewise.
28083 (vmaxvq_s32): Likewise.
28084 (vmaxvq_u8): Likewise.
28085 (vmaxvq_u16): Likewise.
28086 (vmaxvq_u32): Likewise.
28087 (vmaxnmv_f32): Likewise.
28088 (vmaxnmvq_f32): Likewise.
28089 (vmaxnmvq_f64): Likewise.
28090 (vminv_f32): Likewise.
28091 (vminv_s8): Likewise.
28092 (vminv_s16): Likewise.
28093 (vminv_s32): Likewise.
28094 (vminv_u8): Likewise.
28095 (vminv_u16): Likewise.
28096 (vminv_u32): Likewise.
28097 (vminvq_f32): Likewise.
28098 (vminvq_f64): Likewise.
28099 (vminvq_s8): Likewise.
28100 (vminvq_s16): Likewise.
28101 (vminvq_s32): Likewise.
28102 (vminvq_u8): Likewise.
28103 (vminvq_u16): Likewise.
28104 (vminvq_u32): Likewise.
28105 (vminnmv_f32): Likewise.
28106 (vminnmvq_f32): Likewise.
28107 (vminnmvq_f64): Likewise.
28108
28109 2014-01-23 James Greenhalgh <james.greenhalgh@arm.com>
28110
28111 * config/aarch64/aarch64-simd.md
28112 (aarch64_dup_lane<mode>): Correct lane number on big-endian.
28113 (aarch64_dup_lane_<vswap_widthi_name><mode>): Likewise.
28114 (*aarch64_mul3_elt<mode>): Likewise.
28115 (*aarch64_mul3_elt<vswap_width_name><mode>): Likewise.
28116 (*aarch64_mul3_elt_to_64v2df): Likewise.
28117 (*aarch64_mla_elt<mode>): Likewise.
28118 (*aarch64_mla_elt_<vswap_width_name><mode>): Likewise.
28119 (*aarch64_mls_elt<mode>): Likewise.
28120 (*aarch64_mls_elt_<vswap_width_name><mode>): Likewise.
28121 (*aarch64_fma4_elt<mode>): Likewise.
28122 (*aarch64_fma4_elt_<vswap_width_name><mode>): Likewise.
28123 (*aarch64_fma4_elt_to_64v2df): Likewise.
28124 (*aarch64_fnma4_elt<mode>): Likewise.
28125 (*aarch64_fnma4_elt_<vswap_width_name><mode>): Likewise.
28126 (*aarch64_fnma4_elt_to_64v2df): Likewise.
28127 (aarch64_sq<r>dmulh_lane<mode>): Likewise.
28128 (aarch64_sq<r>dmulh_laneq<mode>): Likewise.
28129 (aarch64_sqdml<SBINQOPS:as>l_lane<mode>_internal): Likewise.
28130 (aarch64_sqdml<SBINQOPS:as>l_lane<mode>_internal): Likewise.
28131 (aarch64_sqdml<SBINQOPS:as>l2_lane<mode>_internal): Likewise.
28132 (aarch64_sqdmull_lane<mode>_internal): Likewise.
28133 (aarch64_sqdmull2_lane<mode>_internal): Likewise.
28134
28135 2013-01-23 Alex Velenko <Alex.Velenko@arm.com>
28136
28137 * config/aarch64/aarch64-simd.md
28138 (aarch64_be_checked_get_lane<mode>): New define_expand.
28139 * config/aarch64/aarch64-simd-builtins.def
28140 (BUILTIN_VALL (GETLANE, be_checked_get_lane, 0)):
28141 New builtin definition.
28142 * config/aarch64/arm_neon.h: (__aarch64_vget_lane_any):
28143 Use new safe be builtin.
28144
28145 2014-01-23 Alex Velenko <Alex.Velenko@arm.com>
28146
28147 * config/aarch64/aarch64-simd.md (aarch64_be_ld1<mode>):
28148 New define_insn.
28149 (aarch64_be_st1<mode>): Likewise.
28150 (aarch_ld1<VALL:mode>): Define_expand modified.
28151 (aarch_st1<VALL:mode>): Likewise.
28152 * config/aarch64/aarch64.md (UNSPEC_LD1): New unspec definition.
28153 (UNSPEC_ST1): Likewise.
28154
28155 2014-01-23 David Holsgrove <david.holsgrove@xilinx.com>
28156
28157 * config/microblaze/microblaze.md: Add trap insn and attribute
28158
28159 2014-01-23 Dodji Seketeli <dodji@redhat.com>
28160
28161 PR preprocessor/58580
28162 * input.h (location_get_source_line): Take an additional line_size
28163 parameter.
28164 (void diagnostics_file_cache_fini): Declare new function.
28165 * input.c (struct fcache): New type.
28166 (fcache_tab_size, fcache_buffer_size, fcache_line_record_size):
28167 New static constants.
28168 (diagnostic_file_cache_init, total_lines_num)
28169 (lookup_file_in_cache_tab, evicted_cache_tab_entry)
28170 (add_file_to_cache_tab, lookup_or_add_file_to_cache_tab)
28171 (needs_read, needs_grow, maybe_grow, read_data, maybe_read_data)
28172 (get_next_line, read_next_line, goto_next_line, read_line_num):
28173 New static function definitions.
28174 (diagnostic_file_cache_fini): New function.
28175 (location_get_source_line): Take an additional output line_len
28176 parameter. Re-write using lookup_or_add_file_to_cache_tab and
28177 read_line_num.
28178 * diagnostic.c (diagnostic_finish): Call
28179 diagnostic_file_cache_fini.
28180 (adjust_line): Take an additional input parameter for the length
28181 of the line, rather than calculating it with strlen.
28182 (diagnostic_show_locus): Adjust the use of
28183 location_get_source_line and adjust_line with respect to their new
28184 signature. While displaying a line now, do not stop at the first
28185 null byte. Rather, display the zero byte as a space and keep
28186 going until we reach the size of the line.
28187 * Makefile.in: Add vec.o to OBJS-libcommon
28188
28189 2014-01-23 Kirill Yukhin <kirill.yukhin@intel.com>
28190 Ilya Tocar <ilya.tocar@intel.com>
28191
28192 * config/i386/avx512fintrin.h (_mm512_kmov): New.
28193 * config/i386/i386.c (IX86_BUILTIN_KMOV16): Ditto.
28194 (__builtin_ia32_kmov16): Ditto.
28195 * config/i386/i386.md (UNSPEC_KMOV): New.
28196 (kmovw): Ditto.
28197
28198 2014-01-23 Kirill Yukhin <kirill.yukhin@intel.com>
28199
28200 * config/i386/avx512fintrin.h (_mm512_loadu_si512): Rename.
28201 (_mm512_storeu_si512): Ditto.
28202
28203 2014-01-23 Richard Sandiford <rdsandiford@googlemail.com>
28204
28205 PR target/52125
28206 * rtl.h (get_referenced_operands): Declare.
28207 * recog.c (get_referenced_operands): New function.
28208 * config/mips/mips.c (mips_reorg_process_insns): Check which asm
28209 operands have been referenced when recording LO_SUM references.
28210
28211 2014-01-22 David Holsgrove <david.holsgrove@xilinx.com>
28212
28213 * config/microblaze/microblaze.md: Correct bswaphi2 insn.
28214
28215 2014-01-22 Jan Hubicka <hubicka@ucw.cz>
28216
28217 * config/i386/x86-tune.def (X86_TUNE_ACCUMULATE_OUTGOING_ARGS):
28218 Enable for generic and recent AMD targets.
28219
28220 2014-01-22 Jan Hubicka <hubicka@ucw.cz>
28221
28222 * combine-stack-adj.c (combine_stack_adjustments_for_block): Remove
28223 ARG_SIZE note when adjustment was eliminated.
28224
28225 2014-01-22 Jeff Law <law@redhat.com>
28226
28227 PR tree-optimization/59597
28228 * tree-ssa-threadupdate.c (dump_jump_thread_path): Move to earlier
28229 in file. Accept new argument REGISTERING and use it to modify
28230 dump output appropriately.
28231 (register_jump_thread): Corresponding changes.
28232 (mark_threaded_blocks): Reinstate code to cancel unprofitable
28233 thread paths involving joiner blocks. Add code to dump cancelled
28234 jump threading paths.
28235
28236 2014-01-22 Vladimir Makarov <vmakarov@redhat.com>
28237
28238 PR rtl-optimization/59477
28239 * lra-constraints.c (inherit_in_ebb): Process call for living hard
28240 regs. Update reloads_num and potential_reload_hard_regs for all insns.
28241
28242 2014-01-22 Tom Tromey <tromey@redhat.com>
28243
28244 * config/i386/i386-interix.h (i386_pe_unique_section): Don't use
28245 PARAMS.
28246 * config/cr16/cr16-protos.h (notice_update_cc): Don't use PARAMS.
28247
28248 2014-01-21 Vladimir Makarov <vmakarov@redhat.com>
28249
28250 PR rtl-optimization/59896
28251 * lra-constraints.c (process_alt_operands): Check unused note for
28252 matched operands of insn with no output reloads.
28253
28254 2014-01-21 Richard Sandiford <rdsandiford@googlemail.com>
28255
28256 * config/mips/mips.c (mips_move_to_gpr_cost): Add M16_REGS case.
28257 (mips_move_from_gpr_cost): Likewise.
28258
28259 2014-01-21 Vladimir Makarov <vmakarov@redhat.com>
28260
28261 PR rtl-optimization/59858
28262 * lra-constraints.c (SMALL_REGISTER_CLASS_P): Use
28263 ira_class_hard_regs_num.
28264 (process_alt_operands): Increase reject for dying matched operand.
28265
28266 2014-01-21 Jakub Jelinek <jakub@redhat.com>
28267
28268 PR target/59003
28269 * config/i386/i386.c (expand_small_movmem_or_setmem): If mode is
28270 smaller than size, perform several stores or loads and stores
28271 at dst + count - size to store or copy all of size bytes, rather
28272 than just last modesize bytes.
28273
28274 2014-01-20 DJ Delorie <dj@redhat.com>
28275
28276 * config/rl78/rl78.c (rl78_propogate_register_origins): Verify
28277 that CLOBBERs are REGs before propogating their values.
28278
28279 2014-01-20 H.J. Lu <hongjiu.lu@intel.com>
28280
28281 PR middle-end/59789
28282 * cgraph.c (cgraph_inline_failed_string): Add type to DEFCIFCODE.
28283 (cgraph_inline_failed_type): New function.
28284 * cgraph.h (DEFCIFCODE): Add type.
28285 (cgraph_inline_failed_type_t): New enum.
28286 (cgraph_inline_failed_type): New prototype.
28287 * cif-code.def: Add CIF_FINAL_NORMAL to OK, FUNCTION_NOT_CONSIDERED,
28288 FUNCTION_NOT_OPTIMIZED, REDEFINED_EXTERN_INLINE,
28289 FUNCTION_NOT_INLINE_CANDIDATE, LARGE_FUNCTION_GROWTH_LIMIT,
28290 LARGE_STACK_FRAME_GROWTH_LIMIT, MAX_INLINE_INSNS_SINGLE_LIMIT,
28291 MAX_INLINE_INSNS_AUTO_LIMIT, INLINE_UNIT_GROWTH_LIMIT,
28292 RECURSIVE_INLINING, UNLIKELY_CALL, NOT_DECLARED_INLINED,
28293 OPTIMIZING_FOR_SIZE, ORIGINALLY_INDIRECT_CALL,
28294 INDIRECT_UNKNOWN_CALL, USES_COMDAT_LOCAL.
28295 Add CIF_FINAL_ERROR to UNSPECIFIED, BODY_NOT_AVAILABLE,
28296 FUNCTION_NOT_INLINABLE, OVERWRITABLE, MISMATCHED_ARGUMENTS,
28297 EH_PERSONALITY, NON_CALL_EXCEPTIONS, TARGET_OPTION_MISMATCH,
28298 OPTIMIZATION_MISMATCH.
28299 * tree-inline.c (expand_call_inline): Emit errors during
28300 early_inlining if cgraph_inline_failed_type returns CIF_FINAL_ERROR.
28301
28302 2014-01-20 Uros Bizjak <ubizjak@gmail.com>
28303
28304 PR target/59685
28305 * config/i386/sse.md (*andnot<mode>3<mask_name>): Handle MODE_V16SF
28306 mode attribute in insn output.
28307
28308 2014-01-20 Eric Botcazou <ebotcazou@adacore.com>
28309
28310 * output.h (output_constant): Delete.
28311 * varasm.c (output_constant): Make private.
28312
28313 2014-01-20 Alex Velenko <Alex.Velenko@arm.com>
28314
28315 * config/aarch64/aarch64-simd.md (vec_perm<mode>): Add BE check.
28316
28317 2014-01-20 Jakub Jelinek <jakub@redhat.com>
28318
28319 PR middle-end/59860
28320 * tree.h (fold_builtin_strcat): New prototype.
28321 * builtins.c (fold_builtin_strcat): No longer static. Add len
28322 argument, if non-NULL, don't call c_strlen. Optimize
28323 directly into __builtin_memcpy instead of __builtin_strcpy.
28324 (fold_builtin_2): Adjust fold_builtin_strcat caller.
28325 * gimple-fold.c (gimple_fold_builtin): Handle BUILT_IN_STRCAT.
28326
28327 2014-01-20 Uros Bizjak <ubizjak@gmail.com>
28328
28329 * config/i386/i386.c (ix86_avoid_lea_for_addr): Return false
28330 for SImode_address_operand operands, having only a REG argument.
28331
28332 2014-01-20 Marcus Shawcroft <marcus.shawcroft@arm.com>
28333
28334 * config/aarch64/aarch64-linux.h (GLIBC_DYNAMIC_LINKER): Expand
28335 loader name using mbig-endian.
28336 (LINUX_TARGET_LINK_SPEC): Pass linker -m flag.
28337
28338 2014-01-20 James Greenhalgh <james.greenhalgh@arm.com>
28339
28340 * doc/invoke.texi (-march): Clarify documentation for AArch64.
28341 (-mtune): Likewise.
28342 (-mcpu): Likewise.
28343
28344 2014-01-20 Tejas Belagod <tejas.belagod@arm.com>
28345
28346 * config/aarch64/aarch64-protos.h
28347 (aarch64_cannot_change_mode_class_ptr): Declare.
28348 * config/aarch64/aarch64.c (aarch64_cannot_change_mode_class,
28349 aarch64_cannot_change_mode_class_ptr): New.
28350 * config/aarch64/aarch64.h (CANNOT_CHANGE_MODE_CLASS): Change to call
28351 backend hook aarch64_cannot_change_mode_class.
28352
28353 2014-01-20 James Greenhalgh <james.greenhalgh@arm.com>
28354
28355 * common/config/aarch64/aarch64-common.c
28356 (aarch64_handle_option): Don't handle any option order logic here.
28357 * config/aarch64/aarch64.c (aarch64_parse_arch): Do not override
28358 selected_cpu, warn on architecture version mismatch.
28359 (aarch64_override_options): Fix parsing order for option strings.
28360
28361 2014-01-20 Jan-Benedict Glaw <jbglaw@lug-owl.de>
28362 Iain Sandoe <iain@codesourcery.com>
28363
28364 PR bootstrap/59496
28365 * config/rs6000/darwin.h (ADJUST_FIELD_ALIGN): Fix unused variable
28366 warning. Amend comment to reflect current functionality.
28367
28368 2014-01-20 Richard Biener <rguenther@suse.de>
28369
28370 PR middle-end/59860
28371 * builtins.c (fold_builtin_strcat): Remove case better handled
28372 by tree-ssa-strlen.c.
28373
28374 2014-01-20 Alan Lawrence <alan.lawrence@arm.com>
28375
28376 * config/aarch64/aarch64.opt
28377 (mcpu, march, mtune): Make case-insensitive.
28378
28379 2014-01-20 Jakub Jelinek <jakub@redhat.com>
28380
28381 PR target/59880
28382 * config/i386/i386.c (ix86_avoid_lea_for_addr): Return false
28383 if operands[1] is a REG or ZERO_EXTEND of a REG.
28384
28385 2014-01-19 Jan Hubicka <hubicka@ucw.cz>
28386
28387 * varasm.c (compute_reloc_for_constant): Use targetm.binds_local_p.
28388
28389 2014-01-19 John David Anglin <danglin@gcc.gnu.org>
28390
28391 * config/pa/pa.c (pa_attr_length_millicode_call): Correct length of
28392 long non-pic millicode calls.
28393
28394 2014-01-19 Jan-Benedict Glaw <jbglaw@lug-owl.de>
28395
28396 * config/vax/vax.h (FUNCTION_ARG_REGNO_P): Fix unused variable warning.
28397
28398 2014-01-19 Kito Cheng <kito@0xlab.org>
28399
28400 * builtins.c (expand_movstr): Check movstr expand done or fail.
28401
28402 2014-01-18 Uros Bizjak <ubizjak@gmail.com>
28403 H.J. Lu <hongjiu.lu@intel.com>
28404
28405 PR target/59379
28406 * config/i386/i386.md (*lea<mode>): Zero-extend return register
28407 to DImode for zero-extended addresses.
28408
28409 2014-01-19 Jakub Jelinek <jakub@redhat.com>
28410
28411 PR rtl-optimization/57763
28412 * bb-reorder.c (fix_crossing_unconditional_branches): Set JUMP_LABEL
28413 on the new indirect jump_insn and increment LABEL_NUSES (label).
28414
28415 2014-01-18 H.J. Lu <hongjiu.lu@intel.com>
28416
28417 PR bootstrap/59580
28418 PR bootstrap/59583
28419 * config.gcc (x86_archs): New variable.
28420 (x86_64_archs): Likewise.
28421 (x86_cpus): Likewise.
28422 Use $x86_archs, $x86_64_archs and $x86_cpus to check valid
28423 --with-arch/--with-cpu= options.
28424 Support --with-arch=/--with-cpu={nehalem,westmere,
28425 sandybridge,ivybridge,haswell,broadwell,bonnell,silvermont}.
28426
28427 2014-01-18 Uros Bizjak <ubizjak@gmail.com>
28428
28429 * config/i386/i386.c (ix86_adjust_cost): Reorder PROCESSOR_K8
28430 and PROCESSOR_ATHLON to simplify code. Move "memory" calculation.
28431
28432 2014-01-18 Uros Bizjak <ubizjak@gmail.com>
28433
28434 * config/i386/i386.md (*swap<mode>): Rename from swap<mode>.
28435
28436 2014-01-18 Jakub Jelinek <jakub@redhat.com>
28437
28438 PR target/58944
28439 * config/i386/i386-c.c (ix86_pragma_target_parse): Temporarily
28440 clear cpp_get_options (parse_in)->warn_unused_macros for
28441 ix86_target_macros_internal with cpp_define.
28442
28443 2014-01-18 Richard Sandiford <rdsandiford@googlemail.com>
28444
28445 * jump.c (delete_related_insns): Keep (use (insn))s.
28446 * reorg.c (redundant_insn): Check for barriers too.
28447
28448 2014-01-17 H.J. Lu <hongjiu.lu@intel.com>
28449
28450 * config/i386/i386.c (ix86_split_lea_for_addr): Fix a comment typo.
28451
28452 2014-01-17 John David Anglin <danglin@gcc.gnu.org>
28453
28454 * config/pa/pa.c (pa_attr_length_indirect_call): Don't output a short
28455 call to $$dyncall when TARGET_LONG_CALLS is true.
28456
28457 2014-01-17 Jeff Law <law@redhat.com>
28458
28459 * ree.c (combine_set_extension): Temporarily disable test for
28460 changing number of hard registers.
28461
28462 2014-01-17 Jan Hubicka <hubicka@ucw.cz>
28463
28464 PR middle-end/58125
28465 * ipa-inline-analysis.c (inline_free_summary):
28466 Do not free summary of aliases.
28467
28468 2014-01-17 Jakub Jelinek <jakub@redhat.com>
28469
28470 PR middle-end/59706
28471 * gimplify.c (gimplify_expr): Use create_tmp_var
28472 instead of create_tmp_var_raw. If cond doesn't have
28473 integral type, don't add the IFN_ANNOTATE builtin at all.
28474
28475 2014-01-17 Martin Jambor <mjambor@suse.cz>
28476
28477 PR ipa/59736
28478 * ipa-cp.c (prev_edge_clone): New variable.
28479 (grow_next_edge_clone_vector): Renamed to grow_edge_clone_vectors.
28480 Also resize prev_edge_clone vector.
28481 (ipcp_edge_duplication_hook): Also update prev_edge_clone.
28482 (ipcp_edge_removal_hook): New function.
28483 (ipcp_driver): Register ipcp_edge_removal_hook.
28484
28485 2014-01-17 Andrew Pinski <apinski@cavium.com>
28486 Steve Ellcey <sellcey@mips.com>
28487
28488 PR target/59462
28489 * config/mips/mips.c (mips_print_operand): Check operand mode instead
28490 of operator mode.
28491
28492 2014-01-17 Jeff Law <law@redhat.com>
28493
28494 PR middle-end/57904
28495 * passes.def: Reorder pass_copy_prop, pass_unrolli, pass_ccp sequence
28496 so that pass_ccp runs first.
28497
28498 2014-01-17 H.J. Lu <hongjiu.lu@intel.com>
28499
28500 * config/i386/i386.c (ix86_lea_outperforms): Use TARGET_XXX.
28501 (ix86_adjust_cost): Use !TARGET_XXX.
28502 (do_reorder_for_imul): Likewise.
28503 (swap_top_of_ready_list): Likewise.
28504 (ix86_sched_reorder): Likewise.
28505
28506 2014-01-17 H.J. Lu <hongjiu.lu@intel.com>
28507
28508 * config/i386/i386-c.c (ix86_target_macros_internal): Handle
28509 PROCESSOR_INTEL. Treat like PROCESSOR_GENERIC.
28510 * config/i386/i386.c (intel_memcpy): New. Duplicate slm_memcpy.
28511 (intel_memset): New. Duplicate slm_memset.
28512 (intel_cost): New. Duplicate slm_cost.
28513 (m_INTEL): New macro.
28514 (processor_target_table): Add "intel".
28515 (ix86_option_override_internal): Replace PROCESSOR_SILVERMONT
28516 with PROCESSOR_INTEL for "intel".
28517 (ix86_lea_outperforms): Support PROCESSOR_INTEL. Duplicate
28518 PROCESSOR_SILVERMONT.
28519 (ix86_issue_rate): Likewise.
28520 (ix86_adjust_cost): Likewise.
28521 (ia32_multipass_dfa_lookahead): Likewise.
28522 (swap_top_of_ready_list): Likewise.
28523 (ix86_sched_reorder): Likewise.
28524 (ix86_avoid_lea_for_addr): Check TARGET_AVOID_LEA_FOR_ADDR
28525 instead of TARGET_OPT_AGU.
28526 * config/i386/i386.h (TARGET_INTEL): New.
28527 (TARGET_AVOID_LEA_FOR_ADDR): Likewise.
28528 (processor_type): Add PROCESSOR_INTEL.
28529 * config/i386/x86-tune.def: Support m_INTEL. Duplicate m_SILVERMONT.
28530 Add X86_TUNE_AVOID_LEA_FOR_ADDR.
28531
28532 2014-01-17 Marek Polacek <polacek@redhat.com>
28533
28534 PR c/58346
28535 * gimple-fold.c (fold_array_ctor_reference): Don't fold if element
28536 size is zero.
28537
28538 2014-01-17 Richard Biener <rguenther@suse.de>
28539
28540 PR tree-optimization/46590
28541 * opts.c (default_options_table): Add entries for
28542 OPT_fbranch_count_reg, OPT_fmove_loop_invariants and OPT_ftree_pta,
28543 all enabled at -O1 but not for -Og.
28544 * common.opt (fbranch-count-reg): Remove Init(1).
28545 (fmove-loop-invariants): Likewise.
28546 (ftree-pta): Likewise.
28547
28548 2014-01-17 Jakub Jelinek <jakub@redhat.com>
28549
28550 * config/i386/i386.c (ix86_data_alignment): For compatibility with
28551 (incorrect) GCC 4.8 and earlier alignment assumptions ensure we align
28552 decls to at least the GCC 4.8 used alignments.
28553
28554 PR fortran/59440
28555 * tree-nested.c (convert_nonlocal_reference_stmt,
28556 convert_local_reference_stmt): For NAMELIST_DECLs in gimple_bind_vars
28557 of GIMPLE_BIND stmts, adjust associated decls.
28558
28559 2014-01-17 Richard Biener <rguenther@suse.de>
28560
28561 PR tree-optimization/46590
28562 * vec.h (vec<>::bseach): New member function implementing
28563 binary search according to C89 bsearch.
28564 (vec<>::qsort): Avoid calling ::qsort for vectors with sizes 0 or 1.
28565 * tree-ssa-loop-im.c (struct mem_ref): Make stored member a
28566 bitmap pointer again. Make accesses_in_loop a flat array.
28567 (mem_ref_obstack): New global.
28568 (outermost_indep_loop): Adjust for mem_ref->stored changes.
28569 (mark_ref_stored): Likewise.
28570 (ref_indep_loop_p_2): Likewise.
28571 (set_ref_stored_in_loop): New helper function.
28572 (mem_ref_alloc): Allocate mem_refs on the mem_ref_obstack obstack.
28573 (memref_free): Adjust.
28574 (record_mem_ref_loc): Simplify.
28575 (gather_mem_refs_stmt): Adjust.
28576 (sort_locs_in_loop_postorder_cmp): New function.
28577 (analyze_memory_references): Sort accesses_in_loop after
28578 loop postorder number.
28579 (find_ref_loc_in_loop_cmp): New function.
28580 (for_all_locs_in_loop): Find relevant cluster of locs in
28581 accesses_in_loop and iterate without recursion.
28582 (execute_sm): Avoid uninit warning.
28583 (struct ref_always_accessed): Simplify.
28584 (ref_always_accessed::operator ()): Likewise.
28585 (ref_always_accessed_p): Likewise.
28586 (tree_ssa_lim_initialize): Initialize mem_ref_obstack, compute
28587 loop postorder numbers here.
28588 (tree_ssa_lim_finalize): Free mem_ref_obstack and loop postorder
28589 numbers.
28590
28591 2014-01-17 Jan Hubicka <hubicka@ucw.cz>
28592
28593 PR c++/57945
28594 * passes.c (rest_of_decl_compilation): Don't call varpool_finalize_decl
28595 on decls for which assemble_alias has been called.
28596
28597 2014-01-17 Nick Clifton <nickc@redhat.com>
28598
28599 * config/msp430/msp430.opt: (mcpu): New option.
28600 * config/msp430/msp430.c (msp430_mcu_name): Use target_mcu.
28601 (msp430_option_override): Parse target_cpu. If the MCU name
28602 matches a generic string, clear target_mcu.
28603 (msp430_attr): Allow numeric interrupt values up to 63.
28604 (msp430_expand_epilogue): No longer invert operand 1 of gen_popm.
28605 * config/msp430/msp430.h (ASM_SPEC): Convert -mcpu into a -mmcu
28606 option.
28607 * config/msp430/t-msp430: (MULTILIB_MATCHES): Remove mcu matches.
28608 Add mcpu matches.
28609 * config/msp430/msp430.md (popm): Use %J rather than %I.
28610 (addsi3): Use msp430_nonimmediate_operand for operand 2.
28611 (addhi_cy_i): Use immediate_operand for operand 2.
28612 * doc/invoke.texi: Document -mcpu option.
28613
28614 2014-01-17 Richard Biener <rguenther@suse.de>
28615
28616 PR rtl-optimization/38518
28617 * df.h (df_analyze_loop): Declare.
28618 * df-core.c: Include cfgloop.h.
28619 (df_analyze_1): Split out main part of df_analyze.
28620 (df_analyze): Adjust.
28621 (loop_inverted_post_order_compute): New function.
28622 (loop_post_order_compute): Likewise.
28623 (df_analyze_loop): New function avoiding whole-function
28624 postorder computes.
28625 * loop-invariant.c (find_defs): Use df_analyze_loop.
28626 (find_invariants): Adjust.
28627 * loop-iv.c (iv_analysis_loop_init): Use df_analyze_loop.
28628
28629 2014-01-17 Zhenqiang Chen <zhenqiang.chen@arm.com>
28630
28631 * config/arm/arm.c (arm_v7m_tune): Set max_insns_skipped to 2.
28632 (thumb2_final_prescan_insn): Set max to MAX_INSN_PER_IT_BLOCK.
28633
28634 2014-01-16 Ilya Enkovich <ilya.enkovich@intel.com>
28635
28636 * ipa-ref.c (ipa_remove_stmt_references): Fix references
28637 traversal when removing references.
28638
28639 2014-01-16 Jan Hubicka <hubicka@ucw.cz>
28640
28641 PR ipa/59775
28642 * tree.c (get_binfo_at_offset): Look harder for virtual bases.
28643
28644 2014-01-16 Bernd Schmidt <bernds@codesourcery.com>
28645
28646 PR middle-end/56791
28647 * reload.c (find_reloads_address_1): Do not use RELOAD_OTHER when
28648 pushing a reload for an autoinc when we had previously reloaded an
28649 inner part of the address.
28650
28651 2014-01-16 Jakub Jelinek <jakub@redhat.com>
28652
28653 * tree-vectorizer.h (struct _loop_vec_info): Add no_data_dependencies
28654 field.
28655 (LOOP_VINFO_NO_DATA_DEPENDENCIES): Define.
28656 * tree-vect-data-refs.c (vect_analyze_data_ref_dependence): Clear it
28657 when not giving up or versioning for alias only because of
28658 loop->safelen.
28659 (vect_analyze_data_ref_dependences): Set to true.
28660 * tree-vect-stmts.c (hoist_defs_of_uses): Return false if def_stmt
28661 is a GIMPLE_PHI.
28662 (vectorizable_load): Use LOOP_VINFO_NO_DATA_DEPENDENCIES instead of
28663 LOOP_REQUIRES_VERSIONING_FOR_ALIAS, add && !nested_in_vect_loop
28664 to the condition.
28665
28666 PR middle-end/58344
28667 * expr.c (expand_expr_real_1): Handle init == NULL_TREE.
28668
28669 PR target/59839
28670 * config/i386/i386.c (ix86_expand_builtin): If target doesn't satisfy
28671 operand 0 predicate for gathers, use a new pseudo as subtarget.
28672
28673 2014-01-16 Vladimir Makarov <vmakarov@redhat.com>
28674
28675 PR middle-end/59609
28676 * lra-constraints.c (process_alt_operands): Add printing debug info.
28677 Check absence of input/output reloads for matched operands too.
28678
28679 2014-01-16 Vladimir Makarov <vmakarov@redhat.com>
28680
28681 PR rtl-optimization/59835
28682 * ira.c (ira_init_register_move_cost): Increase cost for
28683 impossible modes.
28684
28685 2014-01-16 Alan Lawrence <alan.lawrence@arm.com>
28686
28687 * config/arm/arm.opt (mcpu, march, mtune): Make case-insensitive.
28688
28689 2014-01-16 Richard Earnshaw <rearnsha@arm.com>
28690
28691 PR target/59780
28692 * aarch64.c (aarch64_split_128bit_move): Don't lookup REGNO on
28693 non-register objects. Use gen_(high/low)part more consistently.
28694 Fix assertions.
28695
28696 2014-01-16 Michael Meissner <meissner@linux.vnet.ibm.com>
28697
28698 PR target/59844
28699 * config/rs6000/rs6000.md (reload_vsx_from_gprsf): Add little
28700 endian support, remove tests for WORDS_BIG_ENDIAN.
28701 (p8_mfvsrd_3_<mode>): Likewise.
28702 (reload_gpr_from_vsx<mode>): Likewise.
28703 (reload_gpr_from_vsxsf): Likewise.
28704 (p8_mfvsrd_4_disf): Likewise.
28705
28706 2014-01-16 Richard Biener <rguenther@suse.de>
28707
28708 PR rtl-optimization/46590
28709 * lcm.c (compute_antinout_edge): Use postorder iteration.
28710 (compute_laterin): Use inverted postorder iteration.
28711
28712 2014-01-16 Nick Clifton <nickc@redhat.com>
28713
28714 PR middle-end/28865
28715 * varasm.c (output_constant): Return the number of bytes actually
28716 emitted.
28717 (output_constructor_array_range): Update the field size with the
28718 number of bytes emitted by output_constant.
28719 (output_constructor_regular_field): Likewise. Also do not
28720 complain if the total number of bytes emitted is now greater
28721 than the expected fieldpos.
28722 * output.h (output_constant): Update prototype and descriptive comment.
28723
28724 2014-01-16 Marek Polacek <polacek@redhat.com>
28725
28726 PR middle-end/59827
28727 * cgraph.c (gimple_check_call_args): Don't use DECL_ARG_TYPE if
28728 it is error_mark_node.
28729
28730 2014-01-15 Uros Bizjak <ubizjak@gmail.com>
28731
28732 * config/i386/i386.c (ix86_hard_regno_mode_ok): Use
28733 VALID_AVX256_REG_OR_OI_MODE.
28734
28735 2014-01-15 Pat Haugen <pthaugen@us.ibm.com>
28736
28737 * config/rs6000/rs6000.c (rs6000_output_function_prologue): Check if
28738 current procedure should be profiled.
28739
28740 2014-01-15 Andrew Pinski <apinski@cavium.com>
28741
28742 * config/aarch64/aarch64.c (aarch64_register_move_cost): Correct cost
28743 of moving from/to the STACK_REG register class.
28744
28745 2014-01-15 Richard Henderson <rth@redhat.com>
28746
28747 PR debug/54694
28748 * reginfo.c (global_regs_decl): Globalize.
28749 * rtl.h (global_regs_decl): Declare.
28750 * ira.c (do_reload): Diagnose frame_pointer_needed and it
28751 reserved via global_regs.
28752
28753 2014-01-15 Teresa Johnson <tejohnson@google.com>
28754
28755 * tree-ssa-sccvn.c (visit_reference_op_call): Handle NULL vdef.
28756
28757 2014-01-15 Bill Schmidt <wschmidt@vnet.linux.ibm.com>
28758
28759 * config/rs6000/altivec.md (mulv8hi3): Explicitly generate vmulesh
28760 and vmulosh rather than call gen_vec_widen_smult_*.
28761 (vec_widen_umult_even_v16qi): Test VECTOR_ELT_ORDER_BIG rather
28762 than BYTES_BIG_ENDIAN to determine use of even or odd instruction.
28763 (vec_widen_smult_even_v16qi): Likewise.
28764 (vec_widen_umult_even_v8hi): Likewise.
28765 (vec_widen_smult_even_v8hi): Likewise.
28766 (vec_widen_umult_odd_v16qi): Likewise.
28767 (vec_widen_smult_odd_v16qi): Likewise.
28768 (vec_widen_umult_odd_v8hi): Likewise.
28769 (vec_widen_smult_odd_v8hi): Likewise.
28770 (vec_widen_umult_hi_v16qi): Explicitly generate vmuleub and
28771 vmuloub rather than call gen_vec_widen_umult_*.
28772 (vec_widen_umult_lo_v16qi): Likewise.
28773 (vec_widen_smult_hi_v16qi): Explicitly generate vmulesb and
28774 vmulosb rather than call gen_vec_widen_smult_*.
28775 (vec_widen_smult_lo_v16qi): Likewise.
28776 (vec_widen_umult_hi_v8hi): Explicitly generate vmuleuh and vmulouh
28777 rather than call gen_vec_widen_umult_*.
28778 (vec_widen_umult_lo_v8hi): Likewise.
28779 (vec_widen_smult_hi_v8hi): Explicitly gnerate vmulesh and vmulosh
28780 rather than call gen_vec_widen_smult_*.
28781 (vec_widen_smult_lo_v8hi): Likewise.
28782
28783 2014-01-15 Jeff Law <law@redhat.com>
28784
28785 PR tree-optimization/59747
28786 * ree.c (find_and_remove_re): Properly handle case where a second
28787 eliminated extension requires widening a copy created for elimination
28788 of a prior extension.
28789 (combine_set_extension): Ensure that the number of hard regs needed
28790 for a destination register does not change when we widen it.
28791
28792 2014-01-15 Sebastian Huber <sebastian.huber@embedded-brains.de>
28793
28794 * config.gcc (*-*-rtems*): Add t-rtems to tmake_file.
28795 (arm*-*-uclinux*eabi*): Do not override an existing tmake_file.
28796 (arm*-*-eabi* | arm*-*-symbianelf* | arm*-*-rtems*): Likwise.
28797 (arm*-*-rtems*): Use t-rtems from existing tmake_file.
28798 (avr-*-rtems*): Likewise.
28799 (bfin*-rtems*): Likewise.
28800 (moxie-*-rtems*): Likewise.
28801 (h8300-*-rtems*): Likewise.
28802 (i[34567]86-*-rtems*): Likewise.
28803 (lm32-*-rtems*): Likewise.
28804 (m32r-*-rtems*): Likewise.
28805 (m68k-*-rtems*): Likewise.
28806 (microblaze*-*-rtems*): Likewise.
28807 (mips*-*-rtems*): Likewise.
28808 (powerpc-*-rtems*): Likewise.
28809 (sh-*-rtems*): Likewise.
28810 (sparc-*-rtems*): Likewise.
28811 (sparc64-*-rtems*): Likewise.
28812 (v850-*-rtems*): Likewise.
28813 (m32c-*-rtems*): Likewise.
28814
28815 2014-01-15 Vladimir Makarov <vmakarov@redhat.com>
28816
28817 PR rtl-optimization/59511
28818 * ira.c (ira_init_register_move_cost): Use memory costs for some
28819 cases of register move cost calculations.
28820 * lra-constraints.c (lra_constraints): Use REG_FREQ_FROM_BB
28821 instead of BB frequency.
28822 * lra-coalesce.c (move_freq_compare_func, lra_coalesce): Ditto.
28823 * lra-assigns.c (find_hard_regno_for): Ditto.
28824
28825 2014-01-15 Richard Biener <rguenther@suse.de>
28826
28827 PR tree-optimization/59822
28828 * tree-vect-stmts.c (hoist_defs_of_uses): New function.
28829 (vectorizable_load): Use it to hoist defs of uses of invariant
28830 loads out of the loop.
28831
28832 2014-01-15 Matthew Gretton-Dann <matthew.gretton-dann@linaro.org>
28833 Kugan Vivekanandarajah <kuganv@linaro.org>
28834
28835 PR target/59695
28836 * config/aarch64/aarch64.c (aarch64_build_constant): Fix incorrect
28837 truncation.
28838
28839 2014-01-15 Richard Biener <rguenther@suse.de>
28840
28841 PR rtl-optimization/59802
28842 * lcm.c (compute_available): Use inverted postorder to seed
28843 the initial worklist.
28844
28845 2014-01-15 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
28846
28847 PR target/59803
28848 * config/s390/s390.c (s390_preferred_reload_class): Don't return
28849 ADDR_REGS for invalid symrefs in non-PIC code.
28850
28851 2014-01-15 Jakub Jelinek <jakub@redhat.com>
28852
28853 PR other/58712
28854 * builtins.c (determine_block_size): Initialize *probable_max_size
28855 even if len_rtx is CONST_INT.
28856
28857 2014-01-14 Andrew Pinski <apinski@cavium.com>
28858
28859 * config/aarch64/aarch64-protos.h (tune_params): Add issue_rate.
28860 * config/aarch64/aarch64.c (generic_tunings): Add issue rate of 2.
28861 (cortexa53_tunings): Likewise.
28862 (aarch64_sched_issue_rate): New function.
28863 (TARGET_SCHED_ISSUE_RATE): Define.
28864
28865 2014-01-14 Vladimir Makarov <vmakarov@redhat.com>
28866
28867 * ira-costs.c (find_costs_and_classes): Add missed
28868 ira_init_register_move_cost_if_necessary.
28869
28870 2014-01-14 Vladimir Makarov <vmakarov@redhat.com>
28871
28872 PR target/59787
28873 * config/arm/arm.c (arm_coproc_mem_operand): Add lra_in_progress.
28874
28875 2014-01-14 H.J. Lu <hongjiu.lu@intel.com>
28876
28877 PR target/59794
28878 * config/i386/i386.c (type_natural_mode): Add a bool parameter
28879 to indicate if type is used for function return value. Warn ABI
28880 change if the vector mode isn't available for function return value.
28881 (ix86_function_arg_advance): Pass false to type_natural_mode.
28882 (ix86_function_arg): Likewise.
28883 (ix86_gimplify_va_arg): Likewise.
28884 (function_arg_32): Don't warn ABI change.
28885 (ix86_function_value): Pass true to type_natural_mode.
28886 (ix86_return_in_memory): Likewise.
28887 (ix86_struct_value_rtx): Removed.
28888 (TARGET_STRUCT_VALUE_RTX): Likewise.
28889
28890 2014-01-14 Richard Sandiford <rsandifo@linux.vnet.ibm.com>
28891
28892 * jump.c (redirect_jump_2): Remove REG_CROSSING_JUMP notes when
28893 converting a conditional jump into a conditional return.
28894
28895 2014-01-14 Richard Biener <rguenther@suse.de>
28896
28897 PR tree-optimization/58921
28898 PR tree-optimization/59006
28899 * tree-vect-loop-manip.c (vect_loop_versioning): Remove code
28900 hoisting invariant stmts.
28901 * tree-vect-stmts.c (vectorizable_load): Insert the splat of
28902 invariant loads on the preheader edge if possible.
28903
28904 2014-01-14 Joey Ye <joey.ye@arm.com>
28905
28906 * doc/plugin.texi (Building GCC plugins): Update to C++.
28907
28908 2014-01-14 Kirill Yukhin <kirill.yukhin@intel.com>
28909
28910 * config/i386/avx512erintrin.h (_mm_rcp28_round_sd): New.
28911 (_mm_rcp28_round_ss): Ditto.
28912 (_mm_rsqrt28_round_sd): Ditto.
28913 (_mm_rsqrt28_round_ss): Ditto.
28914 (_mm_rcp28_sd): Ditto.
28915 (_mm_rcp28_ss): Ditto.
28916 (_mm_rsqrt28_sd): Ditto.
28917 (_mm_rsqrt28_ss): Ditto.
28918 * config/i386/avx512fintrin.h (_mm512_stream_load_si512): Ditto.
28919 * config/i386/i386-builtin-types.def (V8DI_FTYPE_PV8DI): Ditto.
28920 * config/i386/i386.c (IX86_BUILTIN_MOVNTDQA512): Ditto.
28921 (IX86_BUILTIN_RCP28SD): Ditto.
28922 (IX86_BUILTIN_RCP28SS): Ditto.
28923 (IX86_BUILTIN_RSQRT28SD): Ditto.
28924 (IX86_BUILTIN_RSQRT28SS): Ditto.
28925 (bdesc_special_args): Define __builtin_ia32_movntdqa512,
28926 __builtin_ia32_rcp28sd_round, __builtin_ia32_rcp28ss_round,
28927 __builtin_ia32_rsqrt28sd_round, __builtin_ia32_rsqrt28ss_round.
28928 (ix86_expand_special_args_builtin): Expand new FTYPE.
28929 * config/i386/sse.md (define_mode_attr "sse4_1_avx2"): Expand to V8DI.
28930 (srcp14<mode>): Make insn unary.
28931 (avx512f_vmscalef<mode><round_name>): Use substed predicate.
28932 (avx512f_sgetexp<mode><round_saeonly_name>): Ditto.
28933 (avx512f_rndscale<mode><round_saeonly_name>): Ditto.
28934 (<sse4_1_avx2>_movntdqa): Extend to 512 bits.
28935 (avx512er_exp2<mode><mask_name><round_saeonly_name>):
28936 Fix rounding: make it SAE only.
28937 (<mask_codefor>avx512er_rcp28<mode><mask_name><round_saeonly_name>):
28938 Ditto.
28939 (<mask_codefor>avx512er_rsqrt28<mode><mask_name><round_saeonly_name>):
28940 Ditto.
28941 (avx512er_vmrcp28<mode><round_saeonly_name>): Ditto.
28942 (avx512er_vmrsqrt28<mode><round_saeonly_name>): Ditto.
28943 (avx512f_getmant<mode><mask_name><round_saeonly_name>): Ditto.
28944 * config/i386/subst.md (round_saeonly_mask_scalar_operand3): Remove.
28945 (round_saeonly_mask_scalar_operand4): Ditto.
28946 (round_saeonly_mask_scalar_op3): Ditto.
28947 (round_saeonly_mask_scalar_op4): Ditto.
28948
28949 2014-01-13 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
28950
28951 * config/rs6000/rs6000-c.c (altivec_resolve_overloaded_builtin):
28952 Implement -maltivec=be for vec_insert and vec_extract.
28953
28954 2014-01-10 DJ Delorie <dj@redhat.com>
28955
28956 * config/msp430/msp430.md (call_internal): Don't allow memory
28957 references with SP as the base register.
28958 (call_value_internal): Likewise.
28959 * config/msp430/constraints.md (Yc): New. For memory references
28960 that don't use SP as a base register.
28961
28962 * config/msp430/msp430.c (msp430_print_operand): Add 'J' to mean
28963 "an integer without a # prefix"
28964 * config/msp430/msp430.md (epilogue_helper): Use it.
28965
28966 2014-01-13 Jakub Jelinek <jakub@redhat.com>
28967
28968 PR target/59617
28969 * config/i386/i386.c (ix86_vectorize_builtin_gather): Uncomment
28970 AVX512F gather builtins.
28971 * tree-vect-stmts.c (vectorizable_mask_load_store): For now punt
28972 on gather decls with INTEGER_TYPE masktype.
28973 (vectorizable_load): For INTEGER_TYPE masktype, put the INTEGER_CST
28974 directly into the builtin rather than hoisting it before loop.
28975
28976 PR tree-optimization/59387
28977 * tree-scalar-evolution.c: Include gimple-fold.h and gimplify-me.h.
28978 (scev_const_prop): If folded_casts and type has undefined overflow,
28979 use force_gimple_operand instead of force_gimple_operand_gsi and
28980 for each added stmt if it is assign with
28981 arith_code_with_undefined_signed_overflow, call
28982 rewrite_to_defined_overflow.
28983 * tree-ssa-loop-im.c: Don't include gimplify-me.h, include
28984 gimple-fold.h instead.
28985 (arith_code_with_undefined_signed_overflow,
28986 rewrite_to_defined_overflow): Moved to ...
28987 * gimple-fold.c (arith_code_with_undefined_signed_overflow,
28988 rewrite_to_defined_overflow): ... here. No longer static.
28989 Include gimplify-me.h.
28990 * gimple-fold.h (arith_code_with_undefined_signed_overflow,
28991 rewrite_to_defined_overflow): New prototypes.
28992
28993 2014-01-13 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
28994
28995 * config/arm/arm.h (MAX_CONDITIONAL_EXECUTE): Fix typo in description.
28996
28997 2014-01-13 Eric Botcazou <ebotcazou@adacore.com>
28998
28999 * builtins.c (get_object_alignment_2): Minor tweak.
29000 * tree-ssa-loop-ivopts.c (may_be_unaligned_p): Rewrite.
29001
29002 2014-01-13 Christian Bruel <christian.bruel@st.com>
29003
29004 * config/sh/sh-mem.cc (sh_expand_cmpnstr): Unroll small sizes and
29005 optimized non constant lengths.
29006
29007 2014-01-13 Jakub Jelinek <jakub@redhat.com>
29008
29009 PR libgomp/59194
29010 * omp-low.c (expand_omp_atomic_pipeline): Expand the initial
29011 load as __atomic_load_N if possible.
29012
29013 2014-01-11 David Edelsohn <dje.gcc@gmail.com>
29014
29015 * config/rs6000/rs6000.c (rs6000_expand_mtfsf_builtin): Remove
29016 target parameter.
29017 (rs6000_expand_builtin): Adjust call.
29018
29019 2014-01-11 David Edelsohn <dje.gcc@gmail.com>
29020
29021 PR target/58115
29022 * config/rs6000/rs6000.h (SWITCHABLE_TARGET): Define.
29023 * config/rs6000/rs6000.c: Include target-globals.h.
29024 (rs6000_set_current_function): Instead of doing target_reinit
29025 unconditionally, use save_target_globals_default_opts and
29026 restore_target_globals.
29027
29028 * config/rs6000/rs6000-builtin.def (mffs, mtfsf): Add builtins for
29029 FPSCR.
29030 * config/rs6000/rs6000.c (rs6000_expand_mtfsf_builtin): New.
29031 (rs6000_expand_builtin): Handle mffs and mtfsf.
29032 (rs6000_init_builtins): Define mffs and mtfsf.
29033 * config/rs6000/rs6000.md (UNSPECV_MFFS, UNSPECV_MTFSF): New constants.
29034 (rs6000_mffs): New pattern.
29035 (rs6000_mtfsf): New pattern.
29036
29037 2014-01-11 Bin Cheng <bin.cheng@arm.com>
29038
29039 * tree-ssa-loop-ivopts.c (iv_ca_narrow): New parameter.
29040 Start narrowing with START. Apply candidate-use pair
29041 and check overall cost in narrowing.
29042 (iv_ca_prune): Pass new argument.
29043
29044 2014-01-10 Jeff Law <law@redhat.com>
29045
29046 PR middle-end/59743
29047 * ree.c (combine_reaching_defs): Ensure the defining statement
29048 occurs before the extension when optimizing extensions with
29049 different source and destination hard registers.
29050
29051 2014-01-10 Jan Hubicka <hubicka@ucw.cz>
29052
29053 PR ipa/58585
29054 * ipa-devirt.c (build_type_inheritance_graph): Also add types of
29055 vtables into the type inheritance graph.
29056
29057 2014-01-10 Jakub Jelinek <jakub@redhat.com>
29058
29059 PR rtl-optimization/59754
29060 * ree.c (combine_reaching_defs): Disallow !SCALAR_INT_MODE_P
29061 modes in the REGNO != REGNO case.
29062
29063 2014-01-10 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
29064
29065 * config/rs6000/rs6000-builtin.def: Fix pasto for VPKSDUS.
29066
29067 2014-01-10 Jakub Jelinek <jakub@redhat.com>
29068
29069 PR tree-optimization/59745
29070 * tree-predcom.c (tree_predictive_commoning_loop): Call
29071 free_affine_expand_cache if giving up because components is NULL.
29072
29073 * target-globals.c (save_target_globals): Allocate < 4KB structs using
29074 GC in payload of target_globals struct instead of allocating them on
29075 the heap and the larger structs separately using GC.
29076 * target-globals.h (struct target_globals): Make regs, hard_regs,
29077 reload, expmed, ira, ira_int and lra_fields GTY((atomic)) instead
29078 of GTY((skip)) and change type to void *.
29079 (reset_target_globals): Cast loads from those fields to corresponding
29080 types.
29081
29082 2014-01-10 Steve Ellcey <sellcey@mips.com>
29083
29084 PR plugins/59335
29085 * Makefile.in (PLUGIN_HEADERS): Add gimplify.h, gimple-iterator.h,
29086 gimple-ssa.h, fold-const.h, tree-cfg.h, tree-into-ssa.h,
29087 tree-ssanames.h, print-tree.h, varasm.h, and context.h.
29088
29089 2014-01-10 Richard Earnshaw <rearnsha@arm.com>
29090
29091 PR target/59744
29092 * aarch64-modes.def (CC_Zmode): New flags mode.
29093 * aarch64.c (aarch64_select_cc_mode): Only allow NEG when the condition
29094 represents an equality.
29095 (aarch64_get_condition_code): Handle CC_Zmode.
29096 * aarch64.md (compare_neg<mode>): Restrict to equality operations.
29097
29098 2014-01-10 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
29099
29100 * config/s390/s390.c (s390_expand_tbegin): Remove jump over CC
29101 extraction in good case.
29102
29103 2014-01-10 Richard Biener <rguenther@suse.de>
29104
29105 PR tree-optimization/59374
29106 * tree-vect-slp.c (vect_slp_analyze_bb_1): Move dependence
29107 checking after SLP discovery. Mark stmts not participating
29108 in any SLP instance properly.
29109
29110 2014-01-10 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
29111
29112 * config/arm/arm.c (arm_new_rtx_costs): Use destination mode
29113 when handling a SET rtx.
29114
29115 2014-01-10 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
29116
29117 * config/arm/arm-cores.def (cortex-a53): Specify FL_CRC32.
29118 (cortex-a57): Likewise.
29119 (cortex-a57.cortex-a53): Likewise. Remove redundant flags.
29120
29121 2014-01-10 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
29122
29123 * config/arm/arm.c (arm_init_iwmmxt_builtins): Skip
29124 non-iwmmxt builtins.
29125
29126 2014-01-10 Jan Hubicka <hubicka@ucw.cz>
29127
29128 PR ipa/58252
29129 PR ipa/59226
29130 * ipa-devirt.c record_target_from_binfo): Take as argument
29131 stack of binfos and lookup matching one for virtual inheritance.
29132 (possible_polymorphic_call_targets_1): Update.
29133
29134 2014-01-10 Huacai Chen <chenhc@lemote.com>
29135
29136 * config/mips/driver-native.c (host_detect_local_cpu): Handle new
29137 kernel strings for Loongson-2E/2F/3A.
29138
29139 2014-01-10 Jakub Jelinek <jakub@redhat.com>
29140
29141 PR middle-end/59670
29142 * tree-vect-data-refs.c (vect_analyze_data_refs): Check
29143 is_gimple_call before calling gimple_call_internal_p.
29144
29145 2014-01-09 Steve Ellcey <sellcey@mips.com>
29146
29147 * Makefile.in (TREE_FLOW_H): Remove.
29148 (TREE_SSA_H): Add file names from tree-flow.h.
29149 * doc/tree-ssa.texi (Annotations): Remove reference to tree-flow.h
29150 * tree.h: Remove tree-flow.h reference.
29151 * hash-table.h: Remove tree-flow.h reference.
29152 * tree-ssa-loop-niter.c (dump_affine_iv): Replace tree-flow.h
29153 reference with tree-ssa-loop.h.
29154
29155 2014-01-09 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
29156
29157 * doc/invoke.texi: Add -maltivec={be,le} options, and document
29158 default element-order behavior for -maltivec.
29159 * config/rs6000/rs6000.opt: Add -maltivec={be,le} options.
29160 * config/rs6000/rs6000.c (rs6000_option_override_internal): Ensure
29161 that -maltivec={le,be} implies -maltivec; disallow -maltivec=le
29162 when targeting big endian, at least for now.
29163 * config/rs6000/rs6000.h: Add #define of VECTOR_ELT_ORDER_BIG.
29164
29165 2014-01-09 Jakub Jelinek <jakub@redhat.com>
29166
29167 PR middle-end/47735
29168 * cfgexpand.c (expand_one_var): For SSA_NAMEs, if the underlying
29169 var satisfies use_register_for_decl, just take into account type
29170 alignment, rather than decl alignment.
29171
29172 PR tree-optimization/59622
29173 * gimple-fold.c (gimple_fold_call): Fix a typo in message. For
29174 __builtin_unreachable replace the OBJ_TYPE_REF call with a call to
29175 __builtin_unreachable and add if needed a setter of the lhs SSA_NAME.
29176 Don't devirtualize for inplace at all. For targets.length () == 1,
29177 if the call is noreturn and cfun isn't in SSA form yet, clear lhs.
29178
29179 2014-01-09 H.J. Lu <hongjiu.lu@intel.com>
29180
29181 * config/i386/i386.md (cpu): Remove the unused btver1.
29182
29183 2014-01-09 H.J. Lu <hongjiu.lu@intel.com>
29184
29185 * gdbasan.in: Put a breakpoint on __sanitizer::Report.
29186
29187 2014-01-09 Jakub Jelinek <jakub@redhat.com>
29188
29189 PR target/58115
29190 * tree-core.h (struct target_globals): New forward declaration.
29191 (struct tree_target_option): Add globals field.
29192 * tree.h (TREE_TARGET_GLOBALS): Define.
29193 (prepare_target_option_nodes_for_pch): New prototype.
29194 * target-globals.h (struct target_globals): Define even if
29195 !SWITCHABLE_TARGET.
29196 * tree.c (prepare_target_option_node_for_pch,
29197 prepare_target_option_nodes_for_pch): New functions.
29198 * config/i386/i386.h (SWITCHABLE_TARGET): Define.
29199 * config/i386/i386.c: Include target-globals.h.
29200 (ix86_set_current_function): Instead of doing target_reinit
29201 unconditionally, use save_target_globals_default_opts and
29202 restore_target_globals.
29203
29204 2014-01-09 Richard Biener <rguenther@suse.de>
29205
29206 PR tree-optimization/59715
29207 * tree-cfg.h (split_critical_edges): Declare.
29208 * tree-cfg.c (split_critical_edges): Export.
29209 * tree-ssa-sink.c (execute_sink_code): Split critical edges.
29210
29211 2014-01-09 Max Ostapenko <m.ostapenko@partner.samsung.com>
29212
29213 * cfgexpand.c (expand_stack_vars): Optionally disable
29214 asan stack protection.
29215 (expand_used_vars): Likewise.
29216 (partition_stack_vars): Likewise.
29217 * asan.c (asan_emit_stack_protection): Optionally disable
29218 after return stack usage.
29219 (instrument_derefs): Optionally disable memory access instrumentation.
29220 (instrument_builtin_call): Likewise.
29221 (instrument_strlen_call): Likewise.
29222 (asan_protect_global): Optionally disable global variables protection.
29223 * doc/invoke.texi: Added doc for new options.
29224 * params.def: Added new options.
29225 * params.h: Likewise.
29226
29227 2014-01-09 Jakub Jelinek <jakub@redhat.com>
29228
29229 PR rtl-optimization/59724
29230 * ifcvt.c (cond_exec_process_if_block): Don't call
29231 flow_find_head_matching_sequence with 0 longest_match.
29232 * cfgcleanup.c (flow_find_head_matching_sequence): Count even
29233 non-active insns if !stop_after.
29234 (try_head_merge_bb): Revert 2014-01-07 changes.
29235
29236 2014-01-08 Jeff Law <law@redhat.com>
29237
29238 * ree.c (get_sub_rtx): New function, extracted from...
29239 (merge_def_and_ext): Here.
29240 (combine_reaching_defs): Use get_sub_rtx.
29241
29242 2014-01-08 Eric Botcazou <ebotcazou@adacore.com>
29243
29244 * cgraph.h (varpool_variable_node): Do not choke on null node.
29245
29246 2014-01-08 Catherine Moore <clm@codesourcery.com>
29247
29248 * config/mips/mips.md (simple_return): Attempt to use JRC
29249 for microMIPS.
29250 * config/mips/mips.h (MIPS_CALL): Attempt to use JALS for microMIPS.
29251
29252 2014-01-08 Richard Sandiford <rdsandiford@googlemail.com>
29253
29254 PR rtl-optimization/59137
29255 * reorg.c (steal_delay_list_from_target): Call update_block for
29256 elided insns.
29257 (steal_delay_list_from_fallthrough, relax_delay_slots): Likewise.
29258
29259 2014-01-08 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
29260
29261 * config/rs6000/rs6000-c.c (altivec_overloaded_builtins): Remove
29262 two duplicate entries.
29263
29264 2014-01-08 Richard Sandiford <rdsandiford@googlemail.com>
29265
29266 Revert:
29267 2012-10-07 Richard Sandiford <rdsandiford@googlemail.com>
29268
29269 * config/mips/mips.c (mips_truncated_op_cost): New function.
29270 (mips_rtx_costs): Adjust test for BADDU.
29271 * config/mips/mips.md (*baddu_di<mode>): Push truncates to operands.
29272
29273 2012-10-02 Richard Sandiford <rdsandiford@googlemail.com>
29274
29275 * config/mips/mips.md (*baddu_si_eb, *baddu_si_el): Merge into...
29276 (*baddu_si): ...this new pattern.
29277
29278 2014-01-08 Jakub Jelinek <jakub@redhat.com>
29279
29280 PR ipa/59722
29281 * ipa-prop.c (ipa_analyze_params_uses): Ignore uses in debug stmts.
29282
29283 2014-01-08 Bernd Edlinger <bernd.edlinger@hotmail.de>
29284
29285 PR middle-end/57748
29286 * expr.h (expand_expr_real, expand_expr_real_1): Add new parameter
29287 inner_reference_p.
29288 (expand_expr, expand_normal): Adjust.
29289 * expr.c (expand_expr_real, expand_expr_real_1): Add new parameter
29290 inner_reference_p. Use inner_reference_p to expand inner references.
29291 (store_expr): Adjust.
29292 * cfgexpand.c (expand_call_stmt): Adjust.
29293
29294 2014-01-08 Rong Xu <xur@google.com>
29295
29296 * gcov-io.c (gcov_var): Move from gcov-io.h.
29297 (gcov_position): Ditto.
29298 (gcov_is_error): Ditto.
29299 (gcov_rewrite): Ditto.
29300 * gcov-io.h: Refactor. Move gcov_var to gcov-io.h, and libgcov
29301 only part to libgcc/libgcov.h.
29302
29303 2014-01-08 Marek Polacek <polacek@redhat.com>
29304
29305 PR middle-end/59669
29306 * omp-low.c (simd_clone_adjust): Don't crash if def is NULL.
29307
29308 2014-01-08 Marek Polacek <polacek@redhat.com>
29309
29310 PR sanitizer/59667
29311 * ubsan.c (ubsan_type_descriptor): Call strip_array_types on type2.
29312
29313 2014-01-08 Jakub Jelinek <jakub@redhat.com>
29314
29315 PR rtl-optimization/59649
29316 * stor-layout.c (get_mode_bounds): For BImode return
29317 0 and STORE_FLAG_VALUE.
29318
29319 2014-01-08 Richard Biener <rguenther@suse.de>
29320
29321 PR middle-end/59630
29322 * gimple.h (is_gimple_builtin_call): Remove.
29323 (gimple_builtin_call_types_compatible_p): New.
29324 (gimple_call_builtin_p): New overload.
29325 * gimple.c (is_gimple_builtin_call): Remove.
29326 (validate_call): Rename to ...
29327 (gimple_builtin_call_types_compatible_p): ... this and export. Also
29328 check return types.
29329 (validate_type): New static function.
29330 (gimple_call_builtin_p): New overload and adjust.
29331 * gimple-fold.c (gimple_fold_builtin): Fold the return value.
29332 (gimple_fold_call): Likewise. Use gimple_call_builtin_p.
29333 (gimple_fold_stmt_to_constant_1): Likewise.
29334 * tsan.c (instrument_gimple): Use gimple_call_builtin_p.
29335
29336 2014-01-08 Richard Biener <rguenther@suse.de>
29337
29338 PR middle-end/59471
29339 * gimplify.c (gimplify_expr): Gimplify register-register type
29340 VIEW_CONVERT_EXPRs to separate stmts.
29341
29342 2014-01-07 Jeff Law <law@redhat.com>
29343
29344 PR middle-end/53623
29345 * ree.c (combine_set_extension): Handle case where source
29346 and destination registers in an extension insn are different.
29347 (combine_reaching_defs): Allow source and destination registers
29348 in extension to be different under limited circumstances.
29349 (add_removable_extension): Remove restriction that the
29350 source and destination registers in the extension are the same.
29351 (find_and_remove_re): Emit a copy from the extension's
29352 destination to its source after the defining insn if
29353 the source and destination registers are different.
29354
29355 PR middle-end/59285
29356 * ifcvt.c (merge_if_block): If we are merging a block with more than
29357 one successor with a block with no successors, remove any BARRIER
29358 after the second block.
29359
29360 2014-01-07 Dan Xio Qiang <ziyan01@163.com>
29361
29362 * hw-doloop.c (reorg_loops): Release the bitmap obstack.
29363
29364 2014-01-07 John David Anglin <danglin@gcc.gnu.org>
29365
29366 PR target/59652
29367 * config/pa/pa.c (pa_legitimate_address_p): Return false before reload
29368 for 14-bit register offsets when INT14_OK_STRICT is false.
29369
29370 2014-01-07 Roland Stigge <stigge@antcom.de>
29371 Michael Meissner <meissner@linux.vnet.ibm.com>
29372
29373 PR 57386/target
29374 * config/rs6000/rs6000.c (rs6000_legitimate_offset_address_p):
29375 Only check TFmode for SPE constants. Don't check TImode or TDmode.
29376
29377 2014-01-07 James Greenhalgh <james.greenhalgh@arm.com>
29378
29379 * config/aarch64/aarch64-elf.h (ASM_SPEC): Remove identity spec for
29380 -mcpu.
29381
29382 2014-01-07 Yufeng Zhang <yufeng.zhang@arm.com>
29383
29384 * config/arm/arm.c (arm_expand_neon_args): Call expand_expr
29385 with EXPAND_MEMORY for NEON_ARG_MEMORY; check if the returned
29386 rtx is const0_rtx or not.
29387
29388 2014-01-07 Richard Sandiford <rdsandiford@googlemail.com>
29389
29390 PR target/58115
29391 * target-globals.c (save_target_globals): Remove this_fn_optab
29392 handling.
29393 * toplev.c: Include optabs.h.
29394 (target_reinit): Temporarily restore the global options if another
29395 set of options are in force.
29396
29397 2014-01-07 Jakub Jelinek <jakub@redhat.com>
29398
29399 PR rtl-optimization/58668
29400 * cfgcleanup.c (flow_find_cross_jump): Don't count
29401 any jumps if dir_p is NULL. Remove p1 variable, use active_insn_p
29402 to determine what is counted.
29403 (flow_find_head_matching_sequence): Use active_insn_p to determine
29404 what is counted.
29405 (try_head_merge_bb): Adjust for the flow_find_head_matching_sequence
29406 counting change.
29407 * ifcvt.c (count_bb_insns): Use active_insn_p && !JUMP_P to
29408 determine what is counted.
29409
29410 PR tree-optimization/59643
29411 * tree-predcom.c (split_data_refs_to_components): If one dr is
29412 read and one write, determine_offset fails and the write isn't
29413 in the bad component, just put the read into the bad component.
29414
29415 2014-01-07 Mike Stump <mikestump@comcast.net>
29416 Jakub Jelinek <jakub@redhat.com>
29417
29418 PR pch/59436
29419 * tree-core.h (struct tree_optimization_option): Change optabs
29420 type from unsigned char * to void *.
29421 * optabs.c (init_tree_optimization_optabs): Adjust
29422 TREE_OPTIMIZATION_OPTABS initialization.
29423
29424 2014-01-06 Jakub Jelinek <jakub@redhat.com>
29425
29426 PR target/59644
29427 * config/i386/i386.h (struct machine_function): Add
29428 no_drap_save_restore field.
29429 * config/i386/i386.c (ix86_save_reg): Use
29430 !cfun->machine->no_drap_save_restore instead of
29431 crtl->stack_realign_needed.
29432 (ix86_finalize_stack_realign_flags): Don't clear drap_reg unless
29433 this function clears frame_pointer_needed. Set
29434 cfun->machine->no_drap_save_restore if clearing frame_pointer_needed
29435 and DRAP reg is needed.
29436
29437 2014-01-06 Marek Polacek <polacek@redhat.com>
29438
29439 PR c/57773
29440 * doc/implement-c.texi: Mention that other integer types are
29441 permitted as bit-field types in strictly conforming mode.
29442
29443 2014-01-06 Felix Yang <fei.yang0953@gmail.com>
29444
29445 * modulo-sched.c (schedule_reg_moves): Clear distance1_uses if it
29446 is newly allocated.
29447
29448 2014-01-06 Richard Earnshaw <rearnsha@arm.com>
29449
29450 * aarch64.c (aarch64_rtx_costs): Fix cost calculation for MADD.
29451
29452 2014-01-06 Martin Jambor <mjambor@suse.cz>
29453
29454 PR ipa/59008
29455 * ipa-cp.c (ipcp_discover_new_direct_edges): Changed param_index type
29456 to int.
29457 * ipa-prop.c (ipa_print_node_params): Fix indentation.
29458
29459 2014-01-06 Eric Botcazou <ebotcazou@adacore.com>
29460
29461 PR debug/59350
29462 PR debug/59510
29463 * var-tracking.c (add_stores): Preserve the value of the source even if
29464 we don't record the store.
29465
29466 2014-01-06 Terry Guo <terry.guo@arm.com>
29467
29468 * config.gcc (arm*-*-*): Check --with-arch against arm-arches.def.
29469
29470 2014-01-05 Iain Sandoe <iain@codesourcery.com>
29471
29472 PR bootstrap/59541
29473 * config/darwin.c (darwin_function_section): Adjust return values to
29474 correspond to optimisation changes made in r206070.
29475
29476 2014-01-05 Uros Bizjak <ubizjak@gmail.com>
29477
29478 * config/i386/i386.c (ix86_data_alignment): Calculate max_align
29479 from prefetch_block tune setting.
29480 (nocona_cost): Correct size of prefetch block to 64.
29481
29482 2014-01-04 Eric Botcazou <ebotcazou@adacore.com>
29483
29484 * config/arm/arm.c (arm_get_frame_offsets): Revamp long lines.
29485 (arm_expand_epilogue_apcs_frame): Take into account the number of bytes
29486 used to save the static chain register in the computation of the offset
29487 from which the FP registers need to be restored.
29488
29489 2014-01-04 Jakub Jelinek <jakub@redhat.com>
29490
29491 PR tree-optimization/59519
29492 * tree-vect-loop-manip.c (slpeel_update_phi_nodes_for_guard1): Don't
29493 ICE if get_current_def (current_new_name) is already non-NULL, as long
29494 as it is a phi result of some other phi in *new_exit_bb that has
29495 the same argument.
29496
29497 * config/i386/sse.md (avx512f_load<mode>_mask): Emit vmovup{s,d}
29498 or vmovdqu* for misaligned_operand.
29499 (<sse>_loadu<ssemodesuffix><avxsizesuffix><mask_name>,
29500 <sse2_avx_avx512f>_loaddqu<mode><mask_name>): Handle <mask_applied>.
29501 * config/i386/i386.c (ix86_expand_special_args_builtin): Set
29502 aligned_mem for AVX512F masked aligned load and store builtins and for
29503 non-temporal moves.
29504
29505 2014-01-03 Bingfeng Mei <bmei@broadcom.com>
29506
29507 PR tree-optimization/59651
29508 * tree-vect-loop-manip.c (vect_create_cond_for_alias_checks):
29509 Address range for negative step should be added by TYPE_SIZE_UNIT.
29510
29511 2014-01-03 Andreas Schwab <schwab@linux-m68k.org>
29512
29513 * config/m68k/m68k.c (handle_move_double): Handle pushes with
29514 overlapping registers also for registers other than the stack pointer.
29515
29516 2014-01-03 Marek Polacek <polacek@redhat.com>
29517
29518 PR other/59661
29519 * doc/extend.texi: Fix the return value of __builtin_FUNCTION and
29520 __builtin_FILE.
29521
29522 2014-01-03 Jakub Jelinek <jakub@redhat.com>
29523
29524 PR target/59625
29525 * config/i386/i386.c (ix86_avoid_jump_mispredicts): Don't consider
29526 asm goto as jump.
29527
29528 * config/i386/i386.md (MODE_SIZE): New mode attribute.
29529 (push splitter): Use <P:MODE_SIZE> instead of
29530 GET_MODE_SIZE (<P:MODE>mode).
29531 (lea splitter): Use <MODE_SIZE> instead of GET_MODE_SIZE (<MODE>mode).
29532 (mov -1, reg peephole2): Likewise.
29533 * config/i386/sse.md (*mov<mode>_internal,
29534 <sse>_storeu<ssemodesuffix><avxsizesuffix>,
29535 <sse2_avx_avx512f>_storedqu<mode>, <sse>_andnot<mode>3,
29536 *<code><mode>3, *andnot<mode>3<mask_name>,
29537 <mask_codefor><code><mode>3<mask_name>): Likewise.
29538 * config/i386/subst.md (mask_mode512bit_condition,
29539 sd_mask_mode512bit_condition): Likewise.
29540
29541 2014-01-02 Xinliang David Li <davidxl@google.com>
29542
29543 PR tree-optimization/59303
29544 * tree-ssa-uninit.c (is_use_properly_guarded): Main cleanup.
29545 (dump_predicates): Better output format.
29546 (pred_equal_p): New function.
29547 (is_neq_relop_p): Ditto.
29548 (is_neq_zero_form_p): Ditto.
29549 (pred_expr_equal_p): Ditto.
29550 (pred_neg_p): Ditto.
29551 (simplify_pred): Ditto.
29552 (simplify_preds_2): Ditto.
29553 (simplify_preds_3): Ditto.
29554 (simplify_preds_4): Ditto.
29555 (simplify_preds): Ditto.
29556 (push_pred): Ditto.
29557 (push_to_worklist): Ditto.
29558 (get_pred_info_from_cmp): Ditto.
29559 (is_degenerated_phi): Ditto.
29560 (normalize_one_pred_1): Ditto.
29561 (normalize_one_pred): Ditto.
29562 (normalize_one_pred_chain): Ditto.
29563 (normalize_preds): Ditto.
29564 (normalize_cond_1): Remove function.
29565 (normalize_cond): Ditto.
29566 (is_gcond_subset_of): Ditto.
29567 (is_subset_of_any): Ditto.
29568 (is_or_set_subset_of): Ditto.
29569 (is_and_set_subset_of): Ditto.
29570 (is_norm_cond_subset_of): Ditto.
29571 (pred_chain_length_cmp): Ditto.
29572 (convert_control_dep_chain_into_preds): Type change.
29573 (find_predicates): Ditto.
29574 (find_def_preds): Ditto.
29575 (destroy_predicates_vecs): Ditto.
29576 (find_matching_predicates_in_rest_chains): Ditto.
29577 (use_pred_not_overlap_with_undef_path_pred): Ditto.
29578 (is_pred_expr_subset): Ditto.
29579 (is_pred_chain_subset_of): Ditto.
29580 (is_included_in): Ditto.
29581 (is_superset_of): Ditto.
29582
29583 2014-01-02 Richard Sandiford <rdsandiford@googlemail.com>
29584
29585 Update copyright years.
29586
29587 2014-01-02 Richard Sandiford <rdsandiford@googlemail.com>
29588
29589 * common/config/arc/arc-common.c, config/arc/arc-modes.def,
29590 config/arc/arc-protos.h, config/arc/arc.c, config/arc/arc.h,
29591 config/arc/arc.md, config/arc/arc.opt,
29592 config/arm/arm_neon_builtins.def, config/arm/crypto.def,
29593 config/i386/avx512cdintrin.h, config/i386/avx512erintrin.h,
29594 config/i386/avx512fintrin.h, config/i386/avx512pfintrin.h,
29595 config/i386/btver2.md, config/i386/shaintrin.h, config/i386/slm.md,
29596 config/linux-protos.h, config/linux.c, config/winnt-c.c,
29597 diagnostic-color.c, diagnostic-color.h, gimple-ssa-isolate-paths.c,
29598 vtable-verify.c, vtable-verify.h: Use the standard form for the
29599 copyright notice.
29600
29601 2014-01-02 Tobias Burnus <burnus@net-b.de>
29602
29603 * gcc.c (process_command): Update copyright notice dates.
29604 * gcov-dump.c: Ditto.
29605 * gcov.c: Ditto.
29606 * doc/cpp.texi: Bump @copying's copyright year.
29607 * doc/cppinternals.texi: Ditto.
29608 * doc/gcc.texi: Ditto.
29609 * doc/gccint.texi: Ditto.
29610 * doc/gcov.texi: Ditto.
29611 * doc/install.texi: Ditto.
29612 * doc/invoke.texi: Ditto.
29613
29614 2014-01-01 Jan-Benedict Glaw <jbglaw@lug-owl.de>
29615
29616 * config/nios2/nios2.h (BITS_PER_UNIT): Don't define it.
29617
29618 2014-01-01 Jakub Jelinek <jakub@redhat.com>
29619
29620 * config/i386/sse.md (*mov<mode>_internal): Guard
29621 EXT_REX_SSE_REGNO_P (REGNO ()) uses with REG_P.
29622
29623 PR rtl-optimization/59647
29624 * cse.c (cse_process_notes_1): Don't substitute negative VOIDmode
29625 new_rtx into UNSIGNED_FLOAT rtxes.
29626 \f
29627 Copyright (C) 2014 Free Software Foundation, Inc.
29628
29629 Copying and distribution of this file, with or without modification,
29630 are permitted in any medium without royalty provided the copyright
29631 notice and this notice are preserved.