[ARC] Update RTX costs.
[gcc.git] / gcc / ChangeLog
1 2019-06-10 Claudiu Zissulescu <claziss@synopsys.com>
2
3 * config/arc/arc.c (arc_rtx_costs): Update costs.
4
5 2019-06-10 Claudiu Zissulescu <claziss@synopsys.com>
6
7 * config/arc/arc-protos.h (arc_check_ior_const): Declare.
8 (arc_split_ior): Likewise.
9 (arc_check_mov_const): Likewise.
10 (arc_split_mov_const): Likewise.
11 * config/arc/arc.c (arc_print_operand): Fix 'z' letter.
12 (arc_rtx_costs): Replace check Crr with Cax constraint.
13 (prepare_move_operands): Cleanup, remove unused code.
14 (arc_split_ior): New function.
15 (arc_check_ior_const): Likewise.
16 (arc_split_mov_const): Likewise.
17 (arc_check_mov_const): Likewise.
18 * config/arc/arc.md (movsi_insn): Restructure it, and convert it
19 in define_insn_and_split pattern.
20 (iorsi3): Likewise.
21 (mulsi3_v2): Add new matching variant.
22 (andsi3_i): Cleanup pattern.
23 (rotrsi3_cnt1): Update pattern.
24 (rotrsi3_cnt8): New pattern.
25 (ashlsi2_cnt8): Likewise.
26 (ashlsi2_cnt16): Likewise.
27 * config/arc/constraints.md (C0p): Update constraint.
28 (Crr): Remove it.
29 (C0x): New pattern.
30 (Cax): New pattern.
31
32 2019-06-10 Martin Liska <mliska@suse.cz>
33
34 * ipa-icf.c (sem_item_optimizer::parse_nonsingleton_classes):
35 Update coding style.
36 (sem_item_optimizer::dump_cong_classes):
37 Print how many items are in a non-singular class. Improve
38 coding style.
39
40 2019-06-10 Martin Liska <mliska@suse.cz>
41
42 * value-prof.c (dump_histogram_value): Change dump format.
43 (gimple_mod_subtract_transform): Remove legacy comment.
44
45 2019-06-10 Martin Liska <mliska@suse.cz>
46
47 * value-prof.c (dump_histogram_value): Print histogram values
48 only if present.
49
50 2019-06-10 Martin Liska <mliska@suse.cz>
51
52 * gcov-io.h (GCOV_DISK_SINGLE_VALUES): New.
53 (GCOV_SINGLE_VALUE_COUNTERS): Likewise.
54 * ipa-profile.c (ipa_profile_generate_summary):
55 Use get_most_common_single_value.
56 * tree-profile.c (gimple_init_gcov_profiler):
57 Instrument with __gcov_one_value_profiler_v2
58 and __gcov_indirect_call_profiler_v4.
59 * value-prof.c (dump_histogram_value):
60 Print all values for HIST_TYPE_SINGLE_VALUE.
61 (stream_out_histogram_value): Update assert for
62 N values.
63 (stream_in_histogram_value): Set number of
64 counters for HIST_TYPE_SINGLE_VALUE.
65 (get_most_common_single_value): New.
66 (gimple_divmod_fixed_value_transform):
67 Use get_most_common_single_value.
68 (gimple_ic_transform): Likewise.
69 (gimple_stringops_transform): Likewise.
70 (gimple_find_values_to_profile): Set number
71 of counters for HIST_TYPE_SINGLE_VALUE.
72 * value-prof.h (get_most_common_single_value):
73 New.
74
75 2019-06-10 Martin Liska <mliska@suse.cz>
76
77 * hash-map.h: Pass default value to hash_table ctor.
78 * hash-table.h: Add default value to call of a ctor.
79
80 2019-06-08 Jonathan Wakely <jwakely@redhat.com>
81
82 * doc/invoke.texi (C Dialect Options): Minor grammatical change.
83 (x86 Options): Replace all uses of "PCL_MUL" with "PCLMUL"
84
85 2019-06-07 John David Anglin <danglin@gcc.gnu.orig>
86
87 PR target/90751
88 * config/pa/pa-linux.h (ASM_DECLARE_FUNCTION_NAME): Update comment.
89 Call pa_output_function_label.
90 (TARGET_ASM_FUNCTION_PROLOGUE): define.
91 * config/pa/pa-protos.h (pa_output_function_label): Declare.
92 * config/pa/pa.c (pa_output_function_prologue): Add ATTRIBUTE_UNUSED
93 to declaration.
94 (pa_linux_output_function_prologue): Declare.
95 (TARGET_ASM_FUNCTION_PROLOGUE): Delete define.
96 (pa_output_function_label): New.
97 (pa_output_function_prologue): Revise to use pa_output_function_label.
98 (pa_linux_output_function_prologue): New.
99 * config/pa/pa.h (TARGET_ASM_FUNCTION_PROLOGUE): Define.
100
101 2019-06-07 Aldy Hernandez <aldyh@redhat.com>
102
103 * tree-vrp.h (value_range_base::intersect): New.
104 (value_range::intersect_helper): Move from here...
105 (value_range_base::intersect_helper): ...to here.
106 * tree-vrp.c (value_range::intersect_helper): Rename to...
107 (value_range_base::intersect_helper): ...this, and rewrite to
108 return a value instead of modifying THIS in place.
109 Also, move equivalence handling...
110 (value_range::intersect): ...here, while calling intersect_helper.
111 * gimple-fold.c (size_must_be_zero_p): Use value_range_base when
112 calling intersect.
113 * gimple-ssa-evrp-analyze.c (ecord_ranges_from_incoming_edge):
114 Same.
115 * vr-values.c (vrp_evaluate_conditional_warnv_with_ops): Same.
116
117 2019-06-07 Jakub Jelinek <jakub@redhat.com>
118
119 * Makefile.in (genprogerr): Add condmd.
120 (genprog): Remove it here.
121
122 2019-06-07 Andrew Stubbs <ams@codesourcery.com>
123
124 * doc/invoke.texi (AMD GCN Options): Add gfx906.
125
126 2019-06-07 Richard Biener <rguenther@suse.de>
127
128 PR debug/90574
129 * tree-cfg.c (stmt_starts_bb_p): Split blocks at labels
130 that appear after user labels.
131
132 2019-06-07 Martin Liska <mliska@suse.cz>
133
134 * cselib.c (cselib_init): Disable hash table
135 sanitization.
136 * hash-set.h: Pass new default argument to m_table.
137 * hash-table.c: Add global variable with hash table
138 sanitization limit.
139 * hash-table.h (Allocator>::hash_table): Add new argument
140 to ctor.
141 (hashtab_chk_error): New.
142 * params.def (PARAM_HASH_TABLE_VERIFICATION_LIMIT): New.
143 * toplev.c (process_options): Set hash_table_sanitize_eq_limit
144 from the PARAM_HASH_TABLE_VERIFICATION_LIMIT value.
145
146 2019-06-07 Jan Hubicka <hubicka@ucw.cz>
147
148 * common.opt (flto-odr-type-merging): Ignore.
149 * invoke.texi (-flto-odr-type-merging): Remove.
150 * ipa-devirt.c (odr_vtable_hasher:odr_name_hasher): Remove.
151 (can_be_vtable_hashed_p): Remove.
152 (hash_odr_vtable): Remove.
153 (odr_vtable_hasher::hash): Remove.
154 (types_same_for_odr): Remove.
155 (types_odr_comparable): Remove.
156 (odr_vtable_hasher::equal): Remove.
157 (odr_vtable_hash_type, odr_vtable_hash): Remove.
158 (add_type_duplicate): Do not synchronize vtable and name hashtables.
159 (get_odr_type): Do not use vtable hash.
160 (dump_odr_type): Remove commented out code.
161 (build_type_inheritance_graph): Do not allocate vtable hash.
162 (rebuild_type_inheritance_graph): Do not delete vtable hash.
163 * ipa-utils.h (type_with_linkage_p): Drop vtable hash path.
164 (odr_type_p): Likewise.
165 * tree.c (need_assembler_name_p): Remove flag_lto_odr_type_mering
166 test.
167
168 2019-06-07 Jan Hubicka <hubicka@ucw.cz>
169
170 * tree-ssa-alias.c (aliasing_component_refs_p): Do not give up
171 immediately after same_types_for_tbaa_p returns -1 and continue
172 looking for possible exact match; if matching types are arrays
173 watch for partial overlaps.
174 (indirect_ref_may_alias_decl_p): Watch for partial array overlaps.
175 (indirect_refs_may_alias_p): Do type based disambiguation first;
176 update comment.
177
178 2019-06-07 Richard Sandiford <richard.sandiford@arm.com>
179
180 * fwprop.c (propagate_rtx): Fix call to paradoxical_subreg_p.
181
182 2019-06-07 Martin Liska <mliska@suse.cz>
183
184 * doc/invoke.texi: Remove param.
185 * gcov-counter.def (GCOV_COUNTER_ICALL_TOPNV):
186 Remove.
187 * gcov-io.h (GCOV_ICALL_TOPN_VAL): Likewise.
188 (GCOV_ICALL_TOPN_NCOUNTS): Likewise.
189 * params.def (PARAM_INDIR_CALL_TOPN_PROFILE): Likewise.
190 * profile.c (instrument_values): Remove
191 HIST_TYPE_INDIR_CALL_TOPN.
192 * tree-profile.c (init_ic_make_global_vars):
193 Always build __gcov_indirect_call only.
194 (gimple_init_gcov_profiler): Remove usage
195 of PARAM_INDIR_CALL_TOPN_PROFILE.
196 (gimple_gen_ic_profiler): Likewise.
197 * value-prof.c (dump_histogram_value): Likewise.
198 (stream_in_histogram_value): Likewise.
199 (gimple_indirect_call_to_profile): Likewise.
200 (gimple_find_values_to_profile): Likewise.
201 * value-prof.h (enum hist_type): Likewise.
202
203 2019-06-07 Martin Liska <mliska@suse.cz>
204
205 * tree-ssa-loop.c (get_lsm_tmp_name): Return at the end of the
206 function.
207
208 2019-06-07 Martin Liska <mliska@suse.cz>
209
210 PR tree-optimization/78902
211 * builtin-attrs.def (ATTR_WARN_UNUSED_RESULT): New.
212 (ATTR_MALLOC_NOTHROW_LEAF_LIST): Remove.
213 (ATTR_WARN_UNUSED_RESULT_NOTHROW_LEAF_LIST): New.
214 (ATTR_MALLOC_WARN_UNUSED_RESULT_NOTHROW_LEAF_LIST): New.
215 (ATTR_ALLOC_SIZE_2_NOTHROW_LIST): Remove.
216 (ATTR_MALLOC_SIZE_1_NOTHROW_LEAF_LIST): Remove.
217 (ATTR_MALLOC_WARN_UNUSED_RESULT_NOTHROW_LIST): New.
218 (ATTR_ALLOC_WARN_UNUSED_RESULT_SIZE_2_NOTHROW_LIST): New.
219 (ATTR_MALLOC_WARN_UNUSED_RESULT_SIZE_1_NOTHROW_LEAF_LIST): New.
220 (ATTR_ALLOCA_SIZE_1_NOTHROW_LEAF_LIST): Remove.
221 (ATTR_ALLOCA_WARN_UNUSED_RESULT_SIZE_1_NOTHROW_LEAF_LIST): New.
222 (ATTR_MALLOC_SIZE_1_2_NOTHROW_LEAF_LIST): Remove.
223 (ATTR_MALLOC_WARN_UNUSED_RESULT_SIZE_1_2_NOTHROW_LEAF_LIST):
224 New.
225 (ATTR_ALLOC_SIZE_2_NOTHROW_LEAF_LIST): Remove.
226 (ATTR_ALLOC_WARN_UNUSED_RESULT_SIZE_2_NOTHROW_LEAF_LIST): New.
227 (ATTR_MALLOC_NOTHROW_NONNULL): Remove.
228 (ATTR_WARN_UNUSED_RESULT_NOTHROW_NONNULL): New.
229 (ATTR_MALLOC_WARN_UNUSED_RESULT_NOTHROW_NONNULL): New.
230 (ATTR_MALLOC_NOTHROW_NONNULL_LEAF): Remove.
231 (ATTR_WARN_UNUSED_RESULT_NOTHROW_NONNULL_LEAF): New.
232 (ATTR_MALLOC_WARN_UNUSED_RESULT_NOTHROW_NONNULL_LEAF): New.
233 * builtins.def (BUILT_IN_ALIGNED_ALLOC): Change to use
234 warn_unused_result attribute.
235 (BUILT_IN_STRDUP): Likewise.
236 (BUILT_IN_STRNDUP): Likewise.
237 (BUILT_IN_ALLOCA): Likewise.
238 (BUILT_IN_CALLOC): Likewise.
239 (BUILT_IN_MALLOC): Likewise.
240 (BUILT_IN_REALLOC): Likewise.
241
242 2019-06-06 Jim Wilson <jimw@sifive.com>
243
244 PR target/89955
245 * config/riscv/riscv.h (STARTFILE_PREFIX_SPEC): Deleted.
246 * config/riscv/freebsd.h (STARTFILE_PREFIX_SPEC): Added.
247 * config/riscv/linux.h (STARTFILE_PREFIX_SPEC): Added.
248
249 2019-06-06 Martin Sebor <msebor@redhat.com>
250
251 * tree-ssa-strlen.c (adjust_related_strinfos): Avoid trailing article.
252 (handle_builtin_malloc): Remove trailing spaces.
253 (handle_builtin_memset): Same.
254 (handle_builtin_memcmp): Same.
255 (compute_string_length): Same.
256 (determine_min_objsize): Same.
257 (handle_builtin_string_cmp): Same.
258 (handle_char_store): Same. Break up excessively long line.
259
260 2019-06-06 Martin Jambor <mjambor@suse.cz>
261
262 * tree-sra.c (build_reconstructed_reference): Drop the alignment
263 check.
264
265 2019-06-06 Martin Jambor <mjambor@suse.cz>
266
267 * tree-sra.c (struct access): New field grp_same_access_path.
268 (dump_access): Dump it.
269 (build_reconstructed_reference): New function.
270 (build_ref_for_model): Use it if possible.
271 (path_comparable_for_same_access): New function.
272 (same_access_path_p): Likewise.
273 (sort_and_splice_var_accesses): Set the new flag.
274 (analyze_access_subtree): Likewise.
275 (propagate_subaccesses_across_link): Propagate zero value of the new
276 flag down the access tree.
277
278 2019-06-06 Andrew Stubbs <ams@codesourcery.com>
279
280 * config.gcc (amdgcn-*-*): Allow --with-arch=gfx906.
281 * config/gcn/gcn.opt (gpu_type): Add gfx906.
282 * config/gcn/t-gcn-hsa (MULTILIB_OPTIONS): Add gfx906 multilib.
283 (MULTILIB_DIRNAMES): Rename gcn5 to gfx900.
284 Add gfx906.
285
286 2019-06-06 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
287
288 PR tree-optimization/90332
289 * config/aarch64/aarch64.c (aarch64_expand_vector_init):
290 Handle VALS containing two vectors.
291 * config/aarch64/aarch64-simd.md (*aarch64_combinez<mode>): Rename
292 to...
293 (@aarch64_combinez<mode>): ... This.
294 (*aarch64_combinez_be<mode>): Rename to...
295 (@aarch64_combinez_be<mode>): ... This.
296 (vec_init<mode><Vhalf>): New define_expand.
297 * config/aarch64/iterators.md (Vhalf): Handle V8HF.
298
299 2019-06-06 Jozef Lawrynowicz <jozef.l@mittosystems.com>
300
301 * config/msp430/msp430.md (ashlhi3): Use the const_variant of shift
302 library functions only when not optimizing for size.
303 (ashlsi3): Likewise.
304 (ashrhi3): Likewise.
305 (ashrsi3): Likewise.
306 (lshrhi3): Likewise.
307 (lshrsi3): Likewise.
308
309 2019-06-06 Andreas Krebbel <krebbel@linux.ibm.com>
310
311 PR rtl-optimization/88751
312 * ira.c (ira): Use the number of the actually referenced registers
313 when calculating the threshold.
314
315 2019-06-06 Jakub Jelinek <jakub@redhat.com>
316
317 * configure: Regenerate.
318
319 2019-06-06 Jozef Lawrynowicz <jozef.l@mittosystems.com>
320
321 * config/msp430/msp430.md (ashlhi3): Force shift src operand into a
322 register if it is in memory, so the shift can be emulated with a rotate
323 instruction.
324 (ashrhi3): Likewise.
325 (lshrhi3): Likewise.
326
327 2019-06-06 Martin Liska <mliska@suse.cz>
328
329 PR tree-optimization/87954
330 * match.pd: Simplify mult where both arguments are 0 or 1.
331
332 2019-06-06 Richard Biener <rguenther@suse.de>
333
334 * vr-values.c (vr_values::extract_range_from_ssa_name): Do not
335 put equivalences on UNDEFINED ranges.
336 * gimple-ssa-evrp.c (evrp_dom_walker::before_dom_children):
337 Make sure to drop defs of stmts added during simplification
338 to VARYING.
339
340 2019-06-06 Richard Biener <rguenther@suse.de>
341
342 * tree-ssa-structalias.c: Include tree-cfg.h.
343 (make_heapvar): Do not make heap vars artificial.
344 (find_func_aliases_for_builtin_call): Handle stack allocation
345 functions.
346 (find_func_aliases): Delay processing of simple enough returns
347 in non-IPA mode.
348 (set_uids_in_ptset): Adjust.
349 (find_what_var_points_to): Likewise.
350 (solve_constraints): Do not dump points-to sets here.
351 (compute_points_to_sets): Post-process return statements,
352 amending the escaped solution. Dump points-to sets afterwards.
353 (ipa_pta_execute): Dump points-to sets.
354
355 2019-06-06 Martin Liska <mliska@suse.cz>
356
357 PR web/87933
358 * doc/install.texi: Fix HTML headers and
359 titles for 'Installing GCC' pages.
360
361 2019-06-06 Martin Liska <mliska@suse.cz>
362
363 * ipa-icf-gimple.h (dump_message_1): Remove.
364 (dump_message): Likewise.
365 (return_false_with_message_1): Print also file.
366 (return_false_with_msg): Likewise.
367 (return_with_result): Likewise.
368 (return_with_debug): Likewise.
369 * ipa-icf.c (sem_function::equals_private): Remove call
370 to dump_message.
371
372 2019-06-05 Hongtao Liu <hongtao.liu@intel.com>
373
374 * config/i386/sse.md (define_mode_suffix vecmemsuffix): New.
375 (define_insn "avx512dq_fpclass<mode><mask_scalar_merge_name>"): Enable
376 memory operand for it.
377 (define_insn "avx512dq_vmfpclass<mode><mask_scalar_merge_name>"): Ditto.
378
379 2019-06-05 Martin Sebor <msebor@redhat.com>
380
381 * config/i386/i386-features.c (ix86_get_function_versions_dispatcher):
382 Adjust quoting and hyphenation.
383 * convert.c (convert_to_real_1): Same.
384 * gcc.c (driver_wrong_lang_callback): Same.
385 (driver::handle_unrecognized_options): Same.
386 * gimple-ssa-nonnull-compare.c (do_warn_nonnull_compare): Same.
387 * opts-common.c (cmdline_handle_error): Same.
388 (read_cmdline_option): Same.
389 * opts-global.c (complain_wrong_lang): Same.
390 (print_ignored_options): Same.
391 (handle_common_deferred_options): Same.
392 * pretty-print.h: Same.
393 * print-rtl.c (debug_bb_n_slim): Same.
394 * sched-rgn.c (make_pass_sched_fusion): Same.
395 * tree-cfg.c (verify_gimple_assign_unary): Same.
396 (verify_gimple_label): Same.
397 * tree-ssa-operands.c (verify_ssa_operands): Same.
398 * varasm.c (do_assemble_alias): Same.
399 (assemble_alias): Same.
400
401 2019-06-05 Richard Henderson <rth@twiddle.net>
402
403 * config/alpha/alpha.c (direct_return): Move down after
404 struct machine_function definition; use saved frame_size;
405 return bool.
406 (struct machine_function): Add sa_mask, sa_size, frame_size.
407 (alpha_sa_mask, alpha_sa_size, compute_frame_size): Merge into ...
408 (alpha_compute_frame_layout): ... new function.
409 (TARGET_COMPUTE_FRAME_LAYOUT): New.
410 (alpha_initial_elimination_offset): Use saved sa_size.
411 (alpha_vms_initial_elimination_offset): Likewise.
412 (alpha_vms_can_eliminate): Remove alpha_sa_size call.
413 (alpha_expand_prologue): Use saved frame data. Merge integer
414 and fp register save loops.
415 (alpha_expand_epilogue): Likewise.
416 (alpha_start_function): Use saved frame data.
417 * config/alpha/alpha-protos.h (direct_return): Update.
418 (alpha_sa_size): Remove.
419
420 2019-06-05 Eric Botcazou <ebotcazou@adacore.com>
421
422 * fold-const.c (extract_muldiv_1) <PLUS_EXPR>: Do not distribute a
423 multiplication by a power-of-two value.
424 (fold_plusminus_mult_expr): Use pow2p_hwi to spot a power-of-two value
425 and turn the modulo operation into a masking operation.
426
427 2019-06-05 Jakub Jelinek <jakub@redhat.com>
428
429 PR debug/90733
430 * var-tracking.c (vt_expand_loc_callback): Don't create raw subregs
431 with VOIDmode inner operands.
432
433 2019-06-05 Richard Biener <rguenther@suse.de>
434
435 PR middle-end/90726
436 * tree-ssa-loop-niter.c (expand_simple_operations): Do not
437 turn an expression graph into a tree.
438
439 2019-06-05 Jakub Jelinek <jakub@redhat.com>
440
441 * omp-expand.c (struct omp_region): Add has_lastprivate_conditional
442 member.
443 (expand_parallel_call): If region->inner->has_lastprivate_conditional,
444 treat it like explicit monotonic schedule modifier.
445 (expand_omp_for): Initialize has_lastprivate_conditional.
446 If fd.lastprivate_conditional != 0, treat it like explicit monotonic
447 schedule modifier.
448
449 * omp-low.c (lower_rec_input_clauses): For lastprivate conditional
450 references, lookup in in hash map MEM_REF operand instead of the
451 MEM_REF itself.
452 (lower_omp_1): When looking for lastprivate conditional assignments,
453 handle MEM_REFs with REFERENCE_TYPE operands.
454
455 * omp-low.c (lower_rec_input_clauses): Force max_vf if is_simd and
456 on privatization clauses OMP_CLAUSE_DECL is privatized by reference
457 and references a VLA. Handle references to non-VLAs if is_simd
458 all privatization clauses like reductions.
459 (lower_rec_input_clauses) <case do_private, case do_firstprivate>:
460 If omp_is_reference, use always omp simd arrays and set
461 DECL_VALUE_EXPR in that case, if lower_rec_simd_input_clauses
462 fails, emit reference initialization.
463
464 2019-06-05 Hongtao Liu <hongtao.liu@intel.com>
465
466 PR target/89803
467 * config/i386/avx512dqintrin.h (_mm_mask_fpclass_ss_mask,
468 _mm_mask_fpclass_sd_mask): New intrinsics.
469 (_mm_fpclass_ss_mask, _mm_fpclass_sd_mask): Modified, use new builtins.
470 * config/i386/i386-builtin.def
471 (__builtin_ia32_fpclassss_mask, __builtin_ia32_fpclasssd_mask):
472 New builtins.
473 (__builtin_ia32_fpclassss, __builtin_ia32_fpclasssd): Deleted.
474 * config/i386/i386-builtin-types.def (DEF_FUNCTION_TYPE (QI, V2DF, INT),
475 DEF_FUNCTION_TYPE (QI, V4SF, INT)): Deleted.
476 * config/i386/i386-expand.c (case QI_FTYPE_V4SF_INT,
477 case QI_FTYPE_V2SF_INT): Ditto.
478 * config/i386/sse.md
479 (define_insn "avx512dq_vmfpclass<mode><mask_scalar_merge_name>):
480 Extended to insnstructions with mask operands.
481
482 2019-06-04 Segher Boessenkool <segher@kernel.crashing.org>
483
484 * config/rs6000/constraints.md (define_register_constraint "wp"):
485 Delete.
486 (define_register_constraint "wq"): Delete.
487 * config/rs6000/rs6000.c (rs6000_debug_reg_global): Adjust.
488 (rs6000_init_hard_regno_mode_ok): Adjust.
489 * config/rs6000/rs6000.h (enum r6000_reg_class_enum): Delete
490 RS6000_CONSTRAINT_wp and RS6000_CONSTRAINT_wq.
491 * config/rs6000/vsx.md (define_mode_attr VSr3): Delete.
492 (define_mode_attr VSa): Delete.
493 (define_mode_attr VSisa): New.
494 (rest of file): Adjust.
495 * doc/md.texi (Machine Constraints): Adjust.
496
497 2019-06-04 Segher Boessenkool <segher@kernel.crashing.org>
498
499 * config/rs6000/rs6000.md (define_attr "isa"): Add p9kf and p9tf.
500 (define_attr "enabled"): Handle those new isa values.
501
502 2019-06-04 Segher Boessenkool <segher@kernel.crashing.org>
503
504 * config/rs6000/vsx.md (define_mode_attr VSr4): Delete.
505 (define_mode_attr VSr5): Delete.
506 (define_mode_attr VStype_sqrt): Delete.
507 (define_mode_iterator VSX_SPDP): Delete.
508 (define_mode_attr VS_spdp_res): Delete.
509 (define_mode_attr VS_spdp_insn): Delete.
510 (define_mode_attr VS_spdp_type): Delete.
511 (*vsx_sqrt<mode>2): Adjust.
512 (vsx_<VS_spdp_insn>): Delete, split to...
513 (vsx_xscvdpsp): ... this. New. And...
514 (vsx_xvcvspdp): ... this. New. And...
515 (vsx_xvcvdpsp): ... this. New.
516
517 2019-06-04 Segher Boessenkool <segher@kernel.crashing.org>
518
519 * config/rs6000/rs6000.md (define_mode_attr sd): Add values for V4SF
520 and V2DF.
521 * config/rs6000/vsx.md (define_mode_attr VSs): Delete.
522 (rest of file): Adjust.
523
524 2019-06-04 Segher Boessenkool <segher@kernel.crashing.org>
525
526 * config/rs6000/vsx.md (vsx_<VS_spdp_insn>): Use wa instead of <VSa>.
527 (vsx_extract_<mode>_var): Ditto.
528
529 2019-06-04 Segher Boessenkool <segher@kernel.crashing.org>
530
531 * config/rs6000/vsx.md: Replace all <VSa> that are used with VSX_TI
532 with just "wa".
533
534 2019-06-04 Segher Boessenkool <segher@kernel.crashing.org>
535
536 * config/rs6000/constraints.md (define_register_constraint "ww"):
537 Delete.
538 * config/rs6000/rs6000.c (rs6000_debug_reg_global): Adjust.
539 (rs6000_init_hard_regno_mode_ok): Adjust.
540 * config/rs6000/rs6000.h (enum r6000_reg_class_enum): Delete
541 RS6000_CONSTRAINT_ww.
542 * config/rs6000/rs6000.md: Adjust.
543 * config/rs6000/vsx.md: Adjust.
544 * doc/md.texi (Machine Constraints): Adjust.
545
546 2019-06-04 Segher Boessenkool <segher@kernel.crashing.org>
547
548 * config/rs6000/rs6000.md (SFDF, SFDF2): Adjust comments.
549 (define_mode_attr sd): New.
550 (define_mode_attr s): New.
551 (define_mode_attr Ftrad): Delete.
552 (define_mode_attr Fvsx): Delete.
553 (define_mode_attr Fs): Delete.
554 (rest of file): Use the new mode attributes.
555 * config.rs6000/vsx.md: Use the new mode attributes.
556
557 2019-06-04 Segher Boessenkool <segher@kernel.crashing.org>
558
559 * config/rs6000/vsx.md: Replace all <VSa> that are used with VSX_W
560 with just "wa".
561
562 2019-06-04 Segher Boessenkool <segher@kernel.crashing.org>
563
564 * config/rs6000/vsx.md (define_mode_attr VSr2): Delete.
565 (rest of file): Replace all <VSa>, <VSr>, <VSr2>, and <VSr3> that are
566 used with VSX_B, VSX_D, or VSX_F, with just "wa".
567
568 2019-06-04 Bill Schmidt <wschmidt@linux.ibm.com>
569
570 PR target/78263
571 * config/rs6000/altivec.h: Don't #define vector, pixel, bool for
572 C++ with strict ANSI requirements.
573
574 2019-06-04 Marc Glisse <marc.glisse@inria.fr>
575
576 * tree-ssa-loop-niter.c (number_of_iterations_ne): Skip
577 computations when step is 1.
578
579 2019-06-04 Segher Boessenkool <segher@kernel.crashing.org>
580
581 * config/rs6000/constraints.md (define_register_constraint "wf"):
582 Delete.
583 * config/rs6000/rs6000.c (rs6000_debug_reg_global): Adjust.
584 (rs6000_init_hard_regno_mode_ok): Adjust.
585 * config/rs6000/rs6000.h (enum r6000_reg_class_enum): Delete
586 RS6000_CONSTRAINT_wf.
587 * config/rs6000/rs6000.md: Adjust.
588 * config/rs6000/vsx.md: Adjust.
589 * doc/md.texi (Machine Constraints): Adjust.
590
591 2019-06-04 Andrew Pinski <apinski@marvell.com>
592
593 * config/aarch64/aarch64.c (aarch64_asan_shadow_offset):
594 Fix ILP32 value.
595
596 2019-06-04 Segher Boessenkool <segher@kernel.crashing.org>
597
598 * config/rs6000/constraints.md (define_register_constraint "wd"):
599 Delete.
600 * config/rs6000/rs6000.c (rs6000_debug_reg_global): Adjust.
601 (rs6000_init_hard_regno_mode_ok): Adjust.
602 * config/rs6000/rs6000.h (enum r6000_reg_class_enum): Delete
603 RS6000_CONSTRAINT_wd.
604 * config/rs6000/rs6000.md: Adjust.
605 * config/rs6000/vsx.md: Adjust.
606 * doc/md.texi (Machine Constraints): Adjust.
607
608 2019-06-04 Segher Boessenkool <segher@kernel.crashing.org>
609
610 * config/rs6000/rs6000.md (define_mode_attr Fv2): Delete.
611 (rest of file): Adjust.
612
613 2019-06-04 Segher Boessenkool <segher@kernel.crashing.org>
614
615 * config/rs6000/vsx.md (define_mode_attr VS_64reg): Delete.
616 (*vsx_extract_<P:mode>_<VSX_D:mode>_load): Adjust.
617 (vsx_splat_<mode>_reg): Adjust.
618
619 2019-06-04 Segher Boessenkool <segher@kernel.crashing.org>
620
621 * config/rs6000/constraints.md (define_register_constraint "ws"):
622 Delete.
623 * config/rs6000/rs6000.c (rs6000_debug_reg_global): Adjust.
624 (rs6000_init_hard_regno_mode_ok): Adjust.
625 * config/rs6000/rs6000.h (enum r6000_reg_class_enum): Delete
626 RS6000_CONSTRAINT_ws.
627 * config/rs6000/rs6000.md: Adjust.
628 * config/rs6000/vsx.md: Adjust.
629 * doc/md.texi (Machine Constraints): Adjust.
630
631 2019-06-04 Segher Boessenkool <segher@kernel.crashing.org>
632
633 * config/rs6000/constraints.md (define_register_constraint "wv"):
634 Delete.
635 * config/rs6000/rs6000.c (rs6000_debug_reg_global): Adjust.
636 (rs6000_init_hard_regno_mode_ok): Adjust.
637 * config/rs6000/rs6000.h (enum r6000_reg_class_enum): Delete
638 RS6000_CONSTRAINT_wv.
639 * config/rs6000/rs6000.md: Adjust.
640 * config/rs6000/vsx.md: Adjust.
641 * doc/md.texi (Machine Constraints): Adjust.
642
643 2019-06-04 Segher Boessenkool <segher@kernel.crashing.org>
644
645 * config/rs6000/constraints.md (define_register_constraint "wi"):
646 Delete.
647 (define_register_constraint "wt"): Delete.
648 * config/rs6000/rs6000.c (rs6000_debug_reg_global): Adjust.
649 (rs6000_init_hard_regno_mode_ok): Adjust.
650 * config/rs6000/rs6000.h (enum r6000_reg_class_enum): Delete
651 RS6000_CONSTRAINT_wi and RS6000_CONSTRAINT_wt.
652 * config/rs6000/rs6000.md: Adjust.
653 * config/rs6000/vsx.md: Adjust.
654 * doc/md.texi (Machine Constraints): Adjust.
655
656 2019-06-04 Szabolcs Nagy <szabolcs.nagy@arm.com>
657
658 * config/aarch64/aarch64-protos.h (aarch64_asm_output_external): Remove
659 const.
660 * config/aarch64/aarch64.c (aarch64_asm_output_external): Call
661 default_elf_asm_output_external.
662
663 2019-06-04 Martin Liska <mliska@suse.cz>
664
665 * ipa-icf.c (INCLUDE_LIST): Remove.
666 (sem_item_optimizer::execute): Remove call to init_wpa.
667 * ipa-icf.h (init_wpa): Remove.
668
669 2019-06-04 Jakub Jelinek <jakub@redhat.com>
670
671 * gimplify.c (gimplify_scan_omp_clauses): Don't sorry_at on lastprivate
672 conditional on combined for simd.
673 * omp-low.c (struct omp_context): Add combined_into_simd_safelen0
674 member.
675 (lower_rec_input_clauses): For gimple_omp_for_combined_into_p max_vf 1
676 constructs, don't remove lastprivate_conditional_map, but instead set
677 ctx->combined_into_simd_safelen0 and adjust hash_map, so that it points
678 to parent construct temporaries.
679 (lower_lastprivate_clauses): Handle ctx->combined_into_simd_safelen0
680 like !ctx->lastprivate_conditional_map.
681 (lower_omp_1) <case GIMPLE_ASSIGN>: If up->combined_into_simd_safelen0,
682 use up->outer context instead of up.
683 * omp-expand.c (expand_omp_for_generic): Perform cond_var bump even if
684 gimple_omp_for_combined_p.
685 (expand_omp_for_static_nochunk): Likewise.
686 (expand_omp_for_static_chunk): Add forgotten cond_var bump that was
687 probably moved over into expand_omp_for_generic rather than being copied
688 there.
689
690 2019-06-04 Martin Liska <mliska@suse.cz>
691
692 * value-prof.c (dump_histogram_value): Fix typo.
693 (gimple_mod_subtract_transform): Likewise.
694
695 2019-06-04 Richard Biener <rguenther@suse.de>
696
697 PR middle-end/90726
698 * tree-chrec.c (chrec_contains_symbols): Add to visited.
699 (tree_contains_chrecs): Likewise.
700 (chrec_contains_symbols_defined_in_loop): Move here and avoid
701 exponential behaivor from ...
702 * tree-scalar-evolution.c (chrec_contains_symbols_defined_in_loop):
703 ... here.
704 (expression_expensive_p): Avoid exponential behavior and compute
705 expanded size, rejecting any expansion.
706 * tree-ssa-loop-ivopts.c (abnormal_ssa_name_p): Remove.
707 (idx_contains_abnormal_ssa_name_p): Likewise.
708 (contains_abnormal_ssa_name_p_1): New helper for walk_tree.
709 (contains_abnormal_ssa_name_p): Simplify and use
710 walk_tree_without_duplicates.
711
712 2019-06-04 Richard Biener <rguenther@suse.de>
713
714 PR tree-optimization/90738
715 Revert
716 2019-06-03 Richard Biener <rguenther@suse.de>
717
718 * tree-ssa-sccvn.c (ao_ref_init_from_vn_reference): Get original
719 full reference tree and record in ref->ref.
720 (vn_reference_lookup_3): Pass in original ref to
721 ao_ref_init_from_vn_reference.
722 (vn_reference_lookup): Likewise.
723 * tree-ssa-sccvn.h (ao_ref_init_from_vn_reference): Adjust prototype.
724 * tree-ssa-alias.c (nonoverlapping_component_refs_of_decl_p):
725 Handle non-decl bases in the original reference.
726
727 2019-06-04 Martin Liska <mliska@suse.cz>
728
729 * ipa-icf.c (sem_item_optimizer::add_item_to_class): Count
730 number of references.
731 (sem_item_optimizer::do_congruence_step):
732 (sem_item_optimizer::worklist_push): Dump how references
733 a class has.
734 (sem_item_optimizer::worklist_pop): Use heap.
735 (sem_item_optimizer::process_cong_reduction): Likewise.
736 * ipa-icf.h: Use fibonacci_heap insteam of std::list.
737
738 2019-06-04 Martin Liska <mliska@suse.cz>
739
740 * ipa-icf.h (struct sem_usage_pair_hash): New.
741 (sem_usage_pair_hash::hash): Likewise.
742 (sem_usage_pair_hash::equal): Likewise.
743 (struct sem_usage_hash): Likewise.
744 * ipa-icf.c (sem_item::sem_item): Initialize
745 referenced_by_count.
746 (sem_item::add_reference): Register a reference
747 in ref_map and not in target->usages.
748 (sem_item::setup): Remove initialization of
749 dead vectors.
750 (sem_item::~sem_item): Remove usage of dead vectors.
751 (sem_item::dump): Remove dump of references.
752 (sem_item_optimizer::sem_item_optimizer): Initialize
753 m_references.
754 (sem_item_optimizer::read_section): Remove useless
755 dump.
756 (sem_item_optimizer::parse_funcs_and_vars): Likewise here.
757 (sem_item_optimizer::build_graph): Pass m_references
758 to ::add_reference.
759 (sem_item_optimizer::verify_classes): Remove usage of dead
760 vectors.
761 (sem_item_optimizer::traverse_congruence_split): Return true
762 when a class is split.
763 (sem_item_optimizer::do_congruence_step_for_index): Use
764 hash_map for look up of (sem_item *, index). That brings
765 significant speed up.
766 (sem_item_optimizer::do_congruence_step): Return true
767 when a split is done.
768 (congruence_class::is_class_used): Use referenced_by_count.
769
770 2019-06-04 Alan Modra <amodra@gmail.com>
771
772 PR target/90689
773 * config/rs6000/rs6000.c (rs6000_call_aix): Correct r271753 merge
774 error.
775
776 2019-06-03 Segher Boessenkool <segher@kernel.crashing.org>
777
778 * config/rs6000/rs6000.h (MASK_MFPGPR): Delete.
779 * config/rs6000/rs6000.c (direct_move_p): Adjust.
780 (rs6000_secondary_reload_simple_move): Adjust.
781 (rs6000_opt_masks): Neuter the "mfpgpr" option.
782 * config/rs6000/rs6000-c.c (rs6000_target_modify_macros): Adjust.
783 * config/rs6000/rs6000-cpus.def (ISA_2_5_MASKS_EMBEDDED): Adjust
784 comment.
785 (power6x): Adjust.
786 * config/rs6000/rs6000.md (floatsi<mode>2_lfiwax): Adjust.
787 (floatunssi<mode>2_lfiwzx): Adjust.
788 (fix_trunc<mode>si2_stfiwx): Adjust.
789 (fixuns_trunc<mode>si2_stfiwx): Adjust.
790 * config/rs6000/rs6000.opt (mno-mfpgpr): New.
791 (mfpgpr): Mark as deprecated.
792 * doc/extend.texi (PowerPC Function Attributes): Delete mfpgpr.
793 (Basic PowerPC Built-in Functions Available on ISA 2.05): Adjust.
794 * doc/invoke.texi (RS/6000 and PowerPC Options): Delete -mmfpgpr.
795
796 2019-06-03 Segher Boessenkool <segher@kernel.crashing.org>
797
798 * config/rs6000/constraints.md (define_register_constraint "wg"):
799 Delete.
800 * config/rs6000/rs6000.h (enum r6000_reg_class_enum): Delete
801 RS6000_CONSTRAINT_wg.
802 * config/rs6000/rs6000.c (rs6000_debug_reg_global): Adjust.
803 (rs6000_init_hard_regno_mode_ok): Adjust.
804 * config/rs6000/rs6000.md (*mov<mode>_softfloat32, *movdi_internal64):
805 Delete "wg" alternatives.
806 * doc/md.texi (Machine Constraints): Adjust.
807
808 2019-06-03 Alan Modra <amodra@gmail.com>
809
810 * bb-reorder.c (copy_bb_p): Don't overflow size calculation.
811 (get_uncond_jump_length): Assert length less than INT_MAX and
812 non-negative.
813
814 2019-06-03 Wilco Dijkstra <wdijkstr@arm.com>
815
816 PR middle-end/64242
817 * builtins.c (expand_builtin_longjmp): Add frame clobbers and schedule
818 block.
819 (expand_builtin_nonlocal_goto): Likewise.
820
821 2019-06-03 Szabolcs Nagy <szabolcs.nagy@arm.com>
822
823 * config/aarch64/aarch64-protos.h (aarch64_asm_output_alias): Declare.
824 (aarch64_asm_output_external): Declare.
825 * config/aarch64/aarch64.c (aarch64_asm_output_variant_pcs): New.
826 (aarch64_declare_function_name): Call aarch64_asm_output_variant_pcs.
827 (aarch64_asm_output_alias): New.
828 (aarch64_asm_output_external): New.
829 * config/aarch64/aarch64.h (ASM_OUTPUT_DEF_FROM_DECLS): Define.
830 (ASM_OUTPUT_EXTERNAL): Define.
831
832 2019-06-03 Aldy Hernandez <aldyh@redhat.com>
833 * tree-vrp.h (value_range_base::nonzero_p): New.
834 (value_range_base::set_nonnull): Rename to...
835 (value_range_base::set_nonzero): ...this.
836 (value_range_base::set_null): Rename to...
837 (value_range_base::set_zero): ...this.
838 (value_range::set_nonnull): Remove.
839 (value_range::set_null): Remove.
840 * tree-vrp.c (range_is_null): Remove.
841 (range_is_nonnull): Remove.
842 (extract_range_from_binary_expr): Use value_range_base::*zero_p
843 instead of range_is_*null.
844 (extract_range_from_unary_expr): Same.
845 (value_range_base::set_nonnull): Rename to...
846 (value_range_base::set_nonzero): ...this.
847 (value_range::set_nonnull): Remove.
848 (value_range_base::set_null): Rename to...
849 (value_range_base::set_zero): ...this.
850 (value_range::set_null): Remove.
851 (extract_range_from_binary_expr): Rename set_*null uses to
852 set_*zero.
853 (extract_range_from_unary_expr): Same.
854 (union_helper): Same.
855 * vr-values.c (get_value_range): Use set_*zero instead of
856 set_*null.
857 (vr_values::extract_range_from_binary_expr): Same.
858 (vr_values::extract_range_basic): Same.
859
860 2019-06-03 Wilco Dijkstra <wdijkstr@arm.com>
861
862 PR driver/90684
863 * opts.c (parse_and_check_align_values): Allow 4 alignment values.
864
865 2019-06-03 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
866
867 * config/aarch64/iterators.md (MAX_OPP): New code attr.
868 * config/aarch64/aarch64-simd.md (*aarch64_<su>abd<mode>_3): Rename to...
869 (aarch64_<su>abd<mode>_3): ... This.
870 (<sur>sadv16qi): Add TARGET_DOTPROD expansion.
871
872 2019-06-03 Richard Biener <rguenther@suse.de>
873
874 * tree-ssa-sccvn.c (ao_ref_init_from_vn_reference): Get original
875 full reference tree and record in ref->ref.
876 (vn_reference_lookup_3): Pass in original ref to
877 ao_ref_init_from_vn_reference.
878 (vn_reference_lookup): Likewise.
879 * tree-ssa-sccvn.h (ao_ref_init_from_vn_reference): Adjust prototype.
880 * tree-ssa-alias.c (nonoverlapping_component_refs_of_decl_p):
881 Handle non-decl bases in the original reference.
882
883 2019-06-03 Martin Liska <mliska@suse.cz>
884
885 * doc/generic.texi: Remove Java Trees.
886
887 2019-06-03 Martin Liska <mliska@suse.cz>
888
889 * fold-const.c (operand_equal_p): Fix typo as compare_tree_int
890 returns 0 when operands are equal.
891
892 2019-06-03 Richard Biener <rguenther@suse.de>
893
894 PR tree-optimization/90716
895 * tree-loop-distribution.c (destroy_loop): Process blocks in
896 correct order.
897
898 2019-06-03 Prathamesh Kulkarni <prathamesh.kulkarni@linaro.org>
899
900 PR target/88837
901 * vector-builder.h (vector_builder::count_dups): New method.
902 * config/aarch64/aarch64-protos.h (aarch64_expand_sve_vector_init):
903 Declare prototype.
904 * config/aarch64/aarch64/sve.md (aarch64_sve_rev64<mode>): Use @.
905 (vec_init<mode><Vel>): New pattern.
906 * config/aarch64/aarch64.c (emit_insr): New function.
907 (aarch64_sve_expand_vector_init_handle_trailing_constants): Likewise.
908 (aarch64_sve_expand_vector_init_insert_elems): Likewise.
909 (aarch64_sve_expand_vector_init_handle_trailing_same_elem): Likewise.
910 (aarch64_sve_expand_vector_init): Define two overloaded functions.
911
912 2019-06-03 Alejandro Martinez <alejandro.martinezvicente@arm.com>
913
914 PR tree-optimization/90681
915 * internal-fn.c (mask_load_direct): Mark as non-vectorizable again.
916 * tree-vect-slp.c (vect_build_slp_tree_1): Add masked loads as a
917 special case for SLP, but fail on non-groupped loads.
918
919 2019-06-03 Martin Liska <mliska@suse.cz>
920
921 * cfg.c (debug): Use TDF_DETAILS for debug and
922 print edge info only once.
923
924 2019-06-02 Thomas Koenig <tkoenig@gcc.gnu.org>
925
926 PR fortran/90539
927 * predict.def (PRED_FORTRAN_CONTIGUOUS): New predictor.
928
929 2019-06-01 Martin Sebor <msebor@redhat.com>
930
931 PR middle-end/90694
932 * tree-pretty-print.c (dump_generic_node): Add parentheses.
933
934 2019-05-31 Jan Hubicka <jh@suse.cz>
935
936 * alias.c: Include ipa-utils.h.
937 (get_alias_set): Try to complete ODR type via ODR type hash lookup.
938 * ipa-devirt.c (prevailing_odr_type): New.
939 * ipa-utils.h (previaling_odr_type): Declare.
940
941 2019-05-31 H.J. Lu <hongjiu.lu@intel.com>
942 Hongtao Liu <hongtao.liu@intel.com>
943
944 PR target/89355
945 * config/i386/i386-features.c (rest_of_insert_endbranch): Remove
946 NOTE_INSN_DELETED_LABEL check.
947
948 2019-05-31 Prachi Godbole <prachi.godbole@imgtec.com>
949 Robert Suchanek <robert.suchanek@mips.com>
950
951 * config/mips/mips.c (mips_expand_builtin_insn): Swap the 1st
952 and 3rd operands of the fmadd/fmsub/maddv builtin.
953
954 2019-05-31 Jakub Jelinek <jakub@redhat.com>
955
956 * tree.h (OMP_CLAUSE__CONDTEMP__ITER): Define.
957 * gimplify.c (gimplify_scan_omp_clauses): Allow lastprivate conditional
958 on OMP_SIMD if not nested inside of worksharing loop that also has
959 lastprivate conditional clause for the same decl.
960 (gimplify_omp_for): Add _condtemp_ clauses to OMP_SIMD if needed.
961 * omp-low.c (scan_sharing_clauses): Handle OMP_CLAUSE__CONDTEMP_ also
962 on simd.
963 (lower_rec_input_clauses): Likewise. Handle lastprivate conditional
964 on simd construct.
965 (lower_lastprivate_conditional_clauses): Handle lastprivate conditional
966 on simd construct.
967 (lower_lastprivate_clauses): Likewise.
968 (lower_omp_sections): Call lower_lastprivate_conditional_clauses before
969 calling lower_rec_input_clauses.
970 (lower_omp_for): Likewise.
971 (lower_omp_1): Use first rather than second OMP_CLAUSE__CONDTEMP_
972 clause on simd construct.
973 * omp-expand.c (expand_omp_simd): Initialize cond_var if
974 OMP_CLAUSE__CONDTEMP_ clause is present.
975
976 * omp-low.c (lower_rec_simd_input_clauses): Set TREE_THIS_NOTRAP on
977 ivar and lvar.
978
979 2019-05-31 Xiong Hu Luo <luoxhu@linux.ibm.com>
980
981 PR c/43673
982 * c-format.c (print_char_table, scanf_char_table): Replace BADLEN with
983 TEX_D32, TEX_D64 or TEX_D128.
984
985 2019-05-31 Marc Glisse <marc.glisse@inria.fr>
986
987 * match.pd (~(vec?cst1:cst2)): New transformation.
988
989 2019-05-31 Marc Glisse <marc.glisse@inria.fr>
990
991 * match.pd (X/[ex]D<Y/[ex]D): Handle negative denominator.
992 ((size_t)(A /[ex] B) CMP C): New transformation.
993
994 2019-05-31 Richard Sandiford <richard.sandiford@arm.com>
995
996 * doc/md.texi: Document define_insn_and_rewrite.
997 * rtl.def (DEFINE_INSN_AND_REWRITE): New rtx code.
998 * gensupport.c (queue_elem): Update comment.
999 (replace_operands_with_dups): New function.
1000 (gen_rewrite_sequence): Likewise.
1001 (process_rtx): Handle DEFINE_INSN_AND_REWRITE.
1002 * read-rtl.c (apply_subst_iterator): Likewise.
1003 (add_condition_to_rtx, named_rtx_p): Likewise.
1004 (rtx_reader::read_rtx_operand): Likewise.
1005 * config/aarch64/aarch64-sve.md
1006 (while_ult<GPI:mode><PRED_ALL:mode>_cc): Rename to...
1007 (*while_ult<GPI:mode><PRED_ALL:mode>_cc): ...this and use
1008 define_insn_and_rewrite.
1009 (*cond_<optab><mode>_any): Turn into define_insn_and_rewrites.
1010 Remove separate define_split.
1011
1012 2019-05-31 Jan Hubicka <jh@suse.cz>
1013
1014 * tree-ssa-alias.c (type_has_components_p): New function.
1015 (aliasing_component_refs_p): Use it.
1016
1017 2019-05-31 Martin Liska <mliska@suse.cz>
1018
1019 * gdbhooks.py: Add const_tree to TreePrinter.
1020
1021 2019-05-31 Thomas De Schampheleire <thomas.de_schampheleire@nokia.com>
1022
1023 PR debug/86964
1024 * common.opt (feliminate-unused-debug-symbols): Enable by default.
1025 * doc/invoke.texi (Debugging Options): Document new default of
1026 -feliminate-unused-debug-symbols and remove restriction to 'stabs'.
1027
1028 2019-05-31 Jakub Jelinek <jakub@redhat.com>
1029
1030 PR tree-optimization/90671
1031 * tree-ssa-threadupdate.c (ssa_create_duplicates): If
1032 template_block used to be empty on the first call, don't use
1033 gsi_split_seq_after and gsi_insert_seq_after, but remember whole
1034 seq with bb_seq and set it with set_bb_seq.
1035
1036 2019-05-31 Iain Sandoe <iain@sandoe.co.uk>
1037
1038 * config/i386/darwin.h (ASM_OUTPUT_MAX_SKIP_ALIGN): New.
1039
1040 2019-05-30 Bill Schmidt <wschmidt@linux.ibm.com>
1041 Michael Meissner <meissner@linux.ibm.com>
1042
1043 * config/rs6000/predicates.md (pcrel_address): New define_predicate.
1044 (prefixed_mem_operand): Likewise.
1045 (non_prefixed_mem_operand): Likewise.
1046 * config/rs6000/rs6000-protos.h (rs6000_prefixed_address): New
1047 prototype.
1048 * config/rs6000/rs6000.c (print_operand_address): Handle
1049 PC-relative addresses.
1050 (mode_supports_prefixed_address_p): New function.
1051 (rs6000_prefixed_address): New function.
1052 * config/rs6000/rs6000.h (SYMBOL_FLAG_PCREL): New #define.
1053 (SYMBOL_REF_PCREL_P): Likewise.
1054
1055 2019-05-30 Jakub Jelinek <jakub@redhat.com>
1056
1057 * gimplify.c (enum gimplify_omp_var_data): Add GOVD_CONDTEMP.
1058 (gimplify_adjust_omp_clauses_1): Handle GOVD_CONDTEMP.
1059 (gimplify_omp_for): If worksharing loop with lastprivate conditional
1060 is nested inside of parallel region, add _condtemp_ clause to both.
1061 * tree-nested.c (convert_nonlocal_omp_clauses,
1062 convert_local_omp_clauses): Ignore OMP_CLAUSE__CONDTEMP_ instead of
1063 assertion failure.
1064 * omp-general.h (struct omp_for_data): Add have_pointer_condtemp
1065 member.
1066 * omp-general.c (omp_extract_for_data): Compute it.
1067 * omp-low.c (scan_sharing_clauses): Handle OMP_CLAUSE__CONDTEMP_.
1068 (lower_rec_input_clauses): Likewise.
1069 (lower_lastprivate_conditional_clauses): If OMP_CLAUSE__CONDTEMP_
1070 clause is already present, just add one further one after it.
1071 (lower_lastprivate_clauses): Handle cond_ptr with array type.
1072 (lower_send_shared_vars): Clear _condtemp_ vars.
1073 (lower_omp_1) <case GIMPLE_ASSIGN>: Handle target data like critical
1074 or section or taskgroup.
1075 * omp-expand.c (determine_parallel_type): Disallow combining only if
1076 first OMP_CLAUSE__CONDTEMP_ has pointer type. Disallow combining
1077 of parallel sections if OMP_CLAUSE__CONDTEMP_ is present.
1078 (expand_omp_for_generic, expand_omp_for_static_nochunk,
1079 expand_omp_for_static_chunk, expand_omp_for): Use
1080 fd->have_pointer_condtemp instead of fd->lastprivate_conditional to
1081 determine if a special set of API routines are needed and if condtemp
1082 needs to be initialized, while always initialize cond_var if
1083 fd->lastprivate_conditional is non-zero.
1084
1085 2019-05-30 Bill Schmidt <wschmidt@linux.ibm.com>
1086 Michael Meissner <meissner@linux.ibm.com>
1087
1088 * config/rs6000/constraints.md (eI): New constraint.
1089 * config/rs6000/predicates.md (cint34_operand): New predicate.
1090 * config/rs6000/rs6000.h (SIGNED_16BIT_OFFSET_P): New #define.
1091 (SIGNED_34BIT_OFFSET_P): Likewise.
1092 * doc/md.texi (eI): Document constraint.
1093
1094 2019-05-30 Sylvia Taylor <sylvia.taylor@arm.com>
1095
1096 * config/aarch64/aarch64-sve.md (*fabd<mode>3): New.
1097
1098 2019-05-30 Bill Schmidt <wschmidt@linux.ibm.com>
1099 Michael Meissner <meissner@linux.ibm.com>
1100
1101 * rs6000-cpus.def (OTHER_FUSION_MASKS): New #define.
1102 (ISA_3_0_MASKS_SERVER): Mask off OTHER_FUSION_MASKS.
1103 (ISA_3_0_MASKS_IEEE): Remove OPTION_MASK_DIRECT_MOVE.
1104 (ISA_FUTURE_MASKS_SERVER): Add OPTION_MASK_PREFIXED_ADDR.
1105 (OTHER_FUTURE_MASKS): Likewise.
1106 (POWERPC_MASKS): Likewise.
1107 * rs6000.c (rs6000_option_override_internal): Error if -mpcrel is
1108 specified without -mprefixed-addr or -mcpu=future. Error if
1109 -mprefixed-addr is specified without -mcpu=future.
1110 (rs6000_opt_masks): Add entry for prefixed-addr.
1111 * rs6000.opt (mprefixed-addr): New option.
1112
1113 2019-05-30 Sam Tebbs <sam.tebbs@arm.com>
1114
1115 * aarch64/aarch64.c (aarch64_post_cfi_startproc): Add
1116 cfun->is_thunk check.
1117
1118 2019-05-30 Jakub Jelinek <jakub@redhat.com>
1119
1120 * tree-predcom.c (is_inv_store_elimination_chain): Fix a typo - lenght
1121 to length.
1122
1123 2019-05-30 Martin Liska <mliska@suse.cz>
1124
1125 * gdbinit.in: Fix 'ptc' command. Add trt
1126 that prints TREE_TYPE($).
1127
1128 2019-05-29 Bill Schmidt <wschmidt@linux.ibm.com>
1129 Alan Modra <amodra@gmail.com>
1130
1131 * config/rs6000/rs6000.c (rs6000_call_template_1): Handle pcrel
1132 calls here...
1133 (rs6000_indirect_call_template_1): ...and here.
1134 (rs6000_pltseq_template): Handle plt_pcrel34. Rework tocsave,
1135 plt16_ha, plt16_lo, mtctr indirect calls. Use
1136 rs6000_pltseq_enum.
1137 (rs6000_decl_ok_for_sibcall): New function.
1138 (rs6000_function_ok_for_sibcall): Refactor.
1139 (rs6000_longcall_ref): Use UNSPEC_PLT_PCREL when pcrel.
1140 (rs6000_call_aix): Don't emit toc restore rtl for indirect calls
1141 when pcrel. Reorganize.
1142 (rs6000_sibcall_aix): Don't add r2 to function usage when pcrel.
1143 * rs6000.h (rs6000_pltseq_enum): New enum.
1144 * rs6000.md (UNSPEC_PLT_PCREL): New unspec.
1145 (*pltseq_tocsave): Use rs6000_pltseq_enum.
1146 (*pltseq_plt16_ha): Likewise.
1147 (*pltseq_plt16_lo): Likewise.
1148 (*pltseq_mtctr): Likewise.
1149 (*pltseq_plt_pcrel): New insn.
1150 (*call_local_aix): Handle @notoc calls.
1151 (*call_value_local_aix): Likewise.
1152 (*call_nonlocal_aix): Adjust lengths for pcrel calls.
1153 (*call_value_nonlocal_aix): Likewise.
1154 (*call_indirect_pcrel): New insn.
1155 (*call_value_indirect_pcrel): Likewise.
1156
1157
1158 2019-05-29 Uroš Bizjak <ubizjak@gmail.com>
1159
1160 * config/i386/sse.md (*save_multiple<mode>): Rename from
1161 save_multiple<mode>.
1162 (*restore_multiple<mode>): Rename from restore_multiple<mode>.
1163 (*restore_multiple_and_return<mode>): Rename from
1164 restore_multiple_and_return<mode>.
1165 (*restore_multiple_leave_return<mode>): Rename from
1166 restore_multiple_leave_return<mode>.
1167
1168 2019-05-29 Yoshinori Sato <ysato@users.sourceforge.jp>
1169
1170 * config.gcc (rx-*-linux*): New target.
1171 * config/rx/elf.opt: New file.
1172 * config/rx/linux.h: Likewise.
1173 * config/rx/t-linux: Likewise.
1174 * config/rx/rx.c (TARGET_SAVE_ACC_REGISTER): If not defined,
1175 make it zero.
1176 * config/rx/rx.h (ASM_APP_ON): Allow to be overridden.
1177 (ASM_APP_OFF): Likewise.
1178 * config/rx/rx.opt: Drop -msim and -mas100-syntax, they were
1179 moved elsewhere.
1180
1181 2019-05-29 Jan Hubicka <jh@suse.cz>
1182
1183 * tree-ssa-alias.c (same_type_for_tbaa): Return ture if main
1184 variants are pointer equivalent.
1185
1186 2019-05-29 Alejandro Martinez <alejandro.martinezvicente@arm.com>
1187
1188 * config/aarch64/aarch64-c.c: Added TARGET_SVE2.
1189 * config/aarch64/aarch64-sve2.md: New file.
1190 (<u>avg<mode>3_floor): New pattern.
1191 (<u>avg<mode>3_ceil): Likewise.
1192 (*<sur>h<addsub><mode>): Likewise.
1193 * config/aarch64/aarch64.h: Added AARCH64_ISA_SVE2 and TARGET_SVE2.
1194 * config/aarch64/aarch64.md: Include aarch64-sve2.md.
1195
1196 2019-05-29 Jakub Jelinek <jakub@redhat.com>
1197
1198 PR bootstrap/90543
1199 * optc-save-gen.awk: In cl_optimization_print, use correct condition
1200 for var_opt_string printing. In cl_optimization_print_diff, print
1201 (null) instead of invoking undefined behavior if one of the
1202 var_opt_string pointers is NULL and use && instead of first || in the
1203 guarding condition. For var_target_other options, handle const char *
1204 target variables similarly to const char * optimize node variables.
1205
1206 2019-05-29 Sam Tebbs <sam.tebbs@arm.com>
1207
1208 * config/aarch64/aarch64-builtins.c (aarch64_builtins): Add
1209 AARCH64_PAUTH_BUILTIN_AUTIB1716 and AARCH64_PAUTH_BUILTIN_PACIB1716.
1210 * config/aarch64/aarch64-builtins.c (aarch64_init_pauth_hint_builtins):
1211 Add autib1716 and pacib1716 initialisation.
1212 * config/aarch64/aarch64-builtins.c (aarch64_expand_builtin): Add checks
1213 for autib1716 and pacib1716.
1214 * config/aarch64/aarch64-protos.h (aarch64_key_type,
1215 aarch64_post_cfi_startproc): Define.
1216 * config/aarch64/aarch64-protos.h (aarch64_ra_sign_key): Define extern.
1217 * config/aarch64/aarch64.c (aarch64_handle_standard_branch_protection,
1218 aarch64_handle_pac_ret_protection): Set default sign key to A.
1219 * config/aarch64/aarch64.c (aarch64_expand_epilogue,
1220 aarch64_expand_prologue): Add check for b-key.
1221 * config/aarch64/aarch64.c (aarch64_ra_sign_key,
1222 aarch64_post_cfi_startproc, aarch64_handle_pac_ret_b_key): Define.
1223 * config/aarch64/aarch64.h (TARGET_ASM_POST_CFI_STARTPROC): Define.
1224 * config/aarch64/aarch64.c (aarch64_pac_ret_subtypes): Add "b-key".
1225 * config/aarch64/aarch64.md (unspec): Add UNSPEC_AUTIA1716,
1226 UNSPEC_AUTIB1716, UNSPEC_AUTIASP, UNSPEC_AUTIBSP, UNSPEC_PACIA1716,
1227 UNSPEC_PACIB1716, UNSPEC_PACIASP, UNSPEC_PACIBSP.
1228 * config/aarch64/aarch64.md (do_return): Add check for b-key.
1229 * config/aarch64/aarch64.md (<pauth_mnem_prefix>sp): Replace
1230 pauth_hint_num_a with pauth_hint_num.
1231 * config/aarch64/aarch64.md (<pauth_mnem_prefix>1716): Replace
1232 pauth_hint_num_a with pauth_hint_num.
1233 * config/aarch64/aarch64.opt (msign-return-address=): Deprecate.
1234 * config/aarch64/iterators.md (PAUTH_LR_SP): Add UNSPEC_AUTIASP,
1235 UNSPEC_AUTIBSP, UNSPEC_PACIASP, UNSPEC_PACIBSP.
1236 * config/aarch64/iterators.md (PAUTH_17_16): Add UNSPEC_AUTIA1716,
1237 UNSPEC_AUTIB1716, UNSPEC_PACIA1716, UNSPEC_PACIB1716.
1238 * config/aarch64/iterators.md (pauth_mnem_prefix): Add UNSPEC_AUTIA1716,
1239 UNSPEC_AUTIB1716, UNSPEC_PACIA1716, UNSPEC_PACIB1716, UNSPEC_AUTIASP,
1240 UNSPEC_AUTIBSP, UNSPEC_PACIASP, UNSPEC_PACIBSP.
1241 * config/aarch64/iterators.md (pauth_hint_num_a): Replace
1242 UNSPEC_PACI1716 and UNSPEC_AUTI1716 with UNSPEC_PACIA1716 and
1243 UNSPEC_AUTIA1716 respectively.
1244 * config/aarch64/iterators.md (pauth_hint_num_a): Rename to pauth_hint_num
1245 and add UNSPEC_PACIBSP, UNSPEC_AUTIBSP, UNSPEC_PACIB1716, UNSPEC_AUTIB1716.
1246 * doc/invoke.texi (-mbranch-protection): Add b-key type.
1247 * config/aarch64/aarch64-bti-insert.c (aarch64_pac_insn_p): Rename
1248 UNSPEC_PACISP to UNSPEC_PACIASP and UNSPEC_PACIBSP.
1249
1250 2019-05-29 Jakub Jelinek <jakub@redhat.com>
1251
1252 * gimplify.c (struct gimplify_omp_ctx): Add clauses member.
1253 (gimplify_scan_omp_clauses): Initialize ctx->clauses.
1254 (gimplify_adjust_omp_clauses_1): Transform lastprivate conditional
1255 explicit clause on combined parallel into implicit shared clause.
1256 (gimplify_adjust_omp_clauses): Move lastprivate conditional clause
1257 and firstprivate if the decl has one too from combined parallel to
1258 the worksharing construct.
1259
1260 2019-05-28 Bill Schmidt <wschmidt@linux.ibm.com>
1261 Michael Meissner <meissner@linux.ibm.com>
1262
1263 * config/rs6000/rs6000-cpus.def (OTHER_FUTURES_MASK): New #define.
1264
1265 2019-05-28 Michael Meissner <meissner@linux.ibm.com>
1266
1267 * rtl.h (LABEL_REF_P): New #define.
1268
1269 2019-05-28 John David Anglin <danglin@gcc.gnu.org>
1270
1271 * config/pa/pa.c (hppa_profile_hook): Remove offset adjustment.
1272
1273 2019-05-28 Alejandro Martinez <alejandro.martinezvicente@arm.com>
1274
1275 * internal-fn.c: Marked mask_load_direct as vectorizable.
1276 * tree-data-ref.c (data_ref_compare_tree): Fixed comment typo.
1277 * tree-vect-data-refs.c (can_group_stmts_p): Allow masked loads to be
1278 combined even if masks different with allow_slp_p param.
1279 (vect_analyze_data_ref_accesses): Mark SLP only vectorizable groups.
1280 * tree-vect-loop.c (vect_dissolve_slp_only_groups): New function to
1281 dissolve SLP-only vectorizable groups when SLP has been discarded.
1282 (vect_analyze_loop_2): Call vect_dissolve_slp_only_groups when needed.
1283 * tree-vect-slp.c (vect_get_and_check_slp_defs): Check masked loads
1284 masks.
1285 (vect_build_slp_tree_1): Fixed comment typo.
1286 (vect_build_slp_tree_2): Include masks from masked loads in SLP tree.
1287 * tree-vect-stmts.c (vectorizable_load): Allow vectorizaion of masked
1288 loads for SLP only.
1289 * tree-vectorizer.h (_stmt_vec_info): Added flag for SLP-only
1290 vectorizable.
1291 * tree-vectorizer.c (vec_info::new_stmt_vec_info): Likewise.
1292
1293 2019-05-28 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
1294
1295 * config/alpha/alpha.c [TARGET_ABI_OSF] (alpha_output_mi_thunk_osf):
1296 Remove obsolete use_thunk reference.
1297 * config/i386/i386.c (x86_output_mi_thunk): Likewise.
1298 * config/ia64/ia64.c (ia64_output_mi_thunk): Likewise.
1299 * config/nios2/nios2.c (nios2_asm_output_mi_thunk): Likewise.
1300 * config/or1k/or1k.c (or1k_output_mi_thunk): Likewise.
1301 * config/rs6000/rs6000.c (rs6000_output_mi_thunk): Likewise.
1302 * config/sh/sh.c (sh_output_mi_thunk): Likewise.
1303 * config/sparc/sparc.c (sparc_output_mi_thunk): Likewise.
1304 * config/tilegx/tilegx.c (tilegx_output_mi_thunk): Likewise.
1305 * config/tilepro/tilepro.c (tilepro_asm_output_mi_thunk): Likewise.
1306
1307 2019-05-28 Nathan Sidwell <nathan@acm.org>
1308
1309 * tree.h (IDENTIFIER_ANON_P): New.
1310 (anon_aggrname_format, anon_aggname_p): Don't declare.
1311 (make_anon_name): Declare.
1312 * lto-streamer-out.c (DFS::DFS_write_tree_body): Use IDENTIFIER_ANON_P.
1313 (hash_tree): Likewise.
1314 * tree-streamer-out.c (write_ts_decl_minimal_tree): Likewise.
1315 * tree.c (anon_aggrname_p, anon_aggrname_format): Delete.
1316 (anon_cnt, make_anon_name): New.
1317
1318 2019-05-28 Martin Liska <mliska@suse.cz>
1319
1320 PR other/90315
1321 * opts-global.c (decode_options): Print help for all
1322 help_option_arguments.
1323 * opts.c (print_help): Add new argument.
1324 (common_handle_option): Remember all values into
1325 help_option_arguments.
1326 * opts.h (print_help): Add new argument.
1327
1328 2019-05-28 Martin Liska <mliska@suse.cz>
1329
1330 PR ipa/90555
1331 * ipa-icf-gimple.c (func_checker::compare_loops): New function.
1332 * ipa-icf-gimple.h (func_checker::compare_loops): Likewise.
1333 (func_checker::compare_bb): Call compare_loops.
1334
1335 2019-05-27 Jakub Jelinek <jakub@redhat.com>
1336
1337 * gimplify.c (gimplify_scan_omp_clauses): Allow lastprivate conditional
1338 on sections construct.
1339 * omp-low.c (lower_lastprivate_conditional_clauses): Handle sections
1340 construct.
1341 (lower_omp_sections): Handle lastprivate conditional.
1342 (lower_omp_1) <case GIMPLE_ASSIGN>: Handle sections construct with
1343 lastprivate_conditional_map.
1344 * omp-expand.c (expand_omp_sections): Handle lastprivate conditional.
1345
1346 * omp-low.c (lower_omp_1) <case GIMPLE_ASSIGN>: Look through ordered,
1347 critical, taskgroup and section regions when looking for a region
1348 with non-NULL lastprivate_conditional_map.
1349
1350 2019-05-27 Uroš Bizjak <ubizjak@gmail.com>
1351
1352 * config/i386/i386.c (ix86_gen_add3): Remove indirect function.
1353 (*ix86_gen_sub3): Ditto.
1354 (*ix86_gen_sub3_carry): Ditto.
1355 (*ix86_gen_one_cmpl2): Ditto.
1356 (*ix86_gen_andsp): Ditto.
1357 (ix86_init_large_pic_reg): Use gen_add2_insn instead of ix86_gen_add3.
1358 (gen_and2_insn): New static function.
1359 (ix86_expand_prologue): Use gen_and2_insn instead of ix86_gen_andsp.
1360 Use gen_add3_insn instead of ix86_gen_add3.
1361 (ix86_expand_split_stack_prologue): Use gen_add2_insn
1362 instead of ix86_gen_add3.
1363 (legitimize_tls_address): Use gen_add2_insn instead of ix86_gen_add3.
1364 Use gen_sub3_insn instead of ix86_gen_sub3.
1365 * config/i386-expand.c (ix86_split_long_move): Use gen_add2_insn
1366 instead of ix86_gen_add3.
1367 (ix86_expand_strlensi_unroll_1): Use gen_add2_insn instead of
1368 ix86_gen_add3. Use gen_sub3_insn instead of ix86_gen_sub3.
1369 (construct_plt_address): Use gen_add2_insn instead of ix86_gen_add3.
1370 * config/i386/i386-options.c (ix86_option_override_internal):
1371 Do not initialize ix86_gen_add3, ix86_gen_sub3, ix86_gen_sub3_carry,
1372 ix86_gen_one_cmpl2 and ix86_gen_andsp.
1373
1374 2019-05-27 Eric Botcazou <ebotcazou@adacore.com>
1375
1376 * dwarf2out.c (resolve_args_picking_1): Deal with DW_OP_GNU_addr_index
1377 and DW_OP_GNU_const_index opcodes.
1378
1379 2019-05-27 Uroš Bizjak <ubizjak@gmail.com>
1380
1381 * config/i386/i386.h (STACK_SIZE_MODE): Define.
1382
1383 2019-05-27 Richard Biener <rguenther@suse.de>
1384
1385 PR tree-optimization/90637
1386 * tree-ssa-sink.c (statement_sink_location): Honor the
1387 computed sink location for single-uses.
1388
1389 2019-05-27 Richard Biener <rguenther@suse.de>
1390
1391 PR middle-end/90610
1392 * match.pd (vec_perm): Avoid clobbering op0 when not generating
1393 a bit-insert.
1394
1395 2019-05-26 Uroš Bizjak <ubizjak@gmail.com>
1396
1397 * config/i386/i386.md (@sub<mode>3_carry): Rename
1398 from sub<mode>3_carry.
1399 (@leave_<mode>): New expander.
1400 (*leave): Rename from leave.
1401 (*leave_rex64): Rename from leave_rex64.
1402 (@monitorx_<mode>): Rename from monitorx_<mode>.
1403 (@clzero_<mode>): Rename from clzero_<mode>.
1404 * config/i386/sse.md (@sse3_monitor_<mode>): Rename
1405 from sse3_monitor_<mode>.
1406 * config/i386/i386.c (ix86_gen_sub3_carry): Remove indirect function.
1407 (*ix86_gen_leave): Ditto.
1408 (*ix86_gen_monitor): Ditto.
1409 (*ix86_gen_monitorx): Ditto.
1410 (*ix86_gen_clzero): Ditto.
1411 (ix86_emit_leave): Use gen_leave instead of ix86_gen_leave.
1412 * config/i386/i386-expand.c (ix86_expand_strlensi_unroll_1):
1413 Use gen_sub3_carry instead of ix86_gen_sub3_carry.
1414 (ix86_expand_builtin) <case IX86_BUILTIN_MONITOR>:
1415 Use gen_sse3_monitor instead of ix86_gen_monitor.
1416 <case IX86_BUILTIN_MONITORX>: Use gen_monitorx
1417 instead of ix86_gen_monitorx.
1418 <case IX86_BUILTIN_CLZERO>: Use gen_clzero
1419 instead of ix86_gen_clzero.
1420 * config/i386/i386-options.c (ix86_option_override_internal):
1421 Do not initialize ix86_gen_leave, ix86_gen_sub3_carry,
1422 ix86_gen_monitor, ix86_gen_monitorx and ix86_gen_clzero.
1423
1424 2019-05-26 Uroš Bizjak <ubizjak@gmail.com>
1425
1426 * config/i386/i386.md (@tls_global_dynamic_64_<mode>):
1427 Rename from tls_global_dynamic_64_<mode>.
1428 (@tls_local_dynamic_base_64_<mode>): Rename from
1429 tls_local_dynamic_base_64_<mode>.
1430 * config/i386/i386.c (*ix86_gen_tls_global_dynamic_64):
1431 Remove indirect function.
1432 (*ix86_gen_tls_local_dynamic_base_64): Ditto.
1433 (legitimize_tls_address): Use gen_tls_global_dynamic_64 function
1434 instead of ix86_gen_tls_global_dynamic_64.
1435 Use gen_tls_local_dynamic_base_64 instead of
1436 ix86_gen_tls_local_dynamic_base_64.
1437 * config/i386/i386-options.c (ix86_option_override_internal):
1438 Do not initialize ix86_gen_tls_global_dynamic_64 and
1439 ix86_gen_tls_local_dynamic_base_64.
1440
1441 2019-05-26 Uroš Bizjak <ubizjak@gmail.com>
1442
1443 * config/i386/i386.md (@pro_epilogue_adjust_stack_add_<mode>)
1444 Rename from pro_epilogue_adjust_stack_<mode>_add.
1445 (@pro_epilogue_adjust_stack_sub_<mode>)
1446 Rename from pro_epilogue_adjust_stack_<mode>_sub.
1447 (@allocate_stack_worker_probe_<mode>):
1448 Rename from allocate_stack_worker_probe_<mode>.
1449 (allocate_stack): Use gen_allocate_stack_worker_probe.
1450 (probe_stack): Use gen_probe_stack_1.
1451 (@probe_stack_1_<mode>): Rename from probe_stack_<mode>.
1452 (@adjust_stack_and_probe_<mode>): Rename from
1453 adjust_stack_and_probe<mode>.
1454 (@probe_stack_range_<mode>): Rename from probe_stack_range<mode>.
1455 (stack_protect_set): Use gen_stack_protect_set_1.
1456 (@stack_protect_set_1_<mode>): Rename from stack_protect_set_<mode>.
1457 (stack_protect_test): Use gen_stack_protect_test_1.
1458 (@stack_protect_test_1_<mode>): Rename from stack_protect_test_<mode>.
1459 * config/i386/i386.c (*ix86_gen_allocate_stack_worker):
1460 Remove indirect function.
1461 (*ix86_gen_adjust_stack_and_probe): Ditto.
1462 (*ix86_gen_probe_stack_range): Ditto.
1463 (pro_epilogue_adjust_stack): Use gen_pro_epilogue_adjust_stack_add
1464 instead of gen_pro_epilogue_adjust_stack_{si,di}_add.
1465 (ix86_adjust_stack_and_probe_stack_clash): Use
1466 gen_adjust_stack_and_probe instead of ix86_gen_adjust_stack_and_probe.
1467 (ix86_adjust_stack_and_probe): Ditto.
1468 (ix86_emit_probe_stack_range): Use gen_probe_stack_range instead
1469 of ix86_gen_probe_stack_range.
1470 (ix86_expand_prologue): Use gen_pro_epilogue_adjust_stack_sub
1471 instead of gen_pro_epilogue_adjust_stack_{si,di}_sub.
1472 * config/i386/x86-tune-sched.c (ix86_macro_fusion_pair_p):
1473 Include insn-opinit.h. Use code_for_stack_protect_test_1 instead of
1474 CODE_FOR_stack_protect_test_{si,di}.
1475 * config/i386/i386-options.c (ix86_option_override_internal):
1476 Do not initialize ix86_gen_allocate_stack_worker,
1477 ix86_gen_adjust_stack_and_probe and ix86_gen_probe_stack_range.
1478
1479 2019-05-26 Gerald Pfeifer <gerald@pfeifer.com>
1480
1481 * doc/invoke.texi (Link Options): Many editorial changes around
1482 -flinker-output.
1483
1484 2019-05-26 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
1485
1486 * doc/invoke.texi (x86 Options, -mvect8-ret-in-mem): Remove
1487 pre-Solaris 11 referene and most Studio compiler details.
1488
1489 2019-05-24 John David Anglin <danglin@gcc.gnu.org>
1490
1491 PR target/90530
1492 * config/pa/pa.c (pa_can_change_mode_class): Accept mode changes from
1493 DImode to SImode in floating-point registers on 64-bit target.
1494 * config/pa/pa.md (umulsidi3): Change nonimmediate_operand to
1495 register_operand in xmpyu patterns.
1496
1497 2019-05-24 Jakub Jelinek <jakub@redhat.com>
1498
1499 * tree-core.h (enum omp_clause_code): Add OMP_CLAUSE__CONDTEMP_.
1500 * tree.h (OMP_CLAUSE_DECL): Use OMP_CLAUSE__CONDTEMP_ instead of
1501 OMP_CLAUSE__REDUCTEMP_.
1502 * tree.c (omp_clause_num_ops, omp_clause_code_name): Add
1503 OMP_CLAUSE__CONDTEMP_.
1504 (walk_tree_1): Handle OMP_CLAUSE__CONDTEMP_.
1505 * tree-pretty-print.c (dump_omp_clause): Likewise.
1506 * tree-nested.c (convert_nonlocal_omp_clauses,
1507 convert_local_omp_clauses): Likewise.
1508 * gimplify.c (enum gimplify_omp_var_data): Use hexadecimal constants
1509 instead of decimal. Add GOVD_LASTPRIVATE_CONDITIONAL.
1510 (gimplify_scan_omp_clauses): Don't reject lastprivate conditional
1511 on OMP_FOR.
1512 (gimplify_omp_for): Warn and disable conditional modifier from
1513 lastprivate on loop iterators.
1514 * omp-general.h (struct omp_for_data): Add lastprivate_conditional
1515 member.
1516 * omp-general.c (omp_extract_for_data): Initialize it.
1517 * omp-low.c (struct omp_context): Add lastprivate_conditional_map
1518 member.
1519 (delete_omp_context): Delete it.
1520 (lower_lastprivate_conditional_clauses): New function.
1521 (lower_lastprivate_clauses): Add BODY_P and CSTMT_LIST arguments,
1522 handle lastprivate conditional clauses.
1523 (lower_reduction_clauses): Add CLIST argument, emit it into
1524 the critical section if any.
1525 (lower_omp_sections): Adjust lower_lastprivate_clauses and
1526 lower_reduction_clauses callers.
1527 (lower_omp_for_lastprivate): Add CLIST argument, pass it through
1528 to lower_lastprivate_clauses.
1529 (lower_omp_for): Call lower_lastprivate_conditional_clauses, adjust
1530 lower_omp_for_lastprivate and lower_reduction_clauses callers, emit
1531 clist into a critical section if not emitted there already by
1532 lower_reduction_clauses.
1533 (lower_omp_taskreg, lower_omp_teams): Adjust lower_reduction_clauses
1534 callers.
1535 (lower_omp_1): Handle GIMPLE_ASSIGNs storing into lastprivate
1536 conditional variables.
1537 * omp-expand.c (determine_parallel_type): Punt if OMP_CLAUSE__CONDTEMP_
1538 clause is present.
1539 (expand_omp_for_generic, expand_omp_for_static_nochunk,
1540 expand_omp_for_static_chunk): Handle lastprivate conditional.
1541 (expand_omp_for): Handle fd.lastprivate_conditional like
1542 fd.have_reductemp.
1543
1544 2019-05-24 Andrew Stubbs <ams@codesourcery.com>
1545
1546 * config/gcn/gcn-run.c (main): Set a non-zero return value if the
1547 kernel does not exit cleanly.
1548 * config/gcn/gcn.md (gcn_return): Insert s_waitcnt before s_dcache_wb.
1549
1550 2019-05-24 Jason Merrill <jason@redhat.com>
1551
1552 Revert:
1553 * gimplify.c (gimplify_cond_expr): Don't check TREE_ADDRESSABLE.
1554
1555 2019-05-24 Richard Biener <rguenther@suse.de>
1556
1557 PR testsuite/90607
1558 * tree-loop-distribution.c (struct partition): Add location
1559 member.
1560 (partition_alloc): Initialize all fields.
1561 (generate_memset_builtin): Use the location recorded in the
1562 partition for the generated call.
1563 (generate_memcpy_builtin): Likewise.
1564 (classify_partition): Record the location of a single store
1565 as location for the partition.
1566
1567 2019-05-24 Andrew Stubbs <ams@codesourcery.com>
1568
1569 * config/gcn/gcn.c (gcn_expand_prologue): Use gen_addsi3_scalar_carry
1570 for lo-part.
1571
1572 2019-05-24 Matthew Malcomson <matthew.malcomson@arm.com>
1573
1574 PR target/90588
1575 * common/config/aarch64/aarch64-common.c
1576 (aarch64_rewrite_selected_cpu): Change local temporary variable
1577 type from unsigned long to uint64_t.
1578 * config/aarch64/aarch64-protos.h (aarch64_parse_extension,
1579 aarch64_get_extension_string_for_isa_flags): Change declaration to
1580 match new definition by replacing unsigned long with uint64_t.
1581
1582 2019-05-24 Jakub Jelinek <jakub@redhat.com>
1583
1584 PR target/90568
1585 * config/i386/x86-tune-sched.c (ix86_macro_funsion_pair_p): Call
1586 gen_attr_type just once instead of 4-7 times. Formatting fixes.
1587 Handle stack_protect_test_<mode> codegen similarly to corresponding
1588 sub instruction.
1589
1590 2019-05-23 Iain Sandoe <iain@sandoe.co.uk>
1591
1592 * config/i386/darwin.h: Reject -mfentry*.
1593 * doc/sourcebuild.texi: Document mfentry target support.
1594
1595 2019-05-23 Bill Schmidt <wschmidt@linux.ibm.com>
1596
1597 * config/rs6000/rs6000.c (rs6000_global_entry_point_needed_p):
1598 Rename to rs6000_global_entry_point_prologue_needed_p. Return
1599 false for PC-relative functions.
1600 (rs6000_output_function_prologue): Change called function name to
1601 rs6000_global_entry_point_prologue_needed_p. Emit ".localentry
1602 name,1" for PC-relative functions.
1603 (rs6000_elf_declare_function_name): Change called function name to
1604 rs6000_global_entry_point_prologue_needed_p.
1605
1606 2019-05-23 Uroš Bizjak <ubizjak@gmail.com>
1607
1608 PR target/90552
1609 * config/i386/i386.c (gen_rtx_cost):
1610 Use ix86_tune_cost instead of ix86_cost.
1611
1612 2019-05-23 Bill Schmidt <wschmidt@linux.ibm.com>
1613 Michael Meissner <meissner@linux.ibm.com>
1614 Segher Boessenkool <segher@kernel.crashing.org>
1615
1616 * config/rs6000/rs6000-cpus.def (ISA_FUTURE_MASKS_SERVER): Add
1617 OPTION_MASK_PCREL.
1618 (POWERPC_MASKS): Add OPTION_MASK_PCREL.
1619 * config/rs6000/rs6000-protos.h (rs6000_pcrel_p): New prototype.
1620 (rs6000_fndecl_pcrel_p): Likewise.
1621 * config/rs6000/rs6000.c (rs6000_option_override_internal): Report
1622 error if -mpcrel is requested without -mcpu=future.
1623 (rs6000_opt_masks): Add entry for pcrel.
1624 (rs6000_fndecl_pcrel_p): New function.
1625 (rs6000_pcrel_p): Likewise.
1626 * config/rs6000/rs6000.opt (mpcrel): New option.
1627 * doc/invoke.texi: Document -mpcrel and -mno-pcrel.
1628
1629 2019-05-23 Jan Hubicka <jh@suse.cz>
1630 Martin Liska <mliska@suse.cz>
1631
1632 PR tree-optimization/90576
1633 * tree-ssa-alias.c (compare_sizes): Remove dead calls to
1634 poly_int_tree_p.
1635 (aliasing_component_refs_p): Fix three way size compare conditional;
1636 give up earlier in case we can not decide on equivalence.
1637
1638 2019-05-23 Bill Schmidt <wschmidt@linux.ibm.com>
1639 Michael Meissner <meissner@linux.ibm.com>
1640 Segher Boessenkool <segher@kernel.crashing.org>
1641
1642 * config.gcc: Add future cpu.
1643 * config/rs6000/driver-rs6000.c (asm_names): Add future cpu.
1644 * config/rs6000/rs6000-cpus.def (ISA_FUTURE_MASKS_SERVER): New
1645 #define.
1646 (POWERPC_MASKS): Add OPTION_MASK_FUTURE.
1647 (RS6000_CPU): New instantiation for future cpu.
1648 * config/rs6000/rs6000-opts.h (enum processor_type): Add
1649 PROCESSOR_FUTURE.
1650 * config/rs6000/rs6000-string.c (expand_compare_loop): Treat
1651 PROCESSOR_FUTURE like PROCESSOR_POWER9 for now.
1652 * config/rs6000/rs6000-tables.opt: Regenerate.
1653 * config/rs6000/rs6000.c (rs6000_option_override_internal): Treat
1654 PROCESSOR_FUTURE similarly to PROCESSOR_POWER9 for now.
1655 (rs6000_machine_from_flags): Handle future cpu.
1656 (rs6000_reassociation_width): Treat PROCESSOR_FUTURE like
1657 PROCESSOR_POWER9 for now.
1658 (rs6000_adjust_cost): Likewise.
1659 (rs6000_issue_rate): Likewise.
1660 (rs6000_register_move_cost): Likewise.
1661 (rs6000_opt_masks): Add entry for future.
1662 * config/rs6000/rs6000.h (ASM_CPU_SPEC): Add future cpu.
1663 (MASK_FUTURE): New #define.
1664 * config/rs6000/rs6000.md (define_attr "cpu"): Add future cpu.
1665 * config/rs6000/rs6000.opt (mfuture): New target option.
1666 * doc/invoke.texi (mcpu): Add future cpu.
1667
1668 2019-05-23 Martin Liska <mliska@suse.cz>
1669
1670 PR c++/90587
1671 * tree-ssa-uninit.c (value_sat_pred_p): The result of &
1672 operation points to a temporary (pointed via tree_to_wide_ref)
1673 that is out of scope after the &.
1674
1675 2019-05-23 Jonathan Wakely <jwakely@redhat.com>
1676
1677 PR c++/90592
1678 * doc/extend.texi (Function Names): Add missing word.
1679
1680 2019-05-23 Richard Biener <rguenther@suse.de>
1681
1682 PR tree-optimization/88440
1683 * opts.c (default_options_table): Enable -ftree-loop-distribute-patterns
1684 at -O[2s]+.
1685 * tree-loop-distribution.c (generate_memset_builtin): Fold the
1686 generated call.
1687 (generate_memcpy_builtin): Likewise.
1688 (distribute_loop): Pass in whether to only distribute patterns.
1689 (prepare_perfect_loop_nest): Also allow size optimization.
1690 (pass_loop_distribution::execute): When optimizing a loop
1691 nest for size allow pattern replacement.
1692
1693 2019-05-23 Jakub Jelinek <jakub@redhat.com>
1694
1695 PR target/90568
1696 * config/i386/i386.md (stack_protect_test_<mode>): Use sub instead
1697 of xor.
1698
1699 2019-05-23 Martin Liska <mliska@suse.cz>
1700
1701 PR sanitizer/90570
1702 * gimplify.c (gimplify_target_expr): Skip TREE_STATIC target
1703 expression similarly to gimplify_decl_expr.
1704
1705 2019-05-23 Prathamesh Kulkarni <prathamesh.kulkarni@linaro.org>
1706
1707 * cse.c (cse_dump_path): s/dump_file/f.
1708
1709 2019-05-22 David Malcolm <dmalcolm@redhat.com>
1710
1711 PR c++/90462
1712 * diagnostic-format-json.cc: Include "selftest.h".
1713 (json_from_expanded_location): Only add "file" key for non-NULL
1714 file strings.
1715 (json_from_location_range): Don't add "start" and "finish"
1716 children if they are UNKNOWN_LOCATION.
1717 (selftest::test_unknown_location): New selftest.
1718 (selftest::test_bad_endpoints): New selftest.
1719 (selftest::diagnostic_format_json_cc_tests): New function.
1720 * json.cc (json::object::get): New function.
1721 (selftest::test_object_get): New selftest.
1722 (selftest::json_cc_tests): Call it.
1723 * json.h (json::object::get): New decl.
1724 * selftest-run-tests.c (selftest::run_tests): Call
1725 selftest::diagnostic_format_json_cc_tests.
1726 * selftest.h (selftest::diagnostic_format_json_cc_tests): New
1727 decl.
1728
1729 2019-05-22 Kwok Cheung Yeung <kcy@codesourcery.com>
1730 Andrew Stubbs <amd@codesourcery.com>
1731
1732 * config.gcc (gcc_cv_initfini_array): Set for AMD GCN.
1733 * config/gcn/gcn-run.c (init_array_kernel, fini_array_kernel): New.
1734 (kernel): Rename to...
1735 (main_kernel): ... this.
1736 (load_image): Load _init_array and _fini_array kernels.
1737 (run): Add argument for kernel to run.
1738 (main): Run init_array_kernel before main_kernel, and
1739 fini_array_kernel after.
1740 * config/gcn/gcn.c (gcn_handle_amdgpu_hsa_kernel_attribute): Allow
1741 amdgpu_hsa_kernel attribute on functions.
1742 (gcn_disable_constructors): Delete.
1743 (TARGET_ASM_CONSTRUCTOR, TARGET_ASM_DESTRUCTOR): Delete.
1744 * config/gcn/crt0.c (size_t): Define.
1745 (_init_array, _fini_array): New.
1746 (__preinit_array_start, __preinit_array_end,
1747 __init_array_start, __init_array_end,
1748 __fini_array_start, __fini_array_end): Declare weak references.
1749
1750 2019-05-22 Andrew Stubbs <ams@codesourcery.com>
1751
1752 * config/gcn/gcn.c (gcn_trampoline_init): Call "sorry" on GCN5.
1753
1754 2019-05-22 Jason Merrill <jason@redhat.com>
1755
1756 * gimplify.c (gimplify_cond_expr): Don't check TREE_ADDRESSABLE.
1757
1758 2019-05-22 H.J. Lu <hongjiu.lu@intel.com>
1759
1760 PR target/88483
1761 * config/i386/i386-options.c (ix86_init_machine_status): Set
1762 stack_frame_required to true.
1763 * config/i386/i386.c (ix86_get_frame_size): New function.
1764 (ix86_frame_pointer_required): Replace get_frame_size with
1765 ix86_get_frame_size.
1766 (ix86_compute_frame_layout): Likewise.
1767 (ix86_find_max_used_stack_alignment): Changed to void. Set
1768 stack_frame_required.
1769 (ix86_finalize_stack_frame_flags): Always call
1770 ix86_find_max_used_stack_alignment. Replace get_frame_size with
1771 ix86_get_frame_size.
1772 * config/i386/i386.h (machine_function): Add stack_frame_required.
1773
1774 2019-05-22 Uroš Bizjak <ubizjak@gmail.com>
1775
1776 * config/i386/sse.md (sse_cvtpi2ps): Use TARGET_MMX in insn condition.
1777
1778 2019-05-22 Matthew Malcomson <matthew.malcomson@arm.com>
1779
1780 * common/config/aarch64/aarch64-common.c
1781 (struct aarch64_option_extension, struct processor_name_to_arch,
1782 struct arch_to_arch_name, aarch64_parse_extension, opt_ext_cmp,
1783 aarch64_contains_opt,
1784 aarch64_get_extension_string_for_isa_flags): Change type of
1785 variables storing flags to uint64_t.
1786 * config/aarch64/aarch64-option-extensions.def (sve2, sve2-sm4,
1787 sve2-aes, sve2-sha3, bitperm): New optional SVE2 extension flags.
1788 * config/aarch64/aarch64.c (struct processor,
1789 aarch64_parse_arch, aarch64_parse_cpu, aarch64_validate_mcpu,
1790 aarch64_validate_march, aarch64_override_options,
1791 aarch64_option_print, aarch64_handle_attr_isa_flags,
1792 aarch64_declare_function_name, aarch64_start_file): Make flag
1793 variables uint64_t.
1794 * config/aarch64/aarch64.h (AARCH64_FL_SVE2, AARCH64_FL_SVE2_AES,
1795 AARCH64_FL_SVE2_SM4, AARCH64_FL_SVE2_SHA3,
1796 AARCH64_FL_SVE2_BITPERM): New macro feature flags.
1797 * config/aarch64/aarch64.opt (aarch64_isa_flags): Make uint64_t.
1798 * config/aarch64/driver-aarch64.c
1799 (struct aarch64_arch_extension, struct aarch64_core_data,
1800 struct aarch64_arch_driver_info, host_detect_local_cpu): Make
1801 flag variables uint64_t.
1802 * doc/invoke.texi: Add documentation for new arguments.
1803
1804 2019-05-22 Richard Biener <rguenther@suse.de>
1805
1806 * alias.c (ao_ref_from_mem): Move stack-slot sharing
1807 rewrite ...
1808 * emit-rtl.c (set_mem_attributes_minus_bitpos): ... here.
1809
1810 2019-05-22 Martin Liska <mliska@suse.cz>
1811
1812 PR lto/90500
1813 * doc/extend.texi: Document the change.
1814
1815 2019-05-22 Richard Biener <rguenther@suse.de>
1816
1817 PR tree-optimization/90450
1818 * tree-ssa-loop-im.c (struct im_mem_ref): Add ref_decomposed.
1819 (mem_ref_hasher::equal): Check it.
1820 (mem_ref_alloc): Initialize it.
1821 (gather_mem_refs_stmt): Set it.
1822
1823 2019-05-22 Richard Biener <rguenther@suse.de>
1824
1825 * gimple-fold.c (arith_code_with_undefined_signed_overflow):
1826 Add ABS_EXPR.
1827 (rewrite_to_defined_overflow): Handle rewriting ABS_EXPR
1828 as ABSU_EXPR.
1829
1830 2019-05-22 Alan Modra <amodra@gmail.com>
1831
1832 * config/rs6000/rs6000.h (ASM_OPT_ANY): Define.
1833 (ASM_CPU_SPEC): Conditionally add -many.
1834 * config/rs6000/rs6000.c (rs6000_machine): New static var.
1835 (rs6000_machine_from_flags, emit_asm_machine): New functions..
1836 (rs6000_file_start): ..extracted from here, and modified to
1837 test all ISA bits.
1838 (rs6000_output_function_prologue): Emit .machine as necessary.
1839 * testsuite/gcc.target/powerpc/ppc32-abi-dfp-1.c: Don't use
1840 power mnemonics.
1841 * testsuite/gcc.dg/vect/O3-pr70130.c: Disable default options
1842 added by check_vect_support_and_set_flags.
1843 * testsuite/gcc.dg/vect/pr48765.c: Likewise.
1844 * testsuite/gfortran.dg/vect/pr45714-b.f: Likewise.
1845
1846 2019-05-22 Hans-Peter Nilsson <hp@axis.com>
1847
1848 PR middle-end/90553
1849 * ira-lives.c (process_bb_node_lives): Consider defs
1850 for a call insn to be die before the call, not after.
1851
1852 * function.c (assign_parm_setup_block): Raise alignment of
1853 stacked parameter only for STRICT_ALIGNMENT targets.
1854
1855 2019-05-21 Segher Boessenkool <segher@kernel.crashing.org>
1856
1857 * config/rs6000/constraints.md (define_register_constraint "wz"):
1858 Delete.
1859 * config/rs6000/rs6000.h (enum r6000_reg_class_enum): Delete
1860 RS6000_CONSTRAINT_wz.
1861 * config/rs6000/rs6000.c (rs6000_debug_reg_global): Adjust.
1862 (rs6000_init_hard_regno_mode_ok): Adjust.
1863 * config/rs6000/rs6000.md: Replace "wz" constraint by "d" with "p7".
1864 * doc/md.texi (Machine Constraints): Adjust.
1865
1866 2019-05-21 Segher Boessenkool <segher@kernel.crashing.org>
1867
1868 * config/rs6000/constraints.md (define_register_constraint "wl"):
1869 Delete.
1870 * config/rs6000/rs6000.h (enum r6000_reg_class_enum): Delete
1871 RS6000_CONSTRAINT_wl.
1872 * config/rs6000/rs6000.c (rs6000_debug_reg_global): Adjust.
1873 (rs6000_init_hard_regno_mode_ok): Adjust.
1874 * config/rs6000/rs6000.md: Replace "wl" constraint by "d" with "p6".
1875 * doc/md.texi (Machine Constraints): Adjust.
1876
1877 2019-05-21 Segher Boessenkool <segher@kernel.crashing.org>
1878
1879 * config/rs6000/constraints.md (define_register_constraint "wm"):
1880 Delete.
1881 * config/rs6000/rs6000.h (enum r6000_reg_class_enum): Delete
1882 RS6000_CONSTRAINT_wm.
1883 * config/rs6000/rs6000.c (rs6000_debug_reg_global): Adjust.
1884 (rs6000_init_hard_regno_mode_ok): Adjust.
1885 * config/rs6000/vsx.md: Replace "wm" constraint by "wa" with "p8v".
1886 * doc/md.texi (Machine Constraints): Adjust.
1887
1888 2019-05-21 Segher Boessenkool <segher@kernel.crashing.org>
1889
1890 * config/rs6000/constraints.md (define_register_constraint "wk"):
1891 Delete.
1892 * config/rs6000/rs6000.h (enum r6000_reg_class_enum): Delete
1893 RS6000_CONSTRAINT_wk.
1894 * config/rs6000/rs6000.c (rs6000_debug_reg_global): Adjust.
1895 (rs6000_init_hard_regno_mode_ok): Adjust.
1896 * config/rs6000/rs6000.md: Replace "wk" constraint by "ws" with "p8v".
1897 * doc/md.texi (Machine Constraints): Adjust.
1898
1899 2019-05-21 Segher Boessenkool <segher@kernel.crashing.org>
1900
1901 * config/rs6000/constraints.md (define_register_constraint "wj"):
1902 Delete.
1903 * config/rs6000/rs6000.h (enum r6000_reg_class_enum): Delete
1904 RS6000_CONSTRAINT_wj.
1905 * config/rs6000/rs6000.c (rs6000_debug_reg_global): Adjust.
1906 (rs6000_init_hard_regno_mode_ok): Adjust.
1907 * config/rs6000/rs6000.md: Replace "wj" constraint by "wi" with "p8v".
1908 (VS_64dm): Delete.
1909 * config/rs6000/vsx.md: Ditto.
1910 * doc/md.texi (Machine Constraints): Adjust.
1911
1912 2019-05-21 Segher Boessenkool <segher@kernel.crashing.org>
1913
1914 * config/rs6000/constraints.md (define_register_constraint "wh"):
1915 Delete.
1916 * config/rs6000/rs6000.h (enum r6000_reg_class_enum): Delete
1917 RS6000_CONSTRAINT_wh.
1918 * config/rs6000/rs6000.c (rs6000_debug_reg_global): Adjust.
1919 (rs6000_init_hard_regno_mode_ok): Adjust.
1920 * config/rs6000/rs6000.md: Replace "wh" constraint by "wa" with "p8v".
1921 * doc/md.texi (Machine Constraints): Adjust.
1922
1923 2019-05-21 Uroš Bizjak <ubizjak@gmail.com>
1924
1925 PR target/90547
1926 * config/i386/i386.md (anddi_1 to andsi_1_zext splitter):
1927 Avoid calling gen_lowpart with CONST operand.
1928
1929 2019-05-21 Alexandre Oliva <aoliva@redhat.com>
1930
1931 * tree-ssa-threadupdate.c (struct ssa_local_info_t): Add
1932 field template_last_to_copy.
1933 (ssa_create_duplicates): Set it, and use it. Attempt to
1934 preserve more debug stmts.
1935
1936 2019-05-21 Uroš Bizjak <ubizjak@gmail.com>
1937
1938 * config/i386/sse.md (VF1_AVX2): New mode iterator.
1939 (signbit<mode>2): New expander
1940
1941 2019-05-21 James Clarke <jrtc27@jrtc27.com>
1942
1943 PR bootstrap/87338
1944 * dwarf2out.c (dwarf2out_inline_entry): Use ASM_OUTPUT_DEBUG_LABEL
1945 instead of ASM_GENERATE_INTERNAL_LABEL and ASM_OUTPUT_LABEL.
1946
1947 2019-05-21 Uroš Bizjak <ubizjak@gmail.com>
1948
1949 * config/i386/cpuid.h (__cpuid): For 32bit targets, zero
1950 %ebx and %ecx bafore calling cpuid with leaf 1 or
1951 non-constant leaf argument.
1952
1953 2019-05-21 Alan Modra <amodra@gmail.com>
1954
1955 PR target/90545
1956 * config/rs6000/rs6000.c (rs6000_register_move_cost): Increase
1957 power9 direct move cost.
1958 * testsuite/gcc.target/powerpc/fold-vec-splats-floatdouble.c:
1959 Correct comments and rename functions to suit parameters.
1960
1961 2019-05-21 Richard Biener <rguenther@suse.de>
1962
1963 PR middle-end/90510
1964 * fold-const.c (fold_read_from_vector): New function.
1965 * fold-const.h (fold_read_from_vector): Declare.
1966 * match.pd (VEC_PERM_EXPR): Build BIT_INSERT_EXPRs for
1967 single-element insert permutations. Canonicalize selector
1968 further and fix issue with last commit.
1969
1970 2019-05-21 Vladislav Ivanishin <vlad@ispras.ru>
1971
1972 * tree-cfg.h (split_critical_edges): Add for_edge_insertion_p
1973 parameter with default value false to declaration.
1974 (split_edges_for_insertion): New inline function. Wrapper for
1975 split_critical_edges with for_edge_insertion_p = true.
1976 * tree-cfg.c (split_critical_edges): Don't split non-critical
1977 edges if for_edge_insertion_p is false. Fix whitespace.
1978 * tree-ssa-pre.c (pass_pre::execute): Call
1979 split_edges_for_insertion instead of split_critical_edges.
1980 * gcc/tree-ssa-tail-merge.c (tail_merge_optimize): Ditto.
1981 * gcc/tree-ssa-sink.c (pass_sink_code::execute): Ditto.
1982 (pass_data_sink_code): Update function name in the comment.
1983
1984 2019-05-21 Vladislav Ivanishin <vlad@ispras.ru>
1985
1986 * tree-ssa-uninit.c (value_sat_pred_p): This new function is a wrapper
1987 around is_value_included_in that knows how to handle BIT_AND_EXPR.
1988 (is_pred_expr_subset_of): Use the new function. Handle more cases where
1989 code1 == EQ_EXPR and where code1 == BIT_AND_EXPR and thus fix some false
1990 positives.
1991
1992 2019-05-21 Martin Liska <mliska@suse.cz>
1993
1994 * config/rs6000/driver-rs6000.c (elf_platform): Do not use
1995 an extra newline.
1996 * config/rs6000/rs6000-c.c (rs6000_pragma_longcal): Wrap pragma in %<%>.
1997 (altivec_resolve_overloaded_builtin): Likewise for vec_lvsl and
1998 vec_lvsr.
1999 * config/rs6000/rs6000.c (rs6000_option_override_internal):
2000 Quote a C type.
2001 (rs6000_function_arg): Likewise.
2002 (rs6000_expand_set_fpscr_drn_builtin): Remove trailing dot.
2003 (rs6000_expand_ternop_builtin): Use interval syntax.
2004 (get_element_number): Likewise.
2005 (altivec_expand_builtin): Likewise.
2006 (rs6000_get_function_versions_dispatcher): Quote target_clones.
2007
2008 Fix test-suite.
2009
2010 2019-05-20 Jakub Jelinek <jakub@redhat.com>
2011
2012 PR c++/59813
2013 PR target/90418
2014 * function.h (struct function): Add calls_eh_return member.
2015 * gimplify.c (gimplify_call_expr): Set cfun->calls_eh_return when
2016 gimplifying __builtin_eh_return call.
2017 * tree-inline.c (initialize_cfun): Copy calls_eh_return from src_cfun
2018 to cfun.
2019 (expand_call_inline): Or in src_cfun->calls_eh_return into
2020 dst_cfun->calls_eh_return.
2021 * tree-tailcall.c (suitable_for_tail_call_opt_p): Return false if
2022 cfun->calls_eh_return.
2023 * lto-streamer-in.c (input_struct_function_base): Read calls_eh_return.
2024 * lto-streamer-out.c (output_struct_function_base): Write
2025 calls_eh_return.
2026
2027 2019-05-20 Marc Glisse <marc.glisse@inria.fr>
2028
2029 PR rtl-optimization/43147
2030 * config/i386/i386.c (ix86_gimple_fold_builtin): Handle
2031 IX86_BUILTIN_SHUFPD.
2032
2033 2019-05-20 Jan Hubicka <hubicka@ucw.cz>
2034
2035 * tree-ssa-alias.c (refs_may_alias_p_2): Break out from ...
2036 (refs_may_alias_p_1): ... here; update stats.
2037 (refs_may_alias_p): Do not update stats here.
2038
2039 2019-05-20 Richard Biener <rguenther@suse.de>
2040
2041 * tree-ssa-structalias.c (find_func_aliases): POINTER_DIFF_EXPR
2042 doesn't produce pointers.
2043 {TRUNC,CEIL,FLOOR,ROUND,EXACT}_{DIV,MOD}_EXPR points to what
2044 the first operand points to.
2045
2046 2019-05-20 Jan Hubicka <hubicka@ucw.cz>
2047
2048 * tree-ssa-alias.c (compare_sizes): New function.
2049 (sompare_type_sizes): New function
2050 (aliasing_component_refs_p): Use it.
2051 (indirect_ref_may_alias_decl_p): Likewise.
2052
2053 2019-05-20 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
2054
2055 * config/i386/sol2.h (CC1_SPEC): Reject -mx32.
2056
2057 2019-05-20 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
2058
2059 * config/sol2.h (LIBTSAN_EARLY_SPEC): Remove : after %e.
2060 (LIBLSAN_EARLY_SPEC): Likewise.
2061 * config/i386/sol2.h (ASAN_REJECT_SPEC): Likewise.
2062
2063 2019-05-20 Martin Liska <mliska@suse.cz>
2064
2065 * config/i386/i386.c (ix86_libc_has_fast_function):
2066 Add ATTRIBUTE_UNUSED for the argument.
2067
2068 2019-05-20 Richard Biener <rguenther@suse.de>
2069
2070 * gimple-match-head.c: Include vec-perm-indices.h.
2071 * generic-match-head.c: Likewise.
2072 * fold-const.h (fold_vec_perm): Declare when vec-perm-indices.h
2073 is included.
2074 * fold-const.c (fold_vec_perm): Export.
2075 (fold_ternary_loc): Move non-constant folding of VEC_PERM_EXPR...
2076 (match.pd): ...here.
2077
2078 2019-05-20 Jakub Jelinek <jakub@redhat.com>
2079
2080 * cfgloop.h (struct loop): Add simdlen member.
2081 * cfgloopmanip.c (copy_loop_info): Copy simdlen as well.
2082 * omp-expand.c (expand_omp_simd): Set it if simdlen clause is present.
2083 * tree-vect-loop.c (vect_analyze_loop): Pass loop->simdlen != 0
2084 as new argument to autovectorize_vector_sizes target hook. If
2085 loop->simdlen, pick up vector size where the vectorization factor
2086 is equal to loop->simd, and if there is none, fall back to the first
2087 successful one.
2088 (vect_transform_loop): Adjust autovectorize_vector_sizes target hook
2089 caller.
2090 * omp-low.c (omp_clause_aligned_alignment): Likewise.
2091 * omp-general.c (omp_max_vf): Likewise.
2092 * optabs-query.c (can_vec_mask_load_store_p): Likewise.
2093 * tree-vect-slp.c (vect_slp_bb): Likewise.
2094 * target.def (autovectorize_vector_sizes): Add ALL argument and
2095 document it.
2096 * doc/tm.texi: Adjust documentation.
2097 * targhooks.c (default_autovectorize_vector_sizes): Add bool argument.
2098 * targhooks.h (default_autovectorize_vector_sizes): Likewise.
2099 * config/aarch64/aarch64.c (aarch64_autovectorize_vector_sizes): Add
2100 bool argument.
2101 * config/arc/arc.c (arc_autovectorize_vector_sizes): Likewise.
2102 * config/arm/arm.c (arm_autovectorize_vector_sizes): Likewise.
2103 * config/mips/mips.c (mips_autovectorize_vector_sizes): Likewise.
2104 * config/i386/i386.c (ix86_autovectorize_vector_sizes): Likewise. If
2105 true and TARGET_AVX512F or TARGET_AVX, push 3 or 2 sizes even if
2106 preferred vector size is not 512-bit or 256-bit, just put those
2107 unpreferred ones last.
2108
2109 2019-05-20 Martin Liska <mliska@suse.cz>
2110
2111 * targhooks.c (default_libc_has_fast_function): New function.
2112 * targhooks.h (default_libc_has_fast_function): Likewise.
2113
2114 2019-05-20 Martin Liska <mliska@suse.cz>
2115
2116 PR middle-end/90263
2117 * builtins.c (expand_builtin_memory_copy_args): When having a
2118 target with fast mempcpy implementation do now use memcpy.
2119 * config/i386/i386.c (ix86_libc_has_fast_function): New.
2120 (TARGET_LIBC_HAS_FAST_FUNCTION): Likewise.
2121 * doc/tm.texi: Likewise.
2122 * doc/tm.texi.in: Likewise.
2123 * target.def:
2124 * expr.c (emit_block_move_hints): Add 2 new arguments.
2125 * expr.h (emit_block_move_hints): Bail out when libcall
2126 to memcpy would be used.
2127
2128 2019-05-20 Martin Liska <mliska@suse.cz>
2129
2130 * profile-count.c: Add vertical spacing in order
2131 to separate functions.
2132 * profile-count.h: Likewise.
2133
2134 2019-05-20 Martin Liska <mliska@suse.cz>
2135
2136 * profile-count.h: Do not use full qualified
2137 names if possible.
2138 * profile-count.c (profile_count::to_frequency): Likewise.
2139
2140 2019-05-20 Martin Liska <mliska@suse.cz>
2141
2142 * profile-count.h (enum profile_quality): Use capital letters
2143 for enum value names. Use the adjusted names.
2144 * profile-count.c: Use the adjusted names.
2145
2146 2019-05-19 Segher Boessenkool <segher@kernel.crashing.org>
2147
2148 * config/rs6000/constraints.md (define_register_constraint "wH"):
2149 Delete.
2150 (define_register_constraint "wI"): Delete.
2151 * config/rs6000/rs6000.h (enum r6000_reg_class_enum): Delete
2152 RS6000_CONSTRAINT_wH and RS6000_CONSTRAINT_wI.
2153 * config/rs6000/rs6000.c (rs6000_debug_reg_global): Adjust.
2154 (rs6000_init_hard_regno_mode_ok): Adjust.
2155 * config/rs6000/rs6000.md: Replace "wH" and "wI" constraints by "v"
2156 resp. "d", or with "wa" as appropriate, all with "p8v".
2157 * config/rs6000/vsx.md: Ditto.
2158 * doc/md.texi (Machine Constraints): Adjust.
2159
2160 2019-05-19 Segher Boessenkool <segher@kernel.crashing.org>
2161
2162 * config/rs6000/constraints.md (define_register_constraint "wy"):
2163 Delete.
2164 * config/rs6000/rs6000.h (enum r6000_reg_class_enum): Delete
2165 RS6000_CONSTRAINT_wy.
2166 * config/rs6000/rs6000.c (rs6000_debug_reg_global): Adjust.
2167 (rs6000_init_hard_regno_mode_ok): Adjust.
2168 * config/rs6000/rs6000.md: Replace "wy" constraint by "wa" with "p8v".
2169 Use "<Fisa>" as "isa" in all alternatives that use "<Fv2>".
2170 (define_mode_attr Fisa): New.
2171 * config/rs6000/vsx.md: Replace "wy" constraint by "wa" with "p8v".
2172 * doc/md.texi (Machine Constraints): Adjust.
2173
2174 2019-05-19 Segher Boessenkool <segher@kernel.crashing.org>
2175
2176 * config/rs6000/constraints.md (define_register_constraint "wu"):
2177 Delete.
2178 * config/rs6000/rs6000.h (enum r6000_reg_class_enum): Delete
2179 RS6000_CONSTRAINT_wu.
2180 * config/rs6000/rs6000.c (rs6000_debug_reg_global): Adjust.
2181 (rs6000_init_hard_regno_mode_ok): Adjust.
2182 * config/rs6000/rs6000.md: Replace "wu" constraint by "v" or "wa",
2183 both with "p8v".
2184 (define_mode_attr Fa): Delete.
2185 * config/rs6000/vsx.md: Ditto.
2186 * doc/md.texi (Machine Constraints): Adjust.
2187
2188 2019-05-19 Segher Boessenkool <segher@kernel.crashing.org>
2189
2190 * config/rs6000/constraints.md (define_register_constraint "wJ"):
2191 Delete.
2192 (define_register_constraint "wK"): Delete.
2193 * config/rs6000/rs6000.h (enum r6000_reg_class_enum): Delete
2194 RS6000_CONSTRAINT_wJ and RS6000_CONSTRAINT_wK.
2195 * config/rs6000/rs6000.c (rs6000_debug_reg_global): Adjust.
2196 (rs6000_init_hard_regno_mode_ok): Adjust.
2197 * config/rs6000/rs6000.md: Replace "wJ" constraint by "wI" with "p9v".
2198 Replace "wK" constraint by "wH" with "p9v".
2199 * config/rs6000/vsx.md: Ditto.
2200 * doc/md.texi (Machine Constraints): Adjust.
2201
2202 2019-05-19 Segher Boessenkool <segher@kernel.crashing.org>
2203
2204 * config/rs6000/constraints.md (define_register_constraint "wb"):
2205 Delete.
2206 * config/rs6000/rs6000.h (enum r6000_reg_class_enum): Delete
2207 RS6000_CONSTRAINT_wb.
2208 * config/rs6000/rs6000.c (rs6000_debug_reg_global): Adjust.
2209 (rs6000_init_hard_regno_mode_ok): Adjust.
2210 * config/rs6000/rs6000.md: Replace "wb" constraint by "v" with "p9v".
2211 * config/rs6000/vsx.md: Ditto.
2212 * doc/md.texi (Machine Constraints): Adjust.
2213
2214 2019-05-19 Segher Boessenkool <segher@kernel.crashing.org>
2215
2216 * config/rs6000/constraints.md (define_register_constraint "wo"):
2217 Delete.
2218 * config/rs6000/rs6000.h (enum r6000_reg_class_enum): Delete
2219 RS6000_CONSTRAINT_wo.
2220 * config/rs6000/rs6000.c (rs6000_debug_reg_global): Adjust.
2221 (rs6000_init_hard_regno_mode_ok): Adjust.
2222 * config/rs6000/rs6000.md: Replace "wo" constraint by "wa" with "p9v".
2223 * config/rs6000/altivec.md: Ditto.
2224 * doc/md.texi (Machine Constraints): Adjust.
2225
2226 2019-05-18 Iain Sandoe <iain@sandoe.co.uk>
2227
2228 * config/darwin-c.c (darwin_register_objc_includes): Do not
2229 prepend the sysroot when building gnu-runtime header search
2230 paths.
2231
2232 2019-05-18 Iain Sandoe <iain@sandoe.co.uk>
2233
2234 * config/darwin.c (darwin_file_end): Use switch_to_section ()
2235 instead of direct output of the asm.
2236
2237 2019-05-17 Segher Boessenkool <segher@kernel.crashing.org>
2238
2239 * config/rs6000/rs6000.c (restore_saved_cr): Change a boolean
2240 argument to be type bool (was int before).
2241 (rs6000_emit_epilogue): Simplify some code. Declare some variables
2242 at first use. Use type bool for some variables. Fix a theoretical
2243 eh_return bug for svr4.
2244
2245 2019-05-17 Segher Boessenkool <segher@kernel.crashing.org>
2246
2247 * config/rs6000/rs6000.md (isa): New attribute.
2248 (enabled): New attribute.
2249
2250 2019-05-17 Max Filippov <jcmvbkbc@gmail.com>
2251
2252 * config/aarch64/aarch64.c (aarch64_output_mi_thunk): Call
2253 assemble_start_function and assemble_end_function.
2254
2255 2019-05-17 Thomas Schwinge <thomas@codesourcery.com>
2256
2257 PR middle-end/89433
2258 * omp-general.c (oacc_verify_routine_clauses): Change formal
2259 parameters. Add checking if already marked with an OpenACC
2260 'routine' directive. Adjust all users.
2261
2262 PR middle-end/89433
2263 * omp-general.c (oacc_build_routine_dims): Move some of its
2264 processing into...
2265 (oacc_verify_routine_clauses): ... this new function.
2266 * omp-general.h (oacc_verify_routine_clauses): New prototype.
2267
2268 2019-05-17 Iain Sandoe <iain@sandoe.co.uk>
2269
2270 * config/rs6000/rs6000.c (machopic_output_stub): Adjust the
2271 formating of picbase labels to match other ports.
2272
2273 2019-05-17 Iain Sandoe <iain@sandoe.co.uk>
2274
2275 * config/rs6000/rs6000.c (macho_branch_islands): Fix bad indent
2276 in the generated code.
2277
2278 2019-05-16 Martin Sebor <msebor@redhat.com>
2279
2280 * builtins.c (expand_builtin_atomic_always_lock_free): Quote
2281 identifiers, keywords, operators, and types in diagnostics. Correct
2282 quoting, spelling, and sentence capitalization issues.
2283 (expand_builtin_atomic_is_lock_free): Same.
2284 (fold_builtin_next_arg): Same.
2285 * cfgexpand.c (expand_one_var): Same.
2286 (tree_conflicts_with_clobbers_p): Same.
2287 (expand_asm_stmt): Same.
2288 (verify_loop_structure): Same.
2289 * cgraphunit.c (process_function_and_variable_attributes): Same.
2290 * collect-utils.c (collect_execute): Same.
2291 * collect2.c (maybe_run_lto_and_relink): Same.
2292 (is_lto_object_file): Same.
2293 (scan_prog_file): Same.
2294 * convert.c (convert_to_real_1): Same.
2295 * dwarf2out.c (dwarf2out_begin_prologue): Same.
2296 * except.c (verify_eh_tree): Same.
2297 * gcc.c (execute): Same.
2298 (eval_spec_function): Same.
2299 (run_attempt): Same.
2300 (driver::set_up_specs): Same.
2301 (compare_debug_auxbase_opt_spec_function): Same.
2302 * gcov-tool.c (unlink_gcda_file): Same.
2303 (do_merge): Same.
2304 (do_rewrite): Same.
2305 * gcse.c (gcse_or_cprop_is_too_expensive): Same.
2306 * gimplify.c (gimplify_asm_expr): Same.
2307 (gimplify_adjust_omp_clauses): Same.
2308 * hsa-gen.c (gen_hsa_addr_insns): Same.
2309 (gen_hsa_insns_for_load): Same.
2310 (gen_hsa_cmp_insn_from_gimple): Same.
2311 (gen_hsa_insns_for_operation_assignment): Same.
2312 (gen_get_level): Same.
2313 (gen_hsa_alloca): Same.
2314 (omp_simple_builtin::generate): Same.
2315 (gen_hsa_atomic_for_builtin): Same.
2316 (gen_hsa_insns_for_call): Same.
2317 * input.c (dump_location_info): Same.
2318 * ipa-devirt.c (compare_virtual_tables): Same.
2319 * ira.c (ira_setup_eliminable_regset): Same.
2320 * lra-assigns.c (lra_assign): Same.
2321 * lra-constraints.c (lra_constraints): Same.
2322 * lto-streamer-in.c (lto_input_mode_table): Same.
2323 * lto-wrapper.c (get_options_from_collect_gcc_options): Same.
2324 (merge_and_complain): Same.
2325 (compile_offload_image): Same.
2326 (compile_images_for_offload_targets): Same.
2327 (debug_objcopy): Same.
2328 (run_gcc): Same.
2329 (main): Same.
2330 * opts.c (print_specific_help): Same.
2331 (parse_no_sanitize_attribute): Same.
2332 (print_help): Same.
2333 (handle_param): Same.
2334 * plugin.c (add_new_plugin): Same.
2335 (parse_plugin_arg_opt): Same.
2336 (try_init_one_plugin): Same.
2337 * print-rtl.c (debug_bb_n_slim): Quote identifiers, keywords,
2338 operators, and types in diagnostics. Correct quoting and spelling
2339 issues.
2340 * read-rtl-function.c (parse_edge_flag_token): Same.
2341 (function_reader::parse_enum_value): Same.
2342 * reg-stack.c (check_asm_stack_operands): Same.
2343 * regcprop.c (validate_value_data): Same.
2344 * sched-rgn.c (make_pass_sched_fusion): Same.
2345 * stmt.c (check_unique_operand_names): Same.
2346 * targhooks.c (default_target_option_pragma_parse): Same.
2347 * tlink.c (recompile_files): Same.
2348 * toplev.c (process_options): Same.
2349 (do_compile): Same.
2350 * trans-mem.c (diagnose_tm_1): Same.
2351 (ipa_tm_scan_irr_block): Same.
2352 (ipa_tm_diagnose_transaction): Same.
2353 * tree-cfg.c (verify_address): Same. Use get_tree_code_name to
2354 format a tree code name in a diagnostic.
2355 (verify_types_in_gimple_min_lval): Same.
2356 (verify_types_in_gimple_reference): Same.
2357 (verify_gimple_call): Same.
2358 (verify_gimple_assign_unary): Same.
2359 (verify_gimple_assign_binary): Same.
2360 (verify_gimple_assign_ternary): Same.
2361 (verify_gimple_assign_single): Same.
2362 (verify_gimple_switch): Same.
2363 (verify_gimple_label): Same.
2364 (verify_gimple_phi): Same.
2365 (verify_gimple_in_seq): Same.
2366 (verify_eh_throw_stmt_node): Same.
2367 (collect_subblocks): Same.
2368 (gimple_verify_flow_info): Same.
2369 (do_warn_unused_result): Same.
2370 * tree-inline.c (expand_call_inline): Same.
2371 * tree-into-ssa.c (update_ssa): Same.
2372 * tree.c (tree_int_cst_elt_check_failed): Same.
2373 (tree_vec_elt_check_failed): Same.
2374 (omp_clause_operand_check_failed): Same.
2375 (verify_type_variant): Same.
2376 (verify_type): Same.
2377 * value-prof.c (verify_histograms): Same.
2378 * varasm.c (assemble_start_function): Same.
2379
2380 2019-05-16 Martin Sebor <msebor@redhat.com>
2381
2382 * config/i386/i386-expand.c (get_element_number): Quote keywords
2383 and other internal names in diagnostics. Adjust other diagnostic
2384 formatting issues noted by -Wformat-diag.
2385 * config/i386/i386-features.c
2386 (ix86_mangle_function_version_assembler_name): Same.
2387 * config/i386/i386-options.c (ix86_handle_abi_attribute): Same.
2388 * config/i386/i386.c (ix86_function_type_abi): Same.
2389 (ix86_function_ms_hook_prologue): Same.
2390 (classify_argument): Same.
2391 (ix86_expand_prologue): Same.
2392 (ix86_md_asm_adjust): Same.
2393 (ix86_memmodel_check): Same.
2394
2395 2019-05-17 Dragan Mladjenovic <dmladjenovic@wavecomp.com>
2396
2397 * config/mips/mips.c (mips_dwarf_frame_reg_mode): Replace
2398 TARGET_FLOAT64 with !TARGET_FLOAT32, thus handling both fp64
2399 and fpxx modes.
2400
2401 2019-05-17 H.J. Lu <hongjiu.lu@intel.com>
2402
2403 PR target/90497
2404 * config/i386/i386-expand.c (ix86_expand_builtin): Enable MMX
2405 intrinsics without SSE/SSE2/SSSE3.
2406 * config/i386/mmx.md (mmx_uavgv8qi3): Restore TARGET_3DNOW
2407 check.
2408 (*mmx_uavgv8qi3): Likewise.
2409
2410 2019-05-17 Richard Biener <rguenther@suse.de>
2411
2412 * gimple-pretty-print.c (dump_ternary_rhs): Handle dumping
2413 VEC_PERM_EXPR as __VEC_PERM with -gimple.
2414
2415 2019-05-17 Andreas Krebbel <krebbel@linux.ibm.com>
2416
2417 * config/s390/s390-builtins.def (s390_vec_sldw_*): Use the
2418 vec_sldw insn pattern.
2419
2420 2019-05-17 Richard Biener <rguenther@suse.de>
2421
2422 * ccmp.c (expand_ccmp_expr_1): Do not use gimple_assign_rhs_to_tree.
2423
2424 2019-05-17 Martin Liska <mliska@suse.cz>
2425
2426 PR driver/90496
2427 * toplev.c (output_stack_usage): With LTO and sanitizer it
2428 happens that a global ctor (_GLOBAL__sub_I_00099_0_main)
2429 has no file location.
2430
2431 2019-05-16 Jakub Jelinek <jakub@redhat.com>
2432
2433 PR c++/90484
2434 * tree-ssa-scopedtables.c (equal_mem_array_ref_p): Don't assert that
2435 sz0 is equal to sz1, instead return false in that case.
2436
2437 * omp-low.c (lower_rec_input_clauses): If OMP_CLAUSE_IF
2438 has non-constant expression, force sctx.lane and use two
2439 argument IFN_GOMP_SIMD_LANE instead of single argument.
2440 * tree-ssa-dce.c (eliminate_unnecessary_stmts): Don't DCE
2441 two argument IFN_GOMP_SIMD_LANE without lhs.
2442 * tree-vectorizer.h (struct _loop_vec_info): Add simd_if_cond
2443 member.
2444 (LOOP_VINFO_SIMD_IF_COND, LOOP_REQUIRES_VERSIONING_FOR_SIMD_IF_COND):
2445 Define.
2446 (LOOP_REQUIRES_VERSIONING): Or in
2447 LOOP_REQUIRES_VERSIONING_FOR_SIMD_IF_COND.
2448 * tree-vect-loop.c (_loop_vec_info::_loop_vec_info): Initialize
2449 simd_if_cond.
2450 (vect_analyze_loop_2): Punt if LOOP_VINFO_SIMD_IF_COND is constant 0.
2451 * tree-vect-loop-manip.c (vect_loop_versioning): Add runtime check
2452 from simd if clause if needed.
2453
2454 2019-05-16 Richard Biener <rguenther@suse.de>
2455
2456 * tree-affine.c (expr_to_aff_combination): New function split
2457 out from...
2458 (tree_to_aff_combination): ... here.
2459 (aff_combination_expand): Avoid building a GENERIC tree.
2460
2461 2019-05-16 Max Filippov <jcmvbkbc@gmail.com>
2462
2463 * cgraphunit.c (cgraph_node::expand_thunk): Remove
2464 assemble_start_function and assemble_end_function calls.
2465 * config/alpha/alpha.c (alpha_output_mi_thunk_osf): Call
2466 assemble_start_function and assemble_end_function.
2467 * config/arc/arc.c (arc_output_mi_thunk): Likewise.
2468 * config/arm/arm.c (arm_output_mi_thunk): Likewise.
2469 * config/bfin/bfin.c (bfin_output_mi_thunk): Likewise.
2470 * config/c6x/c6x.c (c6x_output_mi_thunk): Likewise.
2471 * config/cris/cris.c (cris_asm_output_mi_thunk): Likewise.
2472 * config/csky/csky.c (csky_output_mi_thunk): Likewise.
2473 * config/epiphany/epiphany.c (epiphany_output_mi_thunk): Likewise.
2474 * config/frv/frv.c (frv_asm_output_mi_thunk): Likewise.
2475 * config/i386/i386.c (x86_output_mi_thunk): Likewise.
2476 * config/ia64/ia64.c (ia64_output_mi_thunk): Likewise.
2477 * config/m68k/m68k.c (m68k_output_mi_thunk): Likewise.
2478 * config/microblaze/microblaze.c (microblaze_asm_output_mi_thunk):
2479 Likewise.
2480 * config/mips/mips.c (mips_output_mi_thunk): Likewise.
2481 * config/mmix/mmix.c (mmix_asm_output_mi_thunk): Likewise.
2482 * config/mn10300/mn10300.c (mn10300_asm_output_mi_thunk): Likewise.
2483 * config/nds32/nds32.c (nds32_asm_output_mi_thunk): Likewise.
2484 * config/nios2/nios2.c (nios2_asm_output_mi_thunk): Likewise.
2485 * config/or1k/or1k.c (or1k_output_mi_thunk): Likewise.
2486 * config/pa/pa.c (pa_asm_output_mi_thunk): Likewise.
2487 * config/riscv/riscv.c (riscv_output_mi_thunk): Likewise.
2488 * config/rs6000/rs6000.c (rs6000_output_mi_thunk): Likewise.
2489 * config/s390/s390.c (s390_output_mi_thunk): Likewise.
2490 * config/sh/sh.c (sh_output_mi_thunk): Likewise.
2491 * config/sparc/sparc.c (sparc_output_mi_thunk): Likewise.
2492 * config/spu/spu.c (spu_output_mi_thunk): Likewise.
2493 * config/stormy16/stormy16.c (xstormy16_asm_output_mi_thunk):
2494 Likewise.
2495 * config/tilegx/tilegx.c (tilegx_output_mi_thunk): Likewise.
2496 * config/tilepro/tilepro.c (tilepro_asm_output_mi_thunk): Likewise.
2497 * config/vax/vax.c (vax_output_mi_thunk): Likewise.
2498
2499 2019-05-16 Jan Hubicka <hubicka@ucw.cz>
2500
2501 * tree-ssa-alias.c (alias_stats): Add
2502 aliasing_component_refs_p_may_alias and
2503 aliasing_component_refs_p_no_alias.
2504 (dump_alias_stats): Print aliasing_component_refs_p stats.
2505 (aliasing_component_refs_p): Update stats.
2506
2507 2019-05-16 Martin Liska <mliska@suse.cz>
2508
2509 PR lto/90500
2510 * multiple_target.c (expand_target_clones): Do not allow
2511 target_clones being used with a symbol that is an alias.
2512
2513 2019-05-16 Vladislav Ivanishin <vlad@ispras.ru>
2514
2515 PR tree-optimization/90394
2516 * tree-ssa-uninit.c (is_pred_expr_subset_of): Potentially give false
2517 positives rather than ICE for cases where (code2 == NE_EXPR
2518 && code1 == BIT_AND_EXPR).
2519
2520 2019-05-16 Jakub Jelinek <jakub@redhat.com>
2521
2522 PR fortran/90329
2523 * tree-core.h (struct tree_decl_common): Document
2524 decl_nonshareable_flag for PARM_DECLs.
2525 * tree.h (DECL_HIDDEN_STRING_LENGTH): Define.
2526 * calls.c (expand_call): Don't try tail call if caller
2527 has any DECL_HIDDEN_STRING_LENGTH PARM_DECLs that are or might be
2528 passed on the stack and callee needs to pass any arguments on the
2529 stack.
2530 * tree-streamer-in.c (unpack_ts_decl_common_value_fields): Use
2531 else if instead of series of mutually exclusive ifs. Handle
2532 DECL_HIDDEN_STRING_LENGTH for PARM_DECLs.
2533 * tree-streamer-out.c (pack_ts_decl_common_value_fields): Likewise.
2534
2535 * lto-streamer.h (LTO_major_version): Bump to 9.
2536
2537 2019-05-16 Jun Ma <JunMa@linux.alibaba.com>
2538
2539 PR tree-optimization/90106
2540 * tree-call-cdce.c (shrink_wrap_one_built_in_call_with_conds): Add
2541 new parameter as new internal function call, also move it to new
2542 basic block.
2543 (use_internal_fn): Pass internal function call to
2544 shrink_wrap_one_built_in_call_with_conds.
2545
2546 2019-05-15 Jakub Jelinek <jakub@redhat.com>
2547
2548 * omp-low.c (lower_rec_input_clauses): For if (0) or simdlen (1) set
2549 max_vf to 1.
2550 * omp-expand.c (expand_omp_simd): For if (0) or simdlen (1) clear
2551 safelen_int and set loop->dont_vectorize.
2552
2553 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2554
2555 PR target/89021
2556 * config/i386/i386-builtin.def: Enable MMX intrinsics with
2557 SSE/SSE2/SSSE3.
2558 * config/i386/i386-builtins.c (ix86_init_mmx_sse_builtins):
2559 Likewise.
2560 * config/i386/i386-expand.c (ix86_expand_builtin): Allow
2561 SSE/SSE2/SSSE3 to emulate MMX intrinsics with TARGET_MMX_WITH_SSE.
2562 * config/i386/mmintrin.h: Only require SSE2 if __MMX_WITH_SSE__
2563 is defined.
2564
2565 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2566
2567 PR target/89021
2568 * config/i386/mmx.md (*vec_dupv2sf): Changed to
2569 define_insn_and_split to support SSE emulation.
2570 (*vec_extractv2sf_0): Likewise.
2571 (*vec_extractv2sf_1): Likewise.
2572 (*vec_extractv2si_0): Likewise.
2573 (*vec_extractv2si_1): Likewise.
2574 (*vec_extractv2si_zext_mem): Likewise.
2575 (vec_setv2sf): Also allow TARGET_MMX_WITH_SSE.
2576 (vec_extractv2sf_1 splitter): Likewise.
2577 (vec_extractv2sfsf): Likewise.
2578 (vec_setv2si): Likewise.
2579 (vec_extractv2si_1 splitter): Likewise.
2580 (vec_extractv2sisi): Likewise.
2581 (vec_setv4hi): Likewise.
2582 (vec_extractv4hihi): Likewise.
2583 (vec_setv8qi): Likewise.
2584 (vec_extractv8qiqi): Likewise.
2585 (vec_extractv2sfsf): Also allow TARGET_MMX_WITH_SSE. Pass
2586 TARGET_MMX_WITH_SSE ix86_expand_vector_extract.
2587 (vec_extractv2sisi): Likewise.
2588 (vec_extractv4hihi): Likewise.
2589 (vec_extractv8qiqi): Likewise.
2590 (vec_initv2sfsf): Also allow TARGET_MMX_WITH_SSE. Pass
2591 TARGET_MMX_WITH_SSE to ix86_expand_vector_init.
2592 (vec_initv2sisi): Likewise.
2593 (vec_initv4hihi): Likewise.
2594 (vec_initv8qiqi): Likewise.
2595 (vec_setv2si): Also allow TARGET_MMX_WITH_SSE. Pass
2596 TARGET_MMX_WITH_SSE to ix86_expand_vector_set.
2597 (vec_setv4hi): Likewise.
2598 (vec_setv8qi): Likewise.
2599
2600 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2601
2602 PR target/89021
2603 * config/i386/mmx.md (MMXMODE:mov<mode>): Also allow
2604 TARGET_MMX_WITH_SSE.
2605 (MMXMODE:*mov<mode>_internal): Likewise.
2606 (MMXMODE:movmisalign<mode>): Likewise.
2607
2608 2019-05-15 Uroš Bizjak <ubizjak@gmail.com>
2609
2610 PR target/89021
2611 * config/i386/i386.md (*zero_extendsidi2): Add mmx_isa attribute.
2612 * config/i386/sse.md (sse2_cvtpi2pd): Ditto.
2613 (sse2_cvtpd2pi): Ditto.
2614 (sse2_cvttpd2pi): Ditto.
2615 (*vec_concatv2sf_sse4_1): Ditto.
2616 (*vec_concatv2sf_sse): Ditto.
2617 (*vec_concatv2si_sse4_1): Ditto.
2618 (*vec_concatv2si): Ditto.
2619 (*vec_concatv4si_0): Ditto.
2620 (*vec_concatv2di_0): Ditto.
2621
2622 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2623
2624 PR target/89021
2625 * config/i386/sse.md (abs<mode>2): Add SSE emulation.
2626
2627 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2628
2629 PR target/89021
2630 * config/i386/sse.md (ssse3_palignrdi): Changed to
2631 define_insn_and_split to support SSE emulation.
2632
2633 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2634
2635 PR target/89021
2636 * config/i386/sse.md (ssse3_psign<mode>3): Add SSE emulation.
2637
2638 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2639
2640 PR target/89021
2641 * config/i386/sse.md (ssse3_pshufbv8qi3): Changed to
2642 define_insn_and_split. Also allow TARGET_MMX_WITH_SSE. Add
2643 SSE emulation.
2644
2645 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2646
2647 PR target/89021
2648 * config/i386/sse.md (ssse3_pmulhrswv4hi3): Require TARGET_MMX
2649 or TARGET_MMX_WITH_SSE.
2650 (*ssse3_pmulhrswv4hi3): Add SSE emulation.
2651
2652 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2653
2654 PR target/89021
2655 * config/i386/sse.md (ssse3_pmaddubsw): Add SSE emulation.
2656
2657 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2658
2659 PR target/89021
2660 * config/i386/sse.md (ssse3_ph<plusminus_mnemonic>dv2si3):
2661 Changed to define_insn_and_split to support SSE emulation.
2662
2663 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2664
2665 PR target/89021
2666 * config/i386/sse.md (ssse3_ph<plusminus_mnemonic>wv4hi3):
2667 Changed to define_insn_and_split to support SSE emulation.
2668
2669 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2670
2671 PR target/89021
2672 * config/i386/mmx.md (mmx_<emms>): Renamed to ...
2673 (*mmx_<emms>): This.
2674 (mmx_<emms>): New expander.
2675
2676 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2677
2678 PR target/89021
2679 * config/i386/mmx.md (sse2_umulv1siv1di3): Add SSE emulation
2680 support.
2681 (*sse2_umulv1siv1di3): Add SSE2 emulation.
2682
2683 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2684
2685 PR target/89021
2686 * config/i386/mmx.md (sse_movntq): Add SSE2 emulation.
2687
2688 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2689
2690 PR target/89021
2691 * config/i386/mmx.md (mmx_psadbw): Add SSE emulation.
2692
2693 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2694
2695 PR target/89021
2696 * config/i386/mmx.md (mmx_uavgv4hi3): Also check TARGET_MMX and
2697 TARGET_MMX_WITH_SSE.
2698 (*mmx_uavgv4hi3): Add SSE emulation.
2699
2700 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2701
2702 PR target/89021
2703 * config/i386/mmx.md (mmx_uavgv8qi3): Also check TARGET_MMX
2704 and TARGET_MMX_WITH_SSE.
2705 (*mmx_uavgv8qi3): Add SSE emulation.
2706
2707 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2708
2709 PR target/89021
2710 * config/i386/xmmintrin.h: Emulate MMX maskmovq with SSE2
2711 maskmovdqu for __MMX_WITH_SSE__.
2712
2713 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2714
2715 PR target/89021
2716 * config/i386/mmx.md (mmx_umulv4hi3_highpart): Also check
2717 TARGET_MMX and TARGET_MMX_WITH_SSE.
2718 (*mmx_umulv4hi3_highpart): Add SSE emulation.
2719
2720 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2721
2722 PR target/89021
2723 * config/i386/mmx.md (mmx_pmovmskb): Changed to
2724 define_insn_and_split to support SSE emulation.
2725
2726 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2727
2728 PR target/89021
2729 * config/i386/mmx.md (mmx_<code>v4hi3): Also check TARGET_MMX
2730 and TARGET_MMX_WITH_SSE.
2731 (mmx_<code>v8qi3): Likewise.
2732 (smaxmin:<code>v4hi3): New.
2733 (umaxmin:<code>v8qi3): Likewise.
2734 (smaxmin:*mmx_<code>v4hi3): Add SSE emulation.
2735 (umaxmin:*mmx_<code>v8qi3): Likewise.
2736
2737 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2738
2739 PR target/89021
2740 * config/i386/mmx.md (mmx_pinsrw): Also check TARGET_MMX and
2741 TARGET_MMX_WITH_SSE.
2742 (*mmx_pinsrw): Add SSE emulation.
2743
2744 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2745
2746 PR target/89021
2747 * config/i386/mmx.md (mmx_pextrw): Add SSE emulation.
2748
2749 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2750
2751 PR target/89021
2752 * config/i386/sse.md (sse_cvtpi2ps): Changed to
2753 define_insn_and_split. Also allow TARGET_MMX_WITH_SSE. Add
2754 SSE emulation.
2755
2756 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2757
2758 PR target/89021
2759 * config/i386/sse.md (sse_cvtps2pi): Add SSE emulation.
2760 (sse_cvttps2pi): Likewise.
2761
2762 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2763
2764 PR target/89021
2765 * config/i386/mmx.md (mmx_pshufw): Also check TARGET_MMX and
2766 TARGET_MMX_WITH_SSE.
2767 (mmx_pshufw_1): Add SSE emulation.
2768 (*vec_dupv4hi): Changed to define_insn_and_split and also allow
2769 TARGET_MMX_WITH_SSE to support SSE emulation.
2770
2771 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2772
2773 PR target/89021
2774 * config/i386/constraints.md (Yw): New constraint.
2775 * config/i386/mmx.md (*vec_dupv2si): Changed to
2776 define_insn_and_split and also allow TARGET_MMX_WITH_SSE to
2777 support SSE emulation.
2778
2779 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2780
2781 PR target/89021
2782 * config/i386/mmx.md (mmx_eq<mode>3): Also allow
2783 TARGET_MMX_WITH_SSE.
2784 (*mmx_eq<mode>3): Also allow TARGET_MMX_WITH_SSE. Add SSE
2785 support.
2786 (mmx_gt<mode>3): Likewise.
2787
2788 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2789
2790 PR target/89021
2791 * config/i386/mmx.md (mmx_andnot<mode>3): Also allow
2792 TARGET_MMX_WITH_SSE. Add SSE support.
2793
2794 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2795
2796 PR target/89021
2797 * config/i386/mmx.md (any_logic:mmx_<code><mode>3): Also allow
2798 TARGET_MMX_WITH_SSE.
2799 (any_logic:<code><mode>3): New.
2800 (any_logic:*mmx_<code><mode>3): Also allow TARGET_MMX_WITH_SSE.
2801 Add SSE support.
2802
2803 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2804
2805 PR target/89021
2806 * config/i386/mmx.md (mmx_ashr<mode>3): Also allow
2807 TARGET_MMX_WITH_SSE. Add SSE emulation.
2808 (mmx_<shift_insn><mode>3): Likewise.
2809 (ashr<mode>3): New.
2810 (<shift_insn><mode>3): Likewise.
2811
2812 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2813
2814 PR target/89021
2815 * config/i386/mmx.md (mmx_pmaddwd): Also allow TARGET_MMX_WITH_SSE.
2816 (*mmx_pmaddwd): Also allow TARGET_MMX_WITH_SSE. Add SSE support.
2817
2818 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2819
2820 PR target/89021
2821 * config/i386/mmx.md (mmx_smulv4hi3_highpart): Also allow
2822 TARGET_MMX_WITH_SSE.
2823 (*mmx_smulv4hi3_highpart): Also allow TARGET_MMX_WITH_SSE. Add
2824 SSE support.
2825
2826 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2827
2828 PR target/89021
2829 * config/i386/mmx.md (mmx_mulv4hi3): Also allow
2830 TARGET_MMX_WITH_SSE.
2831 (mulv4hi3): New.
2832 (*mmx_mulv4hi3): Also allow TARGET_MMX_WITH_SSE. Add SSE
2833 support.
2834
2835 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2836
2837 PR target/89021
2838 * config/i386/mmx.md (MMXMODEI8): Require TARGET_SSE2 for V1DI.
2839 (plusminus:mmx_<plusminus_insn><mode>3): Check
2840 TARGET_MMX_WITH_SSE.
2841 (sat_plusminus:mmx_<plusminus_insn><mode>3): Likewise.
2842 (<plusminus_insn><mode>3): New.
2843 (*mmx_<plusminus_insn><mode>3): Add SSE emulation.
2844 (*mmx_<plusminus_insn><mode>3): Likewise.
2845
2846 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2847
2848 PR target/89021
2849 * config/i386/i386-expand.c (ix86_split_mmx_punpck): New function.
2850 * config/i386/i386-protos.h (ix86_split_mmx_punpck): New
2851 prototype.
2852 * config/i386/mmx.m (mmx_punpckhbw): Changed to
2853 define_insn_and_split to support SSE emulation.
2854 (mmx_punpcklbw): Likewise.
2855 (mmx_punpckhwd): Likewise.
2856 (mmx_punpcklwd): Likewise.
2857 (mmx_punpckhdq): Likewise.
2858 (mmx_punpckldq): Likewise.
2859
2860 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2861 Uros Bizjak <ubizjak@gmail.com>
2862
2863 PR target/89021
2864 * config/i386/i386-expand.c (ix86_move_vector_high_sse_to_mmx):
2865 New function.
2866 (ix86_split_mmx_pack): Likewise.
2867 * config/i386/i386-protos.h (ix86_move_vector_high_sse_to_mmx):
2868 New prototype.
2869 (ix86_split_mmx_pack): Likewise.
2870 * config/i386/i386.md (mmx_isa): New.
2871 (enabled): Also check mmx_isa.
2872 * config/i386/mmx.md (any_s_truncate): New code iterator.
2873 (s_trunsuffix): New code attr.
2874 (mmx_packsswb): Removed.
2875 (mmx_packssdw): Likewise.
2876 (mmx_packuswb): Likewise.
2877 (mmx_pack<s_trunsuffix>swb): New define_insn_and_split to emulate
2878 MMX packsswb/packuswb with SSE2.
2879 (mmx_packssdw): Likewise.
2880 * config/i386/predicates.md (register_mmxmem_operand): New.
2881
2882 2019-05-15 H.J. Lu <hongjiu.lu@intel.com>
2883
2884 PR target/89021
2885 * config/i386/i386-c.c (ix86_target_macros_internal): Define
2886 __MMX_WITH_SSE__ for TARGET_MMX_WITH_SSE.
2887 * config/i386/i386.c (ix86_set_reg_reg_cost): Add support for
2888 TARGET_MMX_WITH_SSE with VALID_MMX_REG_MODE.
2889 (ix86_vector_mode_supported_p): Likewise.
2890 * config/i386/i386.h (TARGET_MMX_WITH_SSE): New.
2891
2892 2019-05-15 Martin Liska <mliska@suse.cz>
2893
2894 PR middle-end/90478
2895 * tree-switch-conversion.c (jump_table_cluster::can_be_handled):
2896 Check for overflow.
2897
2898 2019-05-15 Richard Biener <rguenther@suse.de>
2899
2900 * tree-into-ssa.c (pass_build_ssa::execute): Run
2901 update_address_taken before going into SSA.
2902
2903 2019-05-15 Richard Biener <rguenther@suse.de>
2904
2905 * tree-pretty-print.c (dump_generic_node): Dump BIT_FIELD_REF
2906 as __BIT_FIELD_REF with type with -gimple.
2907
2908 2019-05-15 Vladislav Ivanishin <vlad@ispras.ru>
2909
2910 * tree-ssa-uninit.c (is_value_included_in): Remove is_unsigned and merge
2911 semantically equivalent branches (left over after prior refactorings).
2912
2913 2019-05-15 Richard Biener <rguenther@suse.de>
2914
2915 PR tree-optimization/88828
2916 * tree-ssa-forwprop.c (simplify_vector_constructor): Fix
2917 bogus check.
2918
2919 2019-05-14 Richard Biener <rguenther@suse.de>
2920
2921 * tree-pretty-print.c (dump_generic_node): Dump VIEW_CONVERT_EXPR
2922 as __VIEW_CONVERT with -gimple.
2923
2924 2019-05-12 Iain Sandoe <iain@sandoe.co.uk>
2925
2926 PR target/82920
2927 * config/i386/darwin.h (CC1_SPEC): Report -mx32 as an error for
2928 Darwin.
2929
2930 2019-05-14 Segher Boessenkool <segher@kernel.crashing.org>
2931
2932 * config/rs6000/rs6000.md (eh_set_lr_<mode>): Merge with following
2933 define_split to become a define_insn_and_split.
2934
2935 2019-05-14 Segher Boessenkool <segher@kernel.crashing.org>
2936
2937 * config/rs6000/rs6000-protos.h (rs6000_emit_epilogue): Change
2938 arguments.
2939 * config/rs6000/rs6000.c (rs6000_emit_epilogue): Change arguments.
2940 * config/rs6000/rs6000.md (epilogue_type): New define_enum.
2941 (sibcall_epilogue): Adjust.
2942 (epilogue): Adjust.
2943
2944 2019-05-14 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
2945
2946 * config.gcc: Move *-*-solaris2.10* from obsolete configurations
2947 to unsupported ones.
2948 Simplify x86_64-*-solaris2.1[0-9]* to x86_64-*-solaris2*.
2949 * config.host: Likewise.
2950 * config/i386/sol2.h (ASM_COMMENT_START): Remove.
2951 * config/sparc/driver-sparc.c (host_detect_local_cpu) [__sun__ &&
2952 __svr4__]: Remove "brand" fallback.
2953 [!KSTAT_DATA_STRING]: Remove.
2954 * configure.ac (gcc_cv_ld_hidden): Simplify *-*-solaris2.1[0-9]*
2955 to *-*-solaris2*.
2956 (comdat_group): Likewise.
2957 (set_have_as_tls): Likewise.
2958 (gcc_cv_target_dl_iterate_phdr): Likewise.
2959 (gcc_cv_as_shf_merge): Remove Solaris 10/x86 workaround.
2960 (gcc_cv_ld_aligned_shf_merge): Remove Solaris 10/SPARC workaround.
2961 * configure: Regenerate.
2962 * doc/install.texi: Simplify Solaris target triplets.
2963 (Specific, i?86-*-solaris2*): Remove Solaris 10 references.
2964 (Specific, *-*-solaris2*): Document Solaris 10 removal.
2965 Remove Solaris 10 references.
2966 Remove obsolete Solaris bug reference.
2967 (Specific, sparc-sun-solaris2.10): Remove.
2968
2969 2019-05-14 Uroš Bizjak <ubizjak@gmail.com>
2970
2971 * config/i386/i386.md (any_div): New code iterator.
2972 (paired_mod): New code attribute.
2973 (sgnprefix): Handle DIV and UDIV RTXes.
2974 (u): Ditto.
2975 (<u>divmod<mode>4): Macroize expander from divmod<mode>4
2976 and udivmod<mode>4 patterns using any_div code iterator.
2977 (divmod splitters): Macroize splitters using any_div code iterator.
2978 (*udivmodsi4_pow2_zext_1): Use exactl_log2 in insn condition.
2979 (*udivmodsi4_pow2_zext_2): Ditto.
2980 (*<u>divmod<mode>4_noext): Macroize insn from *divmod<mode>4_noext
2981 and *udivmod<mode>4_noext patterns using any_div code iterator.
2982 (*<u>divmod<mode>4_noext_zext_1): Macroize insn from
2983 *divmod<mode>4_noext_zext_1 and *udivmod<mode>4_noext_zext_1
2984 patterns using any_div code iterator.
2985 (*<u>divmod<mode>4_noext_zext_2): Macroize insn from
2986 *divmod<mode>4_noext_zext_2 and *udivmod<mode>4_noext_zext_2
2987 patterns using any_div code iterator.
2988 (<u>divmodhiqi3): Macroize insn from divmodhiqi3 and
2989 udivmodhiqi3 patterns using any_extend code iterator.
2990
2991 2019-05-14 Richard Biener <rguenther@suse.de>
2992 H.J. Lu <hongjiu.lu@intel.com>
2993
2994 PR tree-optimization/88828
2995 * tree-ssa-forwprop.c (simplify_vector_constructor): Handle
2996 permuting in a single non-constant element not extracted
2997 from a vector.
2998
2999 2019-05-14 Przemyslaw Wirkus <przemyslaw.wirkus@arm.com>
3000
3001 * internal-fn.def (SIGNBIT): New.
3002 * config/aarch64/aarch64-simd.md (signbitv2sf2): New expand
3003 defined.
3004 (signbitv4sf2): Likewise.
3005
3006 2019-05-14 Chenghua Xu <paul.hua.gm@gmail.com>
3007
3008 PR target/90357
3009 * config/mips/mips.c (mips_split_move): Skip forward SRC into
3010 next insn when the SRC reg is dead.
3011
3012 2019-05-14 Bin Cheng <bin.cheng@linux.alibaba.com>
3013
3014 * gimple-ssa-strength-reduction.c (lookup_cand): Adjust index by 1.
3015 (alloc_cand_and_find_basis): Ditto.
3016 (backtrace_base_for_ref, create_mul_ssa_cand): Remove if-then-else.
3017 (create_mul_imm_cand, create_add_ssa_cand): Ditto.
3018 (create_add_imm_cand, slsr_process_cast): Ditto.
3019 (slsr_process_copy, replace_mult_candidate): Ditto.
3020 (replace_rhs_if_not_dup, replace_one_candidate): Ditto.
3021 (dump_cand_vec, analyze_candidates_and_replace): Skip NULL element.
3022 (pass_strength_reduction::execute): Init the first NULL element.
3023
3024 2019-05-13 Nathan Sidwell <nathan@acm.org>
3025
3026 * gcc.c (execute): Simplify cond-expr into if. Reformat comment.
3027 (run_attempt): Reformat line break.
3028
3029 2019-05-13 David Edelsohn <dje.gcc@gmail.com>
3030
3031 PR target/90418
3032 * config/rs6000/rs6000.c (rs6000_emit_epilogue): Don't load EH
3033 data registers in sibcall epilogues.
3034 Don't add EH_RETURN_STACKADJ_RTX to sp in sibcall epilogues.
3035
3036 2019-05-13 Uroš Bizjak <ubizjak@gmail.com>
3037
3038 PR target/89221
3039 * configure.ac (--enable-frame-pointer):
3040 Disable by default for cygwin and mingw.
3041 * configure: Regenerate.
3042
3043 2019-05-13 Nathan Sidwell <nathan@acm.org>
3044
3045 * dwarf2out.c (breakout_comdat_types): Move comment to correct
3046 piece of code.
3047 (const_ok_for_output_1): Balance parens around #if/#else/#endif
3048 (gen_member_die): Move abstract origin check earlier. Only VARs
3049 can be static_inline_p. Simplify splicing control flow.
3050
3051 2019-05-13 Richard Biener <rguenther@suse.de>
3052
3053 * tree-vect-slp.c (vect_get_and_check_slp_defs): Handle
3054 VIEW_CONVERT_EXPR.
3055 (vect_build_slp_tree_1): Likewise.
3056
3057 2019-05-13 Richard Biener <rguenther@suse.de>
3058
3059 PR tree-optimization/90402
3060 * tree-if-conv.c (tree_if_conversion): Value number only
3061 the loop body by making the latch an exit of the region
3062 as well.
3063 * tree-ssa-sccvn.c (process_bb): Add flag whether to skip
3064 processing PHIs.
3065 (do_rpo_vn): Deal with multiple edges into the entry block
3066 that are not backedges inside the region by skipping PHIs
3067 of the entry block.
3068
3069 2019-05-13 Richard Biener <rguenther@suse.de>
3070
3071 PR tree-optimization/90316
3072 * tree-ssa-pre.c (insert_aux): Fold into ...
3073 (insert): ... this function. Use a RPO walk to reduce the
3074 number of required iterations.
3075
3076 2019-05-13 Martin Liska <mliska@suse.cz>
3077
3078 PR tree-optimization/90416
3079 * tree-vect-stmts.c (vect_check_load_store_mask): Concatenate
3080 string instead of passing the second part as va_arg argument.
3081
3082 2019-05-13 Martin Liska <mliska@suse.cz>
3083
3084 PR gcov-profile/90380
3085 * gcov.c (handle_cycle): Do not support zero cycle count,
3086 it should not be possible.
3087 (path_contains_zero_cycle_arc): New function.
3088 (circuit): Ignore zero cycle arc counts.
3089
3090 2019-05-13 Martin Liska <mliska@suse.cz>
3091
3092 PR gcov-profile/90380
3093 * gcov.c (enum loop_type): Remove the enum and
3094 the operator.
3095 (handle_cycle): Assert that we should not reach
3096 a negative count.
3097 (circuit): Use loop_found instead of a tri-state loop_type.
3098 (get_cycles_count): Do not handle NEGATIVE_LOOP as it can't
3099 happen.
3100
3101 2019-05-12 Iain Sandoe <iain@sandoe.co.uk>
3102
3103 PR target/82920
3104 * config/i386/i386.c (ix86_output_jmp_thunk_or_indirect): New.
3105 (ix86_output_indirect_branch_via_reg): Use output mechanism
3106 accounting for __USER_LABEL_PREFIX__.
3107 (ix86_output_indirect_branch_via_push): Likewise.
3108 (ix86_output_function_return): Likewise.
3109 (ix86_output_indirect_function_return): Likewise.
3110
3111 2019-05-12 Richard Sandiford <richard.sandiford@arm.com>
3112
3113 * doc/md.texi: Document use of code attributes in rtx patterns.
3114 * read-md.h (rtx_reader::rtx_alloc_for_name): New member function.
3115 * read-rtl.c (find_code): Split out search loops into...
3116 (maybe_find_code): ...this new function.
3117 (check_code_iterator): Make the error message more informative.
3118 (check_code_attribute): New function.
3119 (rtx_reader::rtx_alloc_for_name): Likewise.
3120 (rtx_reader::read_rtx_code): Use rtx_alloc_for_name.
3121 * config/aarch64/predicates.md (aarch64_smin, aarch64_umin): Delete.
3122 * config/aarch64/aarch64-simd.md (*aarch64_<su>abd<mode>_3): Use
3123 <max_opp> directly as an rtx code instead of via a match_operator.
3124 * config/aarch64/aarch64-sve.md (aarch64_<su>abd<mode>_3): Likewise.
3125 (<su>abd<mode>_3): Update accordingly.
3126
3127 2019-05-12 Iain Sandoe <iain@sandoe.co.uk>
3128
3129 * config/rs6000/rs6000.c (debug_stack_info): When -mdebug=stack
3130 is given, print the state of the EH "save world" computation for
3131 Darwin.
3132
3133 2019-05-11 Jakub Jelinek <jakub@redhat.com>
3134
3135 PR c++/59813
3136 * config/aarch64/aarch64.c (aarch64_expand_epilogue): Don't add
3137 EH_RETURN_STACKADJ_RTX to sp in sibcall epilogues.
3138
3139 2019-05-11 Uroš Bizjak <ubizjak@gmail.com>
3140
3141 * config/i386/i386.md (floatdi<X87MODEF:mode>2_i387_with_xmm):
3142 Use pinsrd for TARGET_SSE4_1.
3143 * config/i386/sse.md (movdi_to_sse): Ditto.
3144
3145 2019-05-10 Richard Biener <rguenther@suse.de>
3146
3147 * tree-ssa-sccvn.c (visit_reference_op_call): Initialize value-id.
3148 (do_rpo_vn): Initialize next_value_id.
3149
3150 2019-05-10 Martin Liska <mliska@suse.cz>
3151
3152 * params.def (PARAM_GIMPLE_FE_COMPUTED_HOT_BB_THRESHOLD):
3153 Fix plural form.
3154
3155 2019-05-10 Jakub Jelinek <jakub@redhat.com>
3156
3157 PR tree-optimization/90385
3158 * tree-parloops.c (try_create_reduction_list): Punt on non-SSA_NAME
3159 arguments of the exit phis.
3160
3161 PR c++/90383
3162 * tree-inline.h (struct copy_body_data): Add do_not_fold member.
3163 * tree-inline.c (remap_gimple_op_r): Avoid folding expressions if
3164 id->do_not_fold.
3165 (copy_tree_body_r): Likewise.
3166 (copy_fn): Set id.do_not_fold to true.
3167
3168 2019-05-10 Martin Liska <mliska@suse.cz>
3169
3170 * config/i386/i386-expand.c (ix86_expand_floorceildf_32):
3171 Reapply changes from r269790.
3172
3173 2019-05-10 Martin Liska <mliska@suse.cz>
3174
3175 PR middle-end/90340
3176 * doc/invoke.texi: New params.
3177 * params.def (PARAM_JUMP_TABLE_MAX_GROWTH_RATIO_FOR_SIZE): New.
3178 (PARAM_JUMP_TABLE_MAX_GROWTH_RATIO_FOR_SPEED): Likewise.
3179 * tree-switch-conversion.c (jump_table_cluster::can_be_handled):
3180 Use it.
3181 * tree-switch-conversion.h (struct jump_table_cluster):
3182 Likewise.
3183
3184 2019-05-09 Segher Boessenkool <segher@kernel.crashing.org>
3185
3186 * combine.c (combine_simplify_rtx): Don't make IF_THEN_ELSE RTL.
3187
3188 2019-05-09 Bill Schmidt <wschmidt@linux.ibm.com>
3189
3190 * doc/loop.texi: Remove reference to FOR_EACH_LOOP_BREAK.
3191
3192 2019-05-09 Alexander Monakov <amonakov@ispras.ru>
3193
3194 PR rtl-optimization/88879
3195 * sel-sched.c (sel_target_adjust_priority): Remove assert.
3196
3197 2019-05-09 Richard Earnshaw <rearnsha@arm.com>
3198
3199 PR target/90405
3200 * config/arm/arm.c (callee_saved_reg_p): Move before
3201 thumb_find_work_register.
3202 (thumb1_prologue_unused_call_clobbered_lo_regs): Move before
3203 thumb_find_work_register. Only call df_get_live_out once.
3204 (thumb1_epilogue_unused_call_clobbered_lo_regs): Likewise.
3205 (thumb_find_work_register): Use
3206 thumb1_prologue_unused_call_clobbered_lo_regs instead of ad hoc
3207 algorithms to locate a spare call clobbered reg.
3208
3209 2019-05-09 Martin Liska <mliska@suse.cz>
3210
3211 * gimple-pretty-print.c (dump_binary_rhs): Dump MIN_EXPR
3212 and MAX_EXPR in GIMPLE FE format.
3213
3214 2019-05-09 Martin Liska <mliska@suse.cz>
3215
3216 * tree-cfg.c (dump_function_to_file): Dump entry BB count.
3217 * gimple-pretty-print.c (dump_gimple_bb_header):
3218 Dump BB count.
3219 (pp_cfg_jump): Dump edge probability.
3220 * profile-count.c (profile_quality_as_string): Simplify
3221 with a static array.
3222 (parse_profile_quality): New function.
3223 (profile_count::dump): Simplify with a static array.
3224 (profile_count::from_gcov_type): Add new argument.
3225 * profile-count.h (parse_profile_quality): Likewise.
3226 * predict.h (set_hot_bb_threshold): New.
3227 * params.def (PARAM_GIMPLE_FE_COMPUTED_HOT_BB_THRESHOLD):
3228 New param.
3229 * predict.c (get_hot_bb_threshold): Set from the new param.
3230 (set_hot_bb_threshold): New.
3231
3232 2019-05-09 Richard Biener <rguenther@suse.de>
3233
3234 PR tree-optimization/90395
3235 * tree-ssa-forwprop.c (pass_forwprop::execute): Do not
3236 rewrite vector stores that throw internally.
3237
3238 2019-05-09 Thomas Schwinge <thomas@codesourcery.com>
3239
3240 * cif-code.def (CHKP): Remove.
3241
3242 PR target/89221
3243 * configure.ac (--enable-frame-pointer): Disable by default for
3244 GNU systems.
3245 * configure: Regenerate.
3246
3247 2019-05-09 Alan Modra <amodra@gmail.com>
3248
3249 PR target/89271
3250 * config/rs6000/rs6000.h (enum reg_class, REG_CLASS_NAMES),
3251 (REG_CLASS_CONTENTS): Add GEN_OR_VSX_REGS class.
3252 * config/rs6000/rs6000.c (rs6000_register_move_cost): Correct
3253 cost for general <-> vsx when direct moves are available.
3254 Cost union classes at minimal cost for any reg in the class.
3255 Correct calculation for moves between vsx, float, and altivec.
3256 Don't return a low cost for moves between special regs. Don't
3257 use hard coded register numbers.
3258 (TARGET_IRA_CHANGE_PSEUDO_ALLOCNO_CLASS): Define.
3259 (rs6000_ira_change_pseudo_allocno_class): New function.
3260 * config/rs6000/rs6000.md (movsi_internal1, mov<mode>_internal),
3261 (movdi_internal32, movdi_internal64): Remove '*' from vsx register
3262 alternatives.
3263 (movsi_internal1): Don't disparage vector alternatives.
3264 (mov<mode>_internal): Likewise, excepting alternative that
3265 will be split.
3266 * config/rs6000/vsx.md (vsx_splat_<mode>_reg): Don't disparage
3267 we <- b alternative.
3268
3269 2019-05-08 Jakub Jelinek <jakub@redhat.com>
3270
3271 PR c++/59813
3272 PR tree-optimization/89060
3273 * tree-ssa-live.h (live_vars_map): New typedef.
3274 (compute_live_vars, live_vars_at_stmt, destroy_live_vars): Declare.
3275 * tree-ssa-live.c: Include gimple-walk.h and cfganal.h.
3276 (struct compute_live_vars_data): New type.
3277 (compute_live_vars_visit, compute_live_vars_1, compute_live_vars,
3278 live_vars_at_stmt, destroy_live_vars): New functions.
3279 * tree-tailcall.c: Include tree-ssa-live.h.
3280 (live_vars, live_vars_vec): New global variables.
3281 (find_tail_calls): Perform variable life analysis before punting.
3282 (tree_optimize_tail_calls_1): Clean up live_vars and live_vars_vec.
3283 * tree-inline.h (struct copy_body_data): Add eh_landing_pad_dest
3284 member.
3285 * tree-inline.c (add_clobbers_to_eh_landing_pad): Remove BB argument.
3286 Perform variable life analysis to select variables that really need
3287 clobbers added.
3288 (copy_edges_for_bb): Don't call add_clobbers_to_eh_landing_pad here,
3289 instead set id->eh_landing_pad_dest and assert it is the same.
3290 (copy_cfg_body): Call it here if id->eh_landing_pad_dest is non-NULL.
3291
3292 2019-05-08 Mihail Ionescu <mihail.ionescu@arm.com>
3293 Richard Earnshaw <rearnsha@arm.com>
3294
3295 PR target/88167
3296 * config/arm/arm.c (thumb1_prologue_unused_call_clobbered_lo_regs): New
3297 function.
3298 (thumb1_epilogue_unused_call_clobbered_lo_regs): New function.
3299 (thumb1_compute_save_core_reg_mask): Don't force a spare work
3300 register if both the epilogue and prologue can use call-clobbered
3301 regs.
3302 (thumb1_unexpanded_epilogue): Use
3303 thumb1_epilogue_unused_call_clobbered_lo_regs. Reverse the logic for
3304 picking temporaries for restoring high regs to match that of the
3305 prologue where possible.
3306 (thumb1_expand_prologue): Add any usable call-clobbered low registers to
3307 the list of work registers. Detect if the return address is still live
3308 at the end of the prologue and avoid using it for a work register if so.
3309 If the return address is not live, add LR to the list of pushable regs
3310 after the first pass.
3311
3312 2019-05-08 Bin Cheng <bin.cheng@linux.alibaba.com>
3313
3314 PR tree-optimization/90078
3315 * tree-ssa-loop-ivopts.c (inttypes.h): Include new header file.
3316 (INFTY): Increase the value for infinite cost.
3317 (struct comp_cost): Promote type of members to int64_t.
3318 (infinite_cost): Don't set complexity in initialization.
3319 (comp_cost::operator +,-,+=,-+,/=,*=): Assert when cost computation
3320 overflows to infinite_cost.
3321 (adjust_setup_cost): Promote type of parameter and cost computation
3322 to int64_t.
3323 (struct ainc_cost_data, struct iv_ca): Promote type of member to
3324 int64_t.
3325 (get_scaled_computation_cost_at, determine_iv_cost): Promote type of
3326 cost computation to int64_t.
3327 (determine_group_iv_costs, iv_ca_dump, find_optimal_iv_set): Use
3328 int64_t's format specifier in dump.
3329
3330 2019-05-08 Bin Cheng <bin.cheng@linux.alibaba.com>
3331
3332 PR tree-optimization/90240
3333 * tree-ssa-loop-ivopts.c (get_scaled_computation_cost_at): Scale cost
3334 with respect to scaling factor pre-computed for each basic block.
3335 (try_improve_iv_set): Return bool if best_cost equals to iv_ca cost.
3336 (find_optimal_iv_set_1): Free iv_ca set if it has infinite_cost.
3337 (COST_SCALING_FACTOR_BOUND, determine_scaling_factor): New.
3338 (tree_ssa_iv_optimize_loop): Call determine_scaling_factor. Extend
3339 live range for array of loop's basic blocks. Cleanup aux field of
3340 loop's basic blocks.
3341
3342 2019-05-08 Jakub Jelinek <jakub@redhat.com>
3343
3344 PR tree-optimization/90356
3345 * match.pd ((X +/- 0.0) +/- 0.0): Optimize into X +/- 0.0 if possible.
3346
3347 2019-05-07 Wei Xiao <wei3.xiao@intel.com>
3348
3349 * common/config/i386/i386-common.c (OPTION_MASK_ISA_AVX512BF16_SET
3350 OPTION_MASK_ISA_AVX512BF16_UNSET, OPTION_MASK_ISA2_AVX512BW_UNSET): New.
3351 (OPTION_MASK_ISA2_AVX512F_UNSET): Add OPTION_MASK_ISA_AVX512BF16_UNSET.
3352 (ix86_handle_option): Handle -mavx512bf16.
3353 * config.gcc: Add avx512bf16vlintrin.h and avx512bf16intrin.h
3354 to extra_headers.
3355 * config/i386/avx512bf16vlintrin.h: New.
3356 * config/i386/avx512bf16intrin.h: New.
3357 * config/i386/cpuid.h (bit_AVX512BF16): New.
3358 * config/i386/driver-i386.c (host_detect_local_cpu): Detect BF16.
3359 * config/i386/i386-builtin-types.def: Add new types.
3360 * config/i386/i386-builtin.def: Add new builtins.
3361 * config/i386/i386-c.c (ix86_target_macros_internal): Define
3362 __AVX512BF16__.
3363 * config/i386/i386-option.c (ix86_target_string): Add -mavx512bf16.
3364 (ix86_option_override_internal): Handle BF16.
3365 (ix86_valid_target_attribute_inner_p): Ditto.
3366 * config/i386/i386-expand.c (ix86_expand_args_builtin): Ditto.
3367 * config/i386/i386-builtin.c (enum processor_features): Add
3368 F_AVX512BF16.
3369 (static const _isa_names_table isa_names_table): Ditto.
3370 * config/i386/i386.h (TARGET_AVX512BF16, TARGET_AVX512BF16_P): New.
3371 (PTA_AVX512BF16): Ditto.
3372 * config/i386/i386.opt: Add -mavx512bf16.
3373 * config/i386/immintrin.h: Include avx512bf16intrin.h
3374 and avx512bf16vlintrin.h.
3375 * config/i386/sse.md (avx512f_cvtne2ps2bf16_<mode><mask_name>,
3376 avx512f_cvtneps2bf16_<mode><mask_name>,
3377 avx512f_dpbf16ps_<mode><mask_half_name>): New define_insn patterns.
3378 * config/i386/subst.md (mask_half): Add new subst.
3379 * doc/invoke.texi: Document -mavx512bf16.
3380
3381 2019-05-07 Segher Boessenkool <segher@kernel.crashing.org>
3382
3383 * config/rs6000/rs6000-protos.h (rs6000_legitimize_reload_address_ptr):
3384 Delete declaration.
3385 * config/rs6000/rs6000.c (rs6000_legitimize_reload_address): Delete.
3386 (rs6000_debug_legitimize_reload_address): Delete.
3387 (rs6000_legitimize_reload_address_ptr): Delete.
3388 (rs6000_option_override_internal): Adjust.
3389 (mem_operand_gpr): Adjust comment.
3390 (legitimate_lo_sum_address_p): Ditto.
3391 (rs6000_legitimize_reload_address): Delete.
3392 (rs6000_debug_legitimize_reload_address): Delete.
3393 * config/rs6000/rs6000.h (LEGITIMIZE_RELOAD_ADDRESS): Delete.
3394
3395 2019-05-07 Kelvin Nilsen <kelvin@gcc.gnu.org>
3396
3397 PR target/89765
3398 * config/rs6000/rs6000-c.c (altivec_resolve_overloaded_builtin):
3399 In handling of ALTIVEC_BUILTIN_VEC_INSERT, use modular arithmetic
3400 to compute vector element selector for both constant and variable
3401 operands.
3402
3403 2019-05-07 Uroš Bizjak <ubizjak@gmail.com>
3404
3405 * config/i386/i386.md (cvt_mnemonic): New mode attribute.
3406 (ashr<mode>3_cvt): Merge insn pattern from ashrsi3_cvt and
3407 ashrdi3_cvt using SWI48 mode iterator.
3408
3409 2019-05-07 Alejandro Martinez <alejandro.martinezvicente@arm.com>
3410
3411 * config/aarch64/aarch64-sve.md (<su>abd<mode>_3): New define_expand.
3412 (aarch64_<su>abd<mode>_3): Likewise.
3413 (*aarch64_<su>abd<mode>_3): New define_insn.
3414 (<sur>sad<vsi2qi>): New define_expand.
3415 * config/aarch64/iterators.md: Added MAX_OPP attribute.
3416 * tree-vect-loop.c (use_mask_by_cond_expr_p): Add SAD_EXPR.
3417 (build_vect_cond_expr): Likewise.
3418
3419 2019-05-07 Uroš Bizjak <ubizjak@gmail.com>
3420
3421 * cfgexpand.c (asm_clobber_reg_is_valid): Reject
3422 clobbers outside of accessible_reg_set.
3423 * config/i386/i386.c (ix86_conditional_register_usage):
3424 Disable register sets by clearing corresponding bits in
3425 accessible_reg_set. Do not set corresponding bits in fixed_regs,
3426 call_used_regs and don't clear corresponding reg_names array members.
3427
3428 2019-05-07 Richard Biener <rguenther@suse.de>
3429
3430 * tree-vect-stmts.c (vect_is_simple_cond): When vectype is
3431 not specified still compute a comp_vectype for invariant
3432 compares.
3433
3434 2019-05-07 Richard Biener <rguenther@suse.de>
3435
3436 PR tree-optimization/90316
3437 * tree-ssa-pre.c (translate_vuse_through_block): When
3438 same_valid is NULL do not bother to search for a virtual
3439 PHI continuation.
3440 (phi_translate_1): When operands changed we cannot keep
3441 the same value-number so do not bother to ask whether
3442 that's possible from translate_vuse_through_block.
3443
3444 2019-05-07 Martin Liska <mliska@suse.cz>
3445
3446 * bitmap.c (bitmap_register): Come up with
3447 alloc_descriptor_max_uid and assign it for
3448 a new bitmap.
3449 (register_overhead): Use get_descriptor as
3450 a descriptor.
3451 (release_overhead): New.
3452 (bitmap_elem_to_freelist): Call it.
3453 (bitmap_elt_clear_from): Likewise.
3454 (bitmap_obstack_free): Likewise.
3455 (bitmap_move): Sensitively release memory.
3456 * bitmap.h (struct GTY): Add alloc_descriptor and padding.
3457 (bitmap_initialize): Initialize alloc_descriptor to zero.
3458 * tree-ssa-pre.c (do_hoist_insertion): Use bitmap_move.
3459
3460 2019-05-07 Richard Biener <rguenther@suse.de>
3461
3462 * tree-vect-slp.c (vect_build_slp_tree_2): Bump size whenever
3463 we build a SLP node. Remove max_size and limiting.
3464 (vect_analyze_slp_instance): Record and dump size of the SLP graph.
3465
3466 2019-05-07 Richard Biener <rguenther@suse.de>
3467
3468 PR tree-optimization/90316
3469 * tree-ssa-alias.h (get_continuation_for_phi): Take walking
3470 limit by reference.
3471 (walk_non_aliased_vuses): Take walking limit argument.
3472 * tree-ssa-alias.c (maybe_skip_until): Take limit and abort
3473 walking if it is reached instead of just counting.
3474 (get_continuation_for_phi): Likewise.
3475 (walk_non_aliased_vuses): Likewise, instead of leaving counter
3476 limiting to the callback.
3477 * tree-ssa-sccvn.c (vn_reference_lookup_2): Adjust.
3478 (vn_reference_lookup_3): Likewise.
3479 (vn_reference_lookup_pieces): Likewise.
3480 (vn_reference_lookup): Likewise.
3481 * tree-ssa-pre.c (translate_vuse_through_block): Limit walking.
3482 * tree-ssa-scopedtables.c (vuse_eq): Adjust.
3483 (avail_exprs_stack::lookup_avail_expr): Likewise.
3484
3485 2019-05-07 Jan Hubicka <hubicka@ucw.cz>
3486
3487 * tree-ssa-alias.c (aliasing_component_refs_p): Continue looking
3488 for comparaible types in the second direction even if first one
3489 hits incomparable type.
3490
3491 2019-05-07 Richard Biener <rguenther@suse.de>
3492
3493 PR lto/90369
3494 * lto-wrapper.c (debug_objcopy): Use the original filename
3495 including archive offset for the filename used for -save-temps.
3496
3497 2019-05-07 Li Jia He <helijia@linux.ibm.com>
3498
3499 * tree-ssa-phiopt.c (two_value_replacement): Fix a typo in parameter
3500 detection.
3501
3502 2019-05-06 H.J. Lu <hongjiu.lu@intel.com>
3503 Hongtao Liu <hongtao.liu@intel.com>
3504
3505 PR target/89750
3506 PR target/86444
3507 * config/i386/i386-expand.c (ix86_expand_sse_comi_round):
3508 Modified, original implementation isn't correct.
3509
3510 2019-05-06 Segher Boessenkool <segher@kernel.crashing.org>
3511
3512 * config/rs6000/rs6000.md (FIRST_ALTIVEC_REGNO, LAST_ALTIVEC_REGNO)
3513 (LR_REGNO, CTR_REGNO, CA_REGNO, ARG_POINTER_REGNUM, CR0_REGNO)
3514 (CR1_REGNO, CR2_REGNO, CR3_REGNO, CR4_REGNO, CR5_REGNO, CR6_REGNO)
3515 (CR7_REGNO, MAX_CR_REGNO, VRSAVE_REGNO, VSCR_REGNO)
3516 (FRAME_POINTER_REGNUM): Change numbering.
3517 * config/rs6000/rs6000.c (rs6000_reg_names): Adjust.
3518 (alt_reg_names): Adjust.
3519 (rs6000_conditional_register_usage): Don't mark hard register 64 as
3520 fixed.
3521 * config/rs6000/rs6000.h (FIRST_PSEUDO_REGISTER): Adjust.
3522 (DWARF_FRAME_REGISTERS): Delete.
3523 (DWARF2_FRAME_REG_OUT): Fix whitespace.
3524 (FIXED_REGISTERS, CALL_USED_REGISTERS, CALL_REALLY_USED_REGISTERS):
3525 Adjust.
3526 (REG_ALLOC_ORDER): Adjust.
3527 (FRAME_POINTER_REGNUM, ARG_POINTER_REGNUM): Adjust.
3528 (REG_CLASS_CONTENTS): Adjust.
3529 (RETURN_ADDR_RTX): Change comment.
3530 (REGNO_OK_FOR_INDEX_P, REGNO_OK_FOR_BASE_P): Use ARG_POINTER_REGNUM
3531 instead of 67.
3532 (REGISTER_NAMES): Adjust.
3533 (ADDITIONAL_REGISTER_NAMES): Adjust.
3534 * config/rs6000/darwin.h (REGISTER_NAMES): Adjust.
3535
3536 2019-05-06 Segher Boessenkool <segher@kernel.crashing.org>
3537
3538 * config/rs6000/rs6000.md (TFHAR_REGNO, TFIAR_REGNO, TEXASR_REGNO):
3539 Delete.
3540 * config/rs6000/rs6000.h (FIRST_PSEUDO_REGISTER): Adjust.
3541 (DWARF_FRAME_REGISTERS): Adjust.
3542 (FIXED_REGISTERS, CALL_USED_REGISTERS, CALL_REALLY_USED_REGISTERS):
3543 Adjust.
3544 (REG_ALLOC_ORDER): Adjust.
3545 (enum reg_class): Delete SPR_REGS.
3546 (REG_CLASS_NAMES): Delete SPR_REGS.
3547 (REG_CLASS_CONTENTS): Delete SPR_REGS. Adjust for deleted TM regs.
3548 (REGISTER_NAMES): Adjust.
3549 (ADDITIONAL_REGISTER_NAMES): Adjust.
3550 * config/rs6000/darwin.h (REGISTER_NAMES): Adjust.
3551 * config/rs6000/htm.md (htm_mfspr_<mode>, htm_mtspr_<mode>): Adjust.
3552 * config/rs6000/predicates.md (htm_spr_reg_operand): Delete.
3553 * config/rs6000/rs6000.c (rs6000_init_hard_regno_mode_ok): Adjust.
3554 (htm_spr_regno): Delete.
3555 (htm_expand_builtin): Adjust: the HTM builtins now have one fewer
3556 argument.
3557 (rs6000_dbx_register_number): Adjust.
3558
3559 2019-05-06 Segher Boessenkool <segher@kernel.crashing.org>
3560
3561 * config/rs6000/rs6000.h (PRE_GCC3_DWARF_FRAME_REGISTERS): Delete.
3562
3563 2019-05-06 Segher Boessenkool <segher@kernel.crashing.org>
3564
3565 * config/rs6000/rs6000.c (rs6000_dbx_register_number): Handle
3566 FRAME_POINTER_REGNUM, ARG_POINTER_REGNUM, and 64 (which was MQ).
3567
3568 2019-05-06 Jakub Jelinek <jakub@redhat.com>
3569
3570 PR tree-optimization/88709
3571 PR tree-optimization/90271
3572 * params.def (PARAM_STORE_MERGING_MAX_SIZE): New parameter.
3573 * gimple-ssa-store-merging.c (encode_tree_to_bitpos): Handle
3574 non-clobber CONSTRUCTORs with no elts. Remove useless tmp_int
3575 variable.
3576 (imm_store_chain_info::coalesce_immediate_stores): Punt if the size
3577 of the store merging group is larger than
3578 PARAM_STORE_MERGING_MAX_SIZE parameter.
3579 (split_group): Add bzero_first argument. If set, always emit first
3580 the first store which must be = {} of the whole area and then for the
3581 rest of the stores consider all zero bytes as paddings.
3582 (imm_store_chain_info::output_merged_store): Check if first store
3583 is = {} of the whole area and if yes, determine which setting of
3584 bzero_first for split_group gives smaller number of stores. Adjust
3585 split_group callers.
3586 (lhs_valid_for_store_merging_p): Allow decls.
3587 (rhs_valid_for_store_merging_p): Allow non-clobber CONTRUCTORs with
3588 no elts.
3589 (pass_store_merging::process_store): Likewise.
3590
3591 2019-05-06 Kelvin Nilsen <kelvin@gcc.gnu.org>
3592
3593 PR target/89424
3594 * config/rs6000/rs6000.c (rs6000_expand_vector_extract): Add
3595 handling of V1TImode.
3596
3597 2019-05-06 Uroš Bizjak <ubizjak@gmail.com>
3598
3599 PR target/89221
3600 * config.gcc (i[34567]86-*-*, x86_64-*-*): Move tests for enable_cld
3601 and enable_frame_pointer ...
3602 * configure.ac: ... here. Update help strings for
3603 --enable-frame-pointer.
3604 * configure: Regenerate.
3605 * config/i386/i386-options.c (ix86_option_override_internal): Remove
3606 USE_X86_64_FRAME_POINTER define, use USE_IX86_FRAME_POINTER instead.
3607 * config/i386/sol2.h (USE_IX86_FRAME_POINTER): Remove.
3608 (USE_X86_64_FRAME_POINTER): Ditto.
3609
3610 2019-05-06 Martin Liska <mliska@suse.cz>
3611
3612 * config.gcc: Append to target_gtfiles and fix indentation.
3613
3614 2019-05-06 Richard Biener <rguenther@suse.de>
3615
3616 PR tree-optimization/90358
3617 * tree-vect-stmts.c (get_group_load_store_type): Properly
3618 detect unused upper half of load.
3619 (vectorizable_load): Likewise.
3620
3621 2019-05-06 Richard Biener <rguenther@suse.de>
3622
3623 PR tree-optimization/88828
3624 * tree-ssa-forwprop.c (get_bit_field_ref_def): Split out from...
3625 (simplify_vector_constructor): ...here. Handle constants in
3626 the constructor.
3627
3628 2019-05-06 Richard Biener <rguenther@suse.de>
3629
3630 PR tree-optimization/90328
3631 * tree-data-ref.h (dr_may_alias_p): Pass in the actual loop nest.
3632 * tree-data-ref.c (dr_may_alias_p): Check whether the clique
3633 is valid in the loop nest before using it.
3634 (initialize_data_dependence_relation): Adjust.
3635 * graphite-scop-detection.c (build_alias_set): Pass the SCOP enclosing
3636 loop as loop-nest to dr_may_alias_p.
3637
3638 2019-05-06 Richard Biener <rguenther@suse.de>
3639
3640 * dwarf2out.c (mem_loc_descriptor): Initialize int_mode.
3641
3642 2019-05-06 Richard Biener <rguenther@suse.de>
3643
3644 PR tree-optimization/90316
3645 * tree-ssa-alias.c (maybe_skip_until): Pass in target BB,
3646 compute target on demand.
3647 (get_continuation_for_phi): Remove code walking stmts to
3648 get to a target virtual operand which could end up being
3649 quadratic.
3650
3651 2019-05-06 Martin Liska <mliska@suse.cz>
3652
3653 PR sanitizer/90312
3654 * config/i386/i386-options.c (ix86_option_override_internal): Error only
3655 when -mabi is selected to a non-default version.
3656
3657 2019-05-06 Hrishikesh Kulkarni <hrishikeshparag@gmail.com>
3658 Martin Liska <mliska@suse.cz>
3659
3660 * Makefile.in: Add lto-dump.texi.
3661 * cgraph.h: Add new functions get_visibility_string and
3662 get_symtab_type_string.
3663 * doc/gcc.texi: Include lto-dump section.
3664 * doc/lto-dump.texi: New file.
3665 * dumpfile.c (dump_switch_p_1): Use parse_dump_option.
3666 (parse_dump_option): Factor out this function.
3667 * dumpfile.h (enum dump_flag): Add new value TDF_ERROR.
3668 (parse_dump_option): Export the function.
3669 * symtab.c (symtab_node::get_visibility_string): New function.
3670 (symtab_node::get_symtab_type_string): Likewise.
3671
3672 2019-05-06 Martin Liska <mliska@suse.cz>
3673
3674 * config/i386/i386-builtins.c: New file.
3675 * config/i386/i386-builtins.h: New file.
3676 * config/i386/i386-expand.c: New file.
3677 * config/i386/i386-expand.h: New file.
3678 * config/i386/i386-features.c: New file.
3679 * config/i386/i386-features.h: New file.
3680 * config/i386/i386-options.c: New file.
3681 * config/i386/i386-options.h: New file.
3682 * config.gcc: Add new files into extra_objs and
3683 target_gtfiles.
3684 * config/i386/i386.c: Split content of the file
3685 into newly introduced files.
3686 * config/i386/i386.h: Declare common variables
3687 and macros.
3688 * config/i386/t-i386: Define dependencies for new files.
3689
3690 2019-05-03 Richard Earnshaw <rearnsha@arm.com>
3691
3692 PR target/89400
3693 * config/arm/arm.md (unaligned_loadsi): Add variant for thumb1.
3694 Restrict 'all' variant to 32-bit configurations.
3695 (unaligned_loadhiu): Likewise.
3696 (unaligned_storehi): Likewise.
3697 (unaligned_storesi): Likewise.
3698 (unaligned_loadhis): Disable when compiling for thumb1.
3699
3700 2019-05-03 Marc Glisse <marc.glisse@inria.fr>
3701
3702 PR tree-optimization/90269
3703 * tree-loop-distribution.c (find_seed_stmts_for_distribution):
3704 Ignore clobbers.
3705
3706 2019-05-03 Martin Liska <mliska@suse.cz>
3707
3708 * hash-map.h: Add is_empty function.
3709 * hash-set.h: Likewise.
3710 * hash-table.h: Likewise.
3711 * dwarf2out.c (dwarf2out_finish): Use is_empty instead of
3712 elements () == 0 (and similar usages).
3713 * gimple-ssa-store-merging.c (pass_store_merging::terminate_and_process_all_chains): Likewise.
3714 * gimplify.c (gimplify_bind_expr): Likewise.
3715 (gimplify_switch_expr): Likewise.
3716 * hash-map-tests.c (test_map_of_strings_to_int): Likewise.
3717 * ipa-icf.c (sem_item_optimizer::remove_symtab_node): Likewise.
3718 * postreload-gcse.c (dump_hash_table): Likewise.
3719 (gcse_after_reload_main): Likewise.
3720 * predict.c (combine_predictions_for_bb): Likewise.
3721 * tree-parloops.c (reduction_phi): Likewise.
3722 (separate_decls_in_region): Likewise.
3723 (transform_to_exit_first_loop): Likewise.
3724 (gen_parallel_loop): Likewise.
3725 (gather_scalar_reductions): Likewise.
3726 (try_create_reduction_list): Likewise.
3727 * var-tracking.c (dump_vars): Likewise.
3728 (emit_notes_for_changes): Likewise.
3729 (vt_emit_notes): Likewise.
3730
3731 2019-05-03 Richard Biener <rguenther@suse.de>
3732
3733 PR tree-optimization/90316
3734 * tree-ssa-pre.c (pass_pre::execute): Re-compute DOM fast queries
3735 before running VN.
3736
3737 2019-05-03 Richard Biener <rguenther@suse.de>
3738
3739 * tree-vect-stmts.c (get_group_load_store_type): Avoid
3740 peeling for gaps by loading only lower halves of vectors
3741 if possible.
3742 (vectorizable_load): Likewise.
3743
3744 2019-05-03 Richard Biener <rguenther@suse.de>
3745
3746 PR middle-end/89518
3747 * match.pd: Add pattern to optimize (A / B) * B + (A % B) to A.
3748
3749 2019-05-03 Richard Biener <rguenther@suse.de>
3750
3751 PR middle-end/87314
3752 * match.pd (cmp (convert1?@2 addr@0) (convert2? addr@1)):
3753 Handle STRING_CST vs DECL or STRING_CST.
3754
3755 2019-05-03 Richard Biener <rguenther@suse.de>
3756
3757 PR tree-optimization/88963
3758 * tree-ssa-forwprop.c (pass_forwprop::execute): Rewrite
3759 vector loads feeding only BIT_FIELD_REFs to component
3760 loads. Rewrite stores fed by CONSTRUCTORs to component
3761 stores.
3762
3763 2019-05-03 Jakub Jelinek <jakub@redhat.com>
3764
3765 * opts.h (finish_options): Remove lang_mask argument.
3766 (print_help, help_option_argument): Declare.
3767 * opts.c (print_help): Remove forward declaration, no longer static.
3768 (finish_options): Remove lang_mask argument, don't call print_help
3769 here.
3770 * opts-global.c (decode_options): Adjust finish_option caller, call
3771 print_help here.
3772
3773 PR tree-optimization/90303
3774 * ipa-devirt.c (obj_type_ref_class, get_odr_type): Don't use
3775 TYPE_CANONICAL for TYPE_STRUCTURAL_EQUALITY_P types in !in_lto_p mode.
3776
3777 2019-05-03 Richard Biener <rguenther@suse.de>
3778
3779 PR tree-optimization/89698
3780 * gimple-fold.c (canonicalize_constructor_val): Early out
3781 for constants, handle unfolded INTEGER_CSTs as they appear in
3782 C++ virtual table ctors.
3783
3784 2019-05-03 Richard Biener <rguenther@suse.de>
3785
3786 * passes.c (execute_function_todo): Remove dead code.
3787
3788 2019-05-02 Segher Boessenkool <segher@kernel.crashing.org>
3789
3790 * config/rs6000/rs6000.c (rs6000_dbx_register_number): Do not use
3791 the internal register number, for any "real" register.
3792
3793 2019-05-02 Segher Boessenkool <segher@kernel.crashing.org>
3794
3795 * config/rs6000/rs6000.c (rs6000_dbx_register_number): Return the
3796 correct numbers for TFHAR, TFIAR, TEXASR.
3797
3798 2019-05-02 Richard Biener <rguenther@suse.de>
3799
3800 PR tree-optimization/89653
3801 * tree-ssa-loop.c (pass_data_tree_loop_init): Execute
3802 update-address-taken before the pass.
3803 * passes.def (pass_tree_loop_init): Put comment before it.
3804
3805 2019-05-02 Richard Biener <rguenther@suse.de>
3806
3807 PR tree-optimization/89509
3808 * tree-ssa-structalias.c (compute_dependence_clique): Look
3809 at the first subvar when determining whether it is restrict.
3810
3811 2019-05-02 Richard Biener <rguenther@suse.de>
3812
3813 PR tree-optimization/90273
3814 * tree-ssa-dce.c (eliminate_unnecessary_stmts): Eliminate
3815 useless debug stmts.
3816
3817 2019-05-02 Alejandro Martinez <alejandro.martinezvicente@arm.com>
3818
3819 * config/aarch64/aarch64-sve.md (<sur>dot_prod<vsi2qi>): Taken from SVE
3820 ACLE branch.
3821 * config/aarch64/iterators.md: Copied Vetype_fourth, VSI2QI and vsi2qi from
3822 SVE ACLE branch.
3823 * tree-vect-loop.c (use_mask_by_cond_expr_p): New function to check if a
3824 VEC_COND_EXPR be inserted to emulate a conditional internal function.
3825 (build_vect_cond_expr): Emit the VEC_COND_EXPR.
3826 (vectorizable_reduction): Use the functions above to vectorize in a
3827 fully masked loop codes that don't have a conditional internal
3828 function.
3829
3830 2019-05-02 Martin Liska <mliska@suse.cz>
3831
3832 * cgraphclones.c: Call valid_attribute_p with 1 for
3833 target_clone.
3834 * config/i386/i386-c.c (ix86_pragma_target_parse): Use 0 as
3835 it's for target attribute.
3836 * config/i386/i386-protos.h (ix86_valid_target_attribute_tree):
3837 Add new boolean argument.
3838 * config/i386/i386.c (ix86_valid_target_attribute_inner_p):
3839 Likewise.
3840 (ix86_valid_target_attribute_tree): Pass target_clone_attr
3841 to ix86_valid_target_attribute_inner_p.
3842 (ix86_valid_target_attribute_p): Pass flags argument to
3843 ix86_valid_target_attribute_inner_p.
3844 (get_builtin_code_for_version): Use 0 as it's target attribute.
3845
3846 2019-05-02 Martin Liska <mliska@suse.cz>
3847
3848 * gcc.c (process_command): Add dummy file only
3849 if n_infiles == 0.
3850 * opts-global.c (decode_options): Pass lang_mask.
3851 * opts.c (print_help): New function.
3852 (finish_options): Print --help if help_option_argument
3853 is set.
3854 (common_handle_option): Factor out content of OPT__help_
3855 into print_help.
3856 * opts.h (finish_options): Add new argument.
3857
3858 2019-05-02 Martin Liska <mliska@suse.cz>
3859
3860 PR target/88809
3861 * config/i386/i386.c (ix86_expand_strlen): Use strlen call.
3862 With -minline-all-stringops use inline expansion using 4B loop.
3863 * doc/invoke.texi: Document the change of
3864 -minline-all-stringops.
3865
3866 2019-05-01 Jeff Law <law@redhat.com>
3867
3868 PR tree-optimization/88797
3869 * gimple-ssa-split-paths (is_feasible_trace): Reject cases where the
3870 PHI feeds a conditional on the RHS of an assignment.
3871
3872 2019-04-30 Andrew Waterman <andrew@sifive.com>
3873 Jim Wilson <jimw@sifive.com>
3874
3875 * config/riscv/constraints.md (L): New.
3876 * config/riscv/predicates.md (lui_operand): New.
3877 (sfb_alu_operand): New.
3878 * config/riscv/riscv-protos.h (riscv_expand_conditional_move): Declare.
3879 * config/riscv/riscv.c (riscv_expand_conditional_move): New.
3880 * config/riscv/riscv.h (TARGET_SFB_ALU): New.
3881 * config/riscv/risc.md (type): Add sfb_alu.
3882 (branch<mode>): Renamed from branch_order<mode>. Change predicate for
3883 operand 3 to reg_or_0_operand. In output string, change %3 to %z3.
3884 (branch_zero<mode>): Delete.
3885 (mov<mode>cc): New.
3886 (mov<GPR:mode><X:mode>cc): Likewise.
3887 * config/riscv/sifive-7.md (sifive_7_sfb_alu): New. Use in bypasses.
3888
3889 2019-04-30 Nathan Sidwell <nathan@acm.org>
3890
3891 * tree.h (MARK_TS_EXP): New.
3892
3893 2019-04-30 Martin Liska <mliska@suse.cz>
3894
3895 * opts.c (enable_warning_as_error): Provide hints
3896 for unknown options.
3897
3898 2019-04-30 Martin Liska <mliska@suse.cz>
3899
3900 PR debug/90288
3901 * doc/invoke.texi: Add missing dash for gas-locview-support
3902 and gno-as-locview-support.
3903
3904 2019-04-30 Jakub Jelinek <jakub@redhat.com>
3905
3906 PR target/89093
3907 * config/aarch64/aarch64.c (aarch64_process_one_target_attr): Don't skip
3908 whitespace at the start of target attribute string.
3909
3910 2019-04-30 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
3911
3912 PR target/86538
3913 * config/aarch64/aarch64-c.c (aarch64_update_cpp_builtins):
3914 Define __ARM_FEATURE_ATOMICS.
3915
3916 2019-04-30 Martin Liska <mliska@suse.cz>
3917
3918 * gimple-fold.c (gimple_fold_builtin_memory_op): Change endp
3919 into built_in_function enum. Remove code for endp == 2 and
3920 use BUILT_IN_* constants.
3921 (gimple_fold_builtin): Call the function with fcode.
3922
3923 2019-04-30 Martin Liska <mliska@suse.cz>
3924
3925 * config/i386/i386.c (ix86_builtin_reciprocal): Cast
3926 DECL_FUNCTION_CODE into ix86_builtins enum before
3927 the switch statement.
3928
3929 2019-04-30 Jakub Jelinek <jakub@redhat.com>
3930
3931 PR tree-optimization/89475
3932 * tree-ssa-ccp.c (evaluate_stmt): Handle BUILT_IN_BSWAP{16,32,64}
3933 calls.
3934
3935 2019-04-30 Martin Liska <mliska@suse.cz>
3936
3937 PR translation/90274
3938 * opts.c (print_filtered_help): Wrap string in _(...).
3939
3940 2019-04-30 Bin Cheng <bin.cheng@linux.alibaba.com>
3941
3942 PR tree-optimization/90240
3943 Revert:
3944 2019-04-23 Bin Cheng <bin.cheng@linux.alibaba.com>
3945
3946 PR tree-optimization/90078
3947 * tree-ssa-loop-ivopts.c (comp_cost::operator +,-,+=,-+,/=,*=): Add
3948 checks for infinite_cost overflow.
3949
3950 2019-04-29 Jeff Law <law@redhat.com>
3951
3952 * passes.def: Move -Wrestrict pass after copy propagation.
3953
3954 2019-04-29 Maya Rashish <coypu@sdf.org>
3955
3956 * config.gcc (default_gnu_indirect_function): Default to yes
3957 for arm*-*-netbsd*, i[34567]86-*-netbsd*, powerpc*-*-netbsd*,
3958 sparc*-*-netbsd*, x86_64-*-netbsd*.
3959
3960 2019-04-29 Vladislav Ivanishin <vlad@ispras.ru>
3961
3962 * tree-ssa-uninit.c (is_pred_expr_subset_of): Correctly handle cases
3963 where cond2 is NE_EXPR.
3964 (is_value_included_in): Update comment.
3965
3966 2019-04-29 Richard Biener <rguenther@suse.de>
3967
3968 PR tree-optimization/90278
3969 * tree-ssa-forwprop.c (pass_forwprop::execute): Transfer/clean
3970 EH on comparison simplification.
3971
3972 2019-04-29 Jason Merrill <jason@redhat.com>
3973
3974 PR c++/82081 - tail call optimization breaks noexcept
3975 * tree-tailcall.c (find_tail_calls): Don't turn a call from a
3976 nothrow function to a might-throw function into a tail call.
3977
3978 2019-04-29 Richard Sandiford <richard.sandiford@arm.com>
3979
3980 * tree-data-ref.h (data_dependence_relation::inner_loop): Delete.
3981 (DDR_INNER_LOOP): Likewise.
3982 * tree-data-ref.c (dump_data_dependence_relation): Update accordingly.
3983 (initialize_data_dependence_relation): Likewise.
3984 (insert_innermost_unit_dist_vector): Use 0 instead of DDR_INNER_LOOP.
3985
3986 2019-04-29 Jakub Jelinek <jakub@redhat.com>
3987
3988 PR rtl-optimization/90257
3989 * cfgrtl.c (flow_active_insn_p): Return true for USE of a function
3990 return value.
3991
3992 Revert the revert:
3993 2019-04-21 H.J. Lu <hongjiu.lu@intel.com>
3994
3995 PR target/90178
3996 Revert:
3997 2018-11-21 Uros Bizjak <ubizjak@gmail.com>
3998
3999 Revert the revert:
4000 2013-10-26 Vladimir Makarov <vmakarov@redhat.com>
4001
4002 Revert:
4003 2013-10-25 Vladimir Makarov <vmakarov@redhat.com>
4004
4005 * lra-spills.c (lra_final_code_change): Remove useless move insns.
4006
4007 2019-04-29 Richard Biener <rguenther@suse.de>
4008
4009 * tree-ssa.c (insert_debug_temp_for_var_def): For {CLOBBER}
4010 rhs issue a reset.
4011
4012 2019-04-27 Iain Buclaw <ibuclaw@gdcproject.org>
4013
4014 * config/netbsd-d.c: Include memmodel.h. Remove unused tree.h,
4015 varasm.h, and netbsd-protos.h.
4016
4017 2019-04-27 Uroš Bizjak <ubizjak@gmail.com>
4018
4019 PR target/89261
4020 * config/i386/i386-protos.h (ix86_data_alignment): Change
4021 the second argument type to unsigned int.
4022 * config/i386/i386.c (ix86_data_alignment): Change "align"
4023 argument type to unsigned int.
4024
4025 2019-04-27 Martin Liska <mliska@suse.cz>
4026
4027 PR middle-end/90258
4028 * opt-suggestions.c (option_proposer::build_option_suggestions):
4029 When get_valid_option_values returns empty values, add the
4030 misspelling candidate.
4031
4032 2019-04-26 Jim Wilson <jimw@sifive.com>
4033
4034 * config/riscv/riscv-protos.h (riscv_move_integer): Add machine_mode
4035 parameter.
4036 * config/riscv/riscv.c (riscv_move_integer): New parameter orig_mode.
4037 Pass orig_mode to riscv_build_integer.
4038 (riscv_split_integer): Pass mode to riscv_move_integer.
4039 (riscv_legitimize_const_move): Likewise.
4040 (riscv_legitimize_move): For MEM dest and CONST_INT src case, new local
4041 promoted_mode. Replace force_reg call with code to load constant into
4042 promoted reg and then subreg it for the store.
4043 * config/riscv/riscv.md (low<mode>+1): Pass <GPR:MODE>mode to
4044 riscv_move_integer.
4045
4046 2018-04-26 Eugene Sharygin <eush@ispras.ru>
4047
4048 * gdbhooks.py: Fix UnicodeDecodeErrors when printing trees with
4049 corrupt codes.
4050
4051 2019-04-26 Richard Sandiford <richard.sandiford@arm.com>
4052
4053 * tree.h (TYPE_VECTOR_SUBPARTS, SET_TYPE_VECTOR_SUBPARTS): Add
4054 commentary about the encoding of precision.
4055
4056 2019-04-25 Andreas Tobler <andreast@gcc.gnu.org>
4057
4058 * config/i386/freebsd64.h: Add bits for 32-bit multilib support.
4059 * config/i386/t-freebsd64: New file.
4060 * config.gcc: Add the t-freebsd64 for multilib support.
4061
4062 2019-04-25 Uroš Bizjak <ubizjak@gmail.com>
4063
4064 * doc/extend.texi (vector_size): Add missing comma after @xref.
4065
4066 2019-04-25 Jakub Jelinek <jakub@redhat.com>
4067
4068 * BASE-VER: Set to 10.0.0.
4069
4070 2019-04-25 Richard Biener <rguenther@suse.de>
4071
4072 PR middle-end/89765
4073 * gimplify.c (gimplify_expr): Avoid turning a lvalue
4074 VIEW_CONVERT_EXPR into one operating on an rvalue.
4075
4076 2019-04-25 H.J. Lu <hongjiu.lu@intel.com>
4077
4078 PR target/89929
4079 * config/i386/i386.c (feature_priority): Moved to file scope.
4080 (processor_features): Likewise.
4081 (processor_model): Likewise.
4082 (_arch_names_table): Likewise.
4083 (arch_names_table): Likewise.
4084 (_feature_list): Removed.
4085 (feature_list): Likewise.
4086 (_isa_names_table): Moved to file scope. Add priority.
4087 (isa_names_table): Likewise.
4088 (get_builtin_code_for_version): Replace feature_list with
4089 isa_names_table. Update error message for P_ZERO priority.
4090
4091 2019-04-25 Richard Biener <rguenther@suse.de>
4092
4093 * tree-pass.h (make_pass_phi_only_cprop): Remove.
4094 * timevar.def (TV_TREE_PHI_CPROP): Likewise.
4095
4096 2019-04-24 Jeff Law <law@redhat.com>
4097
4098 PR tree-optimization/90037
4099 * Makefile.in (OBJS): Remove tree-ssa-phionlycprop.c
4100 * passes.def: Replace all instance of phi-only cprop with the
4101 lattice propagator. Move propagation pass from after erroneous
4102 path isolation to before erroneous path isolation.
4103 * tree-ssa-phionlycprop.c: Remove.
4104
4105 2019-04-24 Richard Biener <rguenther@suse.de>
4106
4107 PR middle-end/90213
4108 * gimple-fold.c (fold_const_aggregate_ref_1): Do multiplication
4109 by size and BITS_PER_UNIT on poly-wide-ints.
4110
4111 2019-04-25 Richard Biener <rguenther@suse.de>
4112
4113 PR middle-end/90194
4114 * match.pd: Add pattern to simplify view-conversion of an
4115 empty constructor.
4116
4117 2019-04-24 Clement Chigot <clement.chigot@atos.net>
4118
4119 * config/rs6000/aix71.h (SUBTARGET_OVERRIDE_OPTIONS): Disable
4120 OPTION_MASK_VSX and OPTION_MASK_ALTIVEC from rs6000_isa_flags
4121 for Go on 32 bit AIX.
4122 * config/rs6000/aix72.h: Likewise.
4123
4124 2019-04-24 Jakub Jelinek <jakub@redhat.com>
4125
4126 PR target/90193
4127 * rtl.c (classify_insn): Return JUMP_INSN for asm goto.
4128 * emit-rtl.c (try_split): Copy over REG_LABEL_TARGET.
4129
4130 2019-04-24 Andreas Krebbel <krebbel@linux.ibm.com>
4131
4132 PR target/89952
4133 * config/s390/s390.c (s390_restore_gprs_from_fprs): Restore GPRs
4134 from FPRs in reverse order. Generate REG_CFA_DEF_CFA note also
4135 for restored hard frame pointer.
4136 (s390_sched_dependencies_evaluation): Implement new target hook.
4137 (TARGET_SCHED_DEPENDENCIES_EVALUATION_HOOK): New macro definition.
4138
4139 2019-04-24 Claudiu Zissulescu <claziss@sysnopsys.com>
4140
4141 * config/arc/arc-options.def: Fix typos and spelling mistakes.
4142 * config/arc/arc.c (arc_init): Cleanup warning message.
4143 (arc_override_options): Likewise.
4144
4145 2019-04-24 Jakub Jelinek <jakub@redhat.com>
4146
4147 PR target/90187
4148 * config/i386/i386.c (ix86_expand_sse_fp_minmax): Force if_true into
4149 a register if both if_true and if_false are MEMs.
4150
4151 PR tree-optimization/90208
4152 * tree-cfg.c (remove_bb): Move forced labels from removed bbs
4153 after labels of new_bb, not before them.
4154
4155 PR tree-optimization/90211
4156 * tree-parloops.c (try_create_reduction_list): Ignore phi arguments
4157 which are not SSA_NAMEs.
4158
4159 2018-04-23 Sudakshina Das <sudi.das@arm.com>
4160
4161 * config/aarch64/aarch64-linux.h (TARGET_ASM_FILE_END): Define for
4162 AArch64.
4163 (aarch64_file_end_indicate_exec_stack): Add gnu note section.
4164
4165 2019-04-23 Roman Zhuykov <zhroma@ispras.ru>
4166
4167 PR rtl-optimization/87979
4168 * modulo-sched.c (sms_schedule): Start ii value "mii" should
4169 not equal zero.
4170
4171 2019-04-23 Roman Zhuykov <zhroma@ispras.ru>
4172
4173 PR rtl-optimization/84032
4174 * modulo-sched.c (ps_insn_find_column): Change condition so that
4175 branch will always be the last insn in a row inside partial
4176 schedule.
4177
4178 2019-04-23 Richard Biener <rguenther@suse.de>
4179
4180 PR debug/90131
4181 * tree-cfgcleanup.c (move_debug_stmts_from_forwarder): Add
4182 dest_single_pred_p argument.
4183 (remove_forwarder_block): Adjust.
4184 (remove_forwarder_block_with_phi): Likewise.
4185
4186 2019-04-23 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
4187 Bernd Edlinger <bernd.edlinger@hotmail.de>
4188 Jakub Jelinek <jakub@redhat.com>
4189
4190 PR target/89093
4191 * config/arm/arm.c (aapcs_vfp_is_call_or_return_candidate): Diagnose
4192 if used with general-regs-only.
4193 (arm_conditional_register_usage): Don't add non-general regs if
4194 general-regs-only.
4195 (arm_valid_target_attribute_rec): Handle general-regs-only.
4196 * config/arm/arm.h (TARGET_HARD_FLOAT): Return false if
4197 general-regs-only.
4198 (TARGET_HARD_FLOAT_SUB): Define.
4199 (TARGET_SOFT_FLOAT): Define as negation of TARGET_HARD_FLOAT_SUB.
4200 (TARGET_REALLY_IWMMXT): Add && !TARGET_GENERAL_REGS_ONLY.
4201 (TARGET_REALLY_IWMMXT2): Likewise.
4202 * config/arm/arm.opt: Add -mgeneral-regs-only.
4203 * doc/extend.texi: Document ARM general-regs-only target.
4204 * doc/invoke.texi: Document ARM -mgeneral-regs-only.
4205
4206 2019-04-23 Bin Cheng <bin.cheng@linux.alibaba.com>
4207
4208 PR tree-optimization/90078
4209 * tree-ssa-loop-ivopts.c (comp_cost::operator +,-,+=,-+,/=,*=): Add
4210 checks for infinite_cost overflow.
4211
4212 2019-04-23 Bin Cheng <bin.cheng@linux.alibaba.com>
4213
4214 PR tree-optimization/90021
4215 * tree-chrec.c (evolution_function_is_univariate_p): New parameter
4216 and check univariate against it.
4217 * tree-chrec.h (evolution_function_is_univariate_p): New parameter.
4218 * tree-data-ref.c (add_other_self_distances): Pass new argument.
4219
4220 2019-04-21 H.J. Lu <hongjiu.lu@intel.com>
4221
4222 PR target/90178
4223 Revert:
4224 2018-11-21 Uros Bizjak <ubizjak@gmail.com>
4225
4226 Revert the revert:
4227 2013-10-26 Vladimir Makarov <vmakarov@redhat.com>
4228
4229 Revert:
4230 2013-10-25 Vladimir Makarov <vmakarov@redhat.com>
4231
4232 * lra-spills.c (lra_final_code_change): Remove useless move insns.
4233
4234 2019-04-21 Iain Sandoe <iain@sandoe.co.uk>
4235
4236 * config/rs6000/rs6000.md (group_end_nop): Emit insn register
4237 names using operand format, rather than hard-wired.
4238 (speculation_barrier): Likewise.
4239
4240 2019-04-19 Segher Boessenkool <segher@kernel.crashing.org>
4241
4242 PR tree-optimization/88055
4243 * tree-call-cdce.c (comparison_code_if_no_nans): New function.
4244 (gen_one_condition): Use it if !HONOR_NANS.
4245
4246 2019-04-19 Jakub Jelinek <jakub@redhat.com>
4247
4248 PR middle-end/90139
4249 * tree-outof-ssa.c (get_temp_reg): If reg_mode is BLKmode, return
4250 assign_temp instead of gen_reg_rtx.
4251
4252 2019-04-19 Christophe Lyon <christophe.lyon@linaro.org>
4253
4254 PR translation/90118
4255 * config/aarch64/aarch64.c (aarch64_override_options_internal):
4256 Add missing space before %<.
4257
4258 2019-04-18 Peter Bergner <bergner@linux.ibm.com>
4259
4260 PR rtl-optimization/87871
4261 * ira-lives.c (make_object_dead): Don't add conflicts to
4262 TOTAL_CONFLICT_HARD_REGS for register ignore_reg_for_conflicts.
4263
4264 2019-04-18 Martin Sebor <msebor@redhat.com>
4265
4266 PR middle-end/89797
4267 * tree.h (TYPE_VECTOR_SUBPARTS): Use HOST_WIDE_INT_1U.
4268 * config/aarch64/aarch64.c (aarch64_simd_vector_alignment): Avoid
4269 assuming type size fits in SHWI.
4270
4271 2019-04-18 Jan Hubicka <hubicka@ucw.cz>
4272
4273 PR ipa/85051
4274 * ipa-inline.c (flatten_function): New parameter UPDATE.
4275 (ipa_inline, early_inliner): Use it.
4276
4277 2019-04-18 Richard Sandiford <richard.sandiford@arm.com>
4278
4279 * fold-const.c (int_const_binop): Return early on failure.
4280
4281 2019-04-18 Richard Sandiford <richard.sandiford@arm.com>
4282
4283 PR middle-end/85164
4284 * combine.c (force_int_to_mode): Cast the argument rather than
4285 the result of known_alignment.
4286 * rtlanal.c (rtx_addr_can_trap_p_1): Use known_subrange_p.
4287
4288 2019-04-18 Richard Biener <rguenther@suse.de>
4289
4290 PR debug/90131
4291 * tree-cfgcleanup.c (move_debug_stmts_from_forwarder): Split
4292 out from ...
4293 (remove_forwarder_block): ... here.
4294 (remove_forwarder_block_with_phi): Also move debug stmts here.
4295
4296 2019-04-18 Jakub Jelinek <jakub@redhat.com>
4297
4298 PR translation/79183
4299 * gimple-ssa-sprintf.c (format_directive): Use inform_n instead of
4300 inform where appropriate.
4301
4302 2019-04-18 Richard Biener <rguenther@suse.de>
4303
4304 * tree.c (get_qualified_type): Put found type variants at the
4305 head of the variant list.
4306
4307 2018-04-17 Segher Boessenkool <segher@kernel.crashing.org>
4308
4309 * config/rs6000/rs6000.c (rs6000_register_move_cost): Fix typo.
4310
4311 2019-04-17 Hongtao Liu <hongtao.liu@intel.com>
4312
4313 PR target/90125
4314 * config/i386/avx512fintrin.h (_mm_maskz_fmadd_round_sd,
4315 _mm_maskz_fmadd_round_ss, _mm_maskz_fmsub_round_sd,
4316 _mm_maskz_fmsub_round_ss, _mm_maskz_fnmadd_round_sd,
4317 _mm_maskz_fnmadd_round_ss, _mm_maskz_fnmsub_round_sd,
4318 _mm_maskz_fnmsub_round_ss): Use _maskz builtin instead of _mask3.
4319
4320 2019-04-17 Peter Bergner <bergner@linux.ibm.com>
4321
4322 * ira-conflicts.c (print_allocno_conflicts): Always print something,
4323 even for allocno's with no conflicts.
4324 (print_conflicts): Print an extra newline.
4325
4326 2019-04-17 Segher Boessenkool <segher@kernel.crashing.org>
4327
4328 * auto-inc-dec.c (attempt_change): Set the alignment of the
4329 temporary memory to that of the original.
4330
4331 2019-04-17 Joao Moreira <jmoreira@suse.de>
4332
4333 * targhooks.c (default_print_patchable_function_entry): Emit
4334 __patchable_function_entries section with writable flags to allow
4335 relocation resolution.
4336
4337 2019-04-17 Jonny Grant <jg@jguk.org>
4338
4339 * collect2.c (main): Change gcc.gnu.org URL to HTTPS.
4340
4341 2019-04-17 Jakub Jelinek <jakub@redhat.com>
4342
4343 PR middle-end/90095
4344 * internal-fn.c (expand_mul_overflow): Don't set SUBREG_PROMOTED_VAR_P
4345 on lowpart SUBREGs.
4346
4347 2019-04-17 Claudiu Zissulescu <claziss@synopsys.com>
4348
4349 * config/arc/arc.c (arc_init): Format diagnostic string.
4350 (arc_override_options): Likewise.
4351 (check_if_valid_regno_const): Likewise.
4352 (arc_reorg): Likewise.
4353
4354 2019-04-17 Segher Boessenkool <segher@kernel.crashing.org>
4355
4356 PR target/17108
4357 * config/rs6000/rs6000.c (rs6000_split_multireg_move): Adjust pattern
4358 name.
4359 (rs6000_emit_allocate_stack_1): Simplify condition. Adjust pattern
4360 name.
4361 * config/rs6000/rs6000.md (bits): Add entries for SF and DF.
4362 (*movdi_update1): Use Pmode.
4363 (movdi_<mode>_update): Fix argument to avoiding_indexed_address_p.
4364 (movdi_<mode>_update_stack): Rename to ...
4365 (movdi_update_stack): ... this. Fix comment. Change condition. Don't
4366 use Pmode.
4367 (*movsi_update1): Use Pmode.
4368 (*movsi_update2): Use Pmode.
4369 (movsi_update): Rename to ...
4370 (movsi_<mode>_update): ... this. Use Pmode.
4371 (movsi_update_stack): Fix condition.
4372 (*movhi_update1): Use Pmode. Fix argument to
4373 avoiding_indexed_address_p.
4374 (*movhi_update2): Ditto.
4375 (*movhi_update3): Ditto.
4376 (*movhi_update4): Ditto.
4377 (*movqi_update1): Ditto.
4378 (*movqi_update2): Ditto.
4379 (*movqi_update3): Ditto.
4380 (*movsf_update1, *movdf_update1): Merge, rename to...
4381 (*mov<mode>_update1): This. Use Pmode. Fix argument to
4382 avoiding_indexed_address_p. Add "size" attribute.
4383 (*movsf_update2, *movdf_update2): Merge, rename to...
4384 (*mov<mode>_update2): This. Ditto.
4385 (*movsf_update3): Use Pmode. Fix argument to
4386 avoiding_indexed_address_p.
4387 (*movsf_update4): Ditto.
4388 (allocate_stack): Simplify condition. Adjust pattern names.
4389
4390 2019-04-17 Jakub Jelinek <jakub@redhat.com>
4391
4392 PR target/89093
4393 * config/arm/arm.c (arm_valid_target_attribute_rec): Don't skip
4394 whitespace at the start of target attribute string.
4395
4396 2019-04-16 Pat Haugen <pthaugen@us.ibm.com>
4397
4398 PR target/84369
4399 * config/rs6000/power9.md: Add store forwarding bypass.
4400
4401 2019-04-16 Alexandre Oliva <aoliva@redhat.com>
4402
4403 PR debug/89528
4404 * valtrack.c (dead_debug_insert_temp): Reset debug references
4405 to the return value of a call being removed.
4406
4407 2019-04-16 Claudiu Zissulescu <claziss@synopsys.com>
4408
4409 * config/arc/arc-protos.h (arc_register_move_cost): Remove.
4410 * config/arc/arc.c (arc_register_move_cost): Re-purpose it to
4411 implement target hook.
4412 (arc_memory_move_cost): New function.
4413 (TARGET_REGISTER_MOVE_COST): Define.
4414 (TARGET_MEMORY_MOVE_COST): Likewise.
4415 * config/arc/arc.h (REGISTER_MOVE_COST): Remove.
4416 (MEMORY_MOVE_COST): Likewise.
4417
4418 2019-04-16 Claudiu Zissulescu <claziss@synopsys.com>
4419
4420 * config/arc/arc.md (sibcall_insn): Use Rcd constraint.
4421 (sibcall_value_insn): Likewise.
4422 * config/arc/constraints.md (Rs5): Remove.
4423
4424 2019-04-16 Claudiu Zissulescu <claziss@synopsys.com>
4425
4426 * config/arc/arc.c (arc_hard_regno_modes): Add two missing modes
4427 for last two fake registers.
4428 (arc_conditional_register_usage): Make sure fake frame and arg
4429 pointer regs are in general regs class.
4430 (FRAME_POINTER_MASK): Remove.
4431 (RETURN_ADDR_MASK): Remove.
4432 (arc_must_save_register): Use hard frame regnum.
4433 (frame_restore_reg): Use hard_frame_pointer_rtx.
4434 (arc_save_callee_saves): Likewise.
4435 (arc_restore_callee_saves): Likewise.
4436 (arc_save_callee_enter): Likewise.
4437 (arc_restore_callee_leave): Likewise.
4438 (arc_save_callee_milli): Likewise.
4439 (arc_eh_return_address_location): Likewise.
4440 (arc_check_multi): Use hard frame regnum.
4441 (arc_can_eliminate): Likewise.
4442 * config/arc/arc.h (FIXED_REGISTERS): Make FP register available
4443 for register allocator.
4444 (REG_CLASS_CONTENTS): Update GENERAL_REGS.
4445 (REGNO_OK_FOR_BASE_P): Consider FRAME_POINTER_REGNUM.
4446 (FRAME_POINTER_REGNUM): Change it to a fake register.
4447 (HARD_FRAME_POINTER_REGNUM): Defined.
4448 (ARG_POINTER_REGNUM): Change it to a new fake register.
4449 (ELIMINABLE_REGS): Update.
4450 (REGISTER_NAMES): Update names.
4451 * config/arc/arc.md (LP_START): Remove.
4452 (LP_END): Likewise.
4453 (shift_si3_loop): Update pattern.
4454
4455 2019-04-16 Claudiu Zissulescu <claziss@synopsys.com>
4456
4457 * config/arc/arc.c (arc_expand_prologue): Emit blockage regardless
4458 to avoid delay slot scheduling.
4459 (arc_must_save_register): Don't save SP.
4460 * config/arc/arc.md (stack_tie): Remove.
4461 (UNSPEC_ARC_STKTIE): Likewise.
4462
4463 2019-04-16 Kito Cheng <kito.cheng@gmail.com>
4464 Shiva Chen <shiva0217@gmail.com>
4465
4466 * config/nds32/nds32-md-auxiliary.c (nds32_split_ashiftdi3): Fix wrong
4467 code gen with large shift amount.
4468
4469 2019-04-16 Chung-Ju Wu <jasonwucj@gmail.com>
4470
4471 * config/nds32/nds32-pipelines-auxiliary.c (wext_odd_dep_p): Handle
4472 subreg.
4473
4474 2019-04-16 Jakub Jelinek <jakub@redhat.com>
4475
4476 PR target/90096
4477 * config/i386/i386.c (ix86_target_string): Add ADD_ABI_P argument, only
4478 print -m64/-mx32/-m32 if it is true.
4479 (ix86_debug_options, ix86_function_specific_print): Pass true as
4480 ADD_ABI_P to ix86_target_string.
4481 (ix86_expand_builtin): Adjust ix86_target_string caller, pass true as
4482 ADD_ABI_P only if OPTION_MASK_ISA_64BIT is set in bisa and in that case
4483 or into it OPTION_MASK_ISA_ABI_64 or OPTION_MASK_ISA_ABI_X32.
4484
4485 PR rtl-optimization/90082
4486 * dce.c (can_delete_call): New function.
4487 (deletable_insn_p, mark_insn): Use it.
4488
4489 PR tree-optimization/90090
4490 * tree-ssa-math-opts.c (is_division_by): Ignore divisions that can
4491 throw internally.
4492 (is_division_by_square): Likewise. Formatting fix.
4493
4494 2019-04-16 Richard Biener <rguenther@suse.de>
4495
4496 PR tree-optimization/56049
4497 * tree-ssa-loop-im.c (mem_ref_hasher::equal): Elide alias-set
4498 equality check if alias-set zero will prevail.
4499
4500 2019-04-15 Jeff Law <law@redhat.com>
4501
4502 * config/microblaze/microblaze.c (microblaze_expand_block_move): Treat
4503 size and alignment as unsigned.
4504
4505 2019-04-15 Richard Biener <rguenther@suse.de>
4506
4507 PR debug/90074
4508 * tree-loop-distribution.c (destroy_loop): Preserve correct
4509 debug info.
4510
4511 2019-04-15 Richard Biener <rguenther@suse.de>
4512
4513 PR tree-optimization/90071
4514 * tree-ssa-reassoc.c (init_range_entry): Do not pick up
4515 abnormal operands from def stmts.
4516
4517 2019-04-15 Segher Boessenkool <segher@kernel.crashing.org>
4518
4519 PR rtl-optimization/89794
4520 * combine.c (count_auto_inc): New function.
4521 (try_combine): Count how many auto_inc expressions there were in the
4522 original instructions. Ensure we have the same number in the new
4523 instructions. Remove the code that tried to ensure auto_inc side
4524 effects on i1 and i0 are not lost.
4525
4526 2019-04-15 Richard Biener <rguenther@suse.de>
4527
4528 PR ipa/88936
4529 * tree.h (auto_var_p): Declare.
4530 * tree.c (auto_var_p): New function, split out from ...
4531 (auto_var_in_fn_p): ... here.
4532 * tree-ssa-structalias.c (struct variable_info): Add shadow_var_uid
4533 member.
4534 (new_var_info): Initialize it.
4535 (set_uids_in_ptset): Also set the shadow variable uid if required.
4536 (ipa_pta_execute): Postprocess points-to solutions assigning
4537 shadow variable uids for locals that may reach their containing
4538 function recursively.
4539 * tree-ssa-ccp.c (fold_builtin_alloca_with_align): Do not
4540 assert but instead check whether the points-to solution is
4541 a singleton.
4542
4543 2019-04-15 Martin Jambor <mjambor@suse.cz>
4544
4545 PR ipa/pr89693
4546 * cgraph.c (clone_of_p): Loop over clone chain for each step in
4547 the thunk chain.
4548
4549 2019-04-15 Monk Chiang <sh.chiang04@gmail.com>
4550
4551 * config.gcc (nds32*-*-linux*): Set gcc_cv_initfini_array to yes.
4552
4553 2019-04-15 Monk Chiang <sh.chiang04@gmail.com>
4554 Kito Cheng <kito.cheng@gmail.com>
4555 Shiva Chen <shiva0217@gmail.com>
4556
4557 * config/nds32/nds32-md-auxiliary.c
4558 (nds32_legitimize_pic_address): Use new PIC pattern.
4559 (nds32_legitimize_tls_address): Use new TLS pattern.
4560 (nds32_output_symrel): New.
4561 * config/nds32/nds32-protos.h (nds32_output_symrel): Declare.
4562 (nds32_alloc_relax_group_id): Ditto.
4563 * config/nds32/nds32-relax-opt.c (nds32_alloc_relax_group_id): New.
4564 (nds32_group_insns): Use nds32_alloc_relax_group_id instead of use
4565 relax_group_id.
4566 (nds32_group_tls_insn): Ditto.
4567 (nds32_group_float_insns): Ditto.
4568 * config/nds32/nds32.md (tls_le): New.
4569 (sym_got): Ditto.
4570
4571 2019-04-15 Chung-Ju Wu <jasonwucj@gmail.com>
4572
4573 * configure: Add nds32 target for dwarf2 debug_line checking.
4574 * configure.ac: Regenerated.
4575
4576 2019-04-14 Jan Hubicka <hubicka@ucw.cz>
4577
4578 PR lto/89358
4579 * ipa-devirt.c (skip_in_fields_list_p): New.
4580 (odr_types_equivalent_p): Use it.
4581
4582 2019-04-13 Jakub Jelinek <jakub@redhat.com>
4583
4584 PR target/89093
4585 * config/arm/arm.c (arm_valid_target_attribute_rec): Use strcmp
4586 instead of strncmp when checking for thumb and arm. Formatting fixes.
4587
4588 2019-04-12 Iain Buclaw <ibuclaw@gdcproject.org>
4589
4590 * doc/install.texi: Document --with-target-system-zlib.
4591
4592 2019-04-12 Martin Sebor <msebor@redhat.com>
4593
4594 PR c/88383
4595 PR c/89288
4596 PR c/89798
4597 PR c/89797
4598 * targhooks.c (default_vector_alignment): Avoid assuming
4599 argument fits in SHWI.
4600 * tree.h (TYPE_VECTOR_SUBPARTS): Avoid sign overflow in
4601 a shift expression.
4602 * doc/extend.texi (__builtin_has_attribute): Add a clarifying note.
4603
4604 2019-04-12 Jakub Jelinek <jakub@redhat.com>
4605
4606 PR rtl-optimization/89965
4607 * dce.c: Include rtl-iter.h.
4608 (struct check_argument_load_data): New type.
4609 (check_argument_load): New function.
4610 (find_call_stack_args): Check for loads from stack slots still tracked
4611 in sp_bytes and punt if any is found.
4612
4613 * config/mips/loongson-mmiintrin.h: Fix up #error message.
4614
4615 2019-04-12 Jan Hubicka <hubicka@ucw.cz>
4616
4617 * params.def (PARAM_MAX_LTO_STREAMING_PARALLELISM): New parameter.
4618 * doc/invoke.texi (max-lto-streaming-paralellism): New --param.
4619
4620 2019-04-12 Martin Liska <mliska@suse.cz>
4621
4622 PR middle-end/89970
4623 * multiple_target.c (create_dispatcher_calls): Wrap ifunc
4624 in error message.
4625 (separate_attrs): Handle multiple 'default's.
4626 (expand_target_clones): Rework error handling code.
4627
4628 2019-04-12 Kelvin Nilsen <kelvin@gcc.gnu.org>
4629
4630 PR target/87532
4631 * config/rs6000/rs6000.c (rs6000_split_vec_extract_var): Use inner
4632 mode of vector rather than mode of destination for move instruction.
4633 * config/rs6000/vsx.md (*vsx_extract_<mode>_<VS_scalar>mode_var):
4634 Use QI inner mode with V16QI vector mode.
4635
4636 2019-04-12 Jakub Jelinek <jakub@redhat.com>
4637
4638 PR target/52726
4639 * config/tilepro/tilepro.c (tilepro_print_operand): Use just
4640 "invalid %%t operand" in output_operand_lossage message.
4641
4642 2019-04-12 Andreas Krebbel <krebbel@linux.ibm.com>
4643
4644 * config/s390/predicates.md (permute_pattern_operand): New
4645 predicate.
4646 * config/s390/vector.md ("*vec_splats_bswap_vec<mode>"): Add USE
4647 operand for the permute pattern.
4648 ("*vec_perm<mode>"): New insn definition.
4649 ("bswap<mode>"): Generate the permute pattern operand in the
4650 expander and perform the operand reloads for pre arch13 level
4651 already.
4652 ("*bswap<mode>_emu"): Rename to ...
4653 ("*bswap<mode>"): ... this. And make the splitter vxe2 only.
4654 * config/s390/vx-builtins.md ("*vec_insert_and_zero_bswap<mode>"):
4655 Add the USE operand for the permute pattern.
4656 ("*vec_set_bswap_vec<mode>"): Likewise.
4657
4658 2019-04-12 Jakub Jelinek <jakub@redhat.com>
4659
4660 PR c/89946
4661 * varasm.c (assemble_start_function): Don't use tree_fits_uhwi_p
4662 and gcc_unreachable if it fails, just call tree_to_uhwi which
4663 verifies that too. Test TREE_CHAIN instead of list_length > 1.
4664 Start warning message with a lower-case letter. Formatting fixes.
4665
4666 PR rtl-optimization/90026
4667 * cfgcleanup.c (try_optimize_cfg): When removing empty bb with no
4668 successors, look for BARRIERs inside of the whole BB_FOOTER chain
4669 rather than just at the start of it. If e->src BB_FOOTER is not NULL
4670 in cfglayout mode, use emit_barrier_after_bb.
4671
4672 2018-04-11 Steve Ellcey <sellcey@marvell.com>
4673
4674 PR rtl-optimization/87763
4675 * config/aarch64/aarch64.md (*aarch64_bfi<GPI:mode>4_noshift_alt):
4676 New Instruction.
4677
4678 2019-04-11 Tom de Vries <tdevries@suse.de>
4679
4680 * doc/extend.texi (@node Statement Exprs): Note variable shadowing at
4681 max macro using statement expression.
4682
4683 2019-04-11 David Edelsohn <dje.gcc@gmail.com>
4684
4685 * xcoffout.h (xcoff_private_rodata_section_name): Declare.
4686 * xcoffout.c (xcoff_private_rodata_section_name): Define.
4687 * config/rs6000/rs6000.c (rs6000_xcoff_asm_init_sections): Create
4688 read_only_private_data_section using xcoff_private_rodata_section_name.
4689 (rs6000_xcoff_file_start): Generate xcoff_private_rodata_section_name.
4690
4691 2019-04-11 Christophe Lyon <christophe.lyon@linaro.org>
4692
4693 PR target/90016
4694 * config/aarch64/aarch64.opt (msve-vector-bits): Add missing final '.'.
4695
4696 2019-04-11 Jakub Jelinek <jakub@redhat.com>
4697
4698 PR rtl-optimization/89965
4699 * dce.c (sp_based_mem_offset): New function.
4700 (find_call_stack_args): Use sp_based_mem_offset.
4701
4702 2019-04-11 Jonathan Wakely <jwakely@redhat.com>
4703
4704 * doc/invoke.texi (Optimize Options): Clarify -flive-patching docs.
4705
4706 2019-04-11 Richard Biener <rguenther@suse.de>
4707
4708 PR tree-optimization/90020
4709 * tree-ssa-sccvn.c (vn_reference_may_trap): New function.
4710 * tree-ssa-sccvn.h (vn_reference_may_trap): Declare.
4711 * tree-ssa-pre.c (compute_avail): Use it to not put
4712 possibly trapping references after a call that might not
4713 return into EXP_GEN.
4714 * gcse.c (compute_hash_table_work): Do not elide
4715 marking a block containing a call if the call might not
4716 return.
4717
4718 2019-04-11 Richard Biener <rguenther@suse.de>
4719
4720 PR tree-optimization/90018
4721 * tree-vect-data-refs.c (vect_preserves_scalar_order_p):
4722 Test both SLP and interleaving variants.
4723
4724 2019-04-11 Robin Dapp <rdapp@linux.ibm.com>
4725
4726 * config/s390/8561.md: New file.
4727 * config/s390/driver-native.c (s390_host_detect_local_cpu):
4728 Add arch13 cpu model.
4729 * config/s390/s390-opts.h (enum processor_type): Likewise.
4730 * config/s390/s390.c (s390_get_sched_attrmask): Add arch13.
4731 (s390_get_unit_mask): Likewise.
4732 (s390_is_fpd): Likewise.
4733 (s390_is_fxd): Likewise.
4734 * config/s390/s390.h (s390_tune_attr): Likewise.
4735 * config/s390/s390.md: Include arch13 pipeline description.
4736 * config/s390/s390.opt: Add arch13.
4737
4738 2018-04-10 Steve Ellcey <sellcey@marvell.com>
4739
4740 PR rtl-optimization/87763
4741 * config/aarch64/aarch64-protos.h (aarch64_masks_and_shift_for_bfi_p):
4742 New prototype.
4743 * config/aarch64/aarch64.c (aarch64_masks_and_shift_for_bfi_p):
4744 New function.
4745 * config/aarch64/aarch64.md (*aarch64_bfi<GPI:mode>5_shift):
4746 New instruction.
4747 (*aarch64_bfi<GPI:mode>5_shift_alt): Ditto.
4748 (*aarch64_bfi<GPI:mode>4_noand): Ditto.
4749 (*aarch64_bfi<GPI:mode>4_noand_alt): Ditto.
4750 (*aarch64_bfi<GPI:mode>4_noshift): Ditto.
4751
4752 2019-04-10 Jonathan Wakely <jwakely@redhat.com>
4753
4754 * doc/invoke.texi (Optimize Options): Change "Nevertheless" to
4755 "Although" in -fipa-icf documentation.
4756
4757 * doc/invoke.texi (Debugging Options): Explicitly state the semantics
4758 of using multiple -g options.
4759
4760 2019-04-10 Martin Liska <mliska@suse.cz>
4761
4762 PR gcov-profile/89959
4763 * doc/gcov.texi: Make documentation of -x option
4764 more precise.
4765
4766 2019-04-10 Richard Biener <rguenther@suse.de>
4767
4768 * tree-vectorizer.h (_stmt_vec_info): Remove same_dr_stmt
4769 member.
4770 (DR_GROUP_SAME_DR_STMT): Remove.
4771 * tree-vect-stmts.c (vectorizable_load): Remove unreachable code.
4772 * tree-vect-data-refs.c (vect_analyze_group_access_1): Likewise,
4773 replace with assert.
4774 (vect_analyze_data_ref_accesses): Fix INTEGER_CST comparison.
4775 (vect_record_grouped_load_vectors): Remove unreachable code.
4776
4777 2019-04-10 Richard Earnshaw <rearnsha@arm.com>
4778
4779 PR target/90016
4780 * config/aarch64/aarch64.opt (msve-vector-bits): Remove redundant and
4781 obsolete reference to N.
4782
4783 2019-04-10 Jakub Jelinek <jakub@redhat.com>
4784
4785 PR middle-end/90025
4786 * expr.c (store_expr): Set properly size on the MEM passed to
4787 clear_storage.
4788
4789 PR c++/90010
4790 * gimple-ssa-sprintf.c (target_to_host): Fix handling of targstr
4791 with strlen in between hostsz-3 and hostsz-1 inclusive when no
4792 translation is needed, and when translation is needed, only append
4793 ... if the string length is hostsz or more bytes long. Avoid using
4794 strncpy or strcat.
4795
4796 2019-04-09 Matthew Malcomson <matthew.malcomson@arm.com>
4797
4798 PR target/90024
4799 * config/arm/arm.c (neon_valid_immediate): Disallow VOIDmode parameter.
4800 * config/arm/constraints.md (Dm, DN, Dn): Split previous Dn constraint
4801 into three.
4802 * config/arm/neon.md (*neon_mov<mode>): Account for TImode and DImode
4803 differences directly.
4804 (*smax<mode>3_neon, vashl<mode>3, vashr<mode>3_imm): Use Dm constraint.
4805
4806 2019-04-09 Jakub Jelinek <jakub@redhat.com>
4807
4808 PR translation/90011
4809 * ipa-devirt.c (compare_virtual_tables): Remove two trailing spaces
4810 from diagnostics.
4811 * config/arm/freebsd.h (LINK_SPEC): Remove trailing space from -p
4812 diagnostics.
4813 * config/riscv/freebsd.h (LINK_SPEC): Likewise.
4814 * config/aarch64/aarch64-freebsd.h (FBSD_TARGET_LINK_SPEC): Likewise.
4815 * config/darwin.h (DRIVER_SELF_SPECS, ASM_FINAL_SPEC): Remove
4816 trailing space from -gsplit-dwarf diagnostics.
4817
4818 PR tree-optimization/89998
4819 * gimple-ssa-sprintf.c (try_substitute_return_value): Use lhs type
4820 instead of integer_type_node if possible, don't add ranges if return
4821 type is not compatible with int.
4822 * gimple-fold.c (gimple_fold_builtin_sprintf,
4823 gimple_fold_builtin_snprintf): Use lhs type instead of hardcoded
4824 integer_type_node.
4825
4826 2019-04-09 Martin Liska <mliska@suse.cz>
4827
4828 * Makefile.in: Use GENERATOR_CFLAGS for all generators.
4829 * doc/install.texi: Document the new config.
4830
4831 2019-04-09 Richard Sandiford <richard.sandiford@arm.com>
4832
4833 * tree-vect-data-refs.c (vect_get_smallest_scalar_type): Always
4834 use gimple_expr_type for load and store calls. Skip over the
4835 condition argument in a conditional internal function.
4836 Protect use of TREE_INT_CST_LOW.
4837
4838 2019-04-09 Jakub Jelinek <jakub@redhat.com>
4839
4840 PR target/90015
4841 * config/riscv/riscv.c (riscv_get_interrupt_type): Fix comment typo.
4842 (riscv_merge_decl_attributes): Fix typo in diagnostics. Remove
4843 trailing period from it too.
4844
4845 2019-04-08 wu yuan <wuyuan5@huawei.com>
4846
4847 * config/aarch64/aarch64-cores.def (tsv1100): Change scheduling model.
4848 * config/aarch64/aarch64.md : Add "tsv110.md"
4849 * config/aarch64/tsv110.md: New file.
4850
4851 2019-04-08 Richard Biener <rguenther@suse.de>
4852
4853 PR tree-optimization/90006
4854 * tree-vect-data-refs.c (vect_get_smallest_scalar_type): Handle
4855 calls like lrint.
4856
4857 2019-04-08 Andrea Corallo <andrea.corallo@arm.com>
4858
4859 PR target/83033
4860 * config/aarch64/cortex-a57-fma-steering.c (fma_forest): Prohibit copy
4861 construction.
4862 (fma_root_node): Likewise.
4863 (func_fma_steering): Likewise.
4864
4865 2019-04-08 Jakub Jelinek <jakub@redhat.com>
4866
4867 PR rtl-optimization/89865
4868 * config/i386/i386.md: Add peepholes for z = x; x ^= y; x != z.
4869
4870 PR rtl-optimization/89865
4871 * config/i386/i386.md
4872 (SWI12 peephole for mem {+,-,&,|,^}= x; mem != 0): Fix up operand
4873 numbers not to clash with the additional operands[4].
4874 (peepholes for mem {+,-,&,|,^}= x; mem != 0): New peephole2s
4875 with extra register copy in the middle.
4876
4877 2019-04-08 Martin Liska <mliska@suse.cz>
4878
4879 PR gcov-profile/89961
4880 * doc/gcov.texi: Document data_file.
4881 * gcov.c (generate_results): Add data_info into JSON output.
4882
4883 2019-04-01 Bin Cheng <bin.cheng@linux.alibaba.com>
4884
4885 PR tree-optimization/89725
4886 * tree-chrec.c (chrec_contains_symbols): New parameter. Handle outer
4887 loop's chrec as invariant symbol.
4888 * tree-chrec.h (chrec_contains_symbols): New parameter.
4889 * tree-data-ref.c (analyze_miv_subscript): Pass new argument.
4890 (build_classic_dist_vector_1, add_other_self_distances): Bypass access
4891 function of loops not in DDR's loop_nest.
4892 * tree-data-ref.h (index_in_loop_nest): Add unreachable check.
4893
4894 2019-04-08 Chenghua Xu <paul.hua.gm@gmail.com>
4895
4896 PR target/89623
4897 * config/mips/mips.opt (LOONGSON_EXT2): Use Var instead of
4898 Mask.
4899
4900 2019-04-07 Uroš Bizjak <ubizjak@gmail.com>
4901
4902 PR target/89945
4903 * config/i386/i386.md (anddi_1 to andsi_1_zext splitter):
4904 Avoid calling gen_lowpart with SYMBOL_REF and LABEL_REF operand.
4905
4906 2019-04-05 Joern Rennecke <joern.rennecke@embecosm.com>
4907
4908 * sched-deps.c (sched_macro_fuse_insns): Check return value of
4909 targetm.fixed_condition_code_regs.
4910
4911 2019-04-05 Richard Biener <rguenther@suse.de>
4912
4913 PR debug/89892
4914 PR debug/89905
4915 * tree-cfgcleanup.c (remove_forwarder_block): Always move
4916 debug bind stmts but reset them if they are not valid at the
4917 destination.
4918
4919 2019-04-05 Martin Liska <mliska@suse.cz>
4920
4921 PR translation/89936
4922 * collect-utils.c (collect_execute): Use %< and %>, or %qs in
4923 order to wrap keywords or arguments.
4924 * collect2.c (main): Likewise.
4925 (scan_prog_file): Likewise.
4926 (scan_libraries): Likewise.
4927 * common/config/riscv/riscv-common.c
4928 (riscv_subset_list::parsing_subset_version): Likewise.
4929 (riscv_subset_list::parse_std_ext): Likewise.
4930 * config/aarch64/aarch64.c (aarch64_override_options_internal):
4931 Likewise.
4932 * config/arm/arm.c (arm_option_override): Likewise.
4933 * config/cris/cris.c (cris_print_operand): Likewise.
4934 * config/darwin-c.c (darwin_pragma_options): Likewise.
4935 (darwin_pragma_unused): Likewise.
4936 (darwin_pragma_ms_struct): Likewise.
4937 * config/ft32/ft32.c (ft32_print_operand): Likewise.
4938 * config/i386/i386.c (print_reg): Likewise.
4939 (ix86_print_operand): Likewise.
4940 * config/i386/xm-djgpp.h: Likewise.
4941 * config/iq2000/iq2000.c (iq2000_print_operand): Likewise.
4942 * config/m32c/m32c.c (m32c_option_override): Likewise.
4943 * config/msp430/msp430.c (msp430_option_override): Likewise.
4944 * config/nds32/nds32.c (nds32_option_override): Likewise.
4945 * config/nvptx/mkoffload.c (main): Likewise.
4946 * config/rx/rx.c (rx_print_operand): Likewise.
4947 (valid_psw_flag): Likewise.
4948 * config/vms/vms-c.c (vms_pragma_member_alignment): Likewise.
4949 (vms_pragma_nomember_alignment): Likewise.
4950 (vms_pragma_extern_model): Likewise.
4951 * lto-wrapper.c (compile_offload_image): Likewise.
4952 * omp-offload.c (oacc_parse_default_dims): Likewise.
4953 * symtab.c (symtab_node::verify_base): Likewise.
4954 * tlink.c (recompile_files): Likewise.
4955 (start_tweaking): Likewise.
4956 * tree-profile.c (parse_profile_filter): Likewise.
4957
4958 2019-04-05 Richard Sandiford <richard.sandiford@arm.com>
4959
4960 PR tree-optimization/89956
4961 * tree-ssa-math-opts.c (convert_mult_to_fma): Protect against
4962 multiple negates of the same value.
4963
4964 2019-04-04 Martin Sebor <msebor@redhat.com>
4965
4966 PR middle-end/89957
4967 PR middle-end/89911
4968 * builtins.c (expand_builtin_strnlen): Make sure wi::ltu_p operands
4969 have the same precision since the function crashes otherwise.
4970 * calls.c (maybe_warn_nonstring_arg): Avoid assuming strnlen() call
4971 has non-zero arguments.
4972
4973 2019-04-04 Martin Sebor <msebor@redhat.com>
4974
4975 PR middle-end/89934
4976 * gimple-ssa-warn-restrict.c (builtin_access::builtin_access): Bail
4977 out if the number of arguments is less than expected.
4978
4979 2019-04-04 Jeff Law <law@redhat.com>
4980
4981 PR rtl-optimization/89399
4982 * ree.c (combine_set_extension): Use single_set rather than
4983 digging into PATTERN for items on the candidate list.
4984 (combine_reaching_defs): Likewise.
4985
4986 2019-04-04 Richard Sandiford <richard.sandiford@arm.com>
4987
4988 PR rtl-optimization/46590
4989 * loop-invariant.c (find_defs): Move df_remove_problem and
4990 df_process_deferred_rescans to move_invariants.
4991 Move df_live_add_problem and df_live_set_all_dirty calls
4992 to move_invariants.
4993 (move_invariants): Likewise.
4994 (move_loop_invariants): Likewise, making the df_live calls
4995 conditional on -O. Remove the problem again if we added it
4996 locally.
4997
4998 2019-04-03 qing zhao <qing.zhao@oracle.com>
4999
5000 PR tree-optimization/89730
5001 * ipa-inline.c (can_inline_edge_p): Delete the checking for
5002 -flive-patching=inline-only-static.
5003 (can_inline_edge_by_limits_p): Add the checking for
5004 -flive-patching=inline-only-static and grant always_inline
5005 even when -flive-patching=inline-only-static is specified.
5006
5007 2019-04-03 Jeff Law <law@redhat.com>
5008
5009 PR rtl-optimization/81025
5010 * reorg.c (skip_consecutive_labels): Do not skip past a BARRIER.
5011
5012 2019-04-03 Richard Biener <rguenther@suse.de>
5013
5014 PR tree-optimization/84101
5015 * tree-vect-stmts.c: Include explow.h for hard_function_value,
5016 regs.h for hard_regno_nregs.
5017 (cfun_returns): New helper.
5018 (vect_model_store_cost): When vectorizing a store to a decl
5019 we return and the function ABI returns in a multi-reg location
5020 account for the possible spilling that will happen.
5021
5022 2019-04-03 Andreas Krebbel <krebbel@linux.ibm.com>
5023
5024 * config/s390/s390.c (s390_legitimate_address_p): Reject long
5025 displacement addresses for vector mode operands.
5026
5027 2019-04-03 Claudiu Zissulescu <claziss@synopsys.com>
5028
5029 * config/arc/arc.c (GMASK_LEN): Define.
5030 (arc_restore_callee_saves): Restore first blink when
5031 !optimize_size.
5032
5033 2019-04-03 Sudakshina Das <sudi.das@arm.com>
5034
5035 * doc/extend.texi: Add deprecated comment on sign-return-address
5036 function attribute and add mbranch-protection.
5037 * doc/invoke.texi: Add bti to the options for mbranch-protection.
5038
5039 2019-04-03 Richard Biener <rguenther@suse.de>
5040
5041 PR lto/89896
5042 * lto-wrapper.c (run_gcc): Avoid implicit rules making
5043 the all target phony.
5044
5045 2019-04-02 Uroš Bizjak <ubizjak@gmail.com>
5046
5047 PR target/89902
5048 PR target/89903
5049 * config/i386/i386.c (dimode_scalar_to_vector_candidate_p):
5050 Return false for variable DImode shifts.
5051 (dimode_scalar_chain::compute_convert_gain): Do not handle
5052 register count operand in variable DImode shifts.
5053 (dimode_scalar_chain::make_vector_copies): Remove support to copy
5054 count argument of a variable shift instruction to a vector register.
5055 (dimode_scalar_chain::convert_reg): Remove support to convert
5056 count argument of a variable shift instruction.
5057
5058 2019-04-02 Andrey Belevantsev <abel@ispras.ru>
5059
5060 PR rtl-optimization/84206
5061 * sel-sched-ir.h (get_all_loop_exits): Avoid the outer loop when
5062 iterating over loop headers.
5063
5064 2019-04-02 Andrey Belevantsev <abel@ispras.ru>
5065
5066 PR rtl-optimization/85876
5067 * sel-sched.c (code_motion_path_driver): Avoid unwinding first_insn
5068 beyond the original fence.
5069
5070 2019-04-02 Ulrich Weigand <uweigand@de.ibm.com>
5071
5072 * config.gcc: Mark spu* targets as deprecated/obsolete.
5073
5074 2019-04-02 Andreas Krebbel <krebbel@linux.ibm.com>
5075
5076 * config/s390/s390-builtin-types.def: New builtin function type
5077 definitions. Remove unused types.
5078 * config/s390/s390-builtins.def (s390_vcdgb, s390_vcdlgb)
5079 (s390_vcgdb, s390_vclgdb): Remove low-level builtin definitions.
5080 (s390_vec_float, s390_vec_signed, s390_vec_unsigned): New
5081 overloaded builtins.
5082 (s390_vcefb, s390_vcdgb, s390_vcelfb, s390_vcdlgb, s390_vcfeb)
5083 (s390_vcgdb, s390_vclfeb, s390_vclgdb): New low-level builtins.
5084 * config/s390/vecintrin.h (vec_float): New builtin macro definition.
5085 (vec_double, vec_signed, vec_unsigned): Define to use the new
5086 overloaded builtins.
5087 * config/s390/vx-builtins.md ("vec_double_s64", "vec_double_u64"):
5088 Remove expanders.
5089
5090 2019-04-02 Andreas Krebbel <krebbel@linux.ibm.com>
5091
5092 * config/s390/s390-builtin-types.def: New builtin function type
5093 definitions.
5094 * config/s390/s390-builtins.def (s390_vec_search_string_cc)
5095 (s390_vec_search_string_until_zero_cc): New overloaded builtins.
5096 (s390_vstrsb, s390_vstrsh, s390_vstrsf, s390_vstrszb)
5097 (s390_vstrszh, s390_vstrszf): New low-level builtins.
5098 * config/s390/s390.md (UNSPEC_VEC_VSTRS, UNSPEC_VEC_VSTRSCC): New
5099 constant definitions.
5100 * config/s390/vecintrin.h (vec_search_string_cc)
5101 (vec_search_string_until_zero_cc): New builtin name definitions.
5102 * config/s390/vx-builtins.md ("vstrs<mode>", "vstrsz<mode>"): New
5103 expanders.
5104 ("vec_vstrs<mode>"): New insn definition.
5105
5106 2019-04-02 Andreas Krebbel <krebbel@linux.ibm.com>
5107
5108 * config/s390/s390-builtin-types.def: Add new builtin function
5109 types.
5110 * config/s390/s390-builtins.def (s390_vec_sldb, s390_vec_srdb):
5111 New overloaded builtins.
5112 (s390_vec_sldb, s390_vec_srdb): New low-level builtins. and
5113 s390_vsrd.
5114 * config/s390/s390.md (UNSPEC_VEC_SLDB): Rename to ...
5115 (UNSPEC_VEC_SLDBYTE): ... this.
5116 (UNSPEC_VEC_SLDBIT, UNSPEC_VEC_SRDBIT): New constant definitions.
5117 * config/s390/vecintrin.h (vec_sldb, vec_srdb): New builtin name
5118 definitions.
5119 * config/s390/vx-builtins.md ("vec_sld<mode>", "vec_sldw<mode>"):
5120 Rename UNSPEC_VEC_SLDB to UNSPEC_VEC_SLDBYTE.
5121 ("vec_sldb<mode>", "vec_srdb<mode>"): New insn definitions.
5122
5123 2019-04-02 Andreas Krebbel <krebbel@linux.ibm.com>
5124
5125 ("*vec_splats_bswap_vec<mode>", "*vec_splats_bswap_elem<mode>"):
5126 New insn definition.
5127 * config/s390/vx-builtins.md (V_HW_HSD): Move to ...
5128 * config/s390/vector.md (V_HW_HSD): ... here.
5129
5130 2019-04-02 Andreas Krebbel <krebbel@linux.ibm.com>
5131
5132 * config/s390/vecintrin.h: Map vec_vster low-level builtins to vec_vler.
5133 * config/s390/vx-builtins.md ("*vec_insert_and_zero_bswap<mode>")
5134 ("*vec_set_bswap_elem<mode>", "*vec_set_bswap_vec<mode>")
5135 ("*vec_extract_bswap_vec<mode>", "*vec_extract_bswap_elem<mode>"):
5136 New insn definitions.
5137
5138 2019-04-02 Andreas Krebbel <krebbel@linux.ibm.com>
5139
5140 * config/s390/s390-builtin-types.def: Add new builtin function type.
5141 * config/s390/s390-builtins.def: Add overloaded builtin
5142 s390_vec_reve and low-level builtins for s390_vler and s390_vster.
5143 * config/s390/s390.md (UNSPEC_VEC_ELTSWAP): New constant definition.
5144 * config/s390/vecintrin.h (vec_reve): New builtin name definition.
5145 * config/s390/vx-builtins.md (V_HW_HSD): New mode iterator.
5146 ("eltswap<mode>"): New expander.
5147 ("*eltswapv16qi", "*eltswap<mode>", "*eltswap<mode>_emu"): New
5148 insn definitions.
5149
5150 2019-04-02 Andreas Krebbel <krebbel@linux.ibm.com>
5151
5152 * config/s390/s390-builtin-types.def: Add new builtin function types.
5153 * config/s390/s390-builtins.def: Add overloaded builtin
5154 s390_vec_revb. Add low-level builtins for vlbr and vstbr
5155 instructions.
5156 * config/s390/vecintrin.h (vec_revb): New builtin name definition.
5157 * config/s390/vector.md (VT_HW_HSDT): New mode iterator.
5158 ("bswap<mode>"): New expander.
5159 ("*bswap<mode>", "*bswap<mode>_emu"): New insn definitions.
5160
5161 2019-04-02 Andreas Krebbel <krebbel@linux.ibm.com>
5162
5163 * config/s390/s390-builtins.def (B_VXE2): New builtin flag definition.
5164 * config/s390/s390-c.c (s390_cpu_cpp_builtins_internal): Increment
5165 vector builtin version number in __VEC__.
5166
5167 2019-04-02 Andreas Krebbel <krebbel@linux.ibm.com>
5168
5169 * config/s390/s390.md (VX_CONV_BFP, VX_CONV_INT): New mode
5170 iterators.
5171 (SFSI): New mode attribute.
5172 ("*fixuns_truncdfdi2_vx", "*fix_truncdfdi2_bfp_z13")
5173 ("*floatunsdidf2_z13", ): Add support for 32 bit conversions and
5174 rename to ...
5175 ("*fixuns_trunc<VX_CONV_BFP:mode><VX_CONV_INT:mode>2_z13")
5176 ("*fix_trunc<VX_CONV_BFP:mode><VX_CONV_INT:mode>2_bfp_z13")
5177 ("*floatuns<VX_CONV_INT:mode><VX_CONV_BFP:mode>2_z13"): ... these.
5178 ("floatsi<mode>2"): Add wcefb instruction.
5179
5180 2019-04-02 Andreas Krebbel <krebbel@linux.ibm.com>
5181
5182 * config/s390/s390.md ("xde"): Extend mode attribute to vector types.
5183 * config/s390/vector.md (VX_VEC_CONV_BFP, VX_VEC_CONV_INT): New
5184 mode iterators.
5185 ("floatv2div2df2", "floatunsv2div2df2", "fix_truncv2dfv2di2")
5186 ("fixuns_truncv2dfv2di2"): Enhance with mode iterator to also
5187 support 32 bit fp-int conversions. Rename to ...
5188 ("float<VX_VEC_CONV_INT:mode><VX_VEC_CONV_BFP:mode>2")
5189 ("floatuns<VX_VEC_CONV_INT:mode><VX_VEC_CONV_BFP:mode>2")
5190 ("fix_trunc<VX_VEC_CONV_BFP:mode><VX_VEC_CONV_INT:mode>2")
5191 ("fixuns_trunc<VX_VEC_CONV_BFP:mode><VX_VEC_CONV_INT:mode>2"):
5192 ... to these.
5193
5194 2019-04-02 Andreas Krebbel <krebbel@linux.ibm.com>
5195
5196 * config/s390/s390.c (s390_rtx_costs): Do not add extra costs for
5197 if-then-else constructs if we can use the select instruction.
5198 * config/s390/s390.md ("*mov<mode>cc"): Add the new instructions.
5199
5200 2019-04-02 Andreas Krebbel <krebbel@linux.ibm.com>
5201
5202 * config/s390/s390.md ("*popcountdi_arch13_cc")
5203 ("*popcountdi_arch13_cconly", "*popcountdi_arch13"): New insn
5204 definition.
5205 ("*popcount<mode>", "popcountdi2", "popcountsi2", "popcounthi2"):
5206 Append _z196 to make it ...
5207 ("*popcount<mode>_z196", "popcountdi2_z196", "popcountsi2_z196")
5208 ("popcounthi2_z196"): ... this.
5209 ("popcountdi2_z196"): Remove TARGET_64BIT from the insn condition.
5210 ("popcountdi2", "popcountsi2", "popcounthi2"): New expanders.
5211
5212 2019-04-02 Andreas Krebbel <krebbel@linux.ibm.com>
5213
5214 * config/s390/s390.c (s390_canonicalize_comparison): Convert
5215 certain compares for arch13 in order to make use of the condition
5216 code result produced by the new instructions.
5217 (s390_rtx_costs): Adjust the costs for nnrk, nngrk, nork, nogrk,
5218 nxrk, and nxgrk instruction patterns.
5219 * config/s390/s390.md (ANDOR, bitops_name, inv_bitops_name)
5220 (inv_no): Add new code iterator together with some attributes.
5221 ("*andc_split_<mode>"): Disable splitter for arch13.
5222 ("*<ANDOR:bitops_name>c<GPR:mode>_cc")
5223 ("*<ANDOR:bitops_name>c<GPR:mode>_cconly")
5224 ("*<ANDOR:bitops_name>c<GPR:mode>")
5225 ("*n<ANDOR:inv_bitops_name><GPR:mode>_cc")
5226 ("*n<ANDOR:inv_bitops_name><mode>_cconly")
5227 ("*n<ANDOR:inv_bitops_name><mode>", "*nxor<GPR:mode>_cc")
5228 ("*nxor<mode>_cconly", "*nxor<mode>"): New insn definitions.
5229
5230 2019-04-02 Andreas Krebbel <krebbel@linux.ibm.com>
5231
5232 * common/config/s390/s390-common.c (processor_flags_table): New
5233 entry for arch13.
5234 * config.gcc: Support arch13 with the --with-arch= configure flag.
5235 * config/s390/driver-native.c (s390_host_detect_local_cpu):
5236 * config/s390/s390-opts.h (enum processor_type): Add PROCESSOR_ARCH13.
5237 * config/s390/s390.c (s390_get_sched_attrmask)
5238 (s390_get_unit_mask): Add PROCESSOR_ARCH13.
5239 * config/s390/s390.h (enum processor_flags): Add PF_VXE2 and PF_ARCH13.
5240 * config/s390/s390.md (TARGET_CPU_ARCH13, TARGET_CPU_ARCH13_P)
5241 (TARGET_CPU_VXE2, TARGET_CPU_VXE2_P, TARGET_ARCH13)
5242 (TARGET_ARCH13_P, TARGET_VXE2, TARGET_VXE2_P): New macro
5243 definitions.
5244 * config/s390/s390.opt: Support arch13 as processor type in
5245 command line options.
5246
5247 2019-04-02 Martin Liska <mliska@suse.cz>
5248
5249 PR translation/89912
5250 * params.def (PARAM_GRAPHITE_MAX_ARRAYS_PER_SCOP):
5251 Fix param description of graphite-max-arrays-per-scop.
5252
5253 2019-04-02 Eric Botcazou <ebotcazou@adacore.com>
5254
5255 * config/sparc/linux64.h (ASAN_REJECT_SPEC): New macro.
5256 (ASAN_CC1_SPEC): Use it in 64-bit mode.
5257 * config/sparc/sol2.h (ASAN_REJECT_SPEC): Remove superfluous colon.
5258
5259 2019-04-01 Andrey Belevantsev <abel@ispras.ru>
5260
5261 PR rtl-optimization/85412
5262 * sel-sched.c (sel_sched_region): Assign reset_sched_cycles_p before
5263 sel_sched_region_1, not after.
5264
5265 2019-04-01 Andrey Belevantsev <abel@ispras.ru>
5266
5267 PR rtl-optimization/86928
5268 * sel-sched-ir.c (sel_redirect_edge_and_branch_force): Invoke
5269 compute_live if necessary.
5270 (sel_redirect_edge_and_branch): Likewise.
5271
5272 2019-04-01 Vladimir Makarov <vmakarov@redhat.com>
5273
5274 PR rtl-optimization/89865
5275 * ira-costs.c (process_bb_node_for_hard_reg_moves): Skip hard
5276 register if it is a part of small class.
5277
5278 2019-04-01 Andrey Belevantsev <abel@ispras.ru>
5279
5280 PR rtl-optimization/87273
5281 * sel-sched-ir.c (merge_fences): Remove assert.
5282
5283 2019-04-01 Richard Biener <rguenther@suse.de>
5284
5285 PR tree-optimization/46590
5286 * domwalk.h (dom_walker::dom_walker): Consolidate constructors.
5287 (dom_walker::m_reachability): Add in place of...
5288 (dom_walker::m_skip_unreachable_blocks): ...this.
5289 * domwalk.c (dom_walker::dom_walker): Consoliate constructors.
5290 Move complex initialization ...
5291 (dom_walker::walk): Here. Especially compute m_bb_to_rpo
5292 lazily and initialize edge flags on each invocation.
5293 (dom_walker::bb_reachable): Use m_reachability.
5294
5295 2019-04-01 Martin Liska <mliska@suse.cz>
5296
5297 PR driver/89861
5298 * opt-suggestions.c (option_proposer::build_option_suggestions):
5299 Add variant without any argument in order to provide better
5300 hints.
5301
5302 2019-04-01 Richard Biener <rguenther@suse.de>
5303
5304 PR c/71598
5305 * gimple.c: Include langhooks.h.
5306 (gimple_get_alias_set): Treat enumeral types as the underlying
5307 integer type.
5308
5309 2019-03-29 Kugan Vivekanandarajah <kuganv@linaro.org>
5310 Eric Botcazou <ebotcazou@adacore.com>
5311
5312 PR rtl-optimization/89862
5313 * rtl.h (word_register_operation_p): Exclude CONST_INT from operations
5314 that operates on the full registers for WORD_REGISTER_OPERATIONS
5315 architectures.
5316
5317 2019-03-29 Jim Wilson <jimw@sifive.com>
5318
5319 * common/config/riscv/riscv-common.c (riscv_parse_arch_string):
5320 Clear MASK_RVC and then set if C subset supported.
5321
5322 2019-03-29 Jakub Jelinek <jakub@redhat.com>
5323
5324 PR c/89872
5325 * gimplify.c (gimplify_compound_literal_expr): Don't optimize a
5326 non-addressable complit into its initializer if it is volatile.
5327
5328 2019-03-29 Roman Zhuykov <zhroma@ispras.ru>
5329
5330 * opts-common.c (integral_argument): Set errno properly in one case.
5331
5332 2019-03-29 Martin Liska <mliska@suse.cz>
5333
5334 * doc/invoke.texi: Remove -Wchkp from documentation.
5335
5336 2019-03-29 Martin Liska <mliska@suse.cz>
5337
5338 * dbgcnt.c (print_limit_reach): New function.
5339 (dbg_cnt): Use it.
5340
5341 2019-03-29 Martin Liska <mliska@suse.cz>
5342
5343 * dbgcnt.c (dbg_cnt_process_single_pair): Fix GNU coding style.
5344 (dbg_cnt_process_opt): Parse first tokens aas
5345 dbg_cnt_process_single_pair is also using strtok.
5346
5347 2019-03-29 Jakub Jelinek <jakub@redhat.com>
5348
5349 PR rtl-optimization/87485
5350 * function.c (expand_function_end): Move stack_protect_epilogue
5351 before loading of return value into hard register(s).
5352
5353 2019-03-28 Jakub Jelinek <jakub@redhat.com>
5354
5355 PR middle-end/89621
5356 * tree-inline.h (struct copy_body_data): Add
5357 dont_remap_vla_if_no_change flag.
5358 * tree-inline.c (remap_type_3, remap_type_2): New functions.
5359 (remap_type): Don't remap vla types if id->dont_remap_vla_if_no_change
5360 and remap_type_2 returns false.
5361 * omp-low.c (new_omp_context): Set ctx->cb.dont_remap_vla_if_no_change.
5362 Move ctx->cb.adjust_array_error_bounds setting to the outermost ctx
5363 only from where it is copied to nested contexts.
5364
5365 2019-03-28 Uroš Bizjak <ubizjak@gmail.com>
5366
5367 PR target/89865
5368 * config/i386/i386.md (RMW operation with LEA peephole):
5369 Use LEAMODE mode attribute instead of SWI mode iterator for
5370 LEA pattern.
5371
5372 2019-03-28 Uroš Bizjak <ubizjak@gmail.com>
5373
5374 PR target/89848
5375 * config/i386/i386.c (dimode_scalar_chain::make_vector_copies):
5376 Also process XEXP (src, 0) of a shift insn.
5377
5378 2019-03-28 David Malcolm <dmalcolm@redhat.com>
5379
5380 PR middle-end/89725
5381 * optinfo-emit-json.cc (optrecord_json_writer::optinfo_to_json):
5382 Use DECL_ASSEMBLER_NAME rather than get_fnname_from_decl.
5383
5384 2019-03-28 Jakub Jelinek <jakub@redhat.com>
5385
5386 * regcprop.c (copyprop_hardreg_forward_1): Remove redundant INSN_P
5387 test.
5388 (cprop_hardreg_bb, cprop_hardreg_debug): New functions.
5389 (pass_cprop_hardreg::execute): Use those. Don't repeat bb processing
5390 immediately after first one with df_analyze in between, but rather
5391 process all bbs, queueing ones that need second pass in a worklist,
5392 df_analyze, process queued debug insn changes and if second pass is
5393 needed, process bbs from worklist, df_analyze, process queued debug
5394 insns again.
5395
5396 * rtl.h (NONDEBUG_INSN_P): Define as NONJUMP_INSN_P or JUMP_P
5397 or CALL_P instead of INSN_P && !DEBUG_INSN_P.
5398 (INSN_P): Define using NONDEBUG_INSN_P or DEBUG_INSN_P.
5399
5400 2019-03-28 Jonathan Wakely <jwakely@redhat.com>
5401
5402 PR c/79022
5403 * gengtype.h (create_nested_ptr_option): Fix parameter names to match
5404 definition.
5405
5406 2019-03-27 Mateusz B <mateuszb@poczta.onet.pl>
5407
5408 PR target/85667
5409 * config/i386/i386.c (ix86_function_value_1): Call the newly added
5410 function for 32-bit MS_ABI.
5411 (function_value_ms_32): New function.
5412
5413 2019-03-27 Andrew Stubbs <ams@codesourcery.com>
5414
5415 * config/gcn/gcn.md (CC_SAVE_REG): New constant.
5416 (movdi): Call gen_movdi_symbol_save_scc.
5417 (gen_movdi_symbol_save_scc): New insn and split.
5418
5419 2019-03-27 Peter Bergner <bergner@linux.ibm.com>
5420
5421 PR rtl-optimization/89313
5422 * function.c (matching_constraint_num): New static function.
5423 (match_asm_constraints_1): Use it. Fixup white space and comment.
5424 Don't replace inputs with non-matching constraints which conflict
5425 with early clobber outputs.
5426
5427 2019-03-27 Jeff Law <law@redhat.com>
5428
5429
5430 PR rtl-optimization/87761
5431 PR rtl-optimization/89826
5432 * regcprop.c (copyprop_hardreg_forward_1): Move may_trap_p test
5433 slightly later.
5434 (pass_cprop_hardreg::execute): Call df_analyze after adding the
5435 note problem to get REG_DEAD/REG_UNUSED notes updated.
5436
5437 2019-03-27 Richard Biener <rguenther@suse.de>
5438
5439 PR tree-optimization/89463
5440 * tree-ssa-dce.c (remove_dead_stmt): Take output vector to
5441 queue edges to remove.
5442 (eliminate_unnecessary_stmts): Remove dead PHIs alongside
5443 dead stmts. Delay edge removal until PHIs are removed to
5444 make debug-stmt creation not confused by seemingly degenerate
5445 PHIs.
5446
5447 2019-03-27 Alan Modra <amodra@gmail.com>
5448
5449 * config/rs6000/rs6000.h: Rename NON_SPECIAL_REGS to GEN_OR_FLOAT_REGS
5450 throughout file.
5451 * config/rs6000/darwin.h: Likewise.
5452 * config/rs6000/rs6000.c: Likewise.
5453
5454 2019-03-27 Alan Modra <amodra@gmail.com>
5455
5456 * config/rs6000/rs6000.c (rs6000_init_hard_regno_mode_ok): Always
5457 assign rs6000_hard_regno_mode_ok_p[m][r]. Formatting.
5458
5459 2019-03-26 Andrew Waterman <andrew@sifive.com>
5460 Jim Wilson <jimw@sifive.com>
5461
5462 * config/riscv/generic.md (generic_alu, generic_load, generic_store)
5463 (generic_xfer, generic_branch, generic_imul, generic_idivsi)
5464 (generic_idivdi, generic_fmul_single, generic_fmul_double)
5465 (generic_fdiv, generic_fsqrt): Add check for generic tune.
5466 (generic_alu): Add auipc to type list.
5467 * config/riscv/riscv-opts.h (enum riscv_microarchitecture_type): New.
5468 (riscv_microarchitecture): Declare.
5469 * config/riscv/riscv-protos.h (riscv_store_data_bypass_p): Declare.
5470 * config/riscv/riscv.c (struct riscv_cpu_info): Add microarchitecture
5471 field.
5472 (riscv_microarchitecture): New.
5473 (sifive_7_tune_info): New.
5474 (riscv_cpu_info_table): Add microarchitecture value for rocket and
5475 size. Add sifive-3-series, sifive-5-series, and sifive-7-series
5476 entries.
5477 (riscv_store_data_bypass_p): New.
5478 (riscv_option_override): Set riscv_microarchitecture from
5479 cpu->microarchitecture.
5480 * config/riscv/riscv.md: Include sifive-7.md.
5481 (type): Add auipc.
5482 (tune): New.
5483 (auipc<mode>): Change type to auipc.
5484 (restore_stack_nonlocal): New.
5485 * config/riscv/sifive-7.md: New.
5486 * doc/invoke.texi (RISC-V Options): Update mtune docs.
5487
5488 2019-03-26 Uroš Bizjak <ubizjak@gmail.com>
5489
5490 PR target/89827
5491 * config/i386/i386.c (dimode_scalar_chain::convert_reg):
5492 Also process XEXP (src, 0) of a shift insn.
5493
5494 2019-03-26 Richard Biener <rguenther@suse.de>
5495
5496 * tree-inline.c (remap_gimple_stmt): Cache gimple_block.
5497 (copy_debug_stmt): Likewise.
5498 (expand_call_inline): Likewise.
5499 (copy_bb): Avoid redundant lookup & set of gimple_block.
5500 * gimple-low.c (lower_gimple_return): Likewise.
5501 (lower_builtin_setjmp): Likewise.
5502
5503 2019-03-26 Jakub Jelinek <jakub@redhat.com>
5504
5505 * hash-table.h (hash_table::m_gather_mem_stats): If GATHER_STATISTICS
5506 is constant 0, turn into static const data member initialized to false.
5507 (hash_table::hash_table): Only initialize m_gather_mem_stats #if
5508 GATHER_STATISTICS. Add ATTRIBUTE_UNUSED to gather_mem_stats param.
5509
5510 2019-03-26 Jason Merrill <jason@redhat.com>
5511 Jakub Jelinek <jakub@redhat.com>
5512
5513 * mem-stats.h (mem_alloc_description::unregister_descriptor): New
5514 method.
5515 (mem_alloc_description::release_object_overhead): Fix comment typos.
5516 * hash-table.h (hash_table::~hash_table): Call
5517 release_instance_overhead only if m_entries is non-NULL, otherwise
5518 call unregister_descriptor.
5519
5520 2019-03-26 Bin Cheng <bin.cheng@linux.alibaba.com>
5521
5522 PR tree-optimization/81740
5523 * tree-vect-data-refs.c (vect_analyze_data_ref_dependence):
5524 In case of outer loop vectorization, check for backward dependence
5525 at the inner loop if outer loop dependence is reversed.
5526
5527 2019-03-26 Alan Modra <amodra@gmail.com>
5528
5529 * config/rs6000/rs6000.c (rs6000_init_hard_regno_mode_ok): Correct
5530 rs6000_vector_mem init. Correct wI and wJ comment.
5531
5532 2019-03-25 Alexander Monakov <amonakov@ispras.ru>
5533
5534 PR rtl-optimization/88347
5535 PR rtl-optimization/88423
5536 * sched-deps.c (sched_analyze_insn): Take into account that for
5537 tablejumps the barrier appears after a label and a jump_table_data.
5538
5539 2019-03-25 Martin Sebor <msebor@redhat.com>
5540
5541 PR c/89812
5542 * c-common.c (check_user_alignment): Rename local. Correct maximum
5543 alignment in diagnostic. Avoid assuming argument fits in SHWI,
5544 convert it to UHWI when it fits.
5545
5546 2019-03-25 Johan Karlsson <johan.karlsson@enea.com>
5547
5548 PR debug/86964
5549 * dwarf2out.c (premark_used_variables): New function.
5550 (prune_unused_types_walk): Do not mark not premarked external
5551 variables.
5552 (prune_unused_types): Call premark_used_variables.
5553
5554 2019-03-25 Vladimir Makarov <vmakarov@redhat.com>
5555
5556 PR rtl-optimization/89676
5557 * lra-constraints.c (curr_insn_transform): Do match reload for
5558 early clobbers when the match was successful only for different
5559 registers.
5560
5561 2019-03-25 Martin Sebor <msebor@redhat.com>
5562
5563 * doc/extend.texi (Common Type Attributes): Document vector_size.
5564 (Common Variable Attributes): Mention size constraint. Correct
5565 quoting and typos.
5566 (Vector Extensions): Use @dfn when defining bas type. Clarify
5567 base type and size constraints.
5568
5569 2019-03-25 Richard Biener <rguenther@suse.de>
5570
5571 PR tree-optimization/89789
5572 * tree-ssa-sccvn.c (set_ssa_val_to): Do not allow lattice
5573 changes from non-undefined back to undefined.
5574
5575 2019-03-25 Thomas Otto <thomas.otto@pdv-fs.de>
5576
5577 * dwarf2out.c (comp_dir_string): cached_wd could be set to both a
5578 heap string and a gc string, but since this variable is unknown to
5579 ggc the gc string might get reused and corrupted. Fixed by always
5580 using a heap string.
5581
5582 2019-03-25 Richard Biener <rguenther@suse.de>
5583
5584 PR tree-optimization/89779
5585 * tree-ssa-loop-ivopts.c (remove_unused_ivs): Return
5586 to remove IV defs, delay actual removal.
5587 (tree_ssa_iv_optimize_loop): Likewise. Avoid SCEV reset.
5588 (tree_ssa_iv_optimize): Remove eliminated IV defs at the
5589 very end, properly also reset loop control IV information.
5590
5591 2019-03-25 Richard Biener <rguenther@suse.de>
5592
5593 PR tree-optimization/89802
5594 * tree-ssa-math-opts.c (convert_mult_to_fma_1): Properly
5595 move EH data to folded stmt.
5596
5597 2019-03-25 Andreas Krebbel <krebbel@linux.ibm.com>
5598
5599 * config/s390/s390-builtin-types.def: Remove few unused types and
5600 fix sort order for others.
5601
5602 2019-03-25 Andreas Krebbel <krebbel@linux.ibm.com>
5603
5604 * config/s390/s390-c.c (s390_fn_types_compatible): Print the
5605 expected and found types with -mdebug during builtin matching.
5606
5607 2019-03-25 Richard Biener <rguenther@suse.de>
5608
5609 PR middle-end/89790
5610 * fold-const.c (operand_equal_p): Revert last change with
5611 updated comment.
5612
5613 2019-03-24 Segher Boessenkool <segher@kernel.crashing.org>
5614
5615 * config/rs6000/rs6000.c (rs6000_legitimize_tls_address): Add REG_EQUAL
5616 notes for the result of the __tls_get_addr calls.
5617 * config/rs6000/rs6000.md (unspec UNSPEC_TLS_GET_ADDR): New.
5618
5619 2019-03-24 Jeff Law <law@redhat.com>
5620
5621 * config/bfin/bfin.md (movpdi): Fix length for alternative 1.
5622
5623 PR rtl-optimization/87761
5624 * regcprop.c (copyprop_hardreg_forward_1): Check may_trap_p on SET,
5625 not INSN. Also check RTX_FRAME_RELATED_P. Queue insns for DF rescan
5626 as needed.
5627 (pass_cprop_hardreg::execute): Add df note problem and defer insn
5628 rescans. Reprocess blocks as needed, calling df_analyze before
5629 reprocessing. Always call df_analyze before fixing up debug bind
5630 insns.
5631
5632 2019-03-23 Segher Boessenkool <segher@kernel.crashing.org>
5633
5634 * config/rs6000/xmmintrin.h (_mm_movemask_pi8): Implement for 32-bit
5635 big endian.
5636
5637 2019-03-22 Andrew Pinski <apinski@marvell.com>
5638
5639 * config/aarch64/aarch64.md (zero_extendsidi2_aarch64): Fix type
5640 attrribute for uxtw.
5641
5642 2019-03-26 Jeff Law <law@redhat.com>
5643
5644 PR rtl-optimization/87761
5645 * config/mips/mips-protos.h (mips_split_move): Add new argument.
5646 (mips_emit_move_or_split): Pass NULL for INSN into mips_split_move.
5647 (mips_split_move): Accept new INSN argument. Try to forward SRC
5648 into the next instruction.
5649 (mips_split_move_insn): Pass INSN through to mips_split_move.
5650
5651 2019-03-22 Vladimir Makarov <vmakarov@redhat.com>
5652
5653 PR rtl-optimization/89676
5654 * lra-constraints.c (curr_insn_transform): Do match reload for
5655 early clobbers even if the match was successful.
5656
5657 2019-03-22 Jakub Jelinek <jakub@redhat.com>
5658
5659 PR c++/87481
5660 * doc/invoke.texi (-fconstexpr-ops-limit=): Document.
5661
5662 2019-03-22 Bill Schmidt <wschmidt@linux.ibm.com>
5663
5664 * config/rs6000/mmintrin.h (_mm_sub_pi32): Fix typo.
5665
5666 2019-03-22 Jakub Jelinek <jakub@redhat.com>
5667
5668 * config/i386/sse.md (<avx512>_fmadd_<mode>_mask3<round_name>,
5669 <avx512>_fmsub_<mode>_mask3<round_name>,
5670 <avx512>_fnmadd_<mode>_mask3<round_name>,
5671 <avx512>_fnmsub_<mode>_mask3<round_name>,
5672 avx512f_vmfmadd_<mode>_mask3<round_name>,
5673 avx512f_vmfmsub_<mode>_mask3<round_name>,
5674 *avx512f_vmfnmadd_<mode>_mask3<round_name>): Use <round_nimm_predicate>
5675 instead of register_operand and %v instead of v for match_operand 1.
5676 (avx512f_vmfnmsub_<mode>_mask3<round_name>): Rename to ...
5677 (*avx512f_vmfnmsub_<mode>_mask3<round_name>): ... this. Use
5678 <round_nimm_predicate> instead of register_operand and %v instead of v
5679 for match_operand 1.
5680
5681 * config/i386/sse.md (<avx512>_fmadd_<mode>_mask<round_name>,
5682 <avx512>_fmadd_<mode>_mask3<round_name>,
5683 <avx512>_fmsub_<mode>_mask<round_name>,
5684 <avx512>_fmsub_<mode>_mask3<round_name>,
5685 <avx512>_fnmadd_<mode>_mask<round_name>,
5686 <avx512>_fnmadd_<mode>_mask3<round_name>,
5687 <avx512>_fnmsub_<mode>_mask<round_name>,
5688 <avx512>_fnmsub_<mode>_mask3<round_name>,
5689 <avx512>_fmaddsub_<mode>_mask<round_name>,
5690 <avx512>_fmaddsub_<mode>_mask3<round_name>,
5691 <avx512>_fmsubadd_<mode>_mask<round_name>,
5692 <avx512>_fmsubadd_<mode>_mask3<round_name>): Use
5693 <round_nimm_predicate> instead of nonimmediate_operand.
5694 (fmai_vmfmadd_<mode><round_name>, fmai_vmfmsub_<mode><round_name>,
5695 fmai_vmfnmadd_<mode><round_name>, fmai_vmfnmsub_<mode><round_name>):
5696 Use register_operand instead of <round_nimm_predicate> for the
5697 operand that needs to match output.
5698 (*fmai_fmadd_<mode>, *fmai_fmsub_<mode>,
5699 *fmai_fnmadd_<mode><round_name>, *fmai_fnmsub_<mode><round_name>):
5700 Likewise. Formatting fixes.
5701
5702 PR target/89784
5703 * config/i386/i386.c (enum ix86_builtins): Remove
5704 IX86_BUILTIN_VFMSUBSD3_MASK3 and IX86_BUILTIN_VFMSUBSS3_MASK3.
5705 * config/i386/i386-builtin.def (__builtin_ia32_vfmaddsd3_mask,
5706 __builtin_ia32_vfmaddsd3_mask3, __builtin_ia32_vfmaddsd3_maskz,
5707 __builtin_ia32_vfmsubsd3_mask3, __builtin_ia32_vfmaddss3_mask,
5708 __builtin_ia32_vfmaddss3_mask3, __builtin_ia32_vfmaddss3_maskz,
5709 __builtin_ia32_vfmsubss3_mask3): New builtins.
5710 * config/i386/sse.md (avx512f_vmfmadd_<mode>_mask<round_name>,
5711 avx512f_vmfmadd_<mode>_mask3<round_name>,
5712 avx512f_vmfmadd_<mode>_maskz_1<round_name>,
5713 *avx512f_vmfmsub_<mode>_mask<round_name>,
5714 avx512f_vmfmsub_<mode>_mask3<round_name>,
5715 *avx512f_vmfmasub_<mode>_maskz_1<round_name>,
5716 *avx512f_vmfnmadd_<mode>_mask<round_name>,
5717 *avx512f_vmfnmadd_<mode>_mask3<round_name>,
5718 *avx512f_vmfnmadd_<mode>_maskz_1<round_name>,
5719 *avx512f_vmfnmsub_<mode>_mask<round_name>,
5720 avx512f_vmfnmsub_<mode>_mask3<round_name>,
5721 *avx512f_vmfnmsub_<mode>_maskz_1<round_name>): New define_insns.
5722 (avx512f_vmfmadd_<mode>_maskz<round_expand_name>): New define_expand.
5723 * config/i386/avx512fintrin.h (_mm_mask_fmadd_sd, _mm_mask_fmadd_ss,
5724 _mm_mask3_fmadd_sd, _mm_mask3_fmadd_ss, _mm_maskz_fmadd_sd,
5725 _mm_maskz_fmadd_ss, _mm_mask_fmsub_sd, _mm_mask_fmsub_ss,
5726 _mm_mask3_fmsub_sd, _mm_mask3_fmsub_ss, _mm_maskz_fmsub_sd,
5727 _mm_maskz_fmsub_ss, _mm_mask_fnmadd_sd, _mm_mask_fnmadd_ss,
5728 _mm_mask3_fnmadd_sd, _mm_mask3_fnmadd_ss, _mm_maskz_fnmadd_sd,
5729 _mm_maskz_fnmadd_ss, _mm_mask_fnmsub_sd, _mm_mask_fnmsub_ss,
5730 _mm_mask3_fnmsub_sd, _mm_mask3_fnmsub_ss, _mm_maskz_fnmsub_sd,
5731 _mm_maskz_fnmsub_ss, _mm_mask_fmadd_round_sd, _mm_mask_fmadd_round_ss,
5732 _mm_mask3_fmadd_round_sd, _mm_mask3_fmadd_round_ss,
5733 _mm_maskz_fmadd_round_sd, _mm_maskz_fmadd_round_ss,
5734 _mm_mask_fmsub_round_sd, _mm_mask_fmsub_round_ss,
5735 _mm_mask3_fmsub_round_sd, _mm_mask3_fmsub_round_ss,
5736 _mm_maskz_fmsub_round_sd, _mm_maskz_fmsub_round_ss,
5737 _mm_mask_fnmadd_round_sd, _mm_mask_fnmadd_round_ss,
5738 _mm_mask3_fnmadd_round_sd, _mm_mask3_fnmadd_round_ss,
5739 _mm_maskz_fnmadd_round_sd, _mm_maskz_fnmadd_round_ss,
5740 _mm_mask_fnmsub_round_sd, _mm_mask_fnmsub_round_ss,
5741 _mm_mask3_fnmsub_round_sd, _mm_mask3_fnmsub_round_ss,
5742 _mm_maskz_fnmsub_round_sd, _mm_maskz_fnmsub_round_ss): New intrinsics.
5743
5744 2019-03-21 Martin Sebor <msebor@redhat.com>
5745
5746 PR tree-optimization/89350
5747 * builtins.c (compute_objsize): Also ignore offsets whose upper
5748 bound is negative.
5749 * gimple-ssa-warn-restrict.c (builtin_memref): Add new member.
5750 (builtin_memref::builtin_memref): Initialize new member.
5751 Allow EXPR to be null.
5752 (builtin_memref::extend_offset_range): Replace local with a member.
5753 Avoid assuming pointer offsets are unsigned.
5754 (builtin_memref::set_base_and_offset): Determine base object
5755 before computing offset range.
5756 (builtin_access::builtin_access): Handle memset.
5757 (builtin_access::generic_overlap): Replace local with a member.
5758 (builtin_access::strcat_overlap): Same.
5759 (builtin_access::overlap): Same.
5760 (maybe_diag_overlap): Same.
5761 (maybe_diag_access_bounds): Same.
5762 (wrestrict_dom_walker::check_call): Handle memset.
5763 (check_bounds_or_overlap): Same.
5764
5765 2019-03-21 Jan Hubicka <hubicka@ucw.cz>
5766 Jakub Jelinek <jakub@redhat.com>
5767
5768 PR lto/89692
5769 * tree.c (fld_type_variant, fld_incomplete_type_of,
5770 fld_process_array_type): Call fld->pset.add and don't call
5771 add_tree_to_fld_list if it returns true.
5772 (free_lang_data_in_type): Similarly with self-recursive call. Purge
5773 non-marked types from TYPE_NEXT_VARIANT list.
5774 (find_decls_types_r): Call fld_worklist_push for TYPE_CANONICAL (t).
5775
5776 2019-03-21 Jakub Jelinek <jakub@redhat.com>
5777
5778 * hash-table.h (hash_table): Add Lazy template parameter defaulted
5779 to false, if true, don't alloc_entries during construction, but defer
5780 it to the first method that needs m_entries allocated.
5781 (hash_table::hash_table, hash_table::~hash_table,
5782 hash_table::alloc_entries, hash_table::find_empty_slot_for_expand,
5783 hash_table::too_empty_p, hash_table::expand, hash_table::empty_slow,
5784 hash_table::clear_slot, hash_table::traverse_noresize,
5785 hash_table::traverse, hash_table::iterator::slide): Adjust all methods.
5786 * hash-set.h (hash_set): Add Lazy template parameter defaulted to
5787 false.
5788 (hash_set::contains): If Lazy is true, use find_slot_with_hash with
5789 NO_INSERT instead of find_with_hash.
5790 (hash_set::traverse, hash_set::iterator, hash_set::iterator::m_iter,
5791 hash_set::m_table): Add Lazy to template params of hash_table.
5792 (gt_ggc_mx, gt_pch_nx): Use false as Lazy in hash_set template param.
5793 * attribs.c (test_attribute_exclusions): Likewise.
5794 * hash-set-tests.c (test_set_of_strings): Add iterator tests for
5795 hash_set. Add tests for hash_set with Lazy = true.
5796
5797 2019-03-21 Richard Biener <rguenther@suse.de>
5798
5799 PR tree-optimization/89779
5800 * tree.c (tree_nop_conversion): Consolidate and fix defensive
5801 checks with respect to released SSA names now having error_mark_node
5802 type.
5803 * fold-const.c (operand_equal_p): Likewise.
5804
5805 2019-03-20 Andreas Krebbel <krebbel@linux.ibm.com>
5806
5807 PR target/89775
5808 * config/s390/s390.c (global_not_special_regno_p): Move to make it
5809 available to ...
5810 (s390_optimize_register_info): Use global_not_special_regno_p to
5811 check for global regs.
5812
5813 2019-03-20 Jakub Jelinek <jakub@redhat.com>
5814
5815 PR target/89752
5816 * lra-constraints.c (process_alt_operands) <reg>: For BLKmode, don't
5817 update this_alternative nor this_alternative_set.
5818
5819 2019-03-19 Jim Wilson <jimw@sifive.com>
5820
5821 PR target/89411
5822 * config/riscv/riscv.c (riscv_valid_lo_sum_p): New arg x. New locals
5823 align, size, offset. Use them to handle a BLKmode reference. Update
5824 comment.
5825 (riscv_classify_address): Pass info->offset to riscv_valid_lo_sum_p.
5826
5827 2019-03-19 Jakub Jelinek <jakub@redhat.com>
5828
5829 PR rtl-optimization/89768
5830 * loop-unroll.c (unroll_loop_constant_iterations): Use gen_int_mode
5831 instead of GEN_INT.
5832 (unroll_loop_runtime_iterations): Likewise.
5833
5834 2019-03-19 Martin Sebor <msebor@redhat.com>
5835
5836 PR tree-optimization/89644
5837 * tree-ssa-strlen.c (handle_builtin_stxncpy): Use full_string_p
5838 rather than endptr as an indicator of nul-termination.
5839
5840 PR tree-optimization/89644
5841 * tree-ssa-strlen.c (handle_builtin_stxncpy): Consider unterminated
5842 arrays in determining sequence sizes in strncpy and stpncpy.
5843
5844 2019-03-19 Martin Liska <mliska@suse.cz>
5845
5846 PR middle-end/89737
5847 * predict.c (combine_predictions_for_bb): Empty likely_edges and
5848 unlikely_edges if there's an edge that belongs to both these sets.
5849
5850 2018-03-19 Segher Boessenkool <segher@kernel.crashing.org>
5851
5852 PR target/89746
5853 * config/rs6000/rs6000.md (fix_trunc<mode>si2_stfiwx): If we have a
5854 non-TARGET_MFCRF target, and the dest is memory but not 32-bit aligned,
5855 go via a stack temporary.
5856
5857 2019-03-19 Jakub Jelinek <jakub@redhat.com>
5858
5859 PR target/89378
5860 * config/mips/mips.c (mips_expand_vec_cond_expr): Use gen_lowpart
5861 instead of gen_rtx_SUBREG.
5862 * config/mips/mips-msa.md (vec_extract<mode><unitmode>): Likewise.
5863
5864 2019-03-19 Richard Biener <rguenther@suse.de>
5865
5866 PR debug/88389
5867 * opts.c (finish_options): Disable -gsplit-dwarf when doing LTO.
5868
5869 2019-03-19 Jan Hubicka <hubicka@ucw.cz>
5870
5871 PR lto/87809
5872 PR lto/89335
5873 * tree.c (free_lang_data_in_decl): Do not free context of C++
5874 destrutors.
5875
5876 2019-03-19 Jakub Jelinek <jakub@redhat.com>
5877
5878 PR target/89506
5879 * config/arm/arm.md (cmpsi2_addneg): Swap the alternatives and use
5880 subs for the first alternative except when operands[3] is 1.
5881
5882 PR target/89752
5883 * gimplify.c (gimplify_asm_expr): For output argument with
5884 TREE_ADDRESSABLE type, clear allows_reg if it allows memory, otherwise
5885 diagnose error.
5886
5887 2019-03-19 Eric Botcazou <ebotcazou@adacore.com>
5888
5889 PR rtl-optimization/89753
5890 * loop-unroll.c (decide_unroll_constant_iterations): Make guard for
5891 explicit unrolling factor even more robust.
5892
5893 2019-03-19 Jakub Jelinek <jakub@redhat.com>
5894
5895 PR target/89726
5896 * config/i386/i386.c (ix86_expand_floorceildf_32): In ceil
5897 compensation use x2 += 1 instead of x2 -= -1 and when honoring
5898 signed zeros, do another copysign after the compensation.
5899
5900 2019-03-18 Martin Sebor <msebor@redhat.com>
5901
5902 PR tree-optimization/89720
5903 * tree-vrp.c (vrp_prop::check_mem_ref): Treat range with max < min
5904 more conservatively, the same as anti-range.
5905
5906 2019-03-18 Richard Biener <rguenther@suse.de>
5907
5908 PR middle-end/88945
5909 * tree-ssanames.c (release_ssa_name_fn): For released SSA names
5910 use a TREE_TYPE of error_mark_node to avoid ICEs when dumping
5911 basic-blocks that are removed. Remove restoring SSA_NAME_VAR.
5912 * tree-outof-ssa.c (eliminate_useless_phis): Remove redundant checking.
5913
5914 2019-03-18 Andrew Stubbs <ams@codesourcery.com>
5915
5916 * config/gcn/gcn-run.c (struct output): Make next_output unsigned.
5917 Extend queue to 1024 entries.
5918 Add "consumed" field.
5919 (gomp_print_output): Remove print_index parameter.
5920 Add final parameter.
5921 Change limit to unsigned.
5922 Use consumed field to implement circular buffer.
5923 Detect interrupted print in final pass.
5924 Flush output at the end.
5925 (run): Update gomp_print_output usage.
5926 (main): Initialize kernargs->output_data.consumed.
5927
5928 2019-03-18 Richard Sandiford <richard.sandiford@arm.com>
5929
5930 * tree-vect-loop.c (vect_estimate_min_profitable_iters): Fix the
5931 calculation of the minimum number of scalar iterations for
5932 fully-predicated loops.
5933
5934 2019-03-18 Martin Jambor <mjambor@suse.cz>
5935
5936 PR tree-optimization/89546
5937 * tree-sra.c (propagate_subaccesses_across_link): Requeue new_acc if
5938 any propagation to its children took place.
5939
5940 2019-03-18 Andrew Burgess <andrew.burgess@embecosm.com>
5941
5942 PR target/89627
5943 * config/riscv/riscv.c (riscv_pass_fpr_single): Add offset
5944 parameter, and make use of it.
5945 (riscv_get_arg_info): Pass offset to riscv_pass_fpr_single.
5946
5947 2019-03-18 Claudiu Zissulescu <claziss@synopsys.com>
5948
5949 * config/arc/arc.opt (mcode-density-frame): Get the inital value
5950 from TARGET_CODE_DENSITY_FRAME_DEFAULT.
5951 * config/arc/elf.h (TARGET_CODE_DENSITY_FRAME_DEFAULT): Define.
5952 * config/arc/linux.h (TARGET_CODE_DENSITY_FRAME_DEFAULT): Define.
5953 * config/arc/arc.md (pop_multi_fp_blink): Adjust constraints to
5954 match what the ops is doing.
5955 (push_multi_fp_blink): Likewise.
5956 * config/arc/arc.c (arc_override_options): Enable enter/leave when
5957 compiling for size and elf target.
5958 (arc_save_callee_enter): Adjust note to match what enter/leave
5959 operation does.
5960
5961 2019-03-18 Claudiu Zissulescu <claziss@synopsys.com>
5962
5963 * config/arc/arc.md (tst_movb): Fix constraint.
5964
5965 2019-03-18 Claudiu Zissulescu <claziss@synopsys.com>
5966
5967 * config/arc/arc.c (TARGET_HAVE_SPECULATION_SAFE_VALUE): Define.
5968
5969 2019-03-18 Claudiu Zissulescu <claziss@synopsys.com>
5970
5971 * config/arc/arc-protos.h (arc_adjust_reg_alloc_order): Declare.
5972 * config/arc/arc.c (arc_conditional_register_usage): Remove all
5973 reg_alloc_order references.
5974 (size_alloc_order): Define.
5975 (arc_adjust_reg_alloc_order): New function.
5976 * config/arc/arc.h (REG_ALLOC_ORDER): Proper define the register
5977 order.
5978 (ADJUST_REG_ALLOC_ORDER): Define.
5979 (HONOR_REG_ALLOC_ORDER): Likewise.
5980
5981 2019-03-18 Richard Biener <rguenther@suse.de>
5982
5983 PR target/87561
5984 * config/i386/i386.c (ix86_add_stmt_cost): Pessimize strided
5985 loads and stores a bit more.
5986
5987 2019-03-18 Richard Biener <rguenther@suse.de>
5988
5989 PR target/87561
5990 * config/i386/i386.c (ix86_add_stmt_cost): Apply strided
5991 load pessimization to stores as well.
5992
5993 2019-03-18 Andrey Belevantsev <abel@ispras.ru>
5994
5995 PR middle-end/86979
5996 * sel-sched.c (compute_av_set_at_bb_end): When we have an ineligible
5997 successor, use NULL as its av set.
5998
5999 2019-03-15 Segher Boessenkool <segher@kernel.crashing.org>
6000
6001 PR rtl-optimization/89721
6002 * lra-constraints (invariant_p): Return false if side_effects_p holds.
6003
6004 2019-03-15 Kelvin Nilsen <kelvin@gcc.gnu.org>
6005
6006 PR target/87532
6007 * config/rs6000/rs6000-c.c (altivec_resolve_overloaded_builtin):
6008 When handling vec_extract, use modular arithmetic to allow
6009 constant selectors greater than vector length.
6010 * config/rs6000/rs6000.c (rs6000_expand_vector_extract): Allow
6011 V1TImode vectors to have constant selector values greater than 0.
6012 Use modular arithmetic to compute vector index.
6013 (rs6000_split_vec_extract_var): Use modular arithmetic to compute
6014 index for in-memory vectors. Correct code generation for
6015 in-register vectors.
6016 (altivec_expand_vec_ext_builtin): Use modular arithmetic to
6017 compute index.
6018
6019 2019-03-15 Alexandre Oliva <aoliva@redhat.com>
6020
6021 PR c++/88534
6022 PR c++/88537
6023 * dwarf2out.c (generic_parameter_die): Follow DECL_INITIAL of
6024 VAR_DECL args.
6025
6026 2019-03-15 Jakub Jelinek <jakub@redhat.com>
6027
6028 PR c++/89709
6029 * tree.c (inchash::add_expr): Strip any location wrappers.
6030 * fold-const.c (operand_equal_p): Move stripping of location wrapper
6031 after hash verification.
6032
6033 PR debug/89704
6034 * dwarf2out.c (add_const_value_attribute): Return false for MINUS,
6035 SIGN_EXTEND and ZERO_EXTEND.
6036
6037 2019-03-14 Jason Merrill <jason@redhat.com>
6038 Jakub Jelinek <jakub@redhat.com>
6039
6040 * hash-table.h (remove_elt_with_hash): Return if slot is NULL rather
6041 than if is_empty (*slot).
6042 * hash-set-tests.c (test_set_of_strings): Add tests for addition of
6043 existing elt and for elt removal.
6044 * hash-map-tests.c (test_map_of_strings_to_int): Add test for removal
6045 of already removed elt.
6046
6047 2019-03-15 H.J. Lu <hongjiu.lu@intel.com>
6048
6049 PR target/89650
6050 * config/i386/i386.c (remove_partial_avx_dependency): Handle
6051 REG_EH_REGION note.
6052
6053 2019-03-14 Martin Liska <mliska@suse.cz>
6054
6055 PR other/89712
6056 * doc/invoke.texi: Remove -fdump-class-hierarchy option.
6057
6058 2019-03-14 Richard Biener <rguenther@suse.de>
6059
6060 PR target/89711
6061 * config/i386/i386.c (make_resolver_func): Properly set
6062 DECL_CONTEXT on the RESULT_DECL.
6063 * config/rs6000/rs6000.c (make_resolver_func): Likewise.
6064
6065 2019-03-14 Richard Biener <rguenther@suse.de>
6066
6067 * gimple-pretty-print.c: Include cfgloop.h.
6068 (dump_gimple_phi): Adjust.
6069 (dump_gimple_bb_header): Dump loop header for GIMPLE.
6070 (pp_cfg_jump): Adjust.
6071 (dump_implicit_edges): Dump fallthru to next block for GIMPLE as well.
6072 * tree-cfg.c (build_gimple_cfg): Remove lower_phi_internal_fn call.
6073 (lower_phi_internal_fn): Remove.
6074 (verify_gimple_call): Remove IFN_PHI special-casing.
6075 (dump_function_to_file): Dump IL state.
6076 * tree-into-ssa.c (rewrite_add_phi_arguments): Revert changes
6077 done to deal with PHI nodes being present in non-SSA state.
6078
6079 2019-03-14 Jakub Jelinek <jakub@redhat.com>
6080
6081 PR ipa/89684
6082 * multiple_target.c (create_dispatcher_calls): Change
6083 references_to_redirect from vector of ipa_ref * to vector of ipa_ref.
6084 In the node->iterate_referring loop, push *ref rather than ref, call
6085 ref->remove_reference () and always pass 0 to iterate_referring.
6086
6087 PR rtl-optimization/89679
6088 * expmed.c (expand_mult_const): Don't add a REG_EQUAL note if it
6089 would contain a paradoxical SUBREG.
6090
6091 2019-03-14 Richard Biener <rguenther@suse.de>
6092
6093 PR tree-optimization/89710
6094 * tree-ssa-loop-ch.c (should_duplicate_loop_header_p): Use
6095 safe_dyn_cast.
6096
6097 2019-03-14 Martin Liska <mliska@suse.cz>
6098
6099 * coverage.c (coverage_begin_function): Stream also
6100 end_column.
6101 * doc/gcov.texi: Document 2 new fields in JSON file. Improve
6102 documentation about function declaration location.
6103 * gcov-dump.c (tag_function): Print whole range
6104 of function declaration.
6105 * gcov.c (struct function_info): Add end_column field.
6106 (function_info::function_info): Initialize it.
6107 (output_json_intermediate_file): Output {start,end}_column
6108 fields.
6109 (read_graph_file): Read end_column.
6110
6111 2019-03-14 Richard Biener <rguenther@suse.de>
6112
6113 PR middle-end/89698
6114 * fold-const.c (operand_equal_p): For INDIRECT_REF check
6115 that the access types are similar.
6116
6117 2019-03-14 Jakub Jelinek <jakub@redhat.com>
6118
6119 PR tree-optimization/89703
6120 * tree-ssa-strlen.c (valid_builtin_call): Punt if stmt call types
6121 aren't compatible also with builtin_decl_explicit. Check pure
6122 or non-pure status of BUILT_IN_STR{{,N}CMP,N{LEN,{CAT,CPY}{,_CHK}}}
6123 and BUILT_IN_STPNCPY{,_CHK}.
6124
6125 2019-03-14 H.J. Lu <hongjiu.lu@intel.com>
6126
6127 PR target/89523
6128 * config/i386/i386.c (ix86_print_operand): Handle 'M' to add
6129 addr32 prefix to VSIB address for X32.
6130 * config/i386/sse.md (*avx512pf_gatherpf<mode>sf_mask): Prepend
6131 "%M2" to opcode.
6132 (*avx512pf_gatherpf<mode>df_mask): Likewise.
6133 (*avx512pf_scatterpf<mode>sf_mask): Likewise.
6134 (*avx512pf_scatterpf<mode>df_mask): Likewise.
6135 (*avx2_gathersi<mode>): Prepend "%M3" to opcode.
6136 (*avx2_gathersi<mode>_2): Prepend "%M2" to opcode.
6137 (*avx2_gatherdi<mode>): Prepend "%M3" to opcode.
6138 (*avx2_gatherdi<mode>_2): Prepend "%M2" to opcode.
6139 (*avx2_gatherdi<mode>_3): Prepend "%M3" to opcode.
6140 (*avx2_gatherdi<mode>_4): Prepend "%M2" to opcode.`
6141 (*avx512f_gathersi<mode>): Prepend "%M4" to opcode.
6142 (*avx512f_gathersi<mode>_2): Prepend "%M3" to opcode.
6143 (*avx512f_gatherdi<mode>): Prepend "%M4" to opcode.
6144 (*avx512f_gatherdi<mode>_2): Prepend "%M3" to opcode.
6145 (*avx512f_scattersi<mode>): Prepend "%M0" to opcode.
6146 (*avx512f_scatterdi<mode>): Likewise.
6147
6148 2019-03-13 Vladimir Makarov <vmakarov@redhat.com>
6149
6150 PR target/85860
6151 * lra-constraints.c (inherit_in_ebb): Update
6152 potential_reload_hard_regs along with live_hard_regs.
6153
6154 2019-03-13 Jakub Jelinek <jakub@redhat.com>
6155
6156 PR debug/89498
6157 * dwarf2out.c (size_of_die): For dw_val_class_view_list always use
6158 DWARF_OFFSET_SIZE.
6159 (value_format): For dw_val_class_view_list never use DW_FORM_loclistx.
6160
6161 2019-03-13 Martin Sebor <msebor@redhat.com>
6162
6163 PR tree-optimization/89662
6164 * tree-vrp.c (vrp_prop::check_mem_ref): Avoid assuming every type
6165 has a size.
6166
6167 2019-03-13 Richard Biener <rguenther@suse.de>
6168
6169 PR middle-end/89677
6170 * tree-scalar-evolution.c (simplify_peeled_chrec): Do not
6171 throw FP expressions at tree-affine.
6172
6173 2019-03-14 Richard Biener <rguenther@suse.de>
6174
6175 * tree-pretty-print.c (dump_generic_node): For -gimple properly
6176 dump negative integer constants using _Literal (type) -num.
6177
6178 2019-03-13 Jakub Jelinek <jakub@redhat.com>
6179
6180 * ipa-param-manipulation.h (struct ipa_parm_adjustment): Remove
6181 nonlocal_value member.
6182
6183 PR middle-end/88588
6184 * omp-simd-clone.c (ipa_simd_modify_stmt_ops): Handle PHI args.
6185 (ipa_simd_modify_function_body): Handle PHIs.
6186
6187 2019-03-12 Robin Dapp <rdapp@linux.ibm.com>
6188
6189 * config/s390/s390.c (s390_option_override_internal): Use more
6190 aggressive inlining parameters.
6191
6192 2019-03-12 Robin Dapp <rdapp@linux.ibm.com>
6193
6194 * config/s390/3906.md: New file.
6195 * config/s390/s390.c (MAX_SCHED_UNITS): Increase.
6196 (LONGRUNNING_THRESHOLD): Remove.
6197 (MAX_SCHED_MIX_SCORE): Decrease.
6198 (MAX_SCHED_MIX_DISTANCE): Decrease.
6199 (s390_bb_fallthru_entry_likely): Assume fallthru for less than likely.
6200 (struct s390_sched_state): New struct to hold scheduling state.
6201 (S390_SCHED_STATE_NORMAL): Remove.
6202 (S390_SCHED_STATE_CRACKED): Remove.
6203 (S390_SCHED_ATTR_MASK_GROUPOFTWO): Add.
6204 (s390_get_sched_attrmask): Use new attribute.
6205 (s390_get_unit_mask): Use new units.
6206 (s390_is_fpd): New function.
6207 (s390_is_fxd): New function.
6208 (s390_is_longrunning): New function.
6209 (s390_sched_score): Use new functions.
6210 (s390_sched_reorder): Likewise.
6211 (s390_sched_variable_issue): Rework and use new functions.
6212 (s390_sched_init): Use new functions.
6213 * config/s390/s390.h (s390_tune_attr): Add z14.
6214 * config/s390/s390.md: Add z14.
6215
6216 2019-03-12 Robin Dapp <rdapp@linux.ibm.com>
6217
6218 * config/s390/2964.md: Update pipeline description.
6219 * config/s390/s390.c (MAX_SCHED_UNITS): Increase.
6220 (LONGRUNNING_THRESHOLD): Remove.
6221 (LATENCY_FACTOR): Remove.
6222 (s390_get_unit_mask): Add unit.
6223 (s390_sched_score): Use fxd/fpd.
6224 (s390_sched_variable_issue): Use fxd/fpd.
6225
6226 2019-03-12 Martin Liska <mliska@suse.cz>
6227
6228 * config/i386/i386.c: Reword an error message.
6229
6230 2019-03-12 Martin Jambor <mjambor@suse.cz>
6231
6232 * cgraph.c (cgraph_node::dump): Dump more info for former thunks,
6233 terminate with newline.
6234
6235 2019-03-12 Jakub Jelinek <jakub@redhat.com>
6236
6237 PR target/52726
6238 * config/s390/s390.md (tabort): Use %wd instead of
6239 HOST_WIDE_INT_PRINT_DEC in error message, reword to avoid two capital
6240 letters and periods.
6241 * config/tilepro/tilepro.c (tilepro_print_operand): Use %wd in
6242 output_operand_lossage instead of HOST_WIDE_INT_PRINT_DEC, replace
6243 's with %< and %>.
6244
6245 PR middle-end/89663
6246 * builtins.c (expand_builtin_int_roundingfn,
6247 expand_builtin_int_roundingfn_2): Return NULL_RTX instead of
6248 gcc_unreachable if validate_arglist fails.
6249
6250 2019-03-12 Richard Biener <rguenther@suse.de>
6251
6252 PR tree-optimization/89664
6253 * tree-ssa-math-opts.c (execute_cse_reciprocals_1): Properly
6254 free the occurance tree after the early out.
6255
6256 2019-03-11 Jakub Jelinek <jakub@redhat.com>
6257
6258 PR middle-end/89655
6259 PR bootstrap/89656
6260 * vr-values.c (vr_values::update_value_range): If
6261 old_vr->varying_p (), don't update it, make new_vr also VARYING
6262 and return false.
6263
6264 2019-03-11 Martin Liska <mliska@suse.cz>
6265
6266 * config/aarch64/aarch64.c (aarch64_override_options_internal):
6267 Fix double string quoting.
6268
6269 2019-03-11 Martin Liska <mliska@suse.cz>
6270
6271 * collect-utils.c (collect_wait): Wrap apostrophes
6272 in gcc internal format with %'.
6273 * collect2.c (main): Likewise.
6274 (scan_prog_file): Likewise.
6275 (scan_libraries): Likewise.
6276 * config/i386/i386.c (ix86_expand_call): Likewise.
6277 (ix86_handle_interrupt_attribute): Likewise.
6278 * config/nds32/nds32-intrinsic.c (nds32_expand_builtin_impl): Likewise.
6279 * config/nds32/nds32.c (nds32_insert_attributes): Likewise.
6280 * config/rl78/rl78.c (rl78_handle_saddr_attribute): Likewise.
6281 * lto-wrapper.c (find_crtoffloadtable): Likewise.
6282 * symtab.c (symtab_node::verify_base): Likewise.
6283 * tree-cfg.c (verify_gimple_label): Likewise.
6284 * tree.c (verify_type_variant): Likewise.
6285
6286 2019-03-11 Martin Liska <mliska@suse.cz>
6287
6288 * builtins.c (expand_builtin_thread_pointer): Wrap an option name
6289 in a string format message and fix GNU coding style.
6290 (expand_builtin_set_thread_pointer): Likewise.
6291 * common/config/aarch64/aarch64-common.c
6292 (aarch64_rewrite_selected_cpu): Likewise.
6293 * common/config/alpha/alpha-common.c (alpha_handle_option): Likewise.
6294 * common/config/arc/arc-common.c (arc_handle_option): Likewise.
6295 * common/config/arm/arm-common.c (arm_parse_fpu_option): Likewise.
6296 * common/config/bfin/bfin-common.c (bfin_handle_option): Likewise.
6297 * common/config/i386/i386-common.c (ix86_handle_option): Likewise.
6298 * common/config/ia64/ia64-common.c (ia64_handle_option): Likewise.
6299 * common/config/m68k/m68k-common.c (m68k_handle_option): Likewise.
6300 * common/config/msp430/msp430-common.c (msp430_handle_option): Likewise.
6301 * common/config/nds32/nds32-common.c (nds32_handle_option): Likewise.
6302 * common/config/powerpcspe/powerpcspe-common.c (rs6000_handle_option):
6303 Likewise.
6304 * common/config/riscv/riscv-common.c
6305 (riscv_subset_list::parsing_subset_version): Likewise.
6306 (riscv_subset_list::parse_std_ext): Likewise.
6307 (riscv_subset_list::parse_sv_or_non_std_ext): Likewise.
6308 (riscv_subset_list::parse): Likewise.
6309 * common/config/rs6000/rs6000-common.c (rs6000_handle_option): Likewise.
6310 * config/aarch64/aarch64.c (aarch64_parse_one_option_token): Likewise.
6311 (aarch64_override_options_internal): Likewise.
6312 (aarch64_validate_mcpu): Likewise.
6313 (aarch64_validate_march): Likewise.
6314 (aarch64_validate_mtune): Likewise.
6315 (aarch64_override_options): Likewise.
6316 * config/alpha/alpha.c (alpha_option_override): Likewise.
6317 * config/arc/arc.c (arc_init): Likewise.
6318 (parse_mrgf_banked_regs_option): Likewise.
6319 (arc_override_options): Likewise.
6320 (arc_expand_builtin_aligned): Likewise.
6321 * config/arm/arm-builtins.c (arm_expand_neon_builtin): Likewise.
6322 (arm_expand_builtin): Likewise.
6323 * config/arm/arm.c (arm_option_check_internal): Likewise.
6324 (arm_configure_build_target): Likewise.
6325 (arm_option_override): Likewise.
6326 (arm_options_perform_arch_sanity_checks): Likewise.
6327 (arm_handle_cmse_nonsecure_entry): Likewise.
6328 (arm_handle_cmse_nonsecure_call): Likewise.
6329 (arm_tls_referenced_p): Likewise.
6330 (thumb1_expand_prologue): Likewise.
6331 * config/avr/avr.c (avr_option_override): Likewise.
6332 * config/bfin/bfin.c (bfin_option_override): Likewise.
6333 * config/c6x/c6x.c (c6x_option_override): Likewise.
6334 * config/cr16/cr16.c (cr16_override_options): Likewise.
6335 * config/cris/cris.c (cris_option_override): Likewise.
6336 * config/csky/csky.c (csky_handle_isr_attribute): Likewise.
6337 * config/darwin-c.c (macosx_version_as_macro): Likewise.
6338 * config/darwin.c (darwin_override_options): Likewise.
6339 * config/frv/frv.c (frv_expand_builtin): Likewise.
6340 * config/h8300/h8300.c (h8300_option_override): Likewise.
6341 * config/i386/i386.c (parse_mtune_ctrl_str): Likewise.
6342 (ix86_option_override_internal): Likewise.
6343 (warn_once_call_ms2sysv_xlogues): Likewise.
6344 (ix86_expand_prologue): Likewise.
6345 (split_stack_prologue_scratch_regno): Likewise.
6346 (ix86_warn_parameter_passing_abi): Likewise.
6347 * config/ia64/ia64.c (fix_range): Likewise.
6348 * config/m68k/m68k.c (m68k_option_override): Likewise.
6349 * config/microblaze/microblaze.c (microblaze_option_override): Likewise.
6350 * config/mips/mips.c (mips_emit_probe_stack_range): Likewise.
6351 (mips_set_compression_mode): Likewise.
6352 * config/mmix/mmix.c (mmix_option_override): Likewise.
6353 * config/mn10300/mn10300.c (mn10300_option_override): Likewise.
6354 * config/msp430/msp430.c (msp430_option_override): Likewise.
6355 * config/nds32/nds32.c (nds32_option_override): Likewise.
6356 * config/nios2/nios2.c (nios2_custom_check_insns): Likewise.
6357 (nios2_option_override): Likewise.
6358 (nios2_expand_custom_builtin): Likewise.
6359 * config/nvptx/mkoffload.c (main): Likewise.
6360 * config/nvptx/nvptx.c (diagnose_openacc_conflict): Likewise.
6361 * config/pa/pa.c (fix_range): Likewise.
6362 (pa_option_override): Likewise.
6363 * config/riscv/riscv.c (riscv_parse_cpu): Likewise.
6364 (riscv_option_override): Likewise.
6365 * config/rl78/rl78.c (rl78_option_override): Likewise.
6366 * config/rs6000/aix61.h: Likewise.
6367 * config/rs6000/aix71.h: Likewise.
6368 * config/rs6000/aix72.h: Likewise.
6369 * config/rs6000/driver-rs6000.c (elf_platform): Likewise.
6370 * config/rs6000/freebsd64.h: Likewise.
6371 * config/rs6000/linux64.h: Likewise.
6372 * config/rs6000/rs6000.c (rs6000_option_override_internal): Likewise.
6373 (rs6000_expand_zeroop_builtin): Likewise.
6374 (rs6000_expand_mtfsb_builtin): Likewise.
6375 (rs6000_expand_set_fpscr_rn_builtin): Likewise.
6376 (rs6000_expand_set_fpscr_drn_builtin): Likewise.
6377 (rs6000_invalid_builtin): Likewise.
6378 (rs6000_expand_split_stack_prologue): Likewise.
6379 * config/rs6000/rtems.h: Likewise.
6380 * config/rx/rx.c (valid_psw_flag): Likewise.
6381 (rx_expand_builtin): Likewise.
6382 * config/s390/s390-c.c (s390_resolve_overloaded_builtin): Likewise.
6383 * config/s390/s390.c (s390_expand_builtin): Likewise.
6384 (s390_function_profiler): Likewise.
6385 (s390_option_override_internal): Likewise.
6386 (s390_option_override): Likewise.
6387 * config/sh/sh.c (sh_option_override): Likewise.
6388 (sh_builtin_saveregs): Likewise.
6389 (sh_fix_range): Likewise.
6390 * config/sh/vxworks.h: Likewise.
6391 * config/sparc/sparc.c (sparc_option_override): Likewise.
6392 * config/spu/spu.c (spu_option_override): Likewise.
6393 (fix_range): Likewise.
6394 * config/visium/visium.c (visium_option_override): Likewise.
6395 (visium_handle_interrupt_attr): Likewise.
6396 * config/xtensa/xtensa.c (xtensa_option_override): Likewise.
6397 * dbgcnt.c (dbg_cnt_set_limit_by_name): Likewise.
6398 (dbg_cnt_process_opt): Likewise.
6399 * dwarf2out.c (output_dwarf_version): Likewise.
6400 * except.c (expand_eh_return): Likewise.
6401 * gcc.c (defined): Likewise.
6402 (driver_handle_option): Likewise.
6403 (process_command): Likewise.
6404 (compare_files): Likewise.
6405 (driver::prepare_infiles): Likewise.
6406 (driver::do_spec_on_infiles): Likewise.
6407 (driver::maybe_run_linker): Likewise.
6408 * omp-offload.c (oacc_parse_default_dims): Likewise.
6409 * opts-global.c (handle_common_deferred_options): Likewise.
6410 * opts.c (parse_sanitizer_options): Likewise.
6411 (common_handle_option): Likewise.
6412 (enable_warning_as_error): Likewise.
6413 * passes.c (enable_disable_pass): Likewise.
6414 * plugin.c (parse_plugin_arg_opt): Likewise.
6415 (default_plugin_dir_name): Likewise.
6416 * targhooks.c (default_expand_builtin_saveregs): Likewise.
6417 (default_pch_valid_p): Likewise.
6418 * toplev.c (init_asm_output): Likewise.
6419 (process_options): Likewise.
6420 (toplev::run_self_tests): Likewise.
6421 * tree-cfg.c (verify_gimple_call): Likewise.
6422 * tree-inline.c (inline_forbidden_p_stmt): Likewise.
6423 (tree_inlinable_function_p): Likewise.
6424 * var-tracking.c (vt_find_locations): Likewise.
6425
6426 2019-03-11 Andreas Krebbel <krebbel@linux.ibm.com>
6427
6428 * config/s390/s390.c (s390_expand_builtin): Do the copy_to_reg not
6429 only on the else branch.
6430
6431 2019-03-11 Martin Liska <mliska@suse.cz>
6432
6433 * gcov.c (output_intermediate_json_line): Print function
6434 name of each line.
6435 (output_json_intermediate_file): Add new argument.
6436 * doc/gcov.texi: Document the change.
6437
6438 2019-03-11 Eric Botcazou <ebotcazou@adacore.com>
6439
6440 PR rtl-optimization/89588
6441 * loop-unroll.c (decide_unroll_constant_iterations): Make guard for
6442 explicit unrolling factor more robust.
6443
6444 2019-03-11 Richard Biener <rguenther@suse.de>
6445
6446 PR tree-optimization/89649
6447 * tree-vectorizer.h (vect_loop_versioning): Adjust prototype.
6448 * tree-vect-loop-manip.c (vect_do_peeling): Unset force_vectorize
6449 on the prolog and epilog loops.
6450 (vect_loop_versioning): Return copy of loop.
6451 * tree-vect-loop.c (vect_transform_loop): Unset force_vectorize
6452 on the non-vectorized version of the loop.
6453
6454 2019-03-10 Uroš Bizjak <ubizjak@gmail.com>
6455
6456 PR target/68924
6457 * config/i386/sse.md (*vec_extractv2di_0_sse):
6458 Add (=r,x) alternative and corresponding splitter.
6459
6460 2019-03-10 Martin Jambor <mjambor@suse.cz>
6461
6462 PR tree-optimization/85762
6463 PR tree-optimization/87008
6464 PR tree-optimization/85459
6465 * tree-sra.c (contains_vce_or_bfcref_p): New parameter, set the bool
6466 it points to if there is a type changing MEM_REF. Adjust all callers.
6467 (build_accesses_from_assign): Disable total scalarization if
6468 contains_vce_or_bfcref_p returns true through the new parameter, for
6469 both rhs and lhs.
6470
6471 2019-03-09 Jakub Jelinek <jakub@redhat.com>
6472
6473 PR c/88568
6474 * attribs.c (handle_dll_attribute): Don't clear TREE_STATIC for
6475 dllimport on VAR_DECLs with RECORD_TYPE or UNION_TYPE DECL_CONTEXT.
6476
6477 PR target/79645
6478 * common.opt (fdiagnostics-show-labels,
6479 fdiagnostics-show-line-numbers, fdiagnostics-format=,
6480 fdiagnostics-minimum-margin-width=, fgnat-encodings=, gas-loc-support,
6481 gas-locview-support, ginline-points, ginternal-reset-location-views):
6482 Terminate description text with a dot.
6483 * config/microblaze/microblaze.opt (mxl-prefetch): Likewise.
6484 * config/mcore/mcore.opt (m210, m340): Likewise.
6485 * config/epiphany/epiphany.opt (mprefer-short-insn-regs, mcmove,
6486 mnops=): Start description text with a capital letter.
6487 * config/arc/arc.opt (msize-level=): Likewise.
6488 * config/sh/sh.opt (minline-ic_invalidate): Likewise.
6489 * config/rs6000/sysv4.opt (mno-toc, mtoc, mno-traceback, mshlib,
6490 mnewlib): Likewise.
6491 * config/ft32/ft32.opt (msim): Likewise.
6492 (mft32b, mcompress): Likewise. Terminate description text with a dot.
6493 (mnodiv, mnopm): Terminate description text with a dot.
6494 * config/c6x/c6x.opt (c6x_sdata): Terminate Enum description with
6495 a colon.
6496 * config/i386/i386.opt (prefer_vector_width, instrument_return):
6497 Likewise.
6498 * config/rx/rx.opt (nofpu): Remove trailing spaces from description
6499 text.
6500
6501 PR rtl-optimization/89634
6502 * cfgcleanup.c (thread_jump): Punt if registers mentioned in cond1
6503 are modified in BB_END (e->src) instruction.
6504
6505 2019-03-08 David Malcolm <dmalcolm@redhat.com>
6506
6507 PR target/79926
6508 * config/i386/i386.c (ix86_set_current_function): Make "sorry"
6509 messages more amenable to translation, and improve wording.
6510
6511 2019-03-08 Bill Schmidt <wschmidt@linux.ibm.com>
6512
6513 * config/rs6000/rs6000-p8swap.c (rs6000_analyze_swaps): Rebuild
6514 ud- and du-chains between phases.
6515
6516 2019-03-08 Richard Sandiford <richard.sandiford@arm.com>
6517
6518 PR debug/89631
6519 * dwarf2cfi.c (dwarf2out_frame_debug_expr): Use CONST_POLY_INT
6520 instead of POLY_INT_CST.
6521
6522 2019-03-08 Andre Vieira <andre.simoesdiasvieira@arm.com>
6523
6524 * config/arm/arm.h (TARGET_FP16_TO_DOUBLE): Add TARGET_VFP_DOUBLE
6525 requirement.
6526
6527 2019-03-08 Uroš Bizjak <ubizjak@gmail.com>
6528
6529 PR target/68924
6530 PR target/78782
6531 PR target/87558
6532 * config/i386/emmintrin.h (_mm_loadu_si64): New intrinsic.
6533 (_mm_storeu_si64): Ditto.
6534
6535 2019-03-08 Martin Liska <mliska@suse.cz>
6536
6537 PR target/86952
6538 * config/i386/i386.c (ix86_option_override_internal): Disable
6539 jump tables when retpolines are used.
6540
6541 2019-03-08 Jan Hubicka <hubicka@ucw.cz>
6542
6543 PR go/63560
6544 * ipa-split.c (execute_split_functions): Do not split
6545 'noinline' or 'section' function.
6546
6547 2019-03-08 Jakub Jelinek <jakub@redhat.com>
6548
6549 PR target/79846
6550 * config/s390/s390.c (s390_const_operand_ok): Use %wu instead of
6551 HOST_WIDE_INT_PRINT_UNSIGNED and %wd instead of
6552 HOST_WIDE_INT_PRINT_DEC. Formatting fixes.
6553
6554 PR ipa/80000
6555 * ipa-devirt.c (compare_virtual_tables): Remove two trailing spaces
6556 from diagnostics. Formatting fixes.
6557
6558 PR target/85665
6559 * ipa-devirt.c (odr_types_equivalent_p): Fix grammar in
6560 warn_odr diagnostics.
6561
6562 PR other/80058
6563 * lra-constraints.c (process_alt_operands): Avoid one space before
6564 " at the end of line and another after " on another line in a string
6565 literal.
6566 * attribs.c (handle_dll_attribute): Likewise.
6567 * config/avr/avr-devices.c (avr_texinfo): Likewise.
6568
6569 * gimple-ssa-warn-alloca.c (pass_walloca::execute): Don't wrap
6570 warning_at or inform messages in G_() if there is no ?:.
6571
6572 PR tree-optimization/89550
6573 * builtins.c (c_strlen): Only set TREE_NO_WARNING if warning_at
6574 returned true. Formatting fixes.
6575 (expand_builtin_strnlen): Formatting fixes.
6576 * tree-vrp.c (vrp_prop::check_mem_ref): Only set TREE_NO_WARNING
6577 if warning_at returned true.
6578 * tree-cfg.c (pass_warn_function_return::execute): Likewise.
6579
6580 2019-03-08 Richard Biener <rguenther@suse.de>
6581
6582 PR middle-end/89578
6583 * cfgloop.h (struct loop): Add owned_clique field.
6584 * cfgloopmanip.c (copy_loop_info): Copy it.
6585 * tree-cfg.c (gimple_duplicate_bb): Do not remap owned_clique
6586 cliques.
6587 * tree-inline.c (copy_loops): Remap owned_clique.
6588 * lto-streamer-in.c (input_cfg): Stream owned_clique.
6589 * lto-streamer-out.c (output_cfg): Likewise.
6590
6591 2019-03-08 Jakub Jelinek <jakub@redhat.com>
6592
6593 PR target/80190
6594 * config/darwin.c: Include intl.h.
6595 (darwin_build_constant_cfstring): Improve i18n of diagnostics by not
6596 composing the message out of two separate parts.
6597
6598 2019-03-07 Jakub Jelinek <jakub@redhat.com>
6599
6600 PR target/80003
6601 * config/i386/i386.c (ix86_set_func_type): Make sure diagnostics
6602 doesn't start with a capital letter and doesn't end with a dot.
6603 (ix86_function_arg_boundary): Make sure diagnostics doesn't start
6604 with a capital letter.
6605 (ix86_mangle_function_version_assembler_name): Likewise.
6606 (ix86_generate_version_dispatcher_body): Likewise.
6607 (fold_builtin_cpu): Likewise.
6608 (get_builtin_code_for_version): Likewise. Remove extraneous space.
6609 (ix86_handle_interrupt_attribute): Make the diagnostics easier for
6610 translators, wrap full type name in %qs.
6611
6612 PR translation/79999
6613 * gimplify.c (gimplify_omp_ordered): Reword diagnostics to talk about
6614 depend clause with source (or sink) modifier.
6615 * omp-expand.c (expand_omp_ordered_sink): Likewise.
6616
6617 PR target/89602
6618 * config/i386/sse.md (avx512f_mov<ssescalarmodelower>_mask,
6619 *avx512f_load<mode>_mask, avx512f_store<mode>_mask): New define_insns.
6620 (avx512f_load<mode>_mask): New define_expand.
6621 * config/i386/i386-builtin.def (__builtin_ia32_loadsd_mask,
6622 __builtin_ia32_loadss_mask, __builtin_ia32_storesd_mask,
6623 __builtin_ia32_storess_mask, __builtin_ia32_movesd_mask,
6624 __builtin_ia32_movess_mask): New builtins.
6625 * config/i386/avx512fintrin.h (_mm_mask_load_ss, _mm_maskz_load_ss,
6626 _mm_mask_load_sd, _mm_maskz_load_sd, _mm_mask_move_ss,
6627 _mm_maskz_move_ss, _mm_mask_move_sd, _mm_maskz_move_sd,
6628 _mm_mask_store_ss, _mm_mask_store_sd): New intrinsics.
6629
6630 2019-03-07 Martin Jambor <mjambor@suse.cz>
6631
6632 PR lto/87525
6633 * ipa-cp.c (perform_estimation_of_a_value): Account zero time benefit
6634 for extern inline functions.
6635
6636 2019-03-07 Martin Jambor <mjambor@suse.cz>
6637
6638 PR ipa/88235
6639 * cgraph.h (cgraph_node): New inline method former_thunk_p.
6640 * cgraph.c (cgraph_node::dump): Dump a note if node is a former thunk.
6641 (clone_of_p): Treat expanded thunks like thunks, be optimistic if they
6642 have multiple callees. At the end check if declarations match as
6643 opposed to cgraph_nodes.
6644
6645 2019-03-07 Martin Liska <mliska@suse.cz>
6646
6647 * cgraph.c (cgraph_node::verify_node): Verify with a neighbour
6648 which is equivalent to searching for this in clones chain.
6649 * symtab.c (symtab_node::verify_base): Similarly compare ASM
6650 names with a neighbour and special case first node in a chain.
6651
6652 2019-01-25 Jason Merrill <jason@redhat.com>
6653
6654 PR c++/80916 - spurious "static but not defined" warning.
6655 * gimple-fold.c (can_refer_decl_in_current_unit_p): Return false
6656 for an internal symbol with DECL_EXTERNAL.
6657
6658 2019-04-07 Richard Biener <rguenther@suse.de>
6659
6660 PR middle-end/89618
6661 * cfgloopmanip.c (copy_loop_info): Copy forgotten fields.
6662 * tree-inline.c (copy_loops): Simplify.
6663
6664 2019-03-07 Martin Liska <mliska@suse.cz>
6665
6666 * dwarf2out.c (add_AT_vms_delta): Revert function removal.
6667
6668 2019-03-07 Richard Biener <rguenther@suse.de>
6669
6670 PR tree-optimization/89595
6671 * tree-ssa-dom.c (dom_opt_dom_walker::optimize_stmt): Take
6672 stmt iterator as reference, take boolean output parameter to
6673 indicate whether the stmt was removed and thus the iterator
6674 already advanced.
6675 (dom_opt_dom_walker::before_dom_children): Re-iterate over
6676 stmts created by folding.
6677
6678 2019-03-07 Jakub Jelinek <jakub@redhat.com>
6679
6680 PR c++/89585
6681 * doc/extend.texi (Basic Asm): Document qualifiers are not allowed
6682 at toplevel.
6683
6684 2019-03-06 Peter Bergner <bergner@linux.ibm.com>
6685
6686 PR rtl-optimization/88845
6687 * config/rs6000/rs6000.c (rs6000_emit_move_si_sf_subreg): Enable during
6688 LRA.
6689 * lra.c (remove_scratches_1): New function.
6690 (remove_scratches): Use it.
6691 (lra_emit_move): Likewise.
6692
6693 2019-03-06 Claudiu Zissulescu <claziss@synopsys.com>
6694
6695 * config/arc/arc-c.def (__ARC_UNALIGNED__): Set it on
6696 unaligned_access variable.
6697 * config/arc/arc.c (arc_override_options): Set unaligned access
6698 default on for HS CPUs.
6699 * config/arc/arc.h (STRICT_ALIGNMENT): Fix logic.
6700
6701 2019-03-06 Martin Liska <mliska@suse.cz>
6702
6703 PR gcov-profile/89577
6704 * doc/gcov.texi: Prefer to use --coverage.
6705 * doc/sourcebuild.texi: Likewise.
6706
6707 2019-03-02 Jason Merrill <jason@redhat.com>
6708
6709 PR c++/86485 - -Wmaybe-unused with empty class ?:
6710 * gimplify.c (gimplify_cond_expr): Use INIT_EXPR.
6711
6712 2019-03-05 Jakub Jelinek <jakub@redhat.com>
6713
6714 PR target/89587
6715 * config/rs6000/t-linux (MULTIARCH_DIRNAME): Set to non-empty only
6716 if_multiarch.
6717
6718 PR middle-end/89590
6719 * builtins.c (maybe_emit_free_warning): Punt if free doesn't have
6720 exactly one argument.
6721
6722 2019-03-05 Jakub Jelinek <jakub@redhat.com>
6723 Richard Sandiford <richard.sandiford@arm.com>
6724
6725 PR tree-optimization/89570
6726 * match.pd (vec_cond into cond_op simplification): Don't use
6727 get_conditional_internal_fn, use as_internal_fn (cond_op).
6728
6729 2019-03-05 Wilco Dijkstra <wdijkstr@arm.com>
6730
6731 PR target/89222
6732 * config/arm/arm.md (movsi): Use targetm.cannot_force_const_mem
6733 to decide when to split off a non-zero offset from a symbol.
6734 * config/arm/arm.c (arm_cannot_force_const_mem): Disallow offsets
6735 in function symbols.
6736
6737 2019-03-05 Richard Biener <rguenther@suse.de>
6738
6739 PR tree-optimization/89594
6740 * tree-if-conv.c (pass_if_conversion::execute): Handle
6741 case where .LOOP_VECTORIZED_FUNCTION was removed.
6742
6743 2019-03-05 Jakub Jelinek <jakub@redhat.com>
6744
6745 PR bootstrap/89560
6746 * fold-const.c (fold_checksum_tree): Don't use fixed size buffer,
6747 instead alloca it only when needed with the needed size.
6748
6749 PR tree-optimization/89570
6750 * match.pd (vec_cond into cond_op simplification): Guard with
6751 vectorized_internal_fn_supported_p test and #if GIMPLE.
6752
6753 PR tree-optimization/89566
6754 * gimple-ssa-sprintf.c (sprintf_dom_walker::handle_gimple_call):
6755 Set info.fncode to BUILT_IN_NONE if gimple_call_builtin_p failed.
6756 Punt if get_user_idx_format succeeds, but idx_format argument is
6757 not provided or doesn't have pointer type, or if idx_args is above
6758 number of provided arguments.
6759
6760 2019-03-04 Wilco Dijkstra <wdijkstr@arm.com>
6761
6762 PR tree-optimization/89437
6763 * match.pd: Use lt in sin(atan(x)) and cos(atan(x)) simplifications.
6764
6765 2019-03-04 Richard Biener <rguenther@suse.de>
6766
6767 PR middle-end/89572
6768 * tree-scalar-evolution.c: (get_loop_exit_condition): Use
6769 safe_dyn_cast.
6770
6771 2019-03-04 Bin Cheng <bin.cheng@linux.alibaba.com>
6772
6773 PR tree-optimization/89487
6774 * tree-loop-distribution.c (has_nonaddressable_dataref_p): New.
6775 (create_rdg_vertices): Compute has_nonaddressable_dataref_p.
6776 (distribute_loop): Don't do runtime alias check if there is non-
6777 addressable data reference.
6778 * tree-ssa-loop-ivopts.c (may_be_nonaddressable_p): Check if VAR_DECL
6779 is a register variable.
6780
6781 2019-03-02 Jakub Jelinek <jakub@redhat.com>
6782
6783 PR target/89506
6784 * config/arm/arm.md (cmpsi2_addneg): Use
6785 trunc_int_for_mode (-INTVAL (...), SImode) instead of -INTVAL (...).
6786 If operands[2] is 0 or INT_MIN, force use of subs.
6787 (*compare_scc splitter): Use gen_int_mode.
6788 (*negscc): Likewise.
6789 * config/arm/thumb2.md (*thumb2_negscc): Likewise.
6790
6791 2019-03-01 Kito Cheng <kito.cheng@gmail.com>
6792 Monk Chiang <sh.chiang04@gmail.com>
6793
6794 * common/config/riscv/riscv-common.c: Include sstream.
6795 (riscv_subset_list::to_string): New.
6796 (riscv_arch_str): Likewise.
6797 * config.gcc (riscv*-*-*): Handle --with-riscv-attribute=
6798 * config.in: Regen.
6799 * config/riscv/riscv-protos.h (riscv_arch_str): New.
6800 * config/riscv/riscv.c (INCLUDE_STRING): Defined.
6801 (riscv_emit_attribute): New.
6802 (riscv_file_start): Emit attribute if needed.
6803 (riscv_option_override): Init riscv_emit_attribute_p.
6804 * config/riscv/riscv.opt (mriscv-attribute): New option.
6805 * configure.ac (riscv*-*-*): Check binutils is supporting ELF
6806 * configure: Regen.
6807 * doc/install.texi: Document --with-riscv-attribute.
6808 * doc/invoke.texi: Document -mriscv-attribute.
6809
6810 * common/config/riscv/riscv-common.c:
6811 Include config/riscv/riscv-protos.h.
6812 (INCLUDE_STRING): Defined.
6813 (RISCV_DONT_CARE_VERSION): Defined.
6814 (riscv_subset_t): Declare.
6815 (riscv_subset_t::riscv_subset_t): New.
6816 (riscv_subset_list): Declare.
6817 (riscv_subset_list::riscv_subset_list): New.
6818 (riscv_subset_list::~riscv_subset_list): Likewise.
6819 (riscv_subset_list::parsing_subset_version): Likewise.
6820 (riscv_subset_list::parse_std_ext): Likewise.
6821 (riscv_subset_list::parse_sv_or_non_std_ext): Likewise.
6822 (riscv_subset_list::add): Likewise.
6823 (riscv_subset_list::lookup): Likewise.
6824 (riscv_subset_list::xlen): Likewise.
6825 (riscv_subset_list::parse): Likewise.
6826 (riscv_supported_std_ext): Likewise.
6827 (current_subset_list): Likewise.
6828 (riscv_parse_arch_string): Using riscv_subset_list::parse to
6829 parse.
6830
6831 2019-03-01 Segher Boessenkool <segher@kernel.crashing.org>
6832
6833 * config/rs6000/rs6000.c (rs6000_option_override_internal): If
6834 rs6000_dejagnu_cpu_index is set, use that to override rs6000_cpu_index.
6835 * config/rs6000/rs6000.opt (mdejagnu-cpu=): New option.
6836
6837 2019-03-01 Alexander Monakov <amonakov@ispras.ru>
6838
6839 PR rtl-optimization/85899
6840 * haifa-sched.c (find_fallthru_edge_from): Relax assert to account for
6841 fallthru edges leading to the exit block.
6842
6843 2019-03-01 Tamar Christina <tamar.christina@arm.com>
6844
6845 PR target/89517
6846 * config/aarch64/aarch64-option-extensions.def (fp, simd, crypto, fp16,
6847 rdma, dotprod, sha2, sha3, sm4, fp16fml, sve): Collapse line.
6848
6849 2019-03-01 Richard Sandiford <richard.sandiford@arm.com>
6850
6851 PR tree-optimization/89535
6852 * tree-vect-stmts.c (vectorizable_call): Record the vector types
6853 for each operand. Calculate the fallback choice for mask operands
6854 and pass it to vect_get_vec_def_for_operand.
6855
6856 2019-03-01 Richard Biener <rguenther@suse.de>
6857
6858 PR middle-end/89541
6859 * tree-ssa-operands.c (add_stmt_operand): CONST_DECL may
6860 get virtual operands.
6861 (get_expr_operands): Handle CONST_DECL like other decls.
6862
6863 2019-03-01 Jakub Jelinek <jakub@redhat.com>
6864
6865 PR middle-end/89503
6866 * fold-const.c (fold_checksum_tree): Ignore TREE_NO_WARNING bit
6867 on DECL_P and EXPR_P.
6868
6869 2019-03-01 Richard Biener <rguenther@suse.de>
6870
6871 PR middle-end/89497
6872 * tree-cfgcleanup.h (cleanup_tree_cfg): Add SSA update flags
6873 argument, defaulted to zero.
6874 * passes.c (execute_function_todo): Pass down SSA update flags
6875 to cleanup_tree_cfg.
6876 * tree-cfgcleanup.c: Include tree-into-ssa.h and tree-cfgcleanup.h.
6877 (cleanup_tree_cfg_noloop): After cleanup_control_flow_pre update SSA
6878 form if requested.
6879 (cleanup_tree_cfg): Get and pass down SSA update flags.
6880
6881 2019-03-01 Jakub Jelinek <jakub@redhat.com>
6882
6883 PR bootstrap/89539
6884 * dwarf2out.c (output_comdat_type_unit): Add ATTRIBUTE_UNUSED to
6885 early_lto_debug argument.
6886
6887 2019-02-28 Eric Botcazou <ebotcazou@adacore.com>
6888
6889 PR tree-optimization/89536
6890 * tree-ssa-dom.c (edge_info::derive_equivalences) <BIT_NOT_EXPR>: Test
6891 only whether bit #0 of the value is 0 instead of the entire value.
6892
6893 2019-02-28 Marek Polacek <polacek@redhat.com>
6894
6895 PR c++/87068 - missing diagnostic with fallthrough statement.
6896 * gimplify.c (expand_FALLTHROUGH_r): If IFN_FALLTHROUGH was found
6897 at the end of a seq, save its location to walk_stmt_info.
6898 (expand_FALLTHROUGH): Warn if IFN_FALLTHROUGH is at the end of
6899 a switch.
6900
6901 2019-02-28 Jan Hubicka <hubicka@ucw.cz>
6902
6903 PR lto/88585
6904 * tree.c (find_atomic_core_type): Move ahead in file.
6905 (check_base_type): Correctly compare alignments of atomic types.
6906
6907 2019-02-28 H.J. Lu <hongjiu.lu@intel.com>
6908
6909 PR target/89455
6910 * config/i386/i386.c (get_builtin_code_for_version): Identify
6911 Westmere from PCLMUL, instead of AES.
6912
6913 2019-02-28 Jakub Jelinek <jakub@redhat.com>
6914
6915 PR target/89434
6916 * config/arm/arm.md (*subsi3_carryin_compare_const): Use
6917 trunc_int_for_mode (-INTVAL (...), SImode), just instead of
6918 -UINTVAL (...).
6919
6920 2019-02-28 Tamar Christina <tamar.christina@arm.com>
6921
6922 PR target/88530
6923 * config/aarch64/aarch64-option-extensions.def: Document it.
6924 * config/aarch64/driver-aarch64.c (host_detect_local_cpu): Skip feature
6925 if empty hwcaps.
6926
6927 2019-02-28 Jakub Jelinek <jakub@redhat.com>
6928
6929 PR c/89520
6930 * convert.c (convert_to_real_1, convert_to_integer_1): Punt for
6931 builtins if they don't have a single scalar floating point argument.
6932 Formatting fixes.
6933
6934 2019-02-27 Bernd Edlinger <bernd.edlinger@hotmail.de>
6935
6936 PR rtl-optimization/89490
6937 * varasm.c (get_block_for_section): Bail out for mergeable sections.
6938 (default_use_anchors_for_symbol_p, output_object_block): Assert the
6939 block section is not mergeable.
6940
6941 2019-02-27 Jakub Jelinek <jakub@redhat.com>
6942
6943 PR target/70341
6944 * config/arm/arm.md (arm_casesi_internal): New define_expand. Rename
6945 old define_insn to ...
6946 (*arm_casesi_internal): ... this. Add mode to LABEL_REFs.
6947 * config/arm/thumb2.md (thumb2_casesi_internal): New define_expand.
6948 Rename old define_insn to ...
6949 (*thumb2_casesi_internal): ... this. Add mode to LABEL_REFs.
6950 (thumb2_casesi_internal_pic): New define_expand. Rename old
6951 define_insn to ...
6952 (*thumb2_casesi_internal_pic): ... this. Add mode to LABEL_REFs.
6953 * config/aarch64/aarch64.md (casesi): Create the casesi_dispatch
6954 MEM manually here, set MEM_READONLY_P and MEM_NOTRAP_P on it.
6955
6956 2019-02-27 Richard Biener <rguenther@suse.de>
6957
6958 PR debug/88878
6959 * dwarf2out.c (use_debug_types): Disable when in_lto_p.
6960
6961 2019-02-27 Richard Biener <rguenther@suse.de>
6962
6963 * passes.c (should_skip_pass_p): Do not skip cgraph-edge
6964 building.
6965
6966 2019-02-27 Richard Biener <rguenther@suse.de>
6967
6968 PR debug/88878
6969 * dwarf2out.c (output_comdat_type_unit): Add early_lto_debug
6970 parameter, prefix section name with .gnu.debuglto_ if true.
6971 (dwarf2out_finish): Pass false to output_comdat_type_unit.
6972 (dwarf2out_early_finish): Pass true to output_comdat_type_unit.
6973
6974 2019-02-27 Richard Biener <rguenther@suse.de>
6975
6976 PR debug/89514
6977 * dwarf2out.c (size_of_die): Key on AT_ref (a)->comdat_type_p
6978 rather than on use_debug_types, doing what output_die does.
6979 (value_format): Likewise.
6980
6981 2019-02-27 Martin Jambor <mjambor@suse.cz>
6982 Martin Sebor <msebor@redhat.com>
6983
6984 * doc/invoke.texi (Warning Options): Reword description of
6985 -Wno-absolute-value.
6986
6987 2019-02-27 Jakub Jelinek <jakub@redhat.com>
6988
6989 PR tree-optimization/89280
6990 * tree-cfgcleanup.c (maybe_dead_abnormal_edge_p,
6991 builtin_setjmp_setup_bb): New functions.
6992 (cleanup_control_flow_pre): Ignore maybe_dead_abnormal_edge_p edges.
6993 When visiting __builtin_setjmp_setup block, queue in special
6994 setjmp_vec vector edges from .ABNORMAL_DISPATCHER to corresponding
6995 __builtin_setjmp_receiver. Remove .ABNORMAL_DISPATCHER basic blocks
6996 from visited after the loop if they don't have any visited successor
6997 blocks.
6998
6999 2018-02-26 Steve Ellcey <sellcey@marvell.com>
7000
7001 * config/aarch64/aarch64.c (aarch64_get_multilib_abi_name):
7002 New function.
7003 (TARGET_GET_MULTILIB_ABI_NAME): New macro.
7004
7005 2019-02-26 Jakub Jelinek <jakub@redhat.com>
7006
7007 PR c++/89507
7008 * tree.c (valid_constant_size_p): Deal with size INTEGER_CSTs
7009 with types other than sizetype/ssizetype.
7010
7011 2019-02-26 Eric Botcazou <ebotcazou@adacore.com>
7012
7013 * config/sparc/sparc-opts.h (enum processor_type): Rename to...
7014 (enum sparc_processor_type): ...this.
7015 (enum sparc_code_model_type): New enumeration type.
7016 (enum sparc_memory_model_type): Tweak comments.
7017 * config/sparc/sparc.opt (mcpu): Adjust to above renaming.
7018 (mtune): Likewise.
7019 (mcmodel): Use sparc_code_model enumeration and variable.
7020 (sparc_code_model): New enumeration.
7021 (mdebug): Add Undocumented marker.
7022 * config/sparc/sparc.h (enum cmodel): Delete.
7023 (sparc_cmodel): Likewise.
7024 (TARGET_CM_MEDLOW): Adjust to above renaming.
7025 (TARGET_CM_MEDMID): Likewise.
7026 (TARGET_CM_MEDANY): Likewise.
7027 (TARGET_CM_EMBMEDANY): Likewise.
7028 * config/sparc/sparc.c (sparc_cmodel): Delete.
7029 (sparc_option_override): Remove string/value mapping support for the
7030 code model. Move code and memory model support to after the handling
7031 of target flags. Do private machine setup last.
7032 (sparc_emit_set_symbolic_const64): Use sparc_code_model.
7033 (sparc_legitimize_reload_address): Likewise.
7034 (sparc_output_mi_thunk): Likewise.
7035 * config/sparc/sparc.md (cpu): Adjust comment to above renaming.
7036
7037 2019-02-26 Jakub Jelinek <jakub@redhat.com>
7038
7039 PR tree-optimization/89500
7040 * tree-ssa-strlen.c (stridx_strlenloc): Adjust comment.
7041 (handle_builtin_strlen): Remove noncst_bound variable. Always
7042 optimize strnlen (x, 0) to 0. Optimize strnlen (x, cst) to
7043 cst if the first cst bytes starting at x are known to be non-zero,
7044 even if the string is not zero terminated. Don't try to modify
7045 *si for strnlen. Update strlen_to_stridx only for strlen or if
7046 we can prove strnlen returns the same value as strlen would.
7047
7048 2019-02-26 Martin Liska <mliska@suse.cz>
7049
7050 * alloc-pool.h (struct pool_usage): Remove extra
7051 print_dash_line.
7052 * bitmap.h (struct bitmap_usage): Likewise.
7053 * ggc-common.c (struct ggc_usage): Likewise.
7054 * mem-stats.h (struct mem_usage): Likewise.
7055 (mem_alloc_description::dump): Print dash lines
7056 here and repeat header at the end of a table report.
7057 It's then more readable.
7058 * tree-phinodes.c (phinodes_print_statistics): Make
7059 horizontal alignment.
7060 * tree-ssanames.c (ssanames_print_statistics): Likewise.
7061 * vec.c (struct vec_usage): Remove extra print_dash_line.
7062 * vec.h (vec_safe_grow_cleared): Pass PASS_MEM_STAT.
7063
7064 2019-02-26 Uroš Bizjak <ubizjak@gmail.com>
7065
7066 * doc/extend.texi (__builtin_object_size):
7067 Use @pxref instead of @xref inside parenthesis.
7068 (__builtin_has_attribute): Add missing comma after @xref.
7069 (__builtin_object_size): Ditto.
7070 * doc/md.texi (cond_*{mode}): Use @samp instead of @var around op1[i].
7071 * fortran/invoke.texi (-ffpe-trap): Use @var for every item
7072 in the list.
7073
7074 2019-02-26 Jeff Law <law@redhat.com>
7075
7076 PR rtl-optimization/87761
7077 * regcprop.c (copyprop_hardreg_forward_1): Use REG_UNUSED notes to
7078 detect obviously dead insns and delete them.
7079
7080 2019-02-26 Richard Biener <rguenther@suse.de>
7081
7082 PR tree-optimization/89505
7083 * tree-ssa-structalias.c (compute_dependence_clique): Make sure
7084 to handle restrict pointed-to vars with multiple subvars
7085 correctly.
7086
7087 2019-02-26 Richard Biener <rguenther@suse.de>
7088
7089 PR tree-optimization/89489
7090 * tree-parloops.c (create_loop_fn): Copy over last_clique.
7091
7092 2019-02-26 Eric Botcazou <ebotcazou@adacore.com>
7093
7094 * tree-ssa-dom.c (edge_info::derive_equivalences) <BIT_IOR_EXPR>: Fix
7095 and move around comment.
7096 <BIT_AND_EXPR>: Likewise.
7097 <BIT_NOT_EXPR>: Add specific handling for boolean types.
7098
7099 2019-02-26 Jakub Jelinek <jakub@redhat.com>
7100
7101 PR target/89474
7102 * config/i386/i386.c (remove_partial_avx_dependency): Call
7103 df_analyze etc. before creation of the v4sf_const0 pseudo, rather than
7104 after changing possibly many instructions to use that pseudo. Fix up
7105 insertion of v4sf_const0 setter at the start of bb.
7106
7107 2019-02-25 Sandra Loosemore <sandra@codesourcery.com>
7108
7109 PR c/80409
7110 * doc/extend.texi (Variadic Pointer Args): New section.
7111
7112 2019-02-25 Sandra Loosemore <sandra@codesourcery.com>
7113 Martin Sebor <msebor@gmail.com>
7114
7115 * common.opt (Wattribute-alias): Likewise.
7116 * doc/invoke.texi (Option Summary): List general form of
7117 -Wattribute-alias=. List positive form of -Wmissing-attributes.
7118 (-Wmissing-attributes): Invert entry, rewrite and correct default.
7119 Add cross-references.
7120 (-Wattribute-alias): Rewrite and correct default. Mention
7121 considered attributes (same as for -Wmissing-attributes).
7122
7123 2019-02-25 Paul A. Clarke <pc@us.ibm.com>
7124
7125 * config/rs6000/emmintrin.h (_mm_cvtpd_epi32): Fix big endian.
7126 (_mm_cvtpd_ps): Likewise.
7127 (_mm_cvttpd_epi32): Likewise.
7128
7129 PR target/89338
7130 * config/rs6000/xmmintrin.h (_mm_cvtss_f32): Fix type mismatch.
7131 (_mm_cvt_ss2si): Fix type mismatch and 32-bit.
7132
7133 PR target/89339
7134 * config/rs6000/xmmintrin.h (_mm_movemask_pi8): Fix 32-bit.
7135
7136 2019-02-25 Tamar Christina <tamar.christina@arm.com>
7137
7138 PR target/88530
7139 * common/config/aarch64/aarch64-common.c
7140 (struct aarch64_option_extension): Add is_synthetic.
7141 (all_extensions): Use it.
7142 (TARGET_OPTION_INIT_STRUCT): Define hook.
7143 (struct gcc_targetm_common): Moved to end.
7144 (all_extensions_by_on): New.
7145 (opt_ext_cmp, typedef opt_ext): New.
7146 (aarch64_option_init_struct): New.
7147 (aarch64_contains_opt): New.
7148 (aarch64_get_extension_string_for_isa_flags): Output smallest set.
7149 * config/aarch64/aarch64-option-extensions.def
7150 (AARCH64_OPT_EXTENSION): Explicitly include AES and SHA2 in crypto.
7151 (fp, simd, crc, lse, fp16, rcpc, rdma, dotprod, aes, sha2, sha3,
7152 sm4, fp16fml, sve, profile, rng, memtag, sb, ssbs, predres):
7153 Set is_synthetic to false.
7154 (crypto): Set is_synthetic to true.
7155 * config/aarch64/driver-aarch64.c (AARCH64_OPT_EXTENSION): Add
7156 SYNTHETIC.
7157
7158 2019-02-25 Tamar Christina <tamar.christina@arm.com>
7159
7160 * config/arm/arm_neon.h (vfmlal_low_u32, vfmlsl_low_u32,
7161 vfmlal_high_u32, vfmlsl_high_u32, vfmlalq_low_u32, vfmlslq_low_u32,
7162 vfmlalq_high_u32, vfmlslq_high_u32, vfmlal_lane_low_u32,
7163 vfmlal_lane_high_u32, vfmlalq_laneq_low_u32, vfmlalq_lane_low_u32,
7164 vfmlal_laneq_low_u32, vfmlalq_laneq_high_u32, vfmlalq_lane_high_u32,
7165 vfmlal_laneq_high_u32, vfmlsl_lane_low_u32, vfmlsl_lane_high_u32,
7166 vfmlslq_laneq_low_u32, vfmlslq_lane_low_u32, vfmlsl_laneq_low_u32,
7167 vfmlslq_laneq_high_u32, vfmlslq_lane_high_u32, vfmlsl_laneq_high_u32):
7168 Rename ...
7169 (vfmlal_low_f16, vfmlsl_low_f16, vfmlal_high_f16, vfmlsl_high_f16,
7170 vfmlalq_low_f16, vfmlslq_low_f16, vfmlalq_high_f16, vfmlslq_high_f16,
7171 vfmlal_lane_low_f16, vfmlal_lane_high_f16, vfmlalq_laneq_low_f16,
7172 vfmlalq_lane_low_f16, vfmlal_laneq_low_f16, vfmlalq_laneq_high_f16,
7173 vfmlalq_lane_high_f16, vfmlal_laneq_high_f16, vfmlsl_lane_low_f16,
7174 vfmlsl_lane_high_f16, vfmlslq_laneq_low_f16, vfmlslq_lane_low_f16,
7175 vfmlsl_laneq_low_f16, vfmlslq_laneq_high_f16, vfmlslq_lane_high_f16,
7176 vfmlsl_laneq_high_f16): ... To this.
7177 * config/arm/neon.md: Update comments.
7178
7179 2019-02-25 Tamar Christina <tamar.christina@arm.com>
7180
7181 * config/aarch64/arm_neon.h (vfmlal_low_u32, vfmlsl_low_u32,
7182 vfmlalq_low_u32, vfmlslq_low_u32, vfmlal_high_u32, vfmlsl_high_u32,
7183 vfmlalq_high_u32, vfmlslq_high_u32, vfmlal_lane_low_u32,
7184 vfmlsl_lane_low_u32, vfmlal_laneq_low_u32, vfmlsl_laneq_low_u32,
7185 vfmlalq_lane_low_u32, vfmlslq_lane_low_u32, vfmlalq_laneq_low_u32,
7186 vfmlslq_laneq_low_u32, vfmlal_lane_high_u32, vfmlsl_lane_high_u32,
7187 vfmlal_laneq_high_u32, vfmlsl_laneq_high_u32, vfmlalq_lane_high_u32,
7188 vfmlslq_lane_high_u32, vfmlalq_laneq_high_u32, vfmlslq_laneq_high_u32):
7189 Rename ...
7190 (vfmlal_low_f16, vfmlsl_low_f16, vfmlalq_low_f16, vfmlslq_low_f16,
7191 vfmlal_high_f16, vfmlsl_high_f16, vfmlalq_high_f16, vfmlslq_high_f16,
7192 vfmlal_lane_low_f16, vfmlsl_lane_low_f16, vfmlal_laneq_low_f16,
7193 vfmlsl_laneq_low_f16, vfmlalq_lane_low_f16, vfmlslq_lane_low_f16,
7194 vfmlalq_laneq_low_f16, vfmlslq_laneq_low_f16, vfmlal_lane_high_f16,
7195 vfmlsl_lane_high_f16, vfmlal_laneq_high_f16, vfmlsl_laneq_high_f16,
7196 vfmlalq_lane_high_f16, vfmlslq_lane_high_f16, vfmlalq_laneq_high_f16,
7197 vfmlslq_laneq_high_f16): ... To this.
7198
7199 2019-02-25 Alexander Monakov <amonakov@ispras.ru>
7200
7201 PR rtl-optimization/86096
7202 * df-scan.c (df_mw_compare): Do not check mw_reg fields when
7203 comparing mw_order values.
7204
7205 2019-02-25 Jakub Jelinek <jakub@redhat.com>
7206
7207 PR target/89434
7208 * config/arm/arm.md (*subsi3_carryin_const): Use
7209 arm_neg_immediate_operand predicate instead of
7210 arm_not_immediate_operand, "L" constraint instead of "K" and
7211 print it using %n2 instead of %B2.
7212 (*subsi3_carryin_const0): New define_insn.
7213 (*subsi3_carryin_compare_const): Use const_int_I_operand predicate
7214 instead of arm_not_operand and "I" constraint instead of "K" and
7215 print it using %n3 instead of %B2. Instead of using match_dup 2 add
7216 another match_operand and in the condition check that it is negation
7217 of operands[2].
7218 (*subsi3_carryin_compare_const0): New define_ins.
7219 (*subdi_di_zesidi): Adjust to use *subsi3_carryin_const0 instead of
7220 *subsi3_carryin_const.
7221 (*arm_cmpdi_insn): Fix splitting into *subsi3_carryin_compare_const,
7222 split into *subsi3_carryin_compare_const0 if the highpart is zero.
7223
7224 PR target/89438
7225 * config/arm.vfp.md (*negdf2_vfp): Use
7226 gen_int_mode (0x80000000, SImode) instead of GEN_INT (0x80000000).
7227 * config/arm/neon.md (neon_copysignf<mode>): Likewise.
7228
7229 2019-02-24 Jakub Jelinek <jakub@redhat.com>
7230
7231 PR rtl-optimization/89445
7232 * simplify-rtx.c (simplify_ternary_operation): Don't use
7233 simplify_merge_mask on operands that may trap.
7234 * rtlanal.c (may_trap_p_1): Use FLOAT_MODE_P instead of
7235 SCALAR_FLOAT_MODE_P checks. For integral division by zero, if
7236 second operand is CONST_VECTOR, check if any element could be zero.
7237 Don't expect traps for VEC_{MERGE,SELECT,CONCAT,DUPLICATE} unless
7238 their operands can trap.
7239
7240 2019-02-23 Martin Sebor <msebor@redhat.com>
7241
7242 * gimple-ssa-sprintf.c (target_strtol): Rename...
7243 (target_strtohwi): ...to this. Handle values up to HOST_WIDE_INT_MAX.
7244 (parse_directive): Adjust to name change. Use HOST_WIDE_INT_MAX to
7245 check for range error.
7246
7247 2019-02-23 H.J. Lu <hongjiu.lu@intel.com>
7248
7249 PR driver/69471
7250 * opts-common.c (prune_options): Also prune joined switches
7251 with Negative and RejectNegative.
7252 * config/i386/i386.opt (march=): Add Negative(march=).
7253 (mtune=): Add Negative(mtune=).
7254 * doc/options.texi: Document Negative used together with Joined
7255 and RejectNegative.
7256
7257 2019-02-22 Martin Sebor <msebor@redhat.com>
7258
7259 * doc/extend.texi (Other Builtins): Add
7260 __builtin_is_constant_evaluated.
7261
7262 2019-02-22 Richard Biener <rguenther@suse.de>
7263
7264 PR tree-optimization/87609
7265 * tree-cfg.c (gimple_duplicate_bb): Only remap inlined cliques.
7266
7267 2019-02-22 Jeff Law <law@redhat.com>
7268
7269 PR rtl-optimization/87761
7270 * config/mips/mips.md: Add new combiner pattern to recognize
7271 a bitfield extraction using (ashiftrt (truncate (ashift (...)))).
7272
7273 2019-02-22 Matthew Malcomson <matthew.malcomson@arm.com>
7274
7275 PR target/89324
7276 * config/aarch64/aarch64.md: Use aarch64_general_reg predicate on
7277 destination register in peepholes generating patterns for ADDS/SUBS.
7278 (add<mode>3_compare0,
7279 *addsi3_compare0_uxtw, add<mode>3_compareC,
7280 add<mode>3_compareV_imm, add<mode>3_compareV,
7281 *adds_<optab><ALLX:mode>_<GPI:mode>,
7282 *subs_<optab><ALLX:mode>_<GPI:mode>,
7283 *adds_<optab><ALLX:mode>_shift_<GPI:mode>,
7284 *subs_<optab><ALLX:mode>_shift_<GPI:mode>,
7285 *adds_<optab><mode>_multp2, *subs_<optab><mode>_multp2,
7286 *sub<mode>3_compare0, *subsi3_compare0_uxtw,
7287 sub<mode>3_compare1): Allow stack pointer for source register.
7288 * config/aarch64/predicates.md (aarch64_general_reg): New predicate.
7289
7290 2019-02-22 Martin Sebor <msebor@redhat.com>
7291
7292 PR tree-optimization/88993
7293 PR tree-optimization/88853
7294 * gimple-ssa-sprintf.c (sprintf_dom_walker::call_info::is_file_func):
7295 New helper.
7296 (sprintf_dom_walker::call_info::is_string_func): New helper.
7297 (format_directive): Only issue "may exceed" 4095/INT_MAX warnings
7298 for formatted string functions.
7299 (sprintf_dom_walker::handle_gimple_call): Fix a typo in a comment.
7300
7301 2019-02-22 Martin Sebor <msebor@redhat.com>
7302
7303 PR c/89425
7304 * c-parser.c (sizeof_ptr_memacc_comptypes): Avoid warning in
7305 unreachable subexpressions.
7306
7307 2019-02-22 H.J. Lu <hongjiu.lu@intel.com>
7308 Hongtao Liu <hongtao.liu@intel.com>
7309 Sunil K Pandey <sunil.k.pandey@intel.com>
7310
7311 PR target/87007
7312 * config/i386/i386-passes.def: Add
7313 pass_remove_partial_avx_dependency.
7314 * config/i386/i386-protos.h
7315 (make_pass_remove_partial_avx_dependency): New.
7316 * config/i386/i386.c (make_pass_remove_partial_avx_dependency):
7317 New function.
7318 (pass_data_remove_partial_avx_dependency): New.
7319 (pass_remove_partial_avx_dependency): Likewise.
7320 (make_pass_remove_partial_avx_dependency): Likewise.
7321 * config/i386/i386.md (avx_partial_xmm_update): New attribute.
7322 (*extendsfdf2): Add avx_partial_xmm_update.
7323 (truncdfsf2): Likewise.
7324 (*float<SWI48:mode><MODEF:mode>2): Likewise.
7325 (SF/DF conversion splitters): Disabled for TARGET_AVX.
7326
7327 2019-02-22 Aldy Hernandez <aldyh@redhat.com>
7328
7329 PR middle-end/85598
7330 * gimple-ssa-sprintf.c (pass_sprintf_length::execute): Enable loop
7331 analysis for pass.
7332
7333 2019-02-22 Thiago Macieira <thiago.macieira@intel.com>
7334
7335 PR target/89444
7336 * config/i386/i386.h (PTA_WESTMERE): Remove PTA_AES.
7337 (PTA_SKYLAKE): Add PTA_AES.
7338 (PTA_GOLDMONT): Likewise.
7339
7340 2019-02-22 Sudakshina Das <sudi.das@arm.com>
7341
7342 * config/aarch64/aarch64.c (aarch64_output_mi_thunk): Add bti
7343 instruction if enabled.
7344 (aarch64_override_options): Remove reference to return address key.
7345
7346 2019-02-22 Richard Biener <rguenther@suse.de>
7347
7348 PR tree-optimization/89440
7349 * tree-vect-loop.c (vect_create_epilog_for_reduction): Remove
7350 not necessary assert.
7351
7352 2019-02-22 Thomas Schwinge <thomas@codesourcery.com>
7353
7354 PR fortran/72741
7355 * omp-general.c (oacc_replace_fn_attrib): Mostly split out into...
7356 (oacc_replace_fn_attrib_attr): ... this new function.
7357 * omp-general.h (oacc_replace_fn_attrib_attr): New prototype.
7358 * config/nvptx/nvptx.c (nvptx_goacc_validate_dims_1): Revert workaround.
7359
7360 2019-02-22 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
7361
7362 * config/arm/arm-cpus.in (ares): Rename to...
7363 (neoverse-n1): ... This. Add ares as alias.
7364 * config/arm/arm-tables.opt: Regenerate.
7365 * config/arm/arm-tune.md: Likewise.
7366 * doc/invoke.txt (ARM Options): Document neoverse-n1.
7367
7368 2019-02-22 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
7369
7370 * config/aarch64/aarch64-cores.def (neoverse-e1): Define.
7371 * config/aarch64/aarch64-tune.md: Regenerate.
7372 * doc/invoke.texi (AArch64 Options): Document neoverse-e1 -mcpu option.
7373
7374 2019-02-22 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
7375
7376 * config/aarch64/aarch64.c (ares_tunings): Rename to...
7377 (neoversen1_tunings): ... This.
7378 * config/aarch64/aarch64-cores.def (ares): Change tuning to the above.
7379 (neoverse-n1): New CPU.
7380 * config/aarch64/aarch64-tune.md: Regenerate.
7381 * doc/invoke.txt (AArch64 Options): Document neoverse-n1.
7382
7383 2019-02-22 Richard Biener <rguenther@suse.de>
7384
7385 PR middle-end/87609
7386 * cfghooks.h (dependence_hash): New typedef.
7387 (struct copy_bb_data): New type.
7388 (cfg_hooks::duplicate_block): Adjust to take a copy_bb_data argument.
7389 (duplicate_block): Likewise.
7390 * cfghooks.c (duplicate_block): Pass down copy_bb_data.
7391 (copy_bbs): Create and pass down copy_bb_data.
7392 * cfgrtl.c (cfg_layout_duplicate_bb): Adjust.
7393 (rtl_duplicate_bb): Likewise.
7394 * tree-cfg.c (gimple_duplicate_bb): If the copy_bb_data arg is not NULL
7395 remap dependence info.
7396
7397 2019-02-22 Richard Biener <rguenther@suse.de>
7398
7399 PR tree-optimization/87609
7400 * tree-core.h (tree_base): Document special clique values.
7401 * tree-inline.c (remap_dependence_clique): Do not use the
7402 special clique value of one.
7403 (maybe_set_dependence_info): Use clique one.
7404 (clear_dependence_clique): New callback.
7405 (compute_dependence_clique): Clear clique one from all refs
7406 before assigning it (again).
7407
7408 2019-02-21 Martin Sebor <msebor@redhat.com>
7409
7410 * doc/extend.texi (__clear_cache): Correct signature.
7411
7412 2019-02-21 Ian Lance Taylor <iant@golang.org>
7413
7414 PR go/89170
7415 * varasm.c (decode_addr_const): Call lookup_constant_def rather
7416 than output_constant_def.
7417 (add_constant_to_table): New static function.
7418 (output_constant_def): Call add_constant_to_table.
7419 (tree_output_constant_def): Likewise.
7420
7421 2019-02-21 Jakub Jelinek <jakub@redhat.com>
7422
7423 PR c++/89285
7424 * builtins.c (fold_builtin_arith_overflow): If first two args are
7425 INTEGER_CSTs, set intres and ovfres to constants rather than calls
7426 to ifn.
7427
7428 2019-02-21 H.J. Lu <hongjiu.lu@intel.com>
7429
7430 PR target/87412
7431 * config/i386/i386.c (ix86_set_indirect_branch_type): Issue an
7432 error for -mindirect-branch/-mfunction-return with incompatible
7433 -fcf-protection.
7434
7435 2019-02-21 Jakub Jelinek <jakub@redhat.com>
7436
7437 PR bootstrap/88714
7438 * constraints.md (q): Remove.
7439 * config/arm/ldrdstrd.md (*arm_ldrd, *arm_strd): Use rk constraint
7440 instead of q.
7441
7442 2019-02-21 Martin Jambor <mjambor@suse.cz>
7443
7444 PR hsa/89302
7445 * omp-general.c (omp_extract_for_data): Removed a duplicate call
7446 to omp_adjust_for_condition, moved NE_EXPR code_cond processing...
7447 (omp_adjust_for_condition): ...here. Added necessary parameters.
7448 * omp-general.h (omp_adjust_for_condition): Updated declaration.
7449 * omp-grid.c (grid_attempt_target_gridification): Adjust to pass
7450 proper values to new parameters of omp_adjust_for_condition.
7451
7452 2019-02-20 Jakub Jelinek <jakub@redhat.com>
7453
7454 PR middle-end/89412
7455 * expr.c (expand_assignment): If result is a MEM, use change_address
7456 instead of simplify_gen_subreg.
7457
7458 2019-02-20 Jakub Jelinek <jakub@redhat.com>
7459 David Malcolm <dmalcolm@redhat.com>
7460
7461 PR middle-end/89091
7462 * fold-const.c (decode_field_reference): Return NULL_TREE if
7463 lang_hooks.types.type_for_size returns NULL. Check it before
7464 overwriting *exp_. Use return NULL_TREE instead of return 0.
7465
7466 2019-02-20 Jakub Jelinek <jakub@redhat.com>
7467
7468 PR middle-end/88074
7469 PR middle-end/89415
7470 * toplev.c (do_compile): Double the emin/emax exponents to workaround
7471 buggy mpc_norm.
7472
7473 2019-02-20 Uroš Bizjak <ubizjak@gmail.com>
7474
7475 PR target/89397
7476 * config/i386/i386.c (ix86_atomic_assign_expand_fenv): Check
7477 TARGET_SSE in addition to TARGET_SSE_MATH.
7478
7479 (ix86_excess_precision): Ditto.
7480 (ix86_float_exceptions_rounding_supported_p): Ditto.
7481 (use_rsqrt_p): Ditto.
7482 * config/i386/sse.md (rsqrt<mode>2): Ditto.
7483
7484 2019-02-20 David Malcolm <dmalcolm@redhat.com>
7485
7486 PR c/89410
7487 * diagnostic-show-locus.c (layout::calculate_line_spans): Use
7488 linenum_arith_t when determining if two adjacent line spans are
7489 close enough to merge.
7490 (diagnostic_show_locus): Use linenum_arith_t when iterating over
7491 lines within each line_span.
7492
7493 2019-02-20 Andre Vieira <andre.simoesdiasvieira@arm.com>
7494
7495 PR target/86487
7496 * lra-constraints.c(uses_hard_regs_p): Fix handling of
7497 paradoxical SUBREGS.
7498
7499 2019-02-20 Li Jia He <helijia@linux.ibm.com>
7500
7501 PR target/88100
7502 * gcc/config/rs6000/rs6000.c (rs6000_gimple_fold_builtin)
7503 <case ALTIVEC_BUILTIN_VSPLTISB, ALTIVEC_BUILTIN_VSPLTISH,
7504 ALTIVEC_BUILTIN_VSPLTISW>: Don't convert the operand before
7505 range checking it.
7506
7507 2019-02-19 Jonathan Wakely <jwakely@redhat.com>
7508
7509 * config/gcn/gcn.c (print_operand): Fix typo.
7510
7511 2019-02-19 Richard Biener <rguenther@suse.de>
7512
7513 PR middle-end/88074
7514 * toplev.c (do_compile): Initialize mpfr's exponent range
7515 based on available float modes.
7516
7517 2019-02-19 Eric Botcazou <ebotcazou@adacore.com>
7518
7519 * rtlanal.c (get_initial_register_offset): Fall back to the estimate
7520 as long as the epilogue isn't completed.
7521
7522 2019-02-18 Martin Sebor <msebor@redhat.com>
7523
7524 * doc/cpp.texi (Conditional syntax): Add __has_attribute,
7525 __has_cpp_attribute, and __has_include.
7526
7527 2019-02-18 Martin Sebor <msebor@redhat.com>
7528
7529 * doc/invoke.texi (-Wreturn-type): Correct and expand.
7530
7531 2019-02-18 Martin Sebor <msebor@redhat.com>
7532
7533 PR middle-end/89294
7534 * tree.c (valid_constant_size_p): Avoid assuming size is a constant
7535 expression.
7536 * tree.h (cst_size_error): Add the cst_size_not_constant enumerator.
7537
7538 2019-02-18 Richard Biener <rguenther@suse.de>
7539
7540 PR tree-optimization/89296
7541 * tree-ssa-loop-ch.c (ch_base::copy_headers): Restrict setting
7542 of no-warning flag to cases that might emit the bogus warning.
7543
7544 2019-02-18 Jakub Jelinek <jakub@redhat.com>
7545
7546 PR bootstrap/88714
7547 * config/arm/arm.md (*arm_movdi, *movdf_soft_insn): Use "r" instead of
7548 "q" constraint.
7549 * config/arm/vfp.md (*movdi_vfp): Likewise.
7550 * config/arm/ldrdstrd.md (*arm_ldrd, *arm_strd): Use "r" instead of
7551 "q" constraint for operands[0].
7552
7553 PR target/89369
7554 * config/s390/s390.md (*r<noxa>sbg_<mode>_srl_bitmask,
7555 *r<noxa>sbg_<mode>_sll, *r<noxa>sbg_<mode>_srl): Don't construct
7556 pattern in a temporary buffer.
7557 (*r<noxa>sbg_sidi_srl): Likewise. Always use 32 as I3 rather
7558 than 64-operands[2].
7559
7560 PR target/89361
7561 * config/s390/s390.c (s390_indirect_branch_attrvalue,
7562 s390_indirect_branch_settings): Define unconditionally.
7563 (s390_set_current_function): Likewise, but guard the whole body except
7564 the s390_indirect_branch_settings call with
7565 #if S390_USE_TARGET_ATTRIBUTE.
7566 (TARGET_SET_CURRENT_FUNCTION): Redefine unconditionally.
7567
7568 * config/s390/s390.md (*<risbg_n>_ior_and_sr_ze,
7569 *<risbg_n>_<mode>_ior_and_lshiftrt, *<risbg_n>_sidi_ior_and_lshiftrt):
7570 Use HOST_WIDE_INT_M1U instead of ~(0ULL).
7571 (*<risbg_n>_and_subregdi_rotr, *<risbg_n>_and_subregdi_rotl): Use
7572 HOST_WIDE_INT_1U instead of 1ULL.
7573 (*pre_z10_extzv<mode>, *pre_z10_extv<mode>): Change mask type from int
7574 to unsigned HOST_WIDE_INT, use HOST_WIDE_INT_1U instead of 1ul.
7575 (*insv<mode><clobbercc_or_nocc>_appendbitsleft,
7576 z = (x << c) | (y >> d) splitters): Use HOST_WIDE_INT_1U
7577 instead of 1UL.
7578 (*insv<mode>_mem_reg, *insvdi_mem_reghigh): Use HOST_WIDE_INT_1U
7579 instead of 1ul.
7580
7581 2019-02-18 Martin Jambor <mjambor@suse.cz>
7582
7583 PR tree-optimization/89209
7584 * tree-sra.c (create_access_replacement): New optional parameter
7585 reg_tree. Use it as a type if non-NULL and access type is not of
7586 a register type.
7587 (get_repl_default_def_ssa_name): New parameter REG_TYPE, pass it
7588 to create_access_replacement.
7589 (sra_modify_assign): Pass LHS type to get_repl_default_def_ssa_name.
7590 Check lacc is non-NULL before attempting to re-create it on the RHS.
7591
7592 2019-02-18 Martin Liska <mliska@suse.cz>
7593
7594 PR ipa/89306
7595 * cgraph.c (symbol_table::create_edge): Set m_summary_id to -1
7596 by default.
7597 (symbol_table::free_edge): Recycle m_summary_id.
7598 * cgraph.h (get_summary_id): New.
7599 (symbol_table::release_symbol): Set m_summary_id to -1
7600 by default.
7601 (symbol_table::allocate_cgraph_symbol): Recycle m_summary_id.
7602 * ipa-fnsummary.c (ipa_fn_summary_t): Switch from
7603 function_summary to fast_function_summary.
7604 * ipa-fnsummary.h (ipa_fn_summary_t): Likewise.
7605 * ipa-pure-const.c (class funct_state_summary_t):
7606 Switch from function_summary to fast_function_summary.
7607 * ipa-reference.c (class ipa_ref_var_info_summary_t): Likewise.
7608 (class ipa_ref_opt_summary_t): Switch from function_summary
7609 to fast_function_summary.
7610 * symbol-summary.h (class function_summary_base): New class
7611 that is created from base of former function_summary.
7612 (function_summary_base::unregister_hooks): New.
7613 (class function_summary): Inherit from function_summary_base.
7614 (class call_summary_base): New class
7615 that is created from base of former call_summary.
7616 (class call_summary): Inherit from call_summary_base.
7617 (struct is_same): New.
7618 (class fast_function_summary): New summary class.
7619 (class fast_call_summary): New summary class.
7620 * vec.h (vec_safe_grow_cleared): New function.
7621
7622 2019-02-18 Martin Liska <mliska@suse.cz>
7623
7624 * config/i386/i386.c (ix86_get_multilib_abi_name): New function.
7625 (TARGET_GET_MULTILIB_ABI_NAME): New macro defined.
7626 * doc/tm.texi: Document new target hook.
7627 * doc/tm.texi.in: Likewise.
7628 * target.def: Add new target macro.
7629 * gcc.c (find_fortran_preinclude_file): Do not search multilib
7630 suffixes.
7631
7632 2019-02-17 Alan Modra <amodra@gmail.com>
7633
7634 PR target/89271
7635 * config/rs6000/rs6000.md (<bd>_<mode> split): Check for an int
7636 output reg on add insn.
7637 (<bd>tf_<mode> split): Likewise. Match predicates with insn.
7638
7639 2019-02-16 H.J. Lu <hongjiu.lu@intel.com>
7640
7641 PR target/89372
7642 * config/i386/sse.md (ssedoublemode): Remove V4HI.
7643 (PMULHRSW): Likewise.
7644 (<ssse3_avx2>_pmulhrsw<mode>3): Require TARGET_SSSE3, not
7645 TARGET_AVX2.
7646 (ssse3_pmulhrswv4hi3): New expander.
7647
7648 2019-02-16 H.J. Lu <hongjiu.lu@intel.com>
7649
7650 * config/i386/mmx.md (*vec_extractv2si_zext_mem): Doesn't require
7651 MMX. Add isa attribute.
7652
7653 2019-02-16 Jakub Jelinek <jakub@redhat.com>
7654
7655 PR rtl-optimization/66152
7656 * builtins.h (c_readstr): Declare.
7657 * builtins.c (c_readstr): Remove forward declaration. Add
7658 null_terminated_p argument, if false, read all bytes from the
7659 string instead of stopping after '\0'.
7660 * expr.c (string_cst_read_str): New function.
7661 (store_expr): Use string_cst_read_str instead of
7662 builtin_strncpy_read_str. Try to store by pieces the whole
7663 exp_len first, and only if that fails, split it up into
7664 store by pieces followed by clear_storage. Formatting fix.
7665
7666 * config/i386/i386.md (*movqi_internal): Remove static from
7667 buf variable. Use output_asm_insn (buf, operands); return "";
7668 instead of return buf;.
7669 * config/i386/sse.md (<sse>_andnot<mode>3<mask_name>,
7670 *<code><mode>3<mask_name>, *andnot<mode>3, *andnottf3, *<code><mode>3,
7671 *<code>tf3, <mask_codefor><code><mode>3<mask_name>): Likewise.
7672
7673 2019-02-15 Eric Botcazou <ebotcazou@adacore.com>
7674
7675 * config/sparc/linux.h (ASAN_CC1_SPEC): Define.
7676 (CC1_SPEC): Use GNU_USER_TARGET_CC1_SPEC and ASAN_CC1_SPEC.
7677 * config/sparc/linux64.h (ASAN_CC1_SPEC): Likewise.
7678 (CC1_SPEC): Likewise.
7679 * config/sparc/sparc.c (sparc_asan_shadow_offset): Adjust for 64-bit.
7680
7681 2019-02-15 Eric Botcazou <ebotcazou@adacore.com>
7682
7683 * asan.c (asan_emit_stack_protection): Use full-sized mask to align
7684 the base address on 64-bit strict-alignment platforms.
7685
7686 2019-02-15 H.J. Lu <hongjiu.lu@intel.com>
7687
7688 * config/i386/i386.h (VALID_MMX_REG_MODE): Correct the misplaced ')'.
7689
7690 2019-02-15 Uroš Bizjak <ubizjak@gmail.com>
7691
7692 * config/i386/darwin.h (TARGET_FPMATH_DEFAULT_P): New define.
7693
7694 2019-02-15 Aaron Sawdey <acsawdey@linux.ibm.com>
7695
7696 PR rtl-optimization/88308
7697 * shrink-wrap.c (move_insn_for_shrink_wrap): Fix LABEL_NUSES counts
7698 on copied instruction.
7699
7700 2019-02-15 Eric Botcazou <ebotcazou@adacore.com>
7701
7702 * final.c (insn_current_reference_address): Replace test on JUMP_P
7703 with test on jump_to_label_p.
7704 * config/visium/visium-passes.def: New file.
7705 * config/visium/t-visium (PASSES_EXTRA): Define.
7706 * config/visium/visium-protos.h (make_pass_visium_reorg): Declare.
7707 * config/visium/visium.h (TRAMPOLINE_SIZE): Adjust.
7708 (TRAMPOLINE_ALIGNMENT): Define.
7709 * config/visium/visium.c (visium_option_override): Do not register
7710 the machine-specific reorg pass here.
7711 (visium_trampoline_init): Align the BRA insn on a 64-bit boundary
7712 for the GR6.
7713 (output_branch): Adjust threshold for long branch instruction.
7714 * config/visium/visium.md (cpu): Move around.
7715 (length): Adjust for the GR6.
7716
7717 2019-02-15 Richard Biener <rguenther@suse.de>
7718 Jakub Jelinek <jakub@redhat.com>
7719
7720 PR tree-optimization/89278
7721 * tree-loop-distribution.c: Include tree-eh.h.
7722 (generate_memset_builtin, generate_memcpy_builtin): Call
7723 rewrite_to_non_trapping_overflow on builtin->size before passing it
7724 to force_gimple_operand_gsi.
7725
7726 2019-02-15 Jakub Jelinek <jakub@redhat.com>
7727
7728 PR other/89342
7729 * optc-save-gen.awk: Handle optimize_fast like optimize_size or
7730 optimize_debug.
7731 * opth-gen.awk: Likewise.
7732
7733 2019-02-15 Uroš Bizjak <ubizjak@gmail.com>
7734
7735 * config/i386/i386.h (TARGET_SUBTARGET64_ISA_DEFAULT):
7736 Enable MMX, SSE and SSE2 by default.
7737 * config/i386/i386.c (ix86_option_override_internal): Do not
7738 explicitly set MMX, SSE and SSE2 flags for TARGET_64BIT here.
7739
7740 2019-02-14 Jakub Jelinek <jakub@redhat.com>
7741
7742 PR rtl-optimization/89354
7743 * combine.c (make_extraction): Punt if extraction_mode is narrower
7744 than len bits.
7745
7746 2019-02-14 Maya Rashish <coypu@sdf.org>
7747
7748 * config.gcc (*-*-netbsd*): Add netbsd-d.o.
7749 * config/netbsd-d.c: New file.
7750 * config/t-netbsd: Add netbsd-d.o
7751
7752 2018-02-14 Steve Ellcey <sellcey@marvell.com>
7753
7754 * config/aarch64/aarch64.c (aarch64_attribute_table): Change
7755 affects_type_identity to true for aarch64_vector_pcs.
7756 (aarch64_comp_type_attributes): New function.
7757 (TARGET_COMP_TYPE_ATTRIBUTES): New macro.
7758
7759 2019-02-14 Tamar Christina <tamar.christina@arm.com>
7760
7761 PR target/88850
7762 * config/arm/iterators.md (ANY64): Add V4HF.
7763
7764 2019-02-14 Martin Liska <mliska@suse.cz>
7765
7766 PR rtl-optimization/89242
7767 * dce.c (delete_unmarked_insns): Call free_dominance_info we
7768 process a transformation.
7769
7770 2019-02-14 Jakub Jelinek <jakub@redhat.com>
7771
7772 PR tree-optimization/89314
7773 * fold-const.c (fold_binary_loc): Cast strlen argument to
7774 const char * before dereferencing it. Formatting fixes.
7775
7776 PR middle-end/89284
7777 * passes.def: Swap pass_ubsan and pass_early_warn_uninitialized.
7778
7779 2019-02-13 Ian Lance Taylor <iant@golang.org>
7780
7781 * optc-save-gen.awk: Set var_opt_hash for initial optimizations
7782 and set current index for other optimizations.
7783
7784 2019-02-13 Uroš Bizjak <ubizjak@gmail.com>
7785
7786 * config/i386/sse.md (vec_set<VI4F_256_512:mode>_0): Use
7787 nonimmediate_operand as operand 2 predicate.
7788 (vec_set<VF2_512_256:mode>_0): Ditto.
7789 (vec_set<VI8_AVX_AVX512F:mode>_0): Ditto.
7790 (*vec_concatv2si): Remove alternative 2.
7791 (*vec_concatv4si_0): Use vm constraint for alternative 0.
7792 (*vec_concatv4si_0): Remove preferred_for_speed attribute.
7793 (vec_concatv2di): Split alternatives 4,5,6 to ...
7794 (*vec_concatv2di_0) ... new pattern.
7795
7796 2019-02-13 Wilco Dijkstra <wdijkstr@arm.com>
7797
7798 PR target/89190
7799 * config/arm/arm.c (ldm_stm_operation_p) Set
7800 addr_reg_in_reglist correctly for first register.
7801 (load_multiple_sequence): Remove dead base check.
7802 (gen_ldm_seq): Correctly set write_back for Thumb-1.
7803
7804 2019-02-13 Tamar Christina <tamar.christina@arm.com>
7805
7806 PR target/88847
7807 * config/aarch64/aarch64-sve.md (*pred_mov<mode>, pred_mov<mode>):
7808 Expose as @aarch64_pred_mov.
7809 * config/aarch64/aarch64.c (aarch64_classify_address):
7810 Use expand_insn which legitimizes operands.
7811
7812 2019-02-13 Martin Liska <mliska@suse.cz>
7813
7814 * builtins.h (expand_builtin_with_bounds): Remove declaration.
7815 * calls.c (struct arg_data): Remove special_slot, pointer_arg
7816 and pointer_offset fields.
7817 (initialize_argument_information): Remove usage of dead
7818 fields.
7819 * cgraph.h (struct cgraph_thunk_info): Remove
7820 add_pointer_bounds_args.
7821 * cgraphunit.c (cgraph_node::expand_thunk): Remove usage of dead
7822 fields.
7823 (cgraph_node::assemble_thunks_and_aliases): Remove usage of dead
7824 fields.
7825 * config/i386/i386.c (ix86_function_arg_advance): Remove
7826 unrelated comment.
7827 (struct builtin_isa): Remove leaf_p and nothrow_p fields.
7828 (def_builtin): Remove usage of dead
7829 fields.
7830 (ix86_add_new_builtins): Likewise.
7831 * ipa-fnsummary.c (compute_fn_summary): Likewise.
7832 * ipa-icf.c (sem_function::equals_wpa): Likewise.
7833 (sem_function::init): Likewise.
7834 (sem_variable::merge): Likewise.
7835 * ipa-visibility.c (function_and_variable_visibility): Likewise.
7836 * ipa.c (symbol_table::remove_unreachable_nodes): Likewise.
7837 * lto-cgraph.c (lto_output_node): Likewise.
7838 (lto_output_varpool_node): Likewise.
7839 (input_node): Likewise.
7840 (input_varpool_node): Likewise.
7841 * lto-streamer-out.c (lto_output): Likewise.
7842 * tree-inline.c (expand_call_inline): Remove usage of
7843 assign_stmts.
7844 * tree-inline.h (struct copy_body_data): Likewise.
7845 * varpool.c (varpool_node::dump): Likewise.
7846
7847 2019-02-13 Jakub Jelinek <jakub@redhat.com>
7848
7849 PR middle-end/89303
7850 * tree-ssa-structalias.c (set_uids_in_ptset): Or in vi->is_heap_var
7851 into pt->vars_contains_escaped_heap instead of setting
7852 pt->vars_contains_escaped_heap to it.
7853
7854 PR middle-end/89281
7855 * optabs.c (prepare_cmp_insn): Use UINTVAL (size) instead of
7856 INTVAL (size), compare it to GET_MODE_MASK instead of
7857 1 << GET_MODE_BITSIZE.
7858
7859 PR target/89290
7860 * config/i386/predicates.md (x86_64_immediate_operand): Allow
7861 TLS UNSPECs offsetted by signed 32-bit CONST_INT even with
7862 -mcmodel=large.
7863
7864 2019-02-13 Martin Liska <mliska@suse.cz>
7865
7866 PR lto/88858
7867 * cfgrtl.c (remove_barriers_from_footer): New function.
7868 (try_redirect_by_replacing_jump): Use it.
7869 (cfg_layout_redirect_edge_and_branch): Likewise.
7870
7871 2019-02-13 Xiong Hu Luo <luoxhu@linux.vnet.ibm.com>
7872
7873 * config/rs6000/altivec.h (vec_sbox_be, vec_cipher_be,
7874 vec_cipherlast_be, vec_ncipher_be, vec_ncipherlast_be): New #defines.
7875 * config/rs6000/crypto.md (CR_vqdi): New define_mode_iterator.
7876 (crypto_vsbox_<mode>, crypto_<CR_insn>_<mode>): New define_insns.
7877 * config/rs6000/rs6000-builtin.def (VSBOX_BE): New BU_CRYPTO_1.
7878 (VCIPHER_BE, VCIPHERLAST_BE, VNCIPHER_BE, VNCIPHERLAST_BE):
7879 New BU_CRYPTO_2.
7880 * config/rs6000/rs6000.c (builtin_function_type)
7881 <CRYPTO_BUILTIN_VSBOX_BE, CRYPTO_BUILTIN_VCIPHER_BE,
7882 CRYPTO_BUILTIN_VCIPHERLAST_BE, CRYPTO_BUILTIN_VNCIPHER_BE,
7883 CRYPTO_BUILTIN_VNCIPHERLAST_BE>: New switch options.
7884 * doc/extend.texi (vec_sbox_be, vec_cipher_be, vec_cipherlast_be,
7885 vec_ncipher_be, vec_ncipherlast_be): New builtin functions.
7886
7887 2019-02-12 Pat Haugen <pthaugen@us.ibm.com>
7888
7889 * doc/invoke.texi (RS/6000 and PowerPC Options): Remove duplicate
7890 -maltivec. Delete -maltivec=be and -maltivec=le documentation.
7891
7892 2019-02-12 H.J. Lu <hongjiu.lu@intel.com>
7893
7894 PR target/89229
7895 * config/i386/i386.md (*movoi_internal_avx): Revert revision
7896 268678 and revision 268657.
7897 (*movti_internal): Likewise.
7898
7899 2019-02-12 Ilya Leoshkevich <iii@linux.ibm.com>
7900
7901 PR target/89233
7902 * config/s390/s390.c (s390_decompose_address): Update comment.
7903 (s390_check_qrst_address): Reject invalid address forms after
7904 LRA.
7905
7906 2019-02-12 Martin Liska <mliska@suse.cz>
7907
7908 PR lto/88876
7909 * ipa-pure-const.c (propagate_pure_const): Revert hunk as
7910 we need default values of funct_state for a function that
7911 is not optimized.
7912
7913 2019-02-12 Eric Botcazou <ebotcazou@adacore.com>
7914
7915 * asan.c (asan_expand_mark_ifn): Take into account the alignment of
7916 the object to pick the size of stores on strict-alignment platforms.
7917
7918 * config/sparc/sparc.md (*movsi_insn): Minor tweak.
7919 (*movdi_insn_sp32): Likewise.
7920 (*movdi_insn_sp64): Likewise.
7921
7922 2019-02-12 Jan Hubicka <hubicka@ucw.cz>
7923
7924 PR lto/88677
7925 * cgraphunit.c (analyze_functions): Clear READONLY flag for external
7926 types that needs constructiong.
7927 * tree.h (may_be_aliased): Do not check TYPE_NEEDS_CONSTRUCTING.
7928
7929 2019-02-12 Richard Biener <rguenther@suse.de>
7930
7931 PR tree-optimization/89253
7932 * tree-ssa-loop-split.c (tree_ssa_split_loops): Check we can
7933 duplicate the loop.
7934
7935 2019-02-11 David Malcolm <dmalcolm@redhat.com>
7936
7937 PR lto/88147
7938 * input.c (selftest::test_line_offset_overflow): New selftest.
7939 (selftest::input_c_tests): Call it.
7940
7941 2019-02-11 Martin Sebor <msebor@redhat.com>
7942
7943 PR tree-optimization/88771
7944 * gimple-ssa-warn-restrict.c (pass_wrestrict::gate): Also enable
7945 when -Wstringop-overflow is set.
7946 (builtin_memref::builtin_memref): Adjust excessive upper bound
7947 only when lower bound is not excessive.
7948 (maybe_diag_overlap): Detect and diagnose excessive bounds via
7949 -Wstringop-ovefflow.
7950 (maybe_diag_offset_bounds): Rename...
7951 (maybe_diag_access_bounds): ...to this.
7952 (check_bounds_or_overlap): Adjust for name change above.
7953
7954 2019-02-11 Martin Sebor <msebor@redhat.com>
7955
7956 PR c++/87996
7957 * builtins.c (max_object_size): Move from here...
7958 * builtins.h (max_object_size): ...and here...
7959 * tree.c (max_object_size): ...to here...
7960 * tree.h (max_object_size): ...and here.
7961
7962 2019-02-11 Bill Schmidt <wschmidt@linux.ibm.com>
7963
7964 * config/rs6000/rs6000.c (rs6000_gimple_fold_builtin): Shift-right
7965 and shift-left vector built-ins need to include a TRUNC_MOD_EXPR
7966 for correct semantics.
7967
7968 2019-02-11 Alan Modra <amodra@gmail.com>
7969
7970 * doc/invoke.texi (man page RS/6000 and PowerPC Options): Mention
7971 -mlongcall and -mpltseq.
7972 (RS/6000 and PowerPC Options <-mlongcall>): Mention inline PLT calls.
7973 (RS/6000 and PowerPC Options <-mpltseq>): Document.
7974 * config/rs6000/rs6000.h (TARGET_PLTSEQ): Define.
7975 * config/rs6000/sysv4.opt (mpltseq): New option.
7976 * config/rs6000/sysv4.h (TARGET_PLTSEQ): Redefine.
7977 (SUBTARGET_OVERRIDE_OPTIONS): Error if given -mpltseq when assembler
7978 support is lacking. Don't allow -mpltseq with -mbss-plt.
7979 * config/rs6000/linux64.h (SUBSUBTARGET_OVERRIDE_OPTIONS): Warn if
7980 -mpltseq given for ELFv1.
7981 * config/rs6000/rs6000.c (rs6000_call_aix): Comment on UNSPEC_PLTSEQ.
7982 Only use UNSPEC_PLTSEQ for inline PLT calls.
7983 (rs6000_call_sysv, rs6000_sibcall_sysv): Expand comments. Only
7984 use UNSPEC_PLTSEQ for inline PLT calls.
7985 (rs6000_indirect_call_template_1, rs6000_longcall_ref),
7986 (rs6000_call_aix, rs6000_call_sysv, rs6000_sibcall_sysv): Replace
7987 uses of HAVE_AS_PLTSEQ with TARGET_PLTSEQ, simplifying.
7988 * config/rs6000/rs6000.md (pltseq_tocsave_<mode>),
7989 (pltseq_plt16_ha_<mode>, pltseq_plt16_lo_<mode>),
7990 (pltseq_mtctr_<mode>): Likewise.
7991
7992 2019-02-11 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
7993
7994 * acinclude.m4 (gcc_AC_INITFINI_ARRAY): Use 8-byte strings with
7995 Solaris ld.
7996 * configure: Regenerate.
7997
7998 2019-02-11 Jakub Jelinek <jakub@redhat.com>
7999
8000 PR bootstrap/88714
8001 * config/arm/ldrdstrd.md (*arm_ldrd, *arm_strd): Use q constraint
8002 instead of r.
8003
8004 2019-02-11 Hans-Peter Nilsson <hp@axis.com>
8005
8006 * function.c (assign_parm_setup_block): Use the stored
8007 size, not the passed size, when allocating stack-space,
8008 also for a parameter with alignment larger than
8009 MAX_SUPPORTED_STACK_ALIGNMENT.
8010
8011 2019-02-11 Martin Liska <mliska@suse.cz>
8012
8013 PR ipa/89009
8014 * ipa-cp.c (build_toporder_info): Remove usage of a param.
8015 * ipa-inline.c (inline_small_functions): Likewise.
8016 * ipa-pure-const.c (propagate_pure_const): Likewise.
8017 (propagate_nothrow): Likewise.
8018 * ipa-reference.c (propagate): Likewise.
8019 * ipa-utils.c (struct searchc_env): Remove unused field.
8020 (searchc): Always search across AVAIL_INTERPOSABLE.
8021 (ipa_reduced_postorder): Always allow AVAIL_INTERPOSABLE as
8022 the only called IPA pure const can properly not propagate
8023 across interposable boundary.
8024 * ipa-utils.h (ipa_reduced_postorder): Remove param.
8025
8026 2019-02-11 Chung-Ju Wu <jasonwucj@gmail.com>
8027
8028 * config/nds32/nds32.md (call_internal, call_value_internal,
8029 sibcall_internal, sibcall_value_internal): Use SImode for mem rtx.
8030
8031 2019-02-11 Hans-Peter Nilsson <hp@axis.com>
8032
8033 * config/cris/cris.c (cris_preferred_minimum_alignment): Fix name
8034 typo.
8035
8036 2019-02-10 H.J. Lu <hongjiu.lu@intel.com>
8037
8038 * config/i386/constraints.md (Yd): Replace AVX512BW with AVX512DQ
8039 in comments
8040
8041 2019-02-10 Chung-Ju Wu <jasonwucj@gmail.com>
8042
8043 * config.gcc (with_nds32_lib): Set default --with-nds32-lib correctly.
8044
8045 2019-02-10 Jakub Jelinek <jakub@redhat.com>
8046
8047 PR tree-optimization/89268
8048 * tree-if-conv.c (version_loop_for_if_conversion): Push to preds only
8049 if preds is non-NULL.
8050
8051 2019-02-09 Jan Hubicka <hubicka@ucw.cz>
8052
8053 PR lto/89272
8054 * tree.c (fld_simplified_type_name): Also keep TYPE_DECL for
8055 polymorphic types.
8056
8057 2019-02-10 Monk Chiang <sh.chiang04@gmail.com>
8058
8059 * config/nds32/nds32.md (trap): New pattern.
8060
8061 2019-02-10 Monk Chiang <sh.chiang04@gmail.com>
8062
8063 * config/nds32/nds32.c (nds32_dwarf_register_span): Refine register
8064 dwarf span.
8065
8066 2019-02-10 Chung-Ju Wu <jasonwucj@gmail.com>
8067
8068 * config/nds32/nds32-md-auxiliary.c (nds32_spilt_doubleword): Support
8069 to split POST_INC.
8070
8071 2019-02-09 Jan Hubicka <hubicka@ucw.cz>
8072
8073 * ipa-visibility.c (localize_node): Also do not localize
8074 LDPR_PREVAILING_DEF_IRONLY_EXP.
8075
8076 2019-02-09 Jan Hubicka <hubicka@ucw.cz>
8077
8078 PR lto/87957
8079 * tree.c (fld_simplified_type_name): Use DECL_ASSEMBLER_NAME_SET_P
8080 instead of type_with_linkage.
8081
8082 2019-02-09 Jan Hubicka <hubicka@ucw.cz>
8083
8084 PR ipa/88755
8085 * params.def (uninlined-function-insns, uninlined-function-time,
8086 uninlined-thunk-insns, uninlined-thunk-time): Add artificial upper
8087 bound so we don't get overflows.
8088
8089 2019-02-09 Aaron Sawdey <acsawdey@linux.ibm.com>
8090
8091 * config/rs6000/rs6000-string.c (expand_compare_loop,
8092 expand_block_compare): Insert REG_BR_PROB notes in inline expansion of
8093 memcmp/strncmp.
8094
8095 2019-02-09 Jakub Jelinek <jakub@redhat.com>
8096
8097 PR middle-end/89246
8098 * config/i386/i386.c (ix86_simd_clone_compute_vecsize_and_simdlen):
8099 If !node->definition and TYPE_ARG_TYPES is non-NULL, use
8100 TYPE_ARG_TYPES instead of DECL_ARGUMENTS.
8101
8102 2019-02-09 Alan Modra <amodra@gmail.com>
8103
8104 PR target/88343
8105 * config/rs6000/rs6000.c (save_reg_p): Correct calls_eh_return
8106 case. Match logic in rs6000_emit_prologue emitting pic_offset_table
8107 setup.
8108
8109 2019-02-08 Vladimir Makarov <vmakarov@redhat.com>
8110
8111 PR middle-end/88560
8112 * lra-constraints.c (process_alt_operands): Don't increase reject
8113 for memory when offset memory is required.
8114
8115 2019-02-08 Robin Dapp <rdapp@linux.ibm.com>
8116
8117 * config/s390/vector.md: Implement vector copysign.
8118
8119 2019-02-08 H.J. Lu <hongjiu.lu@intel.com>
8120
8121 * expr.c (expand_constructor): Correct indentations.
8122
8123 2019-02-08 Richard Biener <rguenther@suse.de>
8124
8125 PR tree-optimization/89247
8126 * tree-if-conv.c: Include tree-cfgcleanup.h.
8127 (version_loop_for_if_conversion): Record LOOP_VECTORIZED call.
8128 (tree_if_conversion): Pass through predicate vector.
8129 (pass_if_conversion::execute): Do CFG cleanup and SSA update
8130 inline, see if any if-converted loops we refrece in
8131 LOOP_VECTORIZED calls vanished and fixup.
8132 * tree-if-conv.h (tree_if_conversion): Adjust prototype.
8133
8134 2019-02-08 Ilya Leoshkevich <iii@linux.ibm.com>
8135
8136 * config/s390/constraints.md (jdd): New constraint.
8137
8138 2019-02-08 H.J. Lu <hongjiu.lu@intel.com>
8139
8140 PR target/89229
8141 * config/i386/i386.md (*movoi_internal_avx): Set mode to XI for
8142 upper 16 vector registers without TARGET_AVX512VL.
8143 (*movti_internal): Likewise.
8144
8145 2019-02-08 Jakub Jelinek <jakub@redhat.com>
8146
8147 PR rtl-optimization/89234
8148 * except.c (copy_reg_eh_region_note_forward): Return if note_or_insn
8149 is a NOTE, CODE_LABEL etc. - rtx_insn * other than INSN_P.
8150 (copy_reg_eh_region_note_backward): Likewise.
8151
8152 2019-02-08 Richard Biener <rguenther@suse.de>
8153
8154 PR middle-end/89223
8155 * tree-data-ref.c (initialize_matrix_A): Fail if constant
8156 doesn't fit in HWI.
8157 (analyze_subscript_affine_affine): Handle failure from
8158 initialize_matrix_A.
8159
8160 2019-02-08 Jakub Jelinek <jakub@redhat.com>
8161
8162 * cfganal.c (pre_and_rev_post_order_compute_fn): Use fn instead of
8163 cfun everywhere.
8164
8165 2019-02-07 David Malcolm <dmalcolm@redhat.com>
8166
8167 PR tree-optimization/86637
8168 PR tree-optimization/89235
8169 * tree-vect-loop.c (optimize_mask_stores): Add an
8170 auto_purge_vect_location sentinel to ensure that vect_location is
8171 purged on exit.
8172 * tree-vectorizer.c
8173 (auto_purge_vect_location::~auto_purge_vect_location): New dtor.
8174 (try_vectorize_loop_1): Add an auto_purge_vect_location sentinel
8175 to ensure that vect_location is purged on exit.
8176 (pass_slp_vectorize::execute): Likewise, replacing the manual
8177 reset.
8178 * tree-vectorizer.h (class auto_purge_vect_location): New class.
8179
8180 2019-02-07 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
8181
8182 * config/aarch64/iterators.md (max_opp): New code_attr.
8183 (USMAX): New code iterator.
8184 * config/aarch64/predicates.md (aarch64_smin): New predicate.
8185 (aarch64_smax): Likewise.
8186 * config/aarch64/aarch64-simd.md (abd<mode>_3): Rename to...
8187 (*aarch64_<su>abd<mode>_3): ... Change RTL representation to
8188 MINUS (MAX MIN).
8189
8190 2019-02-07 H.J. Lu <hongjiu.lu@intel.com>
8191
8192 PR target/89229
8193 * config/i386/i386.md (*movoi_internal_avx): Set mode to OI
8194 for TARGET_AVX512VL.
8195 (*movti_internal): Set mode to TI for TARGET_AVX512VL.
8196
8197 2019-02-07 Andreas Krebbel <krebbel@linux.ibm.com>
8198
8199 * config/s390/s390-builtin-types.def: Add new types.
8200 * config/s390/s390-builtins.def: (s390_vec_xl, s390_vec_xld2)
8201 (s390_vec_xlw4): Make the memory operand into a const pointer.
8202 (s390_vec_xld2, s390_vec_xlw4): Add a variant for single precision
8203 float.
8204 * config/s390/s390-c.c (s390_expand_overloaded_builtin): Generate
8205 a new vector type with the alignment of the scalar memory operand.
8206
8207 2019-02-07 Matthew Malcomson <matthew.malcomson@arm.com>
8208 Jakub Jelinek <jakub@redhat.com>
8209
8210 PR bootstrap/88714
8211 * config/arm/arm-protos.h (valid_operands_ldrd_strd,
8212 arm_count_ldrdstrd_insns): New declarations.
8213 * config/arm/arm.c (mem_ok_for_ldrd_strd): Remove broken handling of
8214 MINUS.
8215 (valid_operands_ldrd_strd): New function.
8216 (arm_count_ldrdstrd_insns): New function.
8217 * config/arm/ldrdstrd.md: Change peepholes to generate PARALLEL SImode
8218 sets instead of single DImode set and define new insns to match this.
8219
8220 2019-02-07 Tamar Christina <tamar.christina@arm.com>
8221
8222 * config/aarch64/aarch64-builtins.c (aarch64_fcmla_lane_builtin_data):
8223 Make it a C initializer.
8224
8225 2019-02-07 Tamar Christina <tamar.christina@arm.com>
8226
8227 PR/target 88850
8228 * config/arm/neon.md (*neon_mov<mode>): Add r -> r case.
8229
8230 2019-02-07 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
8231
8232 * config/arm/neon.md (neon_<sup>dot<vsi2qi>):
8233 Use neon_dot<q> for type.
8234 (neon_<sup>dot_lane<vsi2qi>): Likewise.
8235
8236 2019-02-07 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
8237
8238 * config/aarch64/aarch64-simd.md (aarch64_<sur>dot<vsi2qi>):
8239 Use neon_dot<q> for type.
8240 (aarch64_<sur>dot_lane<vsi2qi>): Likewise.
8241 (aarch64_<sur>dot_laneq<vsi2qi>): Likewise.
8242
8243 2019-02-06 Vladimir Makarov <vmakarov@redhat.com>
8244
8245 PR rtl-optimization/89225
8246 * lra-constaints.c (simplify_operand_subreg): Add subreg mode
8247 sizes check.
8248
8249 2019-02-06 Eric Botcazou <ebotcazou@adacore.com>
8250
8251 * config/i386/i386.c (ix86_expand_prologue): Emit a memory blockage
8252 after restoring registers saved to allocate the frame on Windows.
8253
8254 2019-02-06 Richard Biener <rguenther@suse.de>
8255
8256 PR tree-optimization/89182
8257 * graphite.h (cached_scalar_evolution_in_region): Declare.
8258 * graphite.c (struct seir_cache_key): New.
8259 (struct sese_scev_hash): Likewise.
8260 (seir_cache): New global.
8261 (cached_scalar_evolution_in_region): New function.
8262 (graphite_transform_loops): Allocate and release seir_cache.
8263 * graphite-isl-ast-to-gimple.c (get_rename_from_scev): Use
8264 cached_scalar_evolution_in_region.
8265 * graphite-scop-detection.c (scop_detection::can_represent_loop):
8266 Simplify.
8267 (scop_detection::graphite_can_represent_expr: Use
8268 cached_scalar_evolution_in_region.
8269 (scop_detection::stmt_simple_for_scop_p): Likewise.
8270 (find_params_in_bb): Likewise.
8271 (gather_bbs::before_dom_children): Likewise.
8272 * graphite-sese-to-poly.c (create_pw_aff_from_tree): Likewise.
8273 (add_loop_constraints): Likewise.
8274
8275 2019-02-06 Jakub Jelinek <jakub@redhat.com>
8276
8277 PR middle-end/89210
8278 * fold-const-call.c (fold_const_vec_convert): Pass true as last
8279 operand to new_unary_operation only if both element types are integral
8280 and it isn't a widening conversion. Return NULL_TREE if
8281 new_unary_operation failed.
8282
8283 2019-02-05 Andreas Krebbel <krebbel@linux.ibm.com>
8284
8285 PR target/88856
8286 * config/s390/s390.md: Remove load and test FP splitter.
8287
8288 2019-02-05 Aaron Sawdey <acsawdey@linux.ibm.com>
8289
8290 PR target/89112
8291 * config/rs6000/rs6000-string.c (do_ifelse, expand_cmp_vec_sequence,
8292 expand_compare_loop, expand_block_compare_gpr,
8293 expand_strncmp_align_check, expand_strncmp_gpr_sequence): Insert
8294 REG_BR_PROB notes in inline expansion of memcmp/strncmp. Add
8295 #include "profile-count.h" and "predict.h" for types and functions
8296 needed to work with REG_BR_PROB notes.
8297
8298 2019-02-05 Aaron Sawdey <acsawdey@linux.ibm.com>
8299
8300 PR target/89112
8301 * config/rs6000/rs6000.md (<bd>tf_<mode>): Generate a local label
8302 for the long branch case.
8303
8304 2019-02-05 Jakub Jelinek <jakub@redhat.com>
8305
8306 PR target/89188
8307 * dce.c (delete_unmarked_insns): Don't remove no-op moves if they
8308 can throw, non-call exceptions are enabled and we can't delete
8309 dead exceptions or alter cfg. Set must_clean if
8310 delete_insn_and_edges returns true, don't set it blindly for calls.
8311 Assert that delete_unreachable_blocks is called only if can_alter_cfg.
8312
8313 PR rtl-optimization/89195
8314 * combine.c (make_extraction): For MEMs, don't extract bytes outside
8315 of the original MEM.
8316
8317 2019-02-05 Martin Liska <mliska@suse.cz>
8318
8319 PR gcov-profile/89000
8320 * gcov.c (function_summary): Remove argument.
8321 (file_summary): New function.
8322 (print_usage): Replace tabs with spaces.
8323 (generate_results): Use new function file_summary.
8324
8325 2019-02-05 Jakub Jelinek <jakub@redhat.com>
8326
8327 PR target/89186
8328 * optabs.c (prepare_cmp_insn): Pass x and y to
8329 emit_block_comp_via_libcall rather than XEXP (x, 0) and XEXP (y, 0).
8330
8331 2019-02-05 Richard Biener <rguenther@suse.de>
8332
8333 PR middle-end/89150
8334 * bitmap.h (struct bitmap_obstack): Do not mark GTY.
8335 (struct bitmap_element): Drop chain_prev so we properly recurse on
8336 the prev member, supporting tree views.
8337 (struct bitmap_head): GTY skip the obstack member.
8338
8339 2019-02-04 Alexander Monakov <amonakov@ispras.ru>
8340
8341 PR c/88698
8342 * doc/extend.texi (Vector Extensions): Add an example of using vector
8343 types together with x86 intrinsics.
8344
8345 2019-02-04 Alan Modra <amodra@gmail.com>
8346
8347 * config/rs6000/rs6000.c (rs6000_indirect_call_template_1): Increase
8348 str[] size to 160, and comment.
8349
8350 2019-02-04 Alan Modra <amodra@gmail.com>
8351
8352 * config/rs6000/rs6000.c (rs6000_indirect_call_template_1),
8353 (rs6000_pltseq_template): Guard output of TLS markers with
8354 TARGET_TLS_MARKERS.
8355 (rs6000_longcall_ref, rs6000_call_aix, rs6000_call_sysv),
8356 (rs6000_sibcall_sysv): Ignore TARGET_TLS_MARKERS when deciding
8357 to use inline PLT sequences.
8358 * config/rs6000/rs6000.md (pltseq_tocsave_<mode>),
8359 (pltseq_plt16_ha_<mode>, pltseq_plt16_lo_<mode>),
8360 (pltseq_mtctr_<mode>): Don't test TARGET_TLS_MARKERS in predicate.
8361
8362 2019-02-04 Martin Liska <mliska@suse.cz>
8363
8364 PR ipa/88985
8365 * ipa-fnsummary.c (estimate_edge_devirt_benefit): Bail
8366 out when ipa_fn_summaries does not contain entry for callee.
8367
8368 2019-02-04 Eric Botcazou <ebotcazou@adacore.com>
8369
8370 * config/sparc/sparc.h: Remove superfluous blank lines.
8371 * config/sparc/sparc.c (global_offset_table_rtx): Rename into...
8372 (got_register_rtx): ...this.
8373 (sparc_got): Adjust to above renaming.
8374 (sparc_tls_got): Likewise.
8375 (sparc_delegitimize_address): Likewise.
8376 (sparc_output_mi_thunk): Likewise.
8377 (sparc_init_pic_reg): Likewise.
8378 (save_local_or_in_reg_p): Fix test on the GOT register.
8379 (USE_HIDDEN_LINKONCE): Move around.
8380 (get_pc_thunk_name): Likewise.
8381 (gen_load_pcrel_sym): Likewise.
8382 (load_got_register): Likewise.
8383
8384 2019-02-04 Kito Cheng <kito.cheng@gmail.com>
8385
8386 * config/nds32/linux.h (GLIBC_DYNAMIC_LINKER): Define the naming rule
8387 of the dynamic linker: "ld-linux-nds32[le|be][f].so.1".
8388
8389 2019-02-04 Chung-Ju Wu <jasonwucj@gmail.com>
8390
8391 * config/nds32/nds32.c (nds32_legitimate_address_p): Add TLS model
8392 into consideration.
8393
8394 2019-02-04 Chung-Ju Wu <jasonwucj@gmail.com>
8395
8396 * config.gcc (with_nds32_lib, glibc):
8397 Remove TARGET_DEFAULT_TLSDESC_TRAMPOLINE=0 setting.
8398 * config/nds32/linux.h (TARGET_DEFAULT_TLSDESC_TRAMPOLINE): Delete.
8399 (NDS32_TLSDESC_TRAMPOLINE_SPEC): Delete.
8400
8401 2019-02-03 Uroš Bizjak <ubizjak@gmail.com>
8402
8403 PR target/89071
8404 * config/i386/i386.md (*sqrt<mode>2_sse): Add (v,0) alternative.
8405 Do not prefer (v,v) alternative for non-AVX targets and (m,v)
8406 alternative for speed when TARGET_SSE_PARTIAL_REG_DEPENDENCY is set.
8407 (*rcpsf2_sse): Ditto.
8408 (*rsqrtsf2_sse): Ditto.
8409 (sse4_1_round<mode<2): Ditto.
8410
8411 2019-02-03 Richard Biener <rguenther@suse.de>
8412
8413 PR debug/87295
8414 * dwarf2out.c (copy_ancestor_tree): Register non-stubs as
8415 orig.
8416
8417 2019-02-02 Jakub Jelinek <jakub@redhat.com>
8418
8419 PR middle-end/87887
8420 * config/i386/i386.c (ix86_simd_clone_compute_vecsize_and_simdlen):
8421 Punt with warning on aggregate return or argument types. Ignore
8422 type/mode checking for uniform arguments.
8423
8424 2019-02-01 Segher Boessenkool <segher@kernel.crashing.org>
8425
8426 * combine.c (try_combine): Do not print "Can't combine" messages unless
8427 printing failed combination attempts.
8428
8429 2019-02-01 Martin Jambor <mjambor@suse.cz>
8430
8431 PR hsa/87863
8432 * omp-grid.c (grid_mark_variable_segment): Set assembler name of group
8433 segment and global segment variables before making them static.
8434
8435 2019-02-01 Martin Jambor <mjambor@suse.cz>
8436
8437 * omp-grid.c (grid_target_follows_gridifiable_pattern): Guard two
8438 missed optimization dump with dump_enabled_p.
8439
8440 2019-02-01 Richard Biener <rguenther@suse.de>
8441
8442 PR middle-end/88597
8443 * tree-scalar-evolution.c (analyze_scalar_evolution): Set up
8444 the instantiate cache.
8445 (instantiate_scev_binary): Elide second operand procesing
8446 if equal to the first.
8447 * tree-chrec.c (chrec_contains_symbols): Add visited set.
8448 (chrec_contains_undetermined): Likewise.
8449 (tree_contains_chrecs): Likewise.
8450
8451 2019-02-01 Jan Hubicka <hubicka@ucw.cz>
8452
8453 * parms.def (MAX_INLINE_INSNS_SINGLE): Reduce from 400 to 200.
8454
8455 2019-02-01 Jakub Jelinek <jakub@redhat.com>
8456
8457 PR tree-optimization/89143
8458 * wide-int-range.h (wide_int_range_absu): Declare.
8459 * wide-int-range.cc (wide_int_range_absu): New function.
8460 * tree-vrp.c (extract_range_from_unary_expr): Handle ABSU_EXPR.
8461
8462 PR tree-optimization/88107
8463 * tree-cfg.c (find_outermost_region_in_block): Add ALL argument,
8464 instead of assertion that eh_region_outermost is non-NULL, if it
8465 is NULL, set *ALL to true and return NULL.
8466 (move_sese_region_to_fn): Adjust caller, if all is set, call
8467 duplicate_eh_regions with NULL region.
8468
8469 2019-02-01 Richard Biener <rguenth@suse.de>
8470
8471 PR rtl-optimization/88593
8472 * mode-switching.c (optimize_mode_switching): Free dominators before
8473 calling cleanup_cfg.
8474
8475 2019-02-01 Bin Cheng <bin.cheng@linux.alibaba.com>
8476
8477 PR tree-optimization/88932
8478 * tree-predcom.c (try_combine_chains): Get loop bbs in dom order.
8479
8480 2019-01-31 Jakub Jelinek <jakub@redhat.com>
8481
8482 PR middle-end/89137
8483 * omp-low.c (lower_omp_task_reductions): Drop redundant test to avoid
8484 bogus clang warning.
8485
8486 2019-01-31 Uroš Bizjak <ubizjak@gmail.com>
8487
8488 PR target/89071
8489 * config/i386/i386.md (*extendsfdf2): Split out reg->reg
8490 alternative to avoid partial SSE register stall for TARGET_AVX.
8491 (truncdfsf2): Ditto.
8492 (sse4_1_round<mode>2): Ditto.
8493
8494 2018-01-31 Bill Schmidt <wschmidt@linux.ibm.com>
8495
8496 PR tree-optimization/89008
8497 * gimple-ssa-strength-reduction.c (slsr_process_mul): Don't
8498 process anything of the form X * 0.
8499
8500 2019-01-31 Richard Biener <rguenther@suse.de>
8501
8502 PR tree-optimization/89135
8503 * tree-ssa-phiprop.c (pass_phiprop::execute): Skip blocks
8504 with abnormal preds.
8505
8506 2019-01-31 Jakub Jelinek <jakub@redhat.com>
8507
8508 PR sanitizer/89124
8509 * ipa-inline.c (sanitize_attrs_match_for_inline_p): Allow inlining
8510 always_inline callees into no_sanitize_address callers.
8511
8512 2019-01-31 Richard Biener <rguenther@suse.de>
8513
8514 PR rtl-optimization/89115
8515 * lra.c (lra_rtx_hash): Properly hash CONST_INT values.
8516
8517 2019-01-30 Martin Sebor <msebor@redhat.com>
8518
8519 PR other/89106
8520 * doc/extend.texi (cast to a union): Correct and expand.
8521
8522 2019-01-30 Vladimir Makarov <vmakarov@redhat.com>
8523
8524 PR rtl-optimization/87246
8525 * lra-constraints.c (simplify_operand_subreg): Reload memory
8526 in subreg if the address became invalid.
8527
8528 2019-01-30 Bill Schmidt <wschmidt@linux.ibm.com>
8529
8530 PR target/87064
8531 * config/rs6000/vsx.md (*vsx_reduc_<VEC_reduc_name>_v4sf_scalar):
8532 Disable for little-endian.
8533
8534 2019-01-30 Richard Biener <rguenther@suse.de>
8535
8536 PR rtl-optimization/89115
8537 * opts.c (default_options_optimization): Reduce
8538 PARAM_MAX_DSE_ACTIVE_LOCAL_STORES by a factor of 10 at -O1.
8539 Make PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP reduction relative
8540 to the default.
8541
8542 2019-01-30 Kelvin Nilsen <kelvin@gcc.gnu.org>
8543
8544 * config/rs6000/rs6000-c.c (altivec-resolve_overloaded_builtin):
8545 Change handling of ALTIVEC_BUILTIN_VEC_EXTRACT. Coerce result to
8546 type of vector element when vec_extract is implemented by direct
8547 move.
8548
8549 2019-01-30 Thomas Schwinge <thomas@codesourcery.com>
8550
8551 * doc/invoke.texi (C Language Options): List "-fopenacc-dim".
8552
8553 2019-01-30 Richard Biener <rguenther@suse.de>
8554
8555 PR tree-optimization/89111
8556 * tree-ssa-loop-im.c (gather_mem_refs_stmt): Restrict
8557 canonicalization to appropriately sized access types.
8558
8559 2019-01-30 Jakub Jelinek <jakub@redhat.com>
8560
8561 PR c++/89105
8562 * config/i386/i386.c (ix86_warn_parameter_passing_abi): Don't warn
8563 for arguments to functions that are TU-local and shouldn't be
8564 referenced by assembly.
8565
8566 2019-01-30 Ulrich Drepper <drepper@redhat.com>
8567
8568 * dumpfile.c (opt_info_switch_p_1): Ignore '-' if it appears
8569 after '='.
8570
8571 2019-01-29 Martin Sebor <msebor@redhat.com>
8572
8573 PR c/88956
8574 * gimple-fold.c (fold_array_ctor_reference): Avoid zero-length arrays.
8575
8576 2019-01-29 Jakub Jelinek <jakub@redhat.com>
8577
8578 PR c++/66676
8579 PR ipa/89104
8580 * omp-simd-clone.c (simd_clone_clauses_extract)
8581 <case OMP_CLAUSE_ALIGNED>: Ignore clauses with NULL
8582 OMP_CLAUSE_ALIGNED_ALIGNMENT.
8583
8584 2019-01-29 Vineet Gupta <vgupta@synopsys.com>
8585
8586 * config.gcc: Force .init_array for ARC.
8587
8588 2019-01-29 Richard Biener <rguenther@suse.de>
8589
8590 PR debug/87295
8591 * dwarf2out.c (collect_skeleton_dies): New helper.
8592 (copy_decls_for_unworthy_types): Call it.
8593 (build_abbrev_table): Assert we do not try to replace
8594 DW_AT_signature refs with local refs.
8595
8596 2019-01-28 Jakub Jelinek <jakub@redhat.com>
8597
8598 PR middle-end/89002
8599 * gimplify.c (gimplify_omp_for): When adding OMP_CLAUSE_*_GIMPLE_SEQ
8600 for lastprivate/linear IV, push gimplify context around gimplify_assign
8601 and, if it needed any temporaries, pop it into a gimple bind around the
8602 sequence.
8603
8604 2019-01-28 Bernd Edlinger <bernd.edlinger@hotmail.de>
8605
8606 * common.opt (-Wattribute-alias): Remove "no-" from name.
8607 Make -Wattribute-alias command line option and
8608 #pragma GCC diagnostic ignored "-Wattribute-alias" work again.
8609
8610 2019-01-28 Jakub Jelinek <jakub@redhat.com>
8611
8612 PR target/89073
8613 * doc/invoke.texi (-mclwb, -mprfchw, -mrdpid, -mrdseed, -msgx,
8614 -madx, -mhle, -mavx5124fmaps, -mavx512vnni, -mavx5124vnniw): Document
8615 x86 ISA options.
8616 (bmi2): Add missing @opindex.
8617 * doc/extend.texi (x86 target attribute): Move fma4, lwp, ssse3
8618 options alphabetically. Add missing 3dnow, 3dnowa, adx, avx, avx2,
8619 avx5124fmaps, avx5124vnniw, avx512bitalg, avx512bw, avx512cd,
8620 avx512dq, avx512er, avx512f, avx512ifma, avx512pf, avx512vbmi,
8621 avx512vbmi2, avx512vl, avx512vnni, avx512vpopcntdq, bmi, bmi2,
8622 cldemote, clflushopt, clwb, clzero, crc32, cx16, f16c, fma, fsgsbase,
8623 fxsr, gfni, hle, lzcnt, movbe, movdir64b, movdiri, mwaitx, pconfig,
8624 pku, prefetchwt1, prfchw, ptwrite, rdpid, rdrnd, rdseed, rtm, sahf,
8625 sgx, sha, shstk, tbm, vaes, vpclmulqdq, waitpkg, wbnoinvd, xsave,
8626 xsavec, xsaveopt and xsaves options.
8627
8628 2019-01-28 Richard Biener <rguenther@suse.de>
8629
8630 PR debug/89076
8631 * dwarf2out.c (gen_subprogram_die): Remove leftover from MPX
8632 support removal.
8633
8634 2019-01-28 Richard Biener <rguenther@suse.de>
8635
8636 PR tree-optimization/88739
8637 * tree-cfg.c (verify_types_in_gimple_reference): Verify
8638 BIT_FIELD_REFs only are applied to mode-precision operands
8639 when they are integral.
8640 (verify_gimple_assign_ternary): Likewise for BIT_INSERT_EXPR.
8641 * tree-ssa-sccvn.c (vn_reference_lookup_3): Avoid generating
8642 BIT_FIELD_REFs of non-mode-precision integral operands.
8643
8644 2019-01-27 Jakub Jelinek <jakub@redhat.com>
8645
8646 PR target/87214
8647 * config/i386/sse.md
8648 (<mask_codefor>avx512dq_shuf_<shuffletype>64x2_1<mask_name>,
8649 avx512f_shuf_<shuffletype>64x2_1<mask_name>): Ensure the
8650 first constants in pairs are multiples of 2. Formatting fixes.
8651 (avx512vl_shuf_<shuffletype>32x4_1<mask_name>,
8652 avx512vl_shuf_<shuffletype>32x4_1<mask_name>): Ensure the
8653 first constants in each quadruple are multiples of 4. Formatting fixes.
8654
8655 2019-01-26 Martin Jambor <mjambor@suse.cz>
8656
8657 PR ipa/88933
8658 * tree-inline.c: Include tree-cfgcleanup.h.
8659 (delete_unreachable_blocks_update_callgraph): Move...
8660 * tree-cfgcleanup.c (delete_unreachable_blocks_update_callgraph):
8661 ...here, make externally visible, make second argument bool, adjust
8662 all callers.
8663 * tree-cfgcleanup.c: Include cgraph.h.
8664 * tree-cfgcleanup.h (delete_unreachable_blocks_update_callgraph):
8665 Declare.
8666 * ipa-prop.c: Include tree-cfgcleanup.h.
8667 (ipcp_transform_function): Call
8668 delete_unreachable_blocks_update_callgraph instead of cleaning uo CFG.
8669
8670 2019-01-25 Vladimir Makarov <vmakarov@redhat.com>
8671
8672 PR rtl-optimization/88846
8673 * ira.c (process_set_for_memref_referenced_p): New.
8674 (memref_referenced_p): Add new param. Use
8675 process_set_for_memref_referenced_p. Add new switch cases.
8676 (memref_used_between_p): Pass new arg to memref_referenced_p.
8677
8678 2019-01-25 Richard Earnshaw <rearnsha@arm.com>
8679
8680 PR target/88469
8681 * config/aarch64/aarch64.c (aarch64_function_arg_alignment): Add new
8682 argument ABI_BREAK. Set to true if the calculated alignment has
8683 changed in gcc-9. Check bit-fields for their base type alignment.
8684 (aarch64_layout_arg): Warn if argument passing has changed in gcc-9.
8685 (aarch64_function_arg_boundary): Likewise.
8686 (aarch64_gimplify_va_arg_expr): Likewise.
8687
8688 2019-01-25 Richard Sandiford <richard.sandiford@arm.com>
8689
8690 PR middle-end/89037
8691 * varasm.c (output_constructor_bitfield): Use wi::extract_uhwi
8692 instead of accessing TREE_INT_CST_ELT directly.
8693
8694 2019-01-25 Christophe Lyon <christophe.lyon@linaro.org>
8695
8696 * doc/sourcebuild.texi (Environment attributes): Add fenv and
8697 fenv_exceptions description.
8698
8699 2019-01-25 Wilco Dijkstra <wdijkstr@arm.com>
8700
8701 PR rtl-optimization/87763
8702 * config/aarch64/aarch64.c (aarch64_select_cc_mode):
8703 Allow SUBREG when matching CC_NZmode compare.
8704
8705 2019-01-25 Richard Biener <rguenther@suse.de>
8706
8707 PR tree-optimization/89049
8708 * tree-vect-loop.c (vect_compute_single_scalar_iteration_cost):
8709 Look at the pattern stmt to determine if the stmt is vectorized.
8710
8711 2019-01-25 Richard Sandiford <richard.sandiford@arm.com>
8712
8713 * config/aarch64/aarch64-sve.md (*pred_mov<mode>)
8714 (pred_mov<mode>): Handle all-register forms using both a new
8715 alternative and a split.
8716
8717 2019-01-25 Richard Biener <rguenther@suse.de>
8718
8719 PR tree-optimization/86865
8720 * graphite-scop-detection.c (scop_detection::can_represent_loop):
8721 Reject non-do-while loops.
8722
8723 2019-01-24 Peter Bergner <bergner@linux.ibm.com>
8724
8725 * config/rs6000/altivec.md (build_vector_mask_for_load): Use MEM_P.
8726 * config/rs6000/constraints.md (Q constraint): Use REG_P.
8727 * config/rs6000/darwin.h (PREFERRED_RELOAD_CLASS): Use SYMBOL_REF_P.
8728 * config/rs6000/freebsd64.h (ASM_OUTPUT_SPECIAL_POOL_ENTRY_P): Use
8729 SYMBOL_REF_P, CONST_INT_P and CONST_DOUBLE_P.
8730 * config/rs6000/linux64.h (ASM_OUTPUT_SPECIAL_POOL_ENTRY_P): Likewise.
8731 * config/rs6000/predicates.md (altivec_register_operand, vint_operand,
8732 vsx_register_operand, vsx_reg_sfsubreg_ok, vfloat_operand,
8733 vlogical_operand, gpc_reg_operand, int_reg_operand,
8734 int_reg_operand_not_pseudo): Use SUBREG_P and HARD_REGISTER_P.
8735 (ca_operand, base_reg_operand, htm_spr_reg_operand, cc_reg_operand,
8736 cc_reg_not_cr0_operand, input_operand): Use SUBREG_P.
8737 (save_world_operation, restore_world_operation, lmw_operation,
8738 stmw_operation): Use MEM_P and REG_P.
8739 (tie_operand): Use MEM_P.
8740 (vrsave_operation, crsave_operation): Use REG_P.
8741 (mfcr_operation, mtcrf_operation): Use REG_P and CONST_INT_P.
8742 (fpr_reg_operand): Use SUBREG_P and HARD_REGISTER_NUM_P.
8743 (quad_int_reg_operand): Use HARD_REGISTER_NUM_P.
8744 (call_operand): Use HARD_REGISTER_P.
8745 (indexed_or_indirect_operand, altivec_indexed_or_indirect_operand):
8746 Use CONST_INT_P.
8747 (lwa_operand): Use SUBREG_P, REG_P and CONST_INT_P.
8748 * config/rs6000/rs6000-p8swap.c (insn_is_load_p, insn_is_store_p,
8749 quad_aligned_load_p, replace_swapped_aligned_store,
8750 recombine_lvx_pattern, replace_swapped_aligned_load,
8751 recombine_stvx_pattern): Use MEM_P.
8752 (const_load_sequence_p, adjust_vperm, replace_swapped_load_constant):
8753 Use MEM_P and SYMBOL_REF_P.
8754 (rtx_is_swappable_p): Use REG_P and CONST_INT_P.
8755 (insn_is_swappable_p): Use REG_P and MEM_P.
8756 (insn_is_swap_p, (alignment_mask): Use CONST_INT_P.
8757 * config/rs6000/rs6000-string.c (expand_block_clear, expand_block_move):
8758 Use CONST_INT_P.
8759 * config/rs6000/rs6000.c (rs6000_secondary_reload, rs6000_emit_cmove):
8760 Use CONST_DOUBLE_P.
8761 (rs6000_output_move_128bit): Use CONST_DOUBLE_P, CONST_INT_P and
8762 CONST_WIDE_INT_P.
8763 (rs6000_legitimize_address): Use CONST_DOUBLE_P, CONST_INT_P,
8764 CONST_WIDE_INT_P, REG_P and SYMBOL_REF_P.
8765 (rs6000_emit_move): Use CONST_DOUBLE_P, CONST_INT_P, HARD_REGISTER_P,
8766 HARD_REGISTER_NUM_P, MEM_P, REG_P, SUBREG_P, SYMBOL_REF_P and
8767 reg_or_subregno:
8768 (output_toc): Use CONST_DOUBLE_P, CONST_INT_P and SYMBOL_REF_P.
8769 (easy_altivec_constant, rs6000_legitimate_offset_address_p,
8770 rs6000_mode_dependent_address, rs6000_expand_mtfsf_builtin,
8771 rs6000_expand_set_fpscr_rn_builtin, rs6000_expand_set_fpscr_drn_builtin,
8772 rs6000_expand_unop_builtin, INT_P, rs6000_generate_compare,
8773 rs6000_machopic_legitimize_pic_address, rs6000_split_logical_inner,
8774 rs6000_split_logical_di): Use CONST_INT_P.
8775 (rs6000_legitimize_reload_address): Use CONST_INT_P, HARD_REGISTER_P,
8776 REG_P and SYMBOL_REF_P.
8777 (setup_incoming_varargs, rs6000_rtx_costs): Use CONST_INT_P and MEM_P.
8778 (print_operand): Use CONST_INT_P, MEM_P and REG_P.
8779 (virtual_stack_registers_memory_p, rs6000_legitimate_address_p,
8780 mems_ok_for_quad_peep): Use CONST_INT_P and REG_P.
8781 (rs6000_secondary_reload_memory): Use CONST_INT_P and SUBREG_P.
8782 (small_data_operand, print_operand_address): Use CONST_INT_P and
8783 SYMBOL_REF_P.
8784 (split_stack_arg_pointer_used_p): Use HARD_REGISTER_P.
8785 (rs6000_init_hard_regno_mode_ok, direct_move_p):
8786 Use HARD_REGISTER_NUM_P.
8787 (rs6000_secondary_reload_gpr): Use HARD_REGISTER_NUM_P and MEM_P.
8788 (rs6000_secondary_reload_class): Use HARD_REGISTER_NUM_P, REG_P,
8789 SUBREG_P and SYMBOL_REF_P.
8790 (register_to_reg_type, rs6000_secondary_reload_inner): Use SUBREG_P
8791 and HARD_REGISTER_NUM_P.
8792 (rs6000_adjust_vec_address): Use HARD_REGISTER_NUM_P and
8793 reg_or_subregno.
8794 (rs6000_adjust_cost, find_mem_ref): Use MEM_P.
8795 (macho_lo_sum_memory_operand, rs6000_eliminate_indexed_memrefs): Use
8796 MEM_P and REG_P.
8797 (legitimate_indirect_address_p, legitimate_lo_sum_address_p,
8798 registers_ok_for_quad_peep, rs6000_output_function_epilogue,
8799 find_addr_reg): Use REG_P.
8800 (altivec_expand_vec_perm_const): Use REG_P and SUBREG_P.
8801 (rs6000_emit_le_vsx_move): Use SUBREG_P.
8802 (offsettable_ok_by_alignment, constant_pool_expr_p,
8803 legitimate_small_data_p, rs6000_output_dwarf_dtprel,
8804 rs6000_delegitimize_address, rs6000_const_not_ok_for_debug_p,
8805 rs6000_cannot_force_const_mem, rs6000_output_addr_const_extra,
8806 rs6000_assemble_integer, create_TOC_reference,
8807 rs6000_emit_allocate_stack, rs6000_xcoff_encode_section_info,
8808 rs6000_call_aix, rs6000_call_aix): Use SYMBOL_REF_P.
8809 (rs6000_split_vec_extract_var): Use reg_or_subregno.
8810 * config/rs6000/rtems.h (ASM_OUTPUT_SPECIAL_POOL_ENTRY_P): Use
8811 CONST_DOUBLE_P, CONST_INT_P and SYMBOL_REF_P.
8812 * config/rs6000/sysv4.h (ASM_OUTPUT_SPECIAL_POOL_ENTRY_P): Likewise.
8813 * config/rs6000/xcoff.h (ASM_OUTPUT_SPECIAL_POOL_ENTRY_P): Likewise.
8814 * config/rs6000/rs6000.h (RS6000_SYMBOL_REF_TLS_P): Use SYMBOL_REF_P.
8815 (REGNO_OK_FOR_INDEX_P, REGNO_OK_FOR_BASE_P): Use HARD_REGISTER_NUM_P.
8816 (INT_REG_OK_FOR_INDEX_P, INT_REG_OK_FOR_BASE_P): Use HARD_REGISTER_P.
8817 (CONSTANT_ADDRESS_P): Use CONST_INT_P and SYMBOL_REF_P.
8818 * config/rs6000/rs6000.md (define_expands strlensi, mod<mode>3
8819 and cbranch<mode>4): Use CONST_INT_P.
8820 (multiple define_splits): Use REG_P and SUBREG_P.
8821 (define_expands call, call_value): Use MEM_P.
8822 (define_expands sibcall, sibcall_value): Use CONST_INT_P and MEM_P.
8823 (define insn *mtcrfsi): Use CONST_INT_P and REG_P.
8824 * config/rs6000/vsx.md (*vsx_le_perm_load_<mode>,
8825 *vsx_le_perm_load_v8hi, *vsx_le_perm_load_v16qi): Use HARD_REGISTER_P
8826 and HARD_REGISTER_NUM_P.
8827 (multiple define_splits): Use HARD_REGISTER_NUM_P.
8828
8829 2019-01-24 Uroš Bizjak <ubizjak@gmail.com>
8830
8831 PR rtl-optimization/88948
8832 * rtl.h (prepare_copy_insn): New prototype.
8833 * gcse.c (prepare_copy_insn): New function, split out from
8834 process_insert_insn.
8835 (process_insert_insn): Use prepare_copy_insn.
8836 * store-motion.c (replace_store_insn): Use prepare_copy_insn
8837 instead of gen_move_insn.
8838
8839 2019-01-24 Jakub Jelinek <jakub@redhat.com>
8840
8841 PR debug/89006
8842 * config/i386/i386.c (ix86_pic_register_p): Return true for
8843 UNSPEC_SET_GOT too.
8844
8845 PR tree-optimization/88964
8846 * gimple-loop-interchange.cc (loop_cand::analyze_induction_var): Also
8847 punt if HONOR_SNANS (chrec).
8848
8849 PR middle-end/89015
8850 * tree-nested.c (convert_nonlocal_reference_stmt,
8851 convert_local_reference_stmt, convert_tramp_reference_stmt,
8852 convert_gimple_call) <case GIMPLE_OMP_TEAMS>: Treat
8853 gimple_omp_teams_host teams stmts like GIMPLE_OMP_PARALLEL
8854 or GIMPLE_OMP_TASK.
8855
8856 PR tree-optimization/89027
8857 * tree-inline.c (add_clobbers_to_eh_landing_pad): Don't add clobbers
8858 for "omp simd array" variables.
8859
8860 2019-01-24 Richard Earnshaw <rearnsha@arm.com>
8861
8862 PR target/88469
8863 * profile-count.h (profile_count): On ARM systems using GCC 6/7/8
8864 force the alignment of m_val.
8865
8866 2019-01-24 Richard Biener <rguenther@suse.de>
8867
8868 PR lto/87187
8869 * tree-streamer-out.c (write_ts_decl_common_tree_pointers):
8870 When in "legacy" debug mode make sure to reset self-origins.
8871
8872 2019-01-24 Martin Liska <mliska@suse.cz>
8873
8874 PR gcov-profile/88994
8875 * gcov-io.c (mangle_path): Do not allocate a bigger buffer,
8876 result will be always smaller or equal to the original.
8877 * gcov.c (mangle_name): Fix else branch where we should
8878 also copy to PTR and shift the pointer.
8879
8880 2019-01-24 Xiong Hu Luo <luoxhu@linux.vnet.ibm.com>
8881
8882 * tree-ssa-dom.c (test_for_singularity): Fix a comment typo.
8883 * vr-values.c (find_case_label_ranges): Fix a comment typo.
8884
8885 2019-01-23 Xuepeng Guo <xuepeng.guo@intel.com>
8886
8887 * common/config/i386/i386-common.c
8888 (OPTION_MASK_ISA_ENQCMD_SET,
8889 OPTION_MASK_ISA_ENQCMD_UNSET): New macros.
8890 (ix86_handle_option): Handle -menqcmd.
8891 * config.gcc (enqcmdintrin.h): New header file.
8892 * config/i386/cpuid.h (bit_ENQCMD): New bit.
8893 * config/i386/driver-i386.c (host_detect_local_cpu): Handle
8894 -menqcmd.
8895 * config/i386/i386-builtin-types.def ((INT, PVOID, PCVOID)): New
8896 function type.
8897 * config/i386/i386-builtin.def (__builtin_ia32_enqcmd,
8898 __builtin_ia32_enqcmds): New builtins.
8899 * config/i386/i386-c.c (__ENQCMD__): New macro.
8900 * config/i386/i386-option.c (ix86_target_string): Add
8901 -menqcmd.
8902 (ix86_valid_target_attribute_inner_p): Likewise.
8903 * config/i386/i386-expand.c
8904 (ix86_expand_builtin): Expand IX86_BUILTIN_ENQCMD and
8905 IX86_BUILTIN_ENQCMDS.
8906 * config/i386/i386.h (TARGET_ENQCMD): New.
8907 * config/i386/i386.md (UNSPECV_ENQCMD, UNSPECV_ENQCMDS): New.
8908 (@enqcmd<enqcmd_sfx>_<mode>): New insn pattern.
8909 (movdir64b_<mode>): Parameterize to enable share expansion code
8910 with ENQCMD in function ix86_expand_builtin.
8911 * config/i386/i386.opt: Add -menqcmd.
8912 * config/i386/immintrin.h: Include enqcmdintrin.h.
8913 * config/i386/enqcmdintrin.h: New intrinsic file.
8914 * doc/invoke.texi: Add -menqcmd.
8915
8916 2019-01-23 Bin Cheng <bin.cheng@arm.com>
8917 Steve Ellcey <sellcey@marvell.com>
8918
8919 PR target/85711
8920 * recog.c (address_operand): Return false on wrong mode for address.
8921 (constrain_operands): Check for mode with 'p' constraint.
8922
8923 2019-01-23 Uroš Bizjak <ubizjak@gmail.com>
8924
8925 PR target/88998
8926 * config/i386/sse.md (sse2_cvtpi2pd): Add SSE alternatives.
8927 Disparage MMX alternative.
8928 (sse2_cvtpd2pi): Ditto.
8929 (sse2_cvttpd2pi): Ditto.
8930
8931 2019-01-23 David Malcolm <dmalcolm@redhat.com>
8932
8933 PR driver/89014
8934 * config/aarch64/driver-aarch64.c (host_detect_local_cpu): Fix
8935 use-after-free of the result of
8936 aarch64_get_extension_string_for_isa_flags.
8937
8938 2019-01-23 Jakub Jelinek <jakub@redhat.com>
8939
8940 PR c/44715
8941 * doc/extend.texi: Document break and continue behavior in
8942 statement expressions.
8943
8944 2019-01-23 Richard Biener <rguenther@suse.de>
8945
8946 PR tree-optimization/89008
8947 * tree-ssa-reassoc.c (eliminate_using_constants): For * 0 do
8948 not leave another stray operand.
8949
8950 2019-01-23 Jakub Jelinek <jakub@redhat.com>
8951
8952 * BASE-VER: Bump to 9.0.1.
8953
8954 2019-01-23 Eric Botcazou <ebotcazou@adacore.com>
8955
8956 * cgraphunit.c (cgraph_node::expand_thunk): When expanding a GIMPLE
8957 thunk that returns by reference, use the type of the return object
8958 of the thunk instead of that of the alias to build the dereference.
8959
8960 2019-01-23 Vineet Gupta <vgupta@synopsys.com>
8961
8962 * config/arc/atomic.md: Add operand to DMB instruction.
8963
8964 2019-01-23 Jakub Jelinek <jakub@redhat.com>
8965
8966 PR tree-optimization/88964
8967 * gimple-loop-interchange.cc (loop_cand::analyze_induction_var): Use
8968 build_zero_cst instead of build_int_cst. Return false for loop
8969 invariants which honor signed zeros.
8970
8971 2019-01-22 Segher Boessenkool <segher@kernel.crashing.org>
8972
8973 * doc/invoke.texi (-fsplit-paths): This is enabled by default at -O3.
8974
8975 2019-01-22 Jakub Jelinek <jakub@redhat.com>
8976
8977 PR target/88965
8978 * config/rs6000/rs6000.c: Include tree-vrp.h and tree-ssanames.h.
8979 (rs6000_gimple_fold_builtin): If MEM_REF address doesn't satisfy
8980 is_gimple_mem_ref_addr predicate, force it into a SSA_NAME first.
8981
8982 PR middle-end/88968
8983 * gimplify.c (gimplify_omp_atomic): Handle bitfield atomics with
8984 non-integral DECL_BIT_FIELD_REPRESENTATIVEs.
8985
8986 PR target/87064
8987 * config/rs6000/vsx.md (*vsx_reduc_<VEC_reduc_name>_v2df_scalar):
8988 Disable for little endian.
8989
8990 2019-01-22 Richard Earnshaw <rearnsha@arm.com>
8991
8992 PR target/88469
8993 * config/arm/arm.c (arm_needs_double_word_align): Check
8994 DECL_BIT_FIELD_TYPE.
8995
8996 2019-01-22 Hongtao Liu <hongtao.liu@intel.com>
8997 H.J. Lu <hongjiu.lu@intel.com>
8998
8999 PR target/88909
9000 * config/i386/i386-builtin.def: Add mask2 to all builtin
9001 initializations. Merge ARGS2 and SPECIAL_ARGS2 into ARGS and
9002 SPECIAL_ARGS.
9003 * config/i386/i386.c (BDESC): Add mask2 to the definition.
9004 (BDESC_FIRST): Likewise.
9005 (define_builtin): Add an argument for mask2. Updated to handle
9006 both ix86_isa_flags and ix86_isa_flags2.
9007 (define_builtin_const): Likewise.
9008 (define_builtin_pure): Likewise.
9009 (define_builtin2): Deleted.
9010 (define_builtin_const2): Likewise.
9011 (builtin_description): Add a member, mask2.
9012 (bdesc_*): Add mask2 to builtin initializations.
9013 (ix86_init_mmx_sse_builtins): Update calls to def_builtin,
9014 def_builtin_const and def_builtin_pure. Remove SPECIAL_ARGS2
9015 support.
9016 (ix86_get_builtin_func_type): Remove SPECIAL_ARGS2 support.
9017
9018 2019-01-22 H.J. Lu <hongjiu.lu@intel.com>
9019
9020 PR target/88954
9021 * config/i386/i386.c (ix86_force_load_from_GOT_p): Also check
9022 noplt attribute.
9023
9024 2019-01-22 Richard Earnshaw <rearnsha@arm.com>
9025
9026 PR target/88469
9027 * config/arm/arm.c (arm_needs_doubleword_align): Return 2 if a record's
9028 alignment is dominated by a bitfield with 64-bit aligned base type.
9029 (arm_function_arg): Emit a warning if the alignment has changed since
9030 earlier GCC releases.
9031 (arm_function_arg_boundary): Likewise.
9032 (arm_setup_incoming_varargs): Likewise.
9033
9034 2019-01-22 Richard Biener <rguenther@suse.de>
9035
9036 PR tree-optimization/88862
9037 * graphite-scop-detection.c
9038 (scop_detection::graphite_can_represent_scev): Reject ADDR_EXPR.
9039
9040 2019-01-22 Andrew Stubbs <ams@codesourcery.com>
9041
9042 * doc/extend.tex (AMD GCN Function Attributes): New section.
9043 * doc/install.texi (amdgcn-unknown-amdhsa): New instructions.
9044 * doc/invoke.texi (AMD GCN Options): New section.
9045 * doc/md.texi (Constraints for Particular Machines): Add AMD GCN.
9046
9047 2019-01-22 Eric Botcazou <ebotcazou@adacore.com>
9048
9049 * config/sparc/sparc.c (parc_delegitimize_address): Recognize the GOT
9050 register and decoded HIGH/LO_SUM combinations for labels in PIC mode.
9051
9052 2019-01-22 Jakub Jelinek <jakub@redhat.com>
9053
9054 PR tree-optimization/88044
9055 * tree-ssa-loop-niter.c (number_of_iterations_cond): If condition
9056 is false in the first iteration, but !every_iteration, return false
9057 instead of true with niter->niter zero.
9058
9059 PR rtl-optimization/88904
9060 * cfgcleanup.c (thread_jump): Verify cond2 doesn't mention
9061 any nonequal registers before processing BB_END (b).
9062
9063 PR target/88905
9064 * optabs.c (add_equal_note): Add op0_mode argument, use it instead of
9065 GET_MODE (op0).
9066 (expand_binop_directly, expand_doubleword_clz,
9067 expand_doubleword_popcount, expand_ctz, expand_ffs,
9068 expand_unop_direct, maybe_emit_unop_insn): Adjust callers.
9069
9070 PR rtl-optimization/49429
9071 PR target/49454
9072 PR rtl-optimization/86334
9073 PR target/88906
9074 * expr.c (emit_block_move_hints): Move marking of MEM_EXPRs
9075 addressable from here...
9076 (emit_block_op_via_libcall): ... to here.
9077
9078 2019-01-22 Richard Biener <rguenther@suse.de>
9079
9080 * tree-vect-loop.c (vect_analyze_loop_operations): Use
9081 auto_vec for cost vector to fix memleak.
9082 (vectorize_fold_left_reduction): Properly gather SLP defs.
9083 (vectorizable_comparison): Do not swap operands to properly
9084 gather SLP defs.
9085
9086 2019-01-22 Alan Modra <amodra@gmail.com>
9087
9088 PR target/88614
9089 * config/rs6000/predicates.md (unspec_tls): Ensure GOT reg
9090 stays a reg. Allow a const_int.
9091 * config/rs6000/rs6000-protos.h (rs6000_output_tlsargs): Declare.
9092 * config/rs6000/rs6000.h (IS_V4_FP_ARGS): Define.
9093 (IS_NOMARK_TLSGETADDR): Define.
9094 * config/rs6000/rs6000.c (edit_tls_call_insn): Delete.
9095 (rs6000_output_tlsargs): New function.
9096 (rs6000_legitimize_tls_address): Don't say a !TARGET_TLS_MARKERS
9097 __tls_get_addr call takes an arg.
9098 (rs6000_call_sysv): Generate sysv4 secure plt call pattern here..
9099 * config/rs6000/rs6000.md (call_nonlocal_sysv): ..rather than here,
9100 delete split..
9101 (call_value_nonlocal_sysv): ..or here, delete split.
9102 (tls_gdld_nomark): Delete.
9103 (call_value_indirect_nonlocal_sysv): Use unspec_tls as operand2
9104 predicate. Call rs6000_output_tlsargs. Adjust length to suit.
9105 (call_value_nonlocal_sysv): Likewise.
9106 (call_value_nonlocal_sysv_secure): Likewise.
9107 (call_value_nonlocal_aix): Likewise.
9108 (call_value_indirect_aix): Likewise.
9109 (call_value_indirect_elfv2): Likewise.
9110 (call_value_local32, call_value_local64): Disable for no-mark tls.
9111 (call_value_local_aix): Likewise.
9112
9113 2019-01-21 Uroš Bizjak <ubizjak@gmail.com>
9114
9115 PR target/88938
9116 * config/i386/i386.c (ix86_expand_builtin) [case IX86_BUILTIN_BEXTRI32,
9117 case IX86_BUILTIN_BEXTRI64]: Sanitize operands.
9118
9119 2019-01-21 Michael Ploujnikov <michael.ploujnikov@oracle.com>
9120
9121 * hash-map-tests.c (test_map_of_strings_to_int): Show how to use
9122 string contents as hash_map keys.
9123
9124 2019-01-21 Bernd Edlinger <bernd.edlinger@hotmail.de>
9125
9126 PR c/88928
9127 * c-warn.c (check_alignment_of_packed_member): Add a boolean parameter
9128 for rvalue context. Handle rvalues correctly. Use min_align_of_type
9129 instead of TYPE_ALIGN.
9130 (check_address_or_pointer_of_packed_member): Handle rvalues coorrectly.
9131 Use min_align_of_type instead of TYPE_ALIGN_UNIT. Check for NULL
9132 pointer from TYPE_STUB_DECL.
9133
9134 2019-01-21 Richard Biener <rguenther@suse.de>
9135
9136 PR tree-optimization/88934
9137 * tree-vect-slp.c (vect_mask_constant_operand_p): Always look
9138 at the possibly non-constant operand.
9139 (vect_get_constant_vectors): Adjust.
9140
9141 2019-01-21 H.J. Lu <hongjiu.lu@intel.com>
9142
9143 PR target/71659
9144 * config/i386/adxintrin.h: Just check _IMMINTRIN_H_INCLUDED.
9145 * config/i386/clflushoptintrin.h: Check _IMMINTRIN_H_INCLUDED
9146 instead of _X86INTRIN_H_INCLUDED.
9147 * onfig/i386/clwbintrin.h: Likewise.
9148 * config/i386/pkuintrin.h: Likewise.
9149 * config/i386/prfchwintrin.h: Likewise.
9150 * config/i386/rdseedintrin.h: Likewise.
9151 * config/i386/wbnoinvdintrin.h: Likewise.
9152 * config/i386/xsavecintrin.h: Likewise.
9153 * config/i386/xsavesintrin.h: Likewise.
9154 * config/i386/fxsrintrin.h: Enable _IMMINTRIN_H_INCLUDED check.
9155 * config/i386/xsaveintrin.h: Likewise.
9156 * config/i386/xsaveoptintrin.h: Likewise.
9157 * config/i386/x86intrin.h: Move "#include" <rdseedintrin.h>,
9158 <prfchwintrin.h>, <fxsrintrin.h>, <xsaveintrin.h>,
9159 <xsaveoptintrin.h>, <adxintrin.h>, <clwbintrin.h>,
9160 <clflushoptintrin.h>, <xsavesintrin.h>, <xsavecintrin.h>,
9161 <wbnoinvdintrin.h> and <pkuintrin.h> to ...
9162 * config/i386/immintrin.h: Here.
9163
9164 2019-01-20 Martin Jambor <mjambor@suse.cz>
9165
9166 PR ipa/87615
9167 * ipa-prop.h (struct ipa_func_body_info): Replaced field aa_walked
9168 with aa_walk_budget.
9169 * cgraph.h (ipa_polymorphic_call_context::get_dynamic_type): Add
9170 aa_walk_budget_p parameter.
9171 * ipa-fnsummary.c (unmodified_parm_1): New parameter fbi. Limit AA
9172 walk. Updated all callers.
9173 (unmodified_parm): New parameter fbi, pass it to unmodified_parm_1.
9174 (eliminated_by_inlining_prob): New parameter fbi, pass it on to
9175 unmodified_parm.
9176 (will_be_nonconstant_expr_predicate): New parameter fbi, removed
9177 parameter info. Extract info from fbi. Pass fbi to recursive calls
9178 and to unmodified_parm.
9179 (phi_result_unknown_predicate): New parameter fbi, removed parameter
9180 info, updated call to will_be_nonconstant_expr_predicate.
9181 (param_change_prob): New parameter fbi, limit AA walking.
9182 (analyze_function_body): Initialize aa_walk_budget in fbi. Update
9183 calls to various above functions.
9184 * ipa-polymorphic-call.c (get_dynamic_type): Add aa_walk_budget_p
9185 parameter. Use it to limit AA walking.
9186 * ipa-prop.c (detect_type_change_from_memory_writes): New parameter
9187 fbi, limit AA walk.
9188 (detect_type_change): New parameter fbi, pass it on to
9189 detect_type_change_from_memory_writes.
9190 (detect_type_change_ssa): Likewise.
9191 (aa_overwalked): Removed.
9192 (parm_preserved_before_stmt_p): Assume fbi is never NULL, stream line
9193 accordingly, adjust to the neew AA limiting scheme.
9194 (parm_ref_data_preserved_p): Likewise.
9195 (ipa_compute_jump_functions_for_edge): Adjust call to
9196 get_dynamic_type.
9197 (ipa_analyze_call_uses): Likewise.
9198 (ipa_analyze_virtual_call_uses): Pass fbi to detect_type_change_ssa.
9199 (ipa_analyze_node): Initialize aa_walk_budget.
9200 (ipcp_transform_function): Likewise.
9201 * tree-ssa-sccvn.c (eliminate_dom_walker::eliminate_stmt): Update call
9202 to get_dynamic_type.
9203
9204 2019-01-19 Jakub Jelinek <jakub@redhat.com>
9205
9206 * config/aarch64/aarch64.c (aarch64_stack_protect_guard): Move
9207 outside of #if CHECKING_P code.
9208
9209 2019-01-19 Richard Sandiford <richard.sandiford@arm.com>
9210
9211 * gimple-loop-versioning.cc (loop_versioning::dump_inner_likelihood):
9212 New function, split out from...
9213 (loop_versioning::analyze_stride): ...here.
9214 (loop_versioning::find_per_loop_multiplication): Use gassign.
9215 (loop_versioning::analyze_term_using_scevs): Return a success code.
9216 (loop_versioning::analyze_arbitrary_term): New function.
9217 (loop_versioning::analyze_address_fragment): Use
9218 analyze_arbitrary_term if all else fails.
9219
9220 2019-01-18 Segher Boessenkool <segher@kernel.crashing.org>
9221
9222 PR target/88892
9223 * config/rs6000/rs6000.md (*movsi_from_df): Allow only register
9224 operands.
9225
9226 2019-01-18 Richard Biener <rguenther@suse.de>
9227
9228 PR tree-optimization/88903
9229 * tree-vect-stmts.c (vectorizable_shift): Verify we see all
9230 scalar stmts a SLP shift amount is composed of when detecting
9231 shifts by scalars.
9232
9233 2019-01-18 Richard Earnshaw <rearnsha@arm.com>
9234
9235 PR target/88799
9236 * config/arm/arm-cpus.in (mp): New feature.
9237 (sec): New feature.
9238 (fgroup ARMv7ve): Add mp and sec features.
9239 (arch armv7-a): Add options to allow mp and sec extensions.
9240 (cpu generic-armv7-a): Add options to allow mp and sec extensions.
9241 (cpu cortex-a5, cpu cortex-7, cpu cortex-a9): Add mp and sec
9242 extenstions to the base architecture.
9243 (cpu cortex-a8): Add sec extension to the base architecture.
9244 (cpu marvell-pj4): Add mp and sec extensions to the base architecture.
9245 * config/arm/t-aprofile (MULTILIB_MATCHES): Map all armv7-a arch
9246 variants down to the base v7-a varaint.
9247 * config/arm/t-multilib (v7_a_arch_variants): New variable.
9248 * doc/invoke.texi (ARM Options): Add +mp and +sec to the list
9249 of permitted extensions for -march=armv7-a and for
9250 -mcpu=generic-armv7-a.
9251
9252 2019-01-18 Martin Liska <mliska@suse.cz>
9253
9254 * params.def: Fix comment.
9255 * tree-profile.c (gimple_init_gcov_profiler): Bump function
9256 name.
9257 (gimple_gen_ic_func_profiler): Likewise.
9258
9259 2019-01-18 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
9260
9261 * config/aarch64/aarch64-opts.h (enum stack_protector_guard): New
9262 * config/aarch64/aarch64.c (aarch64_override_options_internal): Handle
9263 and put in error checks for stack protector guard options.
9264 (aarch64_stack_protect_guard): New.
9265 (TARGET_STACK_PROTECT_GUARD): Define.
9266 * config/aarch64/aarch64.md (UNSPEC_SSP_SYSREG): New.
9267 (reg_stack_protect_address<mode>): New.
9268 (stack_protect_set): Adjust for SSP_GLOBAL.
9269 (stack_protect_test): Likewise.
9270 * config/aarch64/aarch64.opt (-mstack-protector-guard-reg): New.
9271 (-mstack-protector-guard): Likewise.
9272 (-mstack-protector-guard-offset): Likewise.
9273
9274 2019-01-18 Jakub Jelinek <jakub@redhat.com>
9275
9276 PR tree-optimization/86214
9277 * tree-inline.h (struct copy_body_data): Add
9278 add_clobbers_to_eh_landing_pads member.
9279 * tree-inline.c (add_clobbers_to_eh_landing_pad): New function.
9280 (copy_edges_for_bb): Call it if EH edge destination is <
9281 id->add_clobbers_to_eh_landing_pads. Fix a comment typo.
9282 (expand_call_inline): Set id->add_clobbers_to_eh_landing_pads
9283 if flag_stack_reuse != SR_NONE and clear it afterwards.
9284
9285 2019-01-18 Christophe Lyon <christophe.lyon@linaro.org>
9286
9287 PR target/85596
9288 * doc/install.texi (with-multilib-list): Document for aarch64.
9289
9290 2019-01-18 Jakub Jelinek <jakub@redhat.com>
9291
9292 PR target/88734
9293 * config/arm/arm_neon.h: Fix #pragma GCC target syntax - replace
9294 (("..."))) with ("...").
9295
9296 2019-01-18 Sebastian Huber <sebastian.huber@embedded-brains.de>
9297
9298 * doc/extend.texi (Built-in Functions for Memory Model Aware
9299 Atomic Operations): Document atomic fetch and nand.
9300
9301 2019-01-18 Martin Liska <mliska@suse.cz>
9302 Richard Biener <rguenther@suse.de>
9303
9304 PR middle-end/88587
9305 * cgraph.h (create_version_clone_with_body): Add new argument
9306 with attributes.
9307 * cgraphclones.c (cgraph_node::create_version_clone): Add
9308 DECL_ATTRIBUTES to a newly created decl. And call
9309 valid_attribute_p so that proper cl_target_optimization_node
9310 is set for the newly created declaration.
9311 * multiple_target.c (create_target_clone): Set DECL_ATTRIBUTES
9312 for declaration.
9313 (expand_target_clones): Do not call valid_attribute_p, it must
9314 be already done.
9315 * tree-inline.c (copy_decl_for_dup_finish): Reset mode for
9316 vector types.
9317
9318 2019-01-17 Jakub Jelinek <jakub@redhat.com>
9319
9320 PR target/88734
9321 * config/aarch64/arm_neon.h: Fix #pragma GCC target syntax - replace
9322 (("..."))) with ("..."). Use arch=armv8.2-a+sha3 instead of
9323 arch=armv8.2-a+crypto for vsha512hq_u64 etc. intrinsics.
9324
9325 2019-01-17 Martin Sebor <msebor@redhat.com>
9326
9327 PR middle-end/88273
9328 * gimple-ssa-warn-restrict.c (builtin_memref::extend_offset_range):
9329 Handle anti-ranges the same as no range at all.
9330
9331 2018-01-17 Steve Ellcey <sellcey@cavium.com>
9332
9333 * config/aarch64/aarch64.c (cgraph.h): New include.
9334 (intl.h): New include.
9335 (supported_simd_type): New function.
9336 (currently_supported_simd_type): Ditto.
9337 (aarch64_simd_clone_compute_vecsize_and_simdlen): Ditto.
9338 (aarch64_simd_clone_adjust): Ditto.
9339 (aarch64_simd_clone_usable): Ditto.
9340 (TARGET_SIMD_CLONE_COMPUTE_VECSIZE_AND_SIMDLEN): New macro.
9341 (TARGET_SIMD_CLONE_ADJUST): Ditto.
9342 (TARGET_SIMD_CLONE_USABLE): Ditto.
9343 * config/i386/i386.c (ix86_simd_clone_adjust): Add definition check.
9344 * omp-simd-clone.c (expand_simd_clones): Add targetm.simd_clone.adjust
9345 call.
9346
9347 2019-01-17 Martin Sebor <msebor@redhat.com>
9348
9349 PR tree-optimization/88800
9350 * gimple-fold.c (gimple_fold_builtin_memory_op): Avoid checking
9351 NO_WARNING bit here. Avoid folding out-of-bounds calls.
9352 * gimple-ssa-warn-restrict.c (maybe_diag_offset_bounds): Remove
9353 redundant argument. Add new argument and issue diagnostics under
9354 its control. Detect out-of-bounds access even with warnings
9355 disabled.
9356 (check_bounds_or_overlap): Change return type. Add argument.
9357 (wrestrict_dom_walker::check_call): Adjust.
9358 * gimple-ssa-warn-restrict.h (check_bounds_or_overlap): Add argument.
9359 * tree-ssa-strlen.c (handle_builtin_strcpy): Adjust to change in
9360 check_bounds_or_overlap's return value.
9361 (handle_builtin_stxncpy): Same.
9362 (handle_builtin_strcat): Same.
9363
9364 2019-01-17 Andrew Stubbs <ams@codesourcery.com>
9365 Kwok Cheung Yeung <kcy@codesourcery.com>
9366 Julian Brown <julian@codesourcery.com>
9367 Tom de Vries <tom@codesourcery.com>
9368
9369 * doc/sourcebuild.texi: Document dg-add-options sqrt_insn.
9370
9371 2019-01-17 Andrew Stubbs <ams@codesourcery.com>
9372
9373 * doc/sourcebuild.texi: Document dg-require-effective-target
9374 llvm_binutils and offload_gcn.
9375
9376 2019-01-17 Andrew Stubbs <ams@codesourcery.com>
9377 Kwok Cheung Yeung <kcy@codesourcery.com>
9378 Julian Brown <julian@codesourcery.com>
9379 Tom de Vries <tom@codesourcery.com>
9380
9381 * doc/sourcebuild.texi: Document dg-required-effective-target
9382 exceptions.
9383
9384 2019-01-17 Andrew Stubbs <ams@codesourcery.com>
9385 Kwok Cheung Yeung <kcy@codesourcery.com>
9386 Julian Brown <julian@codesourcery.com>
9387 Tom de Vries <tom@codesourcery.com>
9388 Jan Hubicka <hubicka@ucw.cz>
9389 Martin Jambor <mjambor@suse.cz>
9390
9391 * config.gcc: Add amdgcn*-*-amdhsa configuration.
9392 * configure.ac: Check for dlopen.
9393 * configure: Regenerate.
9394
9395 2019-01-17 Andrew Stubbs <ams@codesourcery.com>
9396 Kwok Cheung Yeung <kcy@codesourcery.com>
9397 Julian Brown <julian@codesourcery.com>
9398 Tom de Vries <tom@codesourcery.com>
9399 Jan Hubicka <hubicka@ucw.cz>
9400 Martin Jambor <mjambor@suse.cz>
9401
9402 * common/config/gcn/gcn-common.c: New file.
9403 * config/gcn/driver-gcn.c: New file.
9404 * config/gcn/gcn-builtins.def: New file.
9405 * config/gcn/gcn-hsa.h: New file.
9406 * config/gcn/gcn-modes.def: New file.
9407 * config/gcn/gcn-opts.h: New file.
9408 * config/gcn/gcn-passes.def: New file.
9409 * config/gcn/gcn-protos.h: New file.
9410 * config/gcn/gcn-run.c: New file.
9411 * config/gcn/gcn-tree.c: New file.
9412 * config/gcn/gcn.c: New file.
9413 * config/gcn/gcn.h: New file.
9414 * config/gcn/gcn.opt: New file.
9415 * config/gcn/t-gcn-hsa: New file.
9416
9417 2019-01-17 Andrew Stubbs <ams@codesourcery.com>
9418 Kwok Cheung Yeung <kcy@codesourcery.com>
9419 Julian Brown <julian@codesourcery.com>
9420 Tom de Vries <tom@codesourcery.com>
9421 Jan Hubicka <hubicka@ucw.cz>
9422 Martin Jambor <mjambor@suse.cz>
9423
9424 * config/gcn/constraints.md: New file.
9425 * config/gcn/gcn-valu.md: New file.
9426 * config/gcn/gcn.md: New file.
9427 * config/gcn/predicates.md: New file.
9428
9429 2019-01-17 Eric Botcazou <ebotcazou@adacore.com>
9430
9431 * gimple-ssa-isolate-paths.c (stmt_uses_name_in_undefined_way): Replace
9432 flag_non_call_exceptions with cfun->can_throw_non_call_exceptions.
9433 (stmt_uses_0_or_null_in_undefined_way): Likewise.
9434 * tree-ssa-alias.c (same_addr_size_stores_p): Likewise.
9435
9436 2019-01-17 Tamar Christina <tamar.christina@arm.com>
9437
9438 PR target/88851
9439 * config/aarch64/aarch64.md (STACK_CLASH_SVE_CFA_REGNUM): New.
9440 * config/aarch64/aarch64.c (aarch64_allocate_and_probe_stack_space): Use
9441 it and document registers.
9442
9443 2019-01-17 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
9444
9445 * config/aarch64/aarch64.c (ares_tunings): Define.
9446 * config/aarch64/aarch64-cores.def (ares): Use the above.
9447
9448 2019-01-17 Wei Xiao <wei3.xiao@intel.com>
9449
9450 PR target/88794
9451 Revert:
9452 2018-11-06 Wei Xiao <wei3.xiao@intel.com>
9453
9454 * config/i386/avx512fintrin.h: Update VFIXUPIMM* intrinsics.
9455 (_mm512_fixupimm_round_pd): Update parameters and builtin.
9456 (_mm512_maskz_fixupimm_round_pd): Ditto.
9457 (_mm512_fixupimm_round_ps): Ditto.
9458 (_mm512_maskz_fixupimm_round_ps): Ditto.
9459 (_mm_fixupimm_round_sd): Ditto.
9460 (_mm_maskz_fixupimm_round_sd): Ditto.
9461 (_mm_fixupimm_round_ss): Ditto.
9462 (_mm_maskz_fixupimm_round_ss): Ditto.
9463 (_mm512_fixupimm_pd): Ditto.
9464 (_mm512_maskz_fixupimm_pd): Ditto.
9465 (_mm512_fixupimm_ps): Ditto.
9466 (_mm512_maskz_fixupimm_ps): Ditto.
9467 (_mm_fixupimm_sd): Ditto.
9468 (_mm_maskz_fixupimm_sd): Ditto.
9469 (_mm_fixupimm_ss): Ditto.
9470 (_mm_maskz_fixupimm_ss): Ditto.
9471 (_mm512_mask_fixupimm_round_pd): Update builtin.
9472 (_mm512_mask_fixupimm_round_ps): Ditto.
9473 (_mm_mask_fixupimm_round_sd): Ditto.
9474 (_mm_mask_fixupimm_round_ss): Ditto.
9475 (_mm512_mask_fixupimm_pd): Ditto.
9476 (_mm512_mask_fixupimm_ps): Ditto.
9477 (_mm_mask_fixupimm_sd): Ditto.
9478 (_mm_mask_fixupimm_ss): Ditto.
9479 * config/i386/avx512vlintrin.h:
9480 (_mm256_fixupimm_pd): Update parameters and builtin.
9481 (_mm256_maskz_fixupimm_pd): Ditto.
9482 (_mm256_fixupimm_ps): Ditto.
9483 (_mm256_maskz_fixupimm_ps): Ditto.
9484 (_mm_fixupimm_pd): Ditto.
9485 (_mm_maskz_fixupimm_pd): Ditto.
9486 (_mm_fixupimm_ps): Ditto.
9487 (_mm_maskz_fixupimm_ps): Ditto.
9488 (_mm256_mask_fixupimm_pd): Update builtin.
9489 (_mm256_mask_fixupimm_ps): Ditto.
9490 (_mm_mask_fixupimm_pd): Ditto.
9491 (_mm_mask_fixupimm_ps): Ditto.
9492 * config/i386/i386-builtin-types.def: Add new types and remove useless ones.
9493 * config/i386/i386-builtin.def: Update builtin definitions.
9494 * config/i386/i386.c: Handle new builtin types and remove useless ones.
9495 * config/i386/sse.md: Update VFIXUPIMM* patterns.
9496 (<avx512>_fixupimm<mode>_maskz<round_saeonly_expand_name>): Update.
9497 (<avx512>_fixupimm<mode><sd_maskz_name><round_saeonly_name>): Update.
9498 (<avx512>_fixupimm<mode>_mask<round_saeonly_name>): Update.
9499 (avx512f_sfixupimm<mode>_maskz<round_saeonly_expand_name>): Update.
9500 (avx512f_sfixupimm<mode><sd_maskz_name><round_saeonly_name>): Update.
9501 (avx512f_sfixupimm<mode>_mask<round_saeonly_name>): Update.
9502 * config/i386/subst.md:
9503 (round_saeonly_sd_mask_operand4): Add new subst_attr.
9504 (round_saeonly_sd_mask_op4): Ditto.
9505 (round_saeonly_expand_operand5): Ditto.
9506 (round_saeonly_expand): Update.
9507
9508 2019-01-17 Wei Xiao <wei3.xiao@intel.com>
9509
9510 PR target/88794
9511 Revert:
9512 2018-11-12 Wei Xiao <wei3.xiao@intel.com>
9513
9514 * config/i386/sse.md: Combine VFIXUPIMM* patterns
9515 (<avx512>_fixupimm<mode>_maskz<round_saeonly_expand_name>): Update.
9516 (<avx512>_fixupimm<mode><sd_maskz_name><round_saeonly_name>): Update.
9517 (<avx512>_fixupimm<mode>_mask<round_saeonly_name>): Remove.
9518 (avx512f_sfixupimm<mode>_maskz<round_saeonly_expand_name>): Update.
9519 (avx512f_sfixupimm<mode><sd_maskz_name><round_saeonly_name>): Update.
9520 (avx512f_sfixupimm<mode>_mask<round_saeonly_name>): Remove.
9521
9522 2019-01-17 Wei Xiao <wei3.xiao@intel.com>
9523
9524 PR target/88794
9525 Revert:
9526 2018-12-15 Jakub Jelinek <jakub@redhat.com>
9527
9528 PR target/88489
9529 * config/i386/sse.md (UNSPEC_SFIXUPIMM): New unspec enumerator.
9530 (avx512f_sfixupimm<mode><mask_name><round_saeonly_name>): Use it
9531 instead of UNSPEC_FIXUPIMM.
9532
9533 2019-01-17 Richard Biener <rguenther@suse.de>
9534
9535 PR lto/86736
9536 * dwarf2out.c (want_pubnames): Never generate pubnames sections
9537 and friends for the LTO part of debug info.
9538
9539 2019-01-17 Jakub Jelinek <jakub@redhat.com>
9540
9541 PR tree-optimization/86214
9542 * cfgexpand.c (add_stack_var_conflict): Don't add any conflicts
9543 if x == y.
9544
9545 PR rtl-optimization/88870
9546 * dce.c (deletable_insn_p): Never delete const/pure calls that can
9547 throw if we can't alter the cfg or delete dead exceptions.
9548 (mark_insn): Don't call find_call_stack_args for such calls.
9549
9550 2019-01-17 Kewen Lin <linkw@gcc.gnu.org>
9551
9552 * doc/extend.texi: Add four new prototypes for vec_ld and seven new
9553 prototypes for vec_st.
9554 * config/rs6000/rs6000-c.c (altivec_overloaded_builtins): Add entries
9555 for scalar address type variants of altivec_vec_ld/altivec_vec_st,
9556 mainly on signed/unsigned long long and double.
9557
9558 2019-01-16 David Malcolm <dmalcolm@redhat.com>
9559
9560 PR target/88861
9561 * combine.c (delete_noop_moves): Convert to "bool" return,
9562 returning true if any edges are eliminated.
9563 (combine_instructions): Also return true if delete_noop_moves
9564 returns true.
9565
9566 2019-01-16 Tamar Christina <tamar.christina@arm.com>
9567
9568 * config/aarch64/aarch64-builtins.c (aarch64_simd_expand_args): Use
9569 correct max nunits for endian swap.
9570 (aarch64_expand_fcmla_builtin): Correct subreg code.
9571 * config/aarch64/aarch64-simd.md (aarch64_fcmla_lane<rot><mode>,
9572 aarch64_fcmla_laneq<rot>v4hf, aarch64_fcmlaq_lane<rot><mode>): Correct
9573 lane endianness.
9574
9575 2019-01-16 Uroš Bizjak <ubizjak@gmail.com>
9576
9577 * config/alpha/alpha.c (alpha_gimplify_va_arg):
9578 Handle split indirect COMPLEX_TYPE arguments.
9579
9580 2019-01-16 Richard Earnshaw <rearnsha@arm.com>
9581
9582 PR target/86891
9583 * config/aarch64/aarch64-modes.def: Add comment about how the carry
9584 bit is set by add and compare.
9585 (CC_ADC): New CC_MODE.
9586 * config/aarch64/aarch64.c (aarch64_select_cc_mode): Use variables
9587 to cache the code and mode of X. Adjust the shape of a CC_Cmode
9588 comparison. Add detection for CC_ADCmode.
9589 (aarch64_get_condition_code_1): Update code support for CC_Cmode. Add
9590 CC_ADCmode.
9591 * config/aarch64/aarch64.md (uaddv<mode>4): Use LTU with CCmode.
9592 (uaddvti4): Comparison result is in CC_ADCmode and the condition is GEU.
9593 (add<mode>3_compareC_cconly_imm): Delete. Merge into...
9594 (add<mode>3_compareC_cconly): ... this. Restructure the comparison
9595 to eliminate the need for zero-extending the operands.
9596 (add<mode>3_compareC_imm): Delete. Merge into ...
9597 (add<mode>3_compareC): ... this. Restructure the comparison to
9598 eliminate the need for zero-extending the operands.
9599 (add<mode>3_carryin): Use LTU for the overflow detection.
9600 (add<mode>3_carryinC): Use CC_ADCmode for the result of the carry out.
9601 Reexpress comparison for overflow.
9602 (add<mode>3_carryinC_zero): Update for change to add<mode>3_carryinC.
9603 (add<mode>3_carryinC): Likewise.
9604 (add<mode>3_carryinV): Use LTU for carry between partials.
9605 * config/aarch64/predicates.md (aarch64_carry_operation): Update
9606 handling of CC_Cmode and add CC_ADCmode.
9607 (aarch64_borrow_operation): Likewise.
9608
9609 2019-01-16 Tamar Christina <tamar.christina@arm.com>
9610
9611 * config/arm/arm-protos.h (neon_vcmla_lane_prepare_operands): Remove patternmode.
9612 * config/arm/arm.c (neon_vcmla_lane_prepare_operands): Likewise.
9613 * config/arm/neon.md (neon_vcmla_lane<rot><mode>, neon_vcmla_laneq<rot><mode>,
9614 neon_vcmlaq_lane<rot><mode>): Remove endianness conversion.
9615
9616 2019-01-16 Martin Liska <mliska@suse.cz>
9617
9618 * Makefile.in: Set TOOL_INCLUDE_DIR and NATIVE_SYSTEM_HEADER_DIR
9619 for GCC driver.
9620 * config/gnu-user.h (TARGET_F951_OPTIONS): Add 'finclude%s/' as
9621 a new argument.
9622 * gcc.c (add_sysrooted_hdrs_prefix): New function.
9623 (path_prefix_reset): Move up in the source file.
9624 (find_fortran_preinclude_file): Make complex search for the
9625 fortran header files.
9626
9627 2019-01-15 Nikhil Benesch <nikhil.benesch@gmail.com>
9628
9629 * godump.c (go_output_typedef): When outputting a typedef, refer
9630 to the underlying type by its name and not its structure.
9631
9632 2019-01-15 David Malcolm <dmalcolm@redhat.com>
9633
9634 PR c++/88795
9635 * tree.c (build_function_type): Assert that arg_types is not
9636 error_mark_node.
9637
9638 2019-01-15 Richard Sandiford <richard.sandiford@arm.com>
9639
9640 PR inline-asm/52813
9641 * doc/extend.texi: Document that listing the stack pointer in the
9642 clobber list of an asm is a deprecated feature.
9643 * common.opt (Wdeprecated): Moved from c-family/c.opt.
9644 * cfgexpand.c (asm_clobber_reg_is_valid): Issue a -Wdeprecated
9645 warning instead of an error for clobbers of the stack pointer.
9646 Add a note explaining why.
9647
9648 2019-01-15 Richard Biener <rguenther@suse.de>
9649
9650 PR debug/88046
9651 * dwarf2out.c (gen_member_die): Do not generate inheritance
9652 DIEs late.
9653
9654 2019-01-15 Richard Biener <rguenther@suse.de>
9655
9656 PR tree-optimization/88855
9657 * tree-if-conv.c (combine_blocks): Collect
9658 SSA_NAME_OCCURS_IN_ABNORMAL_PHI from propagated out virtuals.
9659
9660 2019-01-15 Tom de Vries <tdevries@suse.de>
9661
9662 PR target/80547
9663 * config/nvptx/nvptx.c (nvptx_goacc_reduction_init): Handle
9664 lhs == NULL_TREE for gang-level reduction.
9665
9666 2019-01-15 Richard Biener <rguenther@suse.de>
9667 Prathamesh Kulkarni <prathamesh.kulkarni@linaro.org>
9668
9669 PR ipa/88788
9670 * ipa-pure-const.c (malloc_candidate_p_1): Add parameter visited and
9671 return true if SSA_NAME is already marked in visited bitmap.
9672 (malloc_candidate_p): Pass visited to malloc_candidate_p_1.
9673
9674 2019-01-15 Jakub Jelinek <jakub@redhat.com>
9675
9676 PR tree-optimization/88775
9677 * match.pd (cmp (convert1?@2 addr@0) (convert2? addr@1)): Optimize
9678 equal == 0 equality pointer comparisons some more if compared in
9679 integral types and either one points to an automatic var and the
9680 other to a global, or we can prove at least one points to the middle
9681 or both point to start or both point to end.
9682
9683 2019-01-14 Andi Kleen <ak@linux.intel.com>
9684
9685 * Makefile.in: Lower autofdo sampling rate by 10x.
9686 * Makefile.tpl: Dito.
9687
9688 2019-01-14 Tom Honermann <tom@honermann.net>
9689
9690 * defaults.h: Define CHAR8_TYPE.
9691
9692 2019-01-14 Martin Sebor <msebor@redhat.com>
9693
9694 PR target/88638
9695 * doc/extend.texi (Darwin Format Checks): Clarify.
9696
9697 2019-01-14 Richard Biener <rguenther@suse.de>
9698
9699 * genmatch.c (dt_simplify::gen_1): Change dumping dependent on
9700 whether we are in (simplify ...) or (match ...) context.
9701
9702 2019-01-14 Jakub Jelinek <jakub@redhat.com>
9703
9704 PR rtl-optimization/88796
9705 * emit-rtl.h (struct rtl_data): Add stack_protect_guard_decl field.
9706 * cfgexpand.c (stack_protect_prologue): Initialize
9707 crtl->stack_protect_guard_decl.
9708 * function.c (stack_protect_epilogue): Use it instead of calling
9709 targetm.stack_protect_guard again.
9710 * dse.c (check_mem_read_rtx): Ignore MEM_VOLATILE_P reads from
9711 MEMs with MEM_EXPR equal to crtl->stack_protect_guard or
9712 crtl->stack_protect_guard_decl.
9713 * config/i386/i386.c (ix86_stack_protect_guard): Set TREE_THIS_VOLATILE
9714 on the returned MEM_EXPR.
9715
9716 2019-01-12 Tom de Vries <tdevries@suse.de>
9717
9718 * config/nvptx/nvptx.c (nvptx_goacc_validate_dims_1): Alow setting
9719 vector length using -fopenacc-dim.
9720
9721 2019-01-12 Tom de Vries <tdevries@suse.de>
9722
9723 * config/nvptx/nvptx.c (nvptx_goacc_validate_dims): Take larger vector
9724 lengths into account.
9725
9726 2019-01-12 Svante Signell <svante.signell@gmail.com>
9727
9728 * config/i386/gnu.h (TARGET_THREAD_SSP_OFFSET): Define.
9729 (TARGET_CAN_SPLIT_STACK): Define.
9730 (TARGET_THREAD_SPLIT_STACK_OFFSET): Define.
9731
9732 2019-01-05 Jan Hubicka <hubicka@ucw.cz>
9733
9734 * params.def (inline-unit-growth): Set to 40.
9735
9736 2019-01-12 Jakub Jelinek <jakub@redhat.com>
9737
9738 * tree-ssa-loop-ivopts.c (find_inv_vars): Fix a comment typo.
9739
9740 2019-01-12 Tom de Vries <tdevries@suse.de>
9741
9742 * config/nvptx/nvptx.c (nvptx_goacc_validate_dims_1): In offloading
9743 region calling vector-partitionable routine, set default_vector_length
9744 to WARP_SIZE.
9745
9746 2019-01-12 Tom de Vries <tdevries@suse.de>
9747
9748 * config/nvptx/nvptx.c (nvptx_goacc_validate_dims_1): Add an use new
9749 variable default_vector_length.
9750
9751 2019-01-12 Tom de Vries <tdevries@suse.de>
9752
9753 PR middle-end/88703
9754 * config/nvptx/nvptx.c (nvptx_goacc_validate_dims_1): Apply defaults
9755 from oacc_default_dims, as oacc_validate_dims would do it, and apply
9756 dimensions limits.
9757
9758 2019-01-12 Tom de Vries <tdevries@suse.de>
9759
9760 * config/nvptx/nvptx.c (nvptx_goacc_validate_dims_1)
9761 (nvptx_goacc_validate_dims): Add used parameter.
9762 * doc/tm.texi: Regenerate.
9763 * omp-offload.c (oacc_parse_default_dims, oacc_validate_dims): Add
9764 argument to call to targetm.goacc.validate_dims.
9765 (default_goacc_validate_dims): Add used
9766 parameter.
9767 * target.def (validate_dims): Add used parameter in DEFHOOK.
9768 * targhooks.h (default_goacc_validate_dims): Add used parameter.
9769
9770 2019-01-11 Jakub Jelinek <jakub@redhat.com>
9771
9772 PR middle-end/85956
9773 PR lto/88733
9774 * tree-inline.h (struct copy_body_data): Add adjust_array_error_bounds
9775 field.
9776 * tree-inline.c (remap_type_1): Formatting fix. If TYPE_MAX_VALUE of
9777 ARRAY_TYPE's TYPE_DOMAIN is newly error_mark_node, replace it with
9778 a dummy "omp dummy var" variable if id->adjust_array_error_bounds.
9779 * omp-low.c (new_omp_context): Set cb.adjust_array_error_bounds.
9780
9781 2019-01-11 Vladimir Makarov <vmakarov@redhat.com>
9782
9783 PR rtl-optimization/87305
9784 * lra-assigns.c
9785 (setup_live_pseudos_and_spill_after_risky_transforms): Add code
9786 for little endian pseudos used as paradoxical subreg.
9787
9788 2019-01-11 Jakub Jelinek <jakub@redhat.com>
9789
9790 PR tree-optimization/88693
9791 * tree-ssa-strlen.c (get_min_string_length): Don't set *full_string_p
9792 for STRING_CSTs that don't contain any NUL characters in the first
9793 TREE_STRING_LENGTH bytes.
9794
9795 2019-01-11 Alan Modra <amodra@gmail.com>
9796
9797 PR 88777
9798 PR 88614
9799 * genattrtab.c (min_fn): Don't translate values.
9800 (min_attr_value): Return INT_MAX when the value can't be calculated.
9801 Return minimum among any values that can be calculated.
9802 (max_attr_value): Adjust.
9803
9804 2019-01-11 Jakub Jelinek <jakub@redhat.com>
9805
9806 * Makefile.in (PLUGIN_HEADERS): Add $(INSN_ATTR_H).
9807
9808 2019-01-11 Steve Ellcey <sellcey@marvell.com>
9809
9810 * config/aarch64/aarch64.c (aarch64_simd_call_p): New function.
9811 (aarch64_hard_regno_call_part_clobbered): Add insn argument.
9812 (aarch64_return_call_with_max_clobbers): New function.
9813 (TARGET_RETURN_CALL_WITH_MAX_CLOBBERS): New macro.
9814 * config/avr/avr.c (avr_hard_regno_call_part_clobbered): Add insn
9815 argument.
9816 * config/i386/i386.c (ix86_hard_regno_call_part_clobbered): Ditto.
9817 * config/mips/mips.c (mips_hard_regno_call_part_clobbered): Ditto.
9818 * config/rs6000/rs6000.c (rs6000_hard_regno_call_part_clobbered): Ditto.
9819 * config/s390/s390.c (s390_hard_regno_call_part_clobbered): Ditto.
9820 * cselib.c (cselib_process_insn): Add argument to
9821 targetm.hard_regno_call_part_clobbered call.
9822 * ira-conflicts.c (ira_build_conflicts): Ditto.
9823 * ira-costs.c (ira_tune_allocno_costs): Ditto.
9824 * lra-constraints.c (inherit_reload_reg): Ditto.
9825 * lra-int.h (struct lra_reg): Add call_insn field, remove call_p field.
9826 * lra-lives.c (check_pseudos_live_through_calls): Add call_insn
9827 argument. Call targetm.return_call_with_max_clobbers.
9828 Add argument to targetm.hard_regno_call_part_clobbered call.
9829 (calls_have_same_clobbers_p): New function.
9830 (process_bb_lives): Add call_insn and last_call_insn variables.
9831 Pass call_insn to check_pseudos_live_through_calls.
9832 Modify if stmt to check targetm.return_call_with_max_clobbers.
9833 Update setting of flush variable.
9834 (lra_create_live_ranges_1): Set call_insn to NULL instead of call_p
9835 to false.
9836 * lra.c (initialize_lra_reg_info_element): Set call_insn to NULL.
9837 * regcprop.c (copyprop_hardreg_forward_1): Add argument to
9838 targetm.hard_regno_call_part_clobbered call.
9839 * reginfo.c (choose_hard_reg_mode): Ditto.
9840 * regrename.c (check_new_reg_p): Ditto.
9841 * reload.c (find_equiv_reg): Ditto.
9842 * reload1.c (emit_reload_insns): Ditto.
9843 * sched-deps.c (deps_analyze_insn): Ditto.
9844 * sel-sched.c (init_regs_for_mode): Ditto.
9845 (mark_unavailable_hard_regs): Ditto.
9846 * targhooks.c (default_dwarf_frame_reg_mode): Ditto.
9847 * target.def (hard_regno_call_part_clobbered): Add insn argument.
9848 (return_call_with_max_clobbers): New target function.
9849 * doc/tm.texi: Regenerate.
9850 * doc/tm.texi.in (TARGET_RETURN_CALL_WITH_MAX_CLOBBERS): New hook.
9851 * hooks.c (hook_bool_uint_mode_false): Change to
9852 hook_bool_insn_uint_mode_false.
9853 * hooks.h (hook_bool_uint_mode_false): Ditto.
9854
9855 2019-01-11 Steve Ellcey <sellcey@marvell.com>
9856
9857 * config/aarch64/aarch64.c (aarch64_simd_call_p): New function.
9858 (aarch64_remove_extra_call_preserved_regs): New function.
9859 (TARGET_REMOVE_EXTRA_CALL_PRESERVED_REGS): New macro.
9860 * doc/tm.texi.in (TARGET_REMOVE_EXTRA_CALL_PRESERVED_REGS): New hook.
9861 * doc/tm.texi: Regenerate.
9862 * final.c (get_call_reg_set_usage): Call new hook.
9863 * target.def (remove_extra_call_preserved_regs): New hook.
9864 * targhooks.c (default_remove_extra_call_preserved_regs): New function.
9865 * targhooks.h (default_remove_extra_call_preserved_regs): New function.
9866
9867 2019-01-11 Jakub Jelinek <jakub@redhat.com>
9868
9869 PR bootstrap/88714
9870 * passes.c (finish_optimization_passes): Call print_combine_total_stats
9871 inside of pass_combine_1 dump rather than pass_profile_1.
9872
9873 2019-01-11 Tom de Vries <tdevries@suse.de>
9874
9875 * config/nvptx/nvptx.c (PTX_CTA_NUM_BARRIERS, PTX_PER_CTA_BARRIER)
9876 (PTX_NUM_PER_CTA_BARRIER, PTX_FIRST_PER_WORKER_BARRIER)
9877 (PTX_NUM_PER_WORKER_BARRIERS): Define.
9878 (nvptx_apply_dim_limits): Prevent vector_length 64 and
9879 num_workers 16.
9880
9881 2019-01-11 Tom de Vries <tdevries@suse.de>
9882
9883 * config/nvptx/nvptx.c (PTX_CTA_SIZE): Move up.
9884
9885 2019-01-11 Jan Beulich <jbeulich@suse.com>
9886
9887 * config/i386/i386.md (rex64suffix): Add L suffix for SI.
9888 * config/i386/sse.md (cvtusi2<ssescalarmodesuffix>32<round_name>,
9889 sse2_cvtsi2sd): Add {l}.
9890 (sse2_cvtsi2sdq<round_name>): Make q conditional upon AT&T
9891 syntax.
9892
9893 2019-01-10 Jakub Jelinek <jakub@redhat.com>
9894
9895 PR target/88785
9896 * config/i386/sse.md (float<floatunssuffix>v2div2sf2): Turn into
9897 define_expand.
9898 (*float<floatunssuffix>v2div2sf2): New define_insn.
9899 (float<floatunssuffix>v2div2sf2_mask): Turn into define_expand.
9900 (*float<floatunssuffix>v2div2sf2_mask): New define_insn.
9901 (*float<floatunssuffix>v2div2sf2_mask_1): Replace
9902 subrtxes (const_vector:V2SF [(const_int 0) (const_int 0)]) with
9903 match_operands with "const0_operand" "C".
9904
9905 2019-01-10 Tamar Christina <tamar.christina@arm.com>
9906
9907 * config/aarch64/aarch64-builtins.c
9908 (aarch64_init_builtins): Move aarch64_init_fcmla_laneq_builtins...
9909 (aarch64_init_simd_builtins): ...Here
9910
9911 2019-01-10 Vladimir Makarov <vmakarov@redhat.com>
9912
9913 PR rtl-optimization/87305
9914 * lra-assigns.c
9915 (setup_live_pseudos_and_spill_after_risky_transforms): Check
9916 allocation for big endian pseudos used as paradoxical subregs and
9917 spill them if it is wrong.
9918 * lra-constraints.c (lra_constraints): Add a comment.
9919
9920 2019-01-10 Richard Biener <rguenther@suse.de>
9921
9922 PR tree-optimization/88792
9923 * tree-ssa-pre.c (get_representative_for): Do not return a
9924 value-number here.
9925
9926 2019-01-10 Jakub Jelinek <jakub@redhat.com>
9927
9928 PR middle-end/84877
9929 PR bootstrap/88450
9930 * function.c (assign_stack_local_1): Revert the 2018-11-21 changes.
9931 (assign_parm_setup_block): Do the argument slot realignment here
9932 instead.
9933
9934 2019-01-10 Stefan Agner <stefan@agner.ch>
9935
9936 PR target/88648
9937 * config/arm/arm.c (arm_option_override_internal): Force
9938 opts->x_inline_asm_unified to true only if TARGET_THUMB2_P.
9939
9940 2019-01-10 Jakub Jelinek <jakub@redhat.com>
9941
9942 PR c/88568
9943 * attribs.c (handle_dll_attribute): Clear TREE_STATIC after setting
9944 DECL_EXTERNAL.
9945
9946 2019-01-10 Tamar Christina <tamar.christina@arm.com>
9947
9948 * config/arm/arm-builtins.c
9949 (enum arm_type_qualifiers): Add qualifier_lane_pair_index.
9950 (MAC_LANE_PAIR_QUALIFIERS): New.
9951 (arm_expand_builtin_args): Use it.
9952 (arm_expand_builtin_1): Likewise.
9953 * config/arm/arm-protos.h (neon_vcmla_lane_prepare_operands): New.
9954 * config/arm/arm.c (neon_vcmla_lane_prepare_operands): New.
9955 * config/arm/arm-c.c (arm_cpu_builtins): Add __ARM_FEATURE_COMPLEX.
9956 * config/arm/arm_neon.h:
9957 (vcadd_rot90_f16): New.
9958 (vcaddq_rot90_f16): New.
9959 (vcadd_rot270_f16): New.
9960 (vcaddq_rot270_f16): New.
9961 (vcmla_f16): New.
9962 (vcmlaq_f16): New.
9963 (vcmla_lane_f16): New.
9964 (vcmla_laneq_f16): New.
9965 (vcmlaq_lane_f16): New.
9966 (vcmlaq_laneq_f16): New.
9967 (vcmla_rot90_f16): New.
9968 (vcmlaq_rot90_f16): New.
9969 (vcmla_rot90_lane_f16): New.
9970 (vcmla_rot90_laneq_f16): New.
9971 (vcmlaq_rot90_lane_f16): New.
9972 (vcmlaq_rot90_laneq_f16): New.
9973 (vcmla_rot180_f16): New.
9974 (vcmlaq_rot180_f16): New.
9975 (vcmla_rot180_lane_f16): New.
9976 (vcmla_rot180_laneq_f16): New.
9977 (vcmlaq_rot180_lane_f16): New.
9978 (vcmlaq_rot180_laneq_f16): New.
9979 (vcmla_rot270_f16): New.
9980 (vcmlaq_rot270_f16): New.
9981 (vcmla_rot270_lane_f16): New.
9982 (vcmla_rot270_laneq_f16): New.
9983 (vcmlaq_rot270_lane_f16): New.
9984 (vcmlaq_rot270_laneq_f16): New.
9985 (vcadd_rot90_f32): New.
9986 (vcaddq_rot90_f32): New.
9987 (vcadd_rot270_f32): New.
9988 (vcaddq_rot270_f32): New.
9989 (vcmla_f32): New.
9990 (vcmlaq_f32): New.
9991 (vcmla_lane_f32): New.
9992 (vcmla_laneq_f32): New.
9993 (vcmlaq_lane_f32): New.
9994 (vcmlaq_laneq_f32): New.
9995 (vcmla_rot90_f32): New.
9996 (vcmlaq_rot90_f32): New.
9997 (vcmla_rot90_lane_f32): New.
9998 (vcmla_rot90_laneq_f32): New.
9999 (vcmlaq_rot90_lane_f32): New.
10000 (vcmlaq_rot90_laneq_f32): New.
10001 (vcmla_rot180_f32): New.
10002 (vcmlaq_rot180_f32): New.
10003 (vcmla_rot180_lane_f32): New.
10004 (vcmla_rot180_laneq_f32): New.
10005 (vcmlaq_rot180_lane_f32): New.
10006 (vcmlaq_rot180_laneq_f32): New.
10007 (vcmla_rot270_f32): New.
10008 (vcmlaq_rot270_f32): New.
10009 (vcmla_rot270_lane_f32): New.
10010 (vcmla_rot270_laneq_f32): New.
10011 (vcmlaq_rot270_lane_f32): New.
10012 (vcmlaq_rot270_laneq_f32): New.
10013 * config/arm/arm_neon_builtins.def (vcadd90, vcadd270, vcmla0, vcmla90,
10014 vcmla180, vcmla270, vcmla_lane0, vcmla_lane90, vcmla_lane180,
10015 vcmla_lane270, vcmla_laneq0, vcmla_laneq90, vcmla_laneq180,
10016 vcmla_laneq270, vcmlaq_lane0, vcmlaq_lane90, vcmlaq_lane180,
10017 vcmlaq_lane270): New.
10018 * config/arm/neon.md (neon_vcmla_lane<rot><mode>,
10019 neon_vcmla_laneq<rot><mode>, neon_vcmlaq_lane<rot><mode>): New.
10020 * config/arm/arm.c (arm_arch8_3, arm_arch8_4): New.
10021 * config/arm/arm.h (TARGET_COMPLEX, arm_arch8_3, arm_arch8_4): New.
10022 (arm_option_reconfigure_globals): Use them.
10023 * config/arm/iterators.md (VDF, VQ_HSF): New.
10024 (VCADD, VCMLA): New.
10025 (VF_constraint, rot, rotsplit1, rotsplit2): Add V4HF and V8HF.
10026 * config/arm/neon.md (neon_vcadd<rot><mode>, neon_vcmla<rot><mode>):
10027 New.
10028 * config/arm/unspecs.md (UNSPEC_VCADD90, UNSPEC_VCADD270,
10029 UNSPEC_VCMLA, UNSPEC_VCMLA90, UNSPEC_VCMLA180, UNSPEC_VCMLA270): New.
10030
10031 2019-01-10 Tamar Christina <tamar.christina@arm.com>
10032
10033 * config/aarch64/aarch64-builtins.c (enum aarch64_type_qualifiers):
10034 Add qualifier_lane_pair_index.
10035 (emit-rtl.h): Include.
10036 (TYPES_QUADOP_LANE_PAIR): New.
10037 (aarch64_simd_expand_args): Use it.
10038 (aarch64_simd_expand_builtin): Likewise.
10039 (AARCH64_SIMD_FCMLA_LANEQ_BUILTINS, aarch64_fcmla_laneq_builtin_datum):
10040 New.
10041 (FCMLA_LANEQ_BUILTIN, AARCH64_SIMD_FCMLA_LANEQ_BUILTIN_BASE,
10042 AARCH64_SIMD_FCMLA_LANEQ_BUILTINS, aarch64_fcmla_lane_builtin_data,
10043 aarch64_init_fcmla_laneq_builtins, aarch64_expand_fcmla_builtin): New.
10044 (aarch64_init_builtins): Add aarch64_init_fcmla_laneq_builtins.
10045 (aarch64_expand_buildin): Add AARCH64_SIMD_BUILTIN_FCMLA_LANEQ0_V2SF,
10046 AARCH64_SIMD_BUILTIN_FCMLA_LANEQ90_V2SF,
10047 AARCH64_SIMD_BUILTIN_FCMLA_LANEQ180_V2SF,
10048 AARCH64_SIMD_BUILTIN_FCMLA_LANEQ2700_V2SF,
10049 AARCH64_SIMD_BUILTIN_FCMLA_LANEQ0_V4HF,
10050 AARCH64_SIMD_BUILTIN_FCMLA_LANEQ90_V4HF,
10051 AARCH64_SIMD_BUILTIN_FCMLA_LANEQ180_V4HF,
10052 AARCH64_SIMD_BUILTIN_FCMLA_LANEQ270_V4HF.
10053 * config/aarch64/iterators.md (FCMLA_maybe_lane): New.
10054 * config/aarch64/aarch64-c.c (aarch64_update_cpp_builtins):
10055 Add __ARM_FEATURE_COMPLEX.
10056 * config/aarch64/aarch64-simd-builtins.def (fcadd90, fcadd270, fcmla0,
10057 fcmla90, fcmla180, fcmla270, fcmla_lane0, fcmla_lane90, fcmla_lane180,
10058 fcmla_lane270, fcmla_laneq0, fcmla_laneq90, fcmla_laneq180,
10059 fcmla_laneq270, fcmlaq_lane0, fcmlaq_lane90, fcmlaq_lane180,
10060 fcmlaq_lane270): New.
10061 * config/aarch64/aarch64-simd.md (aarch64_fcmla_lane<rot><mode>,
10062 aarch64_fcmla_laneq<rot>v4hf, aarch64_fcmlaq_lane<rot><mode>,
10063 aarch64_fcadd<rot><mode>, aarch64_fcmla<rot><mode>): New.
10064 * config/aarch64/arm_neon.h:
10065 (vcadd_rot90_f16): New.
10066 (vcaddq_rot90_f16): New.
10067 (vcadd_rot270_f16): New.
10068 (vcaddq_rot270_f16): New.
10069 (vcmla_f16): New.
10070 (vcmlaq_f16): New.
10071 (vcmla_lane_f16): New.
10072 (vcmla_laneq_f16): New.
10073 (vcmlaq_lane_f16): New.
10074 (vcmlaq_rot90_lane_f16): New.
10075 (vcmla_rot90_laneq_f16): New.
10076 (vcmla_rot90_lane_f16): New.
10077 (vcmlaq_rot90_f16): New.
10078 (vcmla_rot90_f16): New.
10079 (vcmlaq_laneq_f16): New.
10080 (vcmla_rot180_laneq_f16): New.
10081 (vcmla_rot180_lane_f16): New.
10082 (vcmlaq_rot180_f16): New.
10083 (vcmla_rot180_f16): New.
10084 (vcmlaq_rot90_laneq_f16): New.
10085 (vcmlaq_rot270_laneq_f16): New.
10086 (vcmlaq_rot270_lane_f16): New.
10087 (vcmla_rot270_laneq_f16): New.
10088 (vcmlaq_rot270_f16): New.
10089 (vcmla_rot270_f16): New.
10090 (vcmlaq_rot180_laneq_f16): New.
10091 (vcmlaq_rot180_lane_f16): New.
10092 (vcmla_rot270_lane_f16): New.
10093 (vcadd_rot90_f32): New.
10094 (vcaddq_rot90_f32): New.
10095 (vcaddq_rot90_f64): New.
10096 (vcadd_rot270_f32): New.
10097 (vcaddq_rot270_f32): New.
10098 (vcaddq_rot270_f64): New.
10099 (vcmla_f32): New.
10100 (vcmlaq_f32): New.
10101 (vcmlaq_f64): New.
10102 (vcmla_lane_f32): New.
10103 (vcmla_laneq_f32): New.
10104 (vcmlaq_lane_f32): New.
10105 (vcmlaq_laneq_f32): New.
10106 (vcmla_rot90_f32): New.
10107 (vcmlaq_rot90_f32): New.
10108 (vcmlaq_rot90_f64): New.
10109 (vcmla_rot90_lane_f32): New.
10110 (vcmla_rot90_laneq_f32): New.
10111 (vcmlaq_rot90_lane_f32): New.
10112 (vcmlaq_rot90_laneq_f32): New.
10113 (vcmla_rot180_f32): New.
10114 (vcmlaq_rot180_f32): New.
10115 (vcmlaq_rot180_f64): New.
10116 (vcmla_rot180_lane_f32): New.
10117 (vcmla_rot180_laneq_f32): New.
10118 (vcmlaq_rot180_lane_f32): New.
10119 (vcmlaq_rot180_laneq_f32): New.
10120 (vcmla_rot270_f32): New.
10121 (vcmlaq_rot270_f32): New.
10122 (vcmlaq_rot270_f64): New.
10123 (vcmla_rot270_lane_f32): New.
10124 (vcmla_rot270_laneq_f32): New.
10125 (vcmlaq_rot270_lane_f32): New.
10126 (vcmlaq_rot270_laneq_f32): New.
10127 * config/aarch64/aarch64.h (TARGET_COMPLEX): New.
10128 * config/aarch64/iterators.md (UNSPEC_FCADD90, UNSPEC_FCADD270,
10129 UNSPEC_FCMLA, UNSPEC_FCMLA90, UNSPEC_FCMLA180, UNSPEC_FCMLA270): New.
10130 (FCADD, FCMLA): New.
10131 (rot): New.
10132 * config/arm/types.md (neon_fcadd, neon_fcmla): New.
10133
10134 2019-01-09 Sandra Loosemore <sandra@codesourcery.com>
10135
10136 PR other/16615
10137
10138 * config/pa/pa.c: Change "can not" to "cannot".
10139 * gimple-ssa-evrp-analyze.c: Likewise.
10140 * ipa-icf.c: Likewise.
10141 * ipa-polymorphic-call.c: Likewise.
10142 * ipa-pure-const.c: Likewise.
10143 * lra-constraints.c: Likewise.
10144 * lra-remat.c: Likewise.
10145 * reload1.c: Likewise.
10146 * reorg.c: Likewise.
10147 * tree-ssa-uninit.c: Likewise.
10148
10149 2019-01-09 Sandra Loosemore <sandra@codesourcery.com>
10150
10151 PR other/16615
10152
10153 * Makefile.in: Mechanically replace "can not" with "cannot".
10154 * alias.c: Likewise.
10155 * builtins.c: Likewise.
10156 * calls.c: Likewise.
10157 * cgraph.c: Likewise.
10158 * cgraph.h: Likewise.
10159 * cgraphclones.c: Likewise.
10160 * cgraphunit.c: Likewise.
10161 * combine-stack-adj.c: Likewise.
10162 * combine.c: Likewise.
10163 * common/config/i386/i386-common.c: Likewise.
10164 * config/aarch64/aarch64.c: Likewise.
10165 * config/alpha/sync.md: Likewise.
10166 * config/arc/arc.c: Likewise.
10167 * config/arc/predicates.md: Likewise.
10168 * config/arm/arm-c.c: Likewise.
10169 * config/arm/arm.c: Likewise.
10170 * config/arm/arm.h: Likewise.
10171 * config/arm/arm.md: Likewise.
10172 * config/arm/cortex-r4f.md: Likewise.
10173 * config/csky/csky.c: Likewise.
10174 * config/csky/csky.h: Likewise.
10175 * config/darwin-f.c: Likewise.
10176 * config/epiphany/epiphany.md: Likewise.
10177 * config/i386/i386.c: Likewise.
10178 * config/i386/sol2.h: Likewise.
10179 * config/m68k/m68k.c: Likewise.
10180 * config/mcore/mcore.h: Likewise.
10181 * config/microblaze/microblaze.md: Likewise.
10182 * config/mips/20kc.md: Likewise.
10183 * config/mips/sb1.md: Likewise.
10184 * config/nds32/nds32.c: Likewise.
10185 * config/nds32/predicates.md: Likewise.
10186 * config/pa/pa.c: Likewise.
10187 * config/rs6000/e300c2c3.md: Likewise.
10188 * config/rs6000/rs6000.c: Likewise.
10189 * config/s390/s390.h: Likewise.
10190 * config/sh/sh.c: Likewise.
10191 * config/sh/sh.md: Likewise.
10192 * config/spu/vmx2spu.h: Likewise.
10193 * cprop.c: Likewise.
10194 * dbxout.c: Likewise.
10195 * df-scan.c: Likewise.
10196 * doc/cfg.texi: Likewise.
10197 * doc/extend.texi: Likewise.
10198 * doc/fragments.texi: Likewise.
10199 * doc/gty.texi: Likewise.
10200 * doc/invoke.texi: Likewise.
10201 * doc/lto.texi: Likewise.
10202 * doc/md.texi: Likewise.
10203 * doc/objc.texi: Likewise.
10204 * doc/rtl.texi: Likewise.
10205 * doc/tm.texi: Likewise.
10206 * dse.c: Likewise.
10207 * emit-rtl.c: Likewise.
10208 * emit-rtl.h: Likewise.
10209 * except.c: Likewise.
10210 * expmed.c: Likewise.
10211 * expr.c: Likewise.
10212 * fold-const.c: Likewise.
10213 * genautomata.c: Likewise.
10214 * gimple-fold.c: Likewise.
10215 * hard-reg-set.h: Likewise.
10216 * ifcvt.c: Likewise.
10217 * ipa-comdats.c: Likewise.
10218 * ipa-cp.c: Likewise.
10219 * ipa-devirt.c: Likewise.
10220 * ipa-fnsummary.c: Likewise.
10221 * ipa-icf.c: Likewise.
10222 * ipa-inline-transform.c: Likewise.
10223 * ipa-inline.c: Likewise.
10224 * ipa-polymorphic-call.c: Likewise.
10225 * ipa-profile.c: Likewise.
10226 * ipa-prop.c: Likewise.
10227 * ipa-pure-const.c: Likewise.
10228 * ipa-reference.c: Likewise.
10229 * ipa-split.c: Likewise.
10230 * ipa-visibility.c: Likewise.
10231 * ipa.c: Likewise.
10232 * ira-build.c: Likewise.
10233 * ira-color.c: Likewise.
10234 * ira-conflicts.c: Likewise.
10235 * ira-costs.c: Likewise.
10236 * ira-int.h: Likewise.
10237 * ira-lives.c: Likewise.
10238 * ira.c: Likewise.
10239 * ira.h: Likewise.
10240 * loop-invariant.c: Likewise.
10241 * loop-unroll.c: Likewise.
10242 * lower-subreg.c: Likewise.
10243 * lra-assigns.c: Likewise.
10244 * lra-constraints.c: Likewise.
10245 * lra-eliminations.c: Likewise.
10246 * lra-lives.c: Likewise.
10247 * lra-remat.c: Likewise.
10248 * lra-spills.c: Likewise.
10249 * lra.c: Likewise.
10250 * lto-cgraph.c: Likewise.
10251 * lto-streamer-out.c: Likewise.
10252 * postreload-gcse.c: Likewise.
10253 * predict.c: Likewise.
10254 * profile-count.h: Likewise.
10255 * profile.c: Likewise.
10256 * recog.c: Likewise.
10257 * ree.c: Likewise.
10258 * reload.c: Likewise.
10259 * reload1.c: Likewise.
10260 * reorg.c: Likewise.
10261 * resource.c: Likewise.
10262 * rtl.def: Likewise.
10263 * rtl.h: Likewise.
10264 * rtlanal.c: Likewise.
10265 * sched-deps.c: Likewise.
10266 * sched-ebb.c: Likewise.
10267 * sched-rgn.c: Likewise.
10268 * sel-sched-ir.c: Likewise.
10269 * sel-sched.c: Likewise.
10270 * shrink-wrap.c: Likewise.
10271 * simplify-rtx.c: Likewise.
10272 * symtab.c: Likewise.
10273 * target.def: Likewise.
10274 * toplev.c: Likewise.
10275 * tree-call-cdce.c: Likewise.
10276 * tree-cfg.c: Likewise.
10277 * tree-complex.c: Likewise.
10278 * tree-core.h: Likewise.
10279 * tree-eh.c: Likewise.
10280 * tree-inline.c: Likewise.
10281 * tree-loop-distribution.c: Likewise.
10282 * tree-nrv.c: Likewise.
10283 * tree-profile.c: Likewise.
10284 * tree-sra.c: Likewise.
10285 * tree-ssa-alias.c: Likewise.
10286 * tree-ssa-dce.c: Likewise.
10287 * tree-ssa-dom.c: Likewise.
10288 * tree-ssa-forwprop.c: Likewise.
10289 * tree-ssa-loop-im.c: Likewise.
10290 * tree-ssa-loop-ivcanon.c: Likewise.
10291 * tree-ssa-loop-ivopts.c: Likewise.
10292 * tree-ssa-loop-niter.c: Likewise.
10293 * tree-ssa-phionlycprop.c: Likewise.
10294 * tree-ssa-phiopt.c: Likewise.
10295 * tree-ssa-propagate.c: Likewise.
10296 * tree-ssa-threadedge.c: Likewise.
10297 * tree-ssa-threadupdate.c: Likewise.
10298 * tree-ssa-uninit.c: Likewise.
10299 * tree-ssanames.c: Likewise.
10300 * tree-streamer-out.c: Likewise.
10301 * tree.c: Likewise.
10302 * tree.h: Likewise.
10303 * vr-values.c: Likewise.
10304
10305 2019-01-09 Uroš Bizjak <ubizjak@gmail.com>
10306
10307 * config/i386/i386-protos.h (ix86_expand_xorsign): New prototype.
10308 (ix86_split_xorsign): Ditto.
10309 * config/i386/i386.c (ix86_expand_xorsign): New function.
10310 (ix86_split_xorsign): Ditto.
10311 * config/i386/i386.md (UNSPEC_XORSIGN): New unspec.
10312 (xorsign<mode>3): New expander.
10313 (xorsign<mode>3_1): New insn_and_split pattern.
10314 * config/i386/sse.md (xorsign<mode>3): New expander.
10315
10316 2019-01-09 Eric Botcazou <ebotcazou@adacore.com>
10317
10318 * config/sparc/sparc.md (*tablejump_sp32): Merge into...
10319 (*tablejump_sp64): Likewise.
10320 (*tablejump<P:mode>): ...this.
10321 (*call_address_sp32): Merge into...
10322 (*call_address_sp64): Likewise.
10323 (*call_address<P:mode>): ...this.
10324 (*call_symbolic_sp32): Merge into...
10325 (*call_symbolic_sp64): Likewise.
10326 (*call_symbolic<P:mode>): ...this.
10327 (call_value): Remove constraint and add predicate.
10328 (*call_value_address_sp32): Merge into...
10329 (*call_value_address_sp64): Likewise.
10330 (*call_value_address<P:mode>): ...this.
10331 (*call_value_symbolic_sp32): Merge into...
10332 (*call_value_symbolic_sp64): Likewise.
10333 (*call_value_symbolic<P:mode>): ...this.
10334 (*sibcall_symbolic_sp32): Merge into...
10335 (*sibcall_symbolic_sp64): Likewise.
10336 (*sibcall_symbolic<P:mode>): ...this.
10337 (sibcall_value): Remove constraint and add predicate.
10338 (*sibcall_value_symbolic_sp32): Merge into...
10339 (*sibcall_value_symbolic_sp64): Likewise.
10340 (*sibcall_value_symbolic<P:mode>): ...this.
10341 (window_save): Minor tweak.
10342 (*branch_sp32): Merge into...
10343 (*branch_sp64): Likewise.
10344 (*branch<P:mode>): ...this.
10345
10346 2019-01-09 Eric Botcazou <ebotcazou@adacore.com>
10347 James Clarke <jrtc27@jrtc27.com>
10348
10349 PR target/84010
10350 * config/sparc/sparc.c (sparc_legitimize_tls_address): Only use Pmode
10351 consistently in TLS address generation and adjust code to the renaming
10352 of patterns. Mark calls to __tls_get_addr as const.
10353 * config/sparc/sparc.md (tgd_hi22): Turn into...
10354 (tgd_hi22<P:mode>): ...this and use Pmode throughout.
10355 (tgd_lo10): Turn into...
10356 (tgd_lo10<P:mode>): ...this and use Pmode throughout.
10357 (tgd_add32): Merge into...
10358 (tgd_add64): Likewise.
10359 (tgd_add<P:mode>): ...this and use Pmode throughout.
10360 (tldm_hi22): Turn into...
10361 (tldm_hi22<P:mode>): ...this and use Pmode throughout.
10362 (tldm_lo10): Turn into...
10363 (tldm_lo10<P:mode>): ...this and use Pmode throughout.
10364 (tldm_add32): Merge into...
10365 (tldm_add64): Likewise.
10366 (tldm_add<P:mode>): ...this and use Pmode throughout.
10367 (tldm_call32): Merge into...
10368 (tldm_call64): Likewise.
10369 (tldm_call<P:mode>): ...this and use Pmode throughout.
10370 (tldo_hix22): Turn into...
10371 (tldo_hix22<P:mode>): ...this and use Pmode throughout.
10372 (tldo_lox10): Turn into...
10373 (tldo_lox10<P:mode>): ...this and use Pmode throughout.
10374 (tldo_add32): Merge into...
10375 (tldo_add64): Likewise.
10376 (tldo_add<P:mode>): ...this and use Pmode throughout.
10377 (tie_hi22): Turn into...
10378 (tie_hi22<P:mode>): ...this and use Pmode throughout.
10379 (tie_lo10): Turn into...
10380 (tie_lo10<P:mode>): ...this and use Pmode throughout.
10381 (tie_ld64): Use DImode throughout.
10382 (tie_add32): Merge into...
10383 (tie_add64): Likewise.
10384 (tie_add<P:mode>): ...this and use Pmode throughout.
10385 (tle_hix22_sp32): Merge into...
10386 (tle_hix22_sp64): Likewise.
10387 (tle_hix22<P:mode>): ...this and use Pmode throughout.
10388 (tle_lox22_sp32): Merge into...
10389 (tle_lox22_sp64): Likewise.
10390 (tle_lox22<P:mode>): ...this and use Pmode throughout.
10391 (*tldo_ldub_sp32): Merge into...
10392 (*tldo_ldub_sp64): Likewise.
10393 (*tldo_ldub<P:mode>): ...this and use Pmode throughout.
10394 (*tldo_ldub1_sp32): Merge into...
10395 (*tldo_ldub1_sp64): Likewise.
10396 (*tldo_ldub1<P:mode>): ...this and use Pmode throughout.
10397 (*tldo_ldub2_sp32): Merge into...
10398 (*tldo_ldub2_sp64): Likewise.
10399 (*tldo_ldub2<P:mode>): ...this and use Pmode throughout.
10400 (*tldo_ldsb1_sp32): Merge into...
10401 (*tldo_ldsb1_sp64): Likewise.
10402 (*tldo_ldsb1<P:mode>): ...this and use Pmode throughout.
10403 (*tldo_ldsb2_sp32): Merge into...
10404 (*tldo_ldsb2_sp64): Likewise.
10405 (*tldo_ldsb2<P:mode>): ...this and use Pmode throughout.
10406 (*tldo_ldub3_sp64): Use DImode throughout.
10407 (*tldo_ldsb3_sp64): Likewise.
10408 (*tldo_lduh_sp32): Merge into...
10409 (*tldo_lduh_sp64): Likewise.
10410 (*tldo_lduh<P:mode>): ...this and use Pmode throughout.
10411 (*tldo_lduh1_sp32): Merge into...
10412 (*tldo_lduh1_sp64): Likewise.
10413 (*tldo_lduh1<P:mode>): ...this and use Pmode throughout.
10414 (*tldo_ldsh1_sp32): Merge into...
10415 (*tldo_ldsh1_sp64): Likewise.
10416 (*tldo_ldsh1<P:mode>): ...this and use Pmode throughout.
10417 (*tldo_lduh2_sp64): Use DImode throughout.
10418 (*tldo_ldsh2_sp64): Likewise.
10419 (*tldo_lduw_sp32): Merge into...
10420 (*tldo_lduw_sp64): Likewise.
10421 (*tldo_lduw<P:mode>): ...this and use Pmode throughout.
10422 (*tldo_lduw1_sp64): Use DImode throughout.
10423 (*tldo_ldsw1_sp64): Likewise.
10424 (*tldo_ldx_sp64): Likewise.
10425 (*tldo_stb_sp32): Merge into...
10426 (*tldo_stb_sp64): Likewise.
10427 (*tldo_stb<P:mode>): ...this and use Pmode throughout.
10428 (*tldo_sth_sp32): Merge into...
10429 (*tldo_sth_sp64): Likewise.
10430 (*tldo_sth<P:mode>): ...this and use Pmode throughout.
10431 (*tldo_stw_sp32): Merge into...
10432 (*tldo_stw_sp64): Likewise.
10433 (*tldo_stw<P:mode>): ...this and use Pmode throughout.
10434 (*tldo_stx_sp64): Use DImode throughout.
10435
10436 2018-01-09 Sudakshina Das <sudi.das@arm.com>
10437
10438 * config/aarch64/aarch64.c (aarch64_override_options): Add case to
10439 check configure option to set BTI and Return Address Signing.
10440 * configure.ac: Add --enable-standard-branch-protection and
10441 --disable-standard-branch-protection.
10442 * configure: Regenerated.
10443 * doc/install.texi: Document the same.
10444
10445 2018-01-09 Sudakshina Das <sudi.das@arm.com>
10446 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
10447
10448 * config.gcc (aarch64*-*-*): Add aarch64-bti-insert.o.
10449 * config/aarch64/aarch64.h: Update comment for TRAMPOLINE_SIZE.
10450 * config/aarch64/aarch64.c (aarch64_asm_trampoline_template): Update
10451 if bti is enabled.
10452 * config/aarch64/aarch64-bti-insert.c: New file.
10453 * config/aarch64/aarch64-passes.def (INSERT_PASS_BEFORE): Insert bti
10454 pass.
10455 * config/aarch64/aarch64-protos.h (make_pass_insert_bti): Declare the
10456 new bti pass.
10457 * config/aarch64/aarch64.md (unspecv): Add UNSPECV_BTI_NOARG,
10458 UNSPECV_BTI_C, UNSPECV_BTI_J and UNSPECV_BTI_JC.
10459 (bti_noarg, bti_j, bti_c, bti_jc): New define_insns.
10460 * config/aarch64/t-aarch64: Add rule for aarch64-bti-insert.o.
10461
10462 2018-01-09 Sudakshina Das <sudi.das@arm.com>
10463
10464 * config/aarch64/aarch64-protos.h (aarch64_bti_enabled): Declare.
10465 * config/aarch64/aarch64.c (aarch64_handle_no_branch_protection):
10466 Disable bti for -mbranch-protection=none.
10467 (aarch64_handle_standard_branch_protection): Enable bti for
10468 -mbranch-protection=standard.
10469 (aarch64_handle_bti_protection): Enable bti for "bti" in the string to
10470 -mbranch-protection.
10471 (aarch64_bti_enabled): Check if bti is enabled.
10472 * config/aarch64/aarch64.opt: Declare target variable.
10473 * doc/invoke.texi: Add bti to the -mbranch-protection documentation.
10474
10475 2018-01-09 Sudakshina Das <sudi.das@arm.com>
10476
10477 * config/aarch64/aarch64.c (aarch64_expand_prologue): Use new
10478 epilogue/prologue scratch registers EP0_REGNUM and EP1_REGNUM.
10479 (aarch64_expand_epilogue): Likewise.
10480 (aarch64_output_mi_thunk): Likewise
10481 * config/aarch64/aarch64.h (REG_CLASS_CONTENTS): Change
10482 TAILCALL_ADDR_REGS to x16 and x17.
10483 * config/aarch64/aarch64.md: Define EP0_REGNUM and EP1_REGNUM.
10484
10485 2018-01-09 Sudakshina Das <sudi.das@arm.com>
10486
10487 * config/aarch64/aarch64-option-extensions.def: Define
10488 AARCH64_OPT_EXTENSION for memtag, rng, sb, ssbs and predres.
10489 * config/aarch64/aarch64.h (AARCH64_FL_RNG): New.
10490 (AARCH64_FL_MEMTAG, ARCH64_FL_SB, AARCH64_FL_SSBS): New.
10491 (AARCH64_FL_PREDRES): New.
10492 (AARCH64_FL_FOR_ARCH8_5): Add AARCH64_FL_SB, AARCH64_FL_SSBS and
10493 AARCH64_FL_PREDRES by default.
10494 * doc/invoke.texi: Document rng, memtag, sb, ssbs and predres.
10495
10496 2018-01-09 Sudakshina Das <sudi.das@arm.com>
10497
10498 * config/aarch64/aarch64-arches.def: Define AARCH64_ARCH for
10499 ARMv8.5-A.
10500 * config/aarch64/aarch64.h (AARCH64_FL_V8_5): New.
10501 (AARCH64_FL_FOR_ARCH8_5, AARCH64_ISA_V8_5): New.
10502 * doc/invoke.texi: Document ARMv8.5-A.
10503
10504 2019-01-09 Alejandro Martinez <alejandro.martinezvicente@arm.com>
10505
10506 * config/aarch64/aarch64-sve.md (copysign<mode>3): New define_expand.
10507 (xorsign<mode>3): Likewise.
10508
10509 2019-01-09 Jelinek <jakub@redhat.com>
10510
10511 PR middle-end/88758
10512 * tree.c (initializer_each_zero_or_onep) <case VECTOR_CST>: Use
10513 vector_cst_elt instead of VECTOR_CST_ENCODED_ELT.
10514
10515 PR rtl-optimization/88331
10516 * function.c (assign_stack_local_1): Don't set dynamic_align_addr if
10517 not currently_expanding_to_rtl.
10518
10519 2019-01-09 Eric Botcazou <ebotcazou@adacore.com>
10520
10521 * doc/invoke.texi (-Os): Remove trailing spaces.
10522 (-finline-functions): Remove reference to -O2.
10523
10524 2019-01-08 Jakub Jelinek <jakub@redhat.com>
10525
10526 PR rtl-optimization/79593
10527 * config/i386/i386.md (reg = mem; mem = reg): New define_peephole2.
10528
10529 * config/rs6000/rs6000.c (rs6000_delegitimize_address): Delegitimize
10530 UNSPEC_FUSION_GPR to its argument. Formatting fixes.
10531
10532 2019-01-08 Eric Botcazou <ebotcazou@adacore.com>
10533
10534 PR bootstrap/88721
10535 * config/sparc/sparc.c (function_arg_slotno): Set *PPREGNO & *PPADDING
10536 to -1 on entry.
10537
10538 PR debug/88723
10539 * config/sparc/sparc.c (sparc_delegitimize_address): Deal with naked
10540 UNSPECs and UNSPEC_MOVE_GOTDATA specifically.
10541
10542 2019-01-08 H.J. Lu <hongjiu.lu@intel.com>
10543
10544 PR target/88717
10545 * config/i386/i386.c (ix86_avx_u128_mode_exit): Call
10546 ix86_avx_u128_mode_entry.
10547
10548 2019-01-08 Martin Liska <mliska@suse.cz>
10549
10550 PR tree-optimization/88753
10551 * tree-switch-conversion.c (switch_conversion::build_one_array):
10552 Come up with local variable constructor. Convert first to
10553 type of constructor values.
10554
10555 2019-01-08 Richard Biener <rguenther@suse.de>
10556
10557 PR tree-optimization/86554
10558 * tree-ssa-sccvn.c (eliminate_dom_walker, rpo_elim,
10559 rpo_avail): Move earlier.
10560 (visit_nary_op): When value-numbering to expressions
10561 with different overflow behavior make sure there's an
10562 available expression on the path.
10563
10564 2019-01-08 Sam Tebbs <sam.tebbs@arm.com>
10565
10566 * config/aarch64/aarch64.c (BRANCH_PROTECT_STR_MAX,
10567 aarch64_parse_branch_protection,
10568 struct aarch64_branch_protect_type,
10569 aarch64_handle_no_branch_protection,
10570 aarch64_handle_standard_branch_protection,
10571 aarch64_validate_mbranch_protection,
10572 aarch64_handle_pac_ret_protection,
10573 aarch64_handle_attr_branch_protection,
10574 accepted_branch_protection_string,
10575 aarch64_pac_ret_subtypes,
10576 aarch64_branch_protect_types,
10577 aarch64_handle_pac_ret_leaf): Define.
10578 (aarch64_override_options_after_change_1, aarch64_override_options):
10579 Add check for accepted_branch_protection_string.
10580 (aarch64_option_save): Save accepted_branch_protection_string.
10581 (aarch64_option_restore): Save accepted_branch_protection_string.
10582 * config/aarch64/aarch64.c (aarch64_attributes): Add branch-protection.
10583 * config/aarch64/aarch64.opt: Add mbranch-protection. Deprecate
10584 msign-return-address.
10585 * doc/invoke.texi: Add mbranch-protection.
10586
10587 2019-01-08 Alan Modra <amodra@gmail.com>
10588
10589 PR target/88614
10590 * genattrtab.c (max_attr_value, min_attr_value, or_attr_value):
10591 Delete "unknownp" parameter. Adjust callers. Handle
10592 CONST_INT, PLUS, MINUS, and MULT.
10593 (attr_value_aligned): Renamed from or_attr_value.
10594 (min_attr_value): Return INT_MIN for unhandled rtl case..
10595 (min_fn): ..and translate to INT_MAX here.
10596 (write_length_unit_log): Modify to cope without "unknown".
10597 (write_attr_value): Handle IF_THEN_ELSE.
10598
10599 2019-01-07 Richard Sandiford <richard.sandiford@arm.com>
10600
10601 * tree-vect-stmts.c (vectorizable_store): Don't use the dataref_offset
10602 optimization for masked stores.
10603
10604 2019-01-07 Richard Sandiford <richard.sandiford@arm.com>
10605
10606 PR middle-end/88567
10607 * tree-vect-loop.c (get_initial_defs_for_reduction): Pass the
10608 output vector directly to duplicate_and_interleave instead of
10609 going through a temporary. Postpone insertion of ctor_seq to
10610 the end of the loop.
10611
10612 2019-01-07 Richard Earnshaw <rearnsha@arm.com>
10613
10614 PR target/86891
10615 * config/aarch64/aarch64.c (aarch64_expand_subvti): New parameter
10616 unsigned_p. Handle signed and unsigned overflow correction as
10617 required.
10618 * config/aarch64/aarch64-protos.h (aarch64_expand_subvti): Update
10619 prototype.
10620 * config/aarch64/aarch64.md (addv<mode>4): Use aarch64_plus_operand
10621 for operand 2.
10622 (add<mode>3_compareV_imm): Make this callable for expanding.
10623 (subv<GPI:mode>4): Use register_operand for operand 1. Use
10624 aarch64_plus_operand for operand 2.
10625 (subv<GPI:mode>_insn): New insn pattern.
10626 (subv<GPI:mode>_imm): Likewise.
10627 (negv<GPI:mode>3): New expand pattern.
10628 (negv<GPI:mode>_insn): New insn pattern.
10629 (negv<GPI:mode>_cmp_only): Likewise.
10630 (cmpv<GPI:mode>_insn): Likewise.
10631 (subvti4): Use register_operand for operand 1. Update call to
10632 aarch64_expand_subvti.
10633 (usubvti4): Likewise.
10634 (negvti3): New expand pattern.
10635 (negdi_carryout): New insn pattern.
10636 (negvdi_carryinV): New insn pattern.
10637 (sub<mode3>_compare1_imm): Delete named insn pattern, make anonymous
10638 version the named version.
10639 (peepholes to convert to sub<mode3>_compare1_imm): Adjust order of
10640 operands.
10641 (usub<GPI:mode>3_carryinC, usub<GPI:mode>3_carryinC_z1): New insn
10642 patterns.
10643 (usub<GPI:mode>3_carryinC_z2, usub<GPI:mode>3_carryinC): New insn
10644 patterns.
10645 (sub<mode>3_carryinCV, sub<mode>3_carryinCV_z1_z2): Delete.
10646 (sub<mode>3_carryinCV_z1, sub<mode>3_carryinCV_z2): Delete.
10647 (sub<mode>3_carryinCV): Delete.
10648 (sub<GPI:mode>3_carryinV): New expand pattern.
10649 sub<mode>3_carryinV, sub<mode>3_carryinV_z2): New insn patterns.
10650
10651 2019-01-07 Richard Biener <rguenther@suse.de>
10652
10653 * tree-ssa-uncprop.c (ssa_equip_hash_traits): Remove in favor
10654 of tree_operand_hash.
10655
10656 2019-01-07 Richard Sandiford <richard.sandiford@arm.com>
10657
10658 PR tree-optimization/88598
10659 * tree.h (single_nonzero_element): Declare.
10660 * tree.c (single_nonzero_element): New function.
10661 * match.pd: Fold certain reductions of X & CST to X[I] & CST[I]
10662 if I is the only nonzero element of CST.
10663
10664 2019-01-07 Richard Sandiford <richard.sandiford@arm.com>
10665
10666 PR tree-optimization/88598
10667 * tree.h (initializer_each_zero_or_onep): Declare.
10668 * tree.c (initializer_each_zero_or_onep): New function.
10669 (signed_or_unsigned_type_for): Handle float types too.
10670 (unsigned_type_for, signed_type_for): Update comments accordingly.
10671 * match.pd: Fold x * { 0 or 1, 0 or 1, ...} to
10672 x & { 0 or -1, 0 or -1, ... }.
10673
10674 2019-01-07 Jonathan Wakely <jwakely@redhat.com>
10675
10676 * doc/install.texi: Replace references to x86_64-unknown-linux-gnu
10677 with x86_64-pc-linux-gnu.
10678
10679 2019-01-07 Tom de Vries <tdevries@suse.de>
10680
10681 PR target/85486
10682 * config/nvptx/nvptx.c (has_vector_partitionable_routine_calls_p): New
10683 function.
10684 (nvptx_goacc_validate_dims): Force vl32 if calling vector-partitionable
10685 routines.
10686
10687 2019-01-07 Jakub Jelinek <jakub@redhat.com>
10688
10689 * config/i386/sse.md (vec_extract<mode><ssehalfvecmodelower>): Use
10690 V_256_512 iterator instead of V_512 and TARGET_AVX instead of
10691 TARGET_AVX512F as condition.
10692
10693 PR debug/88723
10694 * dwarf2out.c (const_ok_for_output_1): Remove redundant call to
10695 const_not_ok_for_debug_p target hook.
10696 (mem_loc_descriptor) <case UNSPEC>: Only call const_ok_for_output_1
10697 on UNSPEC and subexpressions thereof if all subexpressions of the
10698 UNSPEC are CONSTANT_P.
10699
10700 PR tree-optimization/88676
10701 * tree-ssa-phiopt.c (two_value_replacement): New function.
10702 (tree_ssa_phiopt_worker): Call it.
10703
10704 PR sanitizer/88619
10705 * cfgexpand.c (expand_stack_vars): Only align prev_offset to
10706 ASAN_MIN_RED_ZONE_SIZE, not to maximum of that and alignb.
10707
10708 PR c++/85052
10709 * tree-vect-generic.c: Include insn-config.h and recog.h.
10710 (expand_vector_piecewise): Add defaulted ret_type argument,
10711 if non-NULL, use that in preference to type for the result type.
10712 (expand_vector_parallel): Formatting fix.
10713 (do_vec_conversion, do_vec_narrowing_conversion,
10714 expand_vector_conversion): New functions.
10715 (expand_vector_operations_1): Call expand_vector_conversion
10716 for VEC_CONVERT ifn calls.
10717 * internal-fn.def (VEC_CONVERT): New internal function.
10718 * internal-fn.c (expand_VEC_CONVERT): New function.
10719 * fold-const-call.c (fold_const_vec_convert): New function.
10720 (fold_const_call): Use it for CFN_VEC_CONVERT.
10721 * doc/extend.texi (__builtin_convertvector): Document.
10722
10723 2019-01-07 Tom de Vries <tdevries@suse.de>
10724
10725 * config/nvptx/nvptx-protos.h (nvptx_output_red_partition): Declare.
10726 * config/nvptx/nvptx.c (vector_red_size, vector_red_align,
10727 vector_red_partition, vector_red_sym): New global variables.
10728 (nvptx_option_override): Initialize vector_red_sym.
10729 (nvptx_declare_function_name): Restore red_partition register.
10730 (nvptx_file_end): Emit code to declare the vector reduction variables.
10731 (nvptx_output_red_partition): New function.
10732 (nvptx_expand_shared_addr): Add vector argument. Use it to handle
10733 large vector reductions.
10734 (enum nvptx_builtins): Add NVPTX_BUILTIN_VECTOR_ADDR.
10735 (nvptx_init_builtins): Add VECTOR_ADDR.
10736 (nvptx_expand_builtin): Update call to nvptx_expand_shared_addr.
10737 Handle nvptx_expand_shared_addr.
10738 (nvptx_get_shared_red_addr): Add vector argument and handle large
10739 vectors.
10740 (nvptx_goacc_reduction_setup): Add offload_attrs argument and handle
10741 large vectors.
10742 (nvptx_goacc_reduction_init): Likewise.
10743 (nvptx_goacc_reduction_fini): Likewise.
10744 (nvptx_goacc_reduction_teardown): Likewise.
10745 (nvptx_goacc_reduction): Update calls to nvptx_goacc_reduction_{setup,
10746 init,fini,teardown}.
10747 (nvptx_init_axis_predicate): Initialize vector_red_partition.
10748 (nvptx_set_current_function): Init vector_red_partition.
10749 * config/nvptx/nvptx.md (UNSPECV_RED_PART): New unspecv.
10750 (nvptx_red_partition): New insn.
10751 * config/nvptx/nvptx.h (struct machine_function): Add red_partition.
10752
10753 2019-01-07 Tom de Vries <tdevries@suse.de>
10754
10755 PR target/85381
10756 * config/nvptx/nvptx.c (nvptx_process_pars): Don't emit barriers for
10757 empty loops.
10758
10759 2019-01-07 Tom de Vries <tdevries@suse.de>
10760
10761 * config/nvptx/nvptx.c (oacc_bcast_partition): Declare.
10762 (nvptx_option_override): Init oacc_bcast_partition.
10763 (nvptx_init_oacc_workers): New function.
10764 (nvptx_declare_function_name): Call nvptx_init_oacc_workers.
10765 (nvptx_needs_shared_bcast): New function.
10766 (nvptx_find_par): Generalize to enable vectors to use shared-memory
10767 to propagate state.
10768 (nvptx_shared_propagate): Initialize vector bcast partition and
10769 synchronization state.
10770 (nvptx_single): Generalize to enable vectors to use shared-memory
10771 to propagate state.
10772 (nvptx_process_pars): Likewise.
10773 (nvptx_set_current_function): Initialize oacc_broadcast_partition.
10774 * config/nvptx/nvptx.h (struct machine_function): Add
10775 bcast_partition and sync_bar members.
10776
10777 2019-01-07 Tom de Vries <tdevries@suse.de>
10778
10779 * config/nvptx/nvptx.c (nvptx_welformed_vector_length_p)
10780 (nvptx_apply_dim_limits): New function.
10781 (nvptx_goacc_validate_dims_1): Allow PTX_MAX_VECTOR_LENGTH larger than
10782 PTX_WARP_SIZE.
10783
10784 2019-01-07 Tom de Vries <tdevries@suse.de>
10785
10786 * config/nvptx/nvptx.c (nvptx_goacc_validate_dims_1): Move warnings to
10787 as late as possible.
10788
10789 2019-01-07 Tom de Vries <tdevries@suse.de>
10790
10791 * config/nvptx/nvptx.c (PTX_VECTOR_LENGTH): Remove.
10792 (PTX_DEFAULT_VECTOR_LENGTH, PTX_MAX_VECTOR_LENGTH): Define.
10793 (nvptx_goacc_validate_dims_1, nvptx_dim_limit)
10794 (nvptx_goacc_reduction_fini): Use PTX_DEFAULT_VECTOR_LENGTH,
10795 PTX_MAX_VECTOR_LENGTH and PTX_WARP_SIZE instead of PTX_VECTOR_LENGTH.
10796
10797 2019-01-07 Tom de Vries <tdevries@suse.de>
10798
10799 * config/nvptx/nvptx.c (nvptx_goacc_validate_dims): Add asserts.
10800
10801 2019-01-07 Tom de Vries <tdevries@suse.de>
10802
10803 * omp-offload.c (oacc_get_min_dim): New function.
10804 * omp-offload.h (oacc_get_min_dim): Declare.
10805
10806 2018-12-26 Mateusz B <mateuszb@poczta.onet.pl>
10807
10808 PR target/88521
10809 * config/i386/i386.c (function_value_ms_64): Return small sturct in
10810 AX_REG and float/double in FIRST_SSE_REG for 4 or 8 byte modes.
10811
10812 2019-01-05 Jan Hubicka <hubicka@ucw.cz>
10813
10814 PR tree-opt/86020
10815 Revert:
10816 2017-05-22 Jan Hubicka <hubicka@ucw.cz>
10817
10818 * ipa-inline.c (edge_badness): Use inlined_time instead of
10819 inline_summaries->get.
10820
10821 2019-01-05 Jan Hubicka <hubicka@ucw.cz>
10822
10823 * opts.c (enable_fdo_optimizations): Enable
10824 version-loops-for-strides, loop-interchange, unrol-and-jam
10825 and tree-loop-distribution.
10826 * invoke.texi: Document newly enabled options.
10827
10828 2019-01-05 Jan Hubicka <hubicka@ucw.cz>
10829
10830 * doc/invoke.texi (max-inline-insns-small): New parameters.
10831 * ipa-inline.c (want_early_inline_function_p): simplify.
10832 (want_inline_small_function_p): Fix pasto from previous patch;
10833 use max-inline-insns-small bound.
10834 * params.def (max-inline-insns-small): New param.
10835 * ipa-fnsummary.c (analyze_function_body): Initialize time/size
10836 variables correctly.
10837
10838 2019-01-05 Jan Hubicka <hubicka@ucw.cz>
10839
10840 * doc/invoke.texi: Document max-inline-insns-size,
10841 uninlined-function-insns, uninlined-function-time,
10842 uninlined-thunk-insns and uninlined-thunk-time.
10843 * params.def: Add max-inline-insns-size,
10844 uninlined-function-insns, uninlined-function-time,
10845 uninlined-thunk-insns and uninlined-thunk-time.
10846 * ipa-fnsummary.c (compute_fn_summary, analyze_function_body): Use
10847 new parameters.
10848 * ipa-inline.c (can_inline_edge_by_limits_p,
10849 want_inline_small_function_p): Use new parameters.
10850
10851 2019-01-05 Jan Hubicka <hubicka@ucw.cz>
10852
10853 * ipa-fnsummary.c (analyze_function_body): Fix accounting of time.
10854
10855 2019-01-05 Jakub Jelinek <jakub@redhat.com>
10856
10857 PR middle-end/82564
10858 PR target/88620
10859 * expr.c (expand_assignment): For calls returning VLA structures
10860 if to_rtx is not a MEM, force it into a stack temporary.
10861
10862 PR debug/88635
10863 * dwarf2out.c (const_ok_for_output_1): Reject MINUS that contains
10864 SYMBOL_REF, CODE_LABEL or UNSPEC in subexpressions of second argument.
10865 Reject PLUS that contains SYMBOL_REF, CODE_LABEL or UNSPEC in
10866 subexpressions of both operands.
10867 (mem_loc_descriptor): Handle UNSPEC if target hook acks it and all the
10868 subrtxes are CONSTANT_P.
10869 * config/i386/i386.c (ix86_const_not_ok_for_debug_p): Revert
10870 2018-11-09 changes.
10871
10872 2019-01-04 Jan Hubicka <hubicka@ucw.cz>
10873
10874 * params.def (hot-bb-count-ws-permille): Set to 990.
10875
10876 2019-01-04 Martin Sebor <msebor@redhat.com>
10877
10878 PR c/88546
10879 * attribs.c (decls_mismatched_attributes): Avoid warning for attribute
10880 leaf.
10881
10882 2019-01-04 Martin Sebor <msebor@redhat.com>
10883
10884 PR c/88363
10885 * doc/extend.texi (attribute alloc_align, alloc_size): Update.
10886
10887 2019-01-04 Jakub Jelinek <jakub@redhat.com>
10888
10889 * gdbinit.in: Turn off pagination for the skip commands, restore
10890 it to previous state afterwards.
10891
10892 2019-01-04 Jakub Jelinek <jakub@redhat.com>
10893
10894 PR target/88594
10895 * config/i386/i386.c (ix86_expand_divmod_libfunc): Use mode instead
10896 of GET_MODE (opN) as modes of the libcall arguments.
10897
10898 2019-01-04 Jan Beulich <jbeulich@suse.com>
10899
10900 * config/i386/sse.md
10901 (<avx512>_cmp<mode>3<mask_scalar_merge_name><round_saeonly_name>,
10902 <avx512>_cmp<mode>3<mask_scalar_merge_name>,
10903 <avx512>_ucmp<mode>3<mask_scalar_merge_name>,
10904 <avx512>_ucmp<mode>3<mask_scalar_merge_name>,
10905 avx512f_vmcmp<mode>3<round_saeonly_name>,
10906 avx512f_vmcmp<mode>3_mask<round_saeonly_name>,
10907 avx512f_maskcmp<mode>3,
10908 <avx512>_cvt<ssemodesuffix>2mask<mode>,
10909 <avx512>_cvt<ssemodesuffix>2mask<mode>,
10910 *<avx512>_cvtmask2<ssemodesuffix><mode>,
10911 *<avx512>_cvtmask2<ssemodesuffix><mode>,
10912 <avx512>_eq<mode>3<mask_scalar_merge_name>_1,
10913 <avx512>_eq<mode>3<mask_scalar_merge_name>_1,
10914 <avx512>_gt<mode>3<mask_scalar_merge_name>,
10915 <avx512>_gt<mode>3<mask_scalar_merge_name>,
10916 <avx512>_testm<mode>3<mask_scalar_merge_name>,
10917 <avx512>_testnm<mode>3<mask_scalar_merge_name>,
10918 *<avx512>_testm<VI1248_AVX512VLBW:mode>3_zext,
10919 *<avx512>_testm<VI1248_AVX512VLBW:mode>3_zext_mask,
10920 *<avx512>_testnm<VI1248_AVX512VLBW:mode>3_zext,
10921 *<avx512>_testnm<VI1248_AVX512VLBW:mode>3_zext_mask,
10922 avx512cd_maskb_vec_dup<mode>,
10923 avx512cd_maskw_vec_dup<mode>,
10924 avx512dq_fpclass<mode><mask_scalar_merge_name>,
10925 avx512dq_vmfpclass<mode>,
10926 avx512vl_vpshufbitqmb<mode><mask_scalar_merge_name>): Use =k
10927 instead of =Yk.
10928
10929 2019-01-03 Martin Sebor <msebor@redhat.com>
10930
10931 PR tree-optimization/88659
10932 * calls.c (maybe_warn_nonstring_arg): Avoid assuming maxlen is set.
10933
10934 2019-01-03 Aaron Sawdey <acsawdey@linux.ibm.com>
10935
10936 * config/rs6000/rs6000-string.c (expand_block_move): Don't use
10937 unaligned vsx and avoid lxvd2x/stxvd2x.
10938 (gen_lvx_v4si_move): New function.
10939
10940 2019-01-03 Tom de Vries <tdevries@suse.de>
10941
10942 * config/nvptx/nvptx.c (MACH_VECTOR_LENGTH, MACH_MAX_WORKERS): Define.
10943 (init_axis_dim, nvptx_mach_max_workers, nvptx_mach_vector_length): New
10944 function.
10945 * config/nvptx/nvptx.h (struct machine_function): Add axis_dims.
10946
10947 2019-01-03 Tom de Vries <tdevries@suse.de>
10948
10949 * config/nvptx/nvptx.c (struct offload_attrs): New.
10950 (populate_offload_attrs): New function. Factor mask extraction out of
10951 nvptx_reorg. Add extraction of dimensions.
10952 (nvptx_reorg): Use populate_offload_attrs.
10953
10954 2019-01-03 Tom de Vries <tdevries@suse.de>
10955
10956 * config/nvptx/nvptx.c (nvptx_goacc_validate_dims_1): Add early-out
10957 cases for oacc_min_dims_p and routine_p. Add asserts for
10958 oacc_default_dims_p and offload_region_p.
10959
10960 2019-01-03 Tom de Vries <tdevries@suse.de>
10961
10962 * config/nvptx/nvptx.c (nvptx_goacc_validate_dims_1): New function,
10963 factored out of ...
10964 (nvptx_goacc_validate_dims): ... here.
10965
10966 2019-01-03 Jan Hubicka <hubicka@ucw.cz>
10967
10968 PR tree-optimization/85574
10969 * tree-ssa-uncprop.c (struct equiv_hash_elt): Remove unused
10970 structure.
10971 (struct ssa_equip_hash_traits): Declare.
10972 (val_ssa_equiv): Use custom hash traits using operand_equal_p.
10973
10974 2019-01-03 Jakub Jelinek <jakub@redhat.com>
10975
10976 PR debug/88644
10977 * dwarf2out.c (modified_type_die): If type is equal to sizetype,
10978 change it to qualified_type.
10979
10980 2019-01-03 Jan Hubicka <hubicka@ucw.cz>
10981
10982 * ipa-utils.c (scale_ipa_profile_for_fn): Break out from ...
10983 (ipa_merge_profiles): ... here; do not ICE on thunks and aliases.
10984
10985 2019-01-02 Martin Sebor <msebor@redhat.com>
10986 Jeff Law <law@redhat.com>
10987
10988 * gimple-fold.c (strlen_range_kind): Remove SRK_LENRANGE_2.
10989 (get_range_strlen_tree): Update appropriately.
10990 (get_range_strlen)
10991 * gimple-fold.h (get_range_strlen): Drop unused last argument.
10992
10993 * gimple-fold.c (gimple_fold_builtin_strlen): Use set_strlen_range
10994 rather than set_range_info.
10995 * tree-ssa-strlen.c (set_strlen_range): Extracted from
10996 maybe_set_strlen_range. Handle potentially boundary crossing
10997 cases more conservatively.
10998 (maybe_set_strlen_range): Parts refactored into set_strlen_range.
10999 Call set_strlen_range.
11000 * tree-ssa-strlen.h (set_strlen_range): Add prototype.
11001
11002 PR middle-end/88663
11003 * gimple-fold.c (get_range_strlen): Update prototype to no longer
11004 need the flexp argument.
11005 (get_range_strlen_tree): Drop flexp argument. Drop flexp argument
11006 from calls to get_range_strlen. Update comments. Just update
11007 VAL for an unterminated const char array and let the reset of the
11008 code handle it normally. No longer try to set *flexp. Adjust
11009 return value.
11010 (get_range_strlen): Update for the new get_range_strlen API.
11011 (get_maxval_strlen): Similarly.
11012 (gimple_fold_builtin_strlen): Handle update meaning of return value
11013 from get_range_strlen.
11014 * gimple-ssa-sprintf.c (get_string_length): Update for the new
11015 get_range_strlen API.
11016
11017 2019-01-02 Jan Hubicka <hubicka@ucw.cz>
11018
11019 PR lto/88130
11020 * varpool.c (varpool_node::ctor_useable_for_folding_p): Also return
11021 false at WPA time when body was removed.
11022
11023 2019-01-02 Martin Liska <mliska@suse.cz>
11024
11025 PR tree-optimization/88650
11026 * predict.c (set_even_probabilities): Calculate probability
11027 remainer only when really used.
11028
11029 2019-01-02 Richard Biener <rguenther@suse.de>
11030
11031 PR middle-end/88651
11032 * tree-data-ref.c (analyze_subscript_affine_affine): Use
11033 widest_ints when mangling max_stmt_execution results.
11034
11035 2019-01-02 Richard Biener <rguenther@suse.de>
11036
11037 PR tree-optimization/88621
11038 * tree-ssa-loop-im.c (gather_mem_refs_stmt): Fix pastos, avoid
11039 bitfields when canoncalizing.
11040
11041 2019-01-02 Richard Biener <rguenther@suse.de>
11042
11043 PR target/87545
11044 * config/i386/x86-tune-costs.h (intel_cost): Adjust
11045 cost of cheap SSE instruction.
11046
11047 2019-01-02 Richard Biener <rguenther@suse.de>
11048
11049 PR ipa/85574
11050 * ipa-icf.h (sem_item_optimizer::sort_congruence_split): Declare.
11051 * ipa-icf.c (sem_item_optimizer::sort_congruence_split): New
11052 function.
11053 (sem_item_optimizer::do_congruence_step_f): Sort the congruence
11054 set after UIDs before splitting them.
11055
11056 2019-01-01 Martin Sebor <msebor@redhat.com>
11057 Jeff Law <law@redhat.com>
11058
11059 * gimple-fold.c (get_range_strlen_tree): Record if the computed
11060 length is optimistic. If it is, then arrange to compute the
11061 conservative length as well.
11062
11063 * gimple-fold.h (get_range_strlen): Update prototype.
11064 * builtins.c (check_access): Update call to get_range_strlen to use
11065 c_strlen_data pointer. Change various variable accesses to instead
11066 pull data from the c_strlen_data structure.
11067 (check_strncat_sizes, expand_builtin_strncat): Likewise.
11068 * calls.c (maybe_warn_nonstring_arg): Likewise.
11069 * tree-ssa-strlen.c (maybe_diag_stxncpy_trunc): Likewise. Reset
11070 minimum length if maximum lengh is unknown.
11071 * gimple-ssa-sprintf.c (get_string_length): Likewise. Drop code
11072 that used c_strlen, it's no longer needed. Restructure slightly.
11073 (format_string): Set unlikely range appropriately.
11074 * gimple-fold.c (get_range_strlen): Update comments. Fix minor
11075 formatting issues.
11076 (get_range_strlen): Accept c_strlen_data pointer for external
11077 call sites as well. Pass through to call to internal get_range_strlen.
11078 Adjust minlen, maxlen and maxbound as needed.
11079 (get_maxval_strlen): Update comments.
11080 (gimple_fold_builtin_strlen): Update call to get_range_strlen
11081 to use c_strlen_data pointer. Change variable accesses to instead
11082 use c_strlen_data data members.
11083
11084 * gimple-fold.c (get_range_strlen): Update prototype.
11085 (get_range_strlen_tree): Update prototype. Drop minlen/maxlen
11086 local variables. Use pdata to return information to caller.
11087 Update calls to get_range_strlen. Update pdata->maxbound.
11088 (get_range_strlen -- static version): Similarly.
11089 (get_range_strlen -- extern version): Update for internal
11090 get_range_strlen API change. Convert to external data format.
11091 (get_maxval_strlen): Similarly.
11092
11093 2019-01-01 Jan Hubicka <hubicka@ucw.cz>
11094
11095 * coverage.c (get_coverage_counts): Use current_function_decl.
11096 * profile.c (read_thunk_profile): New function.
11097 (branch_prob): Add THUNK parameter.
11098 * tree-profile.c (tree_profiling): Handle thunks.
11099 * value-prof.c (init_node_map): Handle thunks.
11100 * value-prof.h (branch_prob): Upate prototype.
11101 (read_thunk_profile): Declare.
11102
11103 2019-01-01 Jakub Jelinek <jakub@redhat.com>
11104
11105 Update copyright years.
11106
11107 * gcc.c (process_command): Update copyright notice dates.
11108 * gcov-dump.c (print_version): Ditto.
11109 * gcov.c (print_version): Ditto.
11110 * gcov-tool.c (print_version): Ditto.
11111 * gengtype.c (create_file): Ditto.
11112 * doc/cpp.texi: Bump @copying's copyright year.
11113 * doc/cppinternals.texi: Ditto.
11114 * doc/gcc.texi: Ditto.
11115 * doc/gccint.texi: Ditto.
11116 * doc/gcov.texi: Ditto.
11117 * doc/install.texi: Ditto.
11118 * doc/invoke.texi: Ditto.
11119 \f
11120 Copyright (C) 2019 Free Software Foundation, Inc.
11121
11122 Copying and distribution of this file, with or without modification,
11123 are permitted in any medium without royalty provided the copyright
11124 notice and this notice are preserved.