5f27a8a08aedfb1def38216f6cd107ecd51028bc
[gcc.git] / gcc / ChangeLog
1 2020-04-23 Andrew Stubbs <ams@codesourcery.com>
2
3 * config/gcn/gcn-valu.md (mov<mode>_exec): Swap the numbers on operands
4 2 and 3.
5 (mov<mode>_exec): Likewise.
6 (trunc<vndi><mode>2_exec): Swap parameters to gen_mov<mode>_exec.
7 (<convop><mode><vndi>2_exec): Likewise.
8
9 2019-04-23 Eric Botcazou <ebotcazou@adacore.com>
10
11 PR tree-optimization/94717
12 * gimple-ssa-store-merging.c (try_coalesce_bswap): Return false if one
13 of the stores doesn't have the same landing pad number as the first.
14 (coalesce_immediate_stores): Do not try to coalesce the store using
15 bswap if it doesn't have the same landing pad number as the first.
16
17 2020-04-23 Bill Schmidt <wschmidt@linux.ibm.com>
18
19 * gcc/doc/extend.texi (PowerPC AltiVec/VSX Built-in Functions):
20 Replace outdated link to ELFv2 ABI.
21
22 2020-04-23 Jakub Jelinek <jakub@redhat.com>
23
24 PR target/94710
25 * optabs.c (expand_vec_perm_const): For shift_amt const0_rtx
26 just return v2.
27
28 PR middle-end/94724
29 * tree.c (get_narrower): Instead of creating COMPOUND_EXPRs
30 temporarily with non-final second operand and updating it later,
31 push COMPOUND_EXPRs into a vector and process it in reverse,
32 creating COMPOUND_EXPRs with the final operands.
33
34 2020-04-23 Szabolcs Nagy <szabolcs.nagy@arm.com>
35
36 PR target/94697
37 * config/aarch64/aarch64-bti-insert.c (rest_of_insert_bti): Swap
38 bti c and bti j handling.
39
40 2020-04-23 Andrew Stubbs <ams@codesourcery.com>
41 Thomas Schwinge <thomas@codesourcery.com>
42
43 PR middle-end/93488
44
45 * omp-expand.c (expand_omp_target): Use force_gimple_operand_gsi on
46 t_async and the wait arguments.
47
48 2020-04-23 Richard Sandiford <richard.sandiford@arm.com>
49
50 PR tree-optimization/94727
51 * tree-vect-stmts.c (vectorizable_comparison): Use mask_type when
52 comparing invariant scalar booleans.
53
54 2020-04-23 Matthew Malcomson <matthew.malcomson@arm.com>
55 Jakub Jelinek <jakub@redhat.com>
56
57 PR target/94383
58 * config/aarch64/aarch64.c (aapcs_vfp_sub_candidate): Account for C++17
59 empty base class artificial fields.
60 (aarch64_vfp_is_call_or_return_candidate): Warn when ABI PCS decision is
61 different after this fix.
62
63 2020-04-23 Jakub Jelinek <jakub@redhat.com>
64
65 PR target/94707
66 * config/rs6000/rs6000-call.c (rs6000_discover_homogeneous_aggregate):
67 Use TYPE_UID (TYPE_MAIN_VARIANT (type)) instead of type to check
68 if the same type has been diagnosed most recently already.
69
70 2020-04-23 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
71
72 * config/arm/arm_mve.h (__arm_vbicq_n_u16): Modify function parameter's
73 datatype.
74 (__arm_vbicq_n_s16): Likewise.
75 (__arm_vbicq_n_u32): Likewise.
76 (__arm_vbicq_n_s32): Likewise.
77 (__arm_vbicq): Likewise.
78 (__arm_vbicq_n_s16): Modify MVE polymorphic variant argument's datatype.
79 (__arm_vbicq_n_s32): Likewise.
80 (__arm_vbicq_n_u16): Likewise.
81 (__arm_vbicq_n_u32): Likewise.
82 (__arm_vdupq_m_n_s8): Likewise.
83 (__arm_vdupq_m_n_s16): Likewise.
84 (__arm_vdupq_m_n_s32): Likewise.
85 (__arm_vdupq_m_n_u8): Likewise.
86 (__arm_vdupq_m_n_u16): Likewise.
87 (__arm_vdupq_m_n_u32): Likewise.
88 (__arm_vdupq_m_n_f16): Likewise.
89 (__arm_vdupq_m_n_f32): Likewise.
90 (__arm_vldrhq_gather_offset_s16): Likewise.
91 (__arm_vldrhq_gather_offset_s32): Likewise.
92 (__arm_vldrhq_gather_offset_u16): Likewise.
93 (__arm_vldrhq_gather_offset_u32): Likewise.
94 (__arm_vldrhq_gather_offset_f16): Likewise.
95 (__arm_vldrhq_gather_offset_z_s16): Likewise.
96 (__arm_vldrhq_gather_offset_z_s32): Likewise.
97 (__arm_vldrhq_gather_offset_z_u16): Likewise.
98 (__arm_vldrhq_gather_offset_z_u32): Likewise.
99 (__arm_vldrhq_gather_offset_z_f16): Likewise.
100 (__arm_vldrhq_gather_shifted_offset_s16): Likewise.
101 (__arm_vldrhq_gather_shifted_offset_s32): Likewise.
102 (__arm_vldrhq_gather_shifted_offset_u16): Likewise.
103 (__arm_vldrhq_gather_shifted_offset_u32): Likewise.
104 (__arm_vldrhq_gather_shifted_offset_f16): Likewise.
105 (__arm_vldrhq_gather_shifted_offset_z_s16): Likewise.
106 (__arm_vldrhq_gather_shifted_offset_z_s32): Likewise.
107 (__arm_vldrhq_gather_shifted_offset_z_u16): Likewise.
108 (__arm_vldrhq_gather_shifted_offset_z_u32): Likewise.
109 (__arm_vldrhq_gather_shifted_offset_z_f16): Likewise.
110 (__arm_vldrwq_gather_offset_s32): Likewise.
111 (__arm_vldrwq_gather_offset_u32): Likewise.
112 (__arm_vldrwq_gather_offset_f32): Likewise.
113 (__arm_vldrwq_gather_offset_z_s32): Likewise.
114 (__arm_vldrwq_gather_offset_z_u32): Likewise.
115 (__arm_vldrwq_gather_offset_z_f32): Likewise.
116 (__arm_vldrwq_gather_shifted_offset_s32): Likewise.
117 (__arm_vldrwq_gather_shifted_offset_u32): Likewise.
118 (__arm_vldrwq_gather_shifted_offset_f32): Likewise.
119 (__arm_vldrwq_gather_shifted_offset_z_s32): Likewise.
120 (__arm_vldrwq_gather_shifted_offset_z_u32): Likewise.
121 (__arm_vldrwq_gather_shifted_offset_z_f32): Likewise.
122 (__arm_vdwdupq_x_n_u8): Likewise.
123 (__arm_vdwdupq_x_n_u16): Likewise.
124 (__arm_vdwdupq_x_n_u32): Likewise.
125 (__arm_viwdupq_x_n_u8): Likewise.
126 (__arm_viwdupq_x_n_u16): Likewise.
127 (__arm_viwdupq_x_n_u32): Likewise.
128 (__arm_vidupq_x_n_u8): Likewise.
129 (__arm_vddupq_x_n_u8): Likewise.
130 (__arm_vidupq_x_n_u16): Likewise.
131 (__arm_vddupq_x_n_u16): Likewise.
132 (__arm_vidupq_x_n_u32): Likewise.
133 (__arm_vddupq_x_n_u32): Likewise.
134 (__arm_vldrdq_gather_offset_s64): Likewise.
135 (__arm_vldrdq_gather_offset_u64): Likewise.
136 (__arm_vldrdq_gather_offset_z_s64): Likewise.
137 (__arm_vldrdq_gather_offset_z_u64): Likewise.
138 (__arm_vldrdq_gather_shifted_offset_s64): Likewise.
139 (__arm_vldrdq_gather_shifted_offset_u64): Likewise.
140 (__arm_vldrdq_gather_shifted_offset_z_s64): Likewise.
141 (__arm_vldrdq_gather_shifted_offset_z_u64): Likewise.
142 (__arm_vidupq_m_n_u8): Likewise.
143 (__arm_vidupq_m_n_u16): Likewise.
144 (__arm_vidupq_m_n_u32): Likewise.
145 (__arm_vddupq_m_n_u8): Likewise.
146 (__arm_vddupq_m_n_u16): Likewise.
147 (__arm_vddupq_m_n_u32): Likewise.
148 (__arm_vidupq_n_u16): Likewise.
149 (__arm_vidupq_n_u32): Likewise.
150 (__arm_vidupq_n_u8): Likewise.
151 (__arm_vddupq_n_u16): Likewise.
152 (__arm_vddupq_n_u32): Likewise.
153 (__arm_vddupq_n_u8): Likewise.
154
155 2020-04-23 Iain Buclaw <ibuclaw@gdcproject.org>
156
157 * doc/install.texi (D-Specific Options): Document
158 --enable-libphobos-checking and --with-libphobos-druntime-only.
159
160 2020-04-23 Jakub Jelinek <jakub@redhat.com>
161
162 PR target/94707
163 * config/rs6000/rs6000-call.c (rs6000_aggregate_candidate): Add
164 cxx17_empty_base_seen argument. Pass it to recursive calls.
165 Ignore cxx17_empty_base_field_p fields after setting
166 *cxx17_empty_base_seen to true.
167 (rs6000_discover_homogeneous_aggregate): Adjust
168 rs6000_aggregate_candidate caller. With -Wpsabi, diagnose homogeneous
169 aggregates with C++17 empty base fields.
170
171 PR c/94705
172 * attribs.c (decl_attribute): Don't diagnose attribute exclusions
173 if last_decl is error_mark_node or has such a TREE_TYPE.
174
175 PR c/94705
176 * attribs.c (decl_attribute): Don't diagnose attribute exclusions
177 if last_decl is error_mark_node or has such a TREE_TYPE.
178
179 2020-04-22 Felix Yang <felix.yang@huawei.com>
180
181 PR target/94678
182 * config/aarch64/aarch64.h (TARGET_SVE):
183 Add && !TARGET_GENERAL_REGS_ONLY.
184 (TARGET_SVE2): Add && TARGET_SVE.
185 (TARGET_SVE2_AES, TARGET_SVE2_BITPERM, TARGET_SVE2_SHA3,
186 TARGET_SVE2_SM4): Add && TARGET_SVE2.
187 * config/aarch64/aarch64-sve-builtins.h
188 (sve_switcher::m_old_general_regs_only): New member.
189 * config/aarch64/aarch64-sve-builtins.cc (check_required_registers):
190 New function.
191 (reported_missing_registers_p): New variable.
192 (check_required_extensions): Call check_required_registers before
193 return if all required extenstions are present.
194 (sve_switcher::sve_switcher): Save TARGET_GENERAL_REGS_ONLY in
195 m_old_general_regs_only and clear MASK_GENERAL_REGS_ONLY in
196 global_options.x_target_flags.
197 (sve_switcher::~sve_switcher): Set MASK_GENERAL_REGS_ONLY in
198 global_options.x_target_flags if m_old_general_regs_only is true.
199
200 2020-04-22 Zackery Spytz <zspytz@gmail.com>
201
202 * doc/extend.exi: Add "free" to list of other builtin functions
203 supported by GCC.
204
205 2020-04-20 Aaron Sawdey <acsawdey@linux.ibm.com>
206
207 PR target/94622
208 * config/rs6000/sync.md (load_quadpti): Add attr "prefixed"
209 if TARGET_PREFIXED.
210 (store_quadpti): Ditto.
211 (atomic_load<mode>): Do not swap doublewords if TARGET_PREFIXED as
212 plq will be used and doesn't need it.
213 (atomic_store<mode>): Ditto, for pstq.
214
215 2020-04-22 Erick Ochoa <erick.ochoa@theobroma-systems.com>
216
217 * doc/invoke.texi: Update flags turned on by -O3.
218
219 2020-04-22 Jakub Jelinek <jakub@redhat.com>
220
221 PR target/94706
222 * config/ia64/ia64.c (hfa_element_mode): Ignore
223 cxx17_empty_base_field_p fields.
224
225 PR target/94383
226 * calls.h (cxx17_empty_base_field_p): Declare.
227 * calls.c (cxx17_empty_base_field_p): Define.
228
229 2020-04-22 Christophe Lyon <christophe.lyon@linaro.org>
230
231 * doc/sourcebuild.texi (arm_softfp_ok, arm_hard_ok): Document.
232
233 2020-04-22 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
234 Andre Vieira <andre.simoesdiasvieira@arm.com>
235 Mihail Ionescu <mihail.ionescu@arm.com>
236
237 * config/arm/arm.c (arm_file_start): Handle isa_bit_quirk_no_asmcpu.
238 * config/arm/arm-cpus.in (quirk_no_asmcpu): Define.
239 (ALL_QUIRKS): Add quirk_no_asmcpu.
240 (cortex-m55): Define new cpu.
241 * config/arm/arm-tables.opt: Regenerate.
242 * config/arm/arm-tune.md: Likewise.
243 * doc/invoke.texi (Arm Options): Document -mcpu=cortex-m55.
244
245 2020-04-22 Richard Sandiford <richard.sandiford@arm.com>
246
247 PR tree-optimization/94700
248 * tree-ssa-forwprop.c (simplify_vector_constructor): When processing
249 an identity constructor, use a VIEW_CONVERT_EXPR to handle mixtures
250 of similarly-structured but distinct vector types.
251
252 2020-04-21 Martin Sebor <msebor@redhat.com>
253
254 PR middle-end/94647
255 * gimple-ssa-warn-restrict.c (builtin_access::builtin_access): Correct
256 the computation of the lower bound of the source access size.
257 (builtin_access::generic_overlap): Remove a hack for setting ranges
258 of overlap offsets.
259
260 2020-04-21 John David Anglin <danglin@gcc.gnu.org>
261
262 * config/pa/som.h (ASM_WEAKEN_LABEL): Delete.
263 (ASM_WEAKEN_DECL): New define.
264 (HAVE_GAS_WEAKREF): Undefine.
265
266 2020-04-21 Richard Sandiford <richard.sandiford@arm.com>
267
268 PR tree-optimization/94683
269 * tree-ssa-forwprop.c (simplify_vector_constructor): Use a
270 VIEW_CONVERT_EXPR to handle mixtures of similarly-structured
271 but distinct vector types.
272
273 2020-04-21 Jakub Jelinek <jakub@redhat.com>
274
275 PR c/94641
276 * stor-layout.c (place_field, finalize_record_size): Don't emit
277 -Wpadded warning on TYPE_ARTIFICIAL rli->t.
278 * ubsan.c (ubsan_get_type_descriptor_type,
279 ubsan_get_source_location_type, ubsan_create_data): Set
280 TYPE_ARTIFICIAL.
281 * asan.c (asan_global_struct): Likewise.
282
283 2020-04-21 Duan bo <duanbo3@huawei.com>
284
285 PR target/94577
286 * config/aarch64/aarch64.c: Add an error message for option conflict.
287 * doc/invoke.texi (-mcmodel=large): Mention that -mcmodel=large is
288 incompatible with -fpic, -fPIC and -mabi=ilp32.
289
290 2020-04-21 Frederik Harwath <frederik@codesourcery.com>
291
292 PR other/94629
293 * omp-low.c (new_omp_context): Remove assignments to
294 ctx->outer_reduction_clauses and ctx->local_reduction_clauses.
295
296 2020-04-20 Andreas Krebbel <krebbel@linux.ibm.com>
297
298 * config/s390/vector.md ("popcountv8hi2_vx", "popcountv4si2_vx")
299 ("popcountv2di2_vx"): Use simplify_gen_subreg.
300
301 2020-04-20 Andreas Krebbel <krebbel@linux.ibm.com>
302
303 PR target/94613
304 * config/s390/s390-builtin-types.def: Add 3 new function modes.
305 * config/s390/s390-builtins.def: Add mode dependent low-level
306 builtin and map the overloaded builtins to these.
307 * config/s390/vx-builtins.md ("vec_selV_HW"): Rename to ...
308 ("vsel<V_HW"): ... this and rewrite the pattern with bitops.
309
310 2020-04-20 Richard Sandiford <richard.sandiford@arm.com>
311
312 * tree-vect-loop.c (vect_better_loop_vinfo_p): If old_loop_vinfo
313 has a variable VF, prefer new_loop_vinfo if it is cheaper for the
314 estimated VF and is no worse at double the estimated VF.
315
316 2020-04-20 Richard Sandiford <richard.sandiford@arm.com>
317
318 PR target/94668
319 * config/aarch64/aarch64.c (aarch64_sve_expand_vector_init): Fix
320 order of arguments to rtx_vector_builder.
321 (aarch64_sve_expand_vector_init_handle_trailing_constants): Likewise.
322 When extending the trailing constants to a full vector, replace any
323 variables with zeros.
324
325 2020-04-20 Jan Hubicka <hubicka@ucw.cz>
326
327 PR ipa/94582
328 * tree-inline.c (optimize_inline_calls): Recompute calls_comdat_local
329 flag.
330
331 2020-04-20 Martin Liska <mliska@suse.cz>
332
333 * symtab.c (symtab_node::dump_references): Add space after
334 one entry.
335 (symtab_node::dump_referring): Likewise.
336
337 2020-04-18 Jeff Law <law@redhat.com>
338
339 PR debug/94439
340 * regrename.c (check_new_reg_p): Ignore DEBUG_INSNs when walking
341 the chain.
342
343 2020-04-18 Iain Buclaw <ibuclaw@gdcproject.org>
344
345 * doc/sourcebuild.texi (Effective-Target Keywords, Environment
346 attributes): Document d_runtime_has_std_library.
347
348 2020-04-17 Jeff Law <law@redhat.com>
349
350 PR rtl-optimization/90275
351 * cse.c (cse_insn): Avoid recording nop sets in multi-set parallels
352 when the destination has a REG_UNUSED note.
353
354 2020-04-17 Tobias Burnus <tobias@codesourcery.com>
355
356 PR middle-end/94635
357 * gimplify.c (gimplify_scan_omp_clauses): Turn MAP_TO_PSET to
358 MAP_DELETE.
359
360 2020-04-17 Richard Sandiford <richard.sandiford@arm.com>
361
362 * config/aarch64/aarch64.c (aarch64_advsimd_ldp_stp_p): New function.
363 (aarch64_sve_adjust_stmt_cost): Add a vectype parameter. Double the
364 cost of load and store insns if one loop iteration has enough scalar
365 elements to use an Advanced SIMD LDP or STP.
366 (aarch64_add_stmt_cost): Update call accordingly.
367
368 2020-04-17 Jakub Jelinek <jakub@redhat.com>
369 Jeff Law <law@redhat.com>
370
371 PR target/94567
372 * config/i386/i386.md (*testqi_ext_3): Use CCZmode rather than
373 CCNOmode in ix86_match_ccmode if len is equal to <MODE>mode precision,
374 or pos + len >= 32, or pos + len is equal to operands[2] precision
375 and operands[2] is not a register operand. During splitting perform
376 SImode AND if operands[0] doesn't have CCZmode and pos + len is
377 equal to mode precision.
378
379 2020-04-17 Richard Biener <rguenther@suse.de>
380
381 PR other/94629
382 * cgraphclones.c (cgraph_node::create_clone): Remove duplicate
383 initialization.
384 * dwarf2out.c (dw_val_equal_p): Fix pasto in
385 dw_val_class_vms_delta comparison.
386 * optabs.c (expand_binop_directly): Fix pasto in commutation
387 check.
388 * tree-ssa-sccvn.c (vn_reference_lookup_pieces): Fix pasto in
389 initialization.
390
391 2020-04-17 Jakub Jelinek <jakub@redhat.com>
392
393 PR rtl-optimization/94618
394 * cfgrtl.c (delete_insn_and_edges): Set purge not just when
395 insn is the BB_END of its block, but also when it is only followed
396 by DEBUG_INSNs in its block.
397
398 PR tree-optimization/94621
399 * tree-inline.c (remap_type_1): Don't dereference NULL TYPE_DOMAIN.
400 Move id->adjust_array_error_bounds check first in the condition.
401
402 2020-04-17 Martin Liska <mliska@suse.cz>
403 Jonathan Yong <10walls@gmail.com>
404
405 PR gcov-profile/94570
406 * coverage.c (coverage_init): Use separator properly.
407
408 2020-04-16 Peter Bergner <bergner@linux.ibm.com>
409
410 PR rtl-optimization/93974
411 * config/rs6000/rs6000.c (TARGET_CANNOT_SUBSTITUTE_MEM_EQUIV_P): Define.
412 (rs6000_cannot_substitute_mem_equiv_p): New function.
413
414 2020-04-16 Martin Jambor <mjambor@suse.cz>
415
416 PR ipa/93621
417 * ipa-inline.h (ipa_saved_clone_sources): Declare.
418 * ipa-inline-transform.c (ipa_saved_clone_sources): New variable.
419 (save_inline_function_body): Link the new body holder with the
420 previous one.
421 * cgraph.c: Include ipa-inline.h.
422 (cgraph_edge::redirect_call_stmt_to_callee): Try to find the decl from
423 the statement in ipa_saved_clone_sources.
424 * cgraphunit.c: Include ipa-inline.h.
425 (expand_all_functions): Free ipa_saved_clone_sources.
426
427 2020-04-16 Richard Sandiford <richard.sandiford@arm.com>
428
429 PR target/94606
430 * config/aarch64/aarch64.c (aarch64_expand_sve_const_pred_eor): Take
431 the VNx16BI lowpart of the recursively-generated constant.
432
433 2020-04-16 Martin Liska <mliska@suse.cz>
434 Jakub Jelinek <jakub@redhat.com>
435
436 PR c++/94314
437 * cgraphclones.c (set_new_clone_decl_and_node_flags): Drop
438 DECL_IS_REPLACEABLE_OPERATOR during cloning.
439 * tree-ssa-dce.c (valid_new_delete_pair_p): New function.
440 (propagate_necessity): Check operator names.
441
442 2020-04-16 Richard Sandiford <richard.sandiford@arm.com>
443
444 PR rtl-optimization/94605
445 * early-remat.c (early_remat::process_block): Handle insns that
446 set multiple candidate registers.
447 2020-04-16 Jan Hubicka <hubicka@ucw.cz>
448
449 PR gcov-profile/93401
450 * common.opt (profile-prefix-path): New option.
451 * coverae.c: Include diagnostics.h.
452 (coverage_init): Strip profile prefix path.
453 * doc/invoke.texi (-fprofile-prefix-path): Document.
454
455 2020-04-16 Richard Biener <rguenther@suse.de>
456
457 PR middle-end/94614
458 * expr.c (emit_move_multi_word): Do not generate code when
459 the destination part is undefined_operand_subword_p.
460 * lower-subreg.c (resolve_clobber): Look through a paradoxica
461 subreg.
462
463 2020-04-16 Martin Jambor <mjambor@suse.cz>
464
465 PR tree-optimization/94598
466 * tree-sra.c (verify_sra_access_forest): Fix verification of total
467 scalarization accesses under access to one-element arrays.
468
469 2020-04-16 Jakub Jelinek <jakub@redhat.com>
470
471 PR bootstrap/89494
472 * function.c (assign_parm_find_data_types): Add workaround for
473 BROKEN_VALUE_INITIALIZATION compilers.
474
475 2020-04-16 Richard Biener <rguenther@suse.de>
476
477 * gdbhooks.py (TreePrinter): Print SSA_NAME_VERSION of SSA_NAME
478 nodes.
479
480 2020-04-15 Uroš Bizjak <ubizjak@gmail.com>
481
482 PR target/94603
483 * config/i386/i386-builtin.def (__builtin_ia32_movq128):
484 Require OPTION_MASK_ISA_SSE2.
485
486 2020-04-15 Gustavo Romero <gromero@linux.ibm.com>
487
488 PR bootstrap/89494
489 * dumpfile.c (selftest::temp_dump_context::temp_dump_context):
490 Don't construct a dump_context temporary to call static method.
491
492 2020-04-15 Andrea Corallo <andrea.corallo@arm.com>
493
494 * config/aarch64/falkor-tag-collision-avoidance.c
495 (valid_src_p): Check for aarch64_address_info type before
496 accessing base field.
497
498 2020-04-15 Andre Vieira <andre.simoesdiasvieira@arm.com>
499
500 * config/arm/mve.md (mve_vec_duplicate<mode>): New pattern.
501 (V_sz_elem2): Remove unused mode attribute.
502
503 2020-04-15 Matthew Malcomson <matthew.malcomson@arm.com>
504
505 * config/arm/arm.md (arm_movdi): Disallow for MVE.
506
507 2020-04-15 Richard Biener <rguenther@suse.de>
508
509 PR middle-end/94539
510 * tree-ssa-alias.c (same_type_for_tbaa): Defer to
511 alias_sets_conflict_p for pointers.
512
513 2020-04-14 Max Filippov <jcmvbkbc@gmail.com>
514
515 PR target/94584
516 * config/xtensa/xtensa.md (zero_extendhisi2, zero_extendqisi2)
517 (extendhisi2_internal): Add %v1 before the load instructions.
518
519 2020-04-14 Aaron Sawdey <acsawdey@linux.ibm.com>
520
521 PR target/94542
522 * config/rs6000/rs6000.c (address_to_insn_form): Do not attempt to
523 use PC-relative addressing for TLS references.
524
525 2020-04-14 Martin Jambor <mjambor@suse.cz>
526
527 PR ipa/94434
528 * ipa-sra.c: Include internal-fn.h.
529 (enum isra_scan_context): Update comment.
530 (scan_function): Treat calls to internal_functions like loads or stores.
531
532 2020-04-14 Yang Yang <yangyang305@huawei.com>
533
534 PR tree-optimization/94574
535 * tree-ssa.c (non_rewritable_lvalue_p): Add size check when analyzing
536 whether a vector-insert is rewritable using a BIT_INSERT_EXPR.
537
538 2020-04-14 H.J. Lu <hongjiu.lu@intel.com>
539
540 PR target/94561
541 * config/i386/i386.c (ix86_get_ssemov): Remove mode size check.
542
543 2020-04-13 Martin Sebor <msebor@redhat.com>
544
545 * doc/extend.texi (-Wall): Mention -Wformat-overflow and
546 -Wformat-truncation. Move -Wzero-length-bounds last.
547 (-Wrestrict): Document positive form of option enabled by -Wall.
548
549 2020-04-13 Zachary Spytz <zspytz@gmail.com>
550
551 * doc/extend.texi: Add realloc to list of built-in functions
552 are recognized by the compiler.
553
554 2020-04-13 H.J. Lu <hongjiu.lu@intel.com>
555
556 PR target/94556
557 * config/i386/i386.c (ix86_expand_epilogue): Restore the frame
558 pointer in word_mode for eh_return epilogues.
559
560 2020-04-13 Jozef Lawrynowicz <jozef.l@mittosystems.com>
561
562 * config/msp430/msp430.c (msp430_print_operand): Don't add offsets to
563 memory references in %B, %C and %D operand selectors when the inner
564 operand is a post increment address.
565
566 2020-04-13 Jozef Lawrynowicz <jozef.l@mittosystems.com>
567
568 * config/msp430/msp430.c (msp430_print_operand): Offset a %C memory
569 reference by 4 bytes, and %D memory reference by 6 bytes.
570
571 2020-04-11 Uroš Bizjak <ubizjak@gmail.com>
572
573 PR target/94494
574 * config/i386/sse.md (REDUC_SSE_SMINMAX_MODE): Use TARGET_SSE2
575 condition for V4SI, V8HI and V16QI modes.
576
577 2020-04-11 Jakub Jelinek <jakub@redhat.com>
578
579 PR debug/94495
580 PR target/94551
581 * cselib.c (cselib_record_sp_cfa_base_equiv): Set PRESERVED_VALUE_P on
582 val->val_rtx.
583
584 2020-04-10 Thomas Schwinge <thomas@codesourcery.com>
585
586 PR middle-end/89433
587 PR middle-end/93465
588 * omp-general.c (oacc_verify_routine_clauses): Diagnose if
589 "#pragma omp declare target" has also been applied.
590
591 2020-04-09 Jozef Lawrynowicz <jozef.l@mittosystems.com>
592
593 * config/msp430/msp430.c (msp430_expand_epilogue): Use emit_jump_insn
594 when to emit the epilogue_helper insn.
595 * config/msp430/msp430.md (epilogue_helper): Add a return insn to the
596 RTL pattern.
597
598 2020-04-09 Jakub Jelinek <jakub@redhat.com>
599
600 PR debug/94495
601 * cselib.h (cselib_record_sp_cfa_base_equiv,
602 cselib_sp_derived_value_p): Declare.
603 * cselib.c (cselib_record_sp_cfa_base_equiv,
604 cselib_sp_derived_value_p): New functions.
605 * var-tracking.c (add_stores): Don't record MO_VAL_SET for
606 cselib_sp_derived_value_p values.
607 (vt_initialize): Call cselib_record_sp_cfa_base_equiv at the
608 start of extended basic blocks other than the first one
609 for !frame_pointer_needed functions.
610
611 2020-04-09 Richard Sandiford <richard.sandiford@arm.com>
612
613 * doc/sourcebuild.texi (aarch64_sve_hw, aarch64_sve128_hw)
614 (aarch64_sve256_hw, aarch64_sve512_hw, aarch64_sve1024_hw)
615 (aarch64_sve2048_hw): Document.
616 * config/aarch64/aarch64-protos.h
617 (aarch64_sve::handle_arm_sve_vector_bits_attribute): Declare.
618 * config/aarch64/aarch64-c.c (aarch64_update_cpp_builtins): Define
619 __ARM_FEATURE_SVE_VECTOR_OPERATIONS when SVE is enabled.
620 * config/aarch64/aarch64-sve-builtins.cc (matches_type_p): New
621 function.
622 (find_type_suffix_for_scalar_type): Use it instead of comparing
623 TYPE_MAIN_VARIANTs.
624 (function_resolver::infer_vector_or_tuple_type): Likewise.
625 (function_resolver::require_vector_type): Likewise.
626 (handle_arm_sve_vector_bits_attribute): New function.
627 * config/aarch64/aarch64.c (pure_scalable_type_info): New class.
628 (aarch64_attribute_table): Add arm_sve_vector_bits.
629 (aarch64_return_in_memory_1):
630 (pure_scalable_type_info::piece::get_rtx): New function.
631 (pure_scalable_type_info::num_zr): Likewise.
632 (pure_scalable_type_info::num_pr): Likewise.
633 (pure_scalable_type_info::get_rtx): Likewise.
634 (pure_scalable_type_info::analyze): Likewise.
635 (pure_scalable_type_info::analyze_registers): Likewise.
636 (pure_scalable_type_info::analyze_array): Likewise.
637 (pure_scalable_type_info::analyze_record): Likewise.
638 (pure_scalable_type_info::add_piece): Likewise.
639 (aarch64_some_values_include_pst_objects_p): Likewise.
640 (aarch64_returns_value_in_sve_regs_p): Use pure_scalable_type_info
641 to analyze whether the type is returned in SVE registers.
642 (aarch64_takes_arguments_in_sve_regs_p): Likwise whether the type
643 is passed in SVE registers.
644 (aarch64_pass_by_reference_1): New function, extracted from...
645 (aarch64_pass_by_reference): ...here. Use pure_scalable_type_info
646 to analyze whether the type is a pure scalable type and, if so,
647 whether it should be passed by reference.
648 (aarch64_return_in_msb): Return false for pure scalable types.
649 (aarch64_function_value_1): Fold back into...
650 (aarch64_function_value): ...this function. Use
651 pure_scalable_type_info to analyze whether the type is a pure
652 scalable type and, if so, which registers it should use. Handle
653 types that include pure scalable types but are not themselves
654 pure scalable types.
655 (aarch64_return_in_memory_1): New function, split out from...
656 (aarch64_return_in_memory): ...here. Use pure_scalable_type_info
657 to analyze whether the type is a pure scalable type and, if so,
658 whether it should be returned by reference.
659 (aarch64_layout_arg): Remove orig_mode argument. Use
660 pure_scalable_type_info to analyze whether the type is a pure
661 scalable type and, if so, which registers it should use. Handle
662 types that include pure scalable types but are not themselves
663 pure scalable types.
664 (aarch64_function_arg): Update call accordingly.
665 (aarch64_function_arg_advance): Likewise.
666 (aarch64_pad_reg_upward): On big-endian targets, return false for
667 pure scalable types that are smaller than 16 bytes.
668 (aarch64_member_type_forces_blk): New function.
669 (aapcs_vfp_sub_candidate): Exit early for built-in SVE types.
670 (aarch64_short_vector_p): Return false for VECTOR_TYPEs that
671 correspond to built-in SVE types. Do not rely on a vector mode
672 if the type includes an pure scalable type. When returning true,
673 assert that the mode is not an SVE mode.
674 (aarch64_vfp_is_call_or_return_candidate): Do not check for SVE
675 built-in types here. When returning true, assert that the type
676 does not have an SVE mode.
677 (aarch64_can_change_mode_class): Don't allow anything to change
678 between a predicate mode and a non-predicate mode. Also don't
679 allow changes between SVE vector modes and other modes that
680 might be bigger than 128 bits.
681 (aarch64_invalid_binary_op): Reject binary operations that mix
682 SVE and GNU vector types.
683 (TARGET_MEMBER_TYPE_FORCES_BLK): Define.
684
685 2020-04-09 Richard Sandiford <richard.sandiford@arm.com>
686
687 * config/aarch64/aarch64.c (aarch64_attribute_table): Add
688 "SVE sizeless type".
689 * config/aarch64/aarch64-sve-builtins.cc (make_type_sizeless)
690 (sizeless_type_p): New functions.
691 (register_builtin_types): Apply make_type_sizeless to the type.
692 (register_tuple_type): Likewise.
693 (verify_type_context): Use sizeless_type_p instead of builin_type_p.
694
695 2020-04-09 Matthew Malcomson <matthew.malcomson@arm.com>
696
697 * config/arm/arm_cde.h: Remove `extern "C"` when compiling for
698 C++.
699
700 2020-04-09 Martin Jambor <mjambor@suse.cz>
701 Richard Biener <rguenther@suse.de>
702
703 PR tree-optimization/94482
704 * tree-sra.c (create_access_replacement): Dump new replacement with
705 TDF_UID.
706 (sra_modify_expr): Fix handling of cases when the original EXPR writes
707 to only part of the replacement.
708 * tree-ssa-forwprop.c (pass_forwprop::execute): Properly verify
709 the first operand of combinations into REAL/IMAGPART_EXPR and
710 BIT_FIELD_REF.
711
712 2020-04-09 Richard Sandiford <richard.sandiford@arm.com>
713
714 * doc/sourcebuild.texi (check-function-bodies): Treat the third
715 parameter as a list of option regexps and require each regexp
716 to match.
717
718 2020-04-09 Andrea Corallo <andrea.corallo@arm.com>
719
720 PR target/94530
721 * config/aarch64/falkor-tag-collision-avoidance.c
722 (valid_src_p): Fix missing rtx type check.
723
724 2020-04-09 Bin Cheng <bin.cheng@linux.alibaba.com>
725 Richard Biener <rguenther@suse.de>
726
727 PR tree-optimization/93674
728 * tree-ssa-loop-ivopts.c (langhooks.h): New include.
729 (add_iv_candidate_for_use): For iv_use of non integer or pointer type,
730 or non-mode precision type, add candidate in unsigned type with the
731 same precision.
732
733 2020-04-08 Clement Chigot <clement.chigot@atos.net>
734
735 * config/rs6000/aix61.h (LIB_SPEC): Add -lc128 with -mlong-double-128.
736 * config/rs6000/aix71.h (LIB_SPEC): Likewise.
737 * config/rs6000/aix72.h (LIB_SPEC): Likewise.
738
739 2020-04-08 Jakub Jelinek <jakub@redhat.com>
740
741 PR middle-end/94526
742 * cselib.c (autoinc_split): Handle e->val_rtx being SP_DERIVED_VALUE_P
743 with zero offset.
744 * reload1.c (eliminate_regs_1): Avoid creating
745 (plus (reg) (const_int 0)) in DEBUG_INSNs.
746
747 PR tree-optimization/94524
748 * tree-vect-generic.c (expand_vector_divmod): If any elt of op1 is
749 negative for signed TRUNC_MOD_EXPR, multiply with absolute value of
750 op1 rather than op1 itself at the end. Punt for signed modulo by
751 most negative constant.
752 * tree-vect-patterns.c (vect_recog_divmod_pattern): Punt for signed
753 modulo by most negative constant.
754
755 2020-04-08 Richard Biener <rguenther@suse.de>
756
757 PR rtl-optimization/93946
758 * cse.c (cse_insn): Record the tabled expression in
759 src_related. Verify a redundant store removal is valid.
760
761 2020-04-08 H.J. Lu <hongjiu.lu@intel.com>
762
763 PR target/94417
764 * config/i386/i386-features.c (rest_of_insert_endbranch): Insert
765 ENDBR at function entry if function will be called indirectly.
766
767 2020-04-08 Jakub Jelinek <jakub@redhat.com>
768
769 PR target/94438
770 * config/i386/i386.c (ix86_get_mask_mode): Only use int mask for elem_size
771 1, 2, 4 and 8.
772
773 2020-04-08 Martin Liska <mliska@suse.cz>
774
775 PR c++/94314
776 * gimple.c (gimple_call_operator_delete_p): Rename to...
777 (gimple_call_replaceable_operator_delete_p): ... this.
778 Use DECL_IS_REPLACEABLE_OPERATOR_DELETE_P.
779 * gimple.h (gimple_call_operator_delete_p): Rename to ...
780 (gimple_call_replaceable_operator_delete_p): ... this.
781 * tree-core.h (tree_function_decl): Add replaceable_operator
782 flag.
783 * tree-ssa-dce.c (mark_all_reaching_defs_necessary_1):
784 Use DECL_IS_REPLACEABLE_OPERATOR_DELETE_P.
785 (propagate_necessity): Use gimple_call_replaceable_operator_delete_p.
786 (eliminate_unnecessary_stmts): Likewise.
787 * tree-streamer-in.c (unpack_ts_function_decl_value_fields):
788 Pack DECL_IS_REPLACEABLE_OPERATOR.
789 * tree-streamer-out.c (pack_ts_function_decl_value_fields):
790 Unpack the field here.
791 * tree.h (DECL_IS_REPLACEABLE_OPERATOR): New.
792 (DECL_IS_REPLACEABLE_OPERATOR_NEW_P): New.
793 (DECL_IS_REPLACEABLE_OPERATOR_DELETE_P): New.
794 * cgraph.c (cgraph_node::dump): Dump if an operator is replaceable.
795 * ipa-icf.c (sem_item::compare_referenced_symbol_properties): Compare
796 replaceable operator flags.
797
798 2020-04-08 Dennis Zhang <dennis.zhang@arm.com>
799 Matthew Malcomson <matthew.malcomson@arm.com>
800
801 * config/arm/arm-builtins.c (CX_IMM_QUALIFIERS): New macro.
802 (CX_UNARY_QUALIFIERS, CX_BINARY_QUALIFIERS): Likewise.
803 (CX_TERNARY_QUALIFIERS): Likewise.
804 (ARM_BUILTIN_CDE_PATTERN_START): Likewise.
805 (ARM_BUILTIN_CDE_PATTERN_END): Likewise.
806 (arm_init_acle_builtins): Initialize CDE builtins.
807 (arm_expand_acle_builtin): Check CDE constant operands.
808 * config/arm/arm.h (ARM_CDE_CONST_COPROC): New macro to set the range
809 of CDE constant operand.
810 * config/arm/arm.c (arm_hard_regno_mode_ok): Support DImode for
811 TARGET_VFP_BASE.
812 (ARM_VCDE_CONST_1, ARM_VCDE_CONST_2, ARM_VCDE_CONST_3): Likewise.
813 * config/arm/arm_cde.h (__arm_vcx1_u32): New macro of ACLE interface.
814 (__arm_vcx1a_u32, __arm_vcx2_u32, __arm_vcx2a_u32): Likewise.
815 (__arm_vcx3_u32, __arm_vcx3a_u32, __arm_vcx1d_u64): Likewise.
816 (__arm_vcx1da_u64, __arm_vcx2d_u64, __arm_vcx2da_u64): Likewise.
817 (__arm_vcx3d_u64, __arm_vcx3da_u64): Likewise.
818 * config/arm/arm_cde_builtins.def: New file.
819 * config/arm/iterators.md (V_reg): New attribute of SI.
820 * config/arm/predicates.md (const_int_coproc_operand): New.
821 (const_int_vcde1_operand, const_int_vcde2_operand): New.
822 (const_int_vcde3_operand): New.
823 * config/arm/unspecs.md (UNSPEC_VCDE, UNSPEC_VCDEA): New.
824 * config/arm/vfp.md (arm_vcx1<mode>): New entry.
825 (arm_vcx1a<mode>, arm_vcx2<mode>, arm_vcx2a<mode>): Likewise.
826 (arm_vcx3<mode>, arm_vcx3a<mode>): Likewise.
827
828 2020-04-08 Dennis Zhang <dennis.zhang@arm.com>
829
830 * config.gcc: Add arm_cde.h.
831 * config/arm/arm-c.c (arm_cpu_builtins): Define or undefine
832 __ARM_FEATURE_CDE and __ARM_FEATURE_CDE_COPROC.
833 * config/arm/arm-cpus.in (cdecp0, cdecp1, ..., cdecp7): New options.
834 * config/arm/arm.c (arm_option_reconfigure_globals): Configure
835 arm_arch_cde and arm_arch_cde_coproc to store the feature bits.
836 * config/arm/arm.h (TARGET_CDE): New macro.
837 * config/arm/arm_cde.h: New file.
838 * doc/invoke.texi: Document CDE options +cdecp[0-7].
839 * doc/sourcebuild.texi (arm_v8m_main_cde_ok): Document new target
840 supports option.
841 (arm_v8m_main_cde_fp, arm_v8_1m_main_cde_mve): Likewise.
842
843 2020-04-08 Jakub Jelinek <jakub@redhat.com>
844
845 PR rtl-optimization/94516
846 * postreload.c: Include rtl-iter.h.
847 (reload_cse_move2add): Handle SP autoinc here by FOR_EACH_SUBRTX_VAR
848 looking for all MEMs with RTX_AUTOINC operand.
849 (move2add_note_store): Remove {PRE,POST}_{INC,DEC} handling.
850
851 2020-04-08 Tobias Burnus <tobias@codesourcery.com>
852
853 * omp-grid.c (grid_eliminate_combined_simd_part): Use
854 OMP_CLAUSE_CODE to access the omp clause code.
855
856 2020-04-07 Jeff Law <law@redhat.com>
857
858 PR rtl-optimization/92264
859 * config/h8300/h8300.md (mov;add peephole2): Avoid applying when
860 the destination is the stack pointer.
861
862 2020-04-07 Jakub Jelinek <jakub@redhat.com>
863
864 PR rtl-optimization/94291
865 PR rtl-optimization/84169
866 * combine.c (try_combine): For split_i2i3, don't assume SET_DEST
867 must be a REG or SUBREG of REG; if it is not one of these, don't
868 update LOG_LINKs.
869
870 2020-04-07 Richard Biener <rguenther@suse.de>
871
872 PR middle-end/94479
873 * gimplify.c (gimplify_addr_expr): Also consider generated
874 MEM_REFs.
875
876 2020-04-07 Andre Vieira <andre.simoesdiasvieira@arm.com>
877
878 * config/arm/arm_mve.h: Add C++ polymorphism and fix preserve MACROs.
879
880 2020-04-07 Andre Vieira <andre.simoesdiasvieira@arm.com>
881
882 * config/arm/arm_mve.h: Cast some pointers to expected types.
883
884 2020-04-07 Andre Vieira <andre.simoesdiasvieira@arm.com>
885
886 * config/arm/arm_mve.h: Replace all uses of vuninitializedq_* with the
887 same with '__arm_' prefix.
888
889 2020-04-07 Andre Vieira <andre.simoesdiasvieira@arm.com>
890
891 * config/arm/mve.md (mve_vec_extract*): Allow memory operands in set.
892
893 2020-04-07 Andre Vieira <andre.simoesdiasvieira@arm.com>
894
895 * config/arm/arm.c (arm_mve_immediate_check): Removed.
896 * config/arm/mve.md (MVE_pred2, MVE_constraint2): Added FP types.
897 (mve_vcvtq_n_to_f_*, mve_vcvtq_n_from_f_*, mve_vqshrnbq_n_*,
898 mve_vqshrntq_n_*, mve_vqshrunbq_n_s*, mve_vqshruntq_n_s*,
899 mve_vcvtq_m_n_from_f_*, mve_vcvtq_m_n_to_f_*, mve_vqshrnbq_m_n_*,
900 mve_vqrshruntq_m_n_s*, mve_vqshrunbq_m_n_s*,
901 mve_vqshruntq_m_n_s*): Fixed immediate constraints.
902
903 2020-04-07 Andre Vieira <andre.simoesdiasvieira@arm.com>
904
905 * config/arm/arm.d (ashldi3): Don't use lsll for constant 32-bit shifts.
906
907 2020-04-07 Andre Vieira <andre.simoesdiasvieira@arm.com>
908
909 * config/arm/arm_mve.h: Fix v[id]wdup intrinsics.
910 * config/arm/mve/md: Fix v[id]wdup patterns.
911
912 2020-04-07 Andre Vieira <andre.simoesdiasvieira@arm.com>
913
914 * config/arm/arm.c (output_move_neon): Deal with label + offset cases.
915 * config/arm/mve.md (*mve_mov<mode>): Handle const vectors.
916
917 2020-04-07 Andre Vieira <andre.simoesdiasvieira@arm.com>
918
919 * config/arm/arm_mve.h: Remove use of typeof for addr pointer parameters
920 and remove const_ptr enums.
921
922 2020-04-07 Andre Vieira <andre.simoesdiasvieira@arm.com>
923
924 * config/arm/arm_mve.h (vsubq_n): Merge with...
925 (vsubq): ... this.
926 (vmulq_n): Merge with...
927 (vmulq): ... this.
928 (__ARM_mve_typeid): Simplify scalar and constant detection.
929
930 2020-04-07 Jakub Jelinek <jakub@redhat.com>
931
932 PR target/94509
933 * config/i386/i386-expand.c (expand_vec_perm_pshufb): Fix the check
934 for inter-lane permutation for 64-byte modes.
935
936 PR target/94488
937 * config/aarch64/aarch64-simd.md (ashl<mode>3, lshr<mode>3,
938 ashr<mode>3): Force operands[2] into reg whenever it is not CONST_INT.
939 Assume it is a REG after that instead of testing it and doing FAIL
940 otherwise. Formatting fix.
941
942 2020-04-07 Sebastian Huber <sebastian.huber@embedded-brains.de>
943
944 * config/rs6000/t-rtems: Delete mcpu=8540 multilib.
945
946 2020-04-07 Jakub Jelinek <jakub@redhat.com>
947
948 PR target/94500
949 * config/i386/i386-expand.c (emit_reduc_half): For V{64QI,32HI}mode
950 handle i < 64 using avx512bw_lshrv4ti3. Formatting fixes.
951
952 2020-04-06 Jakub Jelinek <jakub@redhat.com>
953
954 * cselib.c (cselib_subst_to_values): For SP_DERIVED_VALUE_P
955 + const0_rtx return the SP_DERIVED_VALUE_P.
956
957 2020-04-06 Richard Sandiford <richard.sandiford@arm.com>
958
959 PR rtl-optimization/92989
960 * lra-lives.c (process_bb_lives): Do not treat eh_return data
961 registers as being live at the beginning of the EH receiver.
962
963 2020-04-05 Zachary Spytz <zspytz@gmail.com>
964
965 * extend.texi: Add free to list of ISO C90 functions that
966 are recognized by the compiler.
967
968 2020-04-05 Nagaraju Mekala <nmekala@xilix.com>
969
970 * config/microblaze/microblaze.c (microblaze_must_save_register): Check
971 for fast_interrupt.
972
973 * config/microblaze/microblaze.md (trap): Update output pattern.
974
975 2020-04-04 Hannes Domani <ssbssa@yahoo.de>
976 Jakub Jelinek <jakub@redhat.com>
977
978 PR debug/94459
979 * dwarf2out.c (gen_subprogram_die): Look through references, pointers,
980 arrays, pointer-to-members, function types and qualifiers when
981 checking if in-class DIE had an 'auto' or 'decltype(auto)' return type
982 to emit type again on definition.
983
984 2020-04-04 Jan Hubicka <hubicka@ucw.cz>
985
986 PR ipa/93940
987 * ipa-fnsummary.c (vrp_will_run_p): New function.
988 (fre_will_run_p): New function.
989 (evaluate_properties_for_edge): Use it.
990 * ipa-inline.c (can_inline_edge_by_limits_p): Do not inline
991 !optimize_debug to optimize_debug.
992
993 2020-04-04 Jakub Jelinek <jakub@redhat.com>
994
995 PR rtl-optimization/94468
996 * cselib.c (references_value_p): Formatting fix.
997 (cselib_useless_value_p): New function.
998 (discard_useless_locs, discard_useless_values,
999 cselib_invalidate_regno_val, cselib_invalidate_mem,
1000 cselib_record_set): Use it instead of
1001 v->locs == 0 && !PRESERVED_VALUE_P (v->val_rtx).
1002
1003 PR debug/94441
1004 * tree-iterator.h (expr_single): Declare.
1005 * tree-iterator.c (expr_single): New function.
1006 * tree.h (protected_set_expr_location_if_unset): Declare.
1007 * tree.c (protected_set_expr_location): Use expr_single.
1008 (protected_set_expr_location_if_unset): New function.
1009
1010 2020-04-03 Jeff Law <law@redhat.com>
1011
1012 PR rtl-optimization/92264
1013 * config/stormy16/stormy16.c (xstormy16_preferred_reload_class): Handle
1014 reloading of auto-increment addressing modes.
1015
1016 2020-04-03 H.J. Lu <hongjiu.lu@intel.com>
1017
1018 PR target/94467
1019 * config/i386/sse.md (ssse3_pshufbv8qi3): Mark scratch operand
1020 as earlyclobber.
1021
1022 2020-04-03 Jeff Law <law@redhat.com>
1023
1024 PR rtl-optimization/92264
1025 * config/m32r/m32r.c (m32r_output_block_move): Properly account for
1026 post-increment addressing of source operands as well as residuals
1027 when computing any adjustments to the input pointer.
1028
1029 2020-04-03 Jakub Jelinek <jakub@redhat.com>
1030
1031 PR target/94460
1032 * config/i386/sse.md (avx2_ph<plusminus_mnemonic>wv16hi3,
1033 avx2_ph<plusminus_mnemonic>dv8si3): Fix up RTL pattern to do
1034 second half of first lane from first lane of second operand and
1035 first half of second lane from second lane of first operand.
1036
1037 2020-04-03 Andre Vieira <andre.simoesdiasvieira@arm.com>
1038
1039 * config/arm/arm_mve.h: Condition the header file on __ARM_FEATURE_MVE.
1040
1041 2020-04-03 Tamar Christina <tamar.christina@arm.com>
1042
1043 PR target/94396
1044 * common/config/aarch64/aarch64-common.c
1045 (aarch64_get_extension_string_for_isa_flags): Handle default flags.
1046
1047 2020-04-03 Richard Biener <rguenther@suse.de>
1048
1049 PR middle-end/94465
1050 * tree.c (array_ref_low_bound): Deal with released SSA names
1051 in index position.
1052
1053 2020-04-03 Kwok Cheung Yeung <kcy@codesourcery.com>
1054
1055 * config/gcn/gcn.c (print_operand): Handle unordered comparison
1056 operators.
1057 * config/gcn/predicates.md (gcn_fp_compare_operator): Add unordered
1058 comparison operators.
1059
1060 2020-04-03 Kewen Lin <linkw@gcc.gnu.org>
1061
1062 PR tree-optimization/94443
1063 * tree-vect-loop.c (vectorizable_live_operation): Use
1064 gsi_insert_seq_before to replace gsi_insert_before.
1065
1066 2020-04-03 Martin Liska <mliska@suse.cz>
1067
1068 PR ipa/94445
1069 * ipa-icf-gimple.c (func_checker::compare_gimple_call):
1070 Compare type attributes for gimple_call_fntypes.
1071
1072 2020-04-02 Sandra Loosemore <sandra@codesourcery.com>
1073
1074 * alias.c (get_alias_set): Fix comment typos.
1075
1076 2020-04-02 Fritz Reese <foreese@gcc.gnu.org>
1077
1078 PR fortran/85982
1079 * fortran/decl.c (match_attr_spec): Lump COMP_STRUCTURE/COMP_MAP into
1080 attribute checking used by TYPE.
1081
1082 2020-04-02 Martin Jambor <mjambor@suse.cz>
1083
1084 PR ipa/92676
1085 * ipa-sra.c (struct caller_issues): New fields candidate and
1086 call_from_outside_comdat.
1087 (check_for_caller_issues): Check for calls from outsied of
1088 candidate's same_comdat_group.
1089 (check_all_callers_for_issues): Set up issues.candidate, check result
1090 of the new check.
1091 (mark_callers_calls_comdat_local): New function.
1092 (process_isra_node_results): Set calls_comdat_local of callers if
1093 appropriate.
1094
1095 2020-04-02 Richard Biener <rguenther@suse.de>
1096
1097 PR c/94392
1098 * common.opt (ffinite-loops): Initialize to zero.
1099 * opts.c (default_options_table): Remove OPT_ffinite_loops
1100 entry.
1101 * cfgloop.h (loop::finite_p): New member.
1102 * cfgloopmanip.c (copy_loop_info): Copy finite_p.
1103 * ipa-icf-gimple.c (func_checker::compare_loops): Compare
1104 finite_p.
1105 * lto-streamer-in.c (input_cfg): Stream finite_p.
1106 * lto-streamer-out.c (output_cfg): Likewise.
1107 * tree-cfg.c (replace_loop_annotate): Initialize finite_p
1108 from flag_finite_loops at CFG build time.
1109 * tree-ssa-loop-niter.c (finite_loop_p): Check the loops
1110 finite_p flag instead of flag_finite_loops.
1111 * doc/invoke.texi (ffinite-loops): Adjust documentation of
1112 default setting.
1113
1114 2020-04-02 Richard Biener <rguenther@suse.de>
1115
1116 PR debug/94450
1117 * dwarf2out.c (dwarf2out_early_finish): Remove code emitting
1118 DW_TAG_imported_unit.
1119
1120 2020-04-02 Maciej W. Rozycki <macro@wdc.com>
1121
1122 * doc/install.texi (Specific) <riscv32-*-elf, riscv32-*-linux>
1123 <riscv64-*-elf, riscv64-*-linux>: Update binutils requirement to
1124 2.30.
1125
1126 2020-04-02 Kewen Lin <linkw@gcc.gnu.org>
1127
1128 PR tree-optimization/94401
1129 * tree-vect-loop.c (vectorizable_load): Handle VMAT_CONTIGUOUS_REVERSE
1130 access type when loading halves of vector to avoid peeling for gaps.
1131
1132 2020-04-02 Jakub Jelinek <jakub@redhat.com>
1133
1134 * config/mips/mti-linux.h (SYSROOT_SUFFIX_SPEC): Add a space in
1135 between a string literal and MIPS_SYSVERSION_SPEC macro.
1136
1137 2020-04-02 Martin Jambor <mjambor@suse.cz>
1138
1139 * doc/invoke.texi (Optimize Options): Document sra-max-propagations.
1140
1141 2020-04-02 Jakub Jelinek <jakub@redhat.com>
1142
1143 PR rtl-optimization/92264
1144 * params.opt (-param=max-find-base-term-values=): Decrease default
1145 from 2000 to 200.
1146
1147 PR rtl-optimization/92264
1148 * rtl.h (struct rtx_def): Mention that call bit is used as
1149 SP_DERIVED_VALUE_P in cselib.c.
1150 * cselib.c (SP_DERIVED_VALUE_P): Define.
1151 (PRESERVED_VALUE_P, SP_BASED_VALUE_P): Move definitions earlier.
1152 (cselib_hasher::equal): Handle equality between SP_DERIVED_VALUE_P
1153 val_rtx and sp based expression where offsets cancel each other.
1154 (preserve_constants_and_equivs): Formatting fix.
1155 (cselib_reset_table): Add reverse op loc to SP_DERIVED_VALUE_P
1156 locs list for cfa_base_preserved_val if needed. Formatting fix.
1157 (autoinc_split): If the to be returned value is a REG, MEM or
1158 VALUE which has SP_DERIVED_VALUE_P + CONST_INT as one of its
1159 locs, return the SP_DERIVED_VALUE_P VALUE and adjust *off.
1160 (rtx_equal_for_cselib_1): Call autoinc_split even if both
1161 expressions are PLUS in Pmode with CONST_INT second operands.
1162 Handle SP_DERIVED_VALUE_P cases.
1163 (cselib_hash_plus_const_int): New function.
1164 (cselib_hash_rtx): Use it for PLUS in Pmode with CONST_INT
1165 second operand, as well as for PRE_DEC etc. that ought to be
1166 hashed the same way.
1167 (cselib_subst_to_values): Substitute PLUS with Pmode and
1168 CONST_INT operand if the first operand is a VALUE which has
1169 SP_DERIVED_VALUE_P + CONST_INT as one of its locs for the
1170 SP_DERIVED_VALUE_P + adjusted offset.
1171 (cselib_lookup_1): When creating a new VALUE for stack_pointer_rtx,
1172 set SP_DERIVED_VALUE_P on it. Set PRESERVED_VALUE_P when adding
1173 SP_DERIVED_VALUE_P PRESERVED_VALUE_P subseted VALUE location.
1174 * var-tracking.c (vt_initialize): Call cselib_add_permanent_equiv
1175 on the sp value before calling cselib_add_permanent_equiv on the
1176 cfa_base value.
1177 * dse.c (check_for_inc_dec_1, check_for_inc_dec): Punt on RTX_AUTOINC
1178 in the insn without REG_INC note.
1179 (replace_read): Punt on RTX_AUTOINC in the *loc being replaced.
1180 Punt on invalid insns added by copy_to_mode_reg. Formatting fixes.
1181
1182 PR target/94435
1183 * config/aarch64/aarch64.c (aarch64_gen_compare_reg_maybe_ze): For
1184 y_mode E_[QH]Imode and y being a CONST_INT, change y_mode to SImode.
1185
1186 2020-04-02 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
1187
1188 PR target/94317
1189 * config/arm/arm-builtins.c (LDRGBWBXU_QUALIFIERS): Define.
1190 (LDRGBWBXU_Z_QUALIFIERS): Likewise.
1191 * config/arm/arm_mve.h (__arm_vldrdq_gather_base_wb_s64): Modify
1192 intrinsic defintion by adding a new builtin call to writeback into base
1193 address.
1194 (__arm_vldrdq_gather_base_wb_u64): Likewise.
1195 (__arm_vldrdq_gather_base_wb_z_s64): Likewise.
1196 (__arm_vldrdq_gather_base_wb_z_u64): Likewise.
1197 (__arm_vldrwq_gather_base_wb_s32): Likewise.
1198 (__arm_vldrwq_gather_base_wb_u32): Likewise.
1199 (__arm_vldrwq_gather_base_wb_z_s32): Likewise.
1200 (__arm_vldrwq_gather_base_wb_z_u32): Likewise.
1201 (__arm_vldrwq_gather_base_wb_f32): Likewise.
1202 (__arm_vldrwq_gather_base_wb_z_f32): Likewise.
1203 * config/arm/arm_mve_builtins.def (vldrwq_gather_base_wb_z_u): Modify
1204 builtin's qualifier.
1205 (vldrdq_gather_base_wb_z_u): Likewise.
1206 (vldrwq_gather_base_wb_u): Likewise.
1207 (vldrdq_gather_base_wb_u): Likewise.
1208 (vldrwq_gather_base_wb_z_s): Likewise.
1209 (vldrwq_gather_base_wb_z_f): Likewise.
1210 (vldrdq_gather_base_wb_z_s): Likewise.
1211 (vldrwq_gather_base_wb_s): Likewise.
1212 (vldrwq_gather_base_wb_f): Likewise.
1213 (vldrdq_gather_base_wb_s): Likewise.
1214 (vldrwq_gather_base_nowb_z_u): Define builtin.
1215 (vldrdq_gather_base_nowb_z_u): Likewise.
1216 (vldrwq_gather_base_nowb_u): Likewise.
1217 (vldrdq_gather_base_nowb_u): Likewise.
1218 (vldrwq_gather_base_nowb_z_s): Likewise.
1219 (vldrwq_gather_base_nowb_z_f): Likewise.
1220 (vldrdq_gather_base_nowb_z_s): Likewise.
1221 (vldrwq_gather_base_nowb_s): Likewise.
1222 (vldrwq_gather_base_nowb_f): Likewise.
1223 (vldrdq_gather_base_nowb_s): Likewise.
1224 * config/arm/mve.md (mve_vldrwq_gather_base_nowb_<supf>v4si): Define RTL
1225 pattern.
1226 (mve_vldrwq_gather_base_wb_<supf>v4si): Modify RTL pattern.
1227 (mve_vldrwq_gather_base_nowb_z_<supf>v4si): Define RTL pattern.
1228 (mve_vldrwq_gather_base_wb_z_<supf>v4si): Modify RTL pattern.
1229 (mve_vldrwq_gather_base_wb_fv4sf): Modify RTL pattern.
1230 (mve_vldrwq_gather_base_nowb_fv4sf): Define RTL pattern.
1231 (mve_vldrwq_gather_base_wb_z_fv4sf): Modify RTL pattern.
1232 (mve_vldrwq_gather_base_nowb_z_fv4sf): Define RTL pattern.
1233 (mve_vldrdq_gather_base_nowb_<supf>v4di): Define RTL pattern.
1234 (mve_vldrdq_gather_base_wb_<supf>v4di): Modify RTL pattern.
1235 (mve_vldrdq_gather_base_nowb_z_<supf>v4di): Define RTL pattern.
1236 (mve_vldrdq_gather_base_wb_z_<supf>v4di): Modify RTL pattern.
1237
1238 2020-04-02 Andreas Krebbel <krebbel@linux.ibm.com>
1239
1240 * config/s390/vector.md ("<ti*>add<mode>3", "mul<mode>3")
1241 ("and<mode>3", "notand<mode>3", "ior<mode>3", "ior_not<mode>3")
1242 ("xor<mode>3", "notxor<mode>3", "smin<mode>3", "smax<mode>3")
1243 ("umin<mode>3", "umax<mode>3", "vec_widen_smult_even_<mode>")
1244 ("vec_widen_umult_even_<mode>", "vec_widen_smult_odd_<mode>")
1245 ("vec_widen_umult_odd_<mode>", "add<mode>3", "sub<mode>3")
1246 ("mul<mode>3", "fma<mode>4", "fms<mode>4", "neg_fma<mode>4")
1247 ("neg_fms<mode>4", "*smax<mode>3_vxe", "*smaxv2df3_vx")
1248 ("*smin<mode>3_vxe", "*sminv2df3_vx"): Remove % constraint
1249 modifier.
1250 ("vec_widen_umult_lo_<mode>", "vec_widen_umult_hi_<mode>")
1251 ("vec_widen_smult_lo_<mode>", "vec_widen_smult_hi_<mode>"):
1252 Remove constraints from expander.
1253 * config/s390/vx-builtins.md ("vacc<bhfgq>_<mode>", "vacq")
1254 ("vacccq", "vec_avg<mode>", "vec_avgu<mode>", "vec_vmal<mode>")
1255 ("vec_vmah<mode>", "vec_vmalh<mode>", "vec_vmae<mode>")
1256 ("vec_vmale<mode>", "vec_vmao<mode>", "vec_vmalo<mode>")
1257 ("vec_smulh<mode>", "vec_umulh<mode>", "vec_nor<mode>3")
1258 ("vfmin<mode>", "vfmax<mode>"): Remove % constraint modifier.
1259
1260 2020-04-01 Peter Bergner <bergner@linux.ibm.com>
1261
1262 PR rtl-optimization/94123
1263 * lower-subreg.c (pass_lower_subreg3::gate): Remove test for
1264 flag_split_wide_types_early.
1265
1266 2020-04-01 Joerg Sonnenberger <joerg@bec.de>
1267
1268 * doc/extend.texi (Common Function Attributes): Fix typo.
1269
1270 2020-04-01 Segher Boessenkool <segher@kernel.crashing.org>
1271
1272 PR target/94420
1273 * config/rs6000/rs6000.md (*tocref<mode> for P): Add insn condition
1274 on operands[1].
1275
1276 2020-04-01 Zackery Spytz <zspytz@gmail.com>
1277
1278 * doc/extend.texi: Fix a typo in the documentation of the
1279 copy function attribute.
1280
1281 2020-04-01 Jakub Jelinek <jakub@redhat.com>
1282
1283 PR middle-end/94423
1284 * tree-object-size.c (pass_object_sizes::execute): Don't call
1285 replace_uses_by for SSA_NAME_OCCURS_IN_ABNORMAL_PHI lhs, instead
1286 call replace_call_with_value.
1287
1288 2020-04-01 Kewen Lin <linkw@gcc.gnu.org>
1289
1290 PR tree-optimization/94043
1291 * tree-vect-loop.c (vectorizable_live_operation): Generate loop-closed
1292 phi for vec_lhs and use it for lane extraction.
1293
1294 2020-03-31 Felix Yang <felix.yang@huawei.com>
1295
1296 PR tree-optimization/94398
1297 * tree-vect-stmts.c (vectorizable_store): Instead of calling
1298 vect_supportable_dr_alignment, set alignment_support_scheme to
1299 dr_unaligned_supported for gather-scatter accesses.
1300 (vectorizable_load): Likewise.
1301
1302 2020-03-31 Andrew Stubbs <ams@codesourcery.com>
1303
1304 * config/gcn/gcn-valu.md (V_QI, V_HI, V_HF, V_SI, V_SF, V_DI, V_DF):
1305 New mode iterators.
1306 (vnsi, VnSI, vndi, VnDI): New mode attributes.
1307 (mov<mode>): Use <VnDI> in place of V64DI.
1308 (mov<mode>_exec): Likewise.
1309 (mov<mode>_sgprbase): Likewise.
1310 (reload_out<mode>): Likewise.
1311 (*vec_set<mode>_1): Use GET_MODE_NUNITS instead of constant 64.
1312 (gather_load<mode>v64si): Rename to ...
1313 (gather_load<mode><vnsi>): ... this, and use <VnSI> in place of V64SI,
1314 and <VnDI> in place of V64DI.
1315 (gather<mode>_insn_1offset<exec>): Use <VnDI> in place of V64DI.
1316 (gather<mode>_insn_1offset_ds<exec>): Use <VnSI> in place of V64SI.
1317 (gather<mode>_insn_2offsets<exec>): Use <VnSI> and <VnDI>.
1318 (scatter_store<mode>v64si): Rename to ...
1319 (scatter_store<mode><vnsi>): ... this, and use <VnSI> and <VnDI>.
1320 (scatter<mode>_expr<exec_scatter>): Use <VnSI> and <VnDI>.
1321 (scatter<mode>_insn_1offset<exec_scatter>): Likewise.
1322 (scatter<mode>_insn_1offset_ds<exec_scatter>): Likewise.
1323 (scatter<mode>_insn_2offsets<exec_scatter>): Likewise.
1324 (ds_bpermute<mode>): Use <VnSI>.
1325 (addv64si3_vcc<exec_vcc>): Rename to ...
1326 (add<mode>3_vcc<exec_vcc>): ... this, and use V_SI.
1327 (addv64si3_vcc_dup<exec_vcc>): Rename to ...
1328 (add<mode>3_vcc_dup<exec_vcc>): ... this, and use V_SI.
1329 (addcv64si3<exec_vcc>): Rename to ...
1330 (addc<mode>3<exec_vcc>): ... this, and use V_SI.
1331 (subv64si3_vcc<exec_vcc>): Rename to ...
1332 (sub<mode>3_vcc<exec_vcc>): ... this, and use V_SI.
1333 (subcv64si3<exec_vcc>): Rename to ...
1334 (subc<mode>3<exec_vcc>): ... this, and use V_SI.
1335 (addv64di3): Rename to ...
1336 (add<mode>3): ... this, and use V_DI.
1337 (addv64di3_exec): Rename to ...
1338 (add<mode>3_exec): ... this, and use V_DI.
1339 (subv64di3): Rename to ...
1340 (sub<mode>3): ... this, and use V_DI.
1341 (subv64di3_exec): Rename to ...
1342 (sub<mode>3_exec): ... this, and use V_DI.
1343 (addv64di3_zext): Rename to ...
1344 (add<mode>3_zext): ... this, and use V_DI and <VnSI>.
1345 (addv64di3_zext_exec): Rename to ...
1346 (add<mode>3_zext_exec): ... this, and use V_DI and <VnSI>.
1347 (addv64di3_zext_dup): Rename to ...
1348 (add<mode>3_zext_dup): ... this, and use V_DI and <VnSI>.
1349 (addv64di3_zext_dup_exec): Rename to ...
1350 (add<mode>3_zext_dup_exec): ... this, and use V_DI and <VnSI>.
1351 (addv64di3_zext_dup2): Rename to ...
1352 (add<mode>3_zext_dup2): ... this, and use V_DI and <VnSI>.
1353 (addv64di3_zext_dup2_exec): Rename to ...
1354 (add<mode>3_zext_dup2_exec): ... this, and use V_DI and <VnSI>.
1355 (addv64di3_sext_dup2): Rename to ...
1356 (add<mode>3_sext_dup2): ... this, and use V_DI and <VnSI>.
1357 (addv64di3_sext_dup2_exec): Rename to ...
1358 (add<mode>3_sext_dup2_exec): ... this, and use V_DI and <VnSI>.
1359 (<su>mulv64si3_highpart<exec>): Rename to ...
1360 (<su>mul<mode>3_highpart<exec>): ... this and use V_SI and <VnDI>.
1361 (mulv64di3): Rename to ...
1362 (mul<mode>3): ... this, and use V_DI and <VnSI>.
1363 (mulv64di3_exec): Rename to ...
1364 (mul<mode>3_exec): ... this, and use V_DI and <VnSI>.
1365 (mulv64di3_zext): Rename to ...
1366 (mul<mode>3_zext): ... this, and use V_DI and <VnSI>.
1367 (mulv64di3_zext_exec): Rename to ...
1368 (mul<mode>3_zext_exec): ... this, and use V_DI and <VnSI>.
1369 (mulv64di3_zext_dup2): Rename to ...
1370 (mul<mode>3_zext_dup2): ... this, and use V_DI and <VnSI>.
1371 (mulv64di3_zext_dup2_exec): Rename to ...
1372 (mul<mode>3_zext_dup2_exec): ... this, and use V_DI and <VnSI>.
1373 (<expander>v64di3): Rename to ...
1374 (<expander><mode>3): ... this, and use V_DI and <VnSI>.
1375 (<expander>v64di3_exec): Rename to ...
1376 (<expander><mode>3_exec): ... this, and use V_DI and <VnSI>.
1377 (<expander>v64si3<exec>): Rename to ...
1378 (<expander><mode>3<exec>): ... this, and use V_SI and <VnSI>.
1379 (v<expander>v64si3<exec>): Rename to ...
1380 (v<expander><mode>3<exec>): ... this, and use V_SI and <VnSI>.
1381 (<expander>v64si3<exec>): Rename to ...
1382 (<expander><vnsi>3<exec>): ... this, and use V_SI.
1383 (subv64df3<exec>): Rename to ...
1384 (sub<mode>3<exec>): ... this, and use V_DF.
1385 (truncv64di<mode>2): Rename to ...
1386 (trunc<vndi><mode>2): ... this, and use <VnDI>.
1387 (truncv64di<mode>2_exec): Rename to ...
1388 (trunc<vndi><mode>2_exec): ... this, and use <VnDI>.
1389 (<convop><mode>v64di2): Rename to ...
1390 (<convop><mode><vndi>2): ... this, and use <VnDI>.
1391 (<convop><mode>v64di2_exec): Rename to ...
1392 (<convop><mode><vndi>2_exec): ... this, and use <VnDI>.
1393 (vec_cmp<u>v64qidi): Rename to ...
1394 (vec_cmp<u><mode>di): ... this, and use <VnSI>.
1395 (vec_cmp<u>v64qidi_exec): Rename to ...
1396 (vec_cmp<u><mode>di_exec): ... this, and use <VnSI>.
1397 (vcond_mask_<mode>di): Use <VnDI>.
1398 (maskload<mode>di): Likewise.
1399 (maskstore<mode>di): Likewise.
1400 (mask_gather_load<mode>v64si): Rename to ...
1401 (mask_gather_load<mode><vnsi>): ... this, and use <VnSI> and <VnDI>.
1402 (mask_scatter_store<mode>v64si): Rename to ...
1403 (mask_scatter_store<mode><vnsi>): ... this, and use <VnSI> and <VnDI>.
1404 (*<reduc_op>_dpp_shr_v64di): Rename to ...
1405 (*<reduc_op>_dpp_shr_<mode>): ... this, and use V_DI and <VnSI>.
1406 (*plus_carry_in_dpp_shr_v64si): Rename to ...
1407 (*plus_carry_in_dpp_shr_<mode>): ... this, and use V_SI.
1408 (*plus_carry_dpp_shr_v64di): Rename to ...
1409 (*plus_carry_dpp_shr_<mode>): ... this, and use V_DI and <VnSI>.
1410 (vec_seriesv64si): Rename to ...
1411 (vec_series<mode>): ... this, and use V_SI.
1412 (vec_seriesv64di): Rename to ...
1413 (vec_series<mode>): ... this, and use V_DI.
1414
1415 2020-03-31 Claudiu Zissulescu <claziss@synopsys.com>
1416
1417 * config/arc/arc.c (arc_print_operand): Use
1418 HOST_WIDE_INT_PRINT_DEC macro.
1419
1420 2020-03-31 Claudiu Zissulescu <claziss@synopsys.com>
1421
1422 * config/arc/arc.h (ASM_FORMAT_PRIVATE_NAME): Fix it.
1423
1424 2020-03-31 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
1425
1426 * config/arm/arm_mve.h (vbicq): Define MVE intrinsic polymorphic
1427 variant.
1428 (__arm_vbicq): Likewise.
1429
1430 2020-03-31 Vineet Gupta <vgupta@synopsys.com>
1431
1432 * config/arc/linux.h: GLIBC_DYNAMIC_LINKER support BE/arc700.
1433
1434 2020-03-31 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
1435
1436 * config/arm/arm_mve.h (vaddlvq): Move the polymorphic variant to the
1437 common section of both MVE Integer and MVE Floating Point.
1438 (vaddvq): Likewise.
1439 (vaddlvq_p): Likewise.
1440 (vaddvaq): Likewise.
1441 (vaddvq_p): Likewise.
1442 (vcmpcsq): Likewise.
1443 (vmlsdavxq): Likewise.
1444 (vmlsdavq): Likewise.
1445 (vmladavxq): Likewise.
1446 (vmladavq): Likewise.
1447 (vminvq): Likewise.
1448 (vminavq): Likewise.
1449 (vmaxvq): Likewise.
1450 (vmaxavq): Likewise.
1451 (vmlaldavq): Likewise.
1452 (vcmphiq): Likewise.
1453 (vaddlvaq): Likewise.
1454 (vrmlaldavhq): Likewise.
1455 (vrmlaldavhxq): Likewise.
1456 (vrmlsldavhq): Likewise.
1457 (vrmlsldavhxq): Likewise.
1458 (vmlsldavxq): Likewise.
1459 (vmlsldavq): Likewise.
1460 (vabavq): Likewise.
1461 (vrmlaldavhaq): Likewise.
1462 (vcmpgeq_m_n): Likewise.
1463 (vmlsdavxq_p): Likewise.
1464 (vmlsdavq_p): Likewise.
1465 (vmlsdavaxq): Likewise.
1466 (vmlsdavaq): Likewise.
1467 (vaddvaq_p): Likewise.
1468 (vcmpcsq_m_n): Likewise.
1469 (vcmpcsq_m): Likewise.
1470 (vmladavxq_p): Likewise.
1471 (vmladavq_p): Likewise.
1472 (vmladavaxq): Likewise.
1473 (vmladavaq): Likewise.
1474 (vminvq_p): Likewise.
1475 (vminavq_p): Likewise.
1476 (vmaxvq_p): Likewise.
1477 (vmaxavq_p): Likewise.
1478 (vcmphiq_m): Likewise.
1479 (vaddlvaq_p): Likewise.
1480 (vmlaldavaq): Likewise.
1481 (vmlaldavaxq): Likewise.
1482 (vmlaldavq_p): Likewise.
1483 (vmlaldavxq_p): Likewise.
1484 (vmlsldavaq): Likewise.
1485 (vmlsldavaxq): Likewise.
1486 (vmlsldavq_p): Likewise.
1487 (vmlsldavxq_p): Likewise.
1488 (vrmlaldavhaxq): Likewise.
1489 (vrmlaldavhq_p): Likewise.
1490 (vrmlaldavhxq_p): Likewise.
1491 (vrmlsldavhaq): Likewise.
1492 (vrmlsldavhaxq): Likewise.
1493 (vrmlsldavhq_p): Likewise.
1494 (vrmlsldavhxq_p): Likewise.
1495 (vabavq_p): Likewise.
1496 (vmladavaq_p): Likewise.
1497 (vstrbq_scatter_offset): Likewise.
1498 (vstrbq_p): Likewise.
1499 (vstrbq_scatter_offset_p): Likewise.
1500 (vstrdq_scatter_base_p): Likewise.
1501 (vstrdq_scatter_base): Likewise.
1502 (vstrdq_scatter_offset_p): Likewise.
1503 (vstrdq_scatter_offset): Likewise.
1504 (vstrdq_scatter_shifted_offset_p): Likewise.
1505 (vstrdq_scatter_shifted_offset): Likewise.
1506 (vmaxq_x): Likewise.
1507 (vminq_x): Likewise.
1508 (vmovlbq_x): Likewise.
1509 (vmovltq_x): Likewise.
1510 (vmulhq_x): Likewise.
1511 (vmullbq_int_x): Likewise.
1512 (vmullbq_poly_x): Likewise.
1513 (vmulltq_int_x): Likewise.
1514 (vmulltq_poly_x): Likewise.
1515 (vstrbq): Likewise.
1516
1517 2020-03-31 Jakub Jelinek <jakub@redhat.com>
1518
1519 PR target/94368
1520 * config/aarch64/constraints.md (Uph): New constraint.
1521 * config/aarch64/atomics.md (cas_short_expected_imm): New mode attr.
1522 (@aarch64_compare_and_swap<mode>): Use it instead of n in operand 2's
1523 constraint.
1524
1525 2020-03-31 Marc Glisse <marc.glisse@inria.fr>
1526 Jakub Jelinek <jakub@redhat.com>
1527
1528 PR middle-end/94412
1529 * fold-const.c (fold_binary_loc) <case TRUNC_DIV_EXPR>: Use
1530 ANY_INTEGRAL_TYPE_P instead of INTEGRAL_TYPE_P.
1531
1532 2020-03-31 Jakub Jelinek <jakub@redhat.com>
1533
1534 PR tree-optimization/94403
1535 * gimple-ssa-store-merging.c (verify_symbolic_number_p): Allow also
1536 ENUMERAL_TYPE lhs_type.
1537
1538 PR rtl-optimization/94344
1539 * tree-ssa-forwprop.c (simplify_rotate): Handle also same precision
1540 conversions, either on both operands of |^+ or just one. Handle
1541 also extra same precision conversion on RSHIFT_EXPR first operand
1542 provided RSHIFT_EXPR is performed in unsigned type.
1543
1544 2020-03-30 David Malcolm <dmalcolm@redhat.com>
1545
1546 * lra.c (finish_insn_code_data_once): Set the array elements
1547 to NULL after freeing them.
1548
1549 2020-03-30 Andreas Schwab <schwab@suse.de>
1550
1551 * config/host-linux.c (TRY_EMPTY_VM_SPACE) [__riscv && __LP64__]:
1552 Define.
1553
1554 2020-03-30 Will Schmidt <will_schmidt@vnet.ibm.com>
1555
1556 * config/rs6000/rs6000-call.c altivec_init_builtins(): Remove code
1557 to skip defining builtins based on builtin_mask.
1558
1559 2020-03-30 Jakub Jelinek <jakub@redhat.com>
1560
1561 PR target/94343
1562 * config/i386/sse.md (<mask_codefor>one_cmpl<mode>2<mask_name>): If
1563 !TARGET_AVX512VL, use 512-bit vpternlog and make sure the input
1564 operand is a register. Don't enable masked variants for V*[QH]Imode.
1565
1566 PR target/93069
1567 * config/i386/sse.md (vec_extract_lo_<mode><mask_name>): Use
1568 <store_mask_constraint> instead of m in output operand constraint.
1569 (vec_extract_hi_<mode><mask_name>): Use <mask_operand2> instead of
1570 %{%3%}.
1571
1572 2020-03-30 Alan Modra <amodra@gmail.com>
1573
1574 * config/rs6000/rs6000.c (rs6000_call_aix): Emit cookie to pattern.
1575 (rs6000_indirect_call_template_1): Adjust to suit.
1576 * config/rs6000/rs6000.md (call_local): Merge call_local32,
1577 call_local64, and call_local_aix.
1578 (call_value_local): Simlarly.
1579 (call_nonlocal_aix, call_value_nonlocal_aix): Adjust rtl to suit,
1580 and disable pattern when CALL_LONG.
1581 (call_indirect_aix, call_value_indirect_aix): Adjust rtl.
1582 (call_indirect_elfv2, call_indirect_pcrel): Likewise.
1583 (call_value_indirect_elfv2, call_value_indirect_pcrel): Likewise.
1584
1585 2020-03-29 H.J. Lu <hongjiu.lu@intel.com>
1586
1587 PR driver/94381
1588 * doc/invoke.texi: Update -falign-functions, -falign-loops and
1589 -falign-jumps documentation.
1590
1591 2020-03-29 Martin Liska <mliska@suse.cz>
1592
1593 PR ipa/94363
1594 * cgraphunit.c (process_function_and_variable_attributes): Remove
1595 double 'attribute' words.
1596
1597 2020-03-29 John David Anglin <dave.anglin@bell.net>
1598
1599 * gcc/config/pa/pa.c (pa_asm_output_aligned_bss): Delete duplicate
1600 .align output.
1601
1602 2020-03-28 Jakub Jelinek <jakub@redhat.com>
1603
1604 PR c/93573
1605 * c-decl.c (grokdeclarator): After issuing errors, set size_int_const
1606 to true after setting size to integer_one_node.
1607
1608 PR tree-optimization/94329
1609 * tree-ssa-reassoc.c (reassociate_bb): When calling reassoc_remove_stmt
1610 on the last stmt in a bb, make sure gsi_prev isn't done immediately
1611 after gsi_last_bb.
1612
1613 2020-03-27 Alan Modra <amodra@gmail.com>
1614
1615 PR target/94145
1616 * config/rs6000/rs6000.c (rs6000_longcall_ref): Use unspec_volatile
1617 for PLT16_LO and PLT_PCREL.
1618 * config/rs6000/rs6000.md (UNSPEC_PLT16_LO, UNSPEC_PLT_PCREL): Remove.
1619 (UNSPECV_PLT16_LO, UNSPECV_PLT_PCREL): Define.
1620 (pltseq_plt16_lo_, pltseq_plt_pcrel): Use unspec_volatile.
1621
1622 2020-03-27 Martin Sebor <msebor@redhat.com>
1623
1624 PR c++/94098
1625 * calls.c (init_attr_rdwr_indices): Iterate over all access attributes.
1626
1627 2020-03-27 Andrew Stubbs <ams@codesourcery.com>
1628
1629 * config/gcn/gcn-valu.md:
1630 (VEC_SUBDWORD_MODE): Rename to V_QIHI throughout.
1631 (VEC_1REG_MODE): Delete.
1632 (VEC_1REG_ALT): Delete.
1633 (VEC_ALL1REG_MODE): Rename to V_1REG throughout.
1634 (VEC_1REG_INT_MODE): Delete.
1635 (VEC_ALL1REG_INT_MODE): Rename to V_INT_1REG throughout.
1636 (VEC_ALL1REG_INT_ALT): Rename to V_INT_1REG_ALT throughout.
1637 (VEC_2REG_MODE): Rename to V_2REG throughout.
1638 (VEC_REG_MODE): Rename to V_noHI throughout.
1639 (VEC_ALLREG_MODE): Rename to V_ALL throughout.
1640 (VEC_ALLREG_ALT): Rename to V_ALL_ALT throughout.
1641 (VEC_ALLREG_INT_MODE): Rename to V_INT throughout.
1642 (VEC_INT_MODE): Delete.
1643 (VEC_FP_MODE): Rename to V_FP throughout and move to top.
1644 (VEC_FP_1REG_MODE): Rename to V_FP_1REG throughout and move to top.
1645 (FP_MODE): Delete and replace with FP throughout.
1646 (FP_1REG_MODE): Delete and replace with FP_1REG throughout.
1647 (VCMP_MODE): Rename to V_noQI throughout and move to top.
1648 (VCMP_MODE_INT): Rename to V_INT_noQI throughout and move to top.
1649 * config/gcn/gcn.md (FP): New mode iterator.
1650 (FP_1REG): New mode iterator.
1651
1652 2020-03-27 David Malcolm <dmalcolm@redhat.com>
1653
1654 * doc/invoke.texi (-fdump-analyzer-supergraph): Document that this
1655 now emits two .dot files.
1656 * graphviz.cc (graphviz_out::begin_tr): Only emit a TR, not a TD.
1657 (graphviz_out::end_tr): Only close a TR, not a TD.
1658 (graphviz_out::begin_td): New.
1659 (graphviz_out::end_td): New.
1660 (graphviz_out::begin_trtd): New, replacing the old implementation
1661 of graphviz_out::begin_tr.
1662 (graphviz_out::end_tdtr): New, replacing the old implementation
1663 of graphviz_out::end_tr.
1664 * graphviz.h (graphviz_out::begin_td): New decl.
1665 (graphviz_out::end_td): New decl.
1666 (graphviz_out::begin_trtd): New decl.
1667 (graphviz_out::end_tdtr): New decl.
1668
1669 2020-03-27 Richard Biener <rguenther@suse.de>
1670
1671 PR debug/94273
1672 * dwarf2out.c (should_emit_struct_debug): Return false for
1673 DINFO_LEVEL_TERSE.
1674
1675 2020-03-27 Richard Biener <rguenther@suse.de>
1676
1677 PR tree-optimization/94352
1678 * tree-ssa-propagate.c (ssa_prop_init): Move seeding of the
1679 worklist ...
1680 (ssa_propagation_engine::ssa_propagate): ... here after
1681 initializing curr_order.
1682
1683 2020-03-27 Kewen Lin <linkw@gcc.gnu.org>
1684
1685 PR tree-optimization/90332
1686 * tree-vect-stmts.c (vector_vector_composition_type): New function.
1687 (get_group_load_store_type): Adjust to call
1688 vector_vector_composition_type, extend it to construct with scalar
1689 types.
1690 (vectorizable_load): Likewise.
1691
1692 2020-03-27 Roman Zhuykov <zhroma@ispras.ru>
1693
1694 * ddg.c (create_ddg_dep_from_intra_loop_link): Remove assertions.
1695 (create_ddg_dep_no_link): Likewise.
1696 (add_cross_iteration_register_deps): Move debug instruction check.
1697 Other minor refactoring.
1698 (add_intra_loop_mem_dep): Do not check for debug instructions.
1699 (add_inter_loop_mem_dep): Likewise.
1700 (build_intra_loop_deps): Likewise.
1701 (create_ddg): Do not include debug insns into the graph.
1702 * ddg.h (struct ddg): Remove num_debug field.
1703 * modulo-sched.c (doloop_register_get): Adjust condition.
1704 (res_MII): Remove DDG num_debug field usage.
1705 (sms_schedule_by_order): Use assertion against debug insns.
1706 (ps_has_conflicts): Drop debug insn check.
1707
1708 2020-03-26 Jakub Jelinek <jakub@redhat.com>
1709
1710 PR debug/94323
1711 * tree.c (protected_set_expr_location): Recurse on STATEMENT_LIST
1712 that contains exactly one non-DEBUG_BEGIN_STMT statement.
1713
1714 PR debug/94281
1715 * gimple.h (gimple_seq_first_nondebug_stmt): New function.
1716 (gimple_seq_last_nondebug_stmt): Don't return NULL if seq contains
1717 a single non-debug stmt followed by one or more debug stmts.
1718 * gimplify.c (gimplify_body): Use gimple_seq_first_nondebug_stmt
1719 instead of gimple_seq_first_stmt, use gimple_seq_first_nondebug_stmt
1720 and gimple_seq_last_nondebug_stmt instead of gimple_seq_first and
1721 gimple_seq_last to check if outer_stmt gbind could be reused and
1722 if yes and it is surrounded by any debug stmts, move them into the
1723 gbind body.
1724
1725 PR rtl-optimization/92264
1726 * var-tracking.c (add_stores): Call cselib_set_value_sp_based even
1727 for sp based values in !frame_pointer_needed
1728 && !ACCUMULATE_OUTGOING_ARGS functions.
1729
1730 2020-03-26 Felix Yang <felix.yang@huawei.com>
1731
1732 PR tree-optimization/94269
1733 * tree-ssa-math-opts.c (convert_plusminus_to_widen): Restrict
1734 this
1735 operation to single basic block.
1736
1737 2020-03-25 Jeff Law <law@redhat.com>
1738
1739 PR rtl-optimization/90275
1740 * config/sh/sh.md (mov_neg_si_t): Clobber the T register in the
1741 pattern.
1742
1743 2020-03-25 Jakub Jelinek <jakub@redhat.com>
1744
1745 PR target/94292
1746 * config/arm/arm.c (arm_gen_dicompare_reg): Set mode of COMPARE to
1747 mode rather than VOIDmode.
1748
1749 2020-03-25 Martin Sebor <msebor@redhat.com>
1750
1751 PR middle-end/94004
1752 * gimple-ssa-warn-alloca.c (pass_walloca::execute): Issue warnings
1753 even for alloca calls resulting from system macro expansion.
1754 Include inlining context in all warnings.
1755
1756 2020-03-25 Richard Sandiford <richard.sandiford@arm.com>
1757
1758 PR target/94254
1759 * config/rs6000/rs6000.c (rs6000_can_change_mode_class): Allow
1760 FPRs to change between SDmode and DDmode.
1761
1762 2020-03-25 Martin Sebor <msebor@redhat.com>
1763
1764 PR tree-optimization/94131
1765 * gimple-fold.c (get_range_strlen_tree): Fail for variable-length
1766 types and decls.
1767 * tree-ssa-strlen.c (get_range_strlen_dynamic): Avoid assuming
1768 types have constant sizes.
1769
1770 2020-03-25 Martin Liska <mliska@suse.cz>
1771
1772 PR lto/94259
1773 * configure.ac: Report error only when --with-zstd
1774 is used.
1775 * configure: Regenerate.
1776
1777 2020-03-25 Jakub Jelinek <jakub@redhat.com>
1778
1779 PR target/94308
1780 * config/i386/i386-features.c (ix86_add_reg_usage_to_vzeroupper): Set
1781 INSN_CODE (insn) to -1 when changing the pattern.
1782
1783 2020-03-25 Martin Liska <mliska@suse.cz>
1784
1785 PR target/93274
1786 PR ipa/94271
1787 * config/i386/i386-features.c (make_resolver_func): Drop
1788 public flag for resolver.
1789 * config/rs6000/rs6000.c (make_resolver_func): Add comdat
1790 group for resolver and drop public flag if possible.
1791 * multiple_target.c (create_dispatcher_calls): Drop unique_name
1792 and resolution as we want to enable LTO privatization of the default
1793 symbol.
1794
1795 2020-03-25 Martin Liska <mliska@suse.cz>
1796
1797 PR lto/94259
1798 * configure.ac: Respect --without-zstd and report
1799 error when we can't find header file with --with-zstd.
1800 * configure: Regenerate.
1801
1802 2020-03-25 Jakub Jelinek <jakub@redhat.com>
1803
1804 PR middle-end/94303
1805 * varasm.c (output_constructor_array_range): If local->index
1806 RANGE_EXPR doesn't start at the current location in the constructor,
1807 skip needed number of bytes using assemble_zeros or assert we don't
1808 go backwards.
1809
1810 PR c++/94223
1811 * langhooks.c (lhd_set_decl_assembler_name): Use a static ulong
1812 counter instead of DECL_UID.
1813
1814 PR tree-optimization/94300
1815 * tree-ssa-sccvn.c (vn_walk_cb_data::push_partial_def): If pd.offset
1816 is positive, make sure that off + size isn't larger than needed_len.
1817
1818 2020-03-25 Richard Biener <rguenther@suse.de>
1819 Jakub Jelinek <jakub@redhat.com>
1820
1821 PR debug/94283
1822 * tree-if-conv.c (ifcvt_local_dce): Delete dead statements backwards.
1823
1824 2020-03-24 Christophe Lyon <christophe.lyon@linaro.org>
1825
1826 * doc/sourcebuild.texi (ARM-specific attributes): Add
1827 arm_fp_dp_ok.
1828 (Features for dg-add-options): Add arm_fp_dp.
1829
1830 2020-03-24 John David Anglin <danglin@gcc.gnu.org>
1831
1832 PR lto/94249
1833 * config/pa/pa.h (TARGET_CPU_CPP_BUILTINS): Define __BIG_ENDIAN__.
1834
1835 2020-03-24 Tobias Burnus <tobias@codesourcery.com>
1836
1837 PR libgomp/81689
1838 * omp-offload.c (omp_finish_file): Fix target-link handling if
1839 targetm_common.have_named_sections is false.
1840
1841 2020-03-24 Jakub Jelinek <jakub@redhat.com>
1842
1843 PR target/94286
1844 * config/arm/arm.md (subvdi4, usubvsi4, usubvdi4): Use gen_int_mode
1845 instead of GEN_INT.
1846
1847 PR debug/94285
1848 * tree-ssa-loop-manip.c (create_iv): If after, set stmt location to
1849 e->goto_locus even if gsi_bb (*incr_pos) contains only debug stmts.
1850 If not after and at *incr_pos is a debug stmt, set stmt location to
1851 location of next non-debug stmt after it if any.
1852
1853 PR debug/94283
1854 * tree-if-conv.c (ifcvt_local_dce): For gimple debug stmts, just set
1855 GF_PLF_2, but don't add them to worklist. Don't add an assigment to
1856 worklist or set GF_PLF_2 just because it is used in a debug stmt in
1857 another bb. Formatting improvements.
1858
1859 PR debug/94277
1860 * cgraphunit.c (check_global_declaration): For DECL_EXTERNAL and
1861 non-TREE_PUBLIC non-DECL_ARTIFICIAL FUNCTION_DECLs, set TREE_PUBLIC
1862 regardless of whether TREE_NO_WARNING is set on it or whether
1863 warn_unused_function is true or not.
1864
1865 2020-03-23 Jeff Law <law@redhat.com>
1866
1867 PR rtl-optimization/90275
1868 PR target/94238
1869 PR target/94144
1870 * simplify-rtx.c (comparison_code_valid_for_mode): New function.
1871 (simplify_logical_relational_operation): Use it.
1872
1873 2020-03-23 Jakub Jelinek <jakub@redhat.com>
1874
1875 PR c++/91993
1876 * tree.c (get_narrower): Handle COMPOUND_EXPR by recursing on
1877 ultimate rhs and if returned something different, reconstructing
1878 the COMPOUND_EXPRs.
1879
1880 2020-03-23 Lewis Hyatt <lhyatt@gmail.com>
1881
1882 * opts.c (print_filtered_help): Improve the help text for alias options.
1883
1884 2020-03-23 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
1885 Andre Vieira <andre.simoesdiasvieira@arm.com>
1886 Mihail Ionescu <mihail.ionescu@arm.com>
1887
1888 * config/arm/arm_mve.h (vshlcq_m_s8): Define macro.
1889 (vshlcq_m_u8): Likewise.
1890 (vshlcq_m_s16): Likewise.
1891 (vshlcq_m_u16): Likewise.
1892 (vshlcq_m_s32): Likewise.
1893 (vshlcq_m_u32): Likewise.
1894 (__arm_vshlcq_m_s8): Define intrinsic.
1895 (__arm_vshlcq_m_u8): Likewise.
1896 (__arm_vshlcq_m_s16): Likewise.
1897 (__arm_vshlcq_m_u16): Likewise.
1898 (__arm_vshlcq_m_s32): Likewise.
1899 (__arm_vshlcq_m_u32): Likewise.
1900 (vshlcq_m): Define polymorphic variant.
1901 * config/arm/arm_mve_builtins.def (QUADOP_NONE_NONE_UNONE_IMM_UNONE):
1902 Use builtin qualifier.
1903 (QUADOP_UNONE_UNONE_UNONE_IMM_UNONE): Likewise.
1904 * config/arm/mve.md (mve_vshlcq_m_vec_<supf><mode>): Define RTL pattern.
1905 (mve_vshlcq_m_carry_<supf><mode>): Likewise.
1906 (mve_vshlcq_m_<supf><mode>): Likewise.
1907
1908 2020-03-23 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
1909
1910 * config/arm/arm-builtins.c (LSLL_QUALIFIERS): Define builtin qualifier.
1911 (UQSHL_QUALIFIERS): Likewise.
1912 (ASRL_QUALIFIERS): Likewise.
1913 (SQSHL_QUALIFIERS): Likewise.
1914 * config/arm/arm_mve.h (__ARM_BIG_ENDIAN): Check to not support MVE in
1915 Big-Endian Mode.
1916 (sqrshr): Define macro.
1917 (sqrshrl): Likewise.
1918 (sqrshrl_sat48): Likewise.
1919 (sqshl): Likewise.
1920 (sqshll): Likewise.
1921 (srshr): Likewise.
1922 (srshrl): Likewise.
1923 (uqrshl): Likewise.
1924 (uqrshll): Likewise.
1925 (uqrshll_sat48): Likewise.
1926 (uqshl): Likewise.
1927 (uqshll): Likewise.
1928 (urshr): Likewise.
1929 (urshrl): Likewise.
1930 (lsll): Likewise.
1931 (asrl): Likewise.
1932 (__arm_lsll): Define intrinsic.
1933 (__arm_asrl): Likewise.
1934 (__arm_uqrshll): Likewise.
1935 (__arm_uqrshll_sat48): Likewise.
1936 (__arm_sqrshrl): Likewise.
1937 (__arm_sqrshrl_sat48): Likewise.
1938 (__arm_uqshll): Likewise.
1939 (__arm_urshrl): Likewise.
1940 (__arm_srshrl): Likewise.
1941 (__arm_sqshll): Likewise.
1942 (__arm_uqrshl): Likewise.
1943 (__arm_sqrshr): Likewise.
1944 (__arm_uqshl): Likewise.
1945 (__arm_urshr): Likewise.
1946 (__arm_sqshl): Likewise.
1947 (__arm_srshr): Likewise.
1948 * config/arm/arm_mve_builtins.def (LSLL_QUALIFIERS): Use builtin
1949 qualifier.
1950 (UQSHL_QUALIFIERS): Likewise.
1951 (ASRL_QUALIFIERS): Likewise.
1952 (SQSHL_QUALIFIERS): Likewise.
1953 * config/arm/mve.md (mve_uqrshll_sat<supf>_di): Define RTL pattern.
1954 (mve_sqrshrl_sat<supf>_di): Likewise.
1955 (mve_uqrshl_si): Likewise.
1956 (mve_sqrshr_si): Likewise.
1957 (mve_uqshll_di): Likewise.
1958 (mve_urshrl_di): Likewise.
1959 (mve_uqshl_si): Likewise.
1960 (mve_urshr_si): Likewise.
1961 (mve_sqshl_si): Likewise.
1962 (mve_srshr_si): Likewise.
1963 (mve_srshrl_di): Likewise.
1964 (mve_sqshll_di): Likewise.
1965
1966 2020-03-23 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
1967 Andre Vieira <andre.simoesdiasvieira@arm.com>
1968 Mihail Ionescu <mihail.ionescu@arm.com>
1969
1970 * config/arm/arm_mve.h (vsetq_lane_f16): Define macro.
1971 (vsetq_lane_f32): Likewise.
1972 (vsetq_lane_s16): Likewise.
1973 (vsetq_lane_s32): Likewise.
1974 (vsetq_lane_s8): Likewise.
1975 (vsetq_lane_s64): Likewise.
1976 (vsetq_lane_u8): Likewise.
1977 (vsetq_lane_u16): Likewise.
1978 (vsetq_lane_u32): Likewise.
1979 (vsetq_lane_u64): Likewise.
1980 (vgetq_lane_f16): Likewise.
1981 (vgetq_lane_f32): Likewise.
1982 (vgetq_lane_s16): Likewise.
1983 (vgetq_lane_s32): Likewise.
1984 (vgetq_lane_s8): Likewise.
1985 (vgetq_lane_s64): Likewise.
1986 (vgetq_lane_u8): Likewise.
1987 (vgetq_lane_u16): Likewise.
1988 (vgetq_lane_u32): Likewise.
1989 (vgetq_lane_u64): Likewise.
1990 (__ARM_NUM_LANES): Likewise.
1991 (__ARM_LANEQ): Likewise.
1992 (__ARM_CHECK_LANEQ): Likewise.
1993 (__arm_vsetq_lane_s16): Define intrinsic.
1994 (__arm_vsetq_lane_s32): Likewise.
1995 (__arm_vsetq_lane_s8): Likewise.
1996 (__arm_vsetq_lane_s64): Likewise.
1997 (__arm_vsetq_lane_u8): Likewise.
1998 (__arm_vsetq_lane_u16): Likewise.
1999 (__arm_vsetq_lane_u32): Likewise.
2000 (__arm_vsetq_lane_u64): Likewise.
2001 (__arm_vgetq_lane_s16): Likewise.
2002 (__arm_vgetq_lane_s32): Likewise.
2003 (__arm_vgetq_lane_s8): Likewise.
2004 (__arm_vgetq_lane_s64): Likewise.
2005 (__arm_vgetq_lane_u8): Likewise.
2006 (__arm_vgetq_lane_u16): Likewise.
2007 (__arm_vgetq_lane_u32): Likewise.
2008 (__arm_vgetq_lane_u64): Likewise.
2009 (__arm_vsetq_lane_f16): Likewise.
2010 (__arm_vsetq_lane_f32): Likewise.
2011 (__arm_vgetq_lane_f16): Likewise.
2012 (__arm_vgetq_lane_f32): Likewise.
2013 (vgetq_lane): Define polymorphic variant.
2014 (vsetq_lane): Likewise.
2015 * config/arm/mve.md (mve_vec_extract<mode><V_elem_l>): Define RTL
2016 pattern.
2017 (mve_vec_extractv2didi): Likewise.
2018 (mve_vec_extract_sext_internal<mode>): Likewise.
2019 (mve_vec_extract_zext_internal<mode>): Likewise.
2020 (mve_vec_set<mode>_internal): Likewise.
2021 (mve_vec_setv2di_internal): Likewise.
2022 * config/arm/neon.md (vec_set<mode>): Move RTL pattern to vec-common.md
2023 file.
2024 (vec_extract<mode><V_elem_l>): Rename to
2025 "neon_vec_extract<mode><V_elem_l>".
2026 (vec_extractv2didi): Rename to "neon_vec_extractv2didi".
2027 * config/arm/vec-common.md (vec_extract<mode><V_elem_l>): Define RTL
2028 pattern common for MVE and NEON.
2029 (vec_set<mode>): Move RTL pattern from neon.md and modify to accept both
2030 MVE and NEON.
2031
2032 2020-03-23 Andre Vieira <andre.simoesdiasvieira@arm.com>
2033
2034 * config/arm/mve.md (earlyclobber_32): New mode attribute.
2035 (mve_vrev64q_*, mve_vcaddq*, mve_vhcaddq_*, mve_vcmulq_*,
2036 mve_vmull[bt]q_*, mve_vqdmull[bt]q_*): Add appropriate early clobbers.
2037
2038 2020-03-23 Richard Biener <rguenther@suse.de>
2039
2040 PR tree-optimization/94261
2041 * tree-vect-slp.c (vect_get_and_check_slp_defs): Remove
2042 IL operand swapping code.
2043 (vect_slp_rearrange_stmts): Do not arrange isomorphic
2044 nodes that would need operation code adjustments.
2045
2046 2020-03-23 Tobias Burnus <tobias@codesourcery.com>
2047
2048 * doc/install.texi (amdgcn-*-amdhsa): Renamed
2049 from amdgcn-unknown-amdhsa; change
2050 amdgcn-unknown-amdhsa to amdgcn-amdhsa.
2051
2052 2020-03-23 Richard Biener <rguenther@suse.de>
2053
2054 PR ipa/94245
2055 * ipa-prop.c (ipa_read_jump_function): Build the ADDR_EXRP
2056 directly rather than also folding it via build_fold_addr_expr.
2057
2058 2020-03-23 Richard Biener <rguenther@suse.de>
2059
2060 PR tree-optimization/94266
2061 * tree-ssa-forwprop.c (pass_forwprop::execute): Do not propagate
2062 addresses of TARGET_MEM_REFs.
2063
2064 2020-03-23 Martin Liska <mliska@suse.cz>
2065
2066 PR ipa/94250
2067 * symtab.c (symtab_node::clone_references): Save speculative_id
2068 as ref may be overwritten by create_reference.
2069 (symtab_node::clone_referring): Likewise.
2070 (symtab_node::clone_reference): Likewise.
2071
2072 2020-03-22 Iain Sandoe <iain@sandoe.co.uk>
2073
2074 * config/i386/darwin.h (JUMP_TABLES_IN_TEXT_SECTION): Remove
2075 references to Darwin.
2076 * config/i386/i386.h (JUMP_TABLES_IN_TEXT_SECTION): Define this
2077 unconditionally and comment on why.
2078
2079 2020-03-21 Iain Sandoe <iain@sandoe.co.uk>
2080
2081 * config/darwin.c (darwin_mergeable_constant_section): Collect
2082 section anchor checks into the caller.
2083 (machopic_select_section): Collect section anchor checks into
2084 the determination of 'effective zero-size' objects. When the
2085 size is unknown, assume it is non-zero, and thus return the
2086 'generic' section for the DECL.
2087
2088 2020-03-21 Iain Sandoe <iain@sandoe.co.uk>
2089
2090 PR target/93694
2091 * gcc/config/darwin.opt: Amend options descriptions.
2092
2093 2020-03-21 Richard Sandiford <richard.sandiford@arm.com>
2094
2095 PR rtl-optimization/94052
2096 * lra-constraints.c (simplify_operand_subreg): Reload the inner
2097 register of a paradoxical subreg if simplify_subreg_regno fails
2098 to give a valid hard register for the outer mode.
2099
2100 2020-03-20 Martin Jambor <mjambor@suse.cz>
2101
2102 PR tree-optimization/93435
2103 * params.opt (sra-max-propagations): New parameter.
2104 * tree-sra.c (propagation_budget): New variable.
2105 (budget_for_propagation_access): New function.
2106 (propagate_subaccesses_from_rhs): Use it.
2107 (propagate_subaccesses_from_lhs): Likewise.
2108 (propagate_all_subaccesses): Set up and destroy propagation_budget.
2109
2110 2020-03-20 Carl Love <cel@us.ibm.com>
2111
2112 PR/target 87583
2113 * gcc/config/rs6000/rs6000.c (rs6000_option_override_internal):
2114 Add check for TARGET_FPRND for Power 7 or newer.
2115
2116 2020-03-20 Jan Hubicka <hubicka@ucw.cz>
2117
2118 PR ipa/93347
2119 * cgraph.c (symbol_table::create_edge): Update calls_comdat_local flag.
2120 (cgraph_edge::redirect_callee): Move here; likewise.
2121 (cgraph_node::remove_callees): Update calls_comdat_local flag.
2122 (cgraph_node::verify_node): Verify that calls_comdat_local flag match
2123 reality.
2124 (cgraph_node::check_calls_comdat_local_p): New member function.
2125 * cgraph.h (cgraph_node::check_calls_comdat_local_p): Declare.
2126 (cgraph_edge::redirect_callee): Move offline.
2127 * ipa-fnsummary.c (compute_fn_summary): Do not compute
2128 calls_comdat_local flag here.
2129 * ipa-inline-transform.c (inline_call): Fix updating of
2130 calls_comdat_local flag.
2131 * ipa-split.c (split_function): Use true instead of 1 to set the flag.
2132 * symtab.c (symtab_node::add_to_same_comdat_group): Update
2133 calls_comdat_local flag.
2134
2135 2020-03-20 Richard Biener <rguenther@suse.de>
2136
2137 * tree-vect-slp.c (vect_analyze_slp_instance): Dump SLP tree
2138 from the possibly modified root.
2139
2140 2020-03-20 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
2141 Andre Vieira <andre.simoesdiasvieira@arm.com>
2142 Mihail Ionescu <mihail.ionescu@arm.com>
2143
2144 * config/arm/arm_mve.h (vst1q_p_u8): Define macro.
2145 (vst1q_p_s8): Likewise.
2146 (vst2q_s8): Likewise.
2147 (vst2q_u8): Likewise.
2148 (vld1q_z_u8): Likewise.
2149 (vld1q_z_s8): Likewise.
2150 (vld2q_s8): Likewise.
2151 (vld2q_u8): Likewise.
2152 (vld4q_s8): Likewise.
2153 (vld4q_u8): Likewise.
2154 (vst1q_p_u16): Likewise.
2155 (vst1q_p_s16): Likewise.
2156 (vst2q_s16): Likewise.
2157 (vst2q_u16): Likewise.
2158 (vld1q_z_u16): Likewise.
2159 (vld1q_z_s16): Likewise.
2160 (vld2q_s16): Likewise.
2161 (vld2q_u16): Likewise.
2162 (vld4q_s16): Likewise.
2163 (vld4q_u16): Likewise.
2164 (vst1q_p_u32): Likewise.
2165 (vst1q_p_s32): Likewise.
2166 (vst2q_s32): Likewise.
2167 (vst2q_u32): Likewise.
2168 (vld1q_z_u32): Likewise.
2169 (vld1q_z_s32): Likewise.
2170 (vld2q_s32): Likewise.
2171 (vld2q_u32): Likewise.
2172 (vld4q_s32): Likewise.
2173 (vld4q_u32): Likewise.
2174 (vld4q_f16): Likewise.
2175 (vld2q_f16): Likewise.
2176 (vld1q_z_f16): Likewise.
2177 (vst2q_f16): Likewise.
2178 (vst1q_p_f16): Likewise.
2179 (vld4q_f32): Likewise.
2180 (vld2q_f32): Likewise.
2181 (vld1q_z_f32): Likewise.
2182 (vst2q_f32): Likewise.
2183 (vst1q_p_f32): Likewise.
2184 (__arm_vst1q_p_u8): Define intrinsic.
2185 (__arm_vst1q_p_s8): Likewise.
2186 (__arm_vst2q_s8): Likewise.
2187 (__arm_vst2q_u8): Likewise.
2188 (__arm_vld1q_z_u8): Likewise.
2189 (__arm_vld1q_z_s8): Likewise.
2190 (__arm_vld2q_s8): Likewise.
2191 (__arm_vld2q_u8): Likewise.
2192 (__arm_vld4q_s8): Likewise.
2193 (__arm_vld4q_u8): Likewise.
2194 (__arm_vst1q_p_u16): Likewise.
2195 (__arm_vst1q_p_s16): Likewise.
2196 (__arm_vst2q_s16): Likewise.
2197 (__arm_vst2q_u16): Likewise.
2198 (__arm_vld1q_z_u16): Likewise.
2199 (__arm_vld1q_z_s16): Likewise.
2200 (__arm_vld2q_s16): Likewise.
2201 (__arm_vld2q_u16): Likewise.
2202 (__arm_vld4q_s16): Likewise.
2203 (__arm_vld4q_u16): Likewise.
2204 (__arm_vst1q_p_u32): Likewise.
2205 (__arm_vst1q_p_s32): Likewise.
2206 (__arm_vst2q_s32): Likewise.
2207 (__arm_vst2q_u32): Likewise.
2208 (__arm_vld1q_z_u32): Likewise.
2209 (__arm_vld1q_z_s32): Likewise.
2210 (__arm_vld2q_s32): Likewise.
2211 (__arm_vld2q_u32): Likewise.
2212 (__arm_vld4q_s32): Likewise.
2213 (__arm_vld4q_u32): Likewise.
2214 (__arm_vld4q_f16): Likewise.
2215 (__arm_vld2q_f16): Likewise.
2216 (__arm_vld1q_z_f16): Likewise.
2217 (__arm_vst2q_f16): Likewise.
2218 (__arm_vst1q_p_f16): Likewise.
2219 (__arm_vld4q_f32): Likewise.
2220 (__arm_vld2q_f32): Likewise.
2221 (__arm_vld1q_z_f32): Likewise.
2222 (__arm_vst2q_f32): Likewise.
2223 (__arm_vst1q_p_f32): Likewise.
2224 (vld1q_z): Define polymorphic variant.
2225 (vld2q): Likewise.
2226 (vld4q): Likewise.
2227 (vst1q_p): Likewise.
2228 (vst2q): Likewise.
2229 * config/arm/arm_mve_builtins.def (STORE1): Use builtin qualifier.
2230 (LOAD1): Likewise.
2231 * config/arm/mve.md (mve_vst2q<mode>): Define RTL pattern.
2232 (mve_vld2q<mode>): Likewise.
2233 (mve_vld4q<mode>): Likewise.
2234
2235 2020-03-20 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
2236 Andre Vieira <andre.simoesdiasvieira@arm.com>
2237 Mihail Ionescu <mihail.ionescu@arm.com>
2238
2239 * config/arm/arm-builtins.c (ARM_BUILTIN_GET_FPSCR_NZCVQC): Define.
2240 (ARM_BUILTIN_SET_FPSCR_NZCVQC): Likewise.
2241 (arm_init_mve_builtins): Add "__builtin_arm_get_fpscr_nzcvqc" and
2242 "__builtin_arm_set_fpscr_nzcvqc" to arm_builtin_decls array.
2243 (arm_expand_builtin): Define case ARM_BUILTIN_GET_FPSCR_NZCVQC
2244 and ARM_BUILTIN_SET_FPSCR_NZCVQC.
2245 * config/arm/arm_mve.h (vadciq_s32): Define macro.
2246 (vadciq_u32): Likewise.
2247 (vadciq_m_s32): Likewise.
2248 (vadciq_m_u32): Likewise.
2249 (vadcq_s32): Likewise.
2250 (vadcq_u32): Likewise.
2251 (vadcq_m_s32): Likewise.
2252 (vadcq_m_u32): Likewise.
2253 (vsbciq_s32): Likewise.
2254 (vsbciq_u32): Likewise.
2255 (vsbciq_m_s32): Likewise.
2256 (vsbciq_m_u32): Likewise.
2257 (vsbcq_s32): Likewise.
2258 (vsbcq_u32): Likewise.
2259 (vsbcq_m_s32): Likewise.
2260 (vsbcq_m_u32): Likewise.
2261 (__arm_vadciq_s32): Define intrinsic.
2262 (__arm_vadciq_u32): Likewise.
2263 (__arm_vadciq_m_s32): Likewise.
2264 (__arm_vadciq_m_u32): Likewise.
2265 (__arm_vadcq_s32): Likewise.
2266 (__arm_vadcq_u32): Likewise.
2267 (__arm_vadcq_m_s32): Likewise.
2268 (__arm_vadcq_m_u32): Likewise.
2269 (__arm_vsbciq_s32): Likewise.
2270 (__arm_vsbciq_u32): Likewise.
2271 (__arm_vsbciq_m_s32): Likewise.
2272 (__arm_vsbciq_m_u32): Likewise.
2273 (__arm_vsbcq_s32): Likewise.
2274 (__arm_vsbcq_u32): Likewise.
2275 (__arm_vsbcq_m_s32): Likewise.
2276 (__arm_vsbcq_m_u32): Likewise.
2277 (vadciq_m): Define polymorphic variant.
2278 (vadciq): Likewise.
2279 (vadcq_m): Likewise.
2280 (vadcq): Likewise.
2281 (vsbciq_m): Likewise.
2282 (vsbciq): Likewise.
2283 (vsbcq_m): Likewise.
2284 (vsbcq): Likewise.
2285 * config/arm/arm_mve_builtins.def (BINOP_NONE_NONE_NONE): Use builtin
2286 qualifier.
2287 (BINOP_UNONE_UNONE_UNONE): Likewise.
2288 (QUADOP_NONE_NONE_NONE_NONE_UNONE): Likewise.
2289 (QUADOP_UNONE_UNONE_UNONE_UNONE_UNONE): Likewise.
2290 * config/arm/mve.md (VADCIQ): Define iterator.
2291 (VADCIQ_M): Likewise.
2292 (VSBCQ): Likewise.
2293 (VSBCQ_M): Likewise.
2294 (VSBCIQ): Likewise.
2295 (VSBCIQ_M): Likewise.
2296 (VADCQ): Likewise.
2297 (VADCQ_M): Likewise.
2298 (mve_vadciq_m_<supf>v4si): Define RTL pattern.
2299 (mve_vadciq_<supf>v4si): Likewise.
2300 (mve_vadcq_m_<supf>v4si): Likewise.
2301 (mve_vadcq_<supf>v4si): Likewise.
2302 (mve_vsbciq_m_<supf>v4si): Likewise.
2303 (mve_vsbciq_<supf>v4si): Likewise.
2304 (mve_vsbcq_m_<supf>v4si): Likewise.
2305 (mve_vsbcq_<supf>v4si): Likewise.
2306 (get_fpscr_nzcvqc): Define isns.
2307 (set_fpscr_nzcvqc): Define isns.
2308 * config/arm/unspecs.md (UNSPEC_GET_FPSCR_NZCVQC): Define.
2309 (UNSPEC_SET_FPSCR_NZCVQC): Define.
2310
2311 2020-03-20 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
2312
2313 * config/arm/arm_mve.h (vddupq_x_n_u8): Define macro.
2314 (vddupq_x_n_u16): Likewise.
2315 (vddupq_x_n_u32): Likewise.
2316 (vddupq_x_wb_u8): Likewise.
2317 (vddupq_x_wb_u16): Likewise.
2318 (vddupq_x_wb_u32): Likewise.
2319 (vdwdupq_x_n_u8): Likewise.
2320 (vdwdupq_x_n_u16): Likewise.
2321 (vdwdupq_x_n_u32): Likewise.
2322 (vdwdupq_x_wb_u8): Likewise.
2323 (vdwdupq_x_wb_u16): Likewise.
2324 (vdwdupq_x_wb_u32): Likewise.
2325 (vidupq_x_n_u8): Likewise.
2326 (vidupq_x_n_u16): Likewise.
2327 (vidupq_x_n_u32): Likewise.
2328 (vidupq_x_wb_u8): Likewise.
2329 (vidupq_x_wb_u16): Likewise.
2330 (vidupq_x_wb_u32): Likewise.
2331 (viwdupq_x_n_u8): Likewise.
2332 (viwdupq_x_n_u16): Likewise.
2333 (viwdupq_x_n_u32): Likewise.
2334 (viwdupq_x_wb_u8): Likewise.
2335 (viwdupq_x_wb_u16): Likewise.
2336 (viwdupq_x_wb_u32): Likewise.
2337 (vdupq_x_n_s8): Likewise.
2338 (vdupq_x_n_s16): Likewise.
2339 (vdupq_x_n_s32): Likewise.
2340 (vdupq_x_n_u8): Likewise.
2341 (vdupq_x_n_u16): Likewise.
2342 (vdupq_x_n_u32): Likewise.
2343 (vminq_x_s8): Likewise.
2344 (vminq_x_s16): Likewise.
2345 (vminq_x_s32): Likewise.
2346 (vminq_x_u8): Likewise.
2347 (vminq_x_u16): Likewise.
2348 (vminq_x_u32): Likewise.
2349 (vmaxq_x_s8): Likewise.
2350 (vmaxq_x_s16): Likewise.
2351 (vmaxq_x_s32): Likewise.
2352 (vmaxq_x_u8): Likewise.
2353 (vmaxq_x_u16): Likewise.
2354 (vmaxq_x_u32): Likewise.
2355 (vabdq_x_s8): Likewise.
2356 (vabdq_x_s16): Likewise.
2357 (vabdq_x_s32): Likewise.
2358 (vabdq_x_u8): Likewise.
2359 (vabdq_x_u16): Likewise.
2360 (vabdq_x_u32): Likewise.
2361 (vabsq_x_s8): Likewise.
2362 (vabsq_x_s16): Likewise.
2363 (vabsq_x_s32): Likewise.
2364 (vaddq_x_s8): Likewise.
2365 (vaddq_x_s16): Likewise.
2366 (vaddq_x_s32): Likewise.
2367 (vaddq_x_n_s8): Likewise.
2368 (vaddq_x_n_s16): Likewise.
2369 (vaddq_x_n_s32): Likewise.
2370 (vaddq_x_u8): Likewise.
2371 (vaddq_x_u16): Likewise.
2372 (vaddq_x_u32): Likewise.
2373 (vaddq_x_n_u8): Likewise.
2374 (vaddq_x_n_u16): Likewise.
2375 (vaddq_x_n_u32): Likewise.
2376 (vclsq_x_s8): Likewise.
2377 (vclsq_x_s16): Likewise.
2378 (vclsq_x_s32): Likewise.
2379 (vclzq_x_s8): Likewise.
2380 (vclzq_x_s16): Likewise.
2381 (vclzq_x_s32): Likewise.
2382 (vclzq_x_u8): Likewise.
2383 (vclzq_x_u16): Likewise.
2384 (vclzq_x_u32): Likewise.
2385 (vnegq_x_s8): Likewise.
2386 (vnegq_x_s16): Likewise.
2387 (vnegq_x_s32): Likewise.
2388 (vmulhq_x_s8): Likewise.
2389 (vmulhq_x_s16): Likewise.
2390 (vmulhq_x_s32): Likewise.
2391 (vmulhq_x_u8): Likewise.
2392 (vmulhq_x_u16): Likewise.
2393 (vmulhq_x_u32): Likewise.
2394 (vmullbq_poly_x_p8): Likewise.
2395 (vmullbq_poly_x_p16): Likewise.
2396 (vmullbq_int_x_s8): Likewise.
2397 (vmullbq_int_x_s16): Likewise.
2398 (vmullbq_int_x_s32): Likewise.
2399 (vmullbq_int_x_u8): Likewise.
2400 (vmullbq_int_x_u16): Likewise.
2401 (vmullbq_int_x_u32): Likewise.
2402 (vmulltq_poly_x_p8): Likewise.
2403 (vmulltq_poly_x_p16): Likewise.
2404 (vmulltq_int_x_s8): Likewise.
2405 (vmulltq_int_x_s16): Likewise.
2406 (vmulltq_int_x_s32): Likewise.
2407 (vmulltq_int_x_u8): Likewise.
2408 (vmulltq_int_x_u16): Likewise.
2409 (vmulltq_int_x_u32): Likewise.
2410 (vmulq_x_s8): Likewise.
2411 (vmulq_x_s16): Likewise.
2412 (vmulq_x_s32): Likewise.
2413 (vmulq_x_n_s8): Likewise.
2414 (vmulq_x_n_s16): Likewise.
2415 (vmulq_x_n_s32): Likewise.
2416 (vmulq_x_u8): Likewise.
2417 (vmulq_x_u16): Likewise.
2418 (vmulq_x_u32): Likewise.
2419 (vmulq_x_n_u8): Likewise.
2420 (vmulq_x_n_u16): Likewise.
2421 (vmulq_x_n_u32): Likewise.
2422 (vsubq_x_s8): Likewise.
2423 (vsubq_x_s16): Likewise.
2424 (vsubq_x_s32): Likewise.
2425 (vsubq_x_n_s8): Likewise.
2426 (vsubq_x_n_s16): Likewise.
2427 (vsubq_x_n_s32): Likewise.
2428 (vsubq_x_u8): Likewise.
2429 (vsubq_x_u16): Likewise.
2430 (vsubq_x_u32): Likewise.
2431 (vsubq_x_n_u8): Likewise.
2432 (vsubq_x_n_u16): Likewise.
2433 (vsubq_x_n_u32): Likewise.
2434 (vcaddq_rot90_x_s8): Likewise.
2435 (vcaddq_rot90_x_s16): Likewise.
2436 (vcaddq_rot90_x_s32): Likewise.
2437 (vcaddq_rot90_x_u8): Likewise.
2438 (vcaddq_rot90_x_u16): Likewise.
2439 (vcaddq_rot90_x_u32): Likewise.
2440 (vcaddq_rot270_x_s8): Likewise.
2441 (vcaddq_rot270_x_s16): Likewise.
2442 (vcaddq_rot270_x_s32): Likewise.
2443 (vcaddq_rot270_x_u8): Likewise.
2444 (vcaddq_rot270_x_u16): Likewise.
2445 (vcaddq_rot270_x_u32): Likewise.
2446 (vhaddq_x_n_s8): Likewise.
2447 (vhaddq_x_n_s16): Likewise.
2448 (vhaddq_x_n_s32): Likewise.
2449 (vhaddq_x_n_u8): Likewise.
2450 (vhaddq_x_n_u16): Likewise.
2451 (vhaddq_x_n_u32): Likewise.
2452 (vhaddq_x_s8): Likewise.
2453 (vhaddq_x_s16): Likewise.
2454 (vhaddq_x_s32): Likewise.
2455 (vhaddq_x_u8): Likewise.
2456 (vhaddq_x_u16): Likewise.
2457 (vhaddq_x_u32): Likewise.
2458 (vhcaddq_rot90_x_s8): Likewise.
2459 (vhcaddq_rot90_x_s16): Likewise.
2460 (vhcaddq_rot90_x_s32): Likewise.
2461 (vhcaddq_rot270_x_s8): Likewise.
2462 (vhcaddq_rot270_x_s16): Likewise.
2463 (vhcaddq_rot270_x_s32): Likewise.
2464 (vhsubq_x_n_s8): Likewise.
2465 (vhsubq_x_n_s16): Likewise.
2466 (vhsubq_x_n_s32): Likewise.
2467 (vhsubq_x_n_u8): Likewise.
2468 (vhsubq_x_n_u16): Likewise.
2469 (vhsubq_x_n_u32): Likewise.
2470 (vhsubq_x_s8): Likewise.
2471 (vhsubq_x_s16): Likewise.
2472 (vhsubq_x_s32): Likewise.
2473 (vhsubq_x_u8): Likewise.
2474 (vhsubq_x_u16): Likewise.
2475 (vhsubq_x_u32): Likewise.
2476 (vrhaddq_x_s8): Likewise.
2477 (vrhaddq_x_s16): Likewise.
2478 (vrhaddq_x_s32): Likewise.
2479 (vrhaddq_x_u8): Likewise.
2480 (vrhaddq_x_u16): Likewise.
2481 (vrhaddq_x_u32): Likewise.
2482 (vrmulhq_x_s8): Likewise.
2483 (vrmulhq_x_s16): Likewise.
2484 (vrmulhq_x_s32): Likewise.
2485 (vrmulhq_x_u8): Likewise.
2486 (vrmulhq_x_u16): Likewise.
2487 (vrmulhq_x_u32): Likewise.
2488 (vandq_x_s8): Likewise.
2489 (vandq_x_s16): Likewise.
2490 (vandq_x_s32): Likewise.
2491 (vandq_x_u8): Likewise.
2492 (vandq_x_u16): Likewise.
2493 (vandq_x_u32): Likewise.
2494 (vbicq_x_s8): Likewise.
2495 (vbicq_x_s16): Likewise.
2496 (vbicq_x_s32): Likewise.
2497 (vbicq_x_u8): Likewise.
2498 (vbicq_x_u16): Likewise.
2499 (vbicq_x_u32): Likewise.
2500 (vbrsrq_x_n_s8): Likewise.
2501 (vbrsrq_x_n_s16): Likewise.
2502 (vbrsrq_x_n_s32): Likewise.
2503 (vbrsrq_x_n_u8): Likewise.
2504 (vbrsrq_x_n_u16): Likewise.
2505 (vbrsrq_x_n_u32): Likewise.
2506 (veorq_x_s8): Likewise.
2507 (veorq_x_s16): Likewise.
2508 (veorq_x_s32): Likewise.
2509 (veorq_x_u8): Likewise.
2510 (veorq_x_u16): Likewise.
2511 (veorq_x_u32): Likewise.
2512 (vmovlbq_x_s8): Likewise.
2513 (vmovlbq_x_s16): Likewise.
2514 (vmovlbq_x_u8): Likewise.
2515 (vmovlbq_x_u16): Likewise.
2516 (vmovltq_x_s8): Likewise.
2517 (vmovltq_x_s16): Likewise.
2518 (vmovltq_x_u8): Likewise.
2519 (vmovltq_x_u16): Likewise.
2520 (vmvnq_x_s8): Likewise.
2521 (vmvnq_x_s16): Likewise.
2522 (vmvnq_x_s32): Likewise.
2523 (vmvnq_x_u8): Likewise.
2524 (vmvnq_x_u16): Likewise.
2525 (vmvnq_x_u32): Likewise.
2526 (vmvnq_x_n_s16): Likewise.
2527 (vmvnq_x_n_s32): Likewise.
2528 (vmvnq_x_n_u16): Likewise.
2529 (vmvnq_x_n_u32): Likewise.
2530 (vornq_x_s8): Likewise.
2531 (vornq_x_s16): Likewise.
2532 (vornq_x_s32): Likewise.
2533 (vornq_x_u8): Likewise.
2534 (vornq_x_u16): Likewise.
2535 (vornq_x_u32): Likewise.
2536 (vorrq_x_s8): Likewise.
2537 (vorrq_x_s16): Likewise.
2538 (vorrq_x_s32): Likewise.
2539 (vorrq_x_u8): Likewise.
2540 (vorrq_x_u16): Likewise.
2541 (vorrq_x_u32): Likewise.
2542 (vrev16q_x_s8): Likewise.
2543 (vrev16q_x_u8): Likewise.
2544 (vrev32q_x_s8): Likewise.
2545 (vrev32q_x_s16): Likewise.
2546 (vrev32q_x_u8): Likewise.
2547 (vrev32q_x_u16): Likewise.
2548 (vrev64q_x_s8): Likewise.
2549 (vrev64q_x_s16): Likewise.
2550 (vrev64q_x_s32): Likewise.
2551 (vrev64q_x_u8): Likewise.
2552 (vrev64q_x_u16): Likewise.
2553 (vrev64q_x_u32): Likewise.
2554 (vrshlq_x_s8): Likewise.
2555 (vrshlq_x_s16): Likewise.
2556 (vrshlq_x_s32): Likewise.
2557 (vrshlq_x_u8): Likewise.
2558 (vrshlq_x_u16): Likewise.
2559 (vrshlq_x_u32): Likewise.
2560 (vshllbq_x_n_s8): Likewise.
2561 (vshllbq_x_n_s16): Likewise.
2562 (vshllbq_x_n_u8): Likewise.
2563 (vshllbq_x_n_u16): Likewise.
2564 (vshlltq_x_n_s8): Likewise.
2565 (vshlltq_x_n_s16): Likewise.
2566 (vshlltq_x_n_u8): Likewise.
2567 (vshlltq_x_n_u16): Likewise.
2568 (vshlq_x_s8): Likewise.
2569 (vshlq_x_s16): Likewise.
2570 (vshlq_x_s32): Likewise.
2571 (vshlq_x_u8): Likewise.
2572 (vshlq_x_u16): Likewise.
2573 (vshlq_x_u32): Likewise.
2574 (vshlq_x_n_s8): Likewise.
2575 (vshlq_x_n_s16): Likewise.
2576 (vshlq_x_n_s32): Likewise.
2577 (vshlq_x_n_u8): Likewise.
2578 (vshlq_x_n_u16): Likewise.
2579 (vshlq_x_n_u32): Likewise.
2580 (vrshrq_x_n_s8): Likewise.
2581 (vrshrq_x_n_s16): Likewise.
2582 (vrshrq_x_n_s32): Likewise.
2583 (vrshrq_x_n_u8): Likewise.
2584 (vrshrq_x_n_u16): Likewise.
2585 (vrshrq_x_n_u32): Likewise.
2586 (vshrq_x_n_s8): Likewise.
2587 (vshrq_x_n_s16): Likewise.
2588 (vshrq_x_n_s32): Likewise.
2589 (vshrq_x_n_u8): Likewise.
2590 (vshrq_x_n_u16): Likewise.
2591 (vshrq_x_n_u32): Likewise.
2592 (vdupq_x_n_f16): Likewise.
2593 (vdupq_x_n_f32): Likewise.
2594 (vminnmq_x_f16): Likewise.
2595 (vminnmq_x_f32): Likewise.
2596 (vmaxnmq_x_f16): Likewise.
2597 (vmaxnmq_x_f32): Likewise.
2598 (vabdq_x_f16): Likewise.
2599 (vabdq_x_f32): Likewise.
2600 (vabsq_x_f16): Likewise.
2601 (vabsq_x_f32): Likewise.
2602 (vaddq_x_f16): Likewise.
2603 (vaddq_x_f32): Likewise.
2604 (vaddq_x_n_f16): Likewise.
2605 (vaddq_x_n_f32): Likewise.
2606 (vnegq_x_f16): Likewise.
2607 (vnegq_x_f32): Likewise.
2608 (vmulq_x_f16): Likewise.
2609 (vmulq_x_f32): Likewise.
2610 (vmulq_x_n_f16): Likewise.
2611 (vmulq_x_n_f32): Likewise.
2612 (vsubq_x_f16): Likewise.
2613 (vsubq_x_f32): Likewise.
2614 (vsubq_x_n_f16): Likewise.
2615 (vsubq_x_n_f32): Likewise.
2616 (vcaddq_rot90_x_f16): Likewise.
2617 (vcaddq_rot90_x_f32): Likewise.
2618 (vcaddq_rot270_x_f16): Likewise.
2619 (vcaddq_rot270_x_f32): Likewise.
2620 (vcmulq_x_f16): Likewise.
2621 (vcmulq_x_f32): Likewise.
2622 (vcmulq_rot90_x_f16): Likewise.
2623 (vcmulq_rot90_x_f32): Likewise.
2624 (vcmulq_rot180_x_f16): Likewise.
2625 (vcmulq_rot180_x_f32): Likewise.
2626 (vcmulq_rot270_x_f16): Likewise.
2627 (vcmulq_rot270_x_f32): Likewise.
2628 (vcvtaq_x_s16_f16): Likewise.
2629 (vcvtaq_x_s32_f32): Likewise.
2630 (vcvtaq_x_u16_f16): Likewise.
2631 (vcvtaq_x_u32_f32): Likewise.
2632 (vcvtnq_x_s16_f16): Likewise.
2633 (vcvtnq_x_s32_f32): Likewise.
2634 (vcvtnq_x_u16_f16): Likewise.
2635 (vcvtnq_x_u32_f32): Likewise.
2636 (vcvtpq_x_s16_f16): Likewise.
2637 (vcvtpq_x_s32_f32): Likewise.
2638 (vcvtpq_x_u16_f16): Likewise.
2639 (vcvtpq_x_u32_f32): Likewise.
2640 (vcvtmq_x_s16_f16): Likewise.
2641 (vcvtmq_x_s32_f32): Likewise.
2642 (vcvtmq_x_u16_f16): Likewise.
2643 (vcvtmq_x_u32_f32): Likewise.
2644 (vcvtbq_x_f32_f16): Likewise.
2645 (vcvttq_x_f32_f16): Likewise.
2646 (vcvtq_x_f16_u16): Likewise.
2647 (vcvtq_x_f16_s16): Likewise.
2648 (vcvtq_x_f32_s32): Likewise.
2649 (vcvtq_x_f32_u32): Likewise.
2650 (vcvtq_x_n_f16_s16): Likewise.
2651 (vcvtq_x_n_f16_u16): Likewise.
2652 (vcvtq_x_n_f32_s32): Likewise.
2653 (vcvtq_x_n_f32_u32): Likewise.
2654 (vcvtq_x_s16_f16): Likewise.
2655 (vcvtq_x_s32_f32): Likewise.
2656 (vcvtq_x_u16_f16): Likewise.
2657 (vcvtq_x_u32_f32): Likewise.
2658 (vcvtq_x_n_s16_f16): Likewise.
2659 (vcvtq_x_n_s32_f32): Likewise.
2660 (vcvtq_x_n_u16_f16): Likewise.
2661 (vcvtq_x_n_u32_f32): Likewise.
2662 (vrndq_x_f16): Likewise.
2663 (vrndq_x_f32): Likewise.
2664 (vrndnq_x_f16): Likewise.
2665 (vrndnq_x_f32): Likewise.
2666 (vrndmq_x_f16): Likewise.
2667 (vrndmq_x_f32): Likewise.
2668 (vrndpq_x_f16): Likewise.
2669 (vrndpq_x_f32): Likewise.
2670 (vrndaq_x_f16): Likewise.
2671 (vrndaq_x_f32): Likewise.
2672 (vrndxq_x_f16): Likewise.
2673 (vrndxq_x_f32): Likewise.
2674 (vandq_x_f16): Likewise.
2675 (vandq_x_f32): Likewise.
2676 (vbicq_x_f16): Likewise.
2677 (vbicq_x_f32): Likewise.
2678 (vbrsrq_x_n_f16): Likewise.
2679 (vbrsrq_x_n_f32): Likewise.
2680 (veorq_x_f16): Likewise.
2681 (veorq_x_f32): Likewise.
2682 (vornq_x_f16): Likewise.
2683 (vornq_x_f32): Likewise.
2684 (vorrq_x_f16): Likewise.
2685 (vorrq_x_f32): Likewise.
2686 (vrev32q_x_f16): Likewise.
2687 (vrev64q_x_f16): Likewise.
2688 (vrev64q_x_f32): Likewise.
2689 (__arm_vddupq_x_n_u8): Define intrinsic.
2690 (__arm_vddupq_x_n_u16): Likewise.
2691 (__arm_vddupq_x_n_u32): Likewise.
2692 (__arm_vddupq_x_wb_u8): Likewise.
2693 (__arm_vddupq_x_wb_u16): Likewise.
2694 (__arm_vddupq_x_wb_u32): Likewise.
2695 (__arm_vdwdupq_x_n_u8): Likewise.
2696 (__arm_vdwdupq_x_n_u16): Likewise.
2697 (__arm_vdwdupq_x_n_u32): Likewise.
2698 (__arm_vdwdupq_x_wb_u8): Likewise.
2699 (__arm_vdwdupq_x_wb_u16): Likewise.
2700 (__arm_vdwdupq_x_wb_u32): Likewise.
2701 (__arm_vidupq_x_n_u8): Likewise.
2702 (__arm_vidupq_x_n_u16): Likewise.
2703 (__arm_vidupq_x_n_u32): Likewise.
2704 (__arm_vidupq_x_wb_u8): Likewise.
2705 (__arm_vidupq_x_wb_u16): Likewise.
2706 (__arm_vidupq_x_wb_u32): Likewise.
2707 (__arm_viwdupq_x_n_u8): Likewise.
2708 (__arm_viwdupq_x_n_u16): Likewise.
2709 (__arm_viwdupq_x_n_u32): Likewise.
2710 (__arm_viwdupq_x_wb_u8): Likewise.
2711 (__arm_viwdupq_x_wb_u16): Likewise.
2712 (__arm_viwdupq_x_wb_u32): Likewise.
2713 (__arm_vdupq_x_n_s8): Likewise.
2714 (__arm_vdupq_x_n_s16): Likewise.
2715 (__arm_vdupq_x_n_s32): Likewise.
2716 (__arm_vdupq_x_n_u8): Likewise.
2717 (__arm_vdupq_x_n_u16): Likewise.
2718 (__arm_vdupq_x_n_u32): Likewise.
2719 (__arm_vminq_x_s8): Likewise.
2720 (__arm_vminq_x_s16): Likewise.
2721 (__arm_vminq_x_s32): Likewise.
2722 (__arm_vminq_x_u8): Likewise.
2723 (__arm_vminq_x_u16): Likewise.
2724 (__arm_vminq_x_u32): Likewise.
2725 (__arm_vmaxq_x_s8): Likewise.
2726 (__arm_vmaxq_x_s16): Likewise.
2727 (__arm_vmaxq_x_s32): Likewise.
2728 (__arm_vmaxq_x_u8): Likewise.
2729 (__arm_vmaxq_x_u16): Likewise.
2730 (__arm_vmaxq_x_u32): Likewise.
2731 (__arm_vabdq_x_s8): Likewise.
2732 (__arm_vabdq_x_s16): Likewise.
2733 (__arm_vabdq_x_s32): Likewise.
2734 (__arm_vabdq_x_u8): Likewise.
2735 (__arm_vabdq_x_u16): Likewise.
2736 (__arm_vabdq_x_u32): Likewise.
2737 (__arm_vabsq_x_s8): Likewise.
2738 (__arm_vabsq_x_s16): Likewise.
2739 (__arm_vabsq_x_s32): Likewise.
2740 (__arm_vaddq_x_s8): Likewise.
2741 (__arm_vaddq_x_s16): Likewise.
2742 (__arm_vaddq_x_s32): Likewise.
2743 (__arm_vaddq_x_n_s8): Likewise.
2744 (__arm_vaddq_x_n_s16): Likewise.
2745 (__arm_vaddq_x_n_s32): Likewise.
2746 (__arm_vaddq_x_u8): Likewise.
2747 (__arm_vaddq_x_u16): Likewise.
2748 (__arm_vaddq_x_u32): Likewise.
2749 (__arm_vaddq_x_n_u8): Likewise.
2750 (__arm_vaddq_x_n_u16): Likewise.
2751 (__arm_vaddq_x_n_u32): Likewise.
2752 (__arm_vclsq_x_s8): Likewise.
2753 (__arm_vclsq_x_s16): Likewise.
2754 (__arm_vclsq_x_s32): Likewise.
2755 (__arm_vclzq_x_s8): Likewise.
2756 (__arm_vclzq_x_s16): Likewise.
2757 (__arm_vclzq_x_s32): Likewise.
2758 (__arm_vclzq_x_u8): Likewise.
2759 (__arm_vclzq_x_u16): Likewise.
2760 (__arm_vclzq_x_u32): Likewise.
2761 (__arm_vnegq_x_s8): Likewise.
2762 (__arm_vnegq_x_s16): Likewise.
2763 (__arm_vnegq_x_s32): Likewise.
2764 (__arm_vmulhq_x_s8): Likewise.
2765 (__arm_vmulhq_x_s16): Likewise.
2766 (__arm_vmulhq_x_s32): Likewise.
2767 (__arm_vmulhq_x_u8): Likewise.
2768 (__arm_vmulhq_x_u16): Likewise.
2769 (__arm_vmulhq_x_u32): Likewise.
2770 (__arm_vmullbq_poly_x_p8): Likewise.
2771 (__arm_vmullbq_poly_x_p16): Likewise.
2772 (__arm_vmullbq_int_x_s8): Likewise.
2773 (__arm_vmullbq_int_x_s16): Likewise.
2774 (__arm_vmullbq_int_x_s32): Likewise.
2775 (__arm_vmullbq_int_x_u8): Likewise.
2776 (__arm_vmullbq_int_x_u16): Likewise.
2777 (__arm_vmullbq_int_x_u32): Likewise.
2778 (__arm_vmulltq_poly_x_p8): Likewise.
2779 (__arm_vmulltq_poly_x_p16): Likewise.
2780 (__arm_vmulltq_int_x_s8): Likewise.
2781 (__arm_vmulltq_int_x_s16): Likewise.
2782 (__arm_vmulltq_int_x_s32): Likewise.
2783 (__arm_vmulltq_int_x_u8): Likewise.
2784 (__arm_vmulltq_int_x_u16): Likewise.
2785 (__arm_vmulltq_int_x_u32): Likewise.
2786 (__arm_vmulq_x_s8): Likewise.
2787 (__arm_vmulq_x_s16): Likewise.
2788 (__arm_vmulq_x_s32): Likewise.
2789 (__arm_vmulq_x_n_s8): Likewise.
2790 (__arm_vmulq_x_n_s16): Likewise.
2791 (__arm_vmulq_x_n_s32): Likewise.
2792 (__arm_vmulq_x_u8): Likewise.
2793 (__arm_vmulq_x_u16): Likewise.
2794 (__arm_vmulq_x_u32): Likewise.
2795 (__arm_vmulq_x_n_u8): Likewise.
2796 (__arm_vmulq_x_n_u16): Likewise.
2797 (__arm_vmulq_x_n_u32): Likewise.
2798 (__arm_vsubq_x_s8): Likewise.
2799 (__arm_vsubq_x_s16): Likewise.
2800 (__arm_vsubq_x_s32): Likewise.
2801 (__arm_vsubq_x_n_s8): Likewise.
2802 (__arm_vsubq_x_n_s16): Likewise.
2803 (__arm_vsubq_x_n_s32): Likewise.
2804 (__arm_vsubq_x_u8): Likewise.
2805 (__arm_vsubq_x_u16): Likewise.
2806 (__arm_vsubq_x_u32): Likewise.
2807 (__arm_vsubq_x_n_u8): Likewise.
2808 (__arm_vsubq_x_n_u16): Likewise.
2809 (__arm_vsubq_x_n_u32): Likewise.
2810 (__arm_vcaddq_rot90_x_s8): Likewise.
2811 (__arm_vcaddq_rot90_x_s16): Likewise.
2812 (__arm_vcaddq_rot90_x_s32): Likewise.
2813 (__arm_vcaddq_rot90_x_u8): Likewise.
2814 (__arm_vcaddq_rot90_x_u16): Likewise.
2815 (__arm_vcaddq_rot90_x_u32): Likewise.
2816 (__arm_vcaddq_rot270_x_s8): Likewise.
2817 (__arm_vcaddq_rot270_x_s16): Likewise.
2818 (__arm_vcaddq_rot270_x_s32): Likewise.
2819 (__arm_vcaddq_rot270_x_u8): Likewise.
2820 (__arm_vcaddq_rot270_x_u16): Likewise.
2821 (__arm_vcaddq_rot270_x_u32): Likewise.
2822 (__arm_vhaddq_x_n_s8): Likewise.
2823 (__arm_vhaddq_x_n_s16): Likewise.
2824 (__arm_vhaddq_x_n_s32): Likewise.
2825 (__arm_vhaddq_x_n_u8): Likewise.
2826 (__arm_vhaddq_x_n_u16): Likewise.
2827 (__arm_vhaddq_x_n_u32): Likewise.
2828 (__arm_vhaddq_x_s8): Likewise.
2829 (__arm_vhaddq_x_s16): Likewise.
2830 (__arm_vhaddq_x_s32): Likewise.
2831 (__arm_vhaddq_x_u8): Likewise.
2832 (__arm_vhaddq_x_u16): Likewise.
2833 (__arm_vhaddq_x_u32): Likewise.
2834 (__arm_vhcaddq_rot90_x_s8): Likewise.
2835 (__arm_vhcaddq_rot90_x_s16): Likewise.
2836 (__arm_vhcaddq_rot90_x_s32): Likewise.
2837 (__arm_vhcaddq_rot270_x_s8): Likewise.
2838 (__arm_vhcaddq_rot270_x_s16): Likewise.
2839 (__arm_vhcaddq_rot270_x_s32): Likewise.
2840 (__arm_vhsubq_x_n_s8): Likewise.
2841 (__arm_vhsubq_x_n_s16): Likewise.
2842 (__arm_vhsubq_x_n_s32): Likewise.
2843 (__arm_vhsubq_x_n_u8): Likewise.
2844 (__arm_vhsubq_x_n_u16): Likewise.
2845 (__arm_vhsubq_x_n_u32): Likewise.
2846 (__arm_vhsubq_x_s8): Likewise.
2847 (__arm_vhsubq_x_s16): Likewise.
2848 (__arm_vhsubq_x_s32): Likewise.
2849 (__arm_vhsubq_x_u8): Likewise.
2850 (__arm_vhsubq_x_u16): Likewise.
2851 (__arm_vhsubq_x_u32): Likewise.
2852 (__arm_vrhaddq_x_s8): Likewise.
2853 (__arm_vrhaddq_x_s16): Likewise.
2854 (__arm_vrhaddq_x_s32): Likewise.
2855 (__arm_vrhaddq_x_u8): Likewise.
2856 (__arm_vrhaddq_x_u16): Likewise.
2857 (__arm_vrhaddq_x_u32): Likewise.
2858 (__arm_vrmulhq_x_s8): Likewise.
2859 (__arm_vrmulhq_x_s16): Likewise.
2860 (__arm_vrmulhq_x_s32): Likewise.
2861 (__arm_vrmulhq_x_u8): Likewise.
2862 (__arm_vrmulhq_x_u16): Likewise.
2863 (__arm_vrmulhq_x_u32): Likewise.
2864 (__arm_vandq_x_s8): Likewise.
2865 (__arm_vandq_x_s16): Likewise.
2866 (__arm_vandq_x_s32): Likewise.
2867 (__arm_vandq_x_u8): Likewise.
2868 (__arm_vandq_x_u16): Likewise.
2869 (__arm_vandq_x_u32): Likewise.
2870 (__arm_vbicq_x_s8): Likewise.
2871 (__arm_vbicq_x_s16): Likewise.
2872 (__arm_vbicq_x_s32): Likewise.
2873 (__arm_vbicq_x_u8): Likewise.
2874 (__arm_vbicq_x_u16): Likewise.
2875 (__arm_vbicq_x_u32): Likewise.
2876 (__arm_vbrsrq_x_n_s8): Likewise.
2877 (__arm_vbrsrq_x_n_s16): Likewise.
2878 (__arm_vbrsrq_x_n_s32): Likewise.
2879 (__arm_vbrsrq_x_n_u8): Likewise.
2880 (__arm_vbrsrq_x_n_u16): Likewise.
2881 (__arm_vbrsrq_x_n_u32): Likewise.
2882 (__arm_veorq_x_s8): Likewise.
2883 (__arm_veorq_x_s16): Likewise.
2884 (__arm_veorq_x_s32): Likewise.
2885 (__arm_veorq_x_u8): Likewise.
2886 (__arm_veorq_x_u16): Likewise.
2887 (__arm_veorq_x_u32): Likewise.
2888 (__arm_vmovlbq_x_s8): Likewise.
2889 (__arm_vmovlbq_x_s16): Likewise.
2890 (__arm_vmovlbq_x_u8): Likewise.
2891 (__arm_vmovlbq_x_u16): Likewise.
2892 (__arm_vmovltq_x_s8): Likewise.
2893 (__arm_vmovltq_x_s16): Likewise.
2894 (__arm_vmovltq_x_u8): Likewise.
2895 (__arm_vmovltq_x_u16): Likewise.
2896 (__arm_vmvnq_x_s8): Likewise.
2897 (__arm_vmvnq_x_s16): Likewise.
2898 (__arm_vmvnq_x_s32): Likewise.
2899 (__arm_vmvnq_x_u8): Likewise.
2900 (__arm_vmvnq_x_u16): Likewise.
2901 (__arm_vmvnq_x_u32): Likewise.
2902 (__arm_vmvnq_x_n_s16): Likewise.
2903 (__arm_vmvnq_x_n_s32): Likewise.
2904 (__arm_vmvnq_x_n_u16): Likewise.
2905 (__arm_vmvnq_x_n_u32): Likewise.
2906 (__arm_vornq_x_s8): Likewise.
2907 (__arm_vornq_x_s16): Likewise.
2908 (__arm_vornq_x_s32): Likewise.
2909 (__arm_vornq_x_u8): Likewise.
2910 (__arm_vornq_x_u16): Likewise.
2911 (__arm_vornq_x_u32): Likewise.
2912 (__arm_vorrq_x_s8): Likewise.
2913 (__arm_vorrq_x_s16): Likewise.
2914 (__arm_vorrq_x_s32): Likewise.
2915 (__arm_vorrq_x_u8): Likewise.
2916 (__arm_vorrq_x_u16): Likewise.
2917 (__arm_vorrq_x_u32): Likewise.
2918 (__arm_vrev16q_x_s8): Likewise.
2919 (__arm_vrev16q_x_u8): Likewise.
2920 (__arm_vrev32q_x_s8): Likewise.
2921 (__arm_vrev32q_x_s16): Likewise.
2922 (__arm_vrev32q_x_u8): Likewise.
2923 (__arm_vrev32q_x_u16): Likewise.
2924 (__arm_vrev64q_x_s8): Likewise.
2925 (__arm_vrev64q_x_s16): Likewise.
2926 (__arm_vrev64q_x_s32): Likewise.
2927 (__arm_vrev64q_x_u8): Likewise.
2928 (__arm_vrev64q_x_u16): Likewise.
2929 (__arm_vrev64q_x_u32): Likewise.
2930 (__arm_vrshlq_x_s8): Likewise.
2931 (__arm_vrshlq_x_s16): Likewise.
2932 (__arm_vrshlq_x_s32): Likewise.
2933 (__arm_vrshlq_x_u8): Likewise.
2934 (__arm_vrshlq_x_u16): Likewise.
2935 (__arm_vrshlq_x_u32): Likewise.
2936 (__arm_vshllbq_x_n_s8): Likewise.
2937 (__arm_vshllbq_x_n_s16): Likewise.
2938 (__arm_vshllbq_x_n_u8): Likewise.
2939 (__arm_vshllbq_x_n_u16): Likewise.
2940 (__arm_vshlltq_x_n_s8): Likewise.
2941 (__arm_vshlltq_x_n_s16): Likewise.
2942 (__arm_vshlltq_x_n_u8): Likewise.
2943 (__arm_vshlltq_x_n_u16): Likewise.
2944 (__arm_vshlq_x_s8): Likewise.
2945 (__arm_vshlq_x_s16): Likewise.
2946 (__arm_vshlq_x_s32): Likewise.
2947 (__arm_vshlq_x_u8): Likewise.
2948 (__arm_vshlq_x_u16): Likewise.
2949 (__arm_vshlq_x_u32): Likewise.
2950 (__arm_vshlq_x_n_s8): Likewise.
2951 (__arm_vshlq_x_n_s16): Likewise.
2952 (__arm_vshlq_x_n_s32): Likewise.
2953 (__arm_vshlq_x_n_u8): Likewise.
2954 (__arm_vshlq_x_n_u16): Likewise.
2955 (__arm_vshlq_x_n_u32): Likewise.
2956 (__arm_vrshrq_x_n_s8): Likewise.
2957 (__arm_vrshrq_x_n_s16): Likewise.
2958 (__arm_vrshrq_x_n_s32): Likewise.
2959 (__arm_vrshrq_x_n_u8): Likewise.
2960 (__arm_vrshrq_x_n_u16): Likewise.
2961 (__arm_vrshrq_x_n_u32): Likewise.
2962 (__arm_vshrq_x_n_s8): Likewise.
2963 (__arm_vshrq_x_n_s16): Likewise.
2964 (__arm_vshrq_x_n_s32): Likewise.
2965 (__arm_vshrq_x_n_u8): Likewise.
2966 (__arm_vshrq_x_n_u16): Likewise.
2967 (__arm_vshrq_x_n_u32): Likewise.
2968 (__arm_vdupq_x_n_f16): Likewise.
2969 (__arm_vdupq_x_n_f32): Likewise.
2970 (__arm_vminnmq_x_f16): Likewise.
2971 (__arm_vminnmq_x_f32): Likewise.
2972 (__arm_vmaxnmq_x_f16): Likewise.
2973 (__arm_vmaxnmq_x_f32): Likewise.
2974 (__arm_vabdq_x_f16): Likewise.
2975 (__arm_vabdq_x_f32): Likewise.
2976 (__arm_vabsq_x_f16): Likewise.
2977 (__arm_vabsq_x_f32): Likewise.
2978 (__arm_vaddq_x_f16): Likewise.
2979 (__arm_vaddq_x_f32): Likewise.
2980 (__arm_vaddq_x_n_f16): Likewise.
2981 (__arm_vaddq_x_n_f32): Likewise.
2982 (__arm_vnegq_x_f16): Likewise.
2983 (__arm_vnegq_x_f32): Likewise.
2984 (__arm_vmulq_x_f16): Likewise.
2985 (__arm_vmulq_x_f32): Likewise.
2986 (__arm_vmulq_x_n_f16): Likewise.
2987 (__arm_vmulq_x_n_f32): Likewise.
2988 (__arm_vsubq_x_f16): Likewise.
2989 (__arm_vsubq_x_f32): Likewise.
2990 (__arm_vsubq_x_n_f16): Likewise.
2991 (__arm_vsubq_x_n_f32): Likewise.
2992 (__arm_vcaddq_rot90_x_f16): Likewise.
2993 (__arm_vcaddq_rot90_x_f32): Likewise.
2994 (__arm_vcaddq_rot270_x_f16): Likewise.
2995 (__arm_vcaddq_rot270_x_f32): Likewise.
2996 (__arm_vcmulq_x_f16): Likewise.
2997 (__arm_vcmulq_x_f32): Likewise.
2998 (__arm_vcmulq_rot90_x_f16): Likewise.
2999 (__arm_vcmulq_rot90_x_f32): Likewise.
3000 (__arm_vcmulq_rot180_x_f16): Likewise.
3001 (__arm_vcmulq_rot180_x_f32): Likewise.
3002 (__arm_vcmulq_rot270_x_f16): Likewise.
3003 (__arm_vcmulq_rot270_x_f32): Likewise.
3004 (__arm_vcvtaq_x_s16_f16): Likewise.
3005 (__arm_vcvtaq_x_s32_f32): Likewise.
3006 (__arm_vcvtaq_x_u16_f16): Likewise.
3007 (__arm_vcvtaq_x_u32_f32): Likewise.
3008 (__arm_vcvtnq_x_s16_f16): Likewise.
3009 (__arm_vcvtnq_x_s32_f32): Likewise.
3010 (__arm_vcvtnq_x_u16_f16): Likewise.
3011 (__arm_vcvtnq_x_u32_f32): Likewise.
3012 (__arm_vcvtpq_x_s16_f16): Likewise.
3013 (__arm_vcvtpq_x_s32_f32): Likewise.
3014 (__arm_vcvtpq_x_u16_f16): Likewise.
3015 (__arm_vcvtpq_x_u32_f32): Likewise.
3016 (__arm_vcvtmq_x_s16_f16): Likewise.
3017 (__arm_vcvtmq_x_s32_f32): Likewise.
3018 (__arm_vcvtmq_x_u16_f16): Likewise.
3019 (__arm_vcvtmq_x_u32_f32): Likewise.
3020 (__arm_vcvtbq_x_f32_f16): Likewise.
3021 (__arm_vcvttq_x_f32_f16): Likewise.
3022 (__arm_vcvtq_x_f16_u16): Likewise.
3023 (__arm_vcvtq_x_f16_s16): Likewise.
3024 (__arm_vcvtq_x_f32_s32): Likewise.
3025 (__arm_vcvtq_x_f32_u32): Likewise.
3026 (__arm_vcvtq_x_n_f16_s16): Likewise.
3027 (__arm_vcvtq_x_n_f16_u16): Likewise.
3028 (__arm_vcvtq_x_n_f32_s32): Likewise.
3029 (__arm_vcvtq_x_n_f32_u32): Likewise.
3030 (__arm_vcvtq_x_s16_f16): Likewise.
3031 (__arm_vcvtq_x_s32_f32): Likewise.
3032 (__arm_vcvtq_x_u16_f16): Likewise.
3033 (__arm_vcvtq_x_u32_f32): Likewise.
3034 (__arm_vcvtq_x_n_s16_f16): Likewise.
3035 (__arm_vcvtq_x_n_s32_f32): Likewise.
3036 (__arm_vcvtq_x_n_u16_f16): Likewise.
3037 (__arm_vcvtq_x_n_u32_f32): Likewise.
3038 (__arm_vrndq_x_f16): Likewise.
3039 (__arm_vrndq_x_f32): Likewise.
3040 (__arm_vrndnq_x_f16): Likewise.
3041 (__arm_vrndnq_x_f32): Likewise.
3042 (__arm_vrndmq_x_f16): Likewise.
3043 (__arm_vrndmq_x_f32): Likewise.
3044 (__arm_vrndpq_x_f16): Likewise.
3045 (__arm_vrndpq_x_f32): Likewise.
3046 (__arm_vrndaq_x_f16): Likewise.
3047 (__arm_vrndaq_x_f32): Likewise.
3048 (__arm_vrndxq_x_f16): Likewise.
3049 (__arm_vrndxq_x_f32): Likewise.
3050 (__arm_vandq_x_f16): Likewise.
3051 (__arm_vandq_x_f32): Likewise.
3052 (__arm_vbicq_x_f16): Likewise.
3053 (__arm_vbicq_x_f32): Likewise.
3054 (__arm_vbrsrq_x_n_f16): Likewise.
3055 (__arm_vbrsrq_x_n_f32): Likewise.
3056 (__arm_veorq_x_f16): Likewise.
3057 (__arm_veorq_x_f32): Likewise.
3058 (__arm_vornq_x_f16): Likewise.
3059 (__arm_vornq_x_f32): Likewise.
3060 (__arm_vorrq_x_f16): Likewise.
3061 (__arm_vorrq_x_f32): Likewise.
3062 (__arm_vrev32q_x_f16): Likewise.
3063 (__arm_vrev64q_x_f16): Likewise.
3064 (__arm_vrev64q_x_f32): Likewise.
3065 (vabdq_x): Define polymorphic variant.
3066 (vabsq_x): Likewise.
3067 (vaddq_x): Likewise.
3068 (vandq_x): Likewise.
3069 (vbicq_x): Likewise.
3070 (vbrsrq_x): Likewise.
3071 (vcaddq_rot270_x): Likewise.
3072 (vcaddq_rot90_x): Likewise.
3073 (vcmulq_rot180_x): Likewise.
3074 (vcmulq_rot270_x): Likewise.
3075 (vcmulq_x): Likewise.
3076 (vcvtq_x): Likewise.
3077 (vcvtq_x_n): Likewise.
3078 (vcvtnq_m): Likewise.
3079 (veorq_x): Likewise.
3080 (vmaxnmq_x): Likewise.
3081 (vminnmq_x): Likewise.
3082 (vmulq_x): Likewise.
3083 (vnegq_x): Likewise.
3084 (vornq_x): Likewise.
3085 (vorrq_x): Likewise.
3086 (vrev32q_x): Likewise.
3087 (vrev64q_x): Likewise.
3088 (vrndaq_x): Likewise.
3089 (vrndmq_x): Likewise.
3090 (vrndnq_x): Likewise.
3091 (vrndpq_x): Likewise.
3092 (vrndq_x): Likewise.
3093 (vrndxq_x): Likewise.
3094 (vsubq_x): Likewise.
3095 (vcmulq_rot90_x): Likewise.
3096 (vadciq): Likewise.
3097 (vclsq_x): Likewise.
3098 (vclzq_x): Likewise.
3099 (vhaddq_x): Likewise.
3100 (vhcaddq_rot270_x): Likewise.
3101 (vhcaddq_rot90_x): Likewise.
3102 (vhsubq_x): Likewise.
3103 (vmaxq_x): Likewise.
3104 (vminq_x): Likewise.
3105 (vmovlbq_x): Likewise.
3106 (vmovltq_x): Likewise.
3107 (vmulhq_x): Likewise.
3108 (vmullbq_int_x): Likewise.
3109 (vmullbq_poly_x): Likewise.
3110 (vmulltq_int_x): Likewise.
3111 (vmulltq_poly_x): Likewise.
3112 (vmvnq_x): Likewise.
3113 (vrev16q_x): Likewise.
3114 (vrhaddq_x): Likewise.
3115 (vrmulhq_x): Likewise.
3116 (vrshlq_x): Likewise.
3117 (vrshrq_x): Likewise.
3118 (vshllbq_x): Likewise.
3119 (vshlltq_x): Likewise.
3120 (vshlq_x_n): Likewise.
3121 (vshlq_x): Likewise.
3122 (vdwdupq_x_u8): Likewise.
3123 (vdwdupq_x_u16): Likewise.
3124 (vdwdupq_x_u32): Likewise.
3125 (viwdupq_x_u8): Likewise.
3126 (viwdupq_x_u16): Likewise.
3127 (viwdupq_x_u32): Likewise.
3128 (vidupq_x_u8): Likewise.
3129 (vddupq_x_u8): Likewise.
3130 (vidupq_x_u16): Likewise.
3131 (vddupq_x_u16): Likewise.
3132 (vidupq_x_u32): Likewise.
3133 (vddupq_x_u32): Likewise.
3134 (vshrq_x): Likewise.
3135
3136 2020-03-20 Richard Biener <rguenther@suse.de>
3137
3138 * tree-vect-slp.c (vect_analyze_slp_instance): Push the stmts
3139 to vectorize for CTOR defs.
3140
3141 2020-03-20 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
3142 Andre Vieira <andre.simoesdiasvieira@arm.com>
3143 Mihail Ionescu <mihail.ionescu@arm.com>
3144
3145 * config/arm/arm-builtins.c (LDRGBWBS_QUALIFIERS): Define builtin
3146 qualifier.
3147 (LDRGBWBU_QUALIFIERS): Likewise.
3148 (LDRGBWBS_Z_QUALIFIERS): Likewise.
3149 (LDRGBWBU_Z_QUALIFIERS): Likewise.
3150 (STRSBWBS_QUALIFIERS): Likewise.
3151 (STRSBWBU_QUALIFIERS): Likewise.
3152 (STRSBWBS_P_QUALIFIERS): Likewise.
3153 (STRSBWBU_P_QUALIFIERS): Likewise.
3154 * config/arm/arm_mve.h (vldrdq_gather_base_wb_s64): Define macro.
3155 (vldrdq_gather_base_wb_u64): Likewise.
3156 (vldrdq_gather_base_wb_z_s64): Likewise.
3157 (vldrdq_gather_base_wb_z_u64): Likewise.
3158 (vldrwq_gather_base_wb_f32): Likewise.
3159 (vldrwq_gather_base_wb_s32): Likewise.
3160 (vldrwq_gather_base_wb_u32): Likewise.
3161 (vldrwq_gather_base_wb_z_f32): Likewise.
3162 (vldrwq_gather_base_wb_z_s32): Likewise.
3163 (vldrwq_gather_base_wb_z_u32): Likewise.
3164 (vstrdq_scatter_base_wb_p_s64): Likewise.
3165 (vstrdq_scatter_base_wb_p_u64): Likewise.
3166 (vstrdq_scatter_base_wb_s64): Likewise.
3167 (vstrdq_scatter_base_wb_u64): Likewise.
3168 (vstrwq_scatter_base_wb_p_s32): Likewise.
3169 (vstrwq_scatter_base_wb_p_f32): Likewise.
3170 (vstrwq_scatter_base_wb_p_u32): Likewise.
3171 (vstrwq_scatter_base_wb_s32): Likewise.
3172 (vstrwq_scatter_base_wb_u32): Likewise.
3173 (vstrwq_scatter_base_wb_f32): Likewise.
3174 (__arm_vldrdq_gather_base_wb_s64): Define intrinsic.
3175 (__arm_vldrdq_gather_base_wb_u64): Likewise.
3176 (__arm_vldrdq_gather_base_wb_z_s64): Likewise.
3177 (__arm_vldrdq_gather_base_wb_z_u64): Likewise.
3178 (__arm_vldrwq_gather_base_wb_s32): Likewise.
3179 (__arm_vldrwq_gather_base_wb_u32): Likewise.
3180 (__arm_vldrwq_gather_base_wb_z_s32): Likewise.
3181 (__arm_vldrwq_gather_base_wb_z_u32): Likewise.
3182 (__arm_vstrdq_scatter_base_wb_s64): Likewise.
3183 (__arm_vstrdq_scatter_base_wb_u64): Likewise.
3184 (__arm_vstrdq_scatter_base_wb_p_s64): Likewise.
3185 (__arm_vstrdq_scatter_base_wb_p_u64): Likewise.
3186 (__arm_vstrwq_scatter_base_wb_p_s32): Likewise.
3187 (__arm_vstrwq_scatter_base_wb_p_u32): Likewise.
3188 (__arm_vstrwq_scatter_base_wb_s32): Likewise.
3189 (__arm_vstrwq_scatter_base_wb_u32): Likewise.
3190 (__arm_vldrwq_gather_base_wb_f32): Likewise.
3191 (__arm_vldrwq_gather_base_wb_z_f32): Likewise.
3192 (__arm_vstrwq_scatter_base_wb_f32): Likewise.
3193 (__arm_vstrwq_scatter_base_wb_p_f32): Likewise.
3194 (vstrwq_scatter_base_wb): Define polymorphic variant.
3195 (vstrwq_scatter_base_wb_p): Likewise.
3196 (vstrdq_scatter_base_wb_p): Likewise.
3197 (vstrdq_scatter_base_wb): Likewise.
3198 * config/arm/arm_mve_builtins.def (LDRGBWBS_QUALIFIERS): Use builtin
3199 qualifier.
3200 * config/arm/mve.md (mve_vstrwq_scatter_base_wb_<supf>v4si): Define RTL
3201 pattern.
3202 (mve_vstrwq_scatter_base_wb_add_<supf>v4si): Likewise.
3203 (mve_vstrwq_scatter_base_wb_<supf>v4si_insn): Likewise.
3204 (mve_vstrwq_scatter_base_wb_p_<supf>v4si): Likewise.
3205 (mve_vstrwq_scatter_base_wb_p_add_<supf>v4si): Likewise.
3206 (mve_vstrwq_scatter_base_wb_p_<supf>v4si_insn): Likewise.
3207 (mve_vstrwq_scatter_base_wb_fv4sf): Likewise.
3208 (mve_vstrwq_scatter_base_wb_add_fv4sf): Likewise.
3209 (mve_vstrwq_scatter_base_wb_fv4sf_insn): Likewise.
3210 (mve_vstrwq_scatter_base_wb_p_fv4sf): Likewise.
3211 (mve_vstrwq_scatter_base_wb_p_add_fv4sf): Likewise.
3212 (mve_vstrwq_scatter_base_wb_p_fv4sf_insn): Likewise.
3213 (mve_vstrdq_scatter_base_wb_<supf>v2di): Likewise.
3214 (mve_vstrdq_scatter_base_wb_add_<supf>v2di): Likewise.
3215 (mve_vstrdq_scatter_base_wb_<supf>v2di_insn): Likewise.
3216 (mve_vstrdq_scatter_base_wb_p_<supf>v2di): Likewise.
3217 (mve_vstrdq_scatter_base_wb_p_add_<supf>v2di): Likewise.
3218 (mve_vstrdq_scatter_base_wb_p_<supf>v2di_insn): Likewise.
3219 (mve_vldrwq_gather_base_wb_<supf>v4si): Likewise.
3220 (mve_vldrwq_gather_base_wb_<supf>v4si_insn): Likewise.
3221 (mve_vldrwq_gather_base_wb_z_<supf>v4si): Likewise.
3222 (mve_vldrwq_gather_base_wb_z_<supf>v4si_insn): Likewise.
3223 (mve_vldrwq_gather_base_wb_fv4sf): Likewise.
3224 (mve_vldrwq_gather_base_wb_fv4sf_insn): Likewise.
3225 (mve_vldrwq_gather_base_wb_z_fv4sf): Likewise.
3226 (mve_vldrwq_gather_base_wb_z_fv4sf_insn): Likewise.
3227 (mve_vldrdq_gather_base_wb_<supf>v2di): Likewise.
3228 (mve_vldrdq_gather_base_wb_<supf>v2di_insn): Likewise.
3229 (mve_vldrdq_gather_base_wb_z_<supf>v2di): Likewise.
3230 (mve_vldrdq_gather_base_wb_z_<supf>v2di_insn): Likewise.
3231
3232 2020-03-20 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
3233 Andre Vieira <andre.simoesdiasvieira@arm.com>
3234 Mihail Ionescu <mihail.ionescu@arm.com>
3235
3236 * config/arm/arm-builtins.c
3237 (QUINOP_UNONE_UNONE_UNONE_UNONE_IMM_UNONE_QUALIFIERS): Define quinary
3238 builtin qualifier.
3239 * config/arm/arm_mve.h (vddupq_m_n_u8): Define macro.
3240 (vddupq_m_n_u32): Likewise.
3241 (vddupq_m_n_u16): Likewise.
3242 (vddupq_m_wb_u8): Likewise.
3243 (vddupq_m_wb_u16): Likewise.
3244 (vddupq_m_wb_u32): Likewise.
3245 (vddupq_n_u8): Likewise.
3246 (vddupq_n_u32): Likewise.
3247 (vddupq_n_u16): Likewise.
3248 (vddupq_wb_u8): Likewise.
3249 (vddupq_wb_u16): Likewise.
3250 (vddupq_wb_u32): Likewise.
3251 (vdwdupq_m_n_u8): Likewise.
3252 (vdwdupq_m_n_u32): Likewise.
3253 (vdwdupq_m_n_u16): Likewise.
3254 (vdwdupq_m_wb_u8): Likewise.
3255 (vdwdupq_m_wb_u32): Likewise.
3256 (vdwdupq_m_wb_u16): Likewise.
3257 (vdwdupq_n_u8): Likewise.
3258 (vdwdupq_n_u32): Likewise.
3259 (vdwdupq_n_u16): Likewise.
3260 (vdwdupq_wb_u8): Likewise.
3261 (vdwdupq_wb_u32): Likewise.
3262 (vdwdupq_wb_u16): Likewise.
3263 (vidupq_m_n_u8): Likewise.
3264 (vidupq_m_n_u32): Likewise.
3265 (vidupq_m_n_u16): Likewise.
3266 (vidupq_m_wb_u8): Likewise.
3267 (vidupq_m_wb_u16): Likewise.
3268 (vidupq_m_wb_u32): Likewise.
3269 (vidupq_n_u8): Likewise.
3270 (vidupq_n_u32): Likewise.
3271 (vidupq_n_u16): Likewise.
3272 (vidupq_wb_u8): Likewise.
3273 (vidupq_wb_u16): Likewise.
3274 (vidupq_wb_u32): Likewise.
3275 (viwdupq_m_n_u8): Likewise.
3276 (viwdupq_m_n_u32): Likewise.
3277 (viwdupq_m_n_u16): Likewise.
3278 (viwdupq_m_wb_u8): Likewise.
3279 (viwdupq_m_wb_u32): Likewise.
3280 (viwdupq_m_wb_u16): Likewise.
3281 (viwdupq_n_u8): Likewise.
3282 (viwdupq_n_u32): Likewise.
3283 (viwdupq_n_u16): Likewise.
3284 (viwdupq_wb_u8): Likewise.
3285 (viwdupq_wb_u32): Likewise.
3286 (viwdupq_wb_u16): Likewise.
3287 (__arm_vddupq_m_n_u8): Define intrinsic.
3288 (__arm_vddupq_m_n_u32): Likewise.
3289 (__arm_vddupq_m_n_u16): Likewise.
3290 (__arm_vddupq_m_wb_u8): Likewise.
3291 (__arm_vddupq_m_wb_u16): Likewise.
3292 (__arm_vddupq_m_wb_u32): Likewise.
3293 (__arm_vddupq_n_u8): Likewise.
3294 (__arm_vddupq_n_u32): Likewise.
3295 (__arm_vddupq_n_u16): Likewise.
3296 (__arm_vdwdupq_m_n_u8): Likewise.
3297 (__arm_vdwdupq_m_n_u32): Likewise.
3298 (__arm_vdwdupq_m_n_u16): Likewise.
3299 (__arm_vdwdupq_m_wb_u8): Likewise.
3300 (__arm_vdwdupq_m_wb_u32): Likewise.
3301 (__arm_vdwdupq_m_wb_u16): Likewise.
3302 (__arm_vdwdupq_n_u8): Likewise.
3303 (__arm_vdwdupq_n_u32): Likewise.
3304 (__arm_vdwdupq_n_u16): Likewise.
3305 (__arm_vdwdupq_wb_u8): Likewise.
3306 (__arm_vdwdupq_wb_u32): Likewise.
3307 (__arm_vdwdupq_wb_u16): Likewise.
3308 (__arm_vidupq_m_n_u8): Likewise.
3309 (__arm_vidupq_m_n_u32): Likewise.
3310 (__arm_vidupq_m_n_u16): Likewise.
3311 (__arm_vidupq_n_u8): Likewise.
3312 (__arm_vidupq_m_wb_u8): Likewise.
3313 (__arm_vidupq_m_wb_u16): Likewise.
3314 (__arm_vidupq_m_wb_u32): Likewise.
3315 (__arm_vidupq_n_u32): Likewise.
3316 (__arm_vidupq_n_u16): Likewise.
3317 (__arm_vidupq_wb_u8): Likewise.
3318 (__arm_vidupq_wb_u16): Likewise.
3319 (__arm_vidupq_wb_u32): Likewise.
3320 (__arm_vddupq_wb_u8): Likewise.
3321 (__arm_vddupq_wb_u16): Likewise.
3322 (__arm_vddupq_wb_u32): Likewise.
3323 (__arm_viwdupq_m_n_u8): Likewise.
3324 (__arm_viwdupq_m_n_u32): Likewise.
3325 (__arm_viwdupq_m_n_u16): Likewise.
3326 (__arm_viwdupq_m_wb_u8): Likewise.
3327 (__arm_viwdupq_m_wb_u32): Likewise.
3328 (__arm_viwdupq_m_wb_u16): Likewise.
3329 (__arm_viwdupq_n_u8): Likewise.
3330 (__arm_viwdupq_n_u32): Likewise.
3331 (__arm_viwdupq_n_u16): Likewise.
3332 (__arm_viwdupq_wb_u8): Likewise.
3333 (__arm_viwdupq_wb_u32): Likewise.
3334 (__arm_viwdupq_wb_u16): Likewise.
3335 (vidupq_m): Define polymorphic variant.
3336 (vddupq_m): Likewise.
3337 (vidupq_u16): Likewise.
3338 (vidupq_u32): Likewise.
3339 (vidupq_u8): Likewise.
3340 (vddupq_u16): Likewise.
3341 (vddupq_u32): Likewise.
3342 (vddupq_u8): Likewise.
3343 (viwdupq_m): Likewise.
3344 (viwdupq_u16): Likewise.
3345 (viwdupq_u32): Likewise.
3346 (viwdupq_u8): Likewise.
3347 (vdwdupq_m): Likewise.
3348 (vdwdupq_u16): Likewise.
3349 (vdwdupq_u32): Likewise.
3350 (vdwdupq_u8): Likewise.
3351 * config/arm/arm_mve_builtins.def
3352 (QUINOP_UNONE_UNONE_UNONE_UNONE_IMM_UNONE_QUALIFIERS): Use builtin
3353 qualifier.
3354 * config/arm/mve.md (mve_vidupq_n_u<mode>): Define RTL pattern.
3355 (mve_vidupq_u<mode>_insn): Likewise.
3356 (mve_vidupq_m_n_u<mode>): Likewise.
3357 (mve_vidupq_m_wb_u<mode>_insn): Likewise.
3358 (mve_vddupq_n_u<mode>): Likewise.
3359 (mve_vddupq_u<mode>_insn): Likewise.
3360 (mve_vddupq_m_n_u<mode>): Likewise.
3361 (mve_vddupq_m_wb_u<mode>_insn): Likewise.
3362 (mve_vdwdupq_n_u<mode>): Likewise.
3363 (mve_vdwdupq_wb_u<mode>): Likewise.
3364 (mve_vdwdupq_wb_u<mode>_insn): Likewise.
3365 (mve_vdwdupq_m_n_u<mode>): Likewise.
3366 (mve_vdwdupq_m_wb_u<mode>): Likewise.
3367 (mve_vdwdupq_m_wb_u<mode>_insn): Likewise.
3368 (mve_viwdupq_n_u<mode>): Likewise.
3369 (mve_viwdupq_wb_u<mode>): Likewise.
3370 (mve_viwdupq_wb_u<mode>_insn): Likewise.
3371 (mve_viwdupq_m_n_u<mode>): Likewise.
3372 (mve_viwdupq_m_wb_u<mode>): Likewise.
3373 (mve_viwdupq_m_wb_u<mode>_insn): Likewise.
3374
3375 2020-03-20 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
3376
3377 * config/arm/arm_mve.h (vreinterpretq_s16_s32): Define macro.
3378 (vreinterpretq_s16_s64): Likewise.
3379 (vreinterpretq_s16_s8): Likewise.
3380 (vreinterpretq_s16_u16): Likewise.
3381 (vreinterpretq_s16_u32): Likewise.
3382 (vreinterpretq_s16_u64): Likewise.
3383 (vreinterpretq_s16_u8): Likewise.
3384 (vreinterpretq_s32_s16): Likewise.
3385 (vreinterpretq_s32_s64): Likewise.
3386 (vreinterpretq_s32_s8): Likewise.
3387 (vreinterpretq_s32_u16): Likewise.
3388 (vreinterpretq_s32_u32): Likewise.
3389 (vreinterpretq_s32_u64): Likewise.
3390 (vreinterpretq_s32_u8): Likewise.
3391 (vreinterpretq_s64_s16): Likewise.
3392 (vreinterpretq_s64_s32): Likewise.
3393 (vreinterpretq_s64_s8): Likewise.
3394 (vreinterpretq_s64_u16): Likewise.
3395 (vreinterpretq_s64_u32): Likewise.
3396 (vreinterpretq_s64_u64): Likewise.
3397 (vreinterpretq_s64_u8): Likewise.
3398 (vreinterpretq_s8_s16): Likewise.
3399 (vreinterpretq_s8_s32): Likewise.
3400 (vreinterpretq_s8_s64): Likewise.
3401 (vreinterpretq_s8_u16): Likewise.
3402 (vreinterpretq_s8_u32): Likewise.
3403 (vreinterpretq_s8_u64): Likewise.
3404 (vreinterpretq_s8_u8): Likewise.
3405 (vreinterpretq_u16_s16): Likewise.
3406 (vreinterpretq_u16_s32): Likewise.
3407 (vreinterpretq_u16_s64): Likewise.
3408 (vreinterpretq_u16_s8): Likewise.
3409 (vreinterpretq_u16_u32): Likewise.
3410 (vreinterpretq_u16_u64): Likewise.
3411 (vreinterpretq_u16_u8): Likewise.
3412 (vreinterpretq_u32_s16): Likewise.
3413 (vreinterpretq_u32_s32): Likewise.
3414 (vreinterpretq_u32_s64): Likewise.
3415 (vreinterpretq_u32_s8): Likewise.
3416 (vreinterpretq_u32_u16): Likewise.
3417 (vreinterpretq_u32_u64): Likewise.
3418 (vreinterpretq_u32_u8): Likewise.
3419 (vreinterpretq_u64_s16): Likewise.
3420 (vreinterpretq_u64_s32): Likewise.
3421 (vreinterpretq_u64_s64): Likewise.
3422 (vreinterpretq_u64_s8): Likewise.
3423 (vreinterpretq_u64_u16): Likewise.
3424 (vreinterpretq_u64_u32): Likewise.
3425 (vreinterpretq_u64_u8): Likewise.
3426 (vreinterpretq_u8_s16): Likewise.
3427 (vreinterpretq_u8_s32): Likewise.
3428 (vreinterpretq_u8_s64): Likewise.
3429 (vreinterpretq_u8_s8): Likewise.
3430 (vreinterpretq_u8_u16): Likewise.
3431 (vreinterpretq_u8_u32): Likewise.
3432 (vreinterpretq_u8_u64): Likewise.
3433 (vreinterpretq_s32_f16): Likewise.
3434 (vreinterpretq_s32_f32): Likewise.
3435 (vreinterpretq_u16_f16): Likewise.
3436 (vreinterpretq_u16_f32): Likewise.
3437 (vreinterpretq_u32_f16): Likewise.
3438 (vreinterpretq_u32_f32): Likewise.
3439 (vreinterpretq_u64_f16): Likewise.
3440 (vreinterpretq_u64_f32): Likewise.
3441 (vreinterpretq_u8_f16): Likewise.
3442 (vreinterpretq_u8_f32): Likewise.
3443 (vreinterpretq_f16_f32): Likewise.
3444 (vreinterpretq_f16_s16): Likewise.
3445 (vreinterpretq_f16_s32): Likewise.
3446 (vreinterpretq_f16_s64): Likewise.
3447 (vreinterpretq_f16_s8): Likewise.
3448 (vreinterpretq_f16_u16): Likewise.
3449 (vreinterpretq_f16_u32): Likewise.
3450 (vreinterpretq_f16_u64): Likewise.
3451 (vreinterpretq_f16_u8): Likewise.
3452 (vreinterpretq_f32_f16): Likewise.
3453 (vreinterpretq_f32_s16): Likewise.
3454 (vreinterpretq_f32_s32): Likewise.
3455 (vreinterpretq_f32_s64): Likewise.
3456 (vreinterpretq_f32_s8): Likewise.
3457 (vreinterpretq_f32_u16): Likewise.
3458 (vreinterpretq_f32_u32): Likewise.
3459 (vreinterpretq_f32_u64): Likewise.
3460 (vreinterpretq_f32_u8): Likewise.
3461 (vreinterpretq_s16_f16): Likewise.
3462 (vreinterpretq_s16_f32): Likewise.
3463 (vreinterpretq_s64_f16): Likewise.
3464 (vreinterpretq_s64_f32): Likewise.
3465 (vreinterpretq_s8_f16): Likewise.
3466 (vreinterpretq_s8_f32): Likewise.
3467 (vuninitializedq_u8): Likewise.
3468 (vuninitializedq_u16): Likewise.
3469 (vuninitializedq_u32): Likewise.
3470 (vuninitializedq_u64): Likewise.
3471 (vuninitializedq_s8): Likewise.
3472 (vuninitializedq_s16): Likewise.
3473 (vuninitializedq_s32): Likewise.
3474 (vuninitializedq_s64): Likewise.
3475 (vuninitializedq_f16): Likewise.
3476 (vuninitializedq_f32): Likewise.
3477 (__arm_vuninitializedq_u8): Define intrinsic.
3478 (__arm_vuninitializedq_u16): Likewise.
3479 (__arm_vuninitializedq_u32): Likewise.
3480 (__arm_vuninitializedq_u64): Likewise.
3481 (__arm_vuninitializedq_s8): Likewise.
3482 (__arm_vuninitializedq_s16): Likewise.
3483 (__arm_vuninitializedq_s32): Likewise.
3484 (__arm_vuninitializedq_s64): Likewise.
3485 (__arm_vreinterpretq_s16_s32): Likewise.
3486 (__arm_vreinterpretq_s16_s64): Likewise.
3487 (__arm_vreinterpretq_s16_s8): Likewise.
3488 (__arm_vreinterpretq_s16_u16): Likewise.
3489 (__arm_vreinterpretq_s16_u32): Likewise.
3490 (__arm_vreinterpretq_s16_u64): Likewise.
3491 (__arm_vreinterpretq_s16_u8): Likewise.
3492 (__arm_vreinterpretq_s32_s16): Likewise.
3493 (__arm_vreinterpretq_s32_s64): Likewise.
3494 (__arm_vreinterpretq_s32_s8): Likewise.
3495 (__arm_vreinterpretq_s32_u16): Likewise.
3496 (__arm_vreinterpretq_s32_u32): Likewise.
3497 (__arm_vreinterpretq_s32_u64): Likewise.
3498 (__arm_vreinterpretq_s32_u8): Likewise.
3499 (__arm_vreinterpretq_s64_s16): Likewise.
3500 (__arm_vreinterpretq_s64_s32): Likewise.
3501 (__arm_vreinterpretq_s64_s8): Likewise.
3502 (__arm_vreinterpretq_s64_u16): Likewise.
3503 (__arm_vreinterpretq_s64_u32): Likewise.
3504 (__arm_vreinterpretq_s64_u64): Likewise.
3505 (__arm_vreinterpretq_s64_u8): Likewise.
3506 (__arm_vreinterpretq_s8_s16): Likewise.
3507 (__arm_vreinterpretq_s8_s32): Likewise.
3508 (__arm_vreinterpretq_s8_s64): Likewise.
3509 (__arm_vreinterpretq_s8_u16): Likewise.
3510 (__arm_vreinterpretq_s8_u32): Likewise.
3511 (__arm_vreinterpretq_s8_u64): Likewise.
3512 (__arm_vreinterpretq_s8_u8): Likewise.
3513 (__arm_vreinterpretq_u16_s16): Likewise.
3514 (__arm_vreinterpretq_u16_s32): Likewise.
3515 (__arm_vreinterpretq_u16_s64): Likewise.
3516 (__arm_vreinterpretq_u16_s8): Likewise.
3517 (__arm_vreinterpretq_u16_u32): Likewise.
3518 (__arm_vreinterpretq_u16_u64): Likewise.
3519 (__arm_vreinterpretq_u16_u8): Likewise.
3520 (__arm_vreinterpretq_u32_s16): Likewise.
3521 (__arm_vreinterpretq_u32_s32): Likewise.
3522 (__arm_vreinterpretq_u32_s64): Likewise.
3523 (__arm_vreinterpretq_u32_s8): Likewise.
3524 (__arm_vreinterpretq_u32_u16): Likewise.
3525 (__arm_vreinterpretq_u32_u64): Likewise.
3526 (__arm_vreinterpretq_u32_u8): Likewise.
3527 (__arm_vreinterpretq_u64_s16): Likewise.
3528 (__arm_vreinterpretq_u64_s32): Likewise.
3529 (__arm_vreinterpretq_u64_s64): Likewise.
3530 (__arm_vreinterpretq_u64_s8): Likewise.
3531 (__arm_vreinterpretq_u64_u16): Likewise.
3532 (__arm_vreinterpretq_u64_u32): Likewise.
3533 (__arm_vreinterpretq_u64_u8): Likewise.
3534 (__arm_vreinterpretq_u8_s16): Likewise.
3535 (__arm_vreinterpretq_u8_s32): Likewise.
3536 (__arm_vreinterpretq_u8_s64): Likewise.
3537 (__arm_vreinterpretq_u8_s8): Likewise.
3538 (__arm_vreinterpretq_u8_u16): Likewise.
3539 (__arm_vreinterpretq_u8_u32): Likewise.
3540 (__arm_vreinterpretq_u8_u64): Likewise.
3541 (__arm_vuninitializedq_f16): Likewise.
3542 (__arm_vuninitializedq_f32): Likewise.
3543 (__arm_vreinterpretq_s32_f16): Likewise.
3544 (__arm_vreinterpretq_s32_f32): Likewise.
3545 (__arm_vreinterpretq_s16_f16): Likewise.
3546 (__arm_vreinterpretq_s16_f32): Likewise.
3547 (__arm_vreinterpretq_s64_f16): Likewise.
3548 (__arm_vreinterpretq_s64_f32): Likewise.
3549 (__arm_vreinterpretq_s8_f16): Likewise.
3550 (__arm_vreinterpretq_s8_f32): Likewise.
3551 (__arm_vreinterpretq_u16_f16): Likewise.
3552 (__arm_vreinterpretq_u16_f32): Likewise.
3553 (__arm_vreinterpretq_u32_f16): Likewise.
3554 (__arm_vreinterpretq_u32_f32): Likewise.
3555 (__arm_vreinterpretq_u64_f16): Likewise.
3556 (__arm_vreinterpretq_u64_f32): Likewise.
3557 (__arm_vreinterpretq_u8_f16): Likewise.
3558 (__arm_vreinterpretq_u8_f32): Likewise.
3559 (__arm_vreinterpretq_f16_f32): Likewise.
3560 (__arm_vreinterpretq_f16_s16): Likewise.
3561 (__arm_vreinterpretq_f16_s32): Likewise.
3562 (__arm_vreinterpretq_f16_s64): Likewise.
3563 (__arm_vreinterpretq_f16_s8): Likewise.
3564 (__arm_vreinterpretq_f16_u16): Likewise.
3565 (__arm_vreinterpretq_f16_u32): Likewise.
3566 (__arm_vreinterpretq_f16_u64): Likewise.
3567 (__arm_vreinterpretq_f16_u8): Likewise.
3568 (__arm_vreinterpretq_f32_f16): Likewise.
3569 (__arm_vreinterpretq_f32_s16): Likewise.
3570 (__arm_vreinterpretq_f32_s32): Likewise.
3571 (__arm_vreinterpretq_f32_s64): Likewise.
3572 (__arm_vreinterpretq_f32_s8): Likewise.
3573 (__arm_vreinterpretq_f32_u16): Likewise.
3574 (__arm_vreinterpretq_f32_u32): Likewise.
3575 (__arm_vreinterpretq_f32_u64): Likewise.
3576 (__arm_vreinterpretq_f32_u8): Likewise.
3577 (vuninitializedq): Define polymorphic variant.
3578 (vreinterpretq_f16): Likewise.
3579 (vreinterpretq_f32): Likewise.
3580 (vreinterpretq_s16): Likewise.
3581 (vreinterpretq_s32): Likewise.
3582 (vreinterpretq_s64): Likewise.
3583 (vreinterpretq_s8): Likewise.
3584 (vreinterpretq_u16): Likewise.
3585 (vreinterpretq_u32): Likewise.
3586 (vreinterpretq_u64): Likewise.
3587 (vreinterpretq_u8): Likewise.
3588
3589 2020-03-20 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
3590 Andre Vieira <andre.simoesdiasvieira@arm.com>
3591 Mihail Ionescu <mihail.ionescu@arm.com>
3592
3593 * config/arm/arm_mve.h (vaddq_s8): Define macro.
3594 (vaddq_s16): Likewise.
3595 (vaddq_s32): Likewise.
3596 (vaddq_u8): Likewise.
3597 (vaddq_u16): Likewise.
3598 (vaddq_u32): Likewise.
3599 (vaddq_f16): Likewise.
3600 (vaddq_f32): Likewise.
3601 (__arm_vaddq_s8): Define intrinsic.
3602 (__arm_vaddq_s16): Likewise.
3603 (__arm_vaddq_s32): Likewise.
3604 (__arm_vaddq_u8): Likewise.
3605 (__arm_vaddq_u16): Likewise.
3606 (__arm_vaddq_u32): Likewise.
3607 (__arm_vaddq_f16): Likewise.
3608 (__arm_vaddq_f32): Likewise.
3609 (vaddq): Define polymorphic variant.
3610 * config/arm/iterators.md (VNIM): Define mode iterator for common types
3611 Neon, IWMMXT and MVE.
3612 (VNINOTM): Likewise.
3613 * config/arm/mve.md (mve_vaddq<mode>): Define RTL pattern.
3614 (mve_vaddq_f<mode>): Define RTL pattern.
3615 * config/arm/neon.md (add<mode>3): Rename to addv4hf3 RTL pattern.
3616 (addv8hf3_neon): Define RTL pattern.
3617 * config/arm/vec-common.md (add<mode>3): Modify standard add RTL pattern
3618 to support MVE.
3619 (addv8hf3): Define standard RTL pattern for MVE and Neon.
3620 (add<mode>3): Modify existing standard add RTL pattern for Neon and IWMMXT.
3621
3622 2020-03-20 Martin Liska <mliska@suse.cz>
3623
3624 PR ipa/94232
3625 * ipa-cp.c (ipa_get_jf_ancestor_result): Use offset in bytes. Previously
3626 build_ref_for_offset function was used and it transforms off to bytes
3627 from bits.
3628
3629 2020-03-20 Richard Biener <rguenther@suse.de>
3630
3631 PR tree-optimization/94266
3632 * gimple-ssa-sprintf.c (get_origin_and_offset): Use the
3633 type of the underlying object to adjust for the containing
3634 field if available.
3635
3636 2020-03-20 Andre Vieira <andre.simoesdiasvieira@arm.com>
3637
3638 * config/arm/unspecs.md (UNSPEC_GET_FPSCR): Rename this to ...
3639 (VUNSPEC_GET_FPSCR): ... this, and move it to vunspec.
3640 * config/arm/vfp.md: (get_fpscr, set_fpscr): Revert to old patterns.
3641
3642 2020-03-20 Andre Vieira <andre.simoesdiasvieira@arm.com>
3643
3644 * config/arm/mve.md (mve_mov<mode>): Fix R->R case.
3645
3646 2020-03-20 Jakub Jelinek <jakub@redhat.com>
3647
3648 PR tree-optimization/94224
3649 * gimple-ssa-store-merging.c
3650 (imm_store_chain_info::coalesce_immediate): Don't consider overlapping
3651 or adjacent INTEGER_CST rhs_code stores as mergeable if they have
3652 different lp_nr.
3653
3654 2020-03-20 Andre Vieira <andre.simoesdiasvieira@arm.com>
3655
3656 * config/arm/arm.md (define_attr "conds"): Fix logic for neon and mve.
3657
3658 2020-03-19 Jan Hubicka <hubicka@ucw.cz>
3659
3660 PR ipa/94202
3661 * cgraph.c (cgraph_node::function_symbol): Fix availability computation.
3662 (cgraph_node::function_or_virtual_thunk_symbol): Likewise.
3663
3664 2020-03-19 Jan Hubicka <hubicka@ucw.cz>
3665
3666 PR ipa/92372
3667 * cgraphunit.c (process_function_and_variable_attributes): warn
3668 for flatten attribute on alias.
3669 * ipa-inline.c (ipa_inline): Do not ICE on flatten attribute on alias.
3670
3671 2020-03-19 Martin Liska <mliska@suse.cz>
3672
3673 * lto-section-in.c: Add ext_symtab.
3674 * lto-streamer-out.c (write_symbol_extension_info): New.
3675 (produce_symtab_extension): New.
3676 (produce_asm_for_decls): Stream also produce_symtab_extension.
3677 * lto-streamer.h (enum lto_section_type): New section.
3678
3679 2020-03-19 Jakub Jelinek <jakub@redhat.com>
3680
3681 PR tree-optimization/94211
3682 * tree-ssa-phiopt.c (value_replacement): Use estimate_num_insns_seq
3683 instead of estimate_num_insns for bb_seq (middle_bb). Rename
3684 emtpy_or_with_defined_p variable to empty_or_with_defined_p, adjust
3685 all uses.
3686
3687 2020-03-19 Richard Biener <rguenther@suse.de>
3688
3689 PR ipa/94217
3690 * ipa-cp.c (ipa_get_jf_ancestor_result): Avoid build_fold_addr_expr
3691 and build_ref_for_offset.
3692
3693 2020-03-19 Richard Biener <rguenther@suse.de>
3694
3695 PR middle-end/94216
3696 * fold-const.c (fold_binary_loc): Avoid using
3697 build_fold_addr_expr when we really want an ADDR_EXPR.
3698
3699 2020-03-18 Segher Boessenkool <segher@kernel.crashing.org>
3700
3701 * config/rs6000/constraints.md (wd, wf, wi, ws, ww): New undocumented
3702 aliases for "wa".
3703
3704 2020-03-12 Richard Sandiford <richard.sandiford@arm.com>
3705
3706 PR rtl-optimization/90275
3707 * cse.c (cse_insn): Delete no-op register moves too.
3708
3709 2020-03-18 Martin Sebor <msebor@redhat.com>
3710
3711 PR ipa/92799
3712 * cgraphunit.c (process_function_and_variable_attributes): Also
3713 complain about weakref function definitions and drop all effects
3714 of the attribute.
3715
3716 2020-03-18 Andre Vieira <andre.simoesdiasvieira@arm.com>
3717 Mihail Ionescu <mihail.ionescu@arm.com>
3718 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
3719
3720 * config/arm/arm_mve.h (vstrdq_scatter_base_p_s64): Define macro.
3721 (vstrdq_scatter_base_p_u64): Likewise.
3722 (vstrdq_scatter_base_s64): Likewise.
3723 (vstrdq_scatter_base_u64): Likewise.
3724 (vstrdq_scatter_offset_p_s64): Likewise.
3725 (vstrdq_scatter_offset_p_u64): Likewise.
3726 (vstrdq_scatter_offset_s64): Likewise.
3727 (vstrdq_scatter_offset_u64): Likewise.
3728 (vstrdq_scatter_shifted_offset_p_s64): Likewise.
3729 (vstrdq_scatter_shifted_offset_p_u64): Likewise.
3730 (vstrdq_scatter_shifted_offset_s64): Likewise.
3731 (vstrdq_scatter_shifted_offset_u64): Likewise.
3732 (vstrhq_scatter_offset_f16): Likewise.
3733 (vstrhq_scatter_offset_p_f16): Likewise.
3734 (vstrhq_scatter_shifted_offset_f16): Likewise.
3735 (vstrhq_scatter_shifted_offset_p_f16): Likewise.
3736 (vstrwq_scatter_base_f32): Likewise.
3737 (vstrwq_scatter_base_p_f32): Likewise.
3738 (vstrwq_scatter_offset_f32): Likewise.
3739 (vstrwq_scatter_offset_p_f32): Likewise.
3740 (vstrwq_scatter_offset_p_s32): Likewise.
3741 (vstrwq_scatter_offset_p_u32): Likewise.
3742 (vstrwq_scatter_offset_s32): Likewise.
3743 (vstrwq_scatter_offset_u32): Likewise.
3744 (vstrwq_scatter_shifted_offset_f32): Likewise.
3745 (vstrwq_scatter_shifted_offset_p_f32): Likewise.
3746 (vstrwq_scatter_shifted_offset_p_s32): Likewise.
3747 (vstrwq_scatter_shifted_offset_p_u32): Likewise.
3748 (vstrwq_scatter_shifted_offset_s32): Likewise.
3749 (vstrwq_scatter_shifted_offset_u32): Likewise.
3750 (__arm_vstrdq_scatter_base_p_s64): Define intrinsic.
3751 (__arm_vstrdq_scatter_base_p_u64): Likewise.
3752 (__arm_vstrdq_scatter_base_s64): Likewise.
3753 (__arm_vstrdq_scatter_base_u64): Likewise.
3754 (__arm_vstrdq_scatter_offset_p_s64): Likewise.
3755 (__arm_vstrdq_scatter_offset_p_u64): Likewise.
3756 (__arm_vstrdq_scatter_offset_s64): Likewise.
3757 (__arm_vstrdq_scatter_offset_u64): Likewise.
3758 (__arm_vstrdq_scatter_shifted_offset_p_s64): Likewise.
3759 (__arm_vstrdq_scatter_shifted_offset_p_u64): Likewise.
3760 (__arm_vstrdq_scatter_shifted_offset_s64): Likewise.
3761 (__arm_vstrdq_scatter_shifted_offset_u64): Likewise.
3762 (__arm_vstrwq_scatter_offset_p_s32): Likewise.
3763 (__arm_vstrwq_scatter_offset_p_u32): Likewise.
3764 (__arm_vstrwq_scatter_offset_s32): Likewise.
3765 (__arm_vstrwq_scatter_offset_u32): Likewise.
3766 (__arm_vstrwq_scatter_shifted_offset_p_s32): Likewise.
3767 (__arm_vstrwq_scatter_shifted_offset_p_u32): Likewise.
3768 (__arm_vstrwq_scatter_shifted_offset_s32): Likewise.
3769 (__arm_vstrwq_scatter_shifted_offset_u32): Likewise.
3770 (__arm_vstrhq_scatter_offset_f16): Likewise.
3771 (__arm_vstrhq_scatter_offset_p_f16): Likewise.
3772 (__arm_vstrhq_scatter_shifted_offset_f16): Likewise.
3773 (__arm_vstrhq_scatter_shifted_offset_p_f16): Likewise.
3774 (__arm_vstrwq_scatter_base_f32): Likewise.
3775 (__arm_vstrwq_scatter_base_p_f32): Likewise.
3776 (__arm_vstrwq_scatter_offset_f32): Likewise.
3777 (__arm_vstrwq_scatter_offset_p_f32): Likewise.
3778 (__arm_vstrwq_scatter_shifted_offset_f32): Likewise.
3779 (__arm_vstrwq_scatter_shifted_offset_p_f32): Likewise.
3780 (vstrhq_scatter_offset): Define polymorphic variant.
3781 (vstrhq_scatter_offset_p): Likewise.
3782 (vstrhq_scatter_shifted_offset): Likewise.
3783 (vstrhq_scatter_shifted_offset_p): Likewise.
3784 (vstrwq_scatter_base): Likewise.
3785 (vstrwq_scatter_base_p): Likewise.
3786 (vstrwq_scatter_offset): Likewise.
3787 (vstrwq_scatter_offset_p): Likewise.
3788 (vstrwq_scatter_shifted_offset): Likewise.
3789 (vstrwq_scatter_shifted_offset_p): Likewise.
3790 (vstrdq_scatter_base_p): Likewise.
3791 (vstrdq_scatter_base): Likewise.
3792 (vstrdq_scatter_offset_p): Likewise.
3793 (vstrdq_scatter_offset): Likewise.
3794 (vstrdq_scatter_shifted_offset_p): Likewise.
3795 (vstrdq_scatter_shifted_offset): Likewise.
3796 * config/arm/arm_mve_builtins.def (STRSBS): Use builtin qualifier.
3797 (STRSBS_P): Likewise.
3798 (STRSBU): Likewise.
3799 (STRSBU_P): Likewise.
3800 (STRSS): Likewise.
3801 (STRSS_P): Likewise.
3802 (STRSU): Likewise.
3803 (STRSU_P): Likewise.
3804 * config/arm/constraints.md (Ri): Define.
3805 * config/arm/mve.md (VSTRDSBQ): Define iterator.
3806 (VSTRDSOQ): Likewise.
3807 (VSTRDSSOQ): Likewise.
3808 (VSTRWSOQ): Likewise.
3809 (VSTRWSSOQ): Likewise.
3810 (mve_vstrdq_scatter_base_p_<supf>v2di): Define RTL pattern.
3811 (mve_vstrdq_scatter_base_<supf>v2di): Likewise.
3812 (mve_vstrdq_scatter_offset_p_<supf>v2di): Likewise.
3813 (mve_vstrdq_scatter_offset_<supf>v2di): Likewise.
3814 (mve_vstrdq_scatter_shifted_offset_p_<supf>v2di): Likewise.
3815 (mve_vstrdq_scatter_shifted_offset_<supf>v2di): Likewise.
3816 (mve_vstrhq_scatter_offset_fv8hf): Likewise.
3817 (mve_vstrhq_scatter_offset_p_fv8hf): Likewise.
3818 (mve_vstrhq_scatter_shifted_offset_fv8hf): Likewise.
3819 (mve_vstrhq_scatter_shifted_offset_p_fv8hf): Likewise.
3820 (mve_vstrwq_scatter_base_fv4sf): Likewise.
3821 (mve_vstrwq_scatter_base_p_fv4sf): Likewise.
3822 (mve_vstrwq_scatter_offset_fv4sf): Likewise.
3823 (mve_vstrwq_scatter_offset_p_fv4sf): Likewise.
3824 (mve_vstrwq_scatter_offset_p_<supf>v4si): Likewise.
3825 (mve_vstrwq_scatter_offset_<supf>v4si): Likewise.
3826 (mve_vstrwq_scatter_shifted_offset_fv4sf): Likewise.
3827 (mve_vstrwq_scatter_shifted_offset_p_fv4sf): Likewise.
3828 (mve_vstrwq_scatter_shifted_offset_p_<supf>v4si): Likewise.
3829 (mve_vstrwq_scatter_shifted_offset_<supf>v4si): Likewise.
3830 * config/arm/predicates.md (Ri): Define predicate to check immediate
3831 is the range +/-1016 and multiple of 8.
3832
3833 2020-03-18 Andre Vieira <andre.simoesdiasvieira@arm.com>
3834 Mihail Ionescu <mihail.ionescu@arm.com>
3835 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
3836
3837 * config/arm/arm_mve.h (vst1q_f32): Define macro.
3838 (vst1q_f16): Likewise.
3839 (vst1q_s8): Likewise.
3840 (vst1q_s32): Likewise.
3841 (vst1q_s16): Likewise.
3842 (vst1q_u8): Likewise.
3843 (vst1q_u32): Likewise.
3844 (vst1q_u16): Likewise.
3845 (vstrhq_f16): Likewise.
3846 (vstrhq_scatter_offset_s32): Likewise.
3847 (vstrhq_scatter_offset_s16): Likewise.
3848 (vstrhq_scatter_offset_u32): Likewise.
3849 (vstrhq_scatter_offset_u16): Likewise.
3850 (vstrhq_scatter_offset_p_s32): Likewise.
3851 (vstrhq_scatter_offset_p_s16): Likewise.
3852 (vstrhq_scatter_offset_p_u32): Likewise.
3853 (vstrhq_scatter_offset_p_u16): Likewise.
3854 (vstrhq_scatter_shifted_offset_s32): Likewise.
3855 (vstrhq_scatter_shifted_offset_s16): Likewise.
3856 (vstrhq_scatter_shifted_offset_u32): Likewise.
3857 (vstrhq_scatter_shifted_offset_u16): Likewise.
3858 (vstrhq_scatter_shifted_offset_p_s32): Likewise.
3859 (vstrhq_scatter_shifted_offset_p_s16): Likewise.
3860 (vstrhq_scatter_shifted_offset_p_u32): Likewise.
3861 (vstrhq_scatter_shifted_offset_p_u16): Likewise.
3862 (vstrhq_s32): Likewise.
3863 (vstrhq_s16): Likewise.
3864 (vstrhq_u32): Likewise.
3865 (vstrhq_u16): Likewise.
3866 (vstrhq_p_f16): Likewise.
3867 (vstrhq_p_s32): Likewise.
3868 (vstrhq_p_s16): Likewise.
3869 (vstrhq_p_u32): Likewise.
3870 (vstrhq_p_u16): Likewise.
3871 (vstrwq_f32): Likewise.
3872 (vstrwq_s32): Likewise.
3873 (vstrwq_u32): Likewise.
3874 (vstrwq_p_f32): Likewise.
3875 (vstrwq_p_s32): Likewise.
3876 (vstrwq_p_u32): Likewise.
3877 (__arm_vst1q_s8): Define intrinsic.
3878 (__arm_vst1q_s32): Likewise.
3879 (__arm_vst1q_s16): Likewise.
3880 (__arm_vst1q_u8): Likewise.
3881 (__arm_vst1q_u32): Likewise.
3882 (__arm_vst1q_u16): Likewise.
3883 (__arm_vstrhq_scatter_offset_s32): Likewise.
3884 (__arm_vstrhq_scatter_offset_s16): Likewise.
3885 (__arm_vstrhq_scatter_offset_u32): Likewise.
3886 (__arm_vstrhq_scatter_offset_u16): Likewise.
3887 (__arm_vstrhq_scatter_offset_p_s32): Likewise.
3888 (__arm_vstrhq_scatter_offset_p_s16): Likewise.
3889 (__arm_vstrhq_scatter_offset_p_u32): Likewise.
3890 (__arm_vstrhq_scatter_offset_p_u16): Likewise.
3891 (__arm_vstrhq_scatter_shifted_offset_s32): Likewise.
3892 (__arm_vstrhq_scatter_shifted_offset_s16): Likewise.
3893 (__arm_vstrhq_scatter_shifted_offset_u32): Likewise.
3894 (__arm_vstrhq_scatter_shifted_offset_u16): Likewise.
3895 (__arm_vstrhq_scatter_shifted_offset_p_s32): Likewise.
3896 (__arm_vstrhq_scatter_shifted_offset_p_s16): Likewise.
3897 (__arm_vstrhq_scatter_shifted_offset_p_u32): Likewise.
3898 (__arm_vstrhq_scatter_shifted_offset_p_u16): Likewise.
3899 (__arm_vstrhq_s32): Likewise.
3900 (__arm_vstrhq_s16): Likewise.
3901 (__arm_vstrhq_u32): Likewise.
3902 (__arm_vstrhq_u16): Likewise.
3903 (__arm_vstrhq_p_s32): Likewise.
3904 (__arm_vstrhq_p_s16): Likewise.
3905 (__arm_vstrhq_p_u32): Likewise.
3906 (__arm_vstrhq_p_u16): Likewise.
3907 (__arm_vstrwq_s32): Likewise.
3908 (__arm_vstrwq_u32): Likewise.
3909 (__arm_vstrwq_p_s32): Likewise.
3910 (__arm_vstrwq_p_u32): Likewise.
3911 (__arm_vstrwq_p_f32): Likewise.
3912 (__arm_vstrwq_f32): Likewise.
3913 (__arm_vst1q_f32): Likewise.
3914 (__arm_vst1q_f16): Likewise.
3915 (__arm_vstrhq_f16): Likewise.
3916 (__arm_vstrhq_p_f16): Likewise.
3917 (vst1q): Define polymorphic variant.
3918 (vstrhq): Likewise.
3919 (vstrhq_p): Likewise.
3920 (vstrhq_scatter_offset_p): Likewise.
3921 (vstrhq_scatter_offset): Likewise.
3922 (vstrhq_scatter_shifted_offset_p): Likewise.
3923 (vstrhq_scatter_shifted_offset): Likewise.
3924 (vstrwq_p): Likewise.
3925 (vstrwq): Likewise.
3926 * config/arm/arm_mve_builtins.def (STRS): Use builtin qualifier.
3927 (STRS_P): Likewise.
3928 (STRSS): Likewise.
3929 (STRSS_P): Likewise.
3930 (STRSU): Likewise.
3931 (STRSU_P): Likewise.
3932 (STRU): Likewise.
3933 (STRU_P): Likewise.
3934 * config/arm/mve.md (VST1Q): Define iterator.
3935 (VSTRHSOQ): Likewise.
3936 (VSTRHSSOQ): Likewise.
3937 (VSTRHQ): Likewise.
3938 (VSTRWQ): Likewise.
3939 (mve_vstrhq_fv8hf): Define RTL pattern.
3940 (mve_vstrhq_p_fv8hf): Likewise.
3941 (mve_vstrhq_p_<supf><mode>): Likewise.
3942 (mve_vstrhq_scatter_offset_p_<supf><mode>): Likewise.
3943 (mve_vstrhq_scatter_offset_<supf><mode>): Likewise.
3944 (mve_vstrhq_scatter_shifted_offset_p_<supf><mode>): Likewise.
3945 (mve_vstrhq_scatter_shifted_offset_<supf><mode>): Likewise.
3946 (mve_vstrhq_<supf><mode>): Likewise.
3947 (mve_vstrwq_fv4sf): Likewise.
3948 (mve_vstrwq_p_fv4sf): Likewise.
3949 (mve_vstrwq_p_<supf>v4si): Likewise.
3950 (mve_vstrwq_<supf>v4si): Likewise.
3951 (mve_vst1q_f<mode>): Define expand.
3952 (mve_vst1q_<supf><mode>): Likewise.
3953
3954 2020-03-18 Andre Vieira <andre.simoesdiasvieira@arm.com>
3955 Mihail Ionescu <mihail.ionescu@arm.com>
3956 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
3957
3958 * config/arm/arm_mve.h (vld1q_s8): Define macro.
3959 (vld1q_s32): Likewise.
3960 (vld1q_s16): Likewise.
3961 (vld1q_u8): Likewise.
3962 (vld1q_u32): Likewise.
3963 (vld1q_u16): Likewise.
3964 (vldrhq_gather_offset_s32): Likewise.
3965 (vldrhq_gather_offset_s16): Likewise.
3966 (vldrhq_gather_offset_u32): Likewise.
3967 (vldrhq_gather_offset_u16): Likewise.
3968 (vldrhq_gather_offset_z_s32): Likewise.
3969 (vldrhq_gather_offset_z_s16): Likewise.
3970 (vldrhq_gather_offset_z_u32): Likewise.
3971 (vldrhq_gather_offset_z_u16): Likewise.
3972 (vldrhq_gather_shifted_offset_s32): Likewise.
3973 (vldrhq_gather_shifted_offset_s16): Likewise.
3974 (vldrhq_gather_shifted_offset_u32): Likewise.
3975 (vldrhq_gather_shifted_offset_u16): Likewise.
3976 (vldrhq_gather_shifted_offset_z_s32): Likewise.
3977 (vldrhq_gather_shifted_offset_z_s16): Likewise.
3978 (vldrhq_gather_shifted_offset_z_u32): Likewise.
3979 (vldrhq_gather_shifted_offset_z_u16): Likewise.
3980 (vldrhq_s32): Likewise.
3981 (vldrhq_s16): Likewise.
3982 (vldrhq_u32): Likewise.
3983 (vldrhq_u16): Likewise.
3984 (vldrhq_z_s32): Likewise.
3985 (vldrhq_z_s16): Likewise.
3986 (vldrhq_z_u32): Likewise.
3987 (vldrhq_z_u16): Likewise.
3988 (vldrwq_s32): Likewise.
3989 (vldrwq_u32): Likewise.
3990 (vldrwq_z_s32): Likewise.
3991 (vldrwq_z_u32): Likewise.
3992 (vld1q_f32): Likewise.
3993 (vld1q_f16): Likewise.
3994 (vldrhq_f16): Likewise.
3995 (vldrhq_z_f16): Likewise.
3996 (vldrwq_f32): Likewise.
3997 (vldrwq_z_f32): Likewise.
3998 (__arm_vld1q_s8): Define intrinsic.
3999 (__arm_vld1q_s32): Likewise.
4000 (__arm_vld1q_s16): Likewise.
4001 (__arm_vld1q_u8): Likewise.
4002 (__arm_vld1q_u32): Likewise.
4003 (__arm_vld1q_u16): Likewise.
4004 (__arm_vldrhq_gather_offset_s32): Likewise.
4005 (__arm_vldrhq_gather_offset_s16): Likewise.
4006 (__arm_vldrhq_gather_offset_u32): Likewise.
4007 (__arm_vldrhq_gather_offset_u16): Likewise.
4008 (__arm_vldrhq_gather_offset_z_s32): Likewise.
4009 (__arm_vldrhq_gather_offset_z_s16): Likewise.
4010 (__arm_vldrhq_gather_offset_z_u32): Likewise.
4011 (__arm_vldrhq_gather_offset_z_u16): Likewise.
4012 (__arm_vldrhq_gather_shifted_offset_s32): Likewise.
4013 (__arm_vldrhq_gather_shifted_offset_s16): Likewise.
4014 (__arm_vldrhq_gather_shifted_offset_u32): Likewise.
4015 (__arm_vldrhq_gather_shifted_offset_u16): Likewise.
4016 (__arm_vldrhq_gather_shifted_offset_z_s32): Likewise.
4017 (__arm_vldrhq_gather_shifted_offset_z_s16): Likewise.
4018 (__arm_vldrhq_gather_shifted_offset_z_u32): Likewise.
4019 (__arm_vldrhq_gather_shifted_offset_z_u16): Likewise.
4020 (__arm_vldrhq_s32): Likewise.
4021 (__arm_vldrhq_s16): Likewise.
4022 (__arm_vldrhq_u32): Likewise.
4023 (__arm_vldrhq_u16): Likewise.
4024 (__arm_vldrhq_z_s32): Likewise.
4025 (__arm_vldrhq_z_s16): Likewise.
4026 (__arm_vldrhq_z_u32): Likewise.
4027 (__arm_vldrhq_z_u16): Likewise.
4028 (__arm_vldrwq_s32): Likewise.
4029 (__arm_vldrwq_u32): Likewise.
4030 (__arm_vldrwq_z_s32): Likewise.
4031 (__arm_vldrwq_z_u32): Likewise.
4032 (__arm_vld1q_f32): Likewise.
4033 (__arm_vld1q_f16): Likewise.
4034 (__arm_vldrwq_f32): Likewise.
4035 (__arm_vldrwq_z_f32): Likewise.
4036 (__arm_vldrhq_z_f16): Likewise.
4037 (__arm_vldrhq_f16): Likewise.
4038 (vld1q): Define polymorphic variant.
4039 (vldrhq_gather_offset): Likewise.
4040 (vldrhq_gather_offset_z): Likewise.
4041 (vldrhq_gather_shifted_offset): Likewise.
4042 (vldrhq_gather_shifted_offset_z): Likewise.
4043 * config/arm/arm_mve_builtins.def (LDRU): Use builtin qualifier.
4044 (LDRS): Likewise.
4045 (LDRU_Z): Likewise.
4046 (LDRS_Z): Likewise.
4047 (LDRGU_Z): Likewise.
4048 (LDRGU): Likewise.
4049 (LDRGS_Z): Likewise.
4050 (LDRGS): Likewise.
4051 * config/arm/mve.md (MVE_H_ELEM): Define mode iterator.
4052 (V_sz_elem1): Likewise.
4053 (VLD1Q): Define iterator.
4054 (VLDRHGOQ): Likewise.
4055 (VLDRHGSOQ): Likewise.
4056 (VLDRHQ): Likewise.
4057 (VLDRWQ): Likewise.
4058 (mve_vldrhq_fv8hf): Define RTL pattern.
4059 (mve_vldrhq_gather_offset_<supf><mode>): Likewise.
4060 (mve_vldrhq_gather_offset_z_<supf><mode>): Likewise.
4061 (mve_vldrhq_gather_shifted_offset_<supf><mode>): Likewise.
4062 (mve_vldrhq_gather_shifted_offset_z_<supf><mode>): Likewise.
4063 (mve_vldrhq_<supf><mode>): Likewise.
4064 (mve_vldrhq_z_fv8hf): Likewise.
4065 (mve_vldrhq_z_<supf><mode>): Likewise.
4066 (mve_vldrwq_fv4sf): Likewise.
4067 (mve_vldrwq_<supf>v4si): Likewise.
4068 (mve_vldrwq_z_fv4sf): Likewise.
4069 (mve_vldrwq_z_<supf>v4si): Likewise.
4070 (mve_vld1q_f<mode>): Define RTL expand pattern.
4071 (mve_vld1q_<supf><mode>): Likewise.
4072
4073 2020-03-18 Andre Vieira <andre.simoesdiasvieira@arm.com>
4074 Mihail Ionescu <mihail.ionescu@arm.com>
4075 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
4076
4077 * config/arm/arm_mve.h (vld1q_s8): Define macro.
4078 (vld1q_s32): Likewise.
4079 (vld1q_s16): Likewise.
4080 (vld1q_u8): Likewise.
4081 (vld1q_u32): Likewise.
4082 (vld1q_u16): Likewise.
4083 (vldrhq_gather_offset_s32): Likewise.
4084 (vldrhq_gather_offset_s16): Likewise.
4085 (vldrhq_gather_offset_u32): Likewise.
4086 (vldrhq_gather_offset_u16): Likewise.
4087 (vldrhq_gather_offset_z_s32): Likewise.
4088 (vldrhq_gather_offset_z_s16): Likewise.
4089 (vldrhq_gather_offset_z_u32): Likewise.
4090 (vldrhq_gather_offset_z_u16): Likewise.
4091 (vldrhq_gather_shifted_offset_s32): Likewise.
4092 (vldrhq_gather_shifted_offset_s16): Likewise.
4093 (vldrhq_gather_shifted_offset_u32): Likewise.
4094 (vldrhq_gather_shifted_offset_u16): Likewise.
4095 (vldrhq_gather_shifted_offset_z_s32): Likewise.
4096 (vldrhq_gather_shifted_offset_z_s16): Likewise.
4097 (vldrhq_gather_shifted_offset_z_u32): Likewise.
4098 (vldrhq_gather_shifted_offset_z_u16): Likewise.
4099 (vldrhq_s32): Likewise.
4100 (vldrhq_s16): Likewise.
4101 (vldrhq_u32): Likewise.
4102 (vldrhq_u16): Likewise.
4103 (vldrhq_z_s32): Likewise.
4104 (vldrhq_z_s16): Likewise.
4105 (vldrhq_z_u32): Likewise.
4106 (vldrhq_z_u16): Likewise.
4107 (vldrwq_s32): Likewise.
4108 (vldrwq_u32): Likewise.
4109 (vldrwq_z_s32): Likewise.
4110 (vldrwq_z_u32): Likewise.
4111 (vld1q_f32): Likewise.
4112 (vld1q_f16): Likewise.
4113 (vldrhq_f16): Likewise.
4114 (vldrhq_z_f16): Likewise.
4115 (vldrwq_f32): Likewise.
4116 (vldrwq_z_f32): Likewise.
4117 (__arm_vld1q_s8): Define intrinsic.
4118 (__arm_vld1q_s32): Likewise.
4119 (__arm_vld1q_s16): Likewise.
4120 (__arm_vld1q_u8): Likewise.
4121 (__arm_vld1q_u32): Likewise.
4122 (__arm_vld1q_u16): Likewise.
4123 (__arm_vldrhq_gather_offset_s32): Likewise.
4124 (__arm_vldrhq_gather_offset_s16): Likewise.
4125 (__arm_vldrhq_gather_offset_u32): Likewise.
4126 (__arm_vldrhq_gather_offset_u16): Likewise.
4127 (__arm_vldrhq_gather_offset_z_s32): Likewise.
4128 (__arm_vldrhq_gather_offset_z_s16): Likewise.
4129 (__arm_vldrhq_gather_offset_z_u32): Likewise.
4130 (__arm_vldrhq_gather_offset_z_u16): Likewise.
4131 (__arm_vldrhq_gather_shifted_offset_s32): Likewise.
4132 (__arm_vldrhq_gather_shifted_offset_s16): Likewise.
4133 (__arm_vldrhq_gather_shifted_offset_u32): Likewise.
4134 (__arm_vldrhq_gather_shifted_offset_u16): Likewise.
4135 (__arm_vldrhq_gather_shifted_offset_z_s32): Likewise.
4136 (__arm_vldrhq_gather_shifted_offset_z_s16): Likewise.
4137 (__arm_vldrhq_gather_shifted_offset_z_u32): Likewise.
4138 (__arm_vldrhq_gather_shifted_offset_z_u16): Likewise.
4139 (__arm_vldrhq_s32): Likewise.
4140 (__arm_vldrhq_s16): Likewise.
4141 (__arm_vldrhq_u32): Likewise.
4142 (__arm_vldrhq_u16): Likewise.
4143 (__arm_vldrhq_z_s32): Likewise.
4144 (__arm_vldrhq_z_s16): Likewise.
4145 (__arm_vldrhq_z_u32): Likewise.
4146 (__arm_vldrhq_z_u16): Likewise.
4147 (__arm_vldrwq_s32): Likewise.
4148 (__arm_vldrwq_u32): Likewise.
4149 (__arm_vldrwq_z_s32): Likewise.
4150 (__arm_vldrwq_z_u32): Likewise.
4151 (__arm_vld1q_f32): Likewise.
4152 (__arm_vld1q_f16): Likewise.
4153 (__arm_vldrwq_f32): Likewise.
4154 (__arm_vldrwq_z_f32): Likewise.
4155 (__arm_vldrhq_z_f16): Likewise.
4156 (__arm_vldrhq_f16): Likewise.
4157 (vld1q): Define polymorphic variant.
4158 (vldrhq_gather_offset): Likewise.
4159 (vldrhq_gather_offset_z): Likewise.
4160 (vldrhq_gather_shifted_offset): Likewise.
4161 (vldrhq_gather_shifted_offset_z): Likewise.
4162 * config/arm/arm_mve_builtins.def (LDRU): Use builtin qualifier.
4163 (LDRS): Likewise.
4164 (LDRU_Z): Likewise.
4165 (LDRS_Z): Likewise.
4166 (LDRGU_Z): Likewise.
4167 (LDRGU): Likewise.
4168 (LDRGS_Z): Likewise.
4169 (LDRGS): Likewise.
4170 * config/arm/mve.md (MVE_H_ELEM): Define mode iterator.
4171 (V_sz_elem1): Likewise.
4172 (VLD1Q): Define iterator.
4173 (VLDRHGOQ): Likewise.
4174 (VLDRHGSOQ): Likewise.
4175 (VLDRHQ): Likewise.
4176 (VLDRWQ): Likewise.
4177 (mve_vldrhq_fv8hf): Define RTL pattern.
4178 (mve_vldrhq_gather_offset_<supf><mode>): Likewise.
4179 (mve_vldrhq_gather_offset_z_<supf><mode>): Likewise.
4180 (mve_vldrhq_gather_shifted_offset_<supf><mode>): Likewise.
4181 (mve_vldrhq_gather_shifted_offset_z_<supf><mode>): Likewise.
4182 (mve_vldrhq_<supf><mode>): Likewise.
4183 (mve_vldrhq_z_fv8hf): Likewise.
4184 (mve_vldrhq_z_<supf><mode>): Likewise.
4185 (mve_vldrwq_fv4sf): Likewise.
4186 (mve_vldrwq_<supf>v4si): Likewise.
4187 (mve_vldrwq_z_fv4sf): Likewise.
4188 (mve_vldrwq_z_<supf>v4si): Likewise.
4189 (mve_vld1q_f<mode>): Define RTL expand pattern.
4190 (mve_vld1q_<supf><mode>): Likewise.
4191
4192 2020-03-18 Andre Vieira <andre.simoesdiasvieira@arm.com>
4193 Mihail Ionescu <mihail.ionescu@arm.com>
4194 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
4195
4196 * config/arm/arm-builtins.c (LDRGBS_Z_QUALIFIERS): Define builtin
4197 qualifier.
4198 (LDRGBU_Z_QUALIFIERS): Likewise.
4199 (LDRGS_Z_QUALIFIERS): Likewise.
4200 (LDRGU_Z_QUALIFIERS): Likewise.
4201 (LDRS_Z_QUALIFIERS): Likewise.
4202 (LDRU_Z_QUALIFIERS): Likewise.
4203 * config/arm/arm_mve.h (vldrbq_gather_offset_z_s16): Define macro.
4204 (vldrbq_gather_offset_z_u8): Likewise.
4205 (vldrbq_gather_offset_z_s32): Likewise.
4206 (vldrbq_gather_offset_z_u16): Likewise.
4207 (vldrbq_gather_offset_z_u32): Likewise.
4208 (vldrbq_gather_offset_z_s8): Likewise.
4209 (vldrbq_z_s16): Likewise.
4210 (vldrbq_z_u8): Likewise.
4211 (vldrbq_z_s8): Likewise.
4212 (vldrbq_z_s32): Likewise.
4213 (vldrbq_z_u16): Likewise.
4214 (vldrbq_z_u32): Likewise.
4215 (vldrwq_gather_base_z_u32): Likewise.
4216 (vldrwq_gather_base_z_s32): Likewise.
4217 (__arm_vldrbq_gather_offset_z_s8): Define intrinsic.
4218 (__arm_vldrbq_gather_offset_z_s32): Likewise.
4219 (__arm_vldrbq_gather_offset_z_s16): Likewise.
4220 (__arm_vldrbq_gather_offset_z_u8): Likewise.
4221 (__arm_vldrbq_gather_offset_z_u32): Likewise.
4222 (__arm_vldrbq_gather_offset_z_u16): Likewise.
4223 (__arm_vldrbq_z_s8): Likewise.
4224 (__arm_vldrbq_z_s32): Likewise.
4225 (__arm_vldrbq_z_s16): Likewise.
4226 (__arm_vldrbq_z_u8): Likewise.
4227 (__arm_vldrbq_z_u32): Likewise.
4228 (__arm_vldrbq_z_u16): Likewise.
4229 (__arm_vldrwq_gather_base_z_s32): Likewise.
4230 (__arm_vldrwq_gather_base_z_u32): Likewise.
4231 (vldrbq_gather_offset_z): Define polymorphic variant.
4232 * config/arm/arm_mve_builtins.def (LDRGBS_Z_QUALIFIERS): Use builtin
4233 qualifier.
4234 (LDRGBU_Z_QUALIFIERS): Likewise.
4235 (LDRGS_Z_QUALIFIERS): Likewise.
4236 (LDRGU_Z_QUALIFIERS): Likewise.
4237 (LDRS_Z_QUALIFIERS): Likewise.
4238 (LDRU_Z_QUALIFIERS): Likewise.
4239 * config/arm/mve.md (mve_vldrbq_gather_offset_z_<supf><mode>): Define
4240 RTL pattern.
4241 (mve_vldrbq_z_<supf><mode>): Likewise.
4242 (mve_vldrwq_gather_base_z_<supf>v4si): Likewise.
4243
4244 2020-03-18 Andre Vieira <andre.simoesdiasvieira@arm.com>
4245 Mihail Ionescu <mihail.ionescu@arm.com>
4246 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
4247
4248 * config/arm/arm-builtins.c (STRS_P_QUALIFIERS): Define builtin
4249 qualifier.
4250 (STRU_P_QUALIFIERS): Likewise.
4251 (STRSU_P_QUALIFIERS): Likewise.
4252 (STRSS_P_QUALIFIERS): Likewise.
4253 (STRSBS_P_QUALIFIERS): Likewise.
4254 (STRSBU_P_QUALIFIERS): Likewise.
4255 * config/arm/arm_mve.h (vstrbq_p_s8): Define macro.
4256 (vstrbq_p_s32): Likewise.
4257 (vstrbq_p_s16): Likewise.
4258 (vstrbq_p_u8): Likewise.
4259 (vstrbq_p_u32): Likewise.
4260 (vstrbq_p_u16): Likewise.
4261 (vstrbq_scatter_offset_p_s8): Likewise.
4262 (vstrbq_scatter_offset_p_s32): Likewise.
4263 (vstrbq_scatter_offset_p_s16): Likewise.
4264 (vstrbq_scatter_offset_p_u8): Likewise.
4265 (vstrbq_scatter_offset_p_u32): Likewise.
4266 (vstrbq_scatter_offset_p_u16): Likewise.
4267 (vstrwq_scatter_base_p_s32): Likewise.
4268 (vstrwq_scatter_base_p_u32): Likewise.
4269 (__arm_vstrbq_p_s8): Define intrinsic.
4270 (__arm_vstrbq_p_s32): Likewise.
4271 (__arm_vstrbq_p_s16): Likewise.
4272 (__arm_vstrbq_p_u8): Likewise.
4273 (__arm_vstrbq_p_u32): Likewise.
4274 (__arm_vstrbq_p_u16): Likewise.
4275 (__arm_vstrbq_scatter_offset_p_s8): Likewise.
4276 (__arm_vstrbq_scatter_offset_p_s32): Likewise.
4277 (__arm_vstrbq_scatter_offset_p_s16): Likewise.
4278 (__arm_vstrbq_scatter_offset_p_u8): Likewise.
4279 (__arm_vstrbq_scatter_offset_p_u32): Likewise.
4280 (__arm_vstrbq_scatter_offset_p_u16): Likewise.
4281 (__arm_vstrwq_scatter_base_p_s32): Likewise.
4282 (__arm_vstrwq_scatter_base_p_u32): Likewise.
4283 (vstrbq_p): Define polymorphic variant.
4284 (vstrbq_scatter_offset_p): Likewise.
4285 (vstrwq_scatter_base_p): Likewise.
4286 * config/arm/arm_mve_builtins.def (STRS_P_QUALIFIERS): Use builtin
4287 qualifier.
4288 (STRU_P_QUALIFIERS): Likewise.
4289 (STRSU_P_QUALIFIERS): Likewise.
4290 (STRSS_P_QUALIFIERS): Likewise.
4291 (STRSBS_P_QUALIFIERS): Likewise.
4292 (STRSBU_P_QUALIFIERS): Likewise.
4293 * config/arm/mve.md (mve_vstrbq_scatter_offset_p_<supf><mode>): Define
4294 RTL pattern.
4295 (mve_vstrwq_scatter_base_p_<supf>v4si): Likewise.
4296 (mve_vstrbq_p_<supf><mode>): Likewise.
4297
4298 2020-03-18 Andre Vieira <andre.simoesdiasvieira@arm.com>
4299 Mihail Ionescu <mihail.ionescu@arm.com>
4300 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
4301
4302 * config/arm/arm-builtins.c (LDRGU_QUALIFIERS): Define builtin
4303 qualifier.
4304 (LDRGS_QUALIFIERS): Likewise.
4305 (LDRS_QUALIFIERS): Likewise.
4306 (LDRU_QUALIFIERS): Likewise.
4307 (LDRGBS_QUALIFIERS): Likewise.
4308 (LDRGBU_QUALIFIERS): Likewise.
4309 * config/arm/arm_mve.h (vldrbq_gather_offset_u8): Define macro.
4310 (vldrbq_gather_offset_s8): Likewise.
4311 (vldrbq_s8): Likewise.
4312 (vldrbq_u8): Likewise.
4313 (vldrbq_gather_offset_u16): Likewise.
4314 (vldrbq_gather_offset_s16): Likewise.
4315 (vldrbq_s16): Likewise.
4316 (vldrbq_u16): Likewise.
4317 (vldrbq_gather_offset_u32): Likewise.
4318 (vldrbq_gather_offset_s32): Likewise.
4319 (vldrbq_s32): Likewise.
4320 (vldrbq_u32): Likewise.
4321 (vldrwq_gather_base_s32): Likewise.
4322 (vldrwq_gather_base_u32): Likewise.
4323 (__arm_vldrbq_gather_offset_u8): Define intrinsic.
4324 (__arm_vldrbq_gather_offset_s8): Likewise.
4325 (__arm_vldrbq_s8): Likewise.
4326 (__arm_vldrbq_u8): Likewise.
4327 (__arm_vldrbq_gather_offset_u16): Likewise.
4328 (__arm_vldrbq_gather_offset_s16): Likewise.
4329 (__arm_vldrbq_s16): Likewise.
4330 (__arm_vldrbq_u16): Likewise.
4331 (__arm_vldrbq_gather_offset_u32): Likewise.
4332 (__arm_vldrbq_gather_offset_s32): Likewise.
4333 (__arm_vldrbq_s32): Likewise.
4334 (__arm_vldrbq_u32): Likewise.
4335 (__arm_vldrwq_gather_base_s32): Likewise.
4336 (__arm_vldrwq_gather_base_u32): Likewise.
4337 (vldrbq_gather_offset): Define polymorphic variant.
4338 * config/arm/arm_mve_builtins.def (LDRGU_QUALIFIERS): Use builtin
4339 qualifier.
4340 (LDRGS_QUALIFIERS): Likewise.
4341 (LDRS_QUALIFIERS): Likewise.
4342 (LDRU_QUALIFIERS): Likewise.
4343 (LDRGBS_QUALIFIERS): Likewise.
4344 (LDRGBU_QUALIFIERS): Likewise.
4345 * config/arm/mve.md (VLDRBGOQ): Define iterator.
4346 (VLDRBQ): Likewise.
4347 (VLDRWGBQ): Likewise.
4348 (mve_vldrbq_gather_offset_<supf><mode>): Define RTL pattern.
4349 (mve_vldrbq_<supf><mode>): Likewise.
4350 (mve_vldrwq_gather_base_<supf>v4si): Likewise.
4351
4352 2020-03-18 Andre Vieira <andre.simoesdiasvieira@arm.com>
4353 Mihail Ionescu <mihail.ionescu@arm.com>
4354 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
4355
4356 * config/arm/arm-builtins.c (STRS_QUALIFIERS): Define builtin qualifier.
4357 (STRU_QUALIFIERS): Likewise.
4358 (STRSS_QUALIFIERS): Likewise.
4359 (STRSU_QUALIFIERS): Likewise.
4360 (STRSBS_QUALIFIERS): Likewise.
4361 (STRSBU_QUALIFIERS): Likewise.
4362 * config/arm/arm_mve.h (vstrbq_s8): Define macro.
4363 (vstrbq_u8): Likewise.
4364 (vstrbq_u16): Likewise.
4365 (vstrbq_scatter_offset_s8): Likewise.
4366 (vstrbq_scatter_offset_u8): Likewise.
4367 (vstrbq_scatter_offset_u16): Likewise.
4368 (vstrbq_s16): Likewise.
4369 (vstrbq_u32): Likewise.
4370 (vstrbq_scatter_offset_s16): Likewise.
4371 (vstrbq_scatter_offset_u32): Likewise.
4372 (vstrbq_s32): Likewise.
4373 (vstrbq_scatter_offset_s32): Likewise.
4374 (vstrwq_scatter_base_s32): Likewise.
4375 (vstrwq_scatter_base_u32): Likewise.
4376 (__arm_vstrbq_scatter_offset_s8): Define intrinsic.
4377 (__arm_vstrbq_scatter_offset_s32): Likewise.
4378 (__arm_vstrbq_scatter_offset_s16): Likewise.
4379 (__arm_vstrbq_scatter_offset_u8): Likewise.
4380 (__arm_vstrbq_scatter_offset_u32): Likewise.
4381 (__arm_vstrbq_scatter_offset_u16): Likewise.
4382 (__arm_vstrbq_s8): Likewise.
4383 (__arm_vstrbq_s32): Likewise.
4384 (__arm_vstrbq_s16): Likewise.
4385 (__arm_vstrbq_u8): Likewise.
4386 (__arm_vstrbq_u32): Likewise.
4387 (__arm_vstrbq_u16): Likewise.
4388 (__arm_vstrwq_scatter_base_s32): Likewise.
4389 (__arm_vstrwq_scatter_base_u32): Likewise.
4390 (vstrbq): Define polymorphic variant.
4391 (vstrbq_scatter_offset): Likewise.
4392 (vstrwq_scatter_base): Likewise.
4393 * config/arm/arm_mve_builtins.def (STRS_QUALIFIERS): Use builtin
4394 qualifier.
4395 (STRU_QUALIFIERS): Likewise.
4396 (STRSS_QUALIFIERS): Likewise.
4397 (STRSU_QUALIFIERS): Likewise.
4398 (STRSBS_QUALIFIERS): Likewise.
4399 (STRSBU_QUALIFIERS): Likewise.
4400 * config/arm/mve.md (MVE_B_ELEM): Define mode attribute iterator.
4401 (VSTRWSBQ): Define iterators.
4402 (VSTRBSOQ): Likewise.
4403 (VSTRBQ): Likewise.
4404 (mve_vstrbq_<supf><mode>): Define RTL pattern.
4405 (mve_vstrbq_scatter_offset_<supf><mode>): Likewise.
4406 (mve_vstrwq_scatter_base_<supf>v4si): Likewise.
4407
4408 2020-03-18 Andre Vieira <andre.simoesdiasvieira@arm.com>
4409 Mihail Ionescu <mihail.ionescu@arm.com>
4410 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
4411
4412 * config/arm/arm_mve.h (vabdq_m_f32): Define macro.
4413 (vabdq_m_f16): Likewise.
4414 (vaddq_m_f32): Likewise.
4415 (vaddq_m_f16): Likewise.
4416 (vaddq_m_n_f32): Likewise.
4417 (vaddq_m_n_f16): Likewise.
4418 (vandq_m_f32): Likewise.
4419 (vandq_m_f16): Likewise.
4420 (vbicq_m_f32): Likewise.
4421 (vbicq_m_f16): Likewise.
4422 (vbrsrq_m_n_f32): Likewise.
4423 (vbrsrq_m_n_f16): Likewise.
4424 (vcaddq_rot270_m_f32): Likewise.
4425 (vcaddq_rot270_m_f16): Likewise.
4426 (vcaddq_rot90_m_f32): Likewise.
4427 (vcaddq_rot90_m_f16): Likewise.
4428 (vcmlaq_m_f32): Likewise.
4429 (vcmlaq_m_f16): Likewise.
4430 (vcmlaq_rot180_m_f32): Likewise.
4431 (vcmlaq_rot180_m_f16): Likewise.
4432 (vcmlaq_rot270_m_f32): Likewise.
4433 (vcmlaq_rot270_m_f16): Likewise.
4434 (vcmlaq_rot90_m_f32): Likewise.
4435 (vcmlaq_rot90_m_f16): Likewise.
4436 (vcmulq_m_f32): Likewise.
4437 (vcmulq_m_f16): Likewise.
4438 (vcmulq_rot180_m_f32): Likewise.
4439 (vcmulq_rot180_m_f16): Likewise.
4440 (vcmulq_rot270_m_f32): Likewise.
4441 (vcmulq_rot270_m_f16): Likewise.
4442 (vcmulq_rot90_m_f32): Likewise.
4443 (vcmulq_rot90_m_f16): Likewise.
4444 (vcvtq_m_n_s32_f32): Likewise.
4445 (vcvtq_m_n_s16_f16): Likewise.
4446 (vcvtq_m_n_u32_f32): Likewise.
4447 (vcvtq_m_n_u16_f16): Likewise.
4448 (veorq_m_f32): Likewise.
4449 (veorq_m_f16): Likewise.
4450 (vfmaq_m_f32): Likewise.
4451 (vfmaq_m_f16): Likewise.
4452 (vfmaq_m_n_f32): Likewise.
4453 (vfmaq_m_n_f16): Likewise.
4454 (vfmasq_m_n_f32): Likewise.
4455 (vfmasq_m_n_f16): Likewise.
4456 (vfmsq_m_f32): Likewise.
4457 (vfmsq_m_f16): Likewise.
4458 (vmaxnmq_m_f32): Likewise.
4459 (vmaxnmq_m_f16): Likewise.
4460 (vminnmq_m_f32): Likewise.
4461 (vminnmq_m_f16): Likewise.
4462 (vmulq_m_f32): Likewise.
4463 (vmulq_m_f16): Likewise.
4464 (vmulq_m_n_f32): Likewise.
4465 (vmulq_m_n_f16): Likewise.
4466 (vornq_m_f32): Likewise.
4467 (vornq_m_f16): Likewise.
4468 (vorrq_m_f32): Likewise.
4469 (vorrq_m_f16): Likewise.
4470 (vsubq_m_f32): Likewise.
4471 (vsubq_m_f16): Likewise.
4472 (vsubq_m_n_f32): Likewise.
4473 (vsubq_m_n_f16): Likewise.
4474 (__attribute__): Likewise.
4475 (__arm_vabdq_m_f32): Likewise.
4476 (__arm_vabdq_m_f16): Likewise.
4477 (__arm_vaddq_m_f32): Likewise.
4478 (__arm_vaddq_m_f16): Likewise.
4479 (__arm_vaddq_m_n_f32): Likewise.
4480 (__arm_vaddq_m_n_f16): Likewise.
4481 (__arm_vandq_m_f32): Likewise.
4482 (__arm_vandq_m_f16): Likewise.
4483 (__arm_vbicq_m_f32): Likewise.
4484 (__arm_vbicq_m_f16): Likewise.
4485 (__arm_vbrsrq_m_n_f32): Likewise.
4486 (__arm_vbrsrq_m_n_f16): Likewise.
4487 (__arm_vcaddq_rot270_m_f32): Likewise.
4488 (__arm_vcaddq_rot270_m_f16): Likewise.
4489 (__arm_vcaddq_rot90_m_f32): Likewise.
4490 (__arm_vcaddq_rot90_m_f16): Likewise.
4491 (__arm_vcmlaq_m_f32): Likewise.
4492 (__arm_vcmlaq_m_f16): Likewise.
4493 (__arm_vcmlaq_rot180_m_f32): Likewise.
4494 (__arm_vcmlaq_rot180_m_f16): Likewise.
4495 (__arm_vcmlaq_rot270_m_f32): Likewise.
4496 (__arm_vcmlaq_rot270_m_f16): Likewise.
4497 (__arm_vcmlaq_rot90_m_f32): Likewise.
4498 (__arm_vcmlaq_rot90_m_f16): Likewise.
4499 (__arm_vcmulq_m_f32): Likewise.
4500 (__arm_vcmulq_m_f16): Likewise.
4501 (__arm_vcmulq_rot180_m_f32): Define intrinsic.
4502 (__arm_vcmulq_rot180_m_f16): Likewise.
4503 (__arm_vcmulq_rot270_m_f32): Likewise.
4504 (__arm_vcmulq_rot270_m_f16): Likewise.
4505 (__arm_vcmulq_rot90_m_f32): Likewise.
4506 (__arm_vcmulq_rot90_m_f16): Likewise.
4507 (__arm_vcvtq_m_n_s32_f32): Likewise.
4508 (__arm_vcvtq_m_n_s16_f16): Likewise.
4509 (__arm_vcvtq_m_n_u32_f32): Likewise.
4510 (__arm_vcvtq_m_n_u16_f16): Likewise.
4511 (__arm_veorq_m_f32): Likewise.
4512 (__arm_veorq_m_f16): Likewise.
4513 (__arm_vfmaq_m_f32): Likewise.
4514 (__arm_vfmaq_m_f16): Likewise.
4515 (__arm_vfmaq_m_n_f32): Likewise.
4516 (__arm_vfmaq_m_n_f16): Likewise.
4517 (__arm_vfmasq_m_n_f32): Likewise.
4518 (__arm_vfmasq_m_n_f16): Likewise.
4519 (__arm_vfmsq_m_f32): Likewise.
4520 (__arm_vfmsq_m_f16): Likewise.
4521 (__arm_vmaxnmq_m_f32): Likewise.
4522 (__arm_vmaxnmq_m_f16): Likewise.
4523 (__arm_vminnmq_m_f32): Likewise.
4524 (__arm_vminnmq_m_f16): Likewise.
4525 (__arm_vmulq_m_f32): Likewise.
4526 (__arm_vmulq_m_f16): Likewise.
4527 (__arm_vmulq_m_n_f32): Likewise.
4528 (__arm_vmulq_m_n_f16): Likewise.
4529 (__arm_vornq_m_f32): Likewise.
4530 (__arm_vornq_m_f16): Likewise.
4531 (__arm_vorrq_m_f32): Likewise.
4532 (__arm_vorrq_m_f16): Likewise.
4533 (__arm_vsubq_m_f32): Likewise.
4534 (__arm_vsubq_m_f16): Likewise.
4535 (__arm_vsubq_m_n_f32): Likewise.
4536 (__arm_vsubq_m_n_f16): Likewise.
4537 (vabdq_m): Define polymorphic variant.
4538 (vaddq_m): Likewise.
4539 (vaddq_m_n): Likewise.
4540 (vandq_m): Likewise.
4541 (vbicq_m): Likewise.
4542 (vbrsrq_m_n): Likewise.
4543 (vcaddq_rot270_m): Likewise.
4544 (vcaddq_rot90_m): Likewise.
4545 (vcmlaq_m): Likewise.
4546 (vcmlaq_rot180_m): Likewise.
4547 (vcmlaq_rot270_m): Likewise.
4548 (vcmlaq_rot90_m): Likewise.
4549 (vcmulq_m): Likewise.
4550 (vcmulq_rot180_m): Likewise.
4551 (vcmulq_rot270_m): Likewise.
4552 (vcmulq_rot90_m): Likewise.
4553 (veorq_m): Likewise.
4554 (vfmaq_m): Likewise.
4555 (vfmaq_m_n): Likewise.
4556 (vfmasq_m_n): Likewise.
4557 (vfmsq_m): Likewise.
4558 (vmaxnmq_m): Likewise.
4559 (vminnmq_m): Likewise.
4560 (vmulq_m): Likewise.
4561 (vmulq_m_n): Likewise.
4562 (vornq_m): Likewise.
4563 (vsubq_m): Likewise.
4564 (vsubq_m_n): Likewise.
4565 (vorrq_m): Likewise.
4566 * config/arm/arm_mve_builtins.def (QUADOP_NONE_NONE_NONE_IMM_UNONE): Use
4567 builtin qualifier.
4568 (QUADOP_NONE_NONE_NONE_NONE_UNONE): Likewise.
4569 (QUADOP_UNONE_UNONE_NONE_IMM_UNONE): Likewise.
4570 * config/arm/mve.md (mve_vabdq_m_f<mode>): Define RTL pattern.
4571 (mve_vaddq_m_f<mode>): Likewise.
4572 (mve_vaddq_m_n_f<mode>): Likewise.
4573 (mve_vandq_m_f<mode>): Likewise.
4574 (mve_vbicq_m_f<mode>): Likewise.
4575 (mve_vbrsrq_m_n_f<mode>): Likewise.
4576 (mve_vcaddq_rot270_m_f<mode>): Likewise.
4577 (mve_vcaddq_rot90_m_f<mode>): Likewise.
4578 (mve_vcmlaq_m_f<mode>): Likewise.
4579 (mve_vcmlaq_rot180_m_f<mode>): Likewise.
4580 (mve_vcmlaq_rot270_m_f<mode>): Likewise.
4581 (mve_vcmlaq_rot90_m_f<mode>): Likewise.
4582 (mve_vcmulq_m_f<mode>): Likewise.
4583 (mve_vcmulq_rot180_m_f<mode>): Likewise.
4584 (mve_vcmulq_rot270_m_f<mode>): Likewise.
4585 (mve_vcmulq_rot90_m_f<mode>): Likewise.
4586 (mve_veorq_m_f<mode>): Likewise.
4587 (mve_vfmaq_m_f<mode>): Likewise.
4588 (mve_vfmaq_m_n_f<mode>): Likewise.
4589 (mve_vfmasq_m_n_f<mode>): Likewise.
4590 (mve_vfmsq_m_f<mode>): Likewise.
4591 (mve_vmaxnmq_m_f<mode>): Likewise.
4592 (mve_vminnmq_m_f<mode>): Likewise.
4593 (mve_vmulq_m_f<mode>): Likewise.
4594 (mve_vmulq_m_n_f<mode>): Likewise.
4595 (mve_vornq_m_f<mode>): Likewise.
4596 (mve_vorrq_m_f<mode>): Likewise.
4597 (mve_vsubq_m_f<mode>): Likewise.
4598 (mve_vsubq_m_n_f<mode>): Likewise.
4599
4600 2020-03-18 Andre Vieira <andre.simoesdiasvieira@arm.com>
4601 Mihail Ionescu <mihail.ionescu@arm.com>
4602 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
4603
4604 * config/arm/arm-protos.h (arm_mve_immediate_check):
4605 * config/arm/arm.c (arm_mve_immediate_check): Define fuction to check
4606 mode and interger value.
4607 * config/arm/arm_mve.h (vmlaldavaq_p_s32): Define macro.
4608 (vmlaldavaq_p_s16): Likewise.
4609 (vmlaldavaq_p_u32): Likewise.
4610 (vmlaldavaq_p_u16): Likewise.
4611 (vmlaldavaxq_p_s32): Likewise.
4612 (vmlaldavaxq_p_s16): Likewise.
4613 (vmlaldavaxq_p_u32): Likewise.
4614 (vmlaldavaxq_p_u16): Likewise.
4615 (vmlsldavaq_p_s32): Likewise.
4616 (vmlsldavaq_p_s16): Likewise.
4617 (vmlsldavaxq_p_s32): Likewise.
4618 (vmlsldavaxq_p_s16): Likewise.
4619 (vmullbq_poly_m_p8): Likewise.
4620 (vmullbq_poly_m_p16): Likewise.
4621 (vmulltq_poly_m_p8): Likewise.
4622 (vmulltq_poly_m_p16): Likewise.
4623 (vqdmullbq_m_n_s32): Likewise.
4624 (vqdmullbq_m_n_s16): Likewise.
4625 (vqdmullbq_m_s32): Likewise.
4626 (vqdmullbq_m_s16): Likewise.
4627 (vqdmulltq_m_n_s32): Likewise.
4628 (vqdmulltq_m_n_s16): Likewise.
4629 (vqdmulltq_m_s32): Likewise.
4630 (vqdmulltq_m_s16): Likewise.
4631 (vqrshrnbq_m_n_s32): Likewise.
4632 (vqrshrnbq_m_n_s16): Likewise.
4633 (vqrshrnbq_m_n_u32): Likewise.
4634 (vqrshrnbq_m_n_u16): Likewise.
4635 (vqrshrntq_m_n_s32): Likewise.
4636 (vqrshrntq_m_n_s16): Likewise.
4637 (vqrshrntq_m_n_u32): Likewise.
4638 (vqrshrntq_m_n_u16): Likewise.
4639 (vqrshrunbq_m_n_s32): Likewise.
4640 (vqrshrunbq_m_n_s16): Likewise.
4641 (vqrshruntq_m_n_s32): Likewise.
4642 (vqrshruntq_m_n_s16): Likewise.
4643 (vqshrnbq_m_n_s32): Likewise.
4644 (vqshrnbq_m_n_s16): Likewise.
4645 (vqshrnbq_m_n_u32): Likewise.
4646 (vqshrnbq_m_n_u16): Likewise.
4647 (vqshrntq_m_n_s32): Likewise.
4648 (vqshrntq_m_n_s16): Likewise.
4649 (vqshrntq_m_n_u32): Likewise.
4650 (vqshrntq_m_n_u16): Likewise.
4651 (vqshrunbq_m_n_s32): Likewise.
4652 (vqshrunbq_m_n_s16): Likewise.
4653 (vqshruntq_m_n_s32): Likewise.
4654 (vqshruntq_m_n_s16): Likewise.
4655 (vrmlaldavhaq_p_s32): Likewise.
4656 (vrmlaldavhaq_p_u32): Likewise.
4657 (vrmlaldavhaxq_p_s32): Likewise.
4658 (vrmlsldavhaq_p_s32): Likewise.
4659 (vrmlsldavhaxq_p_s32): Likewise.
4660 (vrshrnbq_m_n_s32): Likewise.
4661 (vrshrnbq_m_n_s16): Likewise.
4662 (vrshrnbq_m_n_u32): Likewise.
4663 (vrshrnbq_m_n_u16): Likewise.
4664 (vrshrntq_m_n_s32): Likewise.
4665 (vrshrntq_m_n_s16): Likewise.
4666 (vrshrntq_m_n_u32): Likewise.
4667 (vrshrntq_m_n_u16): Likewise.
4668 (vshllbq_m_n_s8): Likewise.
4669 (vshllbq_m_n_s16): Likewise.
4670 (vshllbq_m_n_u8): Likewise.
4671 (vshllbq_m_n_u16): Likewise.
4672 (vshlltq_m_n_s8): Likewise.
4673 (vshlltq_m_n_s16): Likewise.
4674 (vshlltq_m_n_u8): Likewise.
4675 (vshlltq_m_n_u16): Likewise.
4676 (vshrnbq_m_n_s32): Likewise.
4677 (vshrnbq_m_n_s16): Likewise.
4678 (vshrnbq_m_n_u32): Likewise.
4679 (vshrnbq_m_n_u16): Likewise.
4680 (vshrntq_m_n_s32): Likewise.
4681 (vshrntq_m_n_s16): Likewise.
4682 (vshrntq_m_n_u32): Likewise.
4683 (vshrntq_m_n_u16): Likewise.
4684 (__arm_vmlaldavaq_p_s32): Define intrinsic.
4685 (__arm_vmlaldavaq_p_s16): Likewise.
4686 (__arm_vmlaldavaq_p_u32): Likewise.
4687 (__arm_vmlaldavaq_p_u16): Likewise.
4688 (__arm_vmlaldavaxq_p_s32): Likewise.
4689 (__arm_vmlaldavaxq_p_s16): Likewise.
4690 (__arm_vmlaldavaxq_p_u32): Likewise.
4691 (__arm_vmlaldavaxq_p_u16): Likewise.
4692 (__arm_vmlsldavaq_p_s32): Likewise.
4693 (__arm_vmlsldavaq_p_s16): Likewise.
4694 (__arm_vmlsldavaxq_p_s32): Likewise.
4695 (__arm_vmlsldavaxq_p_s16): Likewise.
4696 (__arm_vmullbq_poly_m_p8): Likewise.
4697 (__arm_vmullbq_poly_m_p16): Likewise.
4698 (__arm_vmulltq_poly_m_p8): Likewise.
4699 (__arm_vmulltq_poly_m_p16): Likewise.
4700 (__arm_vqdmullbq_m_n_s32): Likewise.
4701 (__arm_vqdmullbq_m_n_s16): Likewise.
4702 (__arm_vqdmullbq_m_s32): Likewise.
4703 (__arm_vqdmullbq_m_s16): Likewise.
4704 (__arm_vqdmulltq_m_n_s32): Likewise.
4705 (__arm_vqdmulltq_m_n_s16): Likewise.
4706 (__arm_vqdmulltq_m_s32): Likewise.
4707 (__arm_vqdmulltq_m_s16): Likewise.
4708 (__arm_vqrshrnbq_m_n_s32): Likewise.
4709 (__arm_vqrshrnbq_m_n_s16): Likewise.
4710 (__arm_vqrshrnbq_m_n_u32): Likewise.
4711 (__arm_vqrshrnbq_m_n_u16): Likewise.
4712 (__arm_vqrshrntq_m_n_s32): Likewise.
4713 (__arm_vqrshrntq_m_n_s16): Likewise.
4714 (__arm_vqrshrntq_m_n_u32): Likewise.
4715 (__arm_vqrshrntq_m_n_u16): Likewise.
4716 (__arm_vqrshrunbq_m_n_s32): Likewise.
4717 (__arm_vqrshrunbq_m_n_s16): Likewise.
4718 (__arm_vqrshruntq_m_n_s32): Likewise.
4719 (__arm_vqrshruntq_m_n_s16): Likewise.
4720 (__arm_vqshrnbq_m_n_s32): Likewise.
4721 (__arm_vqshrnbq_m_n_s16): Likewise.
4722 (__arm_vqshrnbq_m_n_u32): Likewise.
4723 (__arm_vqshrnbq_m_n_u16): Likewise.
4724 (__arm_vqshrntq_m_n_s32): Likewise.
4725 (__arm_vqshrntq_m_n_s16): Likewise.
4726 (__arm_vqshrntq_m_n_u32): Likewise.
4727 (__arm_vqshrntq_m_n_u16): Likewise.
4728 (__arm_vqshrunbq_m_n_s32): Likewise.
4729 (__arm_vqshrunbq_m_n_s16): Likewise.
4730 (__arm_vqshruntq_m_n_s32): Likewise.
4731 (__arm_vqshruntq_m_n_s16): Likewise.
4732 (__arm_vrmlaldavhaq_p_s32): Likewise.
4733 (__arm_vrmlaldavhaq_p_u32): Likewise.
4734 (__arm_vrmlaldavhaxq_p_s32): Likewise.
4735 (__arm_vrmlsldavhaq_p_s32): Likewise.
4736 (__arm_vrmlsldavhaxq_p_s32): Likewise.
4737 (__arm_vrshrnbq_m_n_s32): Likewise.
4738 (__arm_vrshrnbq_m_n_s16): Likewise.
4739 (__arm_vrshrnbq_m_n_u32): Likewise.
4740 (__arm_vrshrnbq_m_n_u16): Likewise.
4741 (__arm_vrshrntq_m_n_s32): Likewise.
4742 (__arm_vrshrntq_m_n_s16): Likewise.
4743 (__arm_vrshrntq_m_n_u32): Likewise.
4744 (__arm_vrshrntq_m_n_u16): Likewise.
4745 (__arm_vshllbq_m_n_s8): Likewise.
4746 (__arm_vshllbq_m_n_s16): Likewise.
4747 (__arm_vshllbq_m_n_u8): Likewise.
4748 (__arm_vshllbq_m_n_u16): Likewise.
4749 (__arm_vshlltq_m_n_s8): Likewise.
4750 (__arm_vshlltq_m_n_s16): Likewise.
4751 (__arm_vshlltq_m_n_u8): Likewise.
4752 (__arm_vshlltq_m_n_u16): Likewise.
4753 (__arm_vshrnbq_m_n_s32): Likewise.
4754 (__arm_vshrnbq_m_n_s16): Likewise.
4755 (__arm_vshrnbq_m_n_u32): Likewise.
4756 (__arm_vshrnbq_m_n_u16): Likewise.
4757 (__arm_vshrntq_m_n_s32): Likewise.
4758 (__arm_vshrntq_m_n_s16): Likewise.
4759 (__arm_vshrntq_m_n_u32): Likewise.
4760 (__arm_vshrntq_m_n_u16): Likewise.
4761 (vmullbq_poly_m): Define polymorphic variant.
4762 (vmulltq_poly_m): Likewise.
4763 (vshllbq_m): Likewise.
4764 (vshrntq_m_n): Likewise.
4765 (vshrnbq_m_n): Likewise.
4766 (vshlltq_m_n): Likewise.
4767 (vshllbq_m_n): Likewise.
4768 (vrshrntq_m_n): Likewise.
4769 (vrshrnbq_m_n): Likewise.
4770 (vqshruntq_m_n): Likewise.
4771 (vqshrunbq_m_n): Likewise.
4772 (vqdmullbq_m_n): Likewise.
4773 (vqdmullbq_m): Likewise.
4774 (vqdmulltq_m_n): Likewise.
4775 (vqdmulltq_m): Likewise.
4776 (vqrshrnbq_m_n): Likewise.
4777 (vqrshrntq_m_n): Likewise.
4778 (vqrshrunbq_m_n): Likewise.
4779 (vqrshruntq_m_n): Likewise.
4780 (vqshrnbq_m_n): Likewise.
4781 (vqshrntq_m_n): Likewise.
4782 * config/arm/arm_mve_builtins.def (QUADOP_NONE_NONE_NONE_IMM_UNONE): Use
4783 builtin qualifiers.
4784 (QUADOP_NONE_NONE_NONE_NONE_UNONE): Likewise.
4785 (QUADOP_UNONE_UNONE_NONE_IMM_UNONE): Likewise.
4786 (QUADOP_UNONE_UNONE_UNONE_IMM_UNONE): Likewise.
4787 (QUADOP_UNONE_UNONE_UNONE_UNONE_UNONE): Likewise.
4788 * config/arm/mve.md (VMLALDAVAQ_P): Define iterator.
4789 (VMLALDAVAXQ_P): Likewise.
4790 (VQRSHRNBQ_M_N): Likewise.
4791 (VQRSHRNTQ_M_N): Likewise.
4792 (VQSHRNBQ_M_N): Likewise.
4793 (VQSHRNTQ_M_N): Likewise.
4794 (VRSHRNBQ_M_N): Likewise.
4795 (VRSHRNTQ_M_N): Likewise.
4796 (VSHLLBQ_M_N): Likewise.
4797 (VSHLLTQ_M_N): Likewise.
4798 (VSHRNBQ_M_N): Likewise.
4799 (VSHRNTQ_M_N): Likewise.
4800 (mve_vmlaldavaq_p_<supf><mode>): Define RTL pattern.
4801 (mve_vmlaldavaxq_p_<supf><mode>): Likewise.
4802 (mve_vqrshrnbq_m_n_<supf><mode>): Likewise.
4803 (mve_vqrshrntq_m_n_<supf><mode>): Likewise.
4804 (mve_vqshrnbq_m_n_<supf><mode>): Likewise.
4805 (mve_vqshrntq_m_n_<supf><mode>): Likewise.
4806 (mve_vrmlaldavhaq_p_sv4si): Likewise.
4807 (mve_vrshrnbq_m_n_<supf><mode>): Likewise.
4808 (mve_vrshrntq_m_n_<supf><mode>): Likewise.
4809 (mve_vshllbq_m_n_<supf><mode>): Likewise.
4810 (mve_vshlltq_m_n_<supf><mode>): Likewise.
4811 (mve_vshrnbq_m_n_<supf><mode>): Likewise.
4812 (mve_vshrntq_m_n_<supf><mode>): Likewise.
4813 (mve_vmlsldavaq_p_s<mode>): Likewise.
4814 (mve_vmlsldavaxq_p_s<mode>): Likewise.
4815 (mve_vmullbq_poly_m_p<mode>): Likewise.
4816 (mve_vmulltq_poly_m_p<mode>): Likewise.
4817 (mve_vqdmullbq_m_n_s<mode>): Likewise.
4818 (mve_vqdmullbq_m_s<mode>): Likewise.
4819 (mve_vqdmulltq_m_n_s<mode>): Likewise.
4820 (mve_vqdmulltq_m_s<mode>): Likewise.
4821 (mve_vqrshrunbq_m_n_s<mode>): Likewise.
4822 (mve_vqrshruntq_m_n_s<mode>): Likewise.
4823 (mve_vqshrunbq_m_n_s<mode>): Likewise.
4824 (mve_vqshruntq_m_n_s<mode>): Likewise.
4825 (mve_vrmlaldavhaq_p_uv4si): Likewise.
4826 (mve_vrmlaldavhaxq_p_sv4si): Likewise.
4827 (mve_vrmlsldavhaq_p_sv4si): Likewise.
4828 (mve_vrmlsldavhaxq_p_sv4si): Likewise.
4829
4830 2020-03-18 Andre Vieira <andre.simoesdiasvieira@arm.com>
4831 Mihail Ionescu <mihail.ionescu@arm.com>
4832 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
4833
4834 * config/arm/arm_mve.h (vabdq_m_s8): Define macro.
4835 (vabdq_m_s32): Likewise.
4836 (vabdq_m_s16): Likewise.
4837 (vabdq_m_u8): Likewise.
4838 (vabdq_m_u32): Likewise.
4839 (vabdq_m_u16): Likewise.
4840 (vaddq_m_n_s8): Likewise.
4841 (vaddq_m_n_s32): Likewise.
4842 (vaddq_m_n_s16): Likewise.
4843 (vaddq_m_n_u8): Likewise.
4844 (vaddq_m_n_u32): Likewise.
4845 (vaddq_m_n_u16): Likewise.
4846 (vaddq_m_s8): Likewise.
4847 (vaddq_m_s32): Likewise.
4848 (vaddq_m_s16): Likewise.
4849 (vaddq_m_u8): Likewise.
4850 (vaddq_m_u32): Likewise.
4851 (vaddq_m_u16): Likewise.
4852 (vandq_m_s8): Likewise.
4853 (vandq_m_s32): Likewise.
4854 (vandq_m_s16): Likewise.
4855 (vandq_m_u8): Likewise.
4856 (vandq_m_u32): Likewise.
4857 (vandq_m_u16): Likewise.
4858 (vbicq_m_s8): Likewise.
4859 (vbicq_m_s32): Likewise.
4860 (vbicq_m_s16): Likewise.
4861 (vbicq_m_u8): Likewise.
4862 (vbicq_m_u32): Likewise.
4863 (vbicq_m_u16): Likewise.
4864 (vbrsrq_m_n_s8): Likewise.
4865 (vbrsrq_m_n_s32): Likewise.
4866 (vbrsrq_m_n_s16): Likewise.
4867 (vbrsrq_m_n_u8): Likewise.
4868 (vbrsrq_m_n_u32): Likewise.
4869 (vbrsrq_m_n_u16): Likewise.
4870 (vcaddq_rot270_m_s8): Likewise.
4871 (vcaddq_rot270_m_s32): Likewise.
4872 (vcaddq_rot270_m_s16): Likewise.
4873 (vcaddq_rot270_m_u8): Likewise.
4874 (vcaddq_rot270_m_u32): Likewise.
4875 (vcaddq_rot270_m_u16): Likewise.
4876 (vcaddq_rot90_m_s8): Likewise.
4877 (vcaddq_rot90_m_s32): Likewise.
4878 (vcaddq_rot90_m_s16): Likewise.
4879 (vcaddq_rot90_m_u8): Likewise.
4880 (vcaddq_rot90_m_u32): Likewise.
4881 (vcaddq_rot90_m_u16): Likewise.
4882 (veorq_m_s8): Likewise.
4883 (veorq_m_s32): Likewise.
4884 (veorq_m_s16): Likewise.
4885 (veorq_m_u8): Likewise.
4886 (veorq_m_u32): Likewise.
4887 (veorq_m_u16): Likewise.
4888 (vhaddq_m_n_s8): Likewise.
4889 (vhaddq_m_n_s32): Likewise.
4890 (vhaddq_m_n_s16): Likewise.
4891 (vhaddq_m_n_u8): Likewise.
4892 (vhaddq_m_n_u32): Likewise.
4893 (vhaddq_m_n_u16): Likewise.
4894 (vhaddq_m_s8): Likewise.
4895 (vhaddq_m_s32): Likewise.
4896 (vhaddq_m_s16): Likewise.
4897 (vhaddq_m_u8): Likewise.
4898 (vhaddq_m_u32): Likewise.
4899 (vhaddq_m_u16): Likewise.
4900 (vhcaddq_rot270_m_s8): Likewise.
4901 (vhcaddq_rot270_m_s32): Likewise.
4902 (vhcaddq_rot270_m_s16): Likewise.
4903 (vhcaddq_rot90_m_s8): Likewise.
4904 (vhcaddq_rot90_m_s32): Likewise.
4905 (vhcaddq_rot90_m_s16): Likewise.
4906 (vhsubq_m_n_s8): Likewise.
4907 (vhsubq_m_n_s32): Likewise.
4908 (vhsubq_m_n_s16): Likewise.
4909 (vhsubq_m_n_u8): Likewise.
4910 (vhsubq_m_n_u32): Likewise.
4911 (vhsubq_m_n_u16): Likewise.
4912 (vhsubq_m_s8): Likewise.
4913 (vhsubq_m_s32): Likewise.
4914 (vhsubq_m_s16): Likewise.
4915 (vhsubq_m_u8): Likewise.
4916 (vhsubq_m_u32): Likewise.
4917 (vhsubq_m_u16): Likewise.
4918 (vmaxq_m_s8): Likewise.
4919 (vmaxq_m_s32): Likewise.
4920 (vmaxq_m_s16): Likewise.
4921 (vmaxq_m_u8): Likewise.
4922 (vmaxq_m_u32): Likewise.
4923 (vmaxq_m_u16): Likewise.
4924 (vminq_m_s8): Likewise.
4925 (vminq_m_s32): Likewise.
4926 (vminq_m_s16): Likewise.
4927 (vminq_m_u8): Likewise.
4928 (vminq_m_u32): Likewise.
4929 (vminq_m_u16): Likewise.
4930 (vmladavaq_p_s8): Likewise.
4931 (vmladavaq_p_s32): Likewise.
4932 (vmladavaq_p_s16): Likewise.
4933 (vmladavaq_p_u8): Likewise.
4934 (vmladavaq_p_u32): Likewise.
4935 (vmladavaq_p_u16): Likewise.
4936 (vmladavaxq_p_s8): Likewise.
4937 (vmladavaxq_p_s32): Likewise.
4938 (vmladavaxq_p_s16): Likewise.
4939 (vmlaq_m_n_s8): Likewise.
4940 (vmlaq_m_n_s32): Likewise.
4941 (vmlaq_m_n_s16): Likewise.
4942 (vmlaq_m_n_u8): Likewise.
4943 (vmlaq_m_n_u32): Likewise.
4944 (vmlaq_m_n_u16): Likewise.
4945 (vmlasq_m_n_s8): Likewise.
4946 (vmlasq_m_n_s32): Likewise.
4947 (vmlasq_m_n_s16): Likewise.
4948 (vmlasq_m_n_u8): Likewise.
4949 (vmlasq_m_n_u32): Likewise.
4950 (vmlasq_m_n_u16): Likewise.
4951 (vmlsdavaq_p_s8): Likewise.
4952 (vmlsdavaq_p_s32): Likewise.
4953 (vmlsdavaq_p_s16): Likewise.
4954 (vmlsdavaxq_p_s8): Likewise.
4955 (vmlsdavaxq_p_s32): Likewise.
4956 (vmlsdavaxq_p_s16): Likewise.
4957 (vmulhq_m_s8): Likewise.
4958 (vmulhq_m_s32): Likewise.
4959 (vmulhq_m_s16): Likewise.
4960 (vmulhq_m_u8): Likewise.
4961 (vmulhq_m_u32): Likewise.
4962 (vmulhq_m_u16): Likewise.
4963 (vmullbq_int_m_s8): Likewise.
4964 (vmullbq_int_m_s32): Likewise.
4965 (vmullbq_int_m_s16): Likewise.
4966 (vmullbq_int_m_u8): Likewise.
4967 (vmullbq_int_m_u32): Likewise.
4968 (vmullbq_int_m_u16): Likewise.
4969 (vmulltq_int_m_s8): Likewise.
4970 (vmulltq_int_m_s32): Likewise.
4971 (vmulltq_int_m_s16): Likewise.
4972 (vmulltq_int_m_u8): Likewise.
4973 (vmulltq_int_m_u32): Likewise.
4974 (vmulltq_int_m_u16): Likewise.
4975 (vmulq_m_n_s8): Likewise.
4976 (vmulq_m_n_s32): Likewise.
4977 (vmulq_m_n_s16): Likewise.
4978 (vmulq_m_n_u8): Likewise.
4979 (vmulq_m_n_u32): Likewise.
4980 (vmulq_m_n_u16): Likewise.
4981 (vmulq_m_s8): Likewise.
4982 (vmulq_m_s32): Likewise.
4983 (vmulq_m_s16): Likewise.
4984 (vmulq_m_u8): Likewise.
4985 (vmulq_m_u32): Likewise.
4986 (vmulq_m_u16): Likewise.
4987 (vornq_m_s8): Likewise.
4988 (vornq_m_s32): Likewise.
4989 (vornq_m_s16): Likewise.
4990 (vornq_m_u8): Likewise.
4991 (vornq_m_u32): Likewise.
4992 (vornq_m_u16): Likewise.
4993 (vorrq_m_s8): Likewise.
4994 (vorrq_m_s32): Likewise.
4995 (vorrq_m_s16): Likewise.
4996 (vorrq_m_u8): Likewise.
4997 (vorrq_m_u32): Likewise.
4998 (vorrq_m_u16): Likewise.
4999 (vqaddq_m_n_s8): Likewise.
5000 (vqaddq_m_n_s32): Likewise.
5001 (vqaddq_m_n_s16): Likewise.
5002 (vqaddq_m_n_u8): Likewise.
5003 (vqaddq_m_n_u32): Likewise.
5004 (vqaddq_m_n_u16): Likewise.
5005 (vqaddq_m_s8): Likewise.
5006 (vqaddq_m_s32): Likewise.
5007 (vqaddq_m_s16): Likewise.
5008 (vqaddq_m_u8): Likewise.
5009 (vqaddq_m_u32): Likewise.
5010 (vqaddq_m_u16): Likewise.
5011 (vqdmladhq_m_s8): Likewise.
5012 (vqdmladhq_m_s32): Likewise.
5013 (vqdmladhq_m_s16): Likewise.
5014 (vqdmladhxq_m_s8): Likewise.
5015 (vqdmladhxq_m_s32): Likewise.
5016 (vqdmladhxq_m_s16): Likewise.
5017 (vqdmlahq_m_n_s8): Likewise.
5018 (vqdmlahq_m_n_s32): Likewise.
5019 (vqdmlahq_m_n_s16): Likewise.
5020 (vqdmlahq_m_n_u8): Likewise.
5021 (vqdmlahq_m_n_u32): Likewise.
5022 (vqdmlahq_m_n_u16): Likewise.
5023 (vqdmlsdhq_m_s8): Likewise.
5024 (vqdmlsdhq_m_s32): Likewise.
5025 (vqdmlsdhq_m_s16): Likewise.
5026 (vqdmlsdhxq_m_s8): Likewise.
5027 (vqdmlsdhxq_m_s32): Likewise.
5028 (vqdmlsdhxq_m_s16): Likewise.
5029 (vqdmulhq_m_n_s8): Likewise.
5030 (vqdmulhq_m_n_s32): Likewise.
5031 (vqdmulhq_m_n_s16): Likewise.
5032 (vqdmulhq_m_s8): Likewise.
5033 (vqdmulhq_m_s32): Likewise.
5034 (vqdmulhq_m_s16): Likewise.
5035 (vqrdmladhq_m_s8): Likewise.
5036 (vqrdmladhq_m_s32): Likewise.
5037 (vqrdmladhq_m_s16): Likewise.
5038 (vqrdmladhxq_m_s8): Likewise.
5039 (vqrdmladhxq_m_s32): Likewise.
5040 (vqrdmladhxq_m_s16): Likewise.
5041 (vqrdmlahq_m_n_s8): Likewise.
5042 (vqrdmlahq_m_n_s32): Likewise.
5043 (vqrdmlahq_m_n_s16): Likewise.
5044 (vqrdmlahq_m_n_u8): Likewise.
5045 (vqrdmlahq_m_n_u32): Likewise.
5046 (vqrdmlahq_m_n_u16): Likewise.
5047 (vqrdmlashq_m_n_s8): Likewise.
5048 (vqrdmlashq_m_n_s32): Likewise.
5049 (vqrdmlashq_m_n_s16): Likewise.
5050 (vqrdmlashq_m_n_u8): Likewise.
5051 (vqrdmlashq_m_n_u32): Likewise.
5052 (vqrdmlashq_m_n_u16): Likewise.
5053 (vqrdmlsdhq_m_s8): Likewise.
5054 (vqrdmlsdhq_m_s32): Likewise.
5055 (vqrdmlsdhq_m_s16): Likewise.
5056 (vqrdmlsdhxq_m_s8): Likewise.
5057 (vqrdmlsdhxq_m_s32): Likewise.
5058 (vqrdmlsdhxq_m_s16): Likewise.
5059 (vqrdmulhq_m_n_s8): Likewise.
5060 (vqrdmulhq_m_n_s32): Likewise.
5061 (vqrdmulhq_m_n_s16): Likewise.
5062 (vqrdmulhq_m_s8): Likewise.
5063 (vqrdmulhq_m_s32): Likewise.
5064 (vqrdmulhq_m_s16): Likewise.
5065 (vqrshlq_m_s8): Likewise.
5066 (vqrshlq_m_s32): Likewise.
5067 (vqrshlq_m_s16): Likewise.
5068 (vqrshlq_m_u8): Likewise.
5069 (vqrshlq_m_u32): Likewise.
5070 (vqrshlq_m_u16): Likewise.
5071 (vqshlq_m_n_s8): Likewise.
5072 (vqshlq_m_n_s32): Likewise.
5073 (vqshlq_m_n_s16): Likewise.
5074 (vqshlq_m_n_u8): Likewise.
5075 (vqshlq_m_n_u32): Likewise.
5076 (vqshlq_m_n_u16): Likewise.
5077 (vqshlq_m_s8): Likewise.
5078 (vqshlq_m_s32): Likewise.
5079 (vqshlq_m_s16): Likewise.
5080 (vqshlq_m_u8): Likewise.
5081 (vqshlq_m_u32): Likewise.
5082 (vqshlq_m_u16): Likewise.
5083 (vqsubq_m_n_s8): Likewise.
5084 (vqsubq_m_n_s32): Likewise.
5085 (vqsubq_m_n_s16): Likewise.
5086 (vqsubq_m_n_u8): Likewise.
5087 (vqsubq_m_n_u32): Likewise.
5088 (vqsubq_m_n_u16): Likewise.
5089 (vqsubq_m_s8): Likewise.
5090 (vqsubq_m_s32): Likewise.
5091 (vqsubq_m_s16): Likewise.
5092 (vqsubq_m_u8): Likewise.
5093 (vqsubq_m_u32): Likewise.
5094 (vqsubq_m_u16): Likewise.
5095 (vrhaddq_m_s8): Likewise.
5096 (vrhaddq_m_s32): Likewise.
5097 (vrhaddq_m_s16): Likewise.
5098 (vrhaddq_m_u8): Likewise.
5099 (vrhaddq_m_u32): Likewise.
5100 (vrhaddq_m_u16): Likewise.
5101 (vrmulhq_m_s8): Likewise.
5102 (vrmulhq_m_s32): Likewise.
5103 (vrmulhq_m_s16): Likewise.
5104 (vrmulhq_m_u8): Likewise.
5105 (vrmulhq_m_u32): Likewise.
5106 (vrmulhq_m_u16): Likewise.
5107 (vrshlq_m_s8): Likewise.
5108 (vrshlq_m_s32): Likewise.
5109 (vrshlq_m_s16): Likewise.
5110 (vrshlq_m_u8): Likewise.
5111 (vrshlq_m_u32): Likewise.
5112 (vrshlq_m_u16): Likewise.
5113 (vrshrq_m_n_s8): Likewise.
5114 (vrshrq_m_n_s32): Likewise.
5115 (vrshrq_m_n_s16): Likewise.
5116 (vrshrq_m_n_u8): Likewise.
5117 (vrshrq_m_n_u32): Likewise.
5118 (vrshrq_m_n_u16): Likewise.
5119 (vshlq_m_n_s8): Likewise.
5120 (vshlq_m_n_s32): Likewise.
5121 (vshlq_m_n_s16): Likewise.
5122 (vshlq_m_n_u8): Likewise.
5123 (vshlq_m_n_u32): Likewise.
5124 (vshlq_m_n_u16): Likewise.
5125 (vshrq_m_n_s8): Likewise.
5126 (vshrq_m_n_s32): Likewise.
5127 (vshrq_m_n_s16): Likewise.
5128 (vshrq_m_n_u8): Likewise.
5129 (vshrq_m_n_u32): Likewise.
5130 (vshrq_m_n_u16): Likewise.
5131 (vsliq_m_n_s8): Likewise.
5132 (vsliq_m_n_s32): Likewise.
5133 (vsliq_m_n_s16): Likewise.
5134 (vsliq_m_n_u8): Likewise.
5135 (vsliq_m_n_u32): Likewise.
5136 (vsliq_m_n_u16): Likewise.
5137 (vsubq_m_n_s8): Likewise.
5138 (vsubq_m_n_s32): Likewise.
5139 (vsubq_m_n_s16): Likewise.
5140 (vsubq_m_n_u8): Likewise.
5141 (vsubq_m_n_u32): Likewise.
5142 (vsubq_m_n_u16): Likewise.
5143 (__arm_vabdq_m_s8): Define intrinsic.
5144 (__arm_vabdq_m_s32): Likewise.
5145 (__arm_vabdq_m_s16): Likewise.
5146 (__arm_vabdq_m_u8): Likewise.
5147 (__arm_vabdq_m_u32): Likewise.
5148 (__arm_vabdq_m_u16): Likewise.
5149 (__arm_vaddq_m_n_s8): Likewise.
5150 (__arm_vaddq_m_n_s32): Likewise.
5151 (__arm_vaddq_m_n_s16): Likewise.
5152 (__arm_vaddq_m_n_u8): Likewise.
5153 (__arm_vaddq_m_n_u32): Likewise.
5154 (__arm_vaddq_m_n_u16): Likewise.
5155 (__arm_vaddq_m_s8): Likewise.
5156 (__arm_vaddq_m_s32): Likewise.
5157 (__arm_vaddq_m_s16): Likewise.
5158 (__arm_vaddq_m_u8): Likewise.
5159 (__arm_vaddq_m_u32): Likewise.
5160 (__arm_vaddq_m_u16): Likewise.
5161 (__arm_vandq_m_s8): Likewise.
5162 (__arm_vandq_m_s32): Likewise.
5163 (__arm_vandq_m_s16): Likewise.
5164 (__arm_vandq_m_u8): Likewise.
5165 (__arm_vandq_m_u32): Likewise.
5166 (__arm_vandq_m_u16): Likewise.
5167 (__arm_vbicq_m_s8): Likewise.
5168 (__arm_vbicq_m_s32): Likewise.
5169 (__arm_vbicq_m_s16): Likewise.
5170 (__arm_vbicq_m_u8): Likewise.
5171 (__arm_vbicq_m_u32): Likewise.
5172 (__arm_vbicq_m_u16): Likewise.
5173 (__arm_vbrsrq_m_n_s8): Likewise.
5174 (__arm_vbrsrq_m_n_s32): Likewise.
5175 (__arm_vbrsrq_m_n_s16): Likewise.
5176 (__arm_vbrsrq_m_n_u8): Likewise.
5177 (__arm_vbrsrq_m_n_u32): Likewise.
5178 (__arm_vbrsrq_m_n_u16): Likewise.
5179 (__arm_vcaddq_rot270_m_s8): Likewise.
5180 (__arm_vcaddq_rot270_m_s32): Likewise.
5181 (__arm_vcaddq_rot270_m_s16): Likewise.
5182 (__arm_vcaddq_rot270_m_u8): Likewise.
5183 (__arm_vcaddq_rot270_m_u32): Likewise.
5184 (__arm_vcaddq_rot270_m_u16): Likewise.
5185 (__arm_vcaddq_rot90_m_s8): Likewise.
5186 (__arm_vcaddq_rot90_m_s32): Likewise.
5187 (__arm_vcaddq_rot90_m_s16): Likewise.
5188 (__arm_vcaddq_rot90_m_u8): Likewise.
5189 (__arm_vcaddq_rot90_m_u32): Likewise.
5190 (__arm_vcaddq_rot90_m_u16): Likewise.
5191 (__arm_veorq_m_s8): Likewise.
5192 (__arm_veorq_m_s32): Likewise.
5193 (__arm_veorq_m_s16): Likewise.
5194 (__arm_veorq_m_u8): Likewise.
5195 (__arm_veorq_m_u32): Likewise.
5196 (__arm_veorq_m_u16): Likewise.
5197 (__arm_vhaddq_m_n_s8): Likewise.
5198 (__arm_vhaddq_m_n_s32): Likewise.
5199 (__arm_vhaddq_m_n_s16): Likewise.
5200 (__arm_vhaddq_m_n_u8): Likewise.
5201 (__arm_vhaddq_m_n_u32): Likewise.
5202 (__arm_vhaddq_m_n_u16): Likewise.
5203 (__arm_vhaddq_m_s8): Likewise.
5204 (__arm_vhaddq_m_s32): Likewise.
5205 (__arm_vhaddq_m_s16): Likewise.
5206 (__arm_vhaddq_m_u8): Likewise.
5207 (__arm_vhaddq_m_u32): Likewise.
5208 (__arm_vhaddq_m_u16): Likewise.
5209 (__arm_vhcaddq_rot270_m_s8): Likewise.
5210 (__arm_vhcaddq_rot270_m_s32): Likewise.
5211 (__arm_vhcaddq_rot270_m_s16): Likewise.
5212 (__arm_vhcaddq_rot90_m_s8): Likewise.
5213 (__arm_vhcaddq_rot90_m_s32): Likewise.
5214 (__arm_vhcaddq_rot90_m_s16): Likewise.
5215 (__arm_vhsubq_m_n_s8): Likewise.
5216 (__arm_vhsubq_m_n_s32): Likewise.
5217 (__arm_vhsubq_m_n_s16): Likewise.
5218 (__arm_vhsubq_m_n_u8): Likewise.
5219 (__arm_vhsubq_m_n_u32): Likewise.
5220 (__arm_vhsubq_m_n_u16): Likewise.
5221 (__arm_vhsubq_m_s8): Likewise.
5222 (__arm_vhsubq_m_s32): Likewise.
5223 (__arm_vhsubq_m_s16): Likewise.
5224 (__arm_vhsubq_m_u8): Likewise.
5225 (__arm_vhsubq_m_u32): Likewise.
5226 (__arm_vhsubq_m_u16): Likewise.
5227 (__arm_vmaxq_m_s8): Likewise.
5228 (__arm_vmaxq_m_s32): Likewise.
5229 (__arm_vmaxq_m_s16): Likewise.
5230 (__arm_vmaxq_m_u8): Likewise.
5231 (__arm_vmaxq_m_u32): Likewise.
5232 (__arm_vmaxq_m_u16): Likewise.
5233 (__arm_vminq_m_s8): Likewise.
5234 (__arm_vminq_m_s32): Likewise.
5235 (__arm_vminq_m_s16): Likewise.
5236 (__arm_vminq_m_u8): Likewise.
5237 (__arm_vminq_m_u32): Likewise.
5238 (__arm_vminq_m_u16): Likewise.
5239 (__arm_vmladavaq_p_s8): Likewise.
5240 (__arm_vmladavaq_p_s32): Likewise.
5241 (__arm_vmladavaq_p_s16): Likewise.
5242 (__arm_vmladavaq_p_u8): Likewise.
5243 (__arm_vmladavaq_p_u32): Likewise.
5244 (__arm_vmladavaq_p_u16): Likewise.
5245 (__arm_vmladavaxq_p_s8): Likewise.
5246 (__arm_vmladavaxq_p_s32): Likewise.
5247 (__arm_vmladavaxq_p_s16): Likewise.
5248 (__arm_vmlaq_m_n_s8): Likewise.
5249 (__arm_vmlaq_m_n_s32): Likewise.
5250 (__arm_vmlaq_m_n_s16): Likewise.
5251 (__arm_vmlaq_m_n_u8): Likewise.
5252 (__arm_vmlaq_m_n_u32): Likewise.
5253 (__arm_vmlaq_m_n_u16): Likewise.
5254 (__arm_vmlasq_m_n_s8): Likewise.
5255 (__arm_vmlasq_m_n_s32): Likewise.
5256 (__arm_vmlasq_m_n_s16): Likewise.
5257 (__arm_vmlasq_m_n_u8): Likewise.
5258 (__arm_vmlasq_m_n_u32): Likewise.
5259 (__arm_vmlasq_m_n_u16): Likewise.
5260 (__arm_vmlsdavaq_p_s8): Likewise.
5261 (__arm_vmlsdavaq_p_s32): Likewise.
5262 (__arm_vmlsdavaq_p_s16): Likewise.
5263 (__arm_vmlsdavaxq_p_s8): Likewise.
5264 (__arm_vmlsdavaxq_p_s32): Likewise.
5265 (__arm_vmlsdavaxq_p_s16): Likewise.
5266 (__arm_vmulhq_m_s8): Likewise.
5267 (__arm_vmulhq_m_s32): Likewise.
5268 (__arm_vmulhq_m_s16): Likewise.
5269 (__arm_vmulhq_m_u8): Likewise.
5270 (__arm_vmulhq_m_u32): Likewise.
5271 (__arm_vmulhq_m_u16): Likewise.
5272 (__arm_vmullbq_int_m_s8): Likewise.
5273 (__arm_vmullbq_int_m_s32): Likewise.
5274 (__arm_vmullbq_int_m_s16): Likewise.
5275 (__arm_vmullbq_int_m_u8): Likewise.
5276 (__arm_vmullbq_int_m_u32): Likewise.
5277 (__arm_vmullbq_int_m_u16): Likewise.
5278 (__arm_vmulltq_int_m_s8): Likewise.
5279 (__arm_vmulltq_int_m_s32): Likewise.
5280 (__arm_vmulltq_int_m_s16): Likewise.
5281 (__arm_vmulltq_int_m_u8): Likewise.
5282 (__arm_vmulltq_int_m_u32): Likewise.
5283 (__arm_vmulltq_int_m_u16): Likewise.
5284 (__arm_vmulq_m_n_s8): Likewise.
5285 (__arm_vmulq_m_n_s32): Likewise.
5286 (__arm_vmulq_m_n_s16): Likewise.
5287 (__arm_vmulq_m_n_u8): Likewise.
5288 (__arm_vmulq_m_n_u32): Likewise.
5289 (__arm_vmulq_m_n_u16): Likewise.
5290 (__arm_vmulq_m_s8): Likewise.
5291 (__arm_vmulq_m_s32): Likewise.
5292 (__arm_vmulq_m_s16): Likewise.
5293 (__arm_vmulq_m_u8): Likewise.
5294 (__arm_vmulq_m_u32): Likewise.
5295 (__arm_vmulq_m_u16): Likewise.
5296 (__arm_vornq_m_s8): Likewise.
5297 (__arm_vornq_m_s32): Likewise.
5298 (__arm_vornq_m_s16): Likewise.
5299 (__arm_vornq_m_u8): Likewise.
5300 (__arm_vornq_m_u32): Likewise.
5301 (__arm_vornq_m_u16): Likewise.
5302 (__arm_vorrq_m_s8): Likewise.
5303 (__arm_vorrq_m_s32): Likewise.
5304 (__arm_vorrq_m_s16): Likewise.
5305 (__arm_vorrq_m_u8): Likewise.
5306 (__arm_vorrq_m_u32): Likewise.
5307 (__arm_vorrq_m_u16): Likewise.
5308 (__arm_vqaddq_m_n_s8): Likewise.
5309 (__arm_vqaddq_m_n_s32): Likewise.
5310 (__arm_vqaddq_m_n_s16): Likewise.
5311 (__arm_vqaddq_m_n_u8): Likewise.
5312 (__arm_vqaddq_m_n_u32): Likewise.
5313 (__arm_vqaddq_m_n_u16): Likewise.
5314 (__arm_vqaddq_m_s8): Likewise.
5315 (__arm_vqaddq_m_s32): Likewise.
5316 (__arm_vqaddq_m_s16): Likewise.
5317 (__arm_vqaddq_m_u8): Likewise.
5318 (__arm_vqaddq_m_u32): Likewise.
5319 (__arm_vqaddq_m_u16): Likewise.
5320 (__arm_vqdmladhq_m_s8): Likewise.
5321 (__arm_vqdmladhq_m_s32): Likewise.
5322 (__arm_vqdmladhq_m_s16): Likewise.
5323 (__arm_vqdmladhxq_m_s8): Likewise.
5324 (__arm_vqdmladhxq_m_s32): Likewise.
5325 (__arm_vqdmladhxq_m_s16): Likewise.
5326 (__arm_vqdmlahq_m_n_s8): Likewise.
5327 (__arm_vqdmlahq_m_n_s32): Likewise.
5328 (__arm_vqdmlahq_m_n_s16): Likewise.
5329 (__arm_vqdmlahq_m_n_u8): Likewise.
5330 (__arm_vqdmlahq_m_n_u32): Likewise.
5331 (__arm_vqdmlahq_m_n_u16): Likewise.
5332 (__arm_vqdmlsdhq_m_s8): Likewise.
5333 (__arm_vqdmlsdhq_m_s32): Likewise.
5334 (__arm_vqdmlsdhq_m_s16): Likewise.
5335 (__arm_vqdmlsdhxq_m_s8): Likewise.
5336 (__arm_vqdmlsdhxq_m_s32): Likewise.
5337 (__arm_vqdmlsdhxq_m_s16): Likewise.
5338 (__arm_vqdmulhq_m_n_s8): Likewise.
5339 (__arm_vqdmulhq_m_n_s32): Likewise.
5340 (__arm_vqdmulhq_m_n_s16): Likewise.
5341 (__arm_vqdmulhq_m_s8): Likewise.
5342 (__arm_vqdmulhq_m_s32): Likewise.
5343 (__arm_vqdmulhq_m_s16): Likewise.
5344 (__arm_vqrdmladhq_m_s8): Likewise.
5345 (__arm_vqrdmladhq_m_s32): Likewise.
5346 (__arm_vqrdmladhq_m_s16): Likewise.
5347 (__arm_vqrdmladhxq_m_s8): Likewise.
5348 (__arm_vqrdmladhxq_m_s32): Likewise.
5349 (__arm_vqrdmladhxq_m_s16): Likewise.
5350 (__arm_vqrdmlahq_m_n_s8): Likewise.
5351 (__arm_vqrdmlahq_m_n_s32): Likewise.
5352 (__arm_vqrdmlahq_m_n_s16): Likewise.
5353 (__arm_vqrdmlahq_m_n_u8): Likewise.
5354 (__arm_vqrdmlahq_m_n_u32): Likewise.
5355 (__arm_vqrdmlahq_m_n_u16): Likewise.
5356 (__arm_vqrdmlashq_m_n_s8): Likewise.
5357 (__arm_vqrdmlashq_m_n_s32): Likewise.
5358 (__arm_vqrdmlashq_m_n_s16): Likewise.
5359 (__arm_vqrdmlashq_m_n_u8): Likewise.
5360 (__arm_vqrdmlashq_m_n_u32): Likewise.
5361 (__arm_vqrdmlashq_m_n_u16): Likewise.
5362 (__arm_vqrdmlsdhq_m_s8): Likewise.
5363 (__arm_vqrdmlsdhq_m_s32): Likewise.
5364 (__arm_vqrdmlsdhq_m_s16): Likewise.
5365 (__arm_vqrdmlsdhxq_m_s8): Likewise.
5366 (__arm_vqrdmlsdhxq_m_s32): Likewise.
5367 (__arm_vqrdmlsdhxq_m_s16): Likewise.
5368 (__arm_vqrdmulhq_m_n_s8): Likewise.
5369 (__arm_vqrdmulhq_m_n_s32): Likewise.
5370 (__arm_vqrdmulhq_m_n_s16): Likewise.
5371 (__arm_vqrdmulhq_m_s8): Likewise.
5372 (__arm_vqrdmulhq_m_s32): Likewise.
5373 (__arm_vqrdmulhq_m_s16): Likewise.
5374 (__arm_vqrshlq_m_s8): Likewise.
5375 (__arm_vqrshlq_m_s32): Likewise.
5376 (__arm_vqrshlq_m_s16): Likewise.
5377 (__arm_vqrshlq_m_u8): Likewise.
5378 (__arm_vqrshlq_m_u32): Likewise.
5379 (__arm_vqrshlq_m_u16): Likewise.
5380 (__arm_vqshlq_m_n_s8): Likewise.
5381 (__arm_vqshlq_m_n_s32): Likewise.
5382 (__arm_vqshlq_m_n_s16): Likewise.
5383 (__arm_vqshlq_m_n_u8): Likewise.
5384 (__arm_vqshlq_m_n_u32): Likewise.
5385 (__arm_vqshlq_m_n_u16): Likewise.
5386 (__arm_vqshlq_m_s8): Likewise.
5387 (__arm_vqshlq_m_s32): Likewise.
5388 (__arm_vqshlq_m_s16): Likewise.
5389 (__arm_vqshlq_m_u8): Likewise.
5390 (__arm_vqshlq_m_u32): Likewise.
5391 (__arm_vqshlq_m_u16): Likewise.
5392 (__arm_vqsubq_m_n_s8): Likewise.
5393 (__arm_vqsubq_m_n_s32): Likewise.
5394 (__arm_vqsubq_m_n_s16): Likewise.
5395 (__arm_vqsubq_m_n_u8): Likewise.
5396 (__arm_vqsubq_m_n_u32): Likewise.
5397 (__arm_vqsubq_m_n_u16): Likewise.
5398 (__arm_vqsubq_m_s8): Likewise.
5399 (__arm_vqsubq_m_s32): Likewise.
5400 (__arm_vqsubq_m_s16): Likewise.
5401 (__arm_vqsubq_m_u8): Likewise.
5402 (__arm_vqsubq_m_u32): Likewise.
5403 (__arm_vqsubq_m_u16): Likewise.
5404 (__arm_vrhaddq_m_s8): Likewise.
5405 (__arm_vrhaddq_m_s32): Likewise.
5406 (__arm_vrhaddq_m_s16): Likewise.
5407 (__arm_vrhaddq_m_u8): Likewise.
5408 (__arm_vrhaddq_m_u32): Likewise.
5409 (__arm_vrhaddq_m_u16): Likewise.
5410 (__arm_vrmulhq_m_s8): Likewise.
5411 (__arm_vrmulhq_m_s32): Likewise.
5412 (__arm_vrmulhq_m_s16): Likewise.
5413 (__arm_vrmulhq_m_u8): Likewise.
5414 (__arm_vrmulhq_m_u32): Likewise.
5415 (__arm_vrmulhq_m_u16): Likewise.
5416 (__arm_vrshlq_m_s8): Likewise.
5417 (__arm_vrshlq_m_s32): Likewise.
5418 (__arm_vrshlq_m_s16): Likewise.
5419 (__arm_vrshlq_m_u8): Likewise.
5420 (__arm_vrshlq_m_u32): Likewise.
5421 (__arm_vrshlq_m_u16): Likewise.
5422 (__arm_vrshrq_m_n_s8): Likewise.
5423 (__arm_vrshrq_m_n_s32): Likewise.
5424 (__arm_vrshrq_m_n_s16): Likewise.
5425 (__arm_vrshrq_m_n_u8): Likewise.
5426 (__arm_vrshrq_m_n_u32): Likewise.
5427 (__arm_vrshrq_m_n_u16): Likewise.
5428 (__arm_vshlq_m_n_s8): Likewise.
5429 (__arm_vshlq_m_n_s32): Likewise.
5430 (__arm_vshlq_m_n_s16): Likewise.
5431 (__arm_vshlq_m_n_u8): Likewise.
5432 (__arm_vshlq_m_n_u32): Likewise.
5433 (__arm_vshlq_m_n_u16): Likewise.
5434 (__arm_vshrq_m_n_s8): Likewise.
5435 (__arm_vshrq_m_n_s32): Likewise.
5436 (__arm_vshrq_m_n_s16): Likewise.
5437 (__arm_vshrq_m_n_u8): Likewise.
5438 (__arm_vshrq_m_n_u32): Likewise.
5439 (__arm_vshrq_m_n_u16): Likewise.
5440 (__arm_vsliq_m_n_s8): Likewise.
5441 (__arm_vsliq_m_n_s32): Likewise.
5442 (__arm_vsliq_m_n_s16): Likewise.
5443 (__arm_vsliq_m_n_u8): Likewise.
5444 (__arm_vsliq_m_n_u32): Likewise.
5445 (__arm_vsliq_m_n_u16): Likewise.
5446 (__arm_vsubq_m_n_s8): Likewise.
5447 (__arm_vsubq_m_n_s32): Likewise.
5448 (__arm_vsubq_m_n_s16): Likewise.
5449 (__arm_vsubq_m_n_u8): Likewise.
5450 (__arm_vsubq_m_n_u32): Likewise.
5451 (__arm_vsubq_m_n_u16): Likewise.
5452 (vqdmladhq_m): Define polymorphic variant.
5453 (vqdmladhxq_m): Likewise.
5454 (vqdmlsdhq_m): Likewise.
5455 (vqdmlsdhxq_m): Likewise.
5456 (vabdq_m): Likewise.
5457 (vandq_m): Likewise.
5458 (vbicq_m): Likewise.
5459 (vbrsrq_m_n): Likewise.
5460 (vcaddq_rot270_m): Likewise.
5461 (vcaddq_rot90_m): Likewise.
5462 (veorq_m): Likewise.
5463 (vmaxq_m): Likewise.
5464 (vminq_m): Likewise.
5465 (vmladavaq_p): Likewise.
5466 (vmlaq_m_n): Likewise.
5467 (vmlasq_m_n): Likewise.
5468 (vmulhq_m): Likewise.
5469 (vmullbq_int_m): Likewise.
5470 (vmulltq_int_m): Likewise.
5471 (vornq_m): Likewise.
5472 (vorrq_m): Likewise.
5473 (vqdmlahq_m_n): Likewise.
5474 (vqrdmlahq_m_n): Likewise.
5475 (vqrdmlashq_m_n): Likewise.
5476 (vqrshlq_m): Likewise.
5477 (vqshlq_m_n): Likewise.
5478 (vqshlq_m): Likewise.
5479 (vrhaddq_m): Likewise.
5480 (vrmulhq_m): Likewise.
5481 (vrshlq_m): Likewise.
5482 (vrshrq_m_n): Likewise.
5483 (vshlq_m_n): Likewise.
5484 (vshrq_m_n): Likewise.
5485 (vsliq_m): Likewise.
5486 (vaddq_m_n): Likewise.
5487 (vaddq_m): Likewise.
5488 (vhaddq_m_n): Likewise.
5489 (vhaddq_m): Likewise.
5490 (vhcaddq_rot270_m): Likewise.
5491 (vhcaddq_rot90_m): Likewise.
5492 (vhsubq_m): Likewise.
5493 (vhsubq_m_n): Likewise.
5494 (vmulq_m_n): Likewise.
5495 (vmulq_m): Likewise.
5496 (vqaddq_m_n): Likewise.
5497 (vqaddq_m): Likewise.
5498 (vqdmulhq_m_n): Likewise.
5499 (vqdmulhq_m): Likewise.
5500 (vsubq_m_n): Likewise.
5501 (vsliq_m_n): Likewise.
5502 (vqsubq_m_n): Likewise.
5503 (vqsubq_m): Likewise.
5504 (vqrdmulhq_m): Likewise.
5505 (vqrdmulhq_m_n): Likewise.
5506 (vqrdmlsdhxq_m): Likewise.
5507 (vqrdmlsdhq_m): Likewise.
5508 (vqrdmladhq_m): Likewise.
5509 (vqrdmladhxq_m): Likewise.
5510 (vmlsdavaxq_p): Likewise.
5511 (vmlsdavaq_p): Likewise.
5512 (vmladavaxq_p): Likewise.
5513 * config/arm/arm_mve_builtins.def (QUADOP_NONE_NONE_NONE_IMM_UNONE): Use
5514 builtin qualifier.
5515 (QUADOP_NONE_NONE_NONE_NONE_UNONE): Likewise.
5516 (QUADOP_UNONE_UNONE_UNONE_IMM_UNONE): Likewise.
5517 (QUADOP_UNONE_UNONE_UNONE_NONE_UNONE): Likewise.
5518 (QUADOP_UNONE_UNONE_UNONE_UNONE_UNONE): Likewise.
5519 * config/arm/mve.md (VHSUBQ_M): Define iterators.
5520 (VSLIQ_M_N): Likewise.
5521 (VQRDMLAHQ_M_N): Likewise.
5522 (VRSHLQ_M): Likewise.
5523 (VMINQ_M): Likewise.
5524 (VMULLBQ_INT_M): Likewise.
5525 (VMULHQ_M): Likewise.
5526 (VMULQ_M): Likewise.
5527 (VHSUBQ_M_N): Likewise.
5528 (VHADDQ_M_N): Likewise.
5529 (VORRQ_M): Likewise.
5530 (VRMULHQ_M): Likewise.
5531 (VQADDQ_M): Likewise.
5532 (VRSHRQ_M_N): Likewise.
5533 (VQSUBQ_M_N): Likewise.
5534 (VADDQ_M): Likewise.
5535 (VORNQ_M): Likewise.
5536 (VQDMLAHQ_M_N): Likewise.
5537 (VRHADDQ_M): Likewise.
5538 (VQSHLQ_M): Likewise.
5539 (VANDQ_M): Likewise.
5540 (VBICQ_M): Likewise.
5541 (VSHLQ_M_N): Likewise.
5542 (VCADDQ_ROT270_M): Likewise.
5543 (VQRSHLQ_M): Likewise.
5544 (VQADDQ_M_N): Likewise.
5545 (VADDQ_M_N): Likewise.
5546 (VMAXQ_M): Likewise.
5547 (VQSUBQ_M): Likewise.
5548 (VMLASQ_M_N): Likewise.
5549 (VMLADAVAQ_P): Likewise.
5550 (VBRSRQ_M_N): Likewise.
5551 (VMULQ_M_N): Likewise.
5552 (VCADDQ_ROT90_M): Likewise.
5553 (VMULLTQ_INT_M): Likewise.
5554 (VEORQ_M): Likewise.
5555 (VSHRQ_M_N): Likewise.
5556 (VSUBQ_M_N): Likewise.
5557 (VHADDQ_M): Likewise.
5558 (VABDQ_M): Likewise.
5559 (VQRDMLASHQ_M_N): Likewise.
5560 (VMLAQ_M_N): Likewise.
5561 (VQSHLQ_M_N): Likewise.
5562 (mve_vabdq_m_<supf><mode>): Define RTL pattern.
5563 (mve_vaddq_m_n_<supf><mode>): Likewise.
5564 (mve_vaddq_m_<supf><mode>): Likewise.
5565 (mve_vandq_m_<supf><mode>): Likewise.
5566 (mve_vbicq_m_<supf><mode>): Likewise.
5567 (mve_vbrsrq_m_n_<supf><mode>): Likewise.
5568 (mve_vcaddq_rot270_m_<supf><mode>): Likewise.
5569 (mve_vcaddq_rot90_m_<supf><mode>): Likewise.
5570 (mve_veorq_m_<supf><mode>): Likewise.
5571 (mve_vhaddq_m_n_<supf><mode>): Likewise.
5572 (mve_vhaddq_m_<supf><mode>): Likewise.
5573 (mve_vhsubq_m_n_<supf><mode>): Likewise.
5574 (mve_vhsubq_m_<supf><mode>): Likewise.
5575 (mve_vmaxq_m_<supf><mode>): Likewise.
5576 (mve_vminq_m_<supf><mode>): Likewise.
5577 (mve_vmladavaq_p_<supf><mode>): Likewise.
5578 (mve_vmlaq_m_n_<supf><mode>): Likewise.
5579 (mve_vmlasq_m_n_<supf><mode>): Likewise.
5580 (mve_vmulhq_m_<supf><mode>): Likewise.
5581 (mve_vmullbq_int_m_<supf><mode>): Likewise.
5582 (mve_vmulltq_int_m_<supf><mode>): Likewise.
5583 (mve_vmulq_m_n_<supf><mode>): Likewise.
5584 (mve_vmulq_m_<supf><mode>): Likewise.
5585 (mve_vornq_m_<supf><mode>): Likewise.
5586 (mve_vorrq_m_<supf><mode>): Likewise.
5587 (mve_vqaddq_m_n_<supf><mode>): Likewise.
5588 (mve_vqaddq_m_<supf><mode>): Likewise.
5589 (mve_vqdmlahq_m_n_<supf><mode>): Likewise.
5590 (mve_vqrdmlahq_m_n_<supf><mode>): Likewise.
5591 (mve_vqrdmlashq_m_n_<supf><mode>): Likewise.
5592 (mve_vqrshlq_m_<supf><mode>): Likewise.
5593 (mve_vqshlq_m_n_<supf><mode>): Likewise.
5594 (mve_vqshlq_m_<supf><mode>): Likewise.
5595 (mve_vqsubq_m_n_<supf><mode>): Likewise.
5596 (mve_vqsubq_m_<supf><mode>): Likewise.
5597 (mve_vrhaddq_m_<supf><mode>): Likewise.
5598 (mve_vrmulhq_m_<supf><mode>): Likewise.
5599 (mve_vrshlq_m_<supf><mode>): Likewise.
5600 (mve_vrshrq_m_n_<supf><mode>): Likewise.
5601 (mve_vshlq_m_n_<supf><mode>): Likewise.
5602 (mve_vshrq_m_n_<supf><mode>): Likewise.
5603 (mve_vsliq_m_n_<supf><mode>): Likewise.
5604 (mve_vsubq_m_n_<supf><mode>): Likewise.
5605 (mve_vhcaddq_rot270_m_s<mode>): Likewise.
5606 (mve_vhcaddq_rot90_m_s<mode>): Likewise.
5607 (mve_vmladavaxq_p_s<mode>): Likewise.
5608 (mve_vmlsdavaq_p_s<mode>): Likewise.
5609 (mve_vmlsdavaxq_p_s<mode>): Likewise.
5610 (mve_vqdmladhq_m_s<mode>): Likewise.
5611 (mve_vqdmladhxq_m_s<mode>): Likewise.
5612 (mve_vqdmlsdhq_m_s<mode>): Likewise.
5613 (mve_vqdmlsdhxq_m_s<mode>): Likewise.
5614 (mve_vqdmulhq_m_n_s<mode>): Likewise.
5615 (mve_vqdmulhq_m_s<mode>): Likewise.
5616 (mve_vqrdmladhq_m_s<mode>): Likewise.
5617 (mve_vqrdmladhxq_m_s<mode>): Likewise.
5618 (mve_vqrdmlsdhq_m_s<mode>): Likewise.
5619 (mve_vqrdmlsdhxq_m_s<mode>): Likewise.
5620 (mve_vqrdmulhq_m_n_s<mode>): Likewise.
5621 (mve_vqrdmulhq_m_s<mode>): Likewise.
5622
5623 2020-03-18 Andre Vieira <andre.simoesdiasvieira@arm.com>
5624 Mihail Ionescu <mihail.ionescu@arm.com>
5625 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
5626
5627 * config/arm/arm-builtins.c (QUADOP_UNONE_UNONE_NONE_NONE_UNONE_QUALIFIERS):
5628 Define builtin qualifier.
5629 (QUADOP_NONE_NONE_NONE_NONE_UNONE_QUALIFIERS): Likewise.
5630 (QUADOP_NONE_NONE_NONE_IMM_UNONE_QUALIFIERS): Likewise.
5631 (QUADOP_UNONE_UNONE_UNONE_UNONE_UNONE_QUALIFIERS): Likewise.
5632 (QUADOP_UNONE_UNONE_NONE_IMM_UNONE_QUALIFIERS): Likewise.
5633 (QUADOP_NONE_NONE_UNONE_IMM_UNONE_QUALIFIERS): Likewise.
5634 (QUADOP_UNONE_UNONE_UNONE_IMM_UNONE_QUALIFIERS): Likewise.
5635 (QUADOP_UNONE_UNONE_UNONE_NONE_UNONE_QUALIFIERS): Likewise.
5636 * config/arm/arm_mve.h (vsriq_m_n_s8): Define macro.
5637 (vsubq_m_s8): Likewise.
5638 (vcvtq_m_n_f16_u16): Likewise.
5639 (vqshluq_m_n_s8): Likewise.
5640 (vabavq_p_s8): Likewise.
5641 (vsriq_m_n_u8): Likewise.
5642 (vshlq_m_u8): Likewise.
5643 (vsubq_m_u8): Likewise.
5644 (vabavq_p_u8): Likewise.
5645 (vshlq_m_s8): Likewise.
5646 (vcvtq_m_n_f16_s16): Likewise.
5647 (vsriq_m_n_s16): Likewise.
5648 (vsubq_m_s16): Likewise.
5649 (vcvtq_m_n_f32_u32): Likewise.
5650 (vqshluq_m_n_s16): Likewise.
5651 (vabavq_p_s16): Likewise.
5652 (vsriq_m_n_u16): Likewise.
5653 (vshlq_m_u16): Likewise.
5654 (vsubq_m_u16): Likewise.
5655 (vabavq_p_u16): Likewise.
5656 (vshlq_m_s16): Likewise.
5657 (vcvtq_m_n_f32_s32): Likewise.
5658 (vsriq_m_n_s32): Likewise.
5659 (vsubq_m_s32): Likewise.
5660 (vqshluq_m_n_s32): Likewise.
5661 (vabavq_p_s32): Likewise.
5662 (vsriq_m_n_u32): Likewise.
5663 (vshlq_m_u32): Likewise.
5664 (vsubq_m_u32): Likewise.
5665 (vabavq_p_u32): Likewise.
5666 (vshlq_m_s32): Likewise.
5667 (__arm_vsriq_m_n_s8): Define intrinsic.
5668 (__arm_vsubq_m_s8): Likewise.
5669 (__arm_vqshluq_m_n_s8): Likewise.
5670 (__arm_vabavq_p_s8): Likewise.
5671 (__arm_vsriq_m_n_u8): Likewise.
5672 (__arm_vshlq_m_u8): Likewise.
5673 (__arm_vsubq_m_u8): Likewise.
5674 (__arm_vabavq_p_u8): Likewise.
5675 (__arm_vshlq_m_s8): Likewise.
5676 (__arm_vsriq_m_n_s16): Likewise.
5677 (__arm_vsubq_m_s16): Likewise.
5678 (__arm_vqshluq_m_n_s16): Likewise.
5679 (__arm_vabavq_p_s16): Likewise.
5680 (__arm_vsriq_m_n_u16): Likewise.
5681 (__arm_vshlq_m_u16): Likewise.
5682 (__arm_vsubq_m_u16): Likewise.
5683 (__arm_vabavq_p_u16): Likewise.
5684 (__arm_vshlq_m_s16): Likewise.
5685 (__arm_vsriq_m_n_s32): Likewise.
5686 (__arm_vsubq_m_s32): Likewise.
5687 (__arm_vqshluq_m_n_s32): Likewise.
5688 (__arm_vabavq_p_s32): Likewise.
5689 (__arm_vsriq_m_n_u32): Likewise.
5690 (__arm_vshlq_m_u32): Likewise.
5691 (__arm_vsubq_m_u32): Likewise.
5692 (__arm_vabavq_p_u32): Likewise.
5693 (__arm_vshlq_m_s32): Likewise.
5694 (__arm_vcvtq_m_n_f16_u16): Likewise.
5695 (__arm_vcvtq_m_n_f16_s16): Likewise.
5696 (__arm_vcvtq_m_n_f32_u32): Likewise.
5697 (__arm_vcvtq_m_n_f32_s32): Likewise.
5698 (vcvtq_m_n): Define polymorphic variant.
5699 (vqshluq_m_n): Likewise.
5700 (vshlq_m): Likewise.
5701 (vsriq_m_n): Likewise.
5702 (vsubq_m): Likewise.
5703 (vabavq_p): Likewise.
5704 * config/arm/arm_mve_builtins.def
5705 (QUADOP_UNONE_UNONE_NONE_NONE_UNONE_QUALIFIERS): Use builtin qualifier.
5706 (QUADOP_NONE_NONE_NONE_NONE_UNONE_QUALIFIERS): Likewise.
5707 (QUADOP_NONE_NONE_NONE_IMM_UNONE_QUALIFIERS): Likewise.
5708 (QUADOP_UNONE_UNONE_UNONE_UNONE_UNONE_QUALIFIERS): Likewise.
5709 (QUADOP_UNONE_UNONE_NONE_IMM_UNONE_QUALIFIERS): Likewise.
5710 (QUADOP_NONE_NONE_UNONE_IMM_UNONE_QUALIFIERS): Likewise.
5711 (QUADOP_UNONE_UNONE_UNONE_IMM_UNONE_QUALIFIERS): Likewise.
5712 (QUADOP_UNONE_UNONE_UNONE_NONE_UNONE_QUALIFIERS): Likewise.
5713 * config/arm/mve.md (VABAVQ_P): Define iterator.
5714 (VSHLQ_M): Likewise.
5715 (VSRIQ_M_N): Likewise.
5716 (VSUBQ_M): Likewise.
5717 (VCVTQ_M_N_TO_F): Likewise.
5718 (mve_vabavq_p_<supf><mode>): Define RTL pattern.
5719 (mve_vqshluq_m_n_s<mode>): Likewise.
5720 (mve_vshlq_m_<supf><mode>): Likewise.
5721 (mve_vsriq_m_n_<supf><mode>): Likewise.
5722 (mve_vsubq_m_<supf><mode>): Likewise.
5723 (mve_vcvtq_m_n_to_f_<supf><mode>): Likewise.
5724
5725 2020-03-18 Andre Vieira <andre.simoesdiasvieira@arm.com>
5726 Mihail Ionescu <mihail.ionescu@arm.com>
5727 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
5728
5729 * config/arm/arm_mve.h (vrmlaldavhaxq_s32): Define macro.
5730 (vrmlsldavhaq_s32): Likewise.
5731 (vrmlsldavhaxq_s32): Likewise.
5732 (vaddlvaq_p_s32): Likewise.
5733 (vcvtbq_m_f16_f32): Likewise.
5734 (vcvtbq_m_f32_f16): Likewise.
5735 (vcvttq_m_f16_f32): Likewise.
5736 (vcvttq_m_f32_f16): Likewise.
5737 (vrev16q_m_s8): Likewise.
5738 (vrev32q_m_f16): Likewise.
5739 (vrmlaldavhq_p_s32): Likewise.
5740 (vrmlaldavhxq_p_s32): Likewise.
5741 (vrmlsldavhq_p_s32): Likewise.
5742 (vrmlsldavhxq_p_s32): Likewise.
5743 (vaddlvaq_p_u32): Likewise.
5744 (vrev16q_m_u8): Likewise.
5745 (vrmlaldavhq_p_u32): Likewise.
5746 (vmvnq_m_n_s16): Likewise.
5747 (vorrq_m_n_s16): Likewise.
5748 (vqrshrntq_n_s16): Likewise.
5749 (vqshrnbq_n_s16): Likewise.
5750 (vqshrntq_n_s16): Likewise.
5751 (vrshrnbq_n_s16): Likewise.
5752 (vrshrntq_n_s16): Likewise.
5753 (vshrnbq_n_s16): Likewise.
5754 (vshrntq_n_s16): Likewise.
5755 (vcmlaq_f16): Likewise.
5756 (vcmlaq_rot180_f16): Likewise.
5757 (vcmlaq_rot270_f16): Likewise.
5758 (vcmlaq_rot90_f16): Likewise.
5759 (vfmaq_f16): Likewise.
5760 (vfmaq_n_f16): Likewise.
5761 (vfmasq_n_f16): Likewise.
5762 (vfmsq_f16): Likewise.
5763 (vmlaldavaq_s16): Likewise.
5764 (vmlaldavaxq_s16): Likewise.
5765 (vmlsldavaq_s16): Likewise.
5766 (vmlsldavaxq_s16): Likewise.
5767 (vabsq_m_f16): Likewise.
5768 (vcvtmq_m_s16_f16): Likewise.
5769 (vcvtnq_m_s16_f16): Likewise.
5770 (vcvtpq_m_s16_f16): Likewise.
5771 (vcvtq_m_s16_f16): Likewise.
5772 (vdupq_m_n_f16): Likewise.
5773 (vmaxnmaq_m_f16): Likewise.
5774 (vmaxnmavq_p_f16): Likewise.
5775 (vmaxnmvq_p_f16): Likewise.
5776 (vminnmaq_m_f16): Likewise.
5777 (vminnmavq_p_f16): Likewise.
5778 (vminnmvq_p_f16): Likewise.
5779 (vmlaldavq_p_s16): Likewise.
5780 (vmlaldavxq_p_s16): Likewise.
5781 (vmlsldavq_p_s16): Likewise.
5782 (vmlsldavxq_p_s16): Likewise.
5783 (vmovlbq_m_s8): Likewise.
5784 (vmovltq_m_s8): Likewise.
5785 (vmovnbq_m_s16): Likewise.
5786 (vmovntq_m_s16): Likewise.
5787 (vnegq_m_f16): Likewise.
5788 (vpselq_f16): Likewise.
5789 (vqmovnbq_m_s16): Likewise.
5790 (vqmovntq_m_s16): Likewise.
5791 (vrev32q_m_s8): Likewise.
5792 (vrev64q_m_f16): Likewise.
5793 (vrndaq_m_f16): Likewise.
5794 (vrndmq_m_f16): Likewise.
5795 (vrndnq_m_f16): Likewise.
5796 (vrndpq_m_f16): Likewise.
5797 (vrndq_m_f16): Likewise.
5798 (vrndxq_m_f16): Likewise.
5799 (vcmpeqq_m_n_f16): Likewise.
5800 (vcmpgeq_m_f16): Likewise.
5801 (vcmpgeq_m_n_f16): Likewise.
5802 (vcmpgtq_m_f16): Likewise.
5803 (vcmpgtq_m_n_f16): Likewise.
5804 (vcmpleq_m_f16): Likewise.
5805 (vcmpleq_m_n_f16): Likewise.
5806 (vcmpltq_m_f16): Likewise.
5807 (vcmpltq_m_n_f16): Likewise.
5808 (vcmpneq_m_f16): Likewise.
5809 (vcmpneq_m_n_f16): Likewise.
5810 (vmvnq_m_n_u16): Likewise.
5811 (vorrq_m_n_u16): Likewise.
5812 (vqrshruntq_n_s16): Likewise.
5813 (vqshrunbq_n_s16): Likewise.
5814 (vqshruntq_n_s16): Likewise.
5815 (vcvtmq_m_u16_f16): Likewise.
5816 (vcvtnq_m_u16_f16): Likewise.
5817 (vcvtpq_m_u16_f16): Likewise.
5818 (vcvtq_m_u16_f16): Likewise.
5819 (vqmovunbq_m_s16): Likewise.
5820 (vqmovuntq_m_s16): Likewise.
5821 (vqrshrntq_n_u16): Likewise.
5822 (vqshrnbq_n_u16): Likewise.
5823 (vqshrntq_n_u16): Likewise.
5824 (vrshrnbq_n_u16): Likewise.
5825 (vrshrntq_n_u16): Likewise.
5826 (vshrnbq_n_u16): Likewise.
5827 (vshrntq_n_u16): Likewise.
5828 (vmlaldavaq_u16): Likewise.
5829 (vmlaldavaxq_u16): Likewise.
5830 (vmlaldavq_p_u16): Likewise.
5831 (vmlaldavxq_p_u16): Likewise.
5832 (vmovlbq_m_u8): Likewise.
5833 (vmovltq_m_u8): Likewise.
5834 (vmovnbq_m_u16): Likewise.
5835 (vmovntq_m_u16): Likewise.
5836 (vqmovnbq_m_u16): Likewise.
5837 (vqmovntq_m_u16): Likewise.
5838 (vrev32q_m_u8): Likewise.
5839 (vmvnq_m_n_s32): Likewise.
5840 (vorrq_m_n_s32): Likewise.
5841 (vqrshrntq_n_s32): Likewise.
5842 (vqshrnbq_n_s32): Likewise.
5843 (vqshrntq_n_s32): Likewise.
5844 (vrshrnbq_n_s32): Likewise.
5845 (vrshrntq_n_s32): Likewise.
5846 (vshrnbq_n_s32): Likewise.
5847 (vshrntq_n_s32): Likewise.
5848 (vcmlaq_f32): Likewise.
5849 (vcmlaq_rot180_f32): Likewise.
5850 (vcmlaq_rot270_f32): Likewise.
5851 (vcmlaq_rot90_f32): Likewise.
5852 (vfmaq_f32): Likewise.
5853 (vfmaq_n_f32): Likewise.
5854 (vfmasq_n_f32): Likewise.
5855 (vfmsq_f32): Likewise.
5856 (vmlaldavaq_s32): Likewise.
5857 (vmlaldavaxq_s32): Likewise.
5858 (vmlsldavaq_s32): Likewise.
5859 (vmlsldavaxq_s32): Likewise.
5860 (vabsq_m_f32): Likewise.
5861 (vcvtmq_m_s32_f32): Likewise.
5862 (vcvtnq_m_s32_f32): Likewise.
5863 (vcvtpq_m_s32_f32): Likewise.
5864 (vcvtq_m_s32_f32): Likewise.
5865 (vdupq_m_n_f32): Likewise.
5866 (vmaxnmaq_m_f32): Likewise.
5867 (vmaxnmavq_p_f32): Likewise.
5868 (vmaxnmvq_p_f32): Likewise.
5869 (vminnmaq_m_f32): Likewise.
5870 (vminnmavq_p_f32): Likewise.
5871 (vminnmvq_p_f32): Likewise.
5872 (vmlaldavq_p_s32): Likewise.
5873 (vmlaldavxq_p_s32): Likewise.
5874 (vmlsldavq_p_s32): Likewise.
5875 (vmlsldavxq_p_s32): Likewise.
5876 (vmovlbq_m_s16): Likewise.
5877 (vmovltq_m_s16): Likewise.
5878 (vmovnbq_m_s32): Likewise.
5879 (vmovntq_m_s32): Likewise.
5880 (vnegq_m_f32): Likewise.
5881 (vpselq_f32): Likewise.
5882 (vqmovnbq_m_s32): Likewise.
5883 (vqmovntq_m_s32): Likewise.
5884 (vrev32q_m_s16): Likewise.
5885 (vrev64q_m_f32): Likewise.
5886 (vrndaq_m_f32): Likewise.
5887 (vrndmq_m_f32): Likewise.
5888 (vrndnq_m_f32): Likewise.
5889 (vrndpq_m_f32): Likewise.
5890 (vrndq_m_f32): Likewise.
5891 (vrndxq_m_f32): Likewise.
5892 (vcmpeqq_m_n_f32): Likewise.
5893 (vcmpgeq_m_f32): Likewise.
5894 (vcmpgeq_m_n_f32): Likewise.
5895 (vcmpgtq_m_f32): Likewise.
5896 (vcmpgtq_m_n_f32): Likewise.
5897 (vcmpleq_m_f32): Likewise.
5898 (vcmpleq_m_n_f32): Likewise.
5899 (vcmpltq_m_f32): Likewise.
5900 (vcmpltq_m_n_f32): Likewise.
5901 (vcmpneq_m_f32): Likewise.
5902 (vcmpneq_m_n_f32): Likewise.
5903 (vmvnq_m_n_u32): Likewise.
5904 (vorrq_m_n_u32): Likewise.
5905 (vqrshruntq_n_s32): Likewise.
5906 (vqshrunbq_n_s32): Likewise.
5907 (vqshruntq_n_s32): Likewise.
5908 (vcvtmq_m_u32_f32): Likewise.
5909 (vcvtnq_m_u32_f32): Likewise.
5910 (vcvtpq_m_u32_f32): Likewise.
5911 (vcvtq_m_u32_f32): Likewise.
5912 (vqmovunbq_m_s32): Likewise.
5913 (vqmovuntq_m_s32): Likewise.
5914 (vqrshrntq_n_u32): Likewise.
5915 (vqshrnbq_n_u32): Likewise.
5916 (vqshrntq_n_u32): Likewise.
5917 (vrshrnbq_n_u32): Likewise.
5918 (vrshrntq_n_u32): Likewise.
5919 (vshrnbq_n_u32): Likewise.
5920 (vshrntq_n_u32): Likewise.
5921 (vmlaldavaq_u32): Likewise.
5922 (vmlaldavaxq_u32): Likewise.
5923 (vmlaldavq_p_u32): Likewise.
5924 (vmlaldavxq_p_u32): Likewise.
5925 (vmovlbq_m_u16): Likewise.
5926 (vmovltq_m_u16): Likewise.
5927 (vmovnbq_m_u32): Likewise.
5928 (vmovntq_m_u32): Likewise.
5929 (vqmovnbq_m_u32): Likewise.
5930 (vqmovntq_m_u32): Likewise.
5931 (vrev32q_m_u16): Likewise.
5932 (__arm_vrmlaldavhaxq_s32): Define intrinsic.
5933 (__arm_vrmlsldavhaq_s32): Likewise.
5934 (__arm_vrmlsldavhaxq_s32): Likewise.
5935 (__arm_vaddlvaq_p_s32): Likewise.
5936 (__arm_vrev16q_m_s8): Likewise.
5937 (__arm_vrmlaldavhq_p_s32): Likewise.
5938 (__arm_vrmlaldavhxq_p_s32): Likewise.
5939 (__arm_vrmlsldavhq_p_s32): Likewise.
5940 (__arm_vrmlsldavhxq_p_s32): Likewise.
5941 (__arm_vaddlvaq_p_u32): Likewise.
5942 (__arm_vrev16q_m_u8): Likewise.
5943 (__arm_vrmlaldavhq_p_u32): Likewise.
5944 (__arm_vmvnq_m_n_s16): Likewise.
5945 (__arm_vorrq_m_n_s16): Likewise.
5946 (__arm_vqrshrntq_n_s16): Likewise.
5947 (__arm_vqshrnbq_n_s16): Likewise.
5948 (__arm_vqshrntq_n_s16): Likewise.
5949 (__arm_vrshrnbq_n_s16): Likewise.
5950 (__arm_vrshrntq_n_s16): Likewise.
5951 (__arm_vshrnbq_n_s16): Likewise.
5952 (__arm_vshrntq_n_s16): Likewise.
5953 (__arm_vmlaldavaq_s16): Likewise.
5954 (__arm_vmlaldavaxq_s16): Likewise.
5955 (__arm_vmlsldavaq_s16): Likewise.
5956 (__arm_vmlsldavaxq_s16): Likewise.
5957 (__arm_vmlaldavq_p_s16): Likewise.
5958 (__arm_vmlaldavxq_p_s16): Likewise.
5959 (__arm_vmlsldavq_p_s16): Likewise.
5960 (__arm_vmlsldavxq_p_s16): Likewise.
5961 (__arm_vmovlbq_m_s8): Likewise.
5962 (__arm_vmovltq_m_s8): Likewise.
5963 (__arm_vmovnbq_m_s16): Likewise.
5964 (__arm_vmovntq_m_s16): Likewise.
5965 (__arm_vqmovnbq_m_s16): Likewise.
5966 (__arm_vqmovntq_m_s16): Likewise.
5967 (__arm_vrev32q_m_s8): Likewise.
5968 (__arm_vmvnq_m_n_u16): Likewise.
5969 (__arm_vorrq_m_n_u16): Likewise.
5970 (__arm_vqrshruntq_n_s16): Likewise.
5971 (__arm_vqshrunbq_n_s16): Likewise.
5972 (__arm_vqshruntq_n_s16): Likewise.
5973 (__arm_vqmovunbq_m_s16): Likewise.
5974 (__arm_vqmovuntq_m_s16): Likewise.
5975 (__arm_vqrshrntq_n_u16): Likewise.
5976 (__arm_vqshrnbq_n_u16): Likewise.
5977 (__arm_vqshrntq_n_u16): Likewise.
5978 (__arm_vrshrnbq_n_u16): Likewise.
5979 (__arm_vrshrntq_n_u16): Likewise.
5980 (__arm_vshrnbq_n_u16): Likewise.
5981 (__arm_vshrntq_n_u16): Likewise.
5982 (__arm_vmlaldavaq_u16): Likewise.
5983 (__arm_vmlaldavaxq_u16): Likewise.
5984 (__arm_vmlaldavq_p_u16): Likewise.
5985 (__arm_vmlaldavxq_p_u16): Likewise.
5986 (__arm_vmovlbq_m_u8): Likewise.
5987 (__arm_vmovltq_m_u8): Likewise.
5988 (__arm_vmovnbq_m_u16): Likewise.
5989 (__arm_vmovntq_m_u16): Likewise.
5990 (__arm_vqmovnbq_m_u16): Likewise.
5991 (__arm_vqmovntq_m_u16): Likewise.
5992 (__arm_vrev32q_m_u8): Likewise.
5993 (__arm_vmvnq_m_n_s32): Likewise.
5994 (__arm_vorrq_m_n_s32): Likewise.
5995 (__arm_vqrshrntq_n_s32): Likewise.
5996 (__arm_vqshrnbq_n_s32): Likewise.
5997 (__arm_vqshrntq_n_s32): Likewise.
5998 (__arm_vrshrnbq_n_s32): Likewise.
5999 (__arm_vrshrntq_n_s32): Likewise.
6000 (__arm_vshrnbq_n_s32): Likewise.
6001 (__arm_vshrntq_n_s32): Likewise.
6002 (__arm_vmlaldavaq_s32): Likewise.
6003 (__arm_vmlaldavaxq_s32): Likewise.
6004 (__arm_vmlsldavaq_s32): Likewise.
6005 (__arm_vmlsldavaxq_s32): Likewise.
6006 (__arm_vmlaldavq_p_s32): Likewise.
6007 (__arm_vmlaldavxq_p_s32): Likewise.
6008 (__arm_vmlsldavq_p_s32): Likewise.
6009 (__arm_vmlsldavxq_p_s32): Likewise.
6010 (__arm_vmovlbq_m_s16): Likewise.
6011 (__arm_vmovltq_m_s16): Likewise.
6012 (__arm_vmovnbq_m_s32): Likewise.
6013 (__arm_vmovntq_m_s32): Likewise.
6014 (__arm_vqmovnbq_m_s32): Likewise.
6015 (__arm_vqmovntq_m_s32): Likewise.
6016 (__arm_vrev32q_m_s16): Likewise.
6017 (__arm_vmvnq_m_n_u32): Likewise.
6018 (__arm_vorrq_m_n_u32): Likewise.
6019 (__arm_vqrshruntq_n_s32): Likewise.
6020 (__arm_vqshrunbq_n_s32): Likewise.
6021 (__arm_vqshruntq_n_s32): Likewise.
6022 (__arm_vqmovunbq_m_s32): Likewise.
6023 (__arm_vqmovuntq_m_s32): Likewise.
6024 (__arm_vqrshrntq_n_u32): Likewise.
6025 (__arm_vqshrnbq_n_u32): Likewise.
6026 (__arm_vqshrntq_n_u32): Likewise.
6027 (__arm_vrshrnbq_n_u32): Likewise.
6028 (__arm_vrshrntq_n_u32): Likewise.
6029 (__arm_vshrnbq_n_u32): Likewise.
6030 (__arm_vshrntq_n_u32): Likewise.
6031 (__arm_vmlaldavaq_u32): Likewise.
6032 (__arm_vmlaldavaxq_u32): Likewise.
6033 (__arm_vmlaldavq_p_u32): Likewise.
6034 (__arm_vmlaldavxq_p_u32): Likewise.
6035 (__arm_vmovlbq_m_u16): Likewise.
6036 (__arm_vmovltq_m_u16): Likewise.
6037 (__arm_vmovnbq_m_u32): Likewise.
6038 (__arm_vmovntq_m_u32): Likewise.
6039 (__arm_vqmovnbq_m_u32): Likewise.
6040 (__arm_vqmovntq_m_u32): Likewise.
6041 (__arm_vrev32q_m_u16): Likewise.
6042 (__arm_vcvtbq_m_f16_f32): Likewise.
6043 (__arm_vcvtbq_m_f32_f16): Likewise.
6044 (__arm_vcvttq_m_f16_f32): Likewise.
6045 (__arm_vcvttq_m_f32_f16): Likewise.
6046 (__arm_vrev32q_m_f16): Likewise.
6047 (__arm_vcmlaq_f16): Likewise.
6048 (__arm_vcmlaq_rot180_f16): Likewise.
6049 (__arm_vcmlaq_rot270_f16): Likewise.
6050 (__arm_vcmlaq_rot90_f16): Likewise.
6051 (__arm_vfmaq_f16): Likewise.
6052 (__arm_vfmaq_n_f16): Likewise.
6053 (__arm_vfmasq_n_f16): Likewise.
6054 (__arm_vfmsq_f16): Likewise.
6055 (__arm_vabsq_m_f16): Likewise.
6056 (__arm_vcvtmq_m_s16_f16): Likewise.
6057 (__arm_vcvtnq_m_s16_f16): Likewise.
6058 (__arm_vcvtpq_m_s16_f16): Likewise.
6059 (__arm_vcvtq_m_s16_f16): Likewise.
6060 (__arm_vdupq_m_n_f16): Likewise.
6061 (__arm_vmaxnmaq_m_f16): Likewise.
6062 (__arm_vmaxnmavq_p_f16): Likewise.
6063 (__arm_vmaxnmvq_p_f16): Likewise.
6064 (__arm_vminnmaq_m_f16): Likewise.
6065 (__arm_vminnmavq_p_f16): Likewise.
6066 (__arm_vminnmvq_p_f16): Likewise.
6067 (__arm_vnegq_m_f16): Likewise.
6068 (__arm_vpselq_f16): Likewise.
6069 (__arm_vrev64q_m_f16): Likewise.
6070 (__arm_vrndaq_m_f16): Likewise.
6071 (__arm_vrndmq_m_f16): Likewise.
6072 (__arm_vrndnq_m_f16): Likewise.
6073 (__arm_vrndpq_m_f16): Likewise.
6074 (__arm_vrndq_m_f16): Likewise.
6075 (__arm_vrndxq_m_f16): Likewise.
6076 (__arm_vcmpeqq_m_n_f16): Likewise.
6077 (__arm_vcmpgeq_m_f16): Likewise.
6078 (__arm_vcmpgeq_m_n_f16): Likewise.
6079 (__arm_vcmpgtq_m_f16): Likewise.
6080 (__arm_vcmpgtq_m_n_f16): Likewise.
6081 (__arm_vcmpleq_m_f16): Likewise.
6082 (__arm_vcmpleq_m_n_f16): Likewise.
6083 (__arm_vcmpltq_m_f16): Likewise.
6084 (__arm_vcmpltq_m_n_f16): Likewise.
6085 (__arm_vcmpneq_m_f16): Likewise.
6086 (__arm_vcmpneq_m_n_f16): Likewise.
6087 (__arm_vcvtmq_m_u16_f16): Likewise.
6088 (__arm_vcvtnq_m_u16_f16): Likewise.
6089 (__arm_vcvtpq_m_u16_f16): Likewise.
6090 (__arm_vcvtq_m_u16_f16): Likewise.
6091 (__arm_vcmlaq_f32): Likewise.
6092 (__arm_vcmlaq_rot180_f32): Likewise.
6093 (__arm_vcmlaq_rot270_f32): Likewise.
6094 (__arm_vcmlaq_rot90_f32): Likewise.
6095 (__arm_vfmaq_f32): Likewise.
6096 (__arm_vfmaq_n_f32): Likewise.
6097 (__arm_vfmasq_n_f32): Likewise.
6098 (__arm_vfmsq_f32): Likewise.
6099 (__arm_vabsq_m_f32): Likewise.
6100 (__arm_vcvtmq_m_s32_f32): Likewise.
6101 (__arm_vcvtnq_m_s32_f32): Likewise.
6102 (__arm_vcvtpq_m_s32_f32): Likewise.
6103 (__arm_vcvtq_m_s32_f32): Likewise.
6104 (__arm_vdupq_m_n_f32): Likewise.
6105 (__arm_vmaxnmaq_m_f32): Likewise.
6106 (__arm_vmaxnmavq_p_f32): Likewise.
6107 (__arm_vmaxnmvq_p_f32): Likewise.
6108 (__arm_vminnmaq_m_f32): Likewise.
6109 (__arm_vminnmavq_p_f32): Likewise.
6110 (__arm_vminnmvq_p_f32): Likewise.
6111 (__arm_vnegq_m_f32): Likewise.
6112 (__arm_vpselq_f32): Likewise.
6113 (__arm_vrev64q_m_f32): Likewise.
6114 (__arm_vrndaq_m_f32): Likewise.
6115 (__arm_vrndmq_m_f32): Likewise.
6116 (__arm_vrndnq_m_f32): Likewise.
6117 (__arm_vrndpq_m_f32): Likewise.
6118 (__arm_vrndq_m_f32): Likewise.
6119 (__arm_vrndxq_m_f32): Likewise.
6120 (__arm_vcmpeqq_m_n_f32): Likewise.
6121 (__arm_vcmpgeq_m_f32): Likewise.
6122 (__arm_vcmpgeq_m_n_f32): Likewise.
6123 (__arm_vcmpgtq_m_f32): Likewise.
6124 (__arm_vcmpgtq_m_n_f32): Likewise.
6125 (__arm_vcmpleq_m_f32): Likewise.
6126 (__arm_vcmpleq_m_n_f32): Likewise.
6127 (__arm_vcmpltq_m_f32): Likewise.
6128 (__arm_vcmpltq_m_n_f32): Likewise.
6129 (__arm_vcmpneq_m_f32): Likewise.
6130 (__arm_vcmpneq_m_n_f32): Likewise.
6131 (__arm_vcvtmq_m_u32_f32): Likewise.
6132 (__arm_vcvtnq_m_u32_f32): Likewise.
6133 (__arm_vcvtpq_m_u32_f32): Likewise.
6134 (__arm_vcvtq_m_u32_f32): Likewise.
6135 (vcvtq_m): Define polymorphic variant.
6136 (vabsq_m): Likewise.
6137 (vcmlaq): Likewise.
6138 (vcmlaq_rot180): Likewise.
6139 (vcmlaq_rot270): Likewise.
6140 (vcmlaq_rot90): Likewise.
6141 (vcmpeqq_m_n): Likewise.
6142 (vcmpgeq_m_n): Likewise.
6143 (vrndxq_m): Likewise.
6144 (vrndq_m): Likewise.
6145 (vrndpq_m): Likewise.
6146 (vcmpgtq_m_n): Likewise.
6147 (vcmpgtq_m): Likewise.
6148 (vcmpleq_m): Likewise.
6149 (vcmpleq_m_n): Likewise.
6150 (vcmpltq_m_n): Likewise.
6151 (vcmpltq_m): Likewise.
6152 (vcmpneq_m): Likewise.
6153 (vcmpneq_m_n): Likewise.
6154 (vcvtbq_m): Likewise.
6155 (vcvttq_m): Likewise.
6156 (vcvtmq_m): Likewise.
6157 (vcvtnq_m): Likewise.
6158 (vcvtpq_m): Likewise.
6159 (vdupq_m_n): Likewise.
6160 (vfmaq_n): Likewise.
6161 (vfmaq): Likewise.
6162 (vfmasq_n): Likewise.
6163 (vfmsq): Likewise.
6164 (vmaxnmaq_m): Likewise.
6165 (vmaxnmavq_m): Likewise.
6166 (vmaxnmvq_m): Likewise.
6167 (vmaxnmavq_p): Likewise.
6168 (vmaxnmvq_p): Likewise.
6169 (vminnmaq_m): Likewise.
6170 (vminnmavq_p): Likewise.
6171 (vminnmvq_p): Likewise.
6172 (vrndnq_m): Likewise.
6173 (vrndaq_m): Likewise.
6174 (vrndmq_m): Likewise.
6175 (vrev64q_m): Likewise.
6176 (vrev32q_m): Likewise.
6177 (vpselq): Likewise.
6178 (vnegq_m): Likewise.
6179 (vcmpgeq_m): Likewise.
6180 (vshrntq_n): Likewise.
6181 (vrshrntq_n): Likewise.
6182 (vmovlbq_m): Likewise.
6183 (vmovnbq_m): Likewise.
6184 (vmovntq_m): Likewise.
6185 (vmvnq_m_n): Likewise.
6186 (vmvnq_m): Likewise.
6187 (vshrnbq_n): Likewise.
6188 (vrshrnbq_n): Likewise.
6189 (vqshruntq_n): Likewise.
6190 (vrev16q_m): Likewise.
6191 (vqshrunbq_n): Likewise.
6192 (vqshrntq_n): Likewise.
6193 (vqrshruntq_n): Likewise.
6194 (vqrshrntq_n): Likewise.
6195 (vqshrnbq_n): Likewise.
6196 (vqmovuntq_m): Likewise.
6197 (vqmovntq_m): Likewise.
6198 (vqmovnbq_m): Likewise.
6199 (vorrq_m_n): Likewise.
6200 (vmovltq_m): Likewise.
6201 (vqmovunbq_m): Likewise.
6202 (vaddlvaq_p): Likewise.
6203 (vmlaldavaq): Likewise.
6204 (vmlaldavaxq): Likewise.
6205 (vmlaldavq_p): Likewise.
6206 (vmlaldavxq_p): Likewise.
6207 (vmlsldavaq): Likewise.
6208 (vmlsldavaxq): Likewise.
6209 (vmlsldavq_p): Likewise.
6210 (vmlsldavxq_p): Likewise.
6211 (vrmlaldavhaxq): Likewise.
6212 (vrmlaldavhq_p): Likewise.
6213 (vrmlaldavhxq_p): Likewise.
6214 (vrmlsldavhaq): Likewise.
6215 (vrmlsldavhaxq): Likewise.
6216 (vrmlsldavhq_p): Likewise.
6217 (vrmlsldavhxq_p): Likewise.
6218 * config/arm/arm_mve_builtins.def (TERNOP_NONE_NONE_IMM_UNONE): Use
6219 builtin qualifier.
6220 (TERNOP_NONE_NONE_NONE_IMM): Likewise.
6221 (TERNOP_NONE_NONE_NONE_NONE): Likewise.
6222 (TERNOP_NONE_NONE_NONE_UNONE): Likewise.
6223 (TERNOP_UNONE_NONE_NONE_UNONE): Likewise.
6224 (TERNOP_UNONE_UNONE_IMM_UNONE): Likewise.
6225 (TERNOP_UNONE_UNONE_NONE_IMM): Likewise.
6226 (TERNOP_UNONE_UNONE_NONE_UNONE): Likewise.
6227 (TERNOP_UNONE_UNONE_UNONE_IMM): Likewise.
6228 (TERNOP_UNONE_UNONE_UNONE_UNONE): Likewise.
6229 * config/arm/mve.md (MVE_constraint3): Define mode attribute iterator.
6230 (MVE_pred3): Likewise.
6231 (MVE_constraint1): Likewise.
6232 (MVE_pred1): Likewise.
6233 (VMLALDAVQ_P): Define iterator.
6234 (VQMOVNBQ_M): Likewise.
6235 (VMOVLTQ_M): Likewise.
6236 (VMOVNBQ_M): Likewise.
6237 (VRSHRNTQ_N): Likewise.
6238 (VORRQ_M_N): Likewise.
6239 (VREV32Q_M): Likewise.
6240 (VREV16Q_M): Likewise.
6241 (VQRSHRNTQ_N): Likewise.
6242 (VMOVNTQ_M): Likewise.
6243 (VMOVLBQ_M): Likewise.
6244 (VMLALDAVAQ): Likewise.
6245 (VQSHRNBQ_N): Likewise.
6246 (VSHRNBQ_N): Likewise.
6247 (VRSHRNBQ_N): Likewise.
6248 (VMLALDAVXQ_P): Likewise.
6249 (VQMOVNTQ_M): Likewise.
6250 (VMVNQ_M_N): Likewise.
6251 (VQSHRNTQ_N): Likewise.
6252 (VMLALDAVAXQ): Likewise.
6253 (VSHRNTQ_N): Likewise.
6254 (VCVTMQ_M): Likewise.
6255 (VCVTNQ_M): Likewise.
6256 (VCVTPQ_M): Likewise.
6257 (VCVTQ_M_N_FROM_F): Likewise.
6258 (VCVTQ_M_FROM_F): Likewise.
6259 (VRMLALDAVHQ_P): Likewise.
6260 (VADDLVAQ_P): Likewise.
6261 (mve_vrndq_m_f<mode>): Define RTL pattern.
6262 (mve_vabsq_m_f<mode>): Likewise.
6263 (mve_vaddlvaq_p_<supf>v4si): Likewise.
6264 (mve_vcmlaq_f<mode>): Likewise.
6265 (mve_vcmlaq_rot180_f<mode>): Likewise.
6266 (mve_vcmlaq_rot270_f<mode>): Likewise.
6267 (mve_vcmlaq_rot90_f<mode>): Likewise.
6268 (mve_vcmpeqq_m_n_f<mode>): Likewise.
6269 (mve_vcmpgeq_m_f<mode>): Likewise.
6270 (mve_vcmpgeq_m_n_f<mode>): Likewise.
6271 (mve_vcmpgtq_m_f<mode>): Likewise.
6272 (mve_vcmpgtq_m_n_f<mode>): Likewise.
6273 (mve_vcmpleq_m_f<mode>): Likewise.
6274 (mve_vcmpleq_m_n_f<mode>): Likewise.
6275 (mve_vcmpltq_m_f<mode>): Likewise.
6276 (mve_vcmpltq_m_n_f<mode>): Likewise.
6277 (mve_vcmpneq_m_f<mode>): Likewise.
6278 (mve_vcmpneq_m_n_f<mode>): Likewise.
6279 (mve_vcvtbq_m_f16_f32v8hf): Likewise.
6280 (mve_vcvtbq_m_f32_f16v4sf): Likewise.
6281 (mve_vcvttq_m_f16_f32v8hf): Likewise.
6282 (mve_vcvttq_m_f32_f16v4sf): Likewise.
6283 (mve_vdupq_m_n_f<mode>): Likewise.
6284 (mve_vfmaq_f<mode>): Likewise.
6285 (mve_vfmaq_n_f<mode>): Likewise.
6286 (mve_vfmasq_n_f<mode>): Likewise.
6287 (mve_vfmsq_f<mode>): Likewise.
6288 (mve_vmaxnmaq_m_f<mode>): Likewise.
6289 (mve_vmaxnmavq_p_f<mode>): Likewise.
6290 (mve_vmaxnmvq_p_f<mode>): Likewise.
6291 (mve_vminnmaq_m_f<mode>): Likewise.
6292 (mve_vminnmavq_p_f<mode>): Likewise.
6293 (mve_vminnmvq_p_f<mode>): Likewise.
6294 (mve_vmlaldavaq_<supf><mode>): Likewise.
6295 (mve_vmlaldavaxq_<supf><mode>): Likewise.
6296 (mve_vmlaldavq_p_<supf><mode>): Likewise.
6297 (mve_vmlaldavxq_p_<supf><mode>): Likewise.
6298 (mve_vmlsldavaq_s<mode>): Likewise.
6299 (mve_vmlsldavaxq_s<mode>): Likewise.
6300 (mve_vmlsldavq_p_s<mode>): Likewise.
6301 (mve_vmlsldavxq_p_s<mode>): Likewise.
6302 (mve_vmovlbq_m_<supf><mode>): Likewise.
6303 (mve_vmovltq_m_<supf><mode>): Likewise.
6304 (mve_vmovnbq_m_<supf><mode>): Likewise.
6305 (mve_vmovntq_m_<supf><mode>): Likewise.
6306 (mve_vmvnq_m_n_<supf><mode>): Likewise.
6307 (mve_vnegq_m_f<mode>): Likewise.
6308 (mve_vorrq_m_n_<supf><mode>): Likewise.
6309 (mve_vpselq_f<mode>): Likewise.
6310 (mve_vqmovnbq_m_<supf><mode>): Likewise.
6311 (mve_vqmovntq_m_<supf><mode>): Likewise.
6312 (mve_vqmovunbq_m_s<mode>): Likewise.
6313 (mve_vqmovuntq_m_s<mode>): Likewise.
6314 (mve_vqrshrntq_n_<supf><mode>): Likewise.
6315 (mve_vqrshruntq_n_s<mode>): Likewise.
6316 (mve_vqshrnbq_n_<supf><mode>): Likewise.
6317 (mve_vqshrntq_n_<supf><mode>): Likewise.
6318 (mve_vqshrunbq_n_s<mode>): Likewise.
6319 (mve_vqshruntq_n_s<mode>): Likewise.
6320 (mve_vrev32q_m_fv8hf): Likewise.
6321 (mve_vrev32q_m_<supf><mode>): Likewise.
6322 (mve_vrev64q_m_f<mode>): Likewise.
6323 (mve_vrmlaldavhaxq_sv4si): Likewise.
6324 (mve_vrmlaldavhxq_p_sv4si): Likewise.
6325 (mve_vrmlsldavhaxq_sv4si): Likewise.
6326 (mve_vrmlsldavhq_p_sv4si): Likewise.
6327 (mve_vrmlsldavhxq_p_sv4si): Likewise.
6328 (mve_vrndaq_m_f<mode>): Likewise.
6329 (mve_vrndmq_m_f<mode>): Likewise.
6330 (mve_vrndnq_m_f<mode>): Likewise.
6331 (mve_vrndpq_m_f<mode>): Likewise.
6332 (mve_vrndxq_m_f<mode>): Likewise.
6333 (mve_vrshrnbq_n_<supf><mode>): Likewise.
6334 (mve_vrshrntq_n_<supf><mode>): Likewise.
6335 (mve_vshrnbq_n_<supf><mode>): Likewise.
6336 (mve_vshrntq_n_<supf><mode>): Likewise.
6337 (mve_vcvtmq_m_<supf><mode>): Likewise.
6338 (mve_vcvtpq_m_<supf><mode>): Likewise.
6339 (mve_vcvtnq_m_<supf><mode>): Likewise.
6340 (mve_vcvtq_m_n_from_f_<supf><mode>): Likewise.
6341 (mve_vrev16q_m_<supf>v16qi): Likewise.
6342 (mve_vcvtq_m_from_f_<supf><mode>): Likewise.
6343 (mve_vrmlaldavhq_p_<supf>v4si): Likewise.
6344 (mve_vrmlsldavhaq_sv4si): Likewise.
6345
6346 2020-03-18 Andre Vieira <andre.simoesdiasvieira@arm.com>
6347 Mihail Ionescu <mihail.ionescu@arm.com>
6348 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
6349
6350 * config/arm/arm_mve.h (vpselq_u8): Define macro.
6351 (vpselq_s8): Likewise.
6352 (vrev64q_m_u8): Likewise.
6353 (vqrdmlashq_n_u8): Likewise.
6354 (vqrdmlahq_n_u8): Likewise.
6355 (vqdmlahq_n_u8): Likewise.
6356 (vmvnq_m_u8): Likewise.
6357 (vmlasq_n_u8): Likewise.
6358 (vmlaq_n_u8): Likewise.
6359 (vmladavq_p_u8): Likewise.
6360 (vmladavaq_u8): Likewise.
6361 (vminvq_p_u8): Likewise.
6362 (vmaxvq_p_u8): Likewise.
6363 (vdupq_m_n_u8): Likewise.
6364 (vcmpneq_m_u8): Likewise.
6365 (vcmpneq_m_n_u8): Likewise.
6366 (vcmphiq_m_u8): Likewise.
6367 (vcmphiq_m_n_u8): Likewise.
6368 (vcmpeqq_m_u8): Likewise.
6369 (vcmpeqq_m_n_u8): Likewise.
6370 (vcmpcsq_m_u8): Likewise.
6371 (vcmpcsq_m_n_u8): Likewise.
6372 (vclzq_m_u8): Likewise.
6373 (vaddvaq_p_u8): Likewise.
6374 (vsriq_n_u8): Likewise.
6375 (vsliq_n_u8): Likewise.
6376 (vshlq_m_r_u8): Likewise.
6377 (vrshlq_m_n_u8): Likewise.
6378 (vqshlq_m_r_u8): Likewise.
6379 (vqrshlq_m_n_u8): Likewise.
6380 (vminavq_p_s8): Likewise.
6381 (vminaq_m_s8): Likewise.
6382 (vmaxavq_p_s8): Likewise.
6383 (vmaxaq_m_s8): Likewise.
6384 (vcmpneq_m_s8): Likewise.
6385 (vcmpneq_m_n_s8): Likewise.
6386 (vcmpltq_m_s8): Likewise.
6387 (vcmpltq_m_n_s8): Likewise.
6388 (vcmpleq_m_s8): Likewise.
6389 (vcmpleq_m_n_s8): Likewise.
6390 (vcmpgtq_m_s8): Likewise.
6391 (vcmpgtq_m_n_s8): Likewise.
6392 (vcmpgeq_m_s8): Likewise.
6393 (vcmpgeq_m_n_s8): Likewise.
6394 (vcmpeqq_m_s8): Likewise.
6395 (vcmpeqq_m_n_s8): Likewise.
6396 (vshlq_m_r_s8): Likewise.
6397 (vrshlq_m_n_s8): Likewise.
6398 (vrev64q_m_s8): Likewise.
6399 (vqshlq_m_r_s8): Likewise.
6400 (vqrshlq_m_n_s8): Likewise.
6401 (vqnegq_m_s8): Likewise.
6402 (vqabsq_m_s8): Likewise.
6403 (vnegq_m_s8): Likewise.
6404 (vmvnq_m_s8): Likewise.
6405 (vmlsdavxq_p_s8): Likewise.
6406 (vmlsdavq_p_s8): Likewise.
6407 (vmladavxq_p_s8): Likewise.
6408 (vmladavq_p_s8): Likewise.
6409 (vminvq_p_s8): Likewise.
6410 (vmaxvq_p_s8): Likewise.
6411 (vdupq_m_n_s8): Likewise.
6412 (vclzq_m_s8): Likewise.
6413 (vclsq_m_s8): Likewise.
6414 (vaddvaq_p_s8): Likewise.
6415 (vabsq_m_s8): Likewise.
6416 (vqrdmlsdhxq_s8): Likewise.
6417 (vqrdmlsdhq_s8): Likewise.
6418 (vqrdmlashq_n_s8): Likewise.
6419 (vqrdmlahq_n_s8): Likewise.
6420 (vqrdmladhxq_s8): Likewise.
6421 (vqrdmladhq_s8): Likewise.
6422 (vqdmlsdhxq_s8): Likewise.
6423 (vqdmlsdhq_s8): Likewise.
6424 (vqdmlahq_n_s8): Likewise.
6425 (vqdmladhxq_s8): Likewise.
6426 (vqdmladhq_s8): Likewise.
6427 (vmlsdavaxq_s8): Likewise.
6428 (vmlsdavaq_s8): Likewise.
6429 (vmlasq_n_s8): Likewise.
6430 (vmlaq_n_s8): Likewise.
6431 (vmladavaxq_s8): Likewise.
6432 (vmladavaq_s8): Likewise.
6433 (vsriq_n_s8): Likewise.
6434 (vsliq_n_s8): Likewise.
6435 (vpselq_u16): Likewise.
6436 (vpselq_s16): Likewise.
6437 (vrev64q_m_u16): Likewise.
6438 (vqrdmlashq_n_u16): Likewise.
6439 (vqrdmlahq_n_u16): Likewise.
6440 (vqdmlahq_n_u16): Likewise.
6441 (vmvnq_m_u16): Likewise.
6442 (vmlasq_n_u16): Likewise.
6443 (vmlaq_n_u16): Likewise.
6444 (vmladavq_p_u16): Likewise.
6445 (vmladavaq_u16): Likewise.
6446 (vminvq_p_u16): Likewise.
6447 (vmaxvq_p_u16): Likewise.
6448 (vdupq_m_n_u16): Likewise.
6449 (vcmpneq_m_u16): Likewise.
6450 (vcmpneq_m_n_u16): Likewise.
6451 (vcmphiq_m_u16): Likewise.
6452 (vcmphiq_m_n_u16): Likewise.
6453 (vcmpeqq_m_u16): Likewise.
6454 (vcmpeqq_m_n_u16): Likewise.
6455 (vcmpcsq_m_u16): Likewise.
6456 (vcmpcsq_m_n_u16): Likewise.
6457 (vclzq_m_u16): Likewise.
6458 (vaddvaq_p_u16): Likewise.
6459 (vsriq_n_u16): Likewise.
6460 (vsliq_n_u16): Likewise.
6461 (vshlq_m_r_u16): Likewise.
6462 (vrshlq_m_n_u16): Likewise.
6463 (vqshlq_m_r_u16): Likewise.
6464 (vqrshlq_m_n_u16): Likewise.
6465 (vminavq_p_s16): Likewise.
6466 (vminaq_m_s16): Likewise.
6467 (vmaxavq_p_s16): Likewise.
6468 (vmaxaq_m_s16): Likewise.
6469 (vcmpneq_m_s16): Likewise.
6470 (vcmpneq_m_n_s16): Likewise.
6471 (vcmpltq_m_s16): Likewise.
6472 (vcmpltq_m_n_s16): Likewise.
6473 (vcmpleq_m_s16): Likewise.
6474 (vcmpleq_m_n_s16): Likewise.
6475 (vcmpgtq_m_s16): Likewise.
6476 (vcmpgtq_m_n_s16): Likewise.
6477 (vcmpgeq_m_s16): Likewise.
6478 (vcmpgeq_m_n_s16): Likewise.
6479 (vcmpeqq_m_s16): Likewise.
6480 (vcmpeqq_m_n_s16): Likewise.
6481 (vshlq_m_r_s16): Likewise.
6482 (vrshlq_m_n_s16): Likewise.
6483 (vrev64q_m_s16): Likewise.
6484 (vqshlq_m_r_s16): Likewise.
6485 (vqrshlq_m_n_s16): Likewise.
6486 (vqnegq_m_s16): Likewise.
6487 (vqabsq_m_s16): Likewise.
6488 (vnegq_m_s16): Likewise.
6489 (vmvnq_m_s16): Likewise.
6490 (vmlsdavxq_p_s16): Likewise.
6491 (vmlsdavq_p_s16): Likewise.
6492 (vmladavxq_p_s16): Likewise.
6493 (vmladavq_p_s16): Likewise.
6494 (vminvq_p_s16): Likewise.
6495 (vmaxvq_p_s16): Likewise.
6496 (vdupq_m_n_s16): Likewise.
6497 (vclzq_m_s16): Likewise.
6498 (vclsq_m_s16): Likewise.
6499 (vaddvaq_p_s16): Likewise.
6500 (vabsq_m_s16): Likewise.
6501 (vqrdmlsdhxq_s16): Likewise.
6502 (vqrdmlsdhq_s16): Likewise.
6503 (vqrdmlashq_n_s16): Likewise.
6504 (vqrdmlahq_n_s16): Likewise.
6505 (vqrdmladhxq_s16): Likewise.
6506 (vqrdmladhq_s16): Likewise.
6507 (vqdmlsdhxq_s16): Likewise.
6508 (vqdmlsdhq_s16): Likewise.
6509 (vqdmlahq_n_s16): Likewise.
6510 (vqdmladhxq_s16): Likewise.
6511 (vqdmladhq_s16): Likewise.
6512 (vmlsdavaxq_s16): Likewise.
6513 (vmlsdavaq_s16): Likewise.
6514 (vmlasq_n_s16): Likewise.
6515 (vmlaq_n_s16): Likewise.
6516 (vmladavaxq_s16): Likewise.
6517 (vmladavaq_s16): Likewise.
6518 (vsriq_n_s16): Likewise.
6519 (vsliq_n_s16): Likewise.
6520 (vpselq_u32): Likewise.
6521 (vpselq_s32): Likewise.
6522 (vrev64q_m_u32): Likewise.
6523 (vqrdmlashq_n_u32): Likewise.
6524 (vqrdmlahq_n_u32): Likewise.
6525 (vqdmlahq_n_u32): Likewise.
6526 (vmvnq_m_u32): Likewise.
6527 (vmlasq_n_u32): Likewise.
6528 (vmlaq_n_u32): Likewise.
6529 (vmladavq_p_u32): Likewise.
6530 (vmladavaq_u32): Likewise.
6531 (vminvq_p_u32): Likewise.
6532 (vmaxvq_p_u32): Likewise.
6533 (vdupq_m_n_u32): Likewise.
6534 (vcmpneq_m_u32): Likewise.
6535 (vcmpneq_m_n_u32): Likewise.
6536 (vcmphiq_m_u32): Likewise.
6537 (vcmphiq_m_n_u32): Likewise.
6538 (vcmpeqq_m_u32): Likewise.
6539 (vcmpeqq_m_n_u32): Likewise.
6540 (vcmpcsq_m_u32): Likewise.
6541 (vcmpcsq_m_n_u32): Likewise.
6542 (vclzq_m_u32): Likewise.
6543 (vaddvaq_p_u32): Likewise.
6544 (vsriq_n_u32): Likewise.
6545 (vsliq_n_u32): Likewise.
6546 (vshlq_m_r_u32): Likewise.
6547 (vrshlq_m_n_u32): Likewise.
6548 (vqshlq_m_r_u32): Likewise.
6549 (vqrshlq_m_n_u32): Likewise.
6550 (vminavq_p_s32): Likewise.
6551 (vminaq_m_s32): Likewise.
6552 (vmaxavq_p_s32): Likewise.
6553 (vmaxaq_m_s32): Likewise.
6554 (vcmpneq_m_s32): Likewise.
6555 (vcmpneq_m_n_s32): Likewise.
6556 (vcmpltq_m_s32): Likewise.
6557 (vcmpltq_m_n_s32): Likewise.
6558 (vcmpleq_m_s32): Likewise.
6559 (vcmpleq_m_n_s32): Likewise.
6560 (vcmpgtq_m_s32): Likewise.
6561 (vcmpgtq_m_n_s32): Likewise.
6562 (vcmpgeq_m_s32): Likewise.
6563 (vcmpgeq_m_n_s32): Likewise.
6564 (vcmpeqq_m_s32): Likewise.
6565 (vcmpeqq_m_n_s32): Likewise.
6566 (vshlq_m_r_s32): Likewise.
6567 (vrshlq_m_n_s32): Likewise.
6568 (vrev64q_m_s32): Likewise.
6569 (vqshlq_m_r_s32): Likewise.
6570 (vqrshlq_m_n_s32): Likewise.
6571 (vqnegq_m_s32): Likewise.
6572 (vqabsq_m_s32): Likewise.
6573 (vnegq_m_s32): Likewise.
6574 (vmvnq_m_s32): Likewise.
6575 (vmlsdavxq_p_s32): Likewise.
6576 (vmlsdavq_p_s32): Likewise.
6577 (vmladavxq_p_s32): Likewise.
6578 (vmladavq_p_s32): Likewise.
6579 (vminvq_p_s32): Likewise.
6580 (vmaxvq_p_s32): Likewise.
6581 (vdupq_m_n_s32): Likewise.
6582 (vclzq_m_s32): Likewise.
6583 (vclsq_m_s32): Likewise.
6584 (vaddvaq_p_s32): Likewise.
6585 (vabsq_m_s32): Likewise.
6586 (vqrdmlsdhxq_s32): Likewise.
6587 (vqrdmlsdhq_s32): Likewise.
6588 (vqrdmlashq_n_s32): Likewise.
6589 (vqrdmlahq_n_s32): Likewise.
6590 (vqrdmladhxq_s32): Likewise.
6591 (vqrdmladhq_s32): Likewise.
6592 (vqdmlsdhxq_s32): Likewise.
6593 (vqdmlsdhq_s32): Likewise.
6594 (vqdmlahq_n_s32): Likewise.
6595 (vqdmladhxq_s32): Likewise.
6596 (vqdmladhq_s32): Likewise.
6597 (vmlsdavaxq_s32): Likewise.
6598 (vmlsdavaq_s32): Likewise.
6599 (vmlasq_n_s32): Likewise.
6600 (vmlaq_n_s32): Likewise.
6601 (vmladavaxq_s32): Likewise.
6602 (vmladavaq_s32): Likewise.
6603 (vsriq_n_s32): Likewise.
6604 (vsliq_n_s32): Likewise.
6605 (vpselq_u64): Likewise.
6606 (vpselq_s64): Likewise.
6607 (__arm_vpselq_u8): Define intrinsic.
6608 (__arm_vpselq_s8): Likewise.
6609 (__arm_vrev64q_m_u8): Likewise.
6610 (__arm_vqrdmlashq_n_u8): Likewise.
6611 (__arm_vqrdmlahq_n_u8): Likewise.
6612 (__arm_vqdmlahq_n_u8): Likewise.
6613 (__arm_vmvnq_m_u8): Likewise.
6614 (__arm_vmlasq_n_u8): Likewise.
6615 (__arm_vmlaq_n_u8): Likewise.
6616 (__arm_vmladavq_p_u8): Likewise.
6617 (__arm_vmladavaq_u8): Likewise.
6618 (__arm_vminvq_p_u8): Likewise.
6619 (__arm_vmaxvq_p_u8): Likewise.
6620 (__arm_vdupq_m_n_u8): Likewise.
6621 (__arm_vcmpneq_m_u8): Likewise.
6622 (__arm_vcmpneq_m_n_u8): Likewise.
6623 (__arm_vcmphiq_m_u8): Likewise.
6624 (__arm_vcmphiq_m_n_u8): Likewise.
6625 (__arm_vcmpeqq_m_u8): Likewise.
6626 (__arm_vcmpeqq_m_n_u8): Likewise.
6627 (__arm_vcmpcsq_m_u8): Likewise.
6628 (__arm_vcmpcsq_m_n_u8): Likewise.
6629 (__arm_vclzq_m_u8): Likewise.
6630 (__arm_vaddvaq_p_u8): Likewise.
6631 (__arm_vsriq_n_u8): Likewise.
6632 (__arm_vsliq_n_u8): Likewise.
6633 (__arm_vshlq_m_r_u8): Likewise.
6634 (__arm_vrshlq_m_n_u8): Likewise.
6635 (__arm_vqshlq_m_r_u8): Likewise.
6636 (__arm_vqrshlq_m_n_u8): Likewise.
6637 (__arm_vminavq_p_s8): Likewise.
6638 (__arm_vminaq_m_s8): Likewise.
6639 (__arm_vmaxavq_p_s8): Likewise.
6640 (__arm_vmaxaq_m_s8): Likewise.
6641 (__arm_vcmpneq_m_s8): Likewise.
6642 (__arm_vcmpneq_m_n_s8): Likewise.
6643 (__arm_vcmpltq_m_s8): Likewise.
6644 (__arm_vcmpltq_m_n_s8): Likewise.
6645 (__arm_vcmpleq_m_s8): Likewise.
6646 (__arm_vcmpleq_m_n_s8): Likewise.
6647 (__arm_vcmpgtq_m_s8): Likewise.
6648 (__arm_vcmpgtq_m_n_s8): Likewise.
6649 (__arm_vcmpgeq_m_s8): Likewise.
6650 (__arm_vcmpgeq_m_n_s8): Likewise.
6651 (__arm_vcmpeqq_m_s8): Likewise.
6652 (__arm_vcmpeqq_m_n_s8): Likewise.
6653 (__arm_vshlq_m_r_s8): Likewise.
6654 (__arm_vrshlq_m_n_s8): Likewise.
6655 (__arm_vrev64q_m_s8): Likewise.
6656 (__arm_vqshlq_m_r_s8): Likewise.
6657 (__arm_vqrshlq_m_n_s8): Likewise.
6658 (__arm_vqnegq_m_s8): Likewise.
6659 (__arm_vqabsq_m_s8): Likewise.
6660 (__arm_vnegq_m_s8): Likewise.
6661 (__arm_vmvnq_m_s8): Likewise.
6662 (__arm_vmlsdavxq_p_s8): Likewise.
6663 (__arm_vmlsdavq_p_s8): Likewise.
6664 (__arm_vmladavxq_p_s8): Likewise.
6665 (__arm_vmladavq_p_s8): Likewise.
6666 (__arm_vminvq_p_s8): Likewise.
6667 (__arm_vmaxvq_p_s8): Likewise.
6668 (__arm_vdupq_m_n_s8): Likewise.
6669 (__arm_vclzq_m_s8): Likewise.
6670 (__arm_vclsq_m_s8): Likewise.
6671 (__arm_vaddvaq_p_s8): Likewise.
6672 (__arm_vabsq_m_s8): Likewise.
6673 (__arm_vqrdmlsdhxq_s8): Likewise.
6674 (__arm_vqrdmlsdhq_s8): Likewise.
6675 (__arm_vqrdmlashq_n_s8): Likewise.
6676 (__arm_vqrdmlahq_n_s8): Likewise.
6677 (__arm_vqrdmladhxq_s8): Likewise.
6678 (__arm_vqrdmladhq_s8): Likewise.
6679 (__arm_vqdmlsdhxq_s8): Likewise.
6680 (__arm_vqdmlsdhq_s8): Likewise.
6681 (__arm_vqdmlahq_n_s8): Likewise.
6682 (__arm_vqdmladhxq_s8): Likewise.
6683 (__arm_vqdmladhq_s8): Likewise.
6684 (__arm_vmlsdavaxq_s8): Likewise.
6685 (__arm_vmlsdavaq_s8): Likewise.
6686 (__arm_vmlasq_n_s8): Likewise.
6687 (__arm_vmlaq_n_s8): Likewise.
6688 (__arm_vmladavaxq_s8): Likewise.
6689 (__arm_vmladavaq_s8): Likewise.
6690 (__arm_vsriq_n_s8): Likewise.
6691 (__arm_vsliq_n_s8): Likewise.
6692 (__arm_vpselq_u16): Likewise.
6693 (__arm_vpselq_s16): Likewise.
6694 (__arm_vrev64q_m_u16): Likewise.
6695 (__arm_vqrdmlashq_n_u16): Likewise.
6696 (__arm_vqrdmlahq_n_u16): Likewise.
6697 (__arm_vqdmlahq_n_u16): Likewise.
6698 (__arm_vmvnq_m_u16): Likewise.
6699 (__arm_vmlasq_n_u16): Likewise.
6700 (__arm_vmlaq_n_u16): Likewise.
6701 (__arm_vmladavq_p_u16): Likewise.
6702 (__arm_vmladavaq_u16): Likewise.
6703 (__arm_vminvq_p_u16): Likewise.
6704 (__arm_vmaxvq_p_u16): Likewise.
6705 (__arm_vdupq_m_n_u16): Likewise.
6706 (__arm_vcmpneq_m_u16): Likewise.
6707 (__arm_vcmpneq_m_n_u16): Likewise.
6708 (__arm_vcmphiq_m_u16): Likewise.
6709 (__arm_vcmphiq_m_n_u16): Likewise.
6710 (__arm_vcmpeqq_m_u16): Likewise.
6711 (__arm_vcmpeqq_m_n_u16): Likewise.
6712 (__arm_vcmpcsq_m_u16): Likewise.
6713 (__arm_vcmpcsq_m_n_u16): Likewise.
6714 (__arm_vclzq_m_u16): Likewise.
6715 (__arm_vaddvaq_p_u16): Likewise.
6716 (__arm_vsriq_n_u16): Likewise.
6717 (__arm_vsliq_n_u16): Likewise.
6718 (__arm_vshlq_m_r_u16): Likewise.
6719 (__arm_vrshlq_m_n_u16): Likewise.
6720 (__arm_vqshlq_m_r_u16): Likewise.
6721 (__arm_vqrshlq_m_n_u16): Likewise.
6722 (__arm_vminavq_p_s16): Likewise.
6723 (__arm_vminaq_m_s16): Likewise.
6724 (__arm_vmaxavq_p_s16): Likewise.
6725 (__arm_vmaxaq_m_s16): Likewise.
6726 (__arm_vcmpneq_m_s16): Likewise.
6727 (__arm_vcmpneq_m_n_s16): Likewise.
6728 (__arm_vcmpltq_m_s16): Likewise.
6729 (__arm_vcmpltq_m_n_s16): Likewise.
6730 (__arm_vcmpleq_m_s16): Likewise.
6731 (__arm_vcmpleq_m_n_s16): Likewise.
6732 (__arm_vcmpgtq_m_s16): Likewise.
6733 (__arm_vcmpgtq_m_n_s16): Likewise.
6734 (__arm_vcmpgeq_m_s16): Likewise.
6735 (__arm_vcmpgeq_m_n_s16): Likewise.
6736 (__arm_vcmpeqq_m_s16): Likewise.
6737 (__arm_vcmpeqq_m_n_s16): Likewise.
6738 (__arm_vshlq_m_r_s16): Likewise.
6739 (__arm_vrshlq_m_n_s16): Likewise.
6740 (__arm_vrev64q_m_s16): Likewise.
6741 (__arm_vqshlq_m_r_s16): Likewise.
6742 (__arm_vqrshlq_m_n_s16): Likewise.
6743 (__arm_vqnegq_m_s16): Likewise.
6744 (__arm_vqabsq_m_s16): Likewise.
6745 (__arm_vnegq_m_s16): Likewise.
6746 (__arm_vmvnq_m_s16): Likewise.
6747 (__arm_vmlsdavxq_p_s16): Likewise.
6748 (__arm_vmlsdavq_p_s16): Likewise.
6749 (__arm_vmladavxq_p_s16): Likewise.
6750 (__arm_vmladavq_p_s16): Likewise.
6751 (__arm_vminvq_p_s16): Likewise.
6752 (__arm_vmaxvq_p_s16): Likewise.
6753 (__arm_vdupq_m_n_s16): Likewise.
6754 (__arm_vclzq_m_s16): Likewise.
6755 (__arm_vclsq_m_s16): Likewise.
6756 (__arm_vaddvaq_p_s16): Likewise.
6757 (__arm_vabsq_m_s16): Likewise.
6758 (__arm_vqrdmlsdhxq_s16): Likewise.
6759 (__arm_vqrdmlsdhq_s16): Likewise.
6760 (__arm_vqrdmlashq_n_s16): Likewise.
6761 (__arm_vqrdmlahq_n_s16): Likewise.
6762 (__arm_vqrdmladhxq_s16): Likewise.
6763 (__arm_vqrdmladhq_s16): Likewise.
6764 (__arm_vqdmlsdhxq_s16): Likewise.
6765 (__arm_vqdmlsdhq_s16): Likewise.
6766 (__arm_vqdmlahq_n_s16): Likewise.
6767 (__arm_vqdmladhxq_s16): Likewise.
6768 (__arm_vqdmladhq_s16): Likewise.
6769 (__arm_vmlsdavaxq_s16): Likewise.
6770 (__arm_vmlsdavaq_s16): Likewise.
6771 (__arm_vmlasq_n_s16): Likewise.
6772 (__arm_vmlaq_n_s16): Likewise.
6773 (__arm_vmladavaxq_s16): Likewise.
6774 (__arm_vmladavaq_s16): Likewise.
6775 (__arm_vsriq_n_s16): Likewise.
6776 (__arm_vsliq_n_s16): Likewise.
6777 (__arm_vpselq_u32): Likewise.
6778 (__arm_vpselq_s32): Likewise.
6779 (__arm_vrev64q_m_u32): Likewise.
6780 (__arm_vqrdmlashq_n_u32): Likewise.
6781 (__arm_vqrdmlahq_n_u32): Likewise.
6782 (__arm_vqdmlahq_n_u32): Likewise.
6783 (__arm_vmvnq_m_u32): Likewise.
6784 (__arm_vmlasq_n_u32): Likewise.
6785 (__arm_vmlaq_n_u32): Likewise.
6786 (__arm_vmladavq_p_u32): Likewise.
6787 (__arm_vmladavaq_u32): Likewise.
6788 (__arm_vminvq_p_u32): Likewise.
6789 (__arm_vmaxvq_p_u32): Likewise.
6790 (__arm_vdupq_m_n_u32): Likewise.
6791 (__arm_vcmpneq_m_u32): Likewise.
6792 (__arm_vcmpneq_m_n_u32): Likewise.
6793 (__arm_vcmphiq_m_u32): Likewise.
6794 (__arm_vcmphiq_m_n_u32): Likewise.
6795 (__arm_vcmpeqq_m_u32): Likewise.
6796 (__arm_vcmpeqq_m_n_u32): Likewise.
6797 (__arm_vcmpcsq_m_u32): Likewise.
6798 (__arm_vcmpcsq_m_n_u32): Likewise.
6799 (__arm_vclzq_m_u32): Likewise.
6800 (__arm_vaddvaq_p_u32): Likewise.
6801 (__arm_vsriq_n_u32): Likewise.
6802 (__arm_vsliq_n_u32): Likewise.
6803 (__arm_vshlq_m_r_u32): Likewise.
6804 (__arm_vrshlq_m_n_u32): Likewise.
6805 (__arm_vqshlq_m_r_u32): Likewise.
6806 (__arm_vqrshlq_m_n_u32): Likewise.
6807 (__arm_vminavq_p_s32): Likewise.
6808 (__arm_vminaq_m_s32): Likewise.
6809 (__arm_vmaxavq_p_s32): Likewise.
6810 (__arm_vmaxaq_m_s32): Likewise.
6811 (__arm_vcmpneq_m_s32): Likewise.
6812 (__arm_vcmpneq_m_n_s32): Likewise.
6813 (__arm_vcmpltq_m_s32): Likewise.
6814 (__arm_vcmpltq_m_n_s32): Likewise.
6815 (__arm_vcmpleq_m_s32): Likewise.
6816 (__arm_vcmpleq_m_n_s32): Likewise.
6817 (__arm_vcmpgtq_m_s32): Likewise.
6818 (__arm_vcmpgtq_m_n_s32): Likewise.
6819 (__arm_vcmpgeq_m_s32): Likewise.
6820 (__arm_vcmpgeq_m_n_s32): Likewise.
6821 (__arm_vcmpeqq_m_s32): Likewise.
6822 (__arm_vcmpeqq_m_n_s32): Likewise.
6823 (__arm_vshlq_m_r_s32): Likewise.
6824 (__arm_vrshlq_m_n_s32): Likewise.
6825 (__arm_vrev64q_m_s32): Likewise.
6826 (__arm_vqshlq_m_r_s32): Likewise.
6827 (__arm_vqrshlq_m_n_s32): Likewise.
6828 (__arm_vqnegq_m_s32): Likewise.
6829 (__arm_vqabsq_m_s32): Likewise.
6830 (__arm_vnegq_m_s32): Likewise.
6831 (__arm_vmvnq_m_s32): Likewise.
6832 (__arm_vmlsdavxq_p_s32): Likewise.
6833 (__arm_vmlsdavq_p_s32): Likewise.
6834 (__arm_vmladavxq_p_s32): Likewise.
6835 (__arm_vmladavq_p_s32): Likewise.
6836 (__arm_vminvq_p_s32): Likewise.
6837 (__arm_vmaxvq_p_s32): Likewise.
6838 (__arm_vdupq_m_n_s32): Likewise.
6839 (__arm_vclzq_m_s32): Likewise.
6840 (__arm_vclsq_m_s32): Likewise.
6841 (__arm_vaddvaq_p_s32): Likewise.
6842 (__arm_vabsq_m_s32): Likewise.
6843 (__arm_vqrdmlsdhxq_s32): Likewise.
6844 (__arm_vqrdmlsdhq_s32): Likewise.
6845 (__arm_vqrdmlashq_n_s32): Likewise.
6846 (__arm_vqrdmlahq_n_s32): Likewise.
6847 (__arm_vqrdmladhxq_s32): Likewise.
6848 (__arm_vqrdmladhq_s32): Likewise.
6849 (__arm_vqdmlsdhxq_s32): Likewise.
6850 (__arm_vqdmlsdhq_s32): Likewise.
6851 (__arm_vqdmlahq_n_s32): Likewise.
6852 (__arm_vqdmladhxq_s32): Likewise.
6853 (__arm_vqdmladhq_s32): Likewise.
6854 (__arm_vmlsdavaxq_s32): Likewise.
6855 (__arm_vmlsdavaq_s32): Likewise.
6856 (__arm_vmlasq_n_s32): Likewise.
6857 (__arm_vmlaq_n_s32): Likewise.
6858 (__arm_vmladavaxq_s32): Likewise.
6859 (__arm_vmladavaq_s32): Likewise.
6860 (__arm_vsriq_n_s32): Likewise.
6861 (__arm_vsliq_n_s32): Likewise.
6862 (__arm_vpselq_u64): Likewise.
6863 (__arm_vpselq_s64): Likewise.
6864 (vcmpneq_m_n): Define polymorphic variant.
6865 (vcmpneq_m): Likewise.
6866 (vqrdmlsdhq): Likewise.
6867 (vqrdmlsdhxq): Likewise.
6868 (vqrshlq_m_n): Likewise.
6869 (vqshlq_m_r): Likewise.
6870 (vrev64q_m): Likewise.
6871 (vrshlq_m_n): Likewise.
6872 (vshlq_m_r): Likewise.
6873 (vsliq_n): Likewise.
6874 (vsriq_n): Likewise.
6875 (vqrdmlashq_n): Likewise.
6876 (vqrdmlahq): Likewise.
6877 (vqrdmladhxq): Likewise.
6878 (vqrdmladhq): Likewise.
6879 (vqnegq_m): Likewise.
6880 (vqdmlsdhxq): Likewise.
6881 (vabsq_m): Likewise.
6882 (vclsq_m): Likewise.
6883 (vclzq_m): Likewise.
6884 (vcmpgeq_m): Likewise.
6885 (vcmpgeq_m_n): Likewise.
6886 (vdupq_m_n): Likewise.
6887 (vmaxaq_m): Likewise.
6888 (vmlaq_n): Likewise.
6889 (vmlasq_n): Likewise.
6890 (vmvnq_m): Likewise.
6891 (vnegq_m): Likewise.
6892 (vpselq): Likewise.
6893 (vqdmlahq_n): Likewise.
6894 (vqrdmlahq_n): Likewise.
6895 (vqdmlsdhq): Likewise.
6896 (vqdmladhq): Likewise.
6897 (vqabsq_m): Likewise.
6898 (vminaq_m): Likewise.
6899 (vrmlaldavhaq): Likewise.
6900 (vmlsdavxq_p): Likewise.
6901 (vmlsdavq_p): Likewise.
6902 (vmlsdavaxq): Likewise.
6903 (vmlsdavaq): Likewise.
6904 (vaddvaq_p): Likewise.
6905 (vcmpcsq_m_n): Likewise.
6906 (vcmpcsq_m): Likewise.
6907 (vcmpeqq_m_n): Likewise.
6908 (vcmpeqq_m): Likewise.
6909 (vmladavxq_p): Likewise.
6910 (vmladavq_p): Likewise.
6911 (vmladavaxq): Likewise.
6912 (vmladavaq): Likewise.
6913 (vminvq_p): Likewise.
6914 (vminavq_p): Likewise.
6915 (vmaxvq_p): Likewise.
6916 (vmaxavq_p): Likewise.
6917 (vcmpltq_m_n): Likewise.
6918 (vcmpltq_m): Likewise.
6919 (vcmpleq_m): Likewise.
6920 (vcmpleq_m_n): Likewise.
6921 (vcmphiq_m_n): Likewise.
6922 (vcmphiq_m): Likewise.
6923 (vcmpgtq_m_n): Likewise.
6924 (vcmpgtq_m): Likewise.
6925 * config/arm/arm_mve_builtins.def (TERNOP_NONE_NONE_NONE_IMM): Use
6926 builtin qualifier.
6927 (TERNOP_NONE_NONE_NONE_NONE): Likewise.
6928 (TERNOP_NONE_NONE_NONE_UNONE): Likewise.
6929 (TERNOP_UNONE_NONE_NONE_UNONE): Likewise.
6930 (TERNOP_UNONE_UNONE_NONE_UNONE): Likewise.
6931 (TERNOP_UNONE_UNONE_UNONE_IMM): Likewise.
6932 (TERNOP_UNONE_UNONE_UNONE_UNONE): Likewise.
6933 * config/arm/constraints.md (Rc): Define constraint to check constant is
6934 in the range of 0 to 15.
6935 (Re): Define constraint to check constant is in the range of 0 to 31.
6936 * config/arm/mve.md (VADDVAQ_P): Define iterator.
6937 (VCLZQ_M): Likewise.
6938 (VCMPEQQ_M_N): Likewise.
6939 (VCMPEQQ_M): Likewise.
6940 (VCMPNEQ_M_N): Likewise.
6941 (VCMPNEQ_M): Likewise.
6942 (VDUPQ_M_N): Likewise.
6943 (VMAXVQ_P): Likewise.
6944 (VMINVQ_P): Likewise.
6945 (VMLADAVAQ): Likewise.
6946 (VMLADAVQ_P): Likewise.
6947 (VMLAQ_N): Likewise.
6948 (VMLASQ_N): Likewise.
6949 (VMVNQ_M): Likewise.
6950 (VPSELQ): Likewise.
6951 (VQDMLAHQ_N): Likewise.
6952 (VQRDMLAHQ_N): Likewise.
6953 (VQRDMLASHQ_N): Likewise.
6954 (VQRSHLQ_M_N): Likewise.
6955 (VQSHLQ_M_R): Likewise.
6956 (VREV64Q_M): Likewise.
6957 (VRSHLQ_M_N): Likewise.
6958 (VSHLQ_M_R): Likewise.
6959 (VSLIQ_N): Likewise.
6960 (VSRIQ_N): Likewise.
6961 (mve_vabsq_m_s<mode>): Define RTL pattern.
6962 (mve_vaddvaq_p_<supf><mode>): Likewise.
6963 (mve_vclsq_m_s<mode>): Likewise.
6964 (mve_vclzq_m_<supf><mode>): Likewise.
6965 (mve_vcmpcsq_m_n_u<mode>): Likewise.
6966 (mve_vcmpcsq_m_u<mode>): Likewise.
6967 (mve_vcmpeqq_m_n_<supf><mode>): Likewise.
6968 (mve_vcmpeqq_m_<supf><mode>): Likewise.
6969 (mve_vcmpgeq_m_n_s<mode>): Likewise.
6970 (mve_vcmpgeq_m_s<mode>): Likewise.
6971 (mve_vcmpgtq_m_n_s<mode>): Likewise.
6972 (mve_vcmpgtq_m_s<mode>): Likewise.
6973 (mve_vcmphiq_m_n_u<mode>): Likewise.
6974 (mve_vcmphiq_m_u<mode>): Likewise.
6975 (mve_vcmpleq_m_n_s<mode>): Likewise.
6976 (mve_vcmpleq_m_s<mode>): Likewise.
6977 (mve_vcmpltq_m_n_s<mode>): Likewise.
6978 (mve_vcmpltq_m_s<mode>): Likewise.
6979 (mve_vcmpneq_m_n_<supf><mode>): Likewise.
6980 (mve_vcmpneq_m_<supf><mode>): Likewise.
6981 (mve_vdupq_m_n_<supf><mode>): Likewise.
6982 (mve_vmaxaq_m_s<mode>): Likewise.
6983 (mve_vmaxavq_p_s<mode>): Likewise.
6984 (mve_vmaxvq_p_<supf><mode>): Likewise.
6985 (mve_vminaq_m_s<mode>): Likewise.
6986 (mve_vminavq_p_s<mode>): Likewise.
6987 (mve_vminvq_p_<supf><mode>): Likewise.
6988 (mve_vmladavaq_<supf><mode>): Likewise.
6989 (mve_vmladavq_p_<supf><mode>): Likewise.
6990 (mve_vmladavxq_p_s<mode>): Likewise.
6991 (mve_vmlaq_n_<supf><mode>): Likewise.
6992 (mve_vmlasq_n_<supf><mode>): Likewise.
6993 (mve_vmlsdavq_p_s<mode>): Likewise.
6994 (mve_vmlsdavxq_p_s<mode>): Likewise.
6995 (mve_vmvnq_m_<supf><mode>): Likewise.
6996 (mve_vnegq_m_s<mode>): Likewise.
6997 (mve_vpselq_<supf><mode>): Likewise.
6998 (mve_vqabsq_m_s<mode>): Likewise.
6999 (mve_vqdmlahq_n_<supf><mode>): Likewise.
7000 (mve_vqnegq_m_s<mode>): Likewise.
7001 (mve_vqrdmladhq_s<mode>): Likewise.
7002 (mve_vqrdmladhxq_s<mode>): Likewise.
7003 (mve_vqrdmlahq_n_<supf><mode>): Likewise.
7004 (mve_vqrdmlashq_n_<supf><mode>): Likewise.
7005 (mve_vqrdmlsdhq_s<mode>): Likewise.
7006 (mve_vqrdmlsdhxq_s<mode>): Likewise.
7007 (mve_vqrshlq_m_n_<supf><mode>): Likewise.
7008 (mve_vqshlq_m_r_<supf><mode>): Likewise.
7009 (mve_vrev64q_m_<supf><mode>): Likewise.
7010 (mve_vrshlq_m_n_<supf><mode>): Likewise.
7011 (mve_vshlq_m_r_<supf><mode>): Likewise.
7012 (mve_vsliq_n_<supf><mode>): Likewise.
7013 (mve_vsriq_n_<supf><mode>): Likewise.
7014 (mve_vqdmlsdhxq_s<mode>): Likewise.
7015 (mve_vqdmlsdhq_s<mode>): Likewise.
7016 (mve_vqdmladhxq_s<mode>): Likewise.
7017 (mve_vqdmladhq_s<mode>): Likewise.
7018 (mve_vmlsdavaxq_s<mode>): Likewise.
7019 (mve_vmlsdavaq_s<mode>): Likewise.
7020 (mve_vmladavaxq_s<mode>): Likewise.
7021 * config/arm/predicates.md (mve_imm_15):Define predicate to check the
7022 matching constraint Rc.
7023 (mve_imm_31): Define predicate to check the matching constraint Re.
7024
7025 2020-03-18 Andrew Stubbs <ams@codesourcery.com>
7026
7027 * config/gcn/gcn-valu.md (vec_cmp<mode>di): Set operand 1 to DImode.
7028 (vec_cmp<mode>di_dup): Likewise.
7029 * config/gcn/gcn.h (STORE_FLAG_VALUE): Set to -1.
7030
7031 2020-03-18 Andrew Stubbs <ams@codesourcery.com>
7032
7033 * config/gcn/gcn-valu.md (COND_MODE): Delete.
7034 (COND_INT_MODE): Delete.
7035 (cond_op): Add "mult".
7036 (cond_<expander><mode>): Use VEC_ALLREG_MODE.
7037 (cond_<expander><mode>): Use VEC_ALLREG_INT_MODE.
7038
7039 2020-03-18 Richard Biener <rguenther@suse.de>
7040
7041 PR middle-end/94206
7042 * gimple-fold.c (gimple_fold_builtin_memset): Avoid using
7043 partial int modes or not mode-precision integer types for
7044 the store.
7045
7046 2020-03-18 Jakub Jelinek <jakub@redhat.com>
7047
7048 * asan.c (get_mem_refs_of_builtin_call): Fix up duplicated word issue
7049 in a comment.
7050 * config/arc/arc.c (frame_stack_add): Likewise.
7051 * gimple-loop-versioning.cc (loop_versioning::analyze_arbitrary_term):
7052 Likewise.
7053 * ipa-predicate.c (predicate::remap_after_inlining): Likewise.
7054 * tree-ssa-strlen.h (handle_printf_call): Likewise.
7055 * tree-ssa-strlen.c (is_strlen_related_p): Likewise.
7056 * optinfo-emit-json.cc (optrecord_json_writer::add_record): Likewise.
7057
7058 2020-03-18 Duan bo <duanbo3@huawei.com>
7059
7060 PR target/94201
7061 * config/aarch64/aarch64.md (ldr_got_tiny): Delete.
7062 (@ldr_got_tiny_<mode>): New pattern.
7063 (ldr_got_tiny_sidi): Likewise.
7064 * config/aarch64/aarch64.c (aarch64_load_symref_appropriately): Use
7065 them to handle SYMBOL_TINY_GOT for ILP32.
7066
7067 2020-03-18 Richard Sandiford <richard.sandiford@arm.com>
7068
7069 * config/aarch64/aarch64.c (aarch64_sve_abi): Treat p12-p15 as
7070 call-preserved for SVE PCS functions.
7071 (aarch64_layout_frame): Cope with up to 12 predicate save slots.
7072 Optimize the case in which there are no following vector save slots.
7073
7074 2020-03-18 Richard Biener <rguenther@suse.de>
7075
7076 PR middle-end/94188
7077 * fold-const.c (build_fold_addr_expr): Convert address to
7078 correct type.
7079 * asan.c (maybe_create_ssa_name): Strip useless type conversions.
7080 * gimple-fold.c (gimple_fold_stmt_to_constant_1): Use build1
7081 to build the ADDR_EXPR which we don't really want to simplify.
7082 * tree-ssa-dom.c (record_equivalences_from_stmt): Likewise.
7083 * tree-ssa-loop-im.c (gather_mem_refs_stmt): Likewise.
7084 * tree-ssa-forwprop.c (forward_propagate_addr_expr_1): Likewise.
7085 (simplify_builtin_call): Strip useless type conversions.
7086 * tree-ssa-strlen.c (new_strinfo): Likewise.
7087
7088 2020-03-17 Alexey Neyman <stilor@att.net>
7089
7090 PR debug/93751
7091 * dwarf2out.c (gen_decl_die): Proceed to generating the DIE if
7092 the debug level is terse and the declaration is public. Do not
7093 generate type info.
7094 (dwarf2out_decl): Same.
7095 (add_type_attribute): Return immediately if debug level is
7096 terse.
7097
7098 2020-03-17 Richard Sandiford <richard.sandiford@arm.com>
7099
7100 * config/aarch64/iterators.md (Vmtype): Handle V4BF and V8BF.
7101
7102 2020-03-17 Andre Vieira <andre.simoesdiasvieira@arm.com>
7103 Mihail Ionescu <mihail.ionescu@arm.com>
7104 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
7105
7106 * config/arm/arm-builtins.c (TERNOP_UNONE_UNONE_UNONE_IMM_QUALIFIERS):
7107 Define qualifier for ternary operands.
7108 (TERNOP_UNONE_UNONE_NONE_NONE_QUALIFIERS): Likewise.
7109 (TERNOP_UNONE_NONE_UNONE_IMM_QUALIFIERS): Likewise.
7110 (TERNOP_NONE_NONE_UNONE_IMM_QUALIFIERS): Likewise.
7111 (TERNOP_UNONE_UNONE_NONE_IMM_QUALIFIERS): Likewise.
7112 (TERNOP_UNONE_UNONE_NONE_UNONE_QUALIFIERS): Likewise.
7113 (TERNOP_UNONE_UNONE_IMM_UNONE_QUALIFIERS): Likewise.
7114 (TERNOP_UNONE_NONE_NONE_UNONE_QUALIFIERS): Likewise.
7115 (TERNOP_NONE_NONE_NONE_IMM_QUALIFIERS): Likewise.
7116 (TERNOP_NONE_NONE_NONE_UNONE_QUALIFIERS): Likewise.
7117 (TERNOP_NONE_NONE_IMM_UNONE_QUALIFIERS): Likewise.
7118 (TERNOP_NONE_NONE_UNONE_UNONE_QUALIFIERS): Likewise.
7119 (TERNOP_UNONE_UNONE_UNONE_UNONE_QUALIFIERS): Likewise.
7120 (TERNOP_NONE_NONE_NONE_NONE_QUALIFIERS): Likewise.
7121 * config/arm/arm_mve.h (vabavq_s8): Define macro.
7122 (vabavq_s16): Likewise.
7123 (vabavq_s32): Likewise.
7124 (vbicq_m_n_s16): Likewise.
7125 (vbicq_m_n_s32): Likewise.
7126 (vbicq_m_n_u16): Likewise.
7127 (vbicq_m_n_u32): Likewise.
7128 (vcmpeqq_m_f16): Likewise.
7129 (vcmpeqq_m_f32): Likewise.
7130 (vcvtaq_m_s16_f16): Likewise.
7131 (vcvtaq_m_u16_f16): Likewise.
7132 (vcvtaq_m_s32_f32): Likewise.
7133 (vcvtaq_m_u32_f32): Likewise.
7134 (vcvtq_m_f16_s16): Likewise.
7135 (vcvtq_m_f16_u16): Likewise.
7136 (vcvtq_m_f32_s32): Likewise.
7137 (vcvtq_m_f32_u32): Likewise.
7138 (vqrshrnbq_n_s16): Likewise.
7139 (vqrshrnbq_n_u16): Likewise.
7140 (vqrshrnbq_n_s32): Likewise.
7141 (vqrshrnbq_n_u32): Likewise.
7142 (vqrshrunbq_n_s16): Likewise.
7143 (vqrshrunbq_n_s32): Likewise.
7144 (vrmlaldavhaq_s32): Likewise.
7145 (vrmlaldavhaq_u32): Likewise.
7146 (vshlcq_s8): Likewise.
7147 (vshlcq_u8): Likewise.
7148 (vshlcq_s16): Likewise.
7149 (vshlcq_u16): Likewise.
7150 (vshlcq_s32): Likewise.
7151 (vshlcq_u32): Likewise.
7152 (vabavq_u8): Likewise.
7153 (vabavq_u16): Likewise.
7154 (vabavq_u32): Likewise.
7155 (__arm_vabavq_s8): Define intrinsic.
7156 (__arm_vabavq_s16): Likewise.
7157 (__arm_vabavq_s32): Likewise.
7158 (__arm_vabavq_u8): Likewise.
7159 (__arm_vabavq_u16): Likewise.
7160 (__arm_vabavq_u32): Likewise.
7161 (__arm_vbicq_m_n_s16): Likewise.
7162 (__arm_vbicq_m_n_s32): Likewise.
7163 (__arm_vbicq_m_n_u16): Likewise.
7164 (__arm_vbicq_m_n_u32): Likewise.
7165 (__arm_vqrshrnbq_n_s16): Likewise.
7166 (__arm_vqrshrnbq_n_u16): Likewise.
7167 (__arm_vqrshrnbq_n_s32): Likewise.
7168 (__arm_vqrshrnbq_n_u32): Likewise.
7169 (__arm_vqrshrunbq_n_s16): Likewise.
7170 (__arm_vqrshrunbq_n_s32): Likewise.
7171 (__arm_vrmlaldavhaq_s32): Likewise.
7172 (__arm_vrmlaldavhaq_u32): Likewise.
7173 (__arm_vshlcq_s8): Likewise.
7174 (__arm_vshlcq_u8): Likewise.
7175 (__arm_vshlcq_s16): Likewise.
7176 (__arm_vshlcq_u16): Likewise.
7177 (__arm_vshlcq_s32): Likewise.
7178 (__arm_vshlcq_u32): Likewise.
7179 (__arm_vcmpeqq_m_f16): Likewise.
7180 (__arm_vcmpeqq_m_f32): Likewise.
7181 (__arm_vcvtaq_m_s16_f16): Likewise.
7182 (__arm_vcvtaq_m_u16_f16): Likewise.
7183 (__arm_vcvtaq_m_s32_f32): Likewise.
7184 (__arm_vcvtaq_m_u32_f32): Likewise.
7185 (__arm_vcvtq_m_f16_s16): Likewise.
7186 (__arm_vcvtq_m_f16_u16): Likewise.
7187 (__arm_vcvtq_m_f32_s32): Likewise.
7188 (__arm_vcvtq_m_f32_u32): Likewise.
7189 (vcvtaq_m): Define polymorphic variant.
7190 (vcvtq_m): Likewise.
7191 (vabavq): Likewise.
7192 (vshlcq): Likewise.
7193 (vbicq_m_n): Likewise.
7194 (vqrshrnbq_n): Likewise.
7195 (vqrshrunbq_n): Likewise.
7196 * config/arm/arm_mve_builtins.def
7197 (TERNOP_UNONE_UNONE_UNONE_IMM_QUALIFIERS): Use the builtin qualifer.
7198 (TERNOP_UNONE_UNONE_NONE_NONE_QUALIFIERS): Likewise.
7199 (TERNOP_UNONE_NONE_UNONE_IMM_QUALIFIERS): Likewise.
7200 (TERNOP_NONE_NONE_UNONE_IMM_QUALIFIERS): Likewise.
7201 (TERNOP_UNONE_UNONE_NONE_IMM_QUALIFIERS): Likewise.
7202 (TERNOP_UNONE_UNONE_NONE_UNONE_QUALIFIERS): Likewise.
7203 (TERNOP_UNONE_UNONE_IMM_UNONE_QUALIFIERS): Likewise.
7204 (TERNOP_UNONE_NONE_NONE_UNONE_QUALIFIERS): Likewise.
7205 (TERNOP_NONE_NONE_NONE_IMM_QUALIFIERS): Likewise.
7206 (TERNOP_NONE_NONE_NONE_UNONE_QUALIFIERS): Likewise.
7207 (TERNOP_NONE_NONE_IMM_UNONE_QUALIFIERS): Likewise.
7208 (TERNOP_NONE_NONE_UNONE_UNONE_QUALIFIERS): Likewise.
7209 (TERNOP_UNONE_UNONE_UNONE_UNONE_QUALIFIERS): Likewise.
7210 (TERNOP_NONE_NONE_NONE_NONE_QUALIFIERS): Likewise.
7211 * config/arm/mve.md (VBICQ_M_N): Define iterator.
7212 (VCVTAQ_M): Likewise.
7213 (VCVTQ_M_TO_F): Likewise.
7214 (VQRSHRNBQ_N): Likewise.
7215 (VABAVQ): Likewise.
7216 (VSHLCQ): Likewise.
7217 (VRMLALDAVHAQ): Likewise.
7218 (mve_vbicq_m_n_<supf><mode>): Define RTL pattern.
7219 (mve_vcmpeqq_m_f<mode>): Likewise.
7220 (mve_vcvtaq_m_<supf><mode>): Likewise.
7221 (mve_vcvtq_m_to_f_<supf><mode>): Likewise.
7222 (mve_vqrshrnbq_n_<supf><mode>): Likewise.
7223 (mve_vqrshrunbq_n_s<mode>): Likewise.
7224 (mve_vrmlaldavhaq_<supf>v4si): Likewise.
7225 (mve_vabavq_<supf><mode>): Likewise.
7226 (mve_vshlcq_<supf><mode>): Likewise.
7227 (mve_vshlcq_<supf><mode>): Likewise.
7228 (mve_vshlcq_vec_<supf><mode>): Define RTL expand.
7229 (mve_vshlcq_carry_<supf><mode>): Likewise.
7230
7231 2020-03-17 Andre Vieira <andre.simoesdiasvieira@arm.com>
7232 Mihail Ionescu <mihail.ionescu@arm.com>
7233 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
7234
7235 * config/arm/arm_mve.h (vqmovntq_u16): Define macro.
7236 (vqmovnbq_u16): Likewise.
7237 (vmulltq_poly_p8): Likewise.
7238 (vmullbq_poly_p8): Likewise.
7239 (vmovntq_u16): Likewise.
7240 (vmovnbq_u16): Likewise.
7241 (vmlaldavxq_u16): Likewise.
7242 (vmlaldavq_u16): Likewise.
7243 (vqmovuntq_s16): Likewise.
7244 (vqmovunbq_s16): Likewise.
7245 (vshlltq_n_u8): Likewise.
7246 (vshllbq_n_u8): Likewise.
7247 (vorrq_n_u16): Likewise.
7248 (vbicq_n_u16): Likewise.
7249 (vcmpneq_n_f16): Likewise.
7250 (vcmpneq_f16): Likewise.
7251 (vcmpltq_n_f16): Likewise.
7252 (vcmpltq_f16): Likewise.
7253 (vcmpleq_n_f16): Likewise.
7254 (vcmpleq_f16): Likewise.
7255 (vcmpgtq_n_f16): Likewise.
7256 (vcmpgtq_f16): Likewise.
7257 (vcmpgeq_n_f16): Likewise.
7258 (vcmpgeq_f16): Likewise.
7259 (vcmpeqq_n_f16): Likewise.
7260 (vcmpeqq_f16): Likewise.
7261 (vsubq_f16): Likewise.
7262 (vqmovntq_s16): Likewise.
7263 (vqmovnbq_s16): Likewise.
7264 (vqdmulltq_s16): Likewise.
7265 (vqdmulltq_n_s16): Likewise.
7266 (vqdmullbq_s16): Likewise.
7267 (vqdmullbq_n_s16): Likewise.
7268 (vorrq_f16): Likewise.
7269 (vornq_f16): Likewise.
7270 (vmulq_n_f16): Likewise.
7271 (vmulq_f16): Likewise.
7272 (vmovntq_s16): Likewise.
7273 (vmovnbq_s16): Likewise.
7274 (vmlsldavxq_s16): Likewise.
7275 (vmlsldavq_s16): Likewise.
7276 (vmlaldavxq_s16): Likewise.
7277 (vmlaldavq_s16): Likewise.
7278 (vminnmvq_f16): Likewise.
7279 (vminnmq_f16): Likewise.
7280 (vminnmavq_f16): Likewise.
7281 (vminnmaq_f16): Likewise.
7282 (vmaxnmvq_f16): Likewise.
7283 (vmaxnmq_f16): Likewise.
7284 (vmaxnmavq_f16): Likewise.
7285 (vmaxnmaq_f16): Likewise.
7286 (veorq_f16): Likewise.
7287 (vcmulq_rot90_f16): Likewise.
7288 (vcmulq_rot270_f16): Likewise.
7289 (vcmulq_rot180_f16): Likewise.
7290 (vcmulq_f16): Likewise.
7291 (vcaddq_rot90_f16): Likewise.
7292 (vcaddq_rot270_f16): Likewise.
7293 (vbicq_f16): Likewise.
7294 (vandq_f16): Likewise.
7295 (vaddq_n_f16): Likewise.
7296 (vabdq_f16): Likewise.
7297 (vshlltq_n_s8): Likewise.
7298 (vshllbq_n_s8): Likewise.
7299 (vorrq_n_s16): Likewise.
7300 (vbicq_n_s16): Likewise.
7301 (vqmovntq_u32): Likewise.
7302 (vqmovnbq_u32): Likewise.
7303 (vmulltq_poly_p16): Likewise.
7304 (vmullbq_poly_p16): Likewise.
7305 (vmovntq_u32): Likewise.
7306 (vmovnbq_u32): Likewise.
7307 (vmlaldavxq_u32): Likewise.
7308 (vmlaldavq_u32): Likewise.
7309 (vqmovuntq_s32): Likewise.
7310 (vqmovunbq_s32): Likewise.
7311 (vshlltq_n_u16): Likewise.
7312 (vshllbq_n_u16): Likewise.
7313 (vorrq_n_u32): Likewise.
7314 (vbicq_n_u32): Likewise.
7315 (vcmpneq_n_f32): Likewise.
7316 (vcmpneq_f32): Likewise.
7317 (vcmpltq_n_f32): Likewise.
7318 (vcmpltq_f32): Likewise.
7319 (vcmpleq_n_f32): Likewise.
7320 (vcmpleq_f32): Likewise.
7321 (vcmpgtq_n_f32): Likewise.
7322 (vcmpgtq_f32): Likewise.
7323 (vcmpgeq_n_f32): Likewise.
7324 (vcmpgeq_f32): Likewise.
7325 (vcmpeqq_n_f32): Likewise.
7326 (vcmpeqq_f32): Likewise.
7327 (vsubq_f32): Likewise.
7328 (vqmovntq_s32): Likewise.
7329 (vqmovnbq_s32): Likewise.
7330 (vqdmulltq_s32): Likewise.
7331 (vqdmulltq_n_s32): Likewise.
7332 (vqdmullbq_s32): Likewise.
7333 (vqdmullbq_n_s32): Likewise.
7334 (vorrq_f32): Likewise.
7335 (vornq_f32): Likewise.
7336 (vmulq_n_f32): Likewise.
7337 (vmulq_f32): Likewise.
7338 (vmovntq_s32): Likewise.
7339 (vmovnbq_s32): Likewise.
7340 (vmlsldavxq_s32): Likewise.
7341 (vmlsldavq_s32): Likewise.
7342 (vmlaldavxq_s32): Likewise.
7343 (vmlaldavq_s32): Likewise.
7344 (vminnmvq_f32): Likewise.
7345 (vminnmq_f32): Likewise.
7346 (vminnmavq_f32): Likewise.
7347 (vminnmaq_f32): Likewise.
7348 (vmaxnmvq_f32): Likewise.
7349 (vmaxnmq_f32): Likewise.
7350 (vmaxnmavq_f32): Likewise.
7351 (vmaxnmaq_f32): Likewise.
7352 (veorq_f32): Likewise.
7353 (vcmulq_rot90_f32): Likewise.
7354 (vcmulq_rot270_f32): Likewise.
7355 (vcmulq_rot180_f32): Likewise.
7356 (vcmulq_f32): Likewise.
7357 (vcaddq_rot90_f32): Likewise.
7358 (vcaddq_rot270_f32): Likewise.
7359 (vbicq_f32): Likewise.
7360 (vandq_f32): Likewise.
7361 (vaddq_n_f32): Likewise.
7362 (vabdq_f32): Likewise.
7363 (vshlltq_n_s16): Likewise.
7364 (vshllbq_n_s16): Likewise.
7365 (vorrq_n_s32): Likewise.
7366 (vbicq_n_s32): Likewise.
7367 (vrmlaldavhq_u32): Likewise.
7368 (vctp8q_m): Likewise.
7369 (vctp64q_m): Likewise.
7370 (vctp32q_m): Likewise.
7371 (vctp16q_m): Likewise.
7372 (vaddlvaq_u32): Likewise.
7373 (vrmlsldavhxq_s32): Likewise.
7374 (vrmlsldavhq_s32): Likewise.
7375 (vrmlaldavhxq_s32): Likewise.
7376 (vrmlaldavhq_s32): Likewise.
7377 (vcvttq_f16_f32): Likewise.
7378 (vcvtbq_f16_f32): Likewise.
7379 (vaddlvaq_s32): Likewise.
7380 (__arm_vqmovntq_u16): Define intrinsic.
7381 (__arm_vqmovnbq_u16): Likewise.
7382 (__arm_vmulltq_poly_p8): Likewise.
7383 (__arm_vmullbq_poly_p8): Likewise.
7384 (__arm_vmovntq_u16): Likewise.
7385 (__arm_vmovnbq_u16): Likewise.
7386 (__arm_vmlaldavxq_u16): Likewise.
7387 (__arm_vmlaldavq_u16): Likewise.
7388 (__arm_vqmovuntq_s16): Likewise.
7389 (__arm_vqmovunbq_s16): Likewise.
7390 (__arm_vshlltq_n_u8): Likewise.
7391 (__arm_vshllbq_n_u8): Likewise.
7392 (__arm_vorrq_n_u16): Likewise.
7393 (__arm_vbicq_n_u16): Likewise.
7394 (__arm_vcmpneq_n_f16): Likewise.
7395 (__arm_vcmpneq_f16): Likewise.
7396 (__arm_vcmpltq_n_f16): Likewise.
7397 (__arm_vcmpltq_f16): Likewise.
7398 (__arm_vcmpleq_n_f16): Likewise.
7399 (__arm_vcmpleq_f16): Likewise.
7400 (__arm_vcmpgtq_n_f16): Likewise.
7401 (__arm_vcmpgtq_f16): Likewise.
7402 (__arm_vcmpgeq_n_f16): Likewise.
7403 (__arm_vcmpgeq_f16): Likewise.
7404 (__arm_vcmpeqq_n_f16): Likewise.
7405 (__arm_vcmpeqq_f16): Likewise.
7406 (__arm_vsubq_f16): Likewise.
7407 (__arm_vqmovntq_s16): Likewise.
7408 (__arm_vqmovnbq_s16): Likewise.
7409 (__arm_vqdmulltq_s16): Likewise.
7410 (__arm_vqdmulltq_n_s16): Likewise.
7411 (__arm_vqdmullbq_s16): Likewise.
7412 (__arm_vqdmullbq_n_s16): Likewise.
7413 (__arm_vorrq_f16): Likewise.
7414 (__arm_vornq_f16): Likewise.
7415 (__arm_vmulq_n_f16): Likewise.
7416 (__arm_vmulq_f16): Likewise.
7417 (__arm_vmovntq_s16): Likewise.
7418 (__arm_vmovnbq_s16): Likewise.
7419 (__arm_vmlsldavxq_s16): Likewise.
7420 (__arm_vmlsldavq_s16): Likewise.
7421 (__arm_vmlaldavxq_s16): Likewise.
7422 (__arm_vmlaldavq_s16): Likewise.
7423 (__arm_vminnmvq_f16): Likewise.
7424 (__arm_vminnmq_f16): Likewise.
7425 (__arm_vminnmavq_f16): Likewise.
7426 (__arm_vminnmaq_f16): Likewise.
7427 (__arm_vmaxnmvq_f16): Likewise.
7428 (__arm_vmaxnmq_f16): Likewise.
7429 (__arm_vmaxnmavq_f16): Likewise.
7430 (__arm_vmaxnmaq_f16): Likewise.
7431 (__arm_veorq_f16): Likewise.
7432 (__arm_vcmulq_rot90_f16): Likewise.
7433 (__arm_vcmulq_rot270_f16): Likewise.
7434 (__arm_vcmulq_rot180_f16): Likewise.
7435 (__arm_vcmulq_f16): Likewise.
7436 (__arm_vcaddq_rot90_f16): Likewise.
7437 (__arm_vcaddq_rot270_f16): Likewise.
7438 (__arm_vbicq_f16): Likewise.
7439 (__arm_vandq_f16): Likewise.
7440 (__arm_vaddq_n_f16): Likewise.
7441 (__arm_vabdq_f16): Likewise.
7442 (__arm_vshlltq_n_s8): Likewise.
7443 (__arm_vshllbq_n_s8): Likewise.
7444 (__arm_vorrq_n_s16): Likewise.
7445 (__arm_vbicq_n_s16): Likewise.
7446 (__arm_vqmovntq_u32): Likewise.
7447 (__arm_vqmovnbq_u32): Likewise.
7448 (__arm_vmulltq_poly_p16): Likewise.
7449 (__arm_vmullbq_poly_p16): Likewise.
7450 (__arm_vmovntq_u32): Likewise.
7451 (__arm_vmovnbq_u32): Likewise.
7452 (__arm_vmlaldavxq_u32): Likewise.
7453 (__arm_vmlaldavq_u32): Likewise.
7454 (__arm_vqmovuntq_s32): Likewise.
7455 (__arm_vqmovunbq_s32): Likewise.
7456 (__arm_vshlltq_n_u16): Likewise.
7457 (__arm_vshllbq_n_u16): Likewise.
7458 (__arm_vorrq_n_u32): Likewise.
7459 (__arm_vbicq_n_u32): Likewise.
7460 (__arm_vcmpneq_n_f32): Likewise.
7461 (__arm_vcmpneq_f32): Likewise.
7462 (__arm_vcmpltq_n_f32): Likewise.
7463 (__arm_vcmpltq_f32): Likewise.
7464 (__arm_vcmpleq_n_f32): Likewise.
7465 (__arm_vcmpleq_f32): Likewise.
7466 (__arm_vcmpgtq_n_f32): Likewise.
7467 (__arm_vcmpgtq_f32): Likewise.
7468 (__arm_vcmpgeq_n_f32): Likewise.
7469 (__arm_vcmpgeq_f32): Likewise.
7470 (__arm_vcmpeqq_n_f32): Likewise.
7471 (__arm_vcmpeqq_f32): Likewise.
7472 (__arm_vsubq_f32): Likewise.
7473 (__arm_vqmovntq_s32): Likewise.
7474 (__arm_vqmovnbq_s32): Likewise.
7475 (__arm_vqdmulltq_s32): Likewise.
7476 (__arm_vqdmulltq_n_s32): Likewise.
7477 (__arm_vqdmullbq_s32): Likewise.
7478 (__arm_vqdmullbq_n_s32): Likewise.
7479 (__arm_vorrq_f32): Likewise.
7480 (__arm_vornq_f32): Likewise.
7481 (__arm_vmulq_n_f32): Likewise.
7482 (__arm_vmulq_f32): Likewise.
7483 (__arm_vmovntq_s32): Likewise.
7484 (__arm_vmovnbq_s32): Likewise.
7485 (__arm_vmlsldavxq_s32): Likewise.
7486 (__arm_vmlsldavq_s32): Likewise.
7487 (__arm_vmlaldavxq_s32): Likewise.
7488 (__arm_vmlaldavq_s32): Likewise.
7489 (__arm_vminnmvq_f32): Likewise.
7490 (__arm_vminnmq_f32): Likewise.
7491 (__arm_vminnmavq_f32): Likewise.
7492 (__arm_vminnmaq_f32): Likewise.
7493 (__arm_vmaxnmvq_f32): Likewise.
7494 (__arm_vmaxnmq_f32): Likewise.
7495 (__arm_vmaxnmavq_f32): Likewise.
7496 (__arm_vmaxnmaq_f32): Likewise.
7497 (__arm_veorq_f32): Likewise.
7498 (__arm_vcmulq_rot90_f32): Likewise.
7499 (__arm_vcmulq_rot270_f32): Likewise.
7500 (__arm_vcmulq_rot180_f32): Likewise.
7501 (__arm_vcmulq_f32): Likewise.
7502 (__arm_vcaddq_rot90_f32): Likewise.
7503 (__arm_vcaddq_rot270_f32): Likewise.
7504 (__arm_vbicq_f32): Likewise.
7505 (__arm_vandq_f32): Likewise.
7506 (__arm_vaddq_n_f32): Likewise.
7507 (__arm_vabdq_f32): Likewise.
7508 (__arm_vshlltq_n_s16): Likewise.
7509 (__arm_vshllbq_n_s16): Likewise.
7510 (__arm_vorrq_n_s32): Likewise.
7511 (__arm_vbicq_n_s32): Likewise.
7512 (__arm_vrmlaldavhq_u32): Likewise.
7513 (__arm_vctp8q_m): Likewise.
7514 (__arm_vctp64q_m): Likewise.
7515 (__arm_vctp32q_m): Likewise.
7516 (__arm_vctp16q_m): Likewise.
7517 (__arm_vaddlvaq_u32): Likewise.
7518 (__arm_vrmlsldavhxq_s32): Likewise.
7519 (__arm_vrmlsldavhq_s32): Likewise.
7520 (__arm_vrmlaldavhxq_s32): Likewise.
7521 (__arm_vrmlaldavhq_s32): Likewise.
7522 (__arm_vcvttq_f16_f32): Likewise.
7523 (__arm_vcvtbq_f16_f32): Likewise.
7524 (__arm_vaddlvaq_s32): Likewise.
7525 (vst4q): Define polymorphic variant.
7526 (vrndxq): Likewise.
7527 (vrndq): Likewise.
7528 (vrndpq): Likewise.
7529 (vrndnq): Likewise.
7530 (vrndmq): Likewise.
7531 (vrndaq): Likewise.
7532 (vrev64q): Likewise.
7533 (vnegq): Likewise.
7534 (vdupq_n): Likewise.
7535 (vabsq): Likewise.
7536 (vrev32q): Likewise.
7537 (vcvtbq_f32): Likewise.
7538 (vcvttq_f32): Likewise.
7539 (vcvtq): Likewise.
7540 (vsubq_n): Likewise.
7541 (vbrsrq_n): Likewise.
7542 (vcvtq_n): Likewise.
7543 (vsubq): Likewise.
7544 (vorrq): Likewise.
7545 (vabdq): Likewise.
7546 (vaddq_n): Likewise.
7547 (vandq): Likewise.
7548 (vbicq): Likewise.
7549 (vornq): Likewise.
7550 (vmulq_n): Likewise.
7551 (vmulq): Likewise.
7552 (vcaddq_rot270): Likewise.
7553 (vcmpeqq_n): Likewise.
7554 (vcmpeqq): Likewise.
7555 (vcaddq_rot90): Likewise.
7556 (vcmpgeq_n): Likewise.
7557 (vcmpgeq): Likewise.
7558 (vcmpgtq_n): Likewise.
7559 (vcmpgtq): Likewise.
7560 (vcmpgtq): Likewise.
7561 (vcmpleq_n): Likewise.
7562 (vcmpleq_n): Likewise.
7563 (vcmpleq): Likewise.
7564 (vcmpleq): Likewise.
7565 (vcmpltq_n): Likewise.
7566 (vcmpltq_n): Likewise.
7567 (vcmpltq): Likewise.
7568 (vcmpltq): Likewise.
7569 (vcmpneq_n): Likewise.
7570 (vcmpneq_n): Likewise.
7571 (vcmpneq): Likewise.
7572 (vcmpneq): Likewise.
7573 (vcmulq): Likewise.
7574 (vcmulq): Likewise.
7575 (vcmulq_rot180): Likewise.
7576 (vcmulq_rot180): Likewise.
7577 (vcmulq_rot270): Likewise.
7578 (vcmulq_rot270): Likewise.
7579 (vcmulq_rot90): Likewise.
7580 (vcmulq_rot90): Likewise.
7581 (veorq): Likewise.
7582 (veorq): Likewise.
7583 (vmaxnmaq): Likewise.
7584 (vmaxnmaq): Likewise.
7585 (vmaxnmavq): Likewise.
7586 (vmaxnmavq): Likewise.
7587 (vmaxnmq): Likewise.
7588 (vmaxnmq): Likewise.
7589 (vmaxnmvq): Likewise.
7590 (vmaxnmvq): Likewise.
7591 (vminnmaq): Likewise.
7592 (vminnmaq): Likewise.
7593 (vminnmavq): Likewise.
7594 (vminnmavq): Likewise.
7595 (vminnmq): Likewise.
7596 (vminnmq): Likewise.
7597 (vminnmvq): Likewise.
7598 (vminnmvq): Likewise.
7599 (vbicq_n): Likewise.
7600 (vqmovntq): Likewise.
7601 (vqmovntq): Likewise.
7602 (vqmovnbq): Likewise.
7603 (vqmovnbq): Likewise.
7604 (vmulltq_poly): Likewise.
7605 (vmulltq_poly): Likewise.
7606 (vmullbq_poly): Likewise.
7607 (vmullbq_poly): Likewise.
7608 (vmovntq): Likewise.
7609 (vmovntq): Likewise.
7610 (vmovnbq): Likewise.
7611 (vmovnbq): Likewise.
7612 (vmlaldavxq): Likewise.
7613 (vmlaldavxq): Likewise.
7614 (vqmovuntq): Likewise.
7615 (vqmovuntq): Likewise.
7616 (vshlltq_n): Likewise.
7617 (vshlltq_n): Likewise.
7618 (vshllbq_n): Likewise.
7619 (vshllbq_n): Likewise.
7620 (vorrq_n): Likewise.
7621 (vorrq_n): Likewise.
7622 (vmlaldavq): Likewise.
7623 (vmlaldavq): Likewise.
7624 (vqmovunbq): Likewise.
7625 (vqmovunbq): Likewise.
7626 (vqdmulltq_n): Likewise.
7627 (vqdmulltq_n): Likewise.
7628 (vqdmulltq): Likewise.
7629 (vqdmulltq): Likewise.
7630 (vqdmullbq_n): Likewise.
7631 (vqdmullbq_n): Likewise.
7632 (vqdmullbq): Likewise.
7633 (vqdmullbq): Likewise.
7634 (vaddlvaq): Likewise.
7635 (vaddlvaq): Likewise.
7636 (vrmlaldavhq): Likewise.
7637 (vrmlaldavhq): Likewise.
7638 (vrmlaldavhxq): Likewise.
7639 (vrmlaldavhxq): Likewise.
7640 (vrmlsldavhq): Likewise.
7641 (vrmlsldavhq): Likewise.
7642 (vrmlsldavhxq): Likewise.
7643 (vrmlsldavhxq): Likewise.
7644 (vmlsldavxq): Likewise.
7645 (vmlsldavxq): Likewise.
7646 (vmlsldavq): Likewise.
7647 (vmlsldavq): Likewise.
7648 * config/arm/arm_mve_builtins.def (BINOP_NONE_NONE_IMM): Use it.
7649 (BINOP_NONE_NONE_NONE): Likewise.
7650 (BINOP_UNONE_NONE_NONE): Likewise.
7651 (BINOP_UNONE_UNONE_IMM): Likewise.
7652 (BINOP_UNONE_UNONE_NONE): Likewise.
7653 (BINOP_UNONE_UNONE_UNONE): Likewise.
7654 * config/arm/mve.md (mve_vabdq_f<mode>): Define RTL pattern.
7655 (mve_vaddlvaq_<supf>v4si): Likewise.
7656 (mve_vaddq_n_f<mode>): Likewise.
7657 (mve_vandq_f<mode>): Likewise.
7658 (mve_vbicq_f<mode>): Likewise.
7659 (mve_vbicq_n_<supf><mode>): Likewise.
7660 (mve_vcaddq_rot270_f<mode>): Likewise.
7661 (mve_vcaddq_rot90_f<mode>): Likewise.
7662 (mve_vcmpeqq_f<mode>): Likewise.
7663 (mve_vcmpeqq_n_f<mode>): Likewise.
7664 (mve_vcmpgeq_f<mode>): Likewise.
7665 (mve_vcmpgeq_n_f<mode>): Likewise.
7666 (mve_vcmpgtq_f<mode>): Likewise.
7667 (mve_vcmpgtq_n_f<mode>): Likewise.
7668 (mve_vcmpleq_f<mode>): Likewise.
7669 (mve_vcmpleq_n_f<mode>): Likewise.
7670 (mve_vcmpltq_f<mode>): Likewise.
7671 (mve_vcmpltq_n_f<mode>): Likewise.
7672 (mve_vcmpneq_f<mode>): Likewise.
7673 (mve_vcmpneq_n_f<mode>): Likewise.
7674 (mve_vcmulq_f<mode>): Likewise.
7675 (mve_vcmulq_rot180_f<mode>): Likewise.
7676 (mve_vcmulq_rot270_f<mode>): Likewise.
7677 (mve_vcmulq_rot90_f<mode>): Likewise.
7678 (mve_vctp<mode1>q_mhi): Likewise.
7679 (mve_vcvtbq_f16_f32v8hf): Likewise.
7680 (mve_vcvttq_f16_f32v8hf): Likewise.
7681 (mve_veorq_f<mode>): Likewise.
7682 (mve_vmaxnmaq_f<mode>): Likewise.
7683 (mve_vmaxnmavq_f<mode>): Likewise.
7684 (mve_vmaxnmq_f<mode>): Likewise.
7685 (mve_vmaxnmvq_f<mode>): Likewise.
7686 (mve_vminnmaq_f<mode>): Likewise.
7687 (mve_vminnmavq_f<mode>): Likewise.
7688 (mve_vminnmq_f<mode>): Likewise.
7689 (mve_vminnmvq_f<mode>): Likewise.
7690 (mve_vmlaldavq_<supf><mode>): Likewise.
7691 (mve_vmlaldavxq_<supf><mode>): Likewise.
7692 (mve_vmlsldavq_s<mode>): Likewise.
7693 (mve_vmlsldavxq_s<mode>): Likewise.
7694 (mve_vmovnbq_<supf><mode>): Likewise.
7695 (mve_vmovntq_<supf><mode>): Likewise.
7696 (mve_vmulq_f<mode>): Likewise.
7697 (mve_vmulq_n_f<mode>): Likewise.
7698 (mve_vornq_f<mode>): Likewise.
7699 (mve_vorrq_f<mode>): Likewise.
7700 (mve_vorrq_n_<supf><mode>): Likewise.
7701 (mve_vqdmullbq_n_s<mode>): Likewise.
7702 (mve_vqdmullbq_s<mode>): Likewise.
7703 (mve_vqdmulltq_n_s<mode>): Likewise.
7704 (mve_vqdmulltq_s<mode>): Likewise.
7705 (mve_vqmovnbq_<supf><mode>): Likewise.
7706 (mve_vqmovntq_<supf><mode>): Likewise.
7707 (mve_vqmovunbq_s<mode>): Likewise.
7708 (mve_vqmovuntq_s<mode>): Likewise.
7709 (mve_vrmlaldavhxq_sv4si): Likewise.
7710 (mve_vrmlsldavhq_sv4si): Likewise.
7711 (mve_vrmlsldavhxq_sv4si): Likewise.
7712 (mve_vshllbq_n_<supf><mode>): Likewise.
7713 (mve_vshlltq_n_<supf><mode>): Likewise.
7714 (mve_vsubq_f<mode>): Likewise.
7715 (mve_vmulltq_poly_p<mode>): Likewise.
7716 (mve_vmullbq_poly_p<mode>): Likewise.
7717 (mve_vrmlaldavhq_<supf>v4si): Likewise.
7718
7719 2020-03-17 Andre Vieira <andre.simoesdiasvieira@arm.com>
7720 Mihail Ionescu <mihail.ionescu@arm.com>
7721 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
7722
7723 * config/arm/arm_mve.h (vsubq_u8): Define macro.
7724 (vsubq_n_u8): Likewise.
7725 (vrmulhq_u8): Likewise.
7726 (vrhaddq_u8): Likewise.
7727 (vqsubq_u8): Likewise.
7728 (vqsubq_n_u8): Likewise.
7729 (vqaddq_u8): Likewise.
7730 (vqaddq_n_u8): Likewise.
7731 (vorrq_u8): Likewise.
7732 (vornq_u8): Likewise.
7733 (vmulq_u8): Likewise.
7734 (vmulq_n_u8): Likewise.
7735 (vmulltq_int_u8): Likewise.
7736 (vmullbq_int_u8): Likewise.
7737 (vmulhq_u8): Likewise.
7738 (vmladavq_u8): Likewise.
7739 (vminvq_u8): Likewise.
7740 (vminq_u8): Likewise.
7741 (vmaxvq_u8): Likewise.
7742 (vmaxq_u8): Likewise.
7743 (vhsubq_u8): Likewise.
7744 (vhsubq_n_u8): Likewise.
7745 (vhaddq_u8): Likewise.
7746 (vhaddq_n_u8): Likewise.
7747 (veorq_u8): Likewise.
7748 (vcmpneq_n_u8): Likewise.
7749 (vcmphiq_u8): Likewise.
7750 (vcmphiq_n_u8): Likewise.
7751 (vcmpeqq_u8): Likewise.
7752 (vcmpeqq_n_u8): Likewise.
7753 (vcmpcsq_u8): Likewise.
7754 (vcmpcsq_n_u8): Likewise.
7755 (vcaddq_rot90_u8): Likewise.
7756 (vcaddq_rot270_u8): Likewise.
7757 (vbicq_u8): Likewise.
7758 (vandq_u8): Likewise.
7759 (vaddvq_p_u8): Likewise.
7760 (vaddvaq_u8): Likewise.
7761 (vaddq_n_u8): Likewise.
7762 (vabdq_u8): Likewise.
7763 (vshlq_r_u8): Likewise.
7764 (vrshlq_u8): Likewise.
7765 (vrshlq_n_u8): Likewise.
7766 (vqshlq_u8): Likewise.
7767 (vqshlq_r_u8): Likewise.
7768 (vqrshlq_u8): Likewise.
7769 (vqrshlq_n_u8): Likewise.
7770 (vminavq_s8): Likewise.
7771 (vminaq_s8): Likewise.
7772 (vmaxavq_s8): Likewise.
7773 (vmaxaq_s8): Likewise.
7774 (vbrsrq_n_u8): Likewise.
7775 (vshlq_n_u8): Likewise.
7776 (vrshrq_n_u8): Likewise.
7777 (vqshlq_n_u8): Likewise.
7778 (vcmpneq_n_s8): Likewise.
7779 (vcmpltq_s8): Likewise.
7780 (vcmpltq_n_s8): Likewise.
7781 (vcmpleq_s8): Likewise.
7782 (vcmpleq_n_s8): Likewise.
7783 (vcmpgtq_s8): Likewise.
7784 (vcmpgtq_n_s8): Likewise.
7785 (vcmpgeq_s8): Likewise.
7786 (vcmpgeq_n_s8): Likewise.
7787 (vcmpeqq_s8): Likewise.
7788 (vcmpeqq_n_s8): Likewise.
7789 (vqshluq_n_s8): Likewise.
7790 (vaddvq_p_s8): Likewise.
7791 (vsubq_s8): Likewise.
7792 (vsubq_n_s8): Likewise.
7793 (vshlq_r_s8): Likewise.
7794 (vrshlq_s8): Likewise.
7795 (vrshlq_n_s8): Likewise.
7796 (vrmulhq_s8): Likewise.
7797 (vrhaddq_s8): Likewise.
7798 (vqsubq_s8): Likewise.
7799 (vqsubq_n_s8): Likewise.
7800 (vqshlq_s8): Likewise.
7801 (vqshlq_r_s8): Likewise.
7802 (vqrshlq_s8): Likewise.
7803 (vqrshlq_n_s8): Likewise.
7804 (vqrdmulhq_s8): Likewise.
7805 (vqrdmulhq_n_s8): Likewise.
7806 (vqdmulhq_s8): Likewise.
7807 (vqdmulhq_n_s8): Likewise.
7808 (vqaddq_s8): Likewise.
7809 (vqaddq_n_s8): Likewise.
7810 (vorrq_s8): Likewise.
7811 (vornq_s8): Likewise.
7812 (vmulq_s8): Likewise.
7813 (vmulq_n_s8): Likewise.
7814 (vmulltq_int_s8): Likewise.
7815 (vmullbq_int_s8): Likewise.
7816 (vmulhq_s8): Likewise.
7817 (vmlsdavxq_s8): Likewise.
7818 (vmlsdavq_s8): Likewise.
7819 (vmladavxq_s8): Likewise.
7820 (vmladavq_s8): Likewise.
7821 (vminvq_s8): Likewise.
7822 (vminq_s8): Likewise.
7823 (vmaxvq_s8): Likewise.
7824 (vmaxq_s8): Likewise.
7825 (vhsubq_s8): Likewise.
7826 (vhsubq_n_s8): Likewise.
7827 (vhcaddq_rot90_s8): Likewise.
7828 (vhcaddq_rot270_s8): Likewise.
7829 (vhaddq_s8): Likewise.
7830 (vhaddq_n_s8): Likewise.
7831 (veorq_s8): Likewise.
7832 (vcaddq_rot90_s8): Likewise.
7833 (vcaddq_rot270_s8): Likewise.
7834 (vbrsrq_n_s8): Likewise.
7835 (vbicq_s8): Likewise.
7836 (vandq_s8): Likewise.
7837 (vaddvaq_s8): Likewise.
7838 (vaddq_n_s8): Likewise.
7839 (vabdq_s8): Likewise.
7840 (vshlq_n_s8): Likewise.
7841 (vrshrq_n_s8): Likewise.
7842 (vqshlq_n_s8): Likewise.
7843 (vsubq_u16): Likewise.
7844 (vsubq_n_u16): Likewise.
7845 (vrmulhq_u16): Likewise.
7846 (vrhaddq_u16): Likewise.
7847 (vqsubq_u16): Likewise.
7848 (vqsubq_n_u16): Likewise.
7849 (vqaddq_u16): Likewise.
7850 (vqaddq_n_u16): Likewise.
7851 (vorrq_u16): Likewise.
7852 (vornq_u16): Likewise.
7853 (vmulq_u16): Likewise.
7854 (vmulq_n_u16): Likewise.
7855 (vmulltq_int_u16): Likewise.
7856 (vmullbq_int_u16): Likewise.
7857 (vmulhq_u16): Likewise.
7858 (vmladavq_u16): Likewise.
7859 (vminvq_u16): Likewise.
7860 (vminq_u16): Likewise.
7861 (vmaxvq_u16): Likewise.
7862 (vmaxq_u16): Likewise.
7863 (vhsubq_u16): Likewise.
7864 (vhsubq_n_u16): Likewise.
7865 (vhaddq_u16): Likewise.
7866 (vhaddq_n_u16): Likewise.
7867 (veorq_u16): Likewise.
7868 (vcmpneq_n_u16): Likewise.
7869 (vcmphiq_u16): Likewise.
7870 (vcmphiq_n_u16): Likewise.
7871 (vcmpeqq_u16): Likewise.
7872 (vcmpeqq_n_u16): Likewise.
7873 (vcmpcsq_u16): Likewise.
7874 (vcmpcsq_n_u16): Likewise.
7875 (vcaddq_rot90_u16): Likewise.
7876 (vcaddq_rot270_u16): Likewise.
7877 (vbicq_u16): Likewise.
7878 (vandq_u16): Likewise.
7879 (vaddvq_p_u16): Likewise.
7880 (vaddvaq_u16): Likewise.
7881 (vaddq_n_u16): Likewise.
7882 (vabdq_u16): Likewise.
7883 (vshlq_r_u16): Likewise.
7884 (vrshlq_u16): Likewise.
7885 (vrshlq_n_u16): Likewise.
7886 (vqshlq_u16): Likewise.
7887 (vqshlq_r_u16): Likewise.
7888 (vqrshlq_u16): Likewise.
7889 (vqrshlq_n_u16): Likewise.
7890 (vminavq_s16): Likewise.
7891 (vminaq_s16): Likewise.
7892 (vmaxavq_s16): Likewise.
7893 (vmaxaq_s16): Likewise.
7894 (vbrsrq_n_u16): Likewise.
7895 (vshlq_n_u16): Likewise.
7896 (vrshrq_n_u16): Likewise.
7897 (vqshlq_n_u16): Likewise.
7898 (vcmpneq_n_s16): Likewise.
7899 (vcmpltq_s16): Likewise.
7900 (vcmpltq_n_s16): Likewise.
7901 (vcmpleq_s16): Likewise.
7902 (vcmpleq_n_s16): Likewise.
7903 (vcmpgtq_s16): Likewise.
7904 (vcmpgtq_n_s16): Likewise.
7905 (vcmpgeq_s16): Likewise.
7906 (vcmpgeq_n_s16): Likewise.
7907 (vcmpeqq_s16): Likewise.
7908 (vcmpeqq_n_s16): Likewise.
7909 (vqshluq_n_s16): Likewise.
7910 (vaddvq_p_s16): Likewise.
7911 (vsubq_s16): Likewise.
7912 (vsubq_n_s16): Likewise.
7913 (vshlq_r_s16): Likewise.
7914 (vrshlq_s16): Likewise.
7915 (vrshlq_n_s16): Likewise.
7916 (vrmulhq_s16): Likewise.
7917 (vrhaddq_s16): Likewise.
7918 (vqsubq_s16): Likewise.
7919 (vqsubq_n_s16): Likewise.
7920 (vqshlq_s16): Likewise.
7921 (vqshlq_r_s16): Likewise.
7922 (vqrshlq_s16): Likewise.
7923 (vqrshlq_n_s16): Likewise.
7924 (vqrdmulhq_s16): Likewise.
7925 (vqrdmulhq_n_s16): Likewise.
7926 (vqdmulhq_s16): Likewise.
7927 (vqdmulhq_n_s16): Likewise.
7928 (vqaddq_s16): Likewise.
7929 (vqaddq_n_s16): Likewise.
7930 (vorrq_s16): Likewise.
7931 (vornq_s16): Likewise.
7932 (vmulq_s16): Likewise.
7933 (vmulq_n_s16): Likewise.
7934 (vmulltq_int_s16): Likewise.
7935 (vmullbq_int_s16): Likewise.
7936 (vmulhq_s16): Likewise.
7937 (vmlsdavxq_s16): Likewise.
7938 (vmlsdavq_s16): Likewise.
7939 (vmladavxq_s16): Likewise.
7940 (vmladavq_s16): Likewise.
7941 (vminvq_s16): Likewise.
7942 (vminq_s16): Likewise.
7943 (vmaxvq_s16): Likewise.
7944 (vmaxq_s16): Likewise.
7945 (vhsubq_s16): Likewise.
7946 (vhsubq_n_s16): Likewise.
7947 (vhcaddq_rot90_s16): Likewise.
7948 (vhcaddq_rot270_s16): Likewise.
7949 (vhaddq_s16): Likewise.
7950 (vhaddq_n_s16): Likewise.
7951 (veorq_s16): Likewise.
7952 (vcaddq_rot90_s16): Likewise.
7953 (vcaddq_rot270_s16): Likewise.
7954 (vbrsrq_n_s16): Likewise.
7955 (vbicq_s16): Likewise.
7956 (vandq_s16): Likewise.
7957 (vaddvaq_s16): Likewise.
7958 (vaddq_n_s16): Likewise.
7959 (vabdq_s16): Likewise.
7960 (vshlq_n_s16): Likewise.
7961 (vrshrq_n_s16): Likewise.
7962 (vqshlq_n_s16): Likewise.
7963 (vsubq_u32): Likewise.
7964 (vsubq_n_u32): Likewise.
7965 (vrmulhq_u32): Likewise.
7966 (vrhaddq_u32): Likewise.
7967 (vqsubq_u32): Likewise.
7968 (vqsubq_n_u32): Likewise.
7969 (vqaddq_u32): Likewise.
7970 (vqaddq_n_u32): Likewise.
7971 (vorrq_u32): Likewise.
7972 (vornq_u32): Likewise.
7973 (vmulq_u32): Likewise.
7974 (vmulq_n_u32): Likewise.
7975 (vmulltq_int_u32): Likewise.
7976 (vmullbq_int_u32): Likewise.
7977 (vmulhq_u32): Likewise.
7978 (vmladavq_u32): Likewise.
7979 (vminvq_u32): Likewise.
7980 (vminq_u32): Likewise.
7981 (vmaxvq_u32): Likewise.
7982 (vmaxq_u32): Likewise.
7983 (vhsubq_u32): Likewise.
7984 (vhsubq_n_u32): Likewise.
7985 (vhaddq_u32): Likewise.
7986 (vhaddq_n_u32): Likewise.
7987 (veorq_u32): Likewise.
7988 (vcmpneq_n_u32): Likewise.
7989 (vcmphiq_u32): Likewise.
7990 (vcmphiq_n_u32): Likewise.
7991 (vcmpeqq_u32): Likewise.
7992 (vcmpeqq_n_u32): Likewise.
7993 (vcmpcsq_u32): Likewise.
7994 (vcmpcsq_n_u32): Likewise.
7995 (vcaddq_rot90_u32): Likewise.
7996 (vcaddq_rot270_u32): Likewise.
7997 (vbicq_u32): Likewise.
7998 (vandq_u32): Likewise.
7999 (vaddvq_p_u32): Likewise.
8000 (vaddvaq_u32): Likewise.
8001 (vaddq_n_u32): Likewise.
8002 (vabdq_u32): Likewise.
8003 (vshlq_r_u32): Likewise.
8004 (vrshlq_u32): Likewise.
8005 (vrshlq_n_u32): Likewise.
8006 (vqshlq_u32): Likewise.
8007 (vqshlq_r_u32): Likewise.
8008 (vqrshlq_u32): Likewise.
8009 (vqrshlq_n_u32): Likewise.
8010 (vminavq_s32): Likewise.
8011 (vminaq_s32): Likewise.
8012 (vmaxavq_s32): Likewise.
8013 (vmaxaq_s32): Likewise.
8014 (vbrsrq_n_u32): Likewise.
8015 (vshlq_n_u32): Likewise.
8016 (vrshrq_n_u32): Likewise.
8017 (vqshlq_n_u32): Likewise.
8018 (vcmpneq_n_s32): Likewise.
8019 (vcmpltq_s32): Likewise.
8020 (vcmpltq_n_s32): Likewise.
8021 (vcmpleq_s32): Likewise.
8022 (vcmpleq_n_s32): Likewise.
8023 (vcmpgtq_s32): Likewise.
8024 (vcmpgtq_n_s32): Likewise.
8025 (vcmpgeq_s32): Likewise.
8026 (vcmpgeq_n_s32): Likewise.
8027 (vcmpeqq_s32): Likewise.
8028 (vcmpeqq_n_s32): Likewise.
8029 (vqshluq_n_s32): Likewise.
8030 (vaddvq_p_s32): Likewise.
8031 (vsubq_s32): Likewise.
8032 (vsubq_n_s32): Likewise.
8033 (vshlq_r_s32): Likewise.
8034 (vrshlq_s32): Likewise.
8035 (vrshlq_n_s32): Likewise.
8036 (vrmulhq_s32): Likewise.
8037 (vrhaddq_s32): Likewise.
8038 (vqsubq_s32): Likewise.
8039 (vqsubq_n_s32): Likewise.
8040 (vqshlq_s32): Likewise.
8041 (vqshlq_r_s32): Likewise.
8042 (vqrshlq_s32): Likewise.
8043 (vqrshlq_n_s32): Likewise.
8044 (vqrdmulhq_s32): Likewise.
8045 (vqrdmulhq_n_s32): Likewise.
8046 (vqdmulhq_s32): Likewise.
8047 (vqdmulhq_n_s32): Likewise.
8048 (vqaddq_s32): Likewise.
8049 (vqaddq_n_s32): Likewise.
8050 (vorrq_s32): Likewise.
8051 (vornq_s32): Likewise.
8052 (vmulq_s32): Likewise.
8053 (vmulq_n_s32): Likewise.
8054 (vmulltq_int_s32): Likewise.
8055 (vmullbq_int_s32): Likewise.
8056 (vmulhq_s32): Likewise.
8057 (vmlsdavxq_s32): Likewise.
8058 (vmlsdavq_s32): Likewise.
8059 (vmladavxq_s32): Likewise.
8060 (vmladavq_s32): Likewise.
8061 (vminvq_s32): Likewise.
8062 (vminq_s32): Likewise.
8063 (vmaxvq_s32): Likewise.
8064 (vmaxq_s32): Likewise.
8065 (vhsubq_s32): Likewise.
8066 (vhsubq_n_s32): Likewise.
8067 (vhcaddq_rot90_s32): Likewise.
8068 (vhcaddq_rot270_s32): Likewise.
8069 (vhaddq_s32): Likewise.
8070 (vhaddq_n_s32): Likewise.
8071 (veorq_s32): Likewise.
8072 (vcaddq_rot90_s32): Likewise.
8073 (vcaddq_rot270_s32): Likewise.
8074 (vbrsrq_n_s32): Likewise.
8075 (vbicq_s32): Likewise.
8076 (vandq_s32): Likewise.
8077 (vaddvaq_s32): Likewise.
8078 (vaddq_n_s32): Likewise.
8079 (vabdq_s32): Likewise.
8080 (vshlq_n_s32): Likewise.
8081 (vrshrq_n_s32): Likewise.
8082 (vqshlq_n_s32): Likewise.
8083 (__arm_vsubq_u8): Define intrinsic.
8084 (__arm_vsubq_n_u8): Likewise.
8085 (__arm_vrmulhq_u8): Likewise.
8086 (__arm_vrhaddq_u8): Likewise.
8087 (__arm_vqsubq_u8): Likewise.
8088 (__arm_vqsubq_n_u8): Likewise.
8089 (__arm_vqaddq_u8): Likewise.
8090 (__arm_vqaddq_n_u8): Likewise.
8091 (__arm_vorrq_u8): Likewise.
8092 (__arm_vornq_u8): Likewise.
8093 (__arm_vmulq_u8): Likewise.
8094 (__arm_vmulq_n_u8): Likewise.
8095 (__arm_vmulltq_int_u8): Likewise.
8096 (__arm_vmullbq_int_u8): Likewise.
8097 (__arm_vmulhq_u8): Likewise.
8098 (__arm_vmladavq_u8): Likewise.
8099 (__arm_vminvq_u8): Likewise.
8100 (__arm_vminq_u8): Likewise.
8101 (__arm_vmaxvq_u8): Likewise.
8102 (__arm_vmaxq_u8): Likewise.
8103 (__arm_vhsubq_u8): Likewise.
8104 (__arm_vhsubq_n_u8): Likewise.
8105 (__arm_vhaddq_u8): Likewise.
8106 (__arm_vhaddq_n_u8): Likewise.
8107 (__arm_veorq_u8): Likewise.
8108 (__arm_vcmpneq_n_u8): Likewise.
8109 (__arm_vcmphiq_u8): Likewise.
8110 (__arm_vcmphiq_n_u8): Likewise.
8111 (__arm_vcmpeqq_u8): Likewise.
8112 (__arm_vcmpeqq_n_u8): Likewise.
8113 (__arm_vcmpcsq_u8): Likewise.
8114 (__arm_vcmpcsq_n_u8): Likewise.
8115 (__arm_vcaddq_rot90_u8): Likewise.
8116 (__arm_vcaddq_rot270_u8): Likewise.
8117 (__arm_vbicq_u8): Likewise.
8118 (__arm_vandq_u8): Likewise.
8119 (__arm_vaddvq_p_u8): Likewise.
8120 (__arm_vaddvaq_u8): Likewise.
8121 (__arm_vaddq_n_u8): Likewise.
8122 (__arm_vabdq_u8): Likewise.
8123 (__arm_vshlq_r_u8): Likewise.
8124 (__arm_vrshlq_u8): Likewise.
8125 (__arm_vrshlq_n_u8): Likewise.
8126 (__arm_vqshlq_u8): Likewise.
8127 (__arm_vqshlq_r_u8): Likewise.
8128 (__arm_vqrshlq_u8): Likewise.
8129 (__arm_vqrshlq_n_u8): Likewise.
8130 (__arm_vminavq_s8): Likewise.
8131 (__arm_vminaq_s8): Likewise.
8132 (__arm_vmaxavq_s8): Likewise.
8133 (__arm_vmaxaq_s8): Likewise.
8134 (__arm_vbrsrq_n_u8): Likewise.
8135 (__arm_vshlq_n_u8): Likewise.
8136 (__arm_vrshrq_n_u8): Likewise.
8137 (__arm_vqshlq_n_u8): Likewise.
8138 (__arm_vcmpneq_n_s8): Likewise.
8139 (__arm_vcmpltq_s8): Likewise.
8140 (__arm_vcmpltq_n_s8): Likewise.
8141 (__arm_vcmpleq_s8): Likewise.
8142 (__arm_vcmpleq_n_s8): Likewise.
8143 (__arm_vcmpgtq_s8): Likewise.
8144 (__arm_vcmpgtq_n_s8): Likewise.
8145 (__arm_vcmpgeq_s8): Likewise.
8146 (__arm_vcmpgeq_n_s8): Likewise.
8147 (__arm_vcmpeqq_s8): Likewise.
8148 (__arm_vcmpeqq_n_s8): Likewise.
8149 (__arm_vqshluq_n_s8): Likewise.
8150 (__arm_vaddvq_p_s8): Likewise.
8151 (__arm_vsubq_s8): Likewise.
8152 (__arm_vsubq_n_s8): Likewise.
8153 (__arm_vshlq_r_s8): Likewise.
8154 (__arm_vrshlq_s8): Likewise.
8155 (__arm_vrshlq_n_s8): Likewise.
8156 (__arm_vrmulhq_s8): Likewise.
8157 (__arm_vrhaddq_s8): Likewise.
8158 (__arm_vqsubq_s8): Likewise.
8159 (__arm_vqsubq_n_s8): Likewise.
8160 (__arm_vqshlq_s8): Likewise.
8161 (__arm_vqshlq_r_s8): Likewise.
8162 (__arm_vqrshlq_s8): Likewise.
8163 (__arm_vqrshlq_n_s8): Likewise.
8164 (__arm_vqrdmulhq_s8): Likewise.
8165 (__arm_vqrdmulhq_n_s8): Likewise.
8166 (__arm_vqdmulhq_s8): Likewise.
8167 (__arm_vqdmulhq_n_s8): Likewise.
8168 (__arm_vqaddq_s8): Likewise.
8169 (__arm_vqaddq_n_s8): Likewise.
8170 (__arm_vorrq_s8): Likewise.
8171 (__arm_vornq_s8): Likewise.
8172 (__arm_vmulq_s8): Likewise.
8173 (__arm_vmulq_n_s8): Likewise.
8174 (__arm_vmulltq_int_s8): Likewise.
8175 (__arm_vmullbq_int_s8): Likewise.
8176 (__arm_vmulhq_s8): Likewise.
8177 (__arm_vmlsdavxq_s8): Likewise.
8178 (__arm_vmlsdavq_s8): Likewise.
8179 (__arm_vmladavxq_s8): Likewise.
8180 (__arm_vmladavq_s8): Likewise.
8181 (__arm_vminvq_s8): Likewise.
8182 (__arm_vminq_s8): Likewise.
8183 (__arm_vmaxvq_s8): Likewise.
8184 (__arm_vmaxq_s8): Likewise.
8185 (__arm_vhsubq_s8): Likewise.
8186 (__arm_vhsubq_n_s8): Likewise.
8187 (__arm_vhcaddq_rot90_s8): Likewise.
8188 (__arm_vhcaddq_rot270_s8): Likewise.
8189 (__arm_vhaddq_s8): Likewise.
8190 (__arm_vhaddq_n_s8): Likewise.
8191 (__arm_veorq_s8): Likewise.
8192 (__arm_vcaddq_rot90_s8): Likewise.
8193 (__arm_vcaddq_rot270_s8): Likewise.
8194 (__arm_vbrsrq_n_s8): Likewise.
8195 (__arm_vbicq_s8): Likewise.
8196 (__arm_vandq_s8): Likewise.
8197 (__arm_vaddvaq_s8): Likewise.
8198 (__arm_vaddq_n_s8): Likewise.
8199 (__arm_vabdq_s8): Likewise.
8200 (__arm_vshlq_n_s8): Likewise.
8201 (__arm_vrshrq_n_s8): Likewise.
8202 (__arm_vqshlq_n_s8): Likewise.
8203 (__arm_vsubq_u16): Likewise.
8204 (__arm_vsubq_n_u16): Likewise.
8205 (__arm_vrmulhq_u16): Likewise.
8206 (__arm_vrhaddq_u16): Likewise.
8207 (__arm_vqsubq_u16): Likewise.
8208 (__arm_vqsubq_n_u16): Likewise.
8209 (__arm_vqaddq_u16): Likewise.
8210 (__arm_vqaddq_n_u16): Likewise.
8211 (__arm_vorrq_u16): Likewise.
8212 (__arm_vornq_u16): Likewise.
8213 (__arm_vmulq_u16): Likewise.
8214 (__arm_vmulq_n_u16): Likewise.
8215 (__arm_vmulltq_int_u16): Likewise.
8216 (__arm_vmullbq_int_u16): Likewise.
8217 (__arm_vmulhq_u16): Likewise.
8218 (__arm_vmladavq_u16): Likewise.
8219 (__arm_vminvq_u16): Likewise.
8220 (__arm_vminq_u16): Likewise.
8221 (__arm_vmaxvq_u16): Likewise.
8222 (__arm_vmaxq_u16): Likewise.
8223 (__arm_vhsubq_u16): Likewise.
8224 (__arm_vhsubq_n_u16): Likewise.
8225 (__arm_vhaddq_u16): Likewise.
8226 (__arm_vhaddq_n_u16): Likewise.
8227 (__arm_veorq_u16): Likewise.
8228 (__arm_vcmpneq_n_u16): Likewise.
8229 (__arm_vcmphiq_u16): Likewise.
8230 (__arm_vcmphiq_n_u16): Likewise.
8231 (__arm_vcmpeqq_u16): Likewise.
8232 (__arm_vcmpeqq_n_u16): Likewise.
8233 (__arm_vcmpcsq_u16): Likewise.
8234 (__arm_vcmpcsq_n_u16): Likewise.
8235 (__arm_vcaddq_rot90_u16): Likewise.
8236 (__arm_vcaddq_rot270_u16): Likewise.
8237 (__arm_vbicq_u16): Likewise.
8238 (__arm_vandq_u16): Likewise.
8239 (__arm_vaddvq_p_u16): Likewise.
8240 (__arm_vaddvaq_u16): Likewise.
8241 (__arm_vaddq_n_u16): Likewise.
8242 (__arm_vabdq_u16): Likewise.
8243 (__arm_vshlq_r_u16): Likewise.
8244 (__arm_vrshlq_u16): Likewise.
8245 (__arm_vrshlq_n_u16): Likewise.
8246 (__arm_vqshlq_u16): Likewise.
8247 (__arm_vqshlq_r_u16): Likewise.
8248 (__arm_vqrshlq_u16): Likewise.
8249 (__arm_vqrshlq_n_u16): Likewise.
8250 (__arm_vminavq_s16): Likewise.
8251 (__arm_vminaq_s16): Likewise.
8252 (__arm_vmaxavq_s16): Likewise.
8253 (__arm_vmaxaq_s16): Likewise.
8254 (__arm_vbrsrq_n_u16): Likewise.
8255 (__arm_vshlq_n_u16): Likewise.
8256 (__arm_vrshrq_n_u16): Likewise.
8257 (__arm_vqshlq_n_u16): Likewise.
8258 (__arm_vcmpneq_n_s16): Likewise.
8259 (__arm_vcmpltq_s16): Likewise.
8260 (__arm_vcmpltq_n_s16): Likewise.
8261 (__arm_vcmpleq_s16): Likewise.
8262 (__arm_vcmpleq_n_s16): Likewise.
8263 (__arm_vcmpgtq_s16): Likewise.
8264 (__arm_vcmpgtq_n_s16): Likewise.
8265 (__arm_vcmpgeq_s16): Likewise.
8266 (__arm_vcmpgeq_n_s16): Likewise.
8267 (__arm_vcmpeqq_s16): Likewise.
8268 (__arm_vcmpeqq_n_s16): Likewise.
8269 (__arm_vqshluq_n_s16): Likewise.
8270 (__arm_vaddvq_p_s16): Likewise.
8271 (__arm_vsubq_s16): Likewise.
8272 (__arm_vsubq_n_s16): Likewise.
8273 (__arm_vshlq_r_s16): Likewise.
8274 (__arm_vrshlq_s16): Likewise.
8275 (__arm_vrshlq_n_s16): Likewise.
8276 (__arm_vrmulhq_s16): Likewise.
8277 (__arm_vrhaddq_s16): Likewise.
8278 (__arm_vqsubq_s16): Likewise.
8279 (__arm_vqsubq_n_s16): Likewise.
8280 (__arm_vqshlq_s16): Likewise.
8281 (__arm_vqshlq_r_s16): Likewise.
8282 (__arm_vqrshlq_s16): Likewise.
8283 (__arm_vqrshlq_n_s16): Likewise.
8284 (__arm_vqrdmulhq_s16): Likewise.
8285 (__arm_vqrdmulhq_n_s16): Likewise.
8286 (__arm_vqdmulhq_s16): Likewise.
8287 (__arm_vqdmulhq_n_s16): Likewise.
8288 (__arm_vqaddq_s16): Likewise.
8289 (__arm_vqaddq_n_s16): Likewise.
8290 (__arm_vorrq_s16): Likewise.
8291 (__arm_vornq_s16): Likewise.
8292 (__arm_vmulq_s16): Likewise.
8293 (__arm_vmulq_n_s16): Likewise.
8294 (__arm_vmulltq_int_s16): Likewise.
8295 (__arm_vmullbq_int_s16): Likewise.
8296 (__arm_vmulhq_s16): Likewise.
8297 (__arm_vmlsdavxq_s16): Likewise.
8298 (__arm_vmlsdavq_s16): Likewise.
8299 (__arm_vmladavxq_s16): Likewise.
8300 (__arm_vmladavq_s16): Likewise.
8301 (__arm_vminvq_s16): Likewise.
8302 (__arm_vminq_s16): Likewise.
8303 (__arm_vmaxvq_s16): Likewise.
8304 (__arm_vmaxq_s16): Likewise.
8305 (__arm_vhsubq_s16): Likewise.
8306 (__arm_vhsubq_n_s16): Likewise.
8307 (__arm_vhcaddq_rot90_s16): Likewise.
8308 (__arm_vhcaddq_rot270_s16): Likewise.
8309 (__arm_vhaddq_s16): Likewise.
8310 (__arm_vhaddq_n_s16): Likewise.
8311 (__arm_veorq_s16): Likewise.
8312 (__arm_vcaddq_rot90_s16): Likewise.
8313 (__arm_vcaddq_rot270_s16): Likewise.
8314 (__arm_vbrsrq_n_s16): Likewise.
8315 (__arm_vbicq_s16): Likewise.
8316 (__arm_vandq_s16): Likewise.
8317 (__arm_vaddvaq_s16): Likewise.
8318 (__arm_vaddq_n_s16): Likewise.
8319 (__arm_vabdq_s16): Likewise.
8320 (__arm_vshlq_n_s16): Likewise.
8321 (__arm_vrshrq_n_s16): Likewise.
8322 (__arm_vqshlq_n_s16): Likewise.
8323 (__arm_vsubq_u32): Likewise.
8324 (__arm_vsubq_n_u32): Likewise.
8325 (__arm_vrmulhq_u32): Likewise.
8326 (__arm_vrhaddq_u32): Likewise.
8327 (__arm_vqsubq_u32): Likewise.
8328 (__arm_vqsubq_n_u32): Likewise.
8329 (__arm_vqaddq_u32): Likewise.
8330 (__arm_vqaddq_n_u32): Likewise.
8331 (__arm_vorrq_u32): Likewise.
8332 (__arm_vornq_u32): Likewise.
8333 (__arm_vmulq_u32): Likewise.
8334 (__arm_vmulq_n_u32): Likewise.
8335 (__arm_vmulltq_int_u32): Likewise.
8336 (__arm_vmullbq_int_u32): Likewise.
8337 (__arm_vmulhq_u32): Likewise.
8338 (__arm_vmladavq_u32): Likewise.
8339 (__arm_vminvq_u32): Likewise.
8340 (__arm_vminq_u32): Likewise.
8341 (__arm_vmaxvq_u32): Likewise.
8342 (__arm_vmaxq_u32): Likewise.
8343 (__arm_vhsubq_u32): Likewise.
8344 (__arm_vhsubq_n_u32): Likewise.
8345 (__arm_vhaddq_u32): Likewise.
8346 (__arm_vhaddq_n_u32): Likewise.
8347 (__arm_veorq_u32): Likewise.
8348 (__arm_vcmpneq_n_u32): Likewise.
8349 (__arm_vcmphiq_u32): Likewise.
8350 (__arm_vcmphiq_n_u32): Likewise.
8351 (__arm_vcmpeqq_u32): Likewise.
8352 (__arm_vcmpeqq_n_u32): Likewise.
8353 (__arm_vcmpcsq_u32): Likewise.
8354 (__arm_vcmpcsq_n_u32): Likewise.
8355 (__arm_vcaddq_rot90_u32): Likewise.
8356 (__arm_vcaddq_rot270_u32): Likewise.
8357 (__arm_vbicq_u32): Likewise.
8358 (__arm_vandq_u32): Likewise.
8359 (__arm_vaddvq_p_u32): Likewise.
8360 (__arm_vaddvaq_u32): Likewise.
8361 (__arm_vaddq_n_u32): Likewise.
8362 (__arm_vabdq_u32): Likewise.
8363 (__arm_vshlq_r_u32): Likewise.
8364 (__arm_vrshlq_u32): Likewise.
8365 (__arm_vrshlq_n_u32): Likewise.
8366 (__arm_vqshlq_u32): Likewise.
8367 (__arm_vqshlq_r_u32): Likewise.
8368 (__arm_vqrshlq_u32): Likewise.
8369 (__arm_vqrshlq_n_u32): Likewise.
8370 (__arm_vminavq_s32): Likewise.
8371 (__arm_vminaq_s32): Likewise.
8372 (__arm_vmaxavq_s32): Likewise.
8373 (__arm_vmaxaq_s32): Likewise.
8374 (__arm_vbrsrq_n_u32): Likewise.
8375 (__arm_vshlq_n_u32): Likewise.
8376 (__arm_vrshrq_n_u32): Likewise.
8377 (__arm_vqshlq_n_u32): Likewise.
8378 (__arm_vcmpneq_n_s32): Likewise.
8379 (__arm_vcmpltq_s32): Likewise.
8380 (__arm_vcmpltq_n_s32): Likewise.
8381 (__arm_vcmpleq_s32): Likewise.
8382 (__arm_vcmpleq_n_s32): Likewise.
8383 (__arm_vcmpgtq_s32): Likewise.
8384 (__arm_vcmpgtq_n_s32): Likewise.
8385 (__arm_vcmpgeq_s32): Likewise.
8386 (__arm_vcmpgeq_n_s32): Likewise.
8387 (__arm_vcmpeqq_s32): Likewise.
8388 (__arm_vcmpeqq_n_s32): Likewise.
8389 (__arm_vqshluq_n_s32): Likewise.
8390 (__arm_vaddvq_p_s32): Likewise.
8391 (__arm_vsubq_s32): Likewise.
8392 (__arm_vsubq_n_s32): Likewise.
8393 (__arm_vshlq_r_s32): Likewise.
8394 (__arm_vrshlq_s32): Likewise.
8395 (__arm_vrshlq_n_s32): Likewise.
8396 (__arm_vrmulhq_s32): Likewise.
8397 (__arm_vrhaddq_s32): Likewise.
8398 (__arm_vqsubq_s32): Likewise.
8399 (__arm_vqsubq_n_s32): Likewise.
8400 (__arm_vqshlq_s32): Likewise.
8401 (__arm_vqshlq_r_s32): Likewise.
8402 (__arm_vqrshlq_s32): Likewise.
8403 (__arm_vqrshlq_n_s32): Likewise.
8404 (__arm_vqrdmulhq_s32): Likewise.
8405 (__arm_vqrdmulhq_n_s32): Likewise.
8406 (__arm_vqdmulhq_s32): Likewise.
8407 (__arm_vqdmulhq_n_s32): Likewise.
8408 (__arm_vqaddq_s32): Likewise.
8409 (__arm_vqaddq_n_s32): Likewise.
8410 (__arm_vorrq_s32): Likewise.
8411 (__arm_vornq_s32): Likewise.
8412 (__arm_vmulq_s32): Likewise.
8413 (__arm_vmulq_n_s32): Likewise.
8414 (__arm_vmulltq_int_s32): Likewise.
8415 (__arm_vmullbq_int_s32): Likewise.
8416 (__arm_vmulhq_s32): Likewise.
8417 (__arm_vmlsdavxq_s32): Likewise.
8418 (__arm_vmlsdavq_s32): Likewise.
8419 (__arm_vmladavxq_s32): Likewise.
8420 (__arm_vmladavq_s32): Likewise.
8421 (__arm_vminvq_s32): Likewise.
8422 (__arm_vminq_s32): Likewise.
8423 (__arm_vmaxvq_s32): Likewise.
8424 (__arm_vmaxq_s32): Likewise.
8425 (__arm_vhsubq_s32): Likewise.
8426 (__arm_vhsubq_n_s32): Likewise.
8427 (__arm_vhcaddq_rot90_s32): Likewise.
8428 (__arm_vhcaddq_rot270_s32): Likewise.
8429 (__arm_vhaddq_s32): Likewise.
8430 (__arm_vhaddq_n_s32): Likewise.
8431 (__arm_veorq_s32): Likewise.
8432 (__arm_vcaddq_rot90_s32): Likewise.
8433 (__arm_vcaddq_rot270_s32): Likewise.
8434 (__arm_vbrsrq_n_s32): Likewise.
8435 (__arm_vbicq_s32): Likewise.
8436 (__arm_vandq_s32): Likewise.
8437 (__arm_vaddvaq_s32): Likewise.
8438 (__arm_vaddq_n_s32): Likewise.
8439 (__arm_vabdq_s32): Likewise.
8440 (__arm_vshlq_n_s32): Likewise.
8441 (__arm_vrshrq_n_s32): Likewise.
8442 (__arm_vqshlq_n_s32): Likewise.
8443 (vsubq): Define polymorphic variant.
8444 (vsubq_n): Likewise.
8445 (vshlq_r): Likewise.
8446 (vrshlq_n): Likewise.
8447 (vrshlq): Likewise.
8448 (vrmulhq): Likewise.
8449 (vrhaddq): Likewise.
8450 (vqsubq_n): Likewise.
8451 (vqsubq): Likewise.
8452 (vqshlq): Likewise.
8453 (vqshlq_r): Likewise.
8454 (vqshluq): Likewise.
8455 (vrshrq_n): Likewise.
8456 (vshlq_n): Likewise.
8457 (vqshluq_n): Likewise.
8458 (vqshlq_n): Likewise.
8459 (vqrshlq_n): Likewise.
8460 (vqrshlq): Likewise.
8461 (vqrdmulhq_n): Likewise.
8462 (vqrdmulhq): Likewise.
8463 (vqdmulhq_n): Likewise.
8464 (vqdmulhq): Likewise.
8465 (vqaddq_n): Likewise.
8466 (vqaddq): Likewise.
8467 (vorrq_n): Likewise.
8468 (vorrq): Likewise.
8469 (vornq): Likewise.
8470 (vmulq_n): Likewise.
8471 (vmulq): Likewise.
8472 (vmulltq_int): Likewise.
8473 (vmullbq_int): Likewise.
8474 (vmulhq): Likewise.
8475 (vminq): Likewise.
8476 (vminaq): Likewise.
8477 (vmaxq): Likewise.
8478 (vmaxaq): Likewise.
8479 (vhsubq_n): Likewise.
8480 (vhsubq): Likewise.
8481 (vhcaddq_rot90): Likewise.
8482 (vhcaddq_rot270): Likewise.
8483 (vhaddq_n): Likewise.
8484 (vhaddq): Likewise.
8485 (veorq): Likewise.
8486 (vcaddq_rot90): Likewise.
8487 (vcaddq_rot270): Likewise.
8488 (vbrsrq_n): Likewise.
8489 (vbicq_n): Likewise.
8490 (vbicq): Likewise.
8491 (vaddq): Likewise.
8492 (vaddq_n): Likewise.
8493 (vandq): Likewise.
8494 (vabdq): Likewise.
8495 * config/arm/arm_mve_builtins.def (BINOP_NONE_NONE_IMM): Use it.
8496 (BINOP_NONE_NONE_NONE): Likewise.
8497 (BINOP_NONE_NONE_UNONE): Likewise.
8498 (BINOP_UNONE_NONE_IMM): Likewise.
8499 (BINOP_UNONE_NONE_NONE): Likewise.
8500 (BINOP_UNONE_UNONE_IMM): Likewise.
8501 (BINOP_UNONE_UNONE_NONE): Likewise.
8502 (BINOP_UNONE_UNONE_UNONE): Likewise.
8503 * config/arm/constraints.md (Ra): Define constraint to check constant is
8504 in the range of 0 to 7.
8505 (Rg): Define constriant to check the constant is one among 1, 2, 4
8506 and 8.
8507 * config/arm/mve.md (mve_vabdq_<supf>): Define RTL pattern.
8508 (mve_vaddq_n_<supf>): Likewise.
8509 (mve_vaddvaq_<supf>): Likewise.
8510 (mve_vaddvq_p_<supf>): Likewise.
8511 (mve_vandq_<supf>): Likewise.
8512 (mve_vbicq_<supf>): Likewise.
8513 (mve_vbrsrq_n_<supf>): Likewise.
8514 (mve_vcaddq_rot270_<supf>): Likewise.
8515 (mve_vcaddq_rot90_<supf>): Likewise.
8516 (mve_vcmpcsq_n_u): Likewise.
8517 (mve_vcmpcsq_u): Likewise.
8518 (mve_vcmpeqq_n_<supf>): Likewise.
8519 (mve_vcmpeqq_<supf>): Likewise.
8520 (mve_vcmpgeq_n_s): Likewise.
8521 (mve_vcmpgeq_s): Likewise.
8522 (mve_vcmpgtq_n_s): Likewise.
8523 (mve_vcmpgtq_s): Likewise.
8524 (mve_vcmphiq_n_u): Likewise.
8525 (mve_vcmphiq_u): Likewise.
8526 (mve_vcmpleq_n_s): Likewise.
8527 (mve_vcmpleq_s): Likewise.
8528 (mve_vcmpltq_n_s): Likewise.
8529 (mve_vcmpltq_s): Likewise.
8530 (mve_vcmpneq_n_<supf>): Likewise.
8531 (mve_vddupq_n_u): Likewise.
8532 (mve_veorq_<supf>): Likewise.
8533 (mve_vhaddq_n_<supf>): Likewise.
8534 (mve_vhaddq_<supf>): Likewise.
8535 (mve_vhcaddq_rot270_s): Likewise.
8536 (mve_vhcaddq_rot90_s): Likewise.
8537 (mve_vhsubq_n_<supf>): Likewise.
8538 (mve_vhsubq_<supf>): Likewise.
8539 (mve_vidupq_n_u): Likewise.
8540 (mve_vmaxaq_s): Likewise.
8541 (mve_vmaxavq_s): Likewise.
8542 (mve_vmaxq_<supf>): Likewise.
8543 (mve_vmaxvq_<supf>): Likewise.
8544 (mve_vminaq_s): Likewise.
8545 (mve_vminavq_s): Likewise.
8546 (mve_vminq_<supf>): Likewise.
8547 (mve_vminvq_<supf>): Likewise.
8548 (mve_vmladavq_<supf>): Likewise.
8549 (mve_vmladavxq_s): Likewise.
8550 (mve_vmlsdavq_s): Likewise.
8551 (mve_vmlsdavxq_s): Likewise.
8552 (mve_vmulhq_<supf>): Likewise.
8553 (mve_vmullbq_int_<supf>): Likewise.
8554 (mve_vmulltq_int_<supf>): Likewise.
8555 (mve_vmulq_n_<supf>): Likewise.
8556 (mve_vmulq_<supf>): Likewise.
8557 (mve_vornq_<supf>): Likewise.
8558 (mve_vorrq_<supf>): Likewise.
8559 (mve_vqaddq_n_<supf>): Likewise.
8560 (mve_vqaddq_<supf>): Likewise.
8561 (mve_vqdmulhq_n_s): Likewise.
8562 (mve_vqdmulhq_s): Likewise.
8563 (mve_vqrdmulhq_n_s): Likewise.
8564 (mve_vqrdmulhq_s): Likewise.
8565 (mve_vqrshlq_n_<supf>): Likewise.
8566 (mve_vqrshlq_<supf>): Likewise.
8567 (mve_vqshlq_n_<supf>): Likewise.
8568 (mve_vqshlq_r_<supf>): Likewise.
8569 (mve_vqshlq_<supf>): Likewise.
8570 (mve_vqshluq_n_s): Likewise.
8571 (mve_vqsubq_n_<supf>): Likewise.
8572 (mve_vqsubq_<supf>): Likewise.
8573 (mve_vrhaddq_<supf>): Likewise.
8574 (mve_vrmulhq_<supf>): Likewise.
8575 (mve_vrshlq_n_<supf>): Likewise.
8576 (mve_vrshlq_<supf>): Likewise.
8577 (mve_vrshrq_n_<supf>): Likewise.
8578 (mve_vshlq_n_<supf>): Likewise.
8579 (mve_vshlq_r_<supf>): Likewise.
8580 (mve_vsubq_n_<supf>): Likewise.
8581 (mve_vsubq_<supf>): Likewise.
8582 * config/arm/predicates.md (mve_imm_7): Define predicate to check
8583 the matching constraint Ra.
8584 (mve_imm_selective_upto_8): Define predicate to check the matching
8585 constraint Rg.
8586
8587 2020-03-17 Andre Vieira <andre.simoesdiasvieira@arm.com>
8588 Mihail Ionescu <mihail.ionescu@arm.com>
8589 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
8590
8591 * config/arm/arm-builtins.c (BINOP_NONE_NONE_UNONE_QUALIFIERS): Define
8592 qualifier for binary operands.
8593 (BINOP_UNONE_NONE_NONE_QUALIFIERS): Likewise.
8594 (BINOP_UNONE_UNONE_NONE_QUALIFIERS): Likewise.
8595 * config/arm/arm_mve.h (vaddlvq_p_s32): Define macro.
8596 (vaddlvq_p_u32): Likewise.
8597 (vcmpneq_s8): Likewise.
8598 (vcmpneq_s16): Likewise.
8599 (vcmpneq_s32): Likewise.
8600 (vcmpneq_u8): Likewise.
8601 (vcmpneq_u16): Likewise.
8602 (vcmpneq_u32): Likewise.
8603 (vshlq_s8): Likewise.
8604 (vshlq_s16): Likewise.
8605 (vshlq_s32): Likewise.
8606 (vshlq_u8): Likewise.
8607 (vshlq_u16): Likewise.
8608 (vshlq_u32): Likewise.
8609 (__arm_vaddlvq_p_s32): Define intrinsic.
8610 (__arm_vaddlvq_p_u32): Likewise.
8611 (__arm_vcmpneq_s8): Likewise.
8612 (__arm_vcmpneq_s16): Likewise.
8613 (__arm_vcmpneq_s32): Likewise.
8614 (__arm_vcmpneq_u8): Likewise.
8615 (__arm_vcmpneq_u16): Likewise.
8616 (__arm_vcmpneq_u32): Likewise.
8617 (__arm_vshlq_s8): Likewise.
8618 (__arm_vshlq_s16): Likewise.
8619 (__arm_vshlq_s32): Likewise.
8620 (__arm_vshlq_u8): Likewise.
8621 (__arm_vshlq_u16): Likewise.
8622 (__arm_vshlq_u32): Likewise.
8623 (vaddlvq_p): Define polymorphic variant.
8624 (vcmpneq): Likewise.
8625 (vshlq): Likewise.
8626 * config/arm/arm_mve_builtins.def (BINOP_NONE_NONE_UNONE_QUALIFIERS):
8627 Use it.
8628 (BINOP_UNONE_NONE_NONE_QUALIFIERS): Likewise.
8629 (BINOP_UNONE_UNONE_NONE_QUALIFIERS): Likewise.
8630 * config/arm/mve.md (mve_vaddlvq_p_<supf>v4si): Define RTL pattern.
8631 (mve_vcmpneq_<supf><mode>): Likewise.
8632 (mve_vshlq_<supf><mode>): Likewise.
8633
8634 2020-03-17 Andre Vieira <andre.simoesdiasvieira@arm.com>
8635 Mihail Ionescu <mihail.ionescu@arm.com>
8636 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
8637
8638 * config/arm/arm-builtins.c (BINOP_UNONE_UNONE_IMM_QUALIFIERS): Define
8639 qualifier for binary operands.
8640 (BINOP_UNONE_UNONE_UNONE_QUALIFIERS): Likewise.
8641 (BINOP_UNONE_NONE_IMM_QUALIFIERS): Likewise.
8642 * config/arm/arm_mve.h (vcvtq_n_s16_f16): Define macro.
8643 (vcvtq_n_s32_f32): Likewise.
8644 (vcvtq_n_u16_f16): Likewise.
8645 (vcvtq_n_u32_f32): Likewise.
8646 (vcreateq_u8): Likewise.
8647 (vcreateq_u16): Likewise.
8648 (vcreateq_u32): Likewise.
8649 (vcreateq_u64): Likewise.
8650 (vcreateq_s8): Likewise.
8651 (vcreateq_s16): Likewise.
8652 (vcreateq_s32): Likewise.
8653 (vcreateq_s64): Likewise.
8654 (vshrq_n_s8): Likewise.
8655 (vshrq_n_s16): Likewise.
8656 (vshrq_n_s32): Likewise.
8657 (vshrq_n_u8): Likewise.
8658 (vshrq_n_u16): Likewise.
8659 (vshrq_n_u32): Likewise.
8660 (__arm_vcreateq_u8): Define intrinsic.
8661 (__arm_vcreateq_u16): Likewise.
8662 (__arm_vcreateq_u32): Likewise.
8663 (__arm_vcreateq_u64): Likewise.
8664 (__arm_vcreateq_s8): Likewise.
8665 (__arm_vcreateq_s16): Likewise.
8666 (__arm_vcreateq_s32): Likewise.
8667 (__arm_vcreateq_s64): Likewise.
8668 (__arm_vshrq_n_s8): Likewise.
8669 (__arm_vshrq_n_s16): Likewise.
8670 (__arm_vshrq_n_s32): Likewise.
8671 (__arm_vshrq_n_u8): Likewise.
8672 (__arm_vshrq_n_u16): Likewise.
8673 (__arm_vshrq_n_u32): Likewise.
8674 (__arm_vcvtq_n_s16_f16): Likewise.
8675 (__arm_vcvtq_n_s32_f32): Likewise.
8676 (__arm_vcvtq_n_u16_f16): Likewise.
8677 (__arm_vcvtq_n_u32_f32): Likewise.
8678 (vshrq_n): Define polymorphic variant.
8679 * config/arm/arm_mve_builtins.def (BINOP_UNONE_UNONE_IMM_QUALIFIERS):
8680 Use it.
8681 (BINOP_UNONE_UNONE_UNONE_QUALIFIERS): Likewise.
8682 (BINOP_UNONE_NONE_IMM_QUALIFIERS): Likewise.
8683 * config/arm/constraints.md (Rb): Define constraint to check constant is
8684 in the range of 1 to 8.
8685 (Rf): Define constraint to check constant is in the range of 1 to 32.
8686 * config/arm/mve.md (mve_vcreateq_<supf><mode>): Define RTL pattern.
8687 (mve_vshrq_n_<supf><mode>): Likewise.
8688 (mve_vcvtq_n_from_f_<supf><mode>): Likewise.
8689 * config/arm/predicates.md (mve_imm_8): Define predicate to check
8690 the matching constraint Rb.
8691 (mve_imm_32): Define predicate to check the matching constraint Rf.
8692
8693 2020-03-17 Andre Vieira <andre.simoesdiasvieira@arm.com>
8694 Mihail Ionescu <mihail.ionescu@arm.com>
8695 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
8696
8697 * config/arm/arm-builtins.c (BINOP_NONE_NONE_NONE_QUALIFIERS): Define
8698 qualifier for binary operands.
8699 (BINOP_NONE_NONE_IMM_QUALIFIERS): Likewise.
8700 (BINOP_NONE_UNONE_IMM_QUALIFIERS): Likewise.
8701 (BINOP_NONE_UNONE_UNONE_QUALIFIERS): Likewise.
8702 * config/arm/arm_mve.h (vsubq_n_f16): Define macro.
8703 (vsubq_n_f32): Likewise.
8704 (vbrsrq_n_f16): Likewise.
8705 (vbrsrq_n_f32): Likewise.
8706 (vcvtq_n_f16_s16): Likewise.
8707 (vcvtq_n_f32_s32): Likewise.
8708 (vcvtq_n_f16_u16): Likewise.
8709 (vcvtq_n_f32_u32): Likewise.
8710 (vcreateq_f16): Likewise.
8711 (vcreateq_f32): Likewise.
8712 (__arm_vsubq_n_f16): Define intrinsic.
8713 (__arm_vsubq_n_f32): Likewise.
8714 (__arm_vbrsrq_n_f16): Likewise.
8715 (__arm_vbrsrq_n_f32): Likewise.
8716 (__arm_vcvtq_n_f16_s16): Likewise.
8717 (__arm_vcvtq_n_f32_s32): Likewise.
8718 (__arm_vcvtq_n_f16_u16): Likewise.
8719 (__arm_vcvtq_n_f32_u32): Likewise.
8720 (__arm_vcreateq_f16): Likewise.
8721 (__arm_vcreateq_f32): Likewise.
8722 (vsubq): Define polymorphic variant.
8723 (vbrsrq): Likewise.
8724 (vcvtq_n): Likewise.
8725 * config/arm/arm_mve_builtins.def (BINOP_NONE_NONE_NONE_QUALIFIERS): Use
8726 it.
8727 (BINOP_NONE_NONE_IMM_QUALIFIERS): Likewise.
8728 (BINOP_NONE_UNONE_IMM_QUALIFIERS): Likewise.
8729 (BINOP_NONE_UNONE_UNONE_QUALIFIERS): Likewise.
8730 * config/arm/constraints.md (Rd): Define constraint to check constant is
8731 in the range of 1 to 16.
8732 * config/arm/mve.md (mve_vsubq_n_f<mode>): Define RTL pattern.
8733 mve_vbrsrq_n_f<mode>: Likewise.
8734 mve_vcvtq_n_to_f_<supf><mode>: Likewise.
8735 mve_vcreateq_f<mode>: Likewise.
8736 * config/arm/predicates.md (mve_imm_16): Define predicate to check
8737 the matching constraint Rd.
8738
8739 2020-03-17 Andre Vieira <andre.simoesdiasvieira@arm.com>
8740 Mihail Ionescu <mihail.ionescu@arm.com>
8741 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
8742
8743 * config/arm/arm-builtins.c (hi_UP): Define mode.
8744 * config/arm/arm.h (IS_VPR_REGNUM): Move.
8745 * config/arm/arm.md (VPR_REGNUM): Define before APSRQ_REGNUM.
8746 (APSRQ_REGNUM): Modify.
8747 (APSRGE_REGNUM): Modify.
8748 * config/arm/arm_mve.h (vctp16q): Define macro.
8749 (vctp32q): Likewise.
8750 (vctp64q): Likewise.
8751 (vctp8q): Likewise.
8752 (vpnot): Likewise.
8753 (__arm_vctp16q): Define intrinsic.
8754 (__arm_vctp32q): Likewise.
8755 (__arm_vctp64q): Likewise.
8756 (__arm_vctp8q): Likewise.
8757 (__arm_vpnot): Likewise.
8758 * config/arm/arm_mve_builtins.def (UNOP_UNONE_UNONE): Use builtin
8759 qualifier.
8760 * config/arm/mve.md (mve_vctp<mode1>qhi): Define RTL pattern.
8761 (mve_vpnothi): Likewise.
8762
8763 2020-03-17 Andre Vieira <andre.simoesdiasvieira@arm.com>
8764 Mihail Ionescu <mihail.ionescu@arm.com>
8765 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
8766
8767 * config/arm/arm.h (enum reg_class): Define new class EVEN_REGS.
8768 * config/arm/arm_mve.h (vdupq_n_s8): Define macro.
8769 (vdupq_n_s16): Likewise.
8770 (vdupq_n_s32): Likewise.
8771 (vabsq_s8): Likewise.
8772 (vabsq_s16): Likewise.
8773 (vabsq_s32): Likewise.
8774 (vclsq_s8): Likewise.
8775 (vclsq_s16): Likewise.
8776 (vclsq_s32): Likewise.
8777 (vclzq_s8): Likewise.
8778 (vclzq_s16): Likewise.
8779 (vclzq_s32): Likewise.
8780 (vnegq_s8): Likewise.
8781 (vnegq_s16): Likewise.
8782 (vnegq_s32): Likewise.
8783 (vaddlvq_s32): Likewise.
8784 (vaddvq_s8): Likewise.
8785 (vaddvq_s16): Likewise.
8786 (vaddvq_s32): Likewise.
8787 (vmovlbq_s8): Likewise.
8788 (vmovlbq_s16): Likewise.
8789 (vmovltq_s8): Likewise.
8790 (vmovltq_s16): Likewise.
8791 (vmvnq_s8): Likewise.
8792 (vmvnq_s16): Likewise.
8793 (vmvnq_s32): Likewise.
8794 (vrev16q_s8): Likewise.
8795 (vrev32q_s8): Likewise.
8796 (vrev32q_s16): Likewise.
8797 (vqabsq_s8): Likewise.
8798 (vqabsq_s16): Likewise.
8799 (vqabsq_s32): Likewise.
8800 (vqnegq_s8): Likewise.
8801 (vqnegq_s16): Likewise.
8802 (vqnegq_s32): Likewise.
8803 (vcvtaq_s16_f16): Likewise.
8804 (vcvtaq_s32_f32): Likewise.
8805 (vcvtnq_s16_f16): Likewise.
8806 (vcvtnq_s32_f32): Likewise.
8807 (vcvtpq_s16_f16): Likewise.
8808 (vcvtpq_s32_f32): Likewise.
8809 (vcvtmq_s16_f16): Likewise.
8810 (vcvtmq_s32_f32): Likewise.
8811 (vmvnq_u8): Likewise.
8812 (vmvnq_u16): Likewise.
8813 (vmvnq_u32): Likewise.
8814 (vdupq_n_u8): Likewise.
8815 (vdupq_n_u16): Likewise.
8816 (vdupq_n_u32): Likewise.
8817 (vclzq_u8): Likewise.
8818 (vclzq_u16): Likewise.
8819 (vclzq_u32): Likewise.
8820 (vaddvq_u8): Likewise.
8821 (vaddvq_u16): Likewise.
8822 (vaddvq_u32): Likewise.
8823 (vrev32q_u8): Likewise.
8824 (vrev32q_u16): Likewise.
8825 (vmovltq_u8): Likewise.
8826 (vmovltq_u16): Likewise.
8827 (vmovlbq_u8): Likewise.
8828 (vmovlbq_u16): Likewise.
8829 (vrev16q_u8): Likewise.
8830 (vaddlvq_u32): Likewise.
8831 (vcvtpq_u16_f16): Likewise.
8832 (vcvtpq_u32_f32): Likewise.
8833 (vcvtnq_u16_f16): Likewise.
8834 (vcvtmq_u16_f16): Likewise.
8835 (vcvtmq_u32_f32): Likewise.
8836 (vcvtaq_u16_f16): Likewise.
8837 (vcvtaq_u32_f32): Likewise.
8838 (__arm_vdupq_n_s8): Define intrinsic.
8839 (__arm_vdupq_n_s16): Likewise.
8840 (__arm_vdupq_n_s32): Likewise.
8841 (__arm_vabsq_s8): Likewise.
8842 (__arm_vabsq_s16): Likewise.
8843 (__arm_vabsq_s32): Likewise.
8844 (__arm_vclsq_s8): Likewise.
8845 (__arm_vclsq_s16): Likewise.
8846 (__arm_vclsq_s32): Likewise.
8847 (__arm_vclzq_s8): Likewise.
8848 (__arm_vclzq_s16): Likewise.
8849 (__arm_vclzq_s32): Likewise.
8850 (__arm_vnegq_s8): Likewise.
8851 (__arm_vnegq_s16): Likewise.
8852 (__arm_vnegq_s32): Likewise.
8853 (__arm_vaddlvq_s32): Likewise.
8854 (__arm_vaddvq_s8): Likewise.
8855 (__arm_vaddvq_s16): Likewise.
8856 (__arm_vaddvq_s32): Likewise.
8857 (__arm_vmovlbq_s8): Likewise.
8858 (__arm_vmovlbq_s16): Likewise.
8859 (__arm_vmovltq_s8): Likewise.
8860 (__arm_vmovltq_s16): Likewise.
8861 (__arm_vmvnq_s8): Likewise.
8862 (__arm_vmvnq_s16): Likewise.
8863 (__arm_vmvnq_s32): Likewise.
8864 (__arm_vrev16q_s8): Likewise.
8865 (__arm_vrev32q_s8): Likewise.
8866 (__arm_vrev32q_s16): Likewise.
8867 (__arm_vqabsq_s8): Likewise.
8868 (__arm_vqabsq_s16): Likewise.
8869 (__arm_vqabsq_s32): Likewise.
8870 (__arm_vqnegq_s8): Likewise.
8871 (__arm_vqnegq_s16): Likewise.
8872 (__arm_vqnegq_s32): Likewise.
8873 (__arm_vmvnq_u8): Likewise.
8874 (__arm_vmvnq_u16): Likewise.
8875 (__arm_vmvnq_u32): Likewise.
8876 (__arm_vdupq_n_u8): Likewise.
8877 (__arm_vdupq_n_u16): Likewise.
8878 (__arm_vdupq_n_u32): Likewise.
8879 (__arm_vclzq_u8): Likewise.
8880 (__arm_vclzq_u16): Likewise.
8881 (__arm_vclzq_u32): Likewise.
8882 (__arm_vaddvq_u8): Likewise.
8883 (__arm_vaddvq_u16): Likewise.
8884 (__arm_vaddvq_u32): Likewise.
8885 (__arm_vrev32q_u8): Likewise.
8886 (__arm_vrev32q_u16): Likewise.
8887 (__arm_vmovltq_u8): Likewise.
8888 (__arm_vmovltq_u16): Likewise.
8889 (__arm_vmovlbq_u8): Likewise.
8890 (__arm_vmovlbq_u16): Likewise.
8891 (__arm_vrev16q_u8): Likewise.
8892 (__arm_vaddlvq_u32): Likewise.
8893 (__arm_vcvtpq_u16_f16): Likewise.
8894 (__arm_vcvtpq_u32_f32): Likewise.
8895 (__arm_vcvtnq_u16_f16): Likewise.
8896 (__arm_vcvtmq_u16_f16): Likewise.
8897 (__arm_vcvtmq_u32_f32): Likewise.
8898 (__arm_vcvtaq_u16_f16): Likewise.
8899 (__arm_vcvtaq_u32_f32): Likewise.
8900 (__arm_vcvtaq_s16_f16): Likewise.
8901 (__arm_vcvtaq_s32_f32): Likewise.
8902 (__arm_vcvtnq_s16_f16): Likewise.
8903 (__arm_vcvtnq_s32_f32): Likewise.
8904 (__arm_vcvtpq_s16_f16): Likewise.
8905 (__arm_vcvtpq_s32_f32): Likewise.
8906 (__arm_vcvtmq_s16_f16): Likewise.
8907 (__arm_vcvtmq_s32_f32): Likewise.
8908 (vdupq_n): Define polymorphic variant.
8909 (vabsq): Likewise.
8910 (vclsq): Likewise.
8911 (vclzq): Likewise.
8912 (vnegq): Likewise.
8913 (vaddlvq): Likewise.
8914 (vaddvq): Likewise.
8915 (vmovlbq): Likewise.
8916 (vmovltq): Likewise.
8917 (vmvnq): Likewise.
8918 (vrev16q): Likewise.
8919 (vrev32q): Likewise.
8920 (vqabsq): Likewise.
8921 (vqnegq): Likewise.
8922 * config/arm/arm_mve_builtins.def (UNOP_SNONE_SNONE): Use it.
8923 (UNOP_SNONE_NONE): Likewise.
8924 (UNOP_UNONE_UNONE): Likewise.
8925 (UNOP_UNONE_NONE): Likewise.
8926 * config/arm/constraints.md (e): Define new constriant to allow only
8927 even registers.
8928 * config/arm/mve.md (mve_vqabsq_s<mode>): Define RTL pattern.
8929 (mve_vnegq_s<mode>): Likewise.
8930 (mve_vmvnq_<supf><mode>): Likewise.
8931 (mve_vdupq_n_<supf><mode>): Likewise.
8932 (mve_vclzq_<supf><mode>): Likewise.
8933 (mve_vclsq_s<mode>): Likewise.
8934 (mve_vaddvq_<supf><mode>): Likewise.
8935 (mve_vabsq_s<mode>): Likewise.
8936 (mve_vrev32q_<supf><mode>): Likewise.
8937 (mve_vmovltq_<supf><mode>): Likewise.
8938 (mve_vmovlbq_<supf><mode>): Likewise.
8939 (mve_vcvtpq_<supf><mode>): Likewise.
8940 (mve_vcvtnq_<supf><mode>): Likewise.
8941 (mve_vcvtmq_<supf><mode>): Likewise.
8942 (mve_vcvtaq_<supf><mode>): Likewise.
8943 (mve_vrev16q_<supf>v16qi): Likewise.
8944 (mve_vaddlvq_<supf>v4si): Likewise.
8945
8946 2020-03-17 Jakub Jelinek <jakub@redhat.com>
8947
8948 * lra-spills.c (remove_pseudos): Fix up duplicated word issue in
8949 a dump message.
8950 * tree-sra.c (create_access_replacement): Fix up duplicated word issue
8951 in a comment.
8952 * read-rtl-function.c (find_param_by_name,
8953 function_reader::parse_enum_value, function_reader::get_insn_by_uid):
8954 Likewise.
8955 * spellcheck.c (get_edit_distance_cutoff): Likewise.
8956 * tree-data-ref.c (create_ifn_alias_checks): Likewise.
8957 * tree.def (SWITCH_EXPR): Likewise.
8958 * selftest.c (assert_str_contains): Likewise.
8959 * ipa-param-manipulation.h (class ipa_param_body_adjustments):
8960 Likewise.
8961 * tree-ssa-math-opts.c (convert_expand_mult_copysign): Likewise.
8962 * tree-ssa-loop-split.c (find_vdef_in_loop): Likewise.
8963 * langhooks.h (struct lang_hooks_for_decls): Likewise.
8964 * ipa-prop.h (struct ipa_param_descriptor): Likewise.
8965 * tree-ssa-strlen.c (handle_builtin_string_cmp, handle_store):
8966 Likewise.
8967 * tree-ssa-dom.c (simplify_stmt_for_jump_threading): Likewise.
8968 * tree-ssa-reassoc.c (reassociate_bb): Likewise.
8969 * tree.c (component_ref_size): Likewise.
8970 * hsa-common.c (hsa_init_compilation_unit_data): Likewise.
8971 * gimple-ssa-sprintf.c (get_string_length, format_string,
8972 format_directive): Likewise.
8973 * omp-grid.c (grid_process_kernel_body_copy): Likewise.
8974 * input.c (string_concat_db::get_string_concatenation,
8975 test_lexer_string_locations_ucn4): Likewise.
8976 * cfgexpand.c (pass_expand::execute): Likewise.
8977 * gimple-ssa-warn-restrict.c (builtin_memref::offset_out_of_bounds,
8978 maybe_diag_overlap): Likewise.
8979 * rtl.c (RTX_CODE_HWINT_P_1): Likewise.
8980 * shrink-wrap.c (spread_components): Likewise.
8981 * tree-ssa-dse.c (initialize_ao_ref_for_dse, valid_ao_ref_for_dse):
8982 Likewise.
8983 * tree-call-cdce.c (shrink_wrap_one_built_in_call_with_conds):
8984 Likewise.
8985 * dwarf2out.c (dwarf2out_early_finish): Likewise.
8986 * gimple-ssa-store-merging.c: Likewise.
8987 * ira-costs.c (record_operand_costs): Likewise.
8988 * tree-vect-loop.c (vectorizable_reduction): Likewise.
8989 * target.def (dispatch): Likewise.
8990 (validate_dims, gen_ccmp_first): Fix up duplicated word issue
8991 in documentation text.
8992 * doc/tm.texi: Regenerated.
8993 * config/i386/x86-tune.def (X86_TUNE_PARTIAL_FLAG_REG_STALL): Fix up
8994 duplicated word issue in a comment.
8995 * config/i386/i386.c (ix86_test_loading_unspec): Likewise.
8996 * config/i386/i386-features.c (remove_partial_avx_dependency):
8997 Likewise.
8998 * config/msp430/msp430.c (msp430_select_section): Likewise.
8999 * config/gcn/gcn-run.c (load_image): Likewise.
9000 * config/aarch64/aarch64-sve.md (sve_ld1r<mode>): Likewise.
9001 * config/aarch64/aarch64.c (aarch64_gen_adjusted_ldpstp): Likewise.
9002 * config/aarch64/falkor-tag-collision-avoidance.c
9003 (single_dest_per_chain): Likewise.
9004 * config/nvptx/nvptx.c (nvptx_record_fndecl): Likewise.
9005 * config/fr30/fr30.c (fr30_arg_partial_bytes): Likewise.
9006 * config/rs6000/rs6000-string.c (expand_cmp_vec_sequence): Likewise.
9007 * config/rs6000/rs6000-p8swap.c (replace_swapped_load_constant):
9008 Likewise.
9009 * config/rs6000/rs6000-c.c (rs6000_target_modify_macros): Likewise.
9010 * config/rs6000/rs6000.c (rs6000_option_override_internal): Likewise.
9011 * config/rs6000/rs6000-logue.c
9012 (rs6000_emit_probe_stack_range_stack_clash): Likewise.
9013 * config/nds32/nds32-md-auxiliary.c (nds32_split_ashiftdi3): Likewise.
9014 Fix various other issues in the comment.
9015
9016 2020-03-17 Mihail Ionescu <mihail.ionescu@arm.com>
9017
9018 * config/arm/t-rmprofile: create new multilib for
9019 armv8.1-m.main+mve hard float and reuse v8-m.main ones for
9020 v8.1-m.main+mve.
9021
9022 2020-03-17 Jakub Jelinek <jakub@redhat.com>
9023
9024 PR tree-optimization/94015
9025 * tree-ssa-strlen.c (count_nonzero_bytes): Split portions of the
9026 function where EXP is address of the bytes being stored rather than
9027 the bytes themselves into count_nonzero_bytes_addr. Punt on zero
9028 sized MEM_REF. Use VAR_P macro and handle CONST_DECL like VAR_DECLs.
9029 Use ctor_for_folding instead of looking at DECL_INITIAL. Punt before
9030 calling native_encode_expr if host or target doesn't have 8-bit
9031 chars. Formatting fixes.
9032 (count_nonzero_bytes_addr): New function.
9033
9034 2020-03-17 Andre Vieira <andre.simoesdiasvieira@arm.com>
9035 Mihail Ionescu <mihail.ionescu@arm.com>
9036 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
9037
9038 * config/arm/arm-builtins.c (UNOP_SNONE_SNONE_QUALIFIERS): Define.
9039 (UNOP_SNONE_NONE_QUALIFIERS): Likewise.
9040 (UNOP_SNONE_IMM_QUALIFIERS): Likewise.
9041 (UNOP_UNONE_NONE_QUALIFIERS): Likewise.
9042 (UNOP_UNONE_UNONE_QUALIFIERS): Likewise.
9043 (UNOP_UNONE_IMM_QUALIFIERS): Likewise.
9044 * config/arm/arm_mve.h (vmvnq_n_s16): Define macro.
9045 (vmvnq_n_s32): Likewise.
9046 (vrev64q_s8): Likewise.
9047 (vrev64q_s16): Likewise.
9048 (vrev64q_s32): Likewise.
9049 (vcvtq_s16_f16): Likewise.
9050 (vcvtq_s32_f32): Likewise.
9051 (vrev64q_u8): Likewise.
9052 (vrev64q_u16): Likewise.
9053 (vrev64q_u32): Likewise.
9054 (vmvnq_n_u16): Likewise.
9055 (vmvnq_n_u32): Likewise.
9056 (vcvtq_u16_f16): Likewise.
9057 (vcvtq_u32_f32): Likewise.
9058 (__arm_vmvnq_n_s16): Define intrinsic.
9059 (__arm_vmvnq_n_s32): Likewise.
9060 (__arm_vrev64q_s8): Likewise.
9061 (__arm_vrev64q_s16): Likewise.
9062 (__arm_vrev64q_s32): Likewise.
9063 (__arm_vrev64q_u8): Likewise.
9064 (__arm_vrev64q_u16): Likewise.
9065 (__arm_vrev64q_u32): Likewise.
9066 (__arm_vmvnq_n_u16): Likewise.
9067 (__arm_vmvnq_n_u32): Likewise.
9068 (__arm_vcvtq_s16_f16): Likewise.
9069 (__arm_vcvtq_s32_f32): Likewise.
9070 (__arm_vcvtq_u16_f16): Likewise.
9071 (__arm_vcvtq_u32_f32): Likewise.
9072 (vrev64q): Define polymorphic variant.
9073 * config/arm/arm_mve_builtins.def (UNOP_SNONE_SNONE): Use it.
9074 (UNOP_SNONE_NONE): Likewise.
9075 (UNOP_SNONE_IMM): Likewise.
9076 (UNOP_UNONE_UNONE): Likewise.
9077 (UNOP_UNONE_NONE): Likewise.
9078 (UNOP_UNONE_IMM): Likewise.
9079 * config/arm/mve.md (mve_vrev64q_<supf><mode>): Define RTL pattern.
9080 (mve_vcvtq_from_f_<supf><mode>): Likewise.
9081 (mve_vmvnq_n_<supf><mode>): Likewise.
9082
9083 2020-03-17 Andre Vieira <andre.simoesdiasvieira@arm.com>
9084 Mihail Ionescu <mihail.ionescu@arm.com>
9085 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
9086
9087 * config/arm/arm-builtins.c (UNOP_NONE_NONE_QUALIFIERS): Define macro.
9088 (UNOP_NONE_SNONE_QUALIFIERS): Likewise.
9089 (UNOP_NONE_UNONE_QUALIFIERS): Likewise.
9090 * config/arm/arm_mve.h (vrndxq_f16): Define macro.
9091 (vrndxq_f32): Likewise.
9092 (vrndq_f16) Likewise.
9093 (vrndq_f32): Likewise.
9094 (vrndpq_f16): Likewise.
9095 (vrndpq_f32): Likewise.
9096 (vrndnq_f16): Likewise.
9097 (vrndnq_f32): Likewise.
9098 (vrndmq_f16): Likewise.
9099 (vrndmq_f32): Likewise.
9100 (vrndaq_f16): Likewise.
9101 (vrndaq_f32): Likewise.
9102 (vrev64q_f16): Likewise.
9103 (vrev64q_f32): Likewise.
9104 (vnegq_f16): Likewise.
9105 (vnegq_f32): Likewise.
9106 (vdupq_n_f16): Likewise.
9107 (vdupq_n_f32): Likewise.
9108 (vabsq_f16): Likewise.
9109 (vabsq_f32): Likewise.
9110 (vrev32q_f16): Likewise.
9111 (vcvttq_f32_f16): Likewise.
9112 (vcvtbq_f32_f16): Likewise.
9113 (vcvtq_f16_s16): Likewise.
9114 (vcvtq_f32_s32): Likewise.
9115 (vcvtq_f16_u16): Likewise.
9116 (vcvtq_f32_u32): Likewise.
9117 (__arm_vrndxq_f16): Define intrinsic.
9118 (__arm_vrndxq_f32): Likewise.
9119 (__arm_vrndq_f16): Likewise.
9120 (__arm_vrndq_f32): Likewise.
9121 (__arm_vrndpq_f16): Likewise.
9122 (__arm_vrndpq_f32): Likewise.
9123 (__arm_vrndnq_f16): Likewise.
9124 (__arm_vrndnq_f32): Likewise.
9125 (__arm_vrndmq_f16): Likewise.
9126 (__arm_vrndmq_f32): Likewise.
9127 (__arm_vrndaq_f16): Likewise.
9128 (__arm_vrndaq_f32): Likewise.
9129 (__arm_vrev64q_f16): Likewise.
9130 (__arm_vrev64q_f32): Likewise.
9131 (__arm_vnegq_f16): Likewise.
9132 (__arm_vnegq_f32): Likewise.
9133 (__arm_vdupq_n_f16): Likewise.
9134 (__arm_vdupq_n_f32): Likewise.
9135 (__arm_vabsq_f16): Likewise.
9136 (__arm_vabsq_f32): Likewise.
9137 (__arm_vrev32q_f16): Likewise.
9138 (__arm_vcvttq_f32_f16): Likewise.
9139 (__arm_vcvtbq_f32_f16): Likewise.
9140 (__arm_vcvtq_f16_s16): Likewise.
9141 (__arm_vcvtq_f32_s32): Likewise.
9142 (__arm_vcvtq_f16_u16): Likewise.
9143 (__arm_vcvtq_f32_u32): Likewise.
9144 (vrndxq): Define polymorphic variants.
9145 (vrndq): Likewise.
9146 (vrndpq): Likewise.
9147 (vrndnq): Likewise.
9148 (vrndmq): Likewise.
9149 (vrndaq): Likewise.
9150 (vrev64q): Likewise.
9151 (vnegq): Likewise.
9152 (vabsq): Likewise.
9153 (vrev32q): Likewise.
9154 (vcvtbq_f32): Likewise.
9155 (vcvttq_f32): Likewise.
9156 (vcvtq): Likewise.
9157 * config/arm/arm_mve_builtins.def (VAR2): Define.
9158 (VAR1): Define.
9159 * config/arm/mve.md (mve_vrndxq_f<mode>): Add RTL pattern.
9160 (mve_vrndq_f<mode>): Likewise.
9161 (mve_vrndpq_f<mode>): Likewise.
9162 (mve_vrndnq_f<mode>): Likewise.
9163 (mve_vrndmq_f<mode>): Likewise.
9164 (mve_vrndaq_f<mode>): Likewise.
9165 (mve_vrev64q_f<mode>): Likewise.
9166 (mve_vnegq_f<mode>): Likewise.
9167 (mve_vdupq_n_f<mode>): Likewise.
9168 (mve_vabsq_f<mode>): Likewise.
9169 (mve_vrev32q_fv8hf): Likewise.
9170 (mve_vcvttq_f32_f16v4sf): Likewise.
9171 (mve_vcvtbq_f32_f16v4sf): Likewise.
9172 (mve_vcvtq_to_f_<supf><mode>): Likewise.
9173
9174 2020-03-16 Andre Vieira <andre.simoesdiasvieira@arm.com>
9175 Mihail Ionescu <mihail.ionescu@arm.com>
9176 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
9177
9178 * config/arm/arm-builtins.c (CF): Define mve_builtin_data.
9179 (VAR1): Define.
9180 (ARM_BUILTIN_MVE_PATTERN_START): Define.
9181 (arm_init_mve_builtins): Define function.
9182 (arm_init_builtins): Add TARGET_HAVE_MVE check.
9183 (arm_expand_builtin_1): Check the range of fcode.
9184 (arm_expand_mve_builtin): Define function to expand MVE builtins.
9185 (arm_expand_builtin): Check the range of fcode.
9186 * config/arm/arm_mve.h (__ARM_FEATURE_MVE): Define MVE floating point
9187 types.
9188 (__ARM_MVE_PRESERVE_USER_NAMESPACE): Define to protect user namespace.
9189 (vst4q_s8): Define macro.
9190 (vst4q_s16): Likewise.
9191 (vst4q_s32): Likewise.
9192 (vst4q_u8): Likewise.
9193 (vst4q_u16): Likewise.
9194 (vst4q_u32): Likewise.
9195 (vst4q_f16): Likewise.
9196 (vst4q_f32): Likewise.
9197 (__arm_vst4q_s8): Define inline builtin.
9198 (__arm_vst4q_s16): Likewise.
9199 (__arm_vst4q_s32): Likewise.
9200 (__arm_vst4q_u8): Likewise.
9201 (__arm_vst4q_u16): Likewise.
9202 (__arm_vst4q_u32): Likewise.
9203 (__arm_vst4q_f16): Likewise.
9204 (__arm_vst4q_f32): Likewise.
9205 (__ARM_mve_typeid): Define macro with MVE types.
9206 (__ARM_mve_coerce): Define macro with _Generic feature.
9207 (vst4q): Define polymorphic variant for different vst4q builtins.
9208 * config/arm/arm_mve_builtins.def: New file.
9209 * config/arm/iterators.md (VSTRUCT): Modify to allow XI and OI
9210 modes in MVE.
9211 * config/arm/mve.md (MVE_VLD_ST): Define iterator.
9212 (unspec): Define unspec.
9213 (mve_vst4q<mode>): Define RTL pattern.
9214 * config/arm/neon.md (mov<mode>): Modify expand to allow XI and OI
9215 modes in MVE.
9216 (neon_mov<mode>): Modify RTL define_insn to allow XI and OI modes
9217 in MVE.
9218 (define_split): Allow OI mode split for MVE after reload.
9219 (define_split): Allow XI mode split for MVE after reload.
9220 * config/arm/t-arm (arm.o): Add entry for arm_mve_builtins.def.
9221 (arm-builtins.o): Likewise.
9222
9223 2020-03-17 Christophe Lyon <christophe.lyon@linaro.org>
9224
9225 * c-typeck.c (process_init_element): Handle constructor_type with
9226 type size represented by POLY_INT_CST.
9227
9228 2020-03-17 Jakub Jelinek <jakub@redhat.com>
9229
9230 PR tree-optimization/94187
9231 * tree-ssa-strlen.c (count_nonzero_bytes): Punt if
9232 nchars - offset < nbytes.
9233
9234 PR middle-end/94189
9235 * builtins.c (expand_builtin_strnlen): Do return NULL_RTX if we would
9236 emit a warning if it was enabled and don't depend on TREE_NO_WARNING
9237 for code-generation.
9238
9239 2020-03-16 Vladimir Makarov <vmakarov@redhat.com>
9240
9241 PR target/94185
9242 * lra-spills.c (remove_pseudos): Do not reuse insn alternative
9243 after changing memory subreg.
9244
9245 2020-03-16 Andre Vieira <andre.simoesdiasvieira@arm.com>
9246 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
9247
9248 * config/arm/arm.c (arm_libcall_uses_aapcs_base): Modify function to add
9249 emulator calls for dobule precision arithmetic operations for MVE.
9250
9251 2020-03-16 Andre Vieira <andre.simoesdiasvieira@arm.com>
9252 Mihail Ionescu <mihail.ionescu@arm.com>
9253 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
9254
9255 * common/config/arm/arm-common.c (arm_asm_auto_mfpu): When vfp_base
9256 feature bit is on and -mfpu=auto is passed as compiler option, do not
9257 generate error on not finding any matching fpu. Because in this case
9258 fpu is not required.
9259 * config/arm/arm-cpus.in (vfp_base): Define feature bit, this bit is
9260 enabled for MVE and also for all VFP extensions.
9261 (VFPv2): Modify fgroup to enable vfp_base feature bit when ever VFPv2
9262 is enabled.
9263 (MVE): Define fgroup to enable feature bits mve, vfp_base and armv7em.
9264 (MVE_FP): Define fgroup to enable feature bits is fgroup MVE and FPv5
9265 along with feature bits mve_float.
9266 (mve): Modify add options in armv8.1-m.main arch for MVE.
9267 (mve.fp): Modify add options in armv8.1-m.main arch for MVE with
9268 floating point.
9269 * config/arm/arm.c (use_return_insn): Replace the
9270 check with TARGET_VFP_BASE.
9271 (thumb2_legitimate_index_p): Replace TARGET_HARD_FLOAT with
9272 TARGET_VFP_BASE.
9273 (arm_rtx_costs_internal): Replace "TARGET_HARD_FLOAT || TARGET_HAVE_MVE"
9274 with TARGET_VFP_BASE, to allow cost calculations for copies in MVE as
9275 well.
9276 (arm_get_vfp_saved_size): Replace TARGET_HARD_FLOAT with
9277 TARGET_VFP_BASE, to allow space calculation for VFP registers in MVE
9278 as well.
9279 (arm_compute_frame_layout): Likewise.
9280 (arm_save_coproc_regs): Likewise.
9281 (arm_fixed_condition_code_regs): Modify to enable using VFPCC_REGNUM
9282 in MVE as well.
9283 (arm_hard_regno_mode_ok): Replace "TARGET_HARD_FLOAT || TARGET_HAVE_MVE"
9284 with equivalent macro TARGET_VFP_BASE.
9285 (arm_expand_epilogue_apcs_frame): Likewise.
9286 (arm_expand_epilogue): Likewise.
9287 (arm_conditional_register_usage): Likewise.
9288 (arm_declare_function_name): Add check to skip printing .fpu directive
9289 in assembly file when TARGET_VFP_BASE is enabled and fpu_to_print is
9290 "softvfp".
9291 * config/arm/arm.h (TARGET_VFP_BASE): Define.
9292 * config/arm/arm.md (arch): Add "mve" to arch.
9293 (eq_attr "arch" "mve"): Enable on TARGET_HAVE_MVE is true.
9294 (vfp_pop_multiple_with_writeback): Replace "TARGET_HARD_FLOAT
9295 || TARGET_HAVE_MVE" with equivalent macro TARGET_VFP_BASE.
9296 * config/arm/constraints.md (Uf): Define to allow modification to FPCCR
9297 in MVE.
9298 * config/arm/thumb2.md (thumb2_movsfcc_soft_insn): Modify target guard
9299 to not allow for MVE.
9300 * config/arm/unspecs.md (UNSPEC_GET_FPSCR): Move to volatile unspecs
9301 enum.
9302 (VUNSPEC_GET_FPSCR): Define.
9303 * config/arm/vfp.md (thumb2_movhi_vfp): Add support for VMSR and VMRS
9304 instructions which move to general-purpose Register from Floating-point
9305 Special register and vice-versa.
9306 (thumb2_movhi_fp16): Likewise.
9307 (thumb2_movsi_vfp): Add support for VMSR and VMRS instructions along
9308 with MCR and MRC instructions which set and get Floating-point Status
9309 and Control Register (FPSCR).
9310 (movdi_vfp): Modify pattern to enable Single-precision scalar float move
9311 in MVE.
9312 (thumb2_movdf_vfp): Modify pattern to enable Double-precision scalar
9313 float move patterns in MVE.
9314 (thumb2_movsfcc_vfp): Modify pattern to enable single float conditional
9315 code move patterns of VFP also in MVE by adding TARGET_VFP_BASE check.
9316 (thumb2_movdfcc_vfp): Modify pattern to enable double float conditional
9317 code move patterns of VFP also in MVE by adding TARGET_VFP_BASE check.
9318 (push_multi_vfp): Add support to use VFP VPUSH pattern for MVE by adding
9319 TARGET_VFP_BASE check.
9320 (set_fpscr): Add support to set FPSCR register for MVE. Modify pattern
9321 using VFPCC_REGNUM as few MVE intrinsics use carry bit of FPSCR
9322 register.
9323 (get_fpscr): Add support to get FPSCR register for MVE. Modify pattern
9324 using VFPCC_REGNUM as few MVE intrinsics use carry bit of FPSCR
9325 register.
9326
9327
9328 2020-03-16 Andre Vieira <andre.simoesdiasvieira@arm.com>
9329 Mihail Ionescu <mihail.ionescu@arm.com>
9330 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
9331
9332 * config.gcc (arm_mve.h): Include mve intrinsics header file.
9333 * config/arm/aout.h (p0): Add new register name for MVE predicated
9334 cases.
9335 * config/arm-builtins.c (ARM_BUILTIN_SIMD_LANE_CHECK): Define macro
9336 common to Neon and MVE.
9337 (ARM_BUILTIN_NEON_LANE_CHECK): Renamed to ARM_BUILTIN_SIMD_LANE_CHECK.
9338 (arm_init_simd_builtin_types): Disable poly types for MVE.
9339 (arm_init_neon_builtins): Move a check to arm_init_builtins function.
9340 (arm_init_builtins): Use ARM_BUILTIN_SIMD_LANE_CHECK instead of
9341 ARM_BUILTIN_NEON_LANE_CHECK.
9342 (mve_dereference_pointer): Add function.
9343 (arm_expand_builtin_args): Call to mve_dereference_pointer when MVE is
9344 enabled.
9345 (arm_expand_neon_builtin): Moved to arm_expand_builtin function.
9346 (arm_expand_builtin): Moved from arm_expand_neon_builtin function.
9347 * config/arm/arm-c.c (__ARM_FEATURE_MVE): Define macro for MVE and MVE
9348 with floating point enabled.
9349 * config/arm/arm-protos.h (neon_immediate_valid_for_move): Renamed to
9350 simd_immediate_valid_for_move.
9351 (simd_immediate_valid_for_move): Renamed from
9352 neon_immediate_valid_for_move function.
9353 * config/arm/arm.c (arm_options_perform_arch_sanity_checks): Generate
9354 error if vfpv2 feature bit is disabled and mve feature bit is also
9355 disabled for HARD_FLOAT_ABI.
9356 (use_return_insn): Check to not push VFP regs for MVE.
9357 (aapcs_vfp_allocate): Add MVE check to have same Procedure Call Standard
9358 as Neon.
9359 (aapcs_vfp_allocate_return_reg): Likewise.
9360 (thumb2_legitimate_address_p): Check to return 0 on valid Thumb-2
9361 address operand for MVE.
9362 (arm_rtx_costs_internal): MVE check to determine cost of rtx.
9363 (neon_valid_immediate): Rename to simd_valid_immediate.
9364 (simd_valid_immediate): Rename from neon_valid_immediate.
9365 (simd_valid_immediate): MVE check on size of vector is 128 bits.
9366 (neon_immediate_valid_for_move): Rename to
9367 simd_immediate_valid_for_move.
9368 (simd_immediate_valid_for_move): Rename from
9369 neon_immediate_valid_for_move.
9370 (neon_immediate_valid_for_logic): Modify call to neon_valid_immediate
9371 function.
9372 (neon_make_constant): Modify call to neon_valid_immediate function.
9373 (neon_vector_mem_operand): Return VFP register for POST_INC or PRE_DEC
9374 for MVE.
9375 (output_move_neon): Add MVE check to generate vldm/vstm instrcutions.
9376 (arm_compute_frame_layout): Calculate space for saved VFP registers for
9377 MVE.
9378 (arm_save_coproc_regs): Save coproc registers for MVE.
9379 (arm_print_operand): Add case 'E' to print memory operands for MVE.
9380 (arm_print_operand_address): Check to print register number for MVE.
9381 (arm_hard_regno_mode_ok): Check for arm hard regno mode ok for MVE.
9382 (arm_modes_tieable_p): Check to allow structure mode for MVE.
9383 (arm_regno_class): Add VPR_REGNUM check.
9384 (arm_expand_epilogue_apcs_frame): MVE check to calculate epilogue code
9385 for APCS frame.
9386 (arm_expand_epilogue): MVE check for enabling pop instructions in
9387 epilogue.
9388 (arm_print_asm_arch_directives): Modify function to disable print of
9389 .arch_extension "mve" and "fp" for cases where MVE is enabled with
9390 "SOFT FLOAT ABI".
9391 (arm_vector_mode_supported_p): Check for modes available in MVE interger
9392 and MVE floating point.
9393 (arm_array_mode_supported_p): Add TARGET_HAVE_MVE check for array mode
9394 pointer support.
9395 (arm_conditional_register_usage): Enable usage of conditional regsiter
9396 for MVE.
9397 (fixed_regs[VPR_REGNUM]): Enable VPR_REG for MVE.
9398 (arm_declare_function_name): Modify function to disable print of
9399 .arch_extension "mve" and "fp" for cases where MVE is enabled with
9400 "SOFT FLOAT ABI".
9401 * config/arm/arm.h (TARGET_HAVE_MVE): Disable for soft float abi and
9402 when target general registers are required.
9403 (TARGET_HAVE_MVE_FLOAT): Likewise.
9404 (FIXED_REGISTERS): Add bit for VFP_REG class which is enabled in arm.c
9405 for MVE.
9406 (CALL_USED_REGISTERS): Set bit for VFP_REG class in CALL_USED_REGISTERS
9407 which indicate this is not available for across function calls.
9408 (FIRST_PSEUDO_REGISTER): Modify.
9409 (VALID_MVE_MODE): Define valid MVE mode.
9410 (VALID_MVE_SI_MODE): Define valid MVE SI mode.
9411 (VALID_MVE_SF_MODE): Define valid MVE SF mode.
9412 (VALID_MVE_STRUCT_MODE): Define valid MVE struct mode.
9413 (VPR_REGNUM): Add Vector Predication Register in arm_regs_in_sequence
9414 for MVE.
9415 (IS_VPR_REGNUM): Macro to check for VPR_REG register.
9416 (REG_ALLOC_ORDER): Add VPR_REGNUM entry.
9417 (enum reg_class): Add VPR_REG entry.
9418 (REG_CLASS_NAMES): Add VPR_REG entry.
9419 * config/arm/arm.md (VPR_REGNUM): Define.
9420 (conds): Check is_mve_type attrbiute to differentiate "conditional" and
9421 "unconditional" instructions.
9422 (arm_movsf_soft_insn): Modify RTL to not allow for MVE.
9423 (movdf_soft_insn): Modify RTL to not allow for MVE.
9424 (vfp_pop_multiple_with_writeback): Enable for MVE.
9425 (include "mve.md"): Include mve.md file.
9426 * config/arm/arm_mve.h: Add MVE intrinsics head file.
9427 * config/arm/constraints.md (Up): Constraint to enable "p0" register in MVE
9428 for vector predicated operands.
9429 * config/arm/iterators.md (VNIM1): Define.
9430 (VNINOTM1): Define.
9431 (VHFBF_split): Define
9432 * config/arm/mve.md: New file.
9433 (mve_mov<mode>): Define RTL for move, store and load in MVE.
9434 (mve_mov<mode>): Define move RTL pattern with vec_duplicate operator for
9435 second operand.
9436 * config/arm/neon.md (neon_immediate_valid_for_move): Rename with
9437 simd_immediate_valid_for_move.
9438 (neon_mov<mode>): Split pattern and move expand pattern "movv8hf" which
9439 is common to MVE and NEON to vec-common.md file.
9440 (vec_init<mode><V_elem_l>): Add TARGET_HAVE_MVE check.
9441 * config/arm/predicates.md (vpr_register_operand): Define.
9442 * config/arm/t-arm: Add mve.md file.
9443 * config/arm/types.md (mve_move): Add MVE instructions mve_move to
9444 attribute "type".
9445 (mve_store): Add MVE instructions mve_store to attribute "type".
9446 (mve_load): Add MVE instructions mve_load to attribute "type".
9447 (is_mve_type): Define attribute.
9448 * config/arm/vec-common.md (mov<mode>): Modify RTL expand to support
9449 standard move patterns in MVE along with NEON and IWMMXT with mode
9450 iterator VNIM1.
9451 (mov<mode>): Modify RTL expand to support standard move patterns in NEON
9452 and IWMMXT with mode iterator V8HF.
9453 (movv8hf): Define RTL expand to support standard "movv8hf" pattern in
9454 NEON and MVE.
9455 * config/arm/vfp.md (neon_immediate_valid_for_move): Rename to
9456 simd_immediate_valid_for_move.
9457
9458
9459 2020-03-16 H.J. Lu <hongjiu.lu@intel.com>
9460
9461 PR target/89229
9462 * config/i386/i386.md (*movsi_internal): Call ix86_output_ssemov
9463 for TYPE_SSEMOV. Remove ext_sse_reg_operand and TARGET_AVX512VL
9464 check.
9465 * config/i386/predicates.md (ext_sse_reg_operand): Removed.
9466
9467 2020-03-16 Jakub Jelinek <jakub@redhat.com>
9468
9469 PR debug/94167
9470 * tree-inline.c (insert_init_stmt): Don't gimple_regimplify_operands
9471 DEBUG_STMTs.
9472
9473 PR tree-optimization/94166
9474 * tree-ssa-reassoc.c (sort_by_mach_mode): Use SSA_NAME_VERSION
9475 as secondary comparison key.
9476
9477 2020-03-16 Bin Cheng <bin.cheng@linux.alibaba.com>
9478
9479 PR tree-optimization/94125
9480 * tree-loop-distribution.c
9481 (loop_distribution::break_alias_scc_partitions): Update post order
9482 number for merged scc.
9483
9484 2020-03-15 H.J. Lu <hongjiu.lu@intel.com>
9485
9486 PR target/89229
9487 * config/i386/i386.c (ix86_output_ssemov): Handle MODE_SI and
9488 MODE_SF.
9489 * config/i386/i386.md (*movsf_internal): Call ix86_output_ssemov
9490 for TYPE_SSEMOV. Remove TARGET_PREFER_AVX256, TARGET_AVX512VL
9491 and ext_sse_reg_operand check.
9492
9493 2020-03-15 Lewis Hyatt <lhyatt@gmail.com>
9494
9495 * common.opt: Avoid redundancy in the help text.
9496 * config/arc/arc.opt: Likewise.
9497 * config/cr16/cr16.opt: Likewise.
9498
9499 2020-03-14 Jakub Jelinek <jakub@redhat.com>
9500
9501 PR middle-end/93566
9502 * tree-nested.c (convert_nonlocal_omp_clauses,
9503 convert_local_omp_clauses): Handle {,in_,task_}reduction clauses
9504 with C/C++ array sections.
9505
9506 2020-03-14 H.J. Lu <hongjiu.lu@intel.com>
9507
9508 PR target/89229
9509 * config/i386/i386.md (*movdi_internal): Call ix86_output_ssemov
9510 for TYPE_SSEMOV. Remove ext_sse_reg_operand and TARGET_AVX512VL
9511 check.
9512
9513 2020-03-14 Jakub Jelinek <jakub@redhat.com>
9514
9515 * gimple-fold.c (gimple_fold_builtin_strncpy): Change
9516 "a an" to "an" in a comment.
9517 * hsa-common.h (is_a_helper): Likewise.
9518 * tree-ssa-strlen.c (maybe_diag_stxncpy_trunc): Likewise.
9519 * config/arc/arc.c (arc600_corereg_hazard): Likewise.
9520 * config/s390/s390.c (s390_indirect_branch_via_thunk): Likewise.
9521
9522 2020-03-13 Aaron Sawdey <acsawdey@linux.ibm.com>
9523
9524 PR target/92379
9525 * config/rs6000/rs6000.c (num_insns_constant_multi): Don't shift a
9526 64-bit value by 64 bits (UB).
9527
9528 2020-03-13 Vladimir Makarov <vmakarov@redhat.com>
9529
9530 PR rtl-optimization/92303
9531 * lra-spills.c (remove_pseudos): Try to simplify memory subreg.
9532
9533 2020-03-13 Segher Boessenkool <segher@kernel.crashing.org>
9534
9535 PR rtl-optimization/94148
9536 PR rtl-optimization/94042
9537 * df-core.c (BB_LAST_CHANGE_AGE): Delete.
9538 (df_worklist_propagate_forward): New parameter last_change_age, use
9539 that instead of bb->aux.
9540 (df_worklist_propagate_backward): Ditto.
9541 (df_worklist_dataflow_doublequeue): Use a local array last_change_age.
9542
9543 2020-03-13 Richard Biener <rguenther@suse.de>
9544
9545 PR tree-optimization/94163
9546 * tree-ssa-pre.c (create_expression_by_pieces): Check
9547 whether alignment would be zero.
9548
9549 2020-03-13 Martin Liska <mliska@suse.cz>
9550
9551 PR lto/94157
9552 * lto-wrapper.c (run_gcc): Use concat for appending
9553 to collect_gcc_options.
9554
9555 2020-03-13 Jakub Jelinek <jakub@redhat.com>
9556
9557 PR target/94121
9558 * config/aarch64/aarch64.c (aarch64_add_offset_1): Use gen_int_mode
9559 instead of GEN_INT.
9560
9561 2020-03-13 H.J. Lu <hongjiu.lu@intel.com>
9562
9563 PR target/89229
9564 * config/i386/i386.c (ix86_output_ssemov): Handle MODE_DF.
9565 * config/i386/i386.md (*movdf_internal): Call ix86_output_ssemov
9566 for TYPE_SSEMOV. Remove TARGET_AVX512F, TARGET_PREFER_AVX256,
9567 TARGET_AVX512VL and ext_sse_reg_operand check.
9568
9569 2020-03-13 Bu Le <bule1@huawei.com>
9570
9571 PR target/94154
9572 * config/aarch64/aarch64.opt (-param=aarch64-float-recp-precision=)
9573 (-param=aarch64-double-recp-precision=): New options.
9574 * doc/invoke.texi: Document them.
9575 * config/aarch64/aarch64.c (aarch64_emit_approx_div): Use them
9576 instead of hard-coding the choice of 1 for float and 2 for double.
9577
9578 2020-03-13 Eric Botcazou <ebotcazou@adacore.com>
9579
9580 PR rtl-optimization/94119
9581 * resource.h (clear_hashed_info_until_next_barrier): Declare.
9582 * resource.c (clear_hashed_info_until_next_barrier): New function.
9583 * reorg.c (add_to_delay_list): Fix formatting.
9584 (relax_delay_slots): Call clear_hashed_info_until_next_barrier on
9585 the next instruction after removing a BARRIER.
9586
9587 2020-03-13 Eric Botcazou <ebotcazou@adacore.com>
9588
9589 PR middle-end/92071
9590 * expmed.c (store_integral_bit_field): For fields larger than a word,
9591 call extract_bit_field on the value if the mode is BLKmode. Remove
9592 specific path for big-endian targets and tidy things up a little bit.
9593
9594 2020-03-12 Richard Sandiford <richard.sandiford@arm.com>
9595
9596 PR rtl-optimization/90275
9597 * cse.c (cse_insn): Delete no-op register moves too.
9598
9599 2020-03-12 Darius Galis <darius.galis@cyberthorstudios.com>
9600
9601 * config/rx/rx.md (CTRLREG_CPEN): Remove.
9602 * config/rx/rx.c (rx_print_operand): Remove CTRLREG_CPEN support.
9603
9604 2020-03-12 Richard Biener <rguenther@suse.de>
9605
9606 PR tree-optimization/94103
9607 * tree-ssa-sccvn.c (visit_reference_op_load): Avoid type
9608 punning when the mode precision is not sufficient.
9609
9610 2020-03-12 H.J. Lu <hongjiu.lu@intel.com>
9611
9612 PR target/89229
9613 * config/i386/i386.c (ix86_output_ssemov): Handle MODE_DI,
9614 MODE_V1DF and MODE_V2SF.
9615 * config/i386/mmx.md (MMXMODE:*mov<mode>_internal): Call
9616 ix86_output_ssemov for TYPE_SSEMOV. Remove ext_sse_reg_operand
9617 check.
9618
9619 2020-03-12 Jakub Jelinek <jakub@redhat.com>
9620
9621 * doc/tm.texi.in (ASM_OUTPUT_ALIGNED_DECL_LOCAL): Change
9622 ASM_OUTPUT_ALIGNED_DECL in description to ASM_OUTPUT_ALIGNED_LOCAL
9623 and ASM_OUTPUT_DECL to ASM_OUTPUT_LOCAL.
9624 * doc/tm.texi: Regenerated.
9625
9626 PR tree-optimization/94130
9627 * tree-ssa-dse.c: Include gimplify.h.
9628 (increment_start_addr): If stmt has lhs, drop the lhs from call and
9629 set it after the call to the original value of the first argument.
9630 Formatting fixes.
9631 (decrement_count): Formatting fix.
9632
9633 2020-03-11 Delia Burduv <delia.burduv@arm.com>
9634
9635 * config/arm/arm-builtins.c
9636 (arm_init_simd_builtin_scalar_types): New.
9637 * config/arm/arm_neon.h (vld2_bf16): Used new builtin type.
9638 (vld2q_bf16): Used new builtin type.
9639 (vld3_bf16): Used new builtin type.
9640 (vld3q_bf16): Used new builtin type.
9641 (vld4_bf16): Used new builtin type.
9642 (vld4q_bf16): Used new builtin type.
9643 (vld2_dup_bf16): Used new builtin type.
9644 (vld2q_dup_bf16): Used new builtin type.
9645 (vld3_dup_bf16): Used new builtin type.
9646 (vld3q_dup_bf16): Used new builtin type.
9647 (vld4_dup_bf16): Used new builtin type.
9648 (vld4q_dup_bf16): Used new builtin type.
9649
9650 2020-03-11 Jakub Jelinek <jakub@redhat.com>
9651
9652 PR target/94134
9653 * config/pdp11/pdp11.c (pdp11_asm_output_var): Call switch_to_section
9654 at the start to switch to data section. Don't print extra newline if
9655 .globl directive has not been emitted.
9656
9657 2020-03-11 Richard Biener <rguenther@suse.de>
9658
9659 * match.pd ((T *)(ptr - ptr-cst) -> &MEM[ptr + -ptr-cst]):
9660 New pattern.
9661
9662 2020-03-11 Eric Botcazou <ebotcazou@adacore.com>
9663
9664 PR middle-end/93961
9665 * tree.c (variably_modified_type_p) <RECORD_TYPE>: Recurse into fields
9666 whose type is a qualified union.
9667
9668 2020-03-11 Jakub Jelinek <jakub@redhat.com>
9669
9670 PR target/94121
9671 * config/aarch64/aarch64.c (aarch64_add_offset_1): Use absu_hwi
9672 instead of abs_hwi, change moffset type to unsigned HOST_WIDE_INT.
9673
9674 PR bootstrap/93962
9675 * value-prof.c (dump_histogram_value): Use abs_hwi instead of
9676 std::abs.
9677 (get_nth_most_common_value): Use abs_hwi instead of abs.
9678
9679 PR middle-end/94111
9680 * dfp.c (decimal_to_binary): Only use decimal128ToString if from->cl
9681 is rvc_normal, otherwise use real_to_decimal to print the number to
9682 string.
9683
9684 PR tree-optimization/94114
9685 * tree-loop-distribution.c (generate_memset_builtin): Call
9686 rewrite_to_non_trapping_overflow even on mem.
9687 (generate_memcpy_builtin): Call rewrite_to_non_trapping_overflow even
9688 on dest and src.
9689
9690 2020-03-10 Jeff Law <law@redhat.com>
9691
9692 * config/bfin/bfin.md (movsi_insv): Add length attribute.
9693
9694 2020-03-10 Jiufu Guo <guojiufu@linux.ibm.com>
9695
9696 PR target/93709
9697 * gcc/config/rs6000/rs6000.c (rs6000_emit_p9_fp_minmax): Check
9698 NAN and SIGNED_ZEROR for smax/smin.
9699
9700 2020-03-10 Will Schmidt <will_schmidt@vnet.ibm.com>
9701
9702 PR target/90763
9703 * config/rs6000/rs6000-c.c (altivec_resolve_overloaded_builtin): Add
9704 clause to handle P9V_BUILTIN_VEC_LXVL with const arguments.
9705
9706 2020-03-10 Roman Zhuykov <zhroma@ispras.ru>
9707
9708 * loop-iv.c (find_simple_exit): Make it static.
9709 * cfgloop.h: Remove the corresponding prototype.
9710
9711 2020-03-10 Roman Zhuykov <zhroma@ispras.ru>
9712
9713 * ddg.c (create_ddg): Fix intendation.
9714 (set_recurrence_length): Likewise.
9715 (create_ddg_all_sccs): Likewise.
9716
9717 2020-03-10 Jakub Jelinek <jakub@redhat.com>
9718
9719 PR target/94088
9720 * config/i386/i386.md (*testqi_ext_3): Call ix86_match_ccmode with
9721 CCZmode instead of CCNOmode if operands[2] has DImode and pos + len
9722 is 32.
9723
9724 2020-03-09 Jason Merrill <jason@redhat.com>
9725
9726 * gdbinit.in (pgs): Fix typo in documentation.
9727
9728 2020-03-09 Vladimir Makarov <vmakarov@redhat.com>
9729
9730 Revert:
9731
9732 2020-02-28 Vladimir Makarov <vmakarov@redhat.com>
9733
9734 PR rtl-optimization/93564
9735 * ira-color.c (assign_hard_reg): Prefer smaller hard regno when we
9736 do not honor reg alloc order.
9737
9738 2020-03-09 Andrew Pinski <apinski@marvell.com>
9739
9740 PR inline-asm/94095
9741 * doc/extend.texi (x86 Operand Modifiers): Fix column
9742 for 'A' modifier.
9743
9744 2020-03-09 Martin Liska <mliska@suse.cz>
9745
9746 PR target/93800
9747 * config/rs6000/rs6000.c (rs6000_option_override_internal):
9748 Remove set of str_align_loops and str_align_jumps as these
9749 should be set in previous 2 conditions in the function.
9750
9751 2020-03-09 Jakub Jelinek <jakub@redhat.com>
9752
9753 PR rtl-optimization/94045
9754 * params.opt (-param=max-find-base-term-values=): New option.
9755 * alias.c (find_base_term): Add cut-off for number of visited VALUEs
9756 in a single toplevel find_base_term call.
9757
9758 2020-03-06 Wilco Dijkstra <wdijkstr@arm.com>
9759
9760 PR target/91598
9761 * config/aarch64/aarch64-builtins.c (TYPES_TERNOPU_LANE): Add define.
9762 * config/aarch64/aarch64-simd.md
9763 (aarch64_vec_<su>mult_lane<Qlane>): Add new insn for widening lane mul.
9764 (aarch64_vec_<su>mlal_lane<Qlane>): Likewise.
9765 * config/aarch64/aarch64-simd-builtins.def: Add intrinsics.
9766 * config/aarch64/arm_neon.h:
9767 (vmlal_lane_s16): Expand using intrinsics rather than inline asm.
9768 (vmlal_lane_u16): Likewise.
9769 (vmlal_lane_s32): Likewise.
9770 (vmlal_lane_u32): Likewise.
9771 (vmlal_laneq_s16): Likewise.
9772 (vmlal_laneq_u16): Likewise.
9773 (vmlal_laneq_s32): Likewise.
9774 (vmlal_laneq_u32): Likewise.
9775 (vmull_lane_s16): Likewise.
9776 (vmull_lane_u16): Likewise.
9777 (vmull_lane_s32): Likewise.
9778 (vmull_lane_u32): Likewise.
9779 (vmull_laneq_s16): Likewise.
9780 (vmull_laneq_u16): Likewise.
9781 (vmull_laneq_s32): Likewise.
9782 (vmull_laneq_u32): Likewise.
9783 * config/aarch64/iterators.md (Vcondtype): New iterator for lane mul.
9784 (Qlane): Likewise.
9785
9786 2020-03-06 Wilco Dijkstra <wdijkstr@arm.com>
9787
9788 * aarch64/aarch64-simd.md (aarch64_mla_elt<mode>): Correct lane syntax.
9789 (aarch64_mla_elt_<vswap_width_name><mode>): Likewise.
9790 (aarch64_mls_elt<mode>): Likewise.
9791 (aarch64_mls_elt_<vswap_width_name><mode>): Likewise.
9792 (aarch64_fma4_elt<mode>): Likewise.
9793 (aarch64_fma4_elt_<vswap_width_name><mode>): Likewise.
9794 (aarch64_fma4_elt_to_64v2df): Likewise.
9795 (aarch64_fnma4_elt<mode>): Likewise.
9796 (aarch64_fnma4_elt_<vswap_width_name><mode>): Likewise.
9797 (aarch64_fnma4_elt_to_64v2df): Likewise.
9798
9799 2020-03-06 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
9800
9801 * config/aarch64/aarch64-sve2.md (@aarch64_sve_<sve_int_op><mode>:
9802 Specify movprfx attribute.
9803 (@aarch64_sve_<sve_int_op>_lane_<mode>): Likewise.
9804
9805 2020-03-06 David Edelsohn <dje.gcc@gmail.com>
9806
9807 PR target/94065
9808 * config/rs6000/aix61.h (TARGET_NO_SUM_IN_TOC): Set to 1 for
9809 cmodel=large.
9810 (TARGET_NO_FP_IN_TOC): Same.
9811 * config/rs6000/aix71.h: Same.
9812 * config/rs6000/aix72.h: Same.
9813
9814 2020-03-06 Andrew Pinski <apinski@marvell.com>
9815 Jeff Law <law@redhat.com>
9816
9817 PR rtl-optimization/93996
9818 * haifa-sched.c (remove_notes): Be more careful when adding
9819 REG_SAVE_NOTE.
9820
9821 2020-03-06 Delia Burduv <delia.burduv@arm.com>
9822
9823 * config/arm/arm_neon.h (vld2_bf16): New.
9824 (vld2q_bf16): New.
9825 (vld3_bf16): New.
9826 (vld3q_bf16): New.
9827 (vld4_bf16): New.
9828 (vld4q_bf16): New.
9829 (vld2_dup_bf16): New.
9830 (vld2q_dup_bf16): New.
9831 (vld3_dup_bf16): New.
9832 (vld3q_dup_bf16): New.
9833 (vld4_dup_bf16): New.
9834 (vld4q_dup_bf16): New.
9835 * config/arm/arm_neon_builtins.def
9836 (vld2): Changed to VAR13 and added v4bf, v8bf
9837 (vld2_dup): Changed to VAR8 and added v4bf, v8bf
9838 (vld3): Changed to VAR13 and added v4bf, v8bf
9839 (vld3_dup): Changed to VAR8 and added v4bf, v8bf
9840 (vld4): Changed to VAR13 and added v4bf, v8bf
9841 (vld4_dup): Changed to VAR8 and added v4bf, v8bf
9842 * config/arm/iterators.md (VDXBF2): New iterator.
9843 *config/arm/neon.md (neon_vld2): Use new iterators.
9844 (neon_vld2_dup<mode): Use new iterators.
9845 (neon_vld3<mode>): Likewise.
9846 (neon_vld3qa<mode>): Likewise.
9847 (neon_vld3qb<mode>): Likewise.
9848 (neon_vld3_dup<mode>): Likewise.
9849 (neon_vld4<mode>): Likewise.
9850 (neon_vld4qa<mode>): Likewise.
9851 (neon_vld4qb<mode>): Likewise.
9852 (neon_vld4_dup<mode>): Likewise.
9853 (neon_vld2_dupv8bf): New.
9854 (neon_vld3_dupv8bf): Likewise.
9855 (neon_vld4_dupv8bf): Likewise.
9856
9857 2020-03-06 Delia Burduv <delia.burduv@arm.com>
9858
9859 * config/arm/arm_neon.h (bfloat16x4x2_t): New typedef.
9860 (bfloat16x8x2_t): New typedef.
9861 (bfloat16x4x3_t): New typedef.
9862 (bfloat16x8x3_t): New typedef.
9863 (bfloat16x4x4_t): New typedef.
9864 (bfloat16x8x4_t): New typedef.
9865 (vst2_bf16): New.
9866 (vst2q_bf16): New.
9867 (vst3_bf16): New.
9868 (vst3q_bf16): New.
9869 (vst4_bf16): New.
9870 (vst4q_bf16): New.
9871 * config/arm/arm-builtins.c (v2bf_UP): Define.
9872 (VAR13): New.
9873 (arm_init_simd_builtin_types): Init Bfloat16x2_t eltype.
9874 * config/arm/arm-modes.def (V2BF): New mode.
9875 * config/arm/arm-simd-builtin-types.def
9876 (Bfloat16x2_t): New entry.
9877 * config/arm/arm_neon_builtins.def
9878 (vst2): Changed to VAR13 and added v4bf, v8bf
9879 (vst3): Changed to VAR13 and added v4bf, v8bf
9880 (vst4): Changed to VAR13 and added v4bf, v8bf
9881 * config/arm/iterators.md (VDXBF): New iterator.
9882 (VQ2BF): New iterator.
9883 *config/arm/neon.md (neon_vst2<mode>): Used new iterators.
9884 (neon_vst2<mode>): Used new iterators.
9885 (neon_vst3<mode>): Used new iterators.
9886 (neon_vst3<mode>): Used new iterators.
9887 (neon_vst3qa<mode>): Used new iterators.
9888 (neon_vst3qb<mode>): Used new iterators.
9889 (neon_vst4<mode>): Used new iterators.
9890 (neon_vst4<mode>): Used new iterators.
9891 (neon_vst4qa<mode>): Used new iterators.
9892 (neon_vst4qb<mode>): Used new iterators.
9893
9894 2020-03-06 Delia Burduv <delia.burduv@arm.com>
9895
9896 * config/aarch64/aarch64-simd-builtins.def
9897 (bfcvtn): New built-in function.
9898 (bfcvtn_q): New built-in function.
9899 (bfcvtn2): New built-in function.
9900 (bfcvt): New built-in function.
9901 * config/aarch64/aarch64-simd.md
9902 (aarch64_bfcvtn<q><mode>): New pattern.
9903 (aarch64_bfcvtn2v8bf): New pattern.
9904 (aarch64_bfcvtbf): New pattern.
9905 * config/aarch64/arm_bf16.h (float32_t): New typedef.
9906 (vcvth_bf16_f32): New intrinsic.
9907 * config/aarch64/arm_bf16.h (vcvt_bf16_f32): New intrinsic.
9908 (vcvtq_low_bf16_f32): New intrinsic.
9909 (vcvtq_high_bf16_f32): New intrinsic.
9910 * config/aarch64/iterators.md (V4SF_TO_BF): New mode iterator.
9911 (UNSPEC_BFCVTN): New UNSPEC.
9912 (UNSPEC_BFCVTN2): New UNSPEC.
9913 (UNSPEC_BFCVT): New UNSPEC.
9914 * config/arm/types.md (bf_cvt): New type.
9915
9916 2020-03-06 Andreas Krebbel <krebbel@linux.ibm.com>
9917
9918 * config/s390/s390.md ("tabort"): Get rid of two consecutive
9919 blanks in format string.
9920
9921 2020-03-05 H.J. Lu <hongjiu.lu@intel.com>
9922
9923 PR target/89229
9924 PR target/89346
9925 * config/i386/i386-protos.h (ix86_output_ssemov): New prototype.
9926 * config/i386/i386.c (ix86_get_ssemov): New function.
9927 (ix86_output_ssemov): Likewise.
9928 * config/i386/sse.md (VMOVE:mov<mode>_internal): Call
9929 ix86_output_ssemov for TYPE_SSEMOV. Remove TARGET_AVX512VL
9930 check.
9931 (*movxi_internal_avx512f): Call ix86_output_ssemov for TYPE_SSEMOV.
9932 (*movoi_internal_avx): Call ix86_output_ssemov for TYPE_SSEMOV.
9933 Remove ext_sse_reg_operand and TARGET_AVX512VL check.
9934 (*movti_internal): Likewise.
9935 (*movtf_internal): Call ix86_output_ssemov for TYPE_SSEMOV.
9936
9937 2020-03-05 Jeff Law <law@redhat.com>
9938
9939 PR tree-optimization/91890
9940 * gimple-ssa-warn-restrict.c (maybe_diag_overlap): Remove LOC argument.
9941 Use gimple_or_expr_nonartificial_location.
9942 (check_bounds_overlap): Drop LOC argument to maybe_diag_access_bounds.
9943 Use gimple_or_expr_nonartificial_location.
9944 * gimple.c (gimple_or_expr_nonartificial_location): New function.
9945 * gimple.h (gimple_or_expr_nonartificial_location): Declare it.
9946 * tree-ssa-strlen.c (maybe_warn_overflow): Use
9947 gimple_or_expr_nonartificial_location.
9948 (maybe_diag_stxncpy_trunc, handle_builtin_stxncpy_strncat): Likewise.
9949 (maybe_warn_pointless_strcmp): Likewise.
9950
9951 2020-03-05 Jakub Jelinek <jakub@redhat.com>
9952
9953 PR target/94046
9954 * config/i386/avx2intrin.h (_mm_mask_i32gather_ps): Fix first cast of
9955 SRC and MASK arguments to __m128 from __m128d.
9956 (_mm256_mask_i32gather_ps): Fix first cast of MASK argument to __m256
9957 from __m256d.
9958 (_mm_mask_i64gather_ps): Fix first cast of MASK argument to __m128
9959 from __m128d.
9960 * config/i386/xopintrin.h (_mm_permute2_pd): Fix first cast of C
9961 argument to __m128i from __m128d.
9962 (_mm256_permute2_pd): Fix first cast of C argument to __m256i from
9963 __m256d.
9964 (_mm_permute2_ps): Fix first cast of C argument to __m128i from __m128.
9965 (_mm256_permute2_ps): Fix first cast of C argument to __m256i from
9966 __m256.
9967
9968 2020-03-05 Delia Burduv <delia.burduv@arm.com>
9969
9970 * config/arm/arm_neon.h (vbfmmlaq_f32): New.
9971 (vbfmlalbq_f32): New.
9972 (vbfmlaltq_f32): New.
9973 (vbfmlalbq_lane_f32): New.
9974 (vbfmlaltq_lane_f32): New.
9975 (vbfmlalbq_laneq_f32): New.
9976 (vbfmlaltq_laneq_f32): New.
9977 * config/arm/arm_neon_builtins.def (vmmla): New.
9978 (vfmab): New.
9979 (vfmat): New.
9980 (vfmab_lane): New.
9981 (vfmat_lane): New.
9982 (vfmab_laneq): New.
9983 (vfmat_laneq): New.
9984 * config/arm/iterators.md (BF_MA): New int iterator.
9985 (bt): New int attribute.
9986 (VQXBF): Copy of VQX with V8BF.
9987 * config/arm/neon.md (neon_vmmlav8bf): New insn.
9988 (neon_vfma<bt>v8bf): New insn.
9989 (neon_vfma<bt>_lanev8bf): New insn.
9990 (neon_vfma<bt>_laneqv8bf): New expand.
9991 (neon_vget_high<mode>): Changed iterator to VQXBF.
9992 * config/arm/unspecs.md (UNSPEC_BFMMLA): New UNSPEC.
9993 (UNSPEC_BFMAB): New UNSPEC.
9994 (UNSPEC_BFMAT): New UNSPEC.
9995
9996 2020-03-05 Jakub Jelinek <jakub@redhat.com>
9997
9998 PR middle-end/93399
9999 * tree-pretty-print.h (pretty_print_string): Declare.
10000 * tree-pretty-print.c (pretty_print_string): Remove forward
10001 declaration, no longer static. Change nbytes parameter type
10002 from unsigned to size_t.
10003 * print-rtl.c (print_value) <case CONST_STRING>: Use
10004 pretty_print_string and for shrink way too long strings.
10005
10006 2020-03-05 Richard Biener <rguenther@suse.de>
10007 Jakub Jelinek <jakub@redhat.com>
10008
10009 PR tree-optimization/93582
10010 * tree-ssa-sccvn.c (vn_reference_lookup_3): Treat POINTER_PLUS_EXPR
10011 last operand as signed when looking for memset offset. Formatting
10012 fix.
10013
10014 2020-03-04 Andrew Pinski <apinski@marvell.com>
10015
10016 PR bootstrap/93962
10017 * value-prof.c (dump_histogram_value): Use std::abs.
10018
10019 2020-03-04 Martin Sebor <msebor@redhat.com>
10020
10021 PR tree-optimization/93986
10022 * tree-ssa-strlen.c (maybe_warn_overflow): Convert all wide_int
10023 operands to the same precision widest_int to avoid ICEs.
10024
10025 2020-03-04 Bill Schmidt <wschmidt@linux.ibm.com>
10026
10027 PR target/87560
10028 * rs6000-cpus.def (OTHER_ALTIVEC_MASKS): New #define.
10029 * rs6000.c (rs6000_disable_incompatible_switches): Add table entry
10030 for OPTION_MASK_ALTIVEC.
10031
10032 2020-03-04 Andreas Krebbel <krebbel@linux.ibm.com>
10033
10034 * config.gcc: Include the glibc-stdint.h header for zTPF.
10035
10036 2020-03-04 Andreas Krebbel <krebbel@linux.ibm.com>
10037
10038 * config/s390/s390.c (s390_secondary_memory_needed): Disallow
10039 direct FPR-GPR copies.
10040 (s390_register_info_gprtofpr): Disallow GPR content to be saved in
10041 FPRs.
10042
10043 2020-03-04 Andreas Krebbel <krebbel@linux.ibm.com>
10044
10045 * config/s390/s390.c (s390_emit_prologue): Specify the 2 new
10046 operands to the prologue_tpf expander.
10047 (s390_emit_epilogue): Likewise.
10048 (s390_option_override_internal): Do error checking and setup for
10049 the new options.
10050 * config/s390/tpf.h (TPF_TRACE_PROLOGUE_CHECK)
10051 (TPF_TRACE_EPILOGUE_CHECK, TPF_TRACE_PROLOGUE_TARGET)
10052 (TPF_TRACE_EPILOGUE_TARGET, TPF_TRACE_PROLOGUE_SKIP_TARGET)
10053 (TPF_TRACE_EPILOGUE_SKIP_TARGET): New macro definitions.
10054 * config/s390/tpf.md ("prologue_tpf", "epilogue_tpf"): Add two new
10055 operands for the check flag and the branch target.
10056 * config/s390/tpf.opt ("mtpf-trace-hook-prologue-check")
10057 ("mtpf-trace-hook-prologue-target")
10058 ("mtpf-trace-hook-epilogue-check")
10059 ("mtpf-trace-hook-epilogue-target", "mtpf-trace-skip"): New
10060 options.
10061 * doc/invoke.texi: Document -mtpf-trace-skip option. The other
10062 options are for debugging purposes and will not be documented
10063 here.
10064
10065 2020-03-04 Jakub Jelinek <jakub@redhat.com>
10066
10067 PR debug/93888
10068 * tree-inline.c (copy_decl_to_var): Copy DECL_BY_REFERENCE flag.
10069
10070 * tree-ssa-sccvn.c (vn_walk_cb_data::push_partial_def): Add offseti
10071 argument. Change pd argument so that it can be modified. Turn
10072 constant non-CONSTRUCTOR store into non-constant if it is too large.
10073 Adjust offset and size of CONSTRUCTOR or non-constant store to avoid
10074 overflows.
10075 (vn_walk_cb_data::vn_walk_cb_data, vn_reference_lookup_3): Adjust
10076 callers.
10077
10078 2020-02-04 Richard Biener <rguenther@suse.de>
10079
10080 PR tree-optimization/93964
10081 * graphite-isl-ast-to-gimple.c
10082 (gcc_expression_from_isl_ast_expr_id): Add intermediate
10083 conversion for pointer to integer converts.
10084 * graphite-scop-detection.c (assign_parameter_index_in_region):
10085 Relax assert.
10086
10087 2020-03-04 Martin Liska <mliska@suse.cz>
10088
10089 PR c/93886
10090 PR c/93887
10091 * doc/invoke.texi: Clarify --help=language and --help=common
10092 interaction.
10093
10094 2020-03-04 Jakub Jelinek <jakub@redhat.com>
10095
10096 PR tree-optimization/94001
10097 * tree-tailcall.c (process_assignment): Before comparing op1 to
10098 *ass_var, verify *ass_var is non-NULL.
10099
10100 2020-03-04 Kito Cheng <kito.cheng@sifive.com>
10101
10102 PR target/93995
10103 * config/riscv/riscv.c (riscv_emit_float_compare): Using NE to compare
10104 the result of IOR.
10105
10106 2020-03-03 Dennis Zhang <dennis.zhang@arm.com>
10107
10108 * config/arm/arm_bf16.h (vcvtah_f32_bf16, vcvth_bf16_f32): New.
10109 * config/arm/arm_neon.h (vcvt_f32_bf16, vcvtq_low_f32_bf16): New.
10110 (vcvtq_high_f32_bf16, vcvt_bf16_f32): New.
10111 (vcvtq_low_bf16_f32, vcvtq_high_bf16_f32): New.
10112 * config/arm/arm_neon_builtins.def (vbfcvt, vbfcvt_high): New entries.
10113 (vbfcvtv4sf, vbfcvtv4sf_high): Likewise.
10114 * config/arm/iterators.md (VBFCVT, VBFCVTM): New mode iterators.
10115 (V_bf_low, V_bf_cvt_m): New mode attributes.
10116 * config/arm/neon.md (neon_vbfcvtv4sf<VBFCVT:mode>): New.
10117 (neon_vbfcvtv4sf_highv8bf, neon_vbfcvtsf): New.
10118 (neon_vbfcvt<VBFCVT:mode>, neon_vbfcvt_highv8bf): New.
10119 (neon_vbfcvtbf_cvtmode<mode>, neon_vbfcvtbf): New
10120 * config/arm/unspecs.md (UNSPEC_BFCVT, UNSPEC_BFCVT_HIG): New.
10121
10122 2020-03-03 Jakub Jelinek <jakub@redhat.com>
10123
10124 PR tree-optimization/93582
10125 * tree-ssa-sccvn.h (vn_reference_lookup): Add mask argument.
10126 * tree-ssa-sccvn.c (struct vn_walk_cb_data): Add mask and masked_result
10127 members, initialize them in the constructor and if mask is non-NULL,
10128 artificially push_partial_def {} for the portions of the mask that
10129 contain zeros.
10130 (vn_walk_cb_data::finish): If mask is non-NULL, set masked_result to
10131 val and return (void *)-1. Formatting fix.
10132 (vn_reference_lookup_pieces): Adjust vn_walk_cb_data initialization.
10133 Formatting fix.
10134 (vn_reference_lookup): Add mask argument. If non-NULL, don't call
10135 fully_constant_vn_reference_p nor vn_reference_lookup_1 and return
10136 data.mask_result.
10137 (visit_nary_op): Handle BIT_AND_EXPR of a memory load and INTEGER_CST
10138 mask.
10139 (visit_stmt): Formatting fix.
10140
10141 2020-03-03 Richard Biener <rguenther@suse.de>
10142
10143 PR tree-optimization/93946
10144 * alias.h (refs_same_for_tbaa_p): Declare.
10145 * alias.c (refs_same_for_tbaa_p): New function.
10146 * tree-ssa-alias.c (ao_ref_alias_set): For a NULL ref return
10147 zero.
10148 * tree-ssa-scopedtables.h
10149 (avail_exprs_stack::lookup_avail_expr): Add output argument
10150 giving access to the hashtable entry.
10151 * tree-ssa-scopedtables.c (avail_exprs_stack::lookup_avail_expr):
10152 Likewise.
10153 * tree-ssa-dom.c: Include alias.h.
10154 (dom_opt_dom_walker::optimize_stmt): Validate TBAA state before
10155 removing redundant store.
10156 * tree-ssa-sccvn.h (vn_reference_s::base_set): New member.
10157 (ao_ref_init_from_vn_reference): Adjust prototype.
10158 (vn_reference_lookup_pieces): Likewise.
10159 (vn_reference_insert_pieces): Likewise.
10160 * tree-ssa-sccvn.c: Track base alias set in addition to alias
10161 set everywhere.
10162 (eliminate_dom_walker::eliminate_stmt): Also check base alias
10163 set when removing redundant stores.
10164 (visit_reference_op_store): Likewise.
10165 * dse.c (record_store): Adjust valdity check for redundant
10166 store removal.
10167
10168 2020-03-03 Jakub Jelinek <jakub@redhat.com>
10169
10170 PR target/26877
10171 * config/s390/s390.h (OPTION_DEFAULT_SPECS): Reorder.
10172
10173 PR rtl-optimization/94002
10174 * explow.c (plus_constant): Punt if cst has VOIDmode and
10175 get_pool_mode is different from mode.
10176
10177 2020-03-03 Claudiu Zissulescu <claziss@synopsys.com>
10178
10179 * config/arc/arc.c (leigitimate_small_data_address_p): Check if an
10180 address has an offset which fits the scalling constraint for a
10181 load/store operation.
10182 (legitimate_scaled_address_p): Update use
10183 leigitimate_small_data_address_p.
10184 (arc_print_operand): Likewise.
10185 (arc_legitimate_address_p): Likewise.
10186 (legitimate_small_data_address_p): Likewise.
10187
10188 2020-03-03 Claudiu Zissulescu <claziss@synopsys.com>
10189
10190 * config/arc/arc.md (fmasf4_fpu): Use accl_operand predicate.
10191 (fnmasf4_fpu): Likewise.
10192
10193 2020-03-03 Claudiu Zissulescu <claziss@synopsys.com>
10194
10195 * config/arc/arc.md (adddi3): Early expand the 64bit operation into
10196 32bit ops.
10197 (subdi3): Likewise.
10198 (adddi3_i): Remove pattern.
10199 (subdi3_i): Likewise.
10200
10201 2020-03-03 Claudiu Zissulescu <claziss@synopsys.com>
10202
10203 * config/arc/arc.md (eh_return): Add length info.
10204
10205 2020-03-02 David Malcolm <dmalcolm@redhat.com>
10206
10207 * doc/invoke.texi (-fanalyzer-show-duplicate-count): New.
10208
10209 2020-03-02 David Malcolm <dmalcolm@redhat.com>
10210
10211 * doc/invoke.texi (Static Analyzer Options): Add
10212 -Wanalyzer-stale-setjmp-buffer to the list of options enabled
10213 by -fanalyzer.
10214
10215 2020-03-02 Uroš Bizjak <ubizjak@gmail.com>
10216
10217 PR target/93997
10218 * config/i386/i386.md (movstrict<mode>): Allow only
10219 registers with VALID_INT_MODE_P modes.
10220
10221 2020-03-02 Andrew Stubbs <ams@codesourcery.com>
10222
10223 * config/gcn/gcn-valu.md (dpp_move<mode>): New.
10224 (reduc_insn): Use 'U' and 'B' operand codes.
10225 (reduc_<reduc_op>_scal_<mode>): Allow all types.
10226 (reduc_<reduc_op>_scal_v64di): Delete.
10227 (*<reduc_op>_dpp_shr_<mode>): Allow all 1reg types.
10228 (*plus_carry_dpp_shr_v64si): Change to ...
10229 (*plus_carry_dpp_shr_<mode>): ... this and allow all 1reg int types.
10230 (mov_from_lane63_v64di): Change to ...
10231 (mov_from_lane63_<mode>): ... this, and allow all 64-bit modes.
10232 * config/gcn/gcn.c (gcn_expand_dpp_shr_insn): Increase buffer size.
10233 Support UNSPEC_MOV_DPP_SHR output formats.
10234 (gcn_expand_reduc_scalar): Add "use_moves" reductions.
10235 Add "use_extends" reductions.
10236 (print_operand_address): Add 'I' and 'U' codes.
10237 * config/gcn/gcn.md (unspec): Add UNSPEC_MOV_DPP_SHR.
10238
10239 2020-03-02 Martin Liska <mliska@suse.cz>
10240
10241 * lto-wrapper.c: Fix typo in comment about
10242 C++ standard version.
10243
10244 2020-03-01 Martin Sebor <msebor@redhat.com>
10245
10246 PR c++/92721
10247 * calls.c (init_attr_rdwr_indices): Correctly handle attribute.
10248
10249 2020-03-01 Martin Sebor <msebor@redhat.com>
10250
10251 PR middle-end/93829
10252 * tree-ssa-strlen.c (count_nonzero_bytes): Set the size to that
10253 of a pointer in the outermost ADDR_EXPRs.
10254
10255 2020-02-28 Jeff Law <law@redhat.com>
10256
10257 * config/v850/v850.h (STATIC_CHAIN_REGNUM): Change to r19.
10258 * config/v850/v850.c (v850_asm_trampoline_template): Update
10259 accordingly.
10260
10261 2020-02-28 Michael Meissner <meissner@linux.ibm.com>
10262
10263 PR target/93937
10264 * config/rs6000/vsx.md (vsx_extract_<mode>_<VS_scalar>mode_var):
10265 Delete insn.
10266
10267 2020-02-28 Martin Liska <mliska@suse.cz>
10268
10269 PR other/93965
10270 * configure.ac: Improve detection of ld_date by requiring
10271 either two dashes or none.
10272 * configure: Regenerate.
10273
10274 2020-02-28 Vladimir Makarov <vmakarov@redhat.com>
10275
10276 PR rtl-optimization/93564
10277 * ira-color.c (assign_hard_reg): Prefer smaller hard regno when we
10278 do not honor reg alloc order.
10279
10280 2020-02-27 Joel Hutton <Joel.Hutton@arm.com>
10281
10282 PR target/87612
10283 * config/aarch64/aarch64.c (aarch64_override_options): Fix
10284 misleading warning string.
10285
10286 2020-02-27 Martin Sebor <msebor@redhat.com>
10287
10288 * doc/invoke.texi (-Wbuiltin-declaration-mismatch): Fix a typo.
10289
10290 2020-02-27 Michael Meissner <meissner@linux.ibm.com>
10291
10292 PR target/93932
10293 * config/rs6000/vsx.md (vsx_extract_<mode>_var, VSX_D iterator):
10294 Split the insn into two parts. This insn only does variable
10295 extract from a register.
10296 (vsx_extract_<mode>_var_load, VSX_D iterator): New insn, do
10297 variable extract from memory.
10298 (vsx_extract_v4sf_var): Split the insn into two parts. This insn
10299 only does variable extract from a register.
10300 (vsx_extract_v4sf_var_load): New insn, do variable extract from
10301 memory.
10302 (vsx_extract_<mode>_var, VSX_EXTRACT_I iterator): Split the insn
10303 into two parts. This insn only does variable extract from a
10304 register.
10305 (vsx_extract_<mode>_var_load, VSX_EXTRACT_I iterator): New insn,
10306 do variable extract from memory.
10307
10308 2020-02-27 Martin Jambor <mjambor@suse.cz>
10309 Feng Xue <fxue@os.amperecomputing.com>
10310
10311 PR ipa/93707
10312 * ipa-cp.c (same_node_or_its_all_contexts_clone_p): Replaced with
10313 new function calls_same_node_or_its_all_contexts_clone_p.
10314 (cgraph_edge_brings_value_p): Use it.
10315 (cgraph_edge_brings_value_p): Likewise.
10316 (self_recursive_pass_through_p): Return false if caller is a clone.
10317 (self_recursive_agg_pass_through_p): Likewise.
10318
10319 2020-02-27 Jan Hubicka <hubicka@ucw.cz>
10320
10321 PR middle-end/92152
10322 * alias.c (ends_tbaa_access_path_p): Break out from ...
10323 (component_uses_parent_alias_set_from): ... here.
10324 * alias.h (ends_tbaa_access_path_p): Declare.
10325 * tree-ssa-alias.c (access_path_may_continue_p): Break out from ...;
10326 handle trailing arrays past end of tbaa access path.
10327 (aliasing_component_refs_p): ... here; likewise.
10328 (nonoverlapping_refs_since_match_p): Track TBAA segment of the access
10329 path; disambiguate also past end of it.
10330 (nonoverlapping_component_refs_p): Use only TBAA segment of the access
10331 path.
10332
10333 2020-02-27 Mihail Ionescu <mihail.ionescu@arm.com>
10334
10335 * (__ARM_NUM_LANES, __arm_lane, __arm_lane_q): Move to the
10336 beginning of the file.
10337 (vcreate_bf16, vcombine_bf16): New.
10338 (vdup_n_bf16, vdupq_n_bf16): New.
10339 (vdup_lane_bf16, vdup_laneq_bf16): New.
10340 (vdupq_lane_bf16, vdupq_laneq_bf16): New.
10341 (vduph_lane_bf16, vduph_laneq_bf16): New.
10342 (vset_lane_bf16, vsetq_lane_bf16): New.
10343 (vget_lane_bf16, vgetq_lane_bf16): New.
10344 (vget_high_bf16, vget_low_bf16): New.
10345 (vreinterpret_bf16_u8, vreinterpretq_bf16_u8): New.
10346 (vreinterpret_bf16_u16, vreinterpretq_bf16_u16): New.
10347 (vreinterpret_bf16_u32, vreinterpretq_bf16_u32): New.
10348 (vreinterpret_bf16_u64, vreinterpretq_bf16_u64): New.
10349 (vreinterpret_bf16_s8, vreinterpretq_bf16_s8): New.
10350 (vreinterpret_bf16_s16, vreinterpretq_bf16_s16): New.
10351 (vreinterpret_bf16_s32, vreinterpretq_bf16_s32): New.
10352 (vreinterpret_bf16_s64, vreinterpretq_bf16_s64): New.
10353 (vreinterpret_bf16_p8, vreinterpretq_bf16_p8): New.
10354 (vreinterpret_bf16_p16, vreinterpretq_bf16_p16): New.
10355 (vreinterpret_bf16_p64, vreinterpretq_bf16_p64): New.
10356 (vreinterpret_bf16_f32, vreinterpretq_bf16_f32): New.
10357 (vreinterpret_bf16_f64, vreinterpretq_bf16_f64): New.
10358 (vreinterpretq_bf16_p128): New.
10359 (vreinterpret_s8_bf16, vreinterpretq_s8_bf16): New.
10360 (vreinterpret_s16_bf16, vreinterpretq_s16_bf16): New.
10361 (vreinterpret_s32_bf16, vreinterpretq_s32_bf16): New.
10362 (vreinterpret_s64_bf16, vreinterpretq_s64_bf16): New.
10363 (vreinterpret_u8_bf16, vreinterpretq_u8_bf16): New.
10364 (vreinterpret_u16_bf16, vreinterpretq_u16_bf16): New.
10365 (vreinterpret_u32_bf16, vreinterpretq_u32_bf16): New.
10366 (vreinterpret_u64_bf16, vreinterpretq_u64_bf16): New.
10367 (vreinterpret_p8_bf16, vreinterpretq_p8_bf16): New.
10368 (vreinterpret_p16_bf16, vreinterpretq_p16_bf16): New.
10369 (vreinterpret_p64_bf16, vreinterpretq_p64_bf16): New.
10370 (vreinterpret_f32_bf16, vreinterpretq_f32_bf16): New.
10371 (vreinterpretq_p128_bf16): New.
10372 * config/arm/arm_neon_builtins.def (VDX): Add V4BF.
10373 (V_elem): Likewise.
10374 (V_elem_l): Likewise.
10375 (VD_LANE): Likewise.
10376 (VQX) Add V8BF.
10377 (V_DOUBLE): Likewise.
10378 (VDQX): Add V4BF and V8BF.
10379 (V_two_elem, V_three_elem, V_four_elem): Likewise.
10380 (V_reg): Likewise.
10381 (V_HALF): Likewise.
10382 (V_double_vector_mode): Likewise.
10383 (V_cmp_result): Likewise.
10384 (V_uf_sclr): Likewise.
10385 (V_sz_elem): Likewise.
10386 (Is_d_reg): Likewise.
10387 (V_mode_nunits): Likewise.
10388 * config/arm/neon.md (neon_vdup_lane): Enable for BFloat16.
10389
10390 2020-02-27 Andrew Stubbs <ams@codesourcery.com>
10391
10392 * config/gcn/gcn-valu.md (VEC_SUBDWORD_MODE): New mode iterator.
10393 (<expander><mode>2<exec>): Change modes to VEC_ALL1REG_INT_MODE.
10394 (<expander><mode>3<exec>): Likewise.
10395 (<expander><mode>3): New.
10396 (v<expander><mode>3): New.
10397 (<expander><mode>3): New.
10398 (<expander><mode>3<exec>): Rename to ...
10399 (<expander>v64si3<exec>): ... this, and change modes to V64SI.
10400 * config/gcn/gcn.md (mnemonic): Use '%B' for not.
10401
10402 2020-02-27 Alexandre Oliva <oliva@adacore.com>
10403
10404 * config/vx-common.h (NO_DOLLAR_IN_LABEL, NO_DOT_IN_LABEL): Leave
10405 them alone on vx7.
10406
10407 2020-02-27 Richard Biener <rguenther@suse.de>
10408
10409 PR tree-optimization/93508
10410 * tree-ssa-sccvn.c (vn_reference_lookup_3): Handle _CHK like
10411 non-_CHK variants. Valueize their length arguments.
10412
10413 2020-02-27 Richard Biener <rguenther@suse.de>
10414
10415 PR tree-optimization/93953
10416 * tree-vect-slp.c (slp_copy_subtree): Avoid keeping a reference
10417 to the hash-map entry.
10418
10419 2020-02-27 Andrew Stubbs <ams@codesourcery.com>
10420
10421 * config/gcn/gcn.md (mov<mode>): Add transformations for BI subregs.
10422
10423 2020-02-27 Mark Williams <mwilliams@fb.com>
10424
10425 * dwarf2out.c (file_name_acquire): Call remap_debug_filename.
10426 * lto-opts.c (lto_write_options): Drop -fdebug-prefix-map,
10427 -ffile-prefix-map and -fmacro-prefix-map.
10428 * lto-streamer-out.c: Include file-prefix-map.h.
10429 (lto_output_location): Remap the file part of locations.
10430
10431 2020-02-27 Jakub Jelinek <jakub@redhat.com>
10432
10433 PR c/93949
10434 * gimplify.c (gimplify_init_constructor): Don't promote readonly
10435 DECL_REGISTER variables to TREE_STATIC.
10436
10437 PR tree-optimization/93582
10438 PR tree-optimization/93945
10439 * tree-ssa-sccvn.c (vn_reference_lookup_3): Handle memset with
10440 non-zero INTEGER_CST second argument and ref->offset or ref->size
10441 not a multiple of BITS_PER_UNIT.
10442
10443 2020-02-27 Jonathan Wakely <jwakely@redhat.com>
10444
10445 * doc/install.texi (Binaries): Update description of BullFreeware.
10446
10447 2020-02-26 Sandra Loosemore <sandra@codesourcery.com>
10448
10449 PR c++/90467
10450
10451 * doc/invoke.texi (Option Summary): Re-alphabetize warnings in
10452 C++ Language Options, Warning Options, and Static Analyzer
10453 Options lists. Document negative form of options enabled by
10454 default. Move some things around to more accurately sort
10455 warnings by category.
10456 (C++ Dialect Options, Warning Options, Static Analyzer
10457 Options): Document negative form of options when enabled by
10458 default. Move some things around to more accurately sort
10459 warnings by category. Add some missing index entries.
10460 Light copy-editing.
10461
10462 2020-02-26 Carl Love <cel@us.ibm.com>
10463
10464 PR target/91276
10465 * doc/extend.texi (PowerPC AltiVec Built-in Functions available on
10466 ISA 2.07): The builtin-function name __builtin_crypto_vpmsumb is only
10467 for the vector unsigned short arguments. It is also listed as the
10468 name of the built-in for arguments vector unsigned short,
10469 vector unsigned int and vector unsigned long long built-ins. The
10470 name of the builtins for these arguments should be:
10471 __builtin_crypto_vpmsumh, __builtin_crypto_vpmsumw and
10472 __builtin_crypto_vpmsumd respectively.
10473
10474 2020-02-26 Richard Biener <rguenther@suse.de>
10475
10476 * tree-vect-slp.c (vect_print_slp_tree): Also dump ref count
10477 and load permutation.
10478
10479 2020-02-26 Richard Sandiford <richard.sandiford@arm.com>
10480
10481 PR middle-end/93843
10482 * optabs-tree.c (supportable_convert_operation): Reject types with
10483 scalar modes.
10484
10485 2020-02-26 David Malcolm <dmalcolm@redhat.com>
10486
10487 * Makefile.in (ANALYZER_OBJS): Add analyzer/bar-chart.o.
10488
10489 2020-02-26 Jakub Jelinek <jakub@redhat.com>
10490
10491 PR tree-optimization/93820
10492 * gimple-ssa-store-merging.c (check_no_overlap): Change RHS_CODE
10493 argument to ALL_INTEGER_CST_P boolean.
10494 (imm_store_chain_info::try_coalesce_bswap): Adjust caller.
10495 (imm_store_chain_info::coalesce_immediate_stores): Likewise. Handle
10496 adjacent INTEGER_CST store into merged_store->only_constants like
10497 overlapping one.
10498
10499 2020-02-25 Jakub Jelinek <jakub@redhat.com>
10500
10501 PR other/93912
10502 * config/sh/sh.c (expand_cbranchdi4): Fix comment typo, probablity
10503 -> probability.
10504 * cfghooks.c (verify_flow_info): Likewise.
10505 * predict.c (combine_predictions_for_bb): Likewise.
10506 * bb-reorder.c (connect_better_edge_p): Likewise. Fix comment typo,
10507 sucessor -> successor.
10508 (find_traces_1_round): Fix comment typo, destinarion -> destination.
10509 * omp-expand.c (expand_oacc_for): Fix comment typo, sucessors ->
10510 successors.
10511 * tree-ssa-loop-ch.c (should_duplicate_loop_header_p): Fix dump
10512 message typo, sucessors -> successors.
10513
10514 2020-02-25 Martin Sebor <msebor@redhat.com>
10515
10516 * doc/extend.texi (attribute access): Correct an example.
10517
10518 2020-02-25 Mihail Ionescu <mihail.ionescu@arm.com>
10519
10520 * config/aarch64/aarch64-builtins.c (aarch64_scalar_builtin_types):
10521 Add simd_bf.
10522 (aarch64_init_simd_builtin_scalar_types): Register simd_bf.
10523 (VAR15, VAR16): New.
10524 * config/aarch64/iterators.md (VALLDIF): Enable for V4BF and V8BF.
10525 (VD): Enable for V4BF.
10526 (VDC): Likewise.
10527 (VQ): Enable for V8BF.
10528 (VQ2): Likewise.
10529 (VQ_NO2E): Likewise.
10530 (VDBL, Vdbl): Add V4BF.
10531 (V_INT_EQUIV, v_int_equiv): Add V4BF and V8BF.
10532 * config/aarch64/arm_neon.h (bfloat16x4x2_t): New typedef.
10533 (bfloat16x8x2_t): Likewise.
10534 (bfloat16x4x3_t): Likewise.
10535 (bfloat16x8x3_t): Likewise.
10536 (bfloat16x4x4_t): Likewise.
10537 (bfloat16x8x4_t): Likewise.
10538 (vcombine_bf16): New.
10539 (vld1_bf16, vld1_bf16_x2): New.
10540 (vld1_bf16_x3, vld1_bf16_x4): New.
10541 (vld1q_bf16, vld1q_bf16_x2): New.
10542 (vld1q_bf16_x3, vld1q_bf16_x4): New.
10543 (vld1_lane_bf16): New.
10544 (vld1q_lane_bf16): New.
10545 (vld1_dup_bf16): New.
10546 (vld1q_dup_bf16): New.
10547 (vld2_bf16): New.
10548 (vld2q_bf16): New.
10549 (vld2_dup_bf16): New.
10550 (vld2q_dup_bf16): New.
10551 (vld3_bf16): New.
10552 (vld3q_bf16): New.
10553 (vld3_dup_bf16): New.
10554 (vld3q_dup_bf16): New.
10555 (vld4_bf16): New.
10556 (vld4q_bf16): New.
10557 (vld4_dup_bf16): New.
10558 (vld4q_dup_bf16): New.
10559 (vst1_bf16, vst1_bf16_x2): New.
10560 (vst1_bf16_x3, vst1_bf16_x4): New.
10561 (vst1q_bf16, vst1q_bf16_x2): New.
10562 (vst1q_bf16_x3, vst1q_bf16_x4): New.
10563 (vst1_lane_bf16): New.
10564 (vst1q_lane_bf16): New.
10565 (vst2_bf16): New.
10566 (vst2q_bf16): New.
10567 (vst3_bf16): New.
10568 (vst3q_bf16): New.
10569 (vst4_bf16): New.
10570 (vst4q_bf16): New.
10571
10572 2020-02-25 Mihail Ionescu <mihail.ionescu@arm.com>
10573
10574 * config/aarch64/iterators.md (VDQF_F16) Add V4BF and V8BF.
10575 (VALL_F16): Likewise.
10576 (VALLDI_F16): Likewise.
10577 (Vtype): Likewise.
10578 (Vetype): Likewise.
10579 (vswap_width_name): Likewise.
10580 (VSWAP_WIDTH): Likewise.
10581 (Vel): Likewise.
10582 (VEL): Likewise.
10583 (q): Likewise.
10584 * config/aarch64/arm_neon.h (vset_lane_bf16, vsetq_lane_bf16): New.
10585 (vget_lane_bf16, vgetq_lane_bf16): New.
10586 (vcreate_bf16): New.
10587 (vdup_n_bf16, vdupq_n_bf16): New.
10588 (vdup_lane_bf16, vdup_laneq_bf16): New.
10589 (vdupq_lane_bf16, vdupq_laneq_bf16): New.
10590 (vduph_lane_bf16, vduph_laneq_bf16): New.
10591 (vreinterpret_bf16_u8, vreinterpretq_bf16_u8): New.
10592 (vreinterpret_bf16_u16, vreinterpretq_bf16_u16): New.
10593 (vreinterpret_bf16_u32, vreinterpretq_bf16_u32): New.
10594 (vreinterpret_bf16_u64, vreinterpretq_bf16_u64): New.
10595 (vreinterpret_bf16_s8, vreinterpretq_bf16_s8): New.
10596 (vreinterpret_bf16_s16, vreinterpretq_bf16_s16): New.
10597 (vreinterpret_bf16_s32, vreinterpretq_bf16_s32): New.
10598 (vreinterpret_bf16_s64, vreinterpretq_bf16_s64): New.
10599 (vreinterpret_bf16_p8, vreinterpretq_bf16_p8): New.
10600 (vreinterpret_bf16_p16, vreinterpretq_bf16_p16): New.
10601 (vreinterpret_bf16_p64, vreinterpretq_bf16_p64): New
10602 (vreinterpret_bf16_f16, vreinterpretq_bf16_f16): New
10603 (vreinterpret_bf16_f32, vreinterpretq_bf16_f32): New.
10604 (vreinterpret_bf16_f64, vreinterpretq_bf16_f64): New.
10605 (vreinterpretq_bf16_p128): New.
10606 (vreinterpret_s8_bf16, vreinterpretq_s8_bf16): New.
10607 (vreinterpret_s16_bf16, vreinterpretq_s16_bf16): New.
10608 (vreinterpret_s32_bf16, vreinterpretq_s32_bf16): New.
10609 (vreinterpret_s64_bf16, vreinterpretq_s64_bf16): New.
10610 (vreinterpret_u8_bf16, vreinterpretq_u8_bf16): New.
10611 (vreinterpret_u16_bf16, vreinterpretq_u16_bf16): New.
10612 (vreinterpret_u32_bf16, vreinterpretq_u32_bf16): New.
10613 (vreinterpret_u64_bf16, vreinterpretq_u64_bf16): New.
10614 (vreinterpret_p8_bf16, vreinterpretq_p8_bf16): New.
10615 (vreinterpret_p16_bf16, vreinterpretq_p16_bf16): New.
10616 (vreinterpret_p64_bf16, vreinterpretq_p64_bf16): New.
10617 (vreinterpret_f32_bf16, vreinterpretq_f32_bf16): New.
10618 (vreinterpret_f64_bf16,vreinterpretq_f64_bf16): New.
10619 (vreinterpret_f16_bf16,vreinterpretq_f16_bf16): New.
10620 (vreinterpretq_p128_bf16): New.
10621
10622 2020-02-25 Dennis Zhang <dennis.zhang@arm.com>
10623
10624 * config/arm/arm_neon.h (vbfdot_f32, vbfdotq_f32): New
10625 (vbfdot_lane_f32, vbfdotq_laneq_f32): New.
10626 (vbfdot_laneq_f32, vbfdotq_lane_f32): New.
10627 * config/arm/arm_neon_builtins.def (vbfdot): New entry.
10628 (vbfdot_lanev4bf, vbfdot_lanev8bf): Likewise.
10629 * config/arm/iterators.md (VSF2BF): New attribute.
10630 * config/arm/neon.md (neon_vbfdot<VCVTF:mode>): New entry.
10631 (neon_vbfdot_lanev4bf<VCVTF:mode>): Likewise.
10632 (neon_vbfdot_lanev8bf<VCVTF:mode>): Likewise.
10633
10634 2020-02-25 Christophe Lyon <christophe.lyon@linaro.org>
10635
10636 * config/arm/arm.md (required_for_purecode): New attribute.
10637 (enabled): Handle required_for_purecode.
10638 * config/arm/thumb1.md (thumb1_movsi_insn): Add alternative to
10639 work with -mpure-code.
10640
10641 2020-02-25 Jakub Jelinek <jakub@redhat.com>
10642
10643 PR rtl-optimization/93908
10644 * combine.c (find_split_point): For store into ZERO_EXTRACT, and src
10645 with mask.
10646
10647 2019-02-25 Eric Botcazou <ebotcazou@adacore.com>
10648
10649 * dwarf2out.c (dwarf2out_size_function): Run in early-DWARF mode.
10650
10651 2020-02-25 Roman Zhuykov <zhroma@ispras.ru>
10652
10653 * doc/install.texi (--enable-checking): Adjust wording.
10654
10655 2020-02-25 Richard Biener <rguenther@suse.de>
10656
10657 PR tree-optimization/93868
10658 * tree-vect-slp.c (slp_copy_subtree): New function.
10659 (vect_attempt_slp_rearrange_stmts): Copy the SLP tree before
10660 re-arranging stmts in it.
10661
10662 2020-02-25 Jakub Jelinek <jakub@redhat.com>
10663
10664 PR middle-end/93874
10665 * passes.c (pass_manager::dump_passes): Create a cgraph node for the
10666 dummy function and remove it at the end.
10667
10668 PR translation/93864
10669 * config/lm32/lm32.c (lm32_setup_incoming_varargs): Fix comment typo
10670 paramter -> parameter.
10671 * config/aarch64/aarch64.c (aarch64_is_extend_from_extract): Likewise.
10672 * ipa-prop.h (struct ipa_agg_replacement_value): Likewise.
10673
10674 2020-02-24 Roman Zhuykov <zhroma@ispras.ru>
10675
10676 * doc/install.texi (--enable-checking): Properly document current
10677 behavior.
10678 (--enable-stage1-checking): Minor clarification about bootstrap.
10679
10680 2020-02-24 David Malcolm <dmalcolm@redhat.com>
10681
10682 PR analyzer/93032
10683 * doc/invoke.texi (-Wnanalyzer-tainted-array-index): Note that
10684 -fanalyzer-checker=taint is also required.
10685 (-fanalyzer-checker=): Note that providing this option enables the
10686 given checker, and doing so may be required for checkers that are
10687 disabled by default.
10688
10689 2020-02-24 David Malcolm <dmalcolm@redhat.com>
10690
10691 * doc/invoke.texi (-fanalyzer-verbosity=): "2" only shows
10692 significant control flow events; add a "3" which shows all
10693 control flow events; the old "3" becomes "4".
10694
10695 2020-02-24 Jakub Jelinek <jakub@redhat.com>
10696
10697 PR tree-optimization/93582
10698 * tree-ssa-sccvn.c (vn_walk_cb_data::push_partial_def): Consider
10699 pd.offset and pd.size to be counted in bits rather than bytes, add
10700 support for maxsizei that is not a multiple of BITS_PER_UNIT and
10701 handle bitfield stores and loads.
10702 (vn_reference_lookup_3): Don't call ranges_known_overlap_p with
10703 uncomparable quantities - bytes vs. bits. Allow push_partial_def
10704 on offsets/sizes that aren't multiple of BITS_PER_UNIT and adjust
10705 pd.offset/pd.size to be counted in bits rather than bytes.
10706 Formatting fix. Rename shadowed len variable to buflen.
10707
10708 2020-02-24 Prathamesh Kulkarni <prathamesh.kulkarni@linaro.org>
10709 Kugan Vivekandarajah <kugan.vivekanandarajah@linaro.org>
10710
10711 PR driver/47785
10712 * gcc.c (putenv_COLLECT_AS_OPTIONS): New function.
10713 (driver::main): Call putenv_COLLECT_AS_OPTIONS.
10714 * opts-common.c (parse_options_from_collect_gcc_options): New function.
10715 (prepend_xassembler_to_collect_as_options): Likewise.
10716 * opts.h (parse_options_from_collect_gcc_options): Declare prototype.
10717 (prepend_xassembler_to_collect_as_options): Likewise.
10718 * lto-opts.c (lto_write_options): Stream assembler options
10719 in COLLECT_AS_OPTIONS.
10720 * lto-wrapper.c (xassembler_options_error): New static variable.
10721 (get_options_from_collect_gcc_options): Move parsing options code to
10722 parse_options_from_collect_gcc_options and call it.
10723 (merge_and_complain): Validate -Xassembler options.
10724 (append_compiler_options): Handle OPT_Xassembler.
10725 (run_gcc): Append command line -Xassembler options to
10726 collect_gcc_options.
10727 * doc/invoke.texi: Add documentation about using Xassembler
10728 options with LTO.
10729
10730 2020-02-24 Kito Cheng <kito.cheng@sifive.com>
10731
10732 * config/riscv/riscv.c (riscv_emit_float_compare): Change the code gen
10733 for LTGT.
10734 (riscv_rtx_costs): Update cost model for LTGT.
10735
10736 2020-02-23 Vladimir Makarov <vmakarov@redhat.com>
10737
10738 PR rtl-optimization/93564
10739 * ira-color.c (struct update_cost_queue_elem): New member start.
10740 (queue_update_cost, get_next_update_cost): Add new arg start.
10741 (allocnos_conflict_p): New function.
10742 (update_costs_from_allocno): Add new arg conflict_cost_update_p.
10743 Add checking conflicts with allocnos_conflict_p.
10744 (update_costs_from_prefs, restore_costs_from_copies): Adjust
10745 update_costs_from_allocno calls.
10746 (update_conflict_hard_regno_costs): Add checking conflicts with
10747 allocnos_conflict_p. Adjust calls of queue_update_cost and
10748 get_next_update_cost.
10749 (assign_hard_reg): Adjust calls of queue_update_cost. Add
10750 debugging print.
10751 (bucket_allocno_compare_func): Restore previous version.
10752
10753 2020-02-21 John David Anglin <danglin@gcc.gnu.org>
10754
10755 * gcc/config/pa/pa.c (pa_function_value): Fix check for word and
10756 double-word size when handling aggregate return values.
10757 * gcc/config/pa/som.h (ASM_DECLARE_FUNCTION_NAME): Fix to indicate
10758 that homogeneous SFmode and DFmode aggregates are passed and returned
10759 in general registers.
10760
10761 2020-02-21 Jakub Jelinek <jakub@redhat.com>
10762
10763 PR translation/93759
10764 * opts.c (print_filtered_help): Translate help before appending
10765 messages to it rather than after that.
10766
10767 2020-02-19 Richard Sandiford <richard.sandiford@arm.com>
10768
10769 PR rtl-optimization/PR92989
10770 * lra-lives.c (process_bb_lives): Restore the original order
10771 of the bb liveness update. Call make_hard_regno_dead for each
10772 register clobbered at the start of an EH receiver.
10773
10774 2020-02-18 Feng Xue <fxue@os.amperecomputing.com>
10775
10776 PR ipa/93763
10777 * ipa-cp.c (self_recursively_generated_p): Mark self-dependent value as
10778 self-recursively generated.
10779
10780 2020-02-21 Iain Sandoe <iain@sandoe.co.uk>
10781
10782 PR target/93860
10783 * config/darwin-c.c (pop_field_alignment): Adjust quoting of
10784 error string.
10785
10786 2020-02-21 Mihail Ionescu <mihail.ionescu@arm.com>
10787
10788 * doc/sourcebuild.texi (arm_v8_1m_mve_ok):
10789 Document new target supports option.
10790
10791 2020-02-21 Dennis Zhang <dennis.zhang@arm.com>
10792
10793 * config/arm/arm_neon.h (vmmlaq_s32, vmmlaq_u32, vusmmlaq_s32): New.
10794 * config/arm/arm_neon_builtins.def (smmla, ummla, usmmla): New.
10795 * config/arm/iterators.md (MATMUL): New iterator.
10796 (sup): Add UNSPEC_MATMUL_S, UNSPEC_MATMUL_U, and UNSPEC_MATMUL_US.
10797 (mmla_sfx): New attribute.
10798 * config/arm/neon.md (neon_<sup>mmlav16qi): New.
10799 * config/arm/unspecs.md (UNSPEC_MATMUL_S, UNSPEC_MATMUL_U): New.
10800 (UNSPEC_MATMUL_US): New.
10801
10802 2020-02-21 Mihail-Calin Ionescu <mihail.ionescu@arm.com>
10803
10804 * config/arm/arm.md: Prevent scalar shifts from being used when big
10805 endian is enabled.
10806
10807 2020-02-21 Jan Hubicka <hubicka@ucw.cz>
10808 Richard Biener <rguenther@suse.de>
10809
10810 PR tree-optimization/93586
10811 * tree-ssa-alias.c (nonoverlapping_array_refs_p): Finish array walk
10812 after mismatched array refs; do not sure type size information to
10813 recover from unmatched referneces with !flag_strict_aliasing_p.
10814
10815 2020-02-21 Andrew Stubbs <ams@codesourcery.com>
10816
10817 * config/gcn/gcn-valu.md (gather_load<mode>): Rename to ...
10818 (gather_load<mode>v64si): ... this and set operand 2 to V64SI.
10819 (scatter_store<mode>): Rename to ...
10820 (scatter_store<mode>v64si): ... this and set operand 1 to V64SI.
10821 (scatter<mode>_exec): Delete. Move contents ...
10822 (mask_scatter_store<mode>): ... here, and rename that to ...
10823 (mask_gather_load<mode>v64si): ... this. Set operand 2 to V64SI.
10824 Remove mode conversion.
10825 (mask_gather_load<mode>): Rename to ...
10826 (mask_scatter_store<mode>v64si): ... this. Set operand 1 to V64SI.
10827 Remove mode conversion.
10828 * config/gcn/gcn.c (gcn_expand_scaled_offsets): Remove mode conversion.
10829
10830 2020-02-21 Martin Jambor <mjambor@suse.cz>
10831
10832 PR tree-optimization/93845
10833 * tree-sra.c (verify_sra_access_forest): Only test access size of
10834 scalar types.
10835
10836 2020-02-21 Andrew Stubbs <ams@codesourcery.com>
10837
10838 * config/gcn/gcn.c (gcn_hard_regno_mode_ok): Align VGPR pairs.
10839 * config/gcn/gcn-valu.md (addv64di3): Remove early-clobber.
10840 (addv64di3_exec): Likewise.
10841 (subv64di3): Likewise.
10842 (subv64di3_exec): Likewise.
10843 (addv64di3_zext): Likewise.
10844 (addv64di3_zext_exec): Likewise.
10845 (addv64di3_zext_dup): Likewise.
10846 (addv64di3_zext_dup_exec): Likewise.
10847 (addv64di3_zext_dup2): Likewise.
10848 (addv64di3_zext_dup2_exec): Likewise.
10849 (addv64di3_sext_dup2): Likewise.
10850 (addv64di3_sext_dup2_exec): Likewise.
10851 (<expander>v64di3): Likewise.
10852 (<expander>v64di3_exec): Likewise.
10853 (*<reduc_op>_dpp_shr_v64di): Likewise.
10854 (*plus_carry_dpp_shr_v64di): Likewise.
10855 * config/gcn/gcn.md (adddi3): Likewise.
10856 (addptrdi3): Likewise.
10857 (<expander>di3): Likewise.
10858
10859 2020-02-21 Andrew Stubbs <ams@codesourcery.com>
10860
10861 * config/gcn/gcn-valu.md (vec_seriesv64di): Use gen_vec_duplicatev64di.
10862
10863 2020-02-21 Richard Sandiford <richard.sandiford@arm.com>
10864
10865 * config/aarch64/aarch64.c (aarch64_emit_approx_sqrt): Add SVE
10866 support. Use aarch64_emit_mult instead of emitting multiplication
10867 instructions directly.
10868 * config/aarch64/aarch64-sve.md (sqrt<mode>2, rsqrt<mode>2)
10869 (@aarch64_rsqrte<mode>, @aarch64_rsqrts<mode>): New expanders.
10870
10871 2020-02-21 Richard Sandiford <richard.sandiford@arm.com>
10872
10873 * config/aarch64/aarch64.c (aarch64_emit_mult): New function.
10874 (aarch64_emit_approx_div): Add SVE support. Use aarch64_emit_mult
10875 instead of emitting multiplication instructions directly.
10876 * config/aarch64/iterators.md (SVE_COND_FP_BINARY_OPTAB): New iterator.
10877 * config/aarch64/aarch64-sve.md (div<mode>3, @aarch64_frecpe<mode>)
10878 (@aarch64_frecps<mode>): New expanders.
10879
10880 2020-02-21 Richard Sandiford <richard.sandiford@arm.com>
10881
10882 * config/aarch64/aarch64-protos.h (AARCH64_APPROX_MODE): Operate
10883 on and produce uint64_ts rather than ints.
10884 (AARCH64_APPROX_NONE, AARCH64_APPROX_ALL): Change to uint64_ts.
10885 (cpu_approx_modes): Change the fields from unsigned int to uint64_t.
10886
10887 2020-02-21 Richard Sandiford <richard.sandiford@arm.com>
10888
10889 * config/aarch64/aarch64.c (aarch64_emit_approx_sqrt): Don't create
10890 an unused xmsk register when handling approximate rsqrt.
10891
10892 2020-02-21 Richard Sandiford <richard.sandiford@arm.com>
10893
10894 * config/aarch64/aarch64.c (aarch64_emit_approx_sqrt): Fix inverted
10895 flag_finite_math_only condition.
10896
10897 2020-02-20 Uroš Bizjak <ubizjak@gmail.com>
10898
10899 PR target/93828
10900 * config/i386/mmx.md (*vec_extractv2sf_1): Match source operand
10901 to destination operand for shufps alternative.
10902 (*vec_extractv2si_1): Ditto.
10903
10904 2020-02-20 Peter Bergner <bergner@linux.ibm.com>
10905
10906 PR target/93658
10907 * config/rs6000/rs6000.c (rs6000_legitimate_address_p): Handle VSX
10908 vector modes.
10909
10910 2020-02-20 Martin Liska <mliska@suse.cz>
10911
10912 PR translation/93831
10913 * config/darwin.c (darwin_override_options): Change 64b to 64-bit mode.
10914
10915 2020-02-20 Martin Liska <mliska@suse.cz>
10916
10917 PR translation/93830
10918 * common/config/avr/avr-common.c: Remote trailing "|".
10919
10920 2020-02-19 Bernd Edlinger <bernd.edlinger@hotmail.de>
10921
10922 * collect2.c (maybe_run_lto_and_relink): Fix typo in
10923 comment.
10924
10925 2020-02-19 Richard Sandiford <richard.sandiford@arm.com>
10926
10927 PR tree-optimization/93767
10928 * tree-vect-data-refs.c (vect_compile_time_alias): Remove the
10929 access-size bias from the offset calculations for negative strides.
10930
10931 2020-02-19 Bernd Edlinger <bernd.edlinger@hotmail.de>
10932
10933 * collect2.c (c_file, o_file): Make const again.
10934 (ldout,lderrout, dump_ld_file): Remove.
10935 (tool_cleanup): Avoid calling not signal-safe functions.
10936 (maybe_run_lto_and_relink): Avoid possible signal handler
10937 access to unintialzed memory (lto_o_files).
10938 (main): Avoid leaking temp files in $TMPDIR.
10939 Initialize c_file/o_file with concat, which avoids exposing
10940 uninitialized memory to signal handler, which calls unlink(!).
10941 Avoid calling maybe_unlink when the main function returns,
10942 since the atexit handler is already doing this.
10943 * collect2.h (dump_ld_file, ldout, lderrout): Remove.
10944
10945 2020-02-19 Martin Jambor <mjambor@suse.cz>
10946
10947 PR tree-optimization/93776
10948 * tree-sra.c (create_access): Do not create zero size accesses.
10949 (get_access_for_expr): Do not search for zero sized accesses.
10950
10951 2020-02-19 Martin Jambor <mjambor@suse.cz>
10952
10953 PR tree-optimization/93667
10954 * tree-sra.c (scalarizable_type_p): Return false if record fields
10955 do not follow wach other.
10956
10957 2020-01-21 Kito Cheng <kito.cheng@sifive.com>
10958
10959 * config/riscv/riscv.c (riscv_output_move) Using fmv.x.w/fmv.w.x
10960 rather than fmv.x.s/fmv.s.x.
10961
10962 2020-02-18 James Greenhalgh <james.greenhalgh@arm.com>
10963
10964 * config/aarch64/aarch64-simd-builtins.def
10965 (intrinsic_vec_smult_lo_): New.
10966 (intrinsic_vec_umult_lo_): Likewise.
10967 (vec_widen_smult_hi_): Likewise.
10968 (vec_widen_umult_hi_): Likewise.
10969 * config/aarch64/aarch64-simd.md
10970 (aarch64_intrinsic_vec_<su>mult_lo_<mode>): New.
10971 * config/aarch64/arm_neon.h (vmull_high_s8): Use intrinsics.
10972 (vmull_high_s16): Likewise.
10973 (vmull_high_s32): Likewise.
10974 (vmull_high_u8): Likewise.
10975 (vmull_high_u16): Likewise.
10976 (vmull_high_u32): Likewise.
10977 (vmull_s8): Likewise.
10978 (vmull_s16): Likewise.
10979 (vmull_s32): Likewise.
10980 (vmull_u8): Likewise.
10981 (vmull_u16): Likewise.
10982 (vmull_u32): Likewise.
10983
10984 2020-02-18 Martin Liska <mliska@suse.cz>
10985
10986 * value-prof.c (stream_out_histogram_value): Restore LTO PGO
10987 bootstrap by missing removal of invalid sanity check.
10988
10989 2020-02-18 Martin Liska <mliska@suse.cz>
10990
10991 PR ipa/92518
10992 * ipa-icf-gimple.c (func_checker::compare_gimple_assign):
10993 Always compare LHS of gimple_assign.
10994
10995 2020-02-18 Martin Liska <mliska@suse.cz>
10996
10997 PR ipa/93583
10998 * cgraph.c (cgraph_node::verify_node): Verify MALLOC attribute
10999 and return type of functions.
11000 * ipa-param-manipulation.c (ipa_param_adjustments::adjust_decl):
11001 Drop MALLOC attribute for void functions.
11002 * ipa-pure-const.c (funct_state_summary_t::duplicate): Drop
11003 malloc_state for a new VOID clone.
11004
11005 2020-02-18 Martin Liska <mliska@suse.cz>
11006
11007 PR ipa/92924
11008 * common.opt: Add -fprofile-reproducibility.
11009 * doc/invoke.texi: Document it.
11010 * value-prof.c (dump_histogram_value):
11011 Document and support behavior for counters[0]
11012 being a negative value.
11013 (get_nth_most_common_value): Handle negative
11014 counters[0] in respect to flag_profile_reproducible.
11015
11016 2020-02-18 Jakub Jelinek <jakub@redhat.com>
11017
11018 PR ipa/93797
11019 * cgraph.c (verify_speculative_call): Use speculative_id instead of
11020 speculative_uid in messages. Remove trailing whitespace from error
11021 message. Use num_speculative_call_targets instead of
11022 num_speculative_targets in a message.
11023 (cgraph_node::verify_node): Use call_stmt instead of cal_stmt in
11024 edge messages and stmt instead of cal_stmt in reference message.
11025
11026 PR tree-optimization/93780
11027 * tree-ssa.c (non_rewritable_lvalue_p): Check valid_vector_subparts_p
11028 before calling build_vector_type.
11029 (execute_update_addresses_taken): Likewise.
11030
11031 PR driver/93796
11032 * params.opt (-param=ipa-max-switch-predicate-bounds=): Fix help
11033 typo, functoin -> function.
11034 * tree.c (free_lang_data_in_decl): Fix comment typo,
11035 functoin -> function.
11036 * ipa-visibility.c (cgraph_externally_visible_p): Likewise.
11037
11038 2020-02-17 David Malcolm <dmalcolm@redhat.com>
11039
11040 * diagnostic.c (print_any_cwe): Don't call get_cwe_url if URLs
11041 won't be printed.
11042 (print_option_information): Don't call get_option_url if URLs
11043 won't be printed.
11044
11045 2020-02-17 Alexandre Oliva <oliva@adacore.com>
11046
11047 * tree-emutls.c (new_emutls_decl, emutls_common_1): Complete
11048 handling of register_common-less targets.
11049
11050 2020-02-17 Martin Liska <mliska@suse.cz>
11051
11052 PR ipa/93760
11053 * ipa-devirt.c (odr_types_equivalent_p): Fix grammar.
11054
11055 2020-02-17 Martin Liska <mliska@suse.cz>
11056
11057 PR translation/93755
11058 * config/rs6000/rs6000.c (rs6000_option_override_internal):
11059 Fix double quotes.
11060
11061 2020-02-17 Martin Liska <mliska@suse.cz>
11062
11063 PR other/93756
11064 * config/rx/elf.opt: Fix typo.
11065
11066 2020-02-17 Richard Biener <rguenther@suse.de>
11067
11068 PR c/86134
11069 * opts-global.c (print_ignored_options): Use inform and
11070 amend message.
11071
11072 2020-02-17 Jiufu Guo <guojiufu@linux.ibm.com>
11073
11074 PR target/93047
11075 * config/rs6000/rs6000.md (untyped_call): Add emit_clobber.
11076
11077 2020-02-16 Uroš Bizjak <ubizjak@gmail.com>
11078
11079 PR target/93743
11080 * config/i386/i386.md (atan2xf3): Swap operands 1 and 2.
11081 (atan2<mode>3): Update operand order in the call to gen_atan2xf3.
11082
11083 2020-02-15 Jason Merrill <jason@redhat.com>
11084
11085 * doc/invoke.texi (C Dialect Options): Add -std=c++20.
11086
11087 2020-02-15 Jakub Jelinek <jakub@redhat.com>
11088
11089 PR tree-optimization/93744
11090 * match.pd (((m1 >/</>=/<= m2) * d -> (m1 >/</>=/<= m2) ? d : 0,
11091 A - ((A - B) & -(C cmp D)) -> (C cmp D) ? B : A,
11092 A + ((B - A) & -(C cmp D)) -> (C cmp D) ? B : A): For GENERIC, make
11093 sure @2 in the first and @1 in the other patterns has no side-effects.
11094
11095 2020-02-15 David Malcolm <dmalcolm@redhat.com>
11096 Bernd Edlinger <bernd.edlinger@hotmail.de>
11097
11098 PR 87488
11099 PR other/93168
11100 * config.in (DIAGNOSTICS_URLS_DEFAULT): New define.
11101 * configure.ac (--with-diagnostics-urls): New configuration
11102 option, based on --with-diagnostics-color.
11103 (DIAGNOSTICS_URLS_DEFAULT): New define.
11104 * config.h: Regenerate.
11105 * configure: Regenerate.
11106 * diagnostic.c (diagnostic_urls_init): Handle -1 for
11107 DIAGNOSTICS_URLS_DEFAULT from configure-time
11108 --with-diagnostics-urls=auto-if-env by querying for a GCC_URLS
11109 and TERM_URLS environment variable.
11110 * diagnostic-url.h (diagnostic_url_format): New enum type.
11111 (diagnostic_urls_enabled_p): rename to...
11112 (determine_url_format): ... this, and change return type.
11113 * diagnostic-color.c (parse_env_vars_for_urls): New helper function.
11114 (auto_enable_urls): Disable URLs on xfce4-terminal, gnome-terminal,
11115 the linux console, and mingw.
11116 (diagnostic_urls_enabled_p): rename to...
11117 (determine_url_format): ... this, and adjust.
11118 * pretty-print.h (pretty_printer::show_urls): rename to...
11119 (pretty_printer::url_format): ... this, and change to enum.
11120 * pretty-print.c (pretty_printer::pretty_printer,
11121 pp_begin_url, pp_end_url, test_urls): Adjust.
11122 * doc/install.texi (--with-diagnostics-urls): Document the new
11123 configuration option.
11124 (--with-diagnostics-color): Document the existing interaction
11125 with GCC_COLORS better.
11126 * doc/invoke.texi (-fdiagnostics-urls): Add GCC_URLS and TERM_URLS
11127 vindex reference. Update description of defaults based on the above.
11128 (-fdiagnostics-color): Update description of how -fdiagnostics-color
11129 interacts with GCC_COLORS.
11130
11131 2020-02-14 Eric Botcazou <ebotcazou@adacore.com>
11132
11133 PR target/93704
11134 * config/sparc/sparc.c (eligible_for_call_delay): Test HAVE_GNU_LD in
11135 conjunction with TARGET_GNU_TLS in early return.
11136
11137 2020-02-14 Alexander Monakov <amonakov@ispras.ru>
11138
11139 * rtlanal.c (rtx_cost): Handle a SET up front. Avoid division if
11140 the mode is not wider than UNITS_PER_WORD.
11141
11142 2020-02-14 Martin Jambor <mjambor@suse.cz>
11143
11144 PR tree-optimization/93516
11145 * tree-sra.c (propagate_subaccesses_from_rhs): Do not create
11146 access of the same type as the parent.
11147 (propagate_subaccesses_from_lhs): Likewise.
11148
11149 2020-02-14 Hongtao Liu <hongtao.liu@intel.com>
11150
11151 PR target/93724
11152 * config/i386/avx512vbmi2intrin.h
11153 (_mm512_shrdi_epi16, _mm512_mask_shrdi_epi16,
11154 _mm512_maskz_shrdi_epi16, _mm512_shrdi_epi32,
11155 _mm512_mask_shrdi_epi32, _mm512_maskz_shrdi_epi32,
11156 _m512_shrdi_epi64, _m512_mask_shrdi_epi64,
11157 _m512_maskz_shrdi_epi64, _mm512_shldi_epi16,
11158 _mm512_mask_shldi_epi16, _mm512_maskz_shldi_epi16,
11159 _mm512_shldi_epi32, _mm512_mask_shldi_epi32,
11160 _mm512_maskz_shldi_epi32, _mm512_shldi_epi64,
11161 _mm512_mask_shldi_epi64, _mm512_maskz_shldi_epi64): Fix typo
11162 of lacking a closing parenthesis.
11163 * config/i386/avx512vbmi2vlintrin.h
11164 (_mm256_shrdi_epi16, _mm256_mask_shrdi_epi16,
11165 _mm256_maskz_shrdi_epi16, _mm256_shrdi_epi32,
11166 _mm256_mask_shrdi_epi32, _mm256_maskz_shrdi_epi32,
11167 _m256_shrdi_epi64, _m256_mask_shrdi_epi64,
11168 _m256_maskz_shrdi_epi64, _mm256_shldi_epi16,
11169 _mm256_mask_shldi_epi16, _mm256_maskz_shldi_epi16,
11170 _mm256_shldi_epi32, _mm256_mask_shldi_epi32,
11171 _mm256_maskz_shldi_epi32, _mm256_shldi_epi64,
11172 _mm256_mask_shldi_epi64, _mm256_maskz_shldi_epi64,
11173 _mm_shrdi_epi16, _mm_mask_shrdi_epi16,
11174 _mm_maskz_shrdi_epi16, _mm_shrdi_epi32,
11175 _mm_mask_shrdi_epi32, _mm_maskz_shrdi_epi32,
11176 _mm_shrdi_epi64, _mm_mask_shrdi_epi64,
11177 _m_maskz_shrdi_epi64, _mm_shldi_epi16,
11178 _mm_mask_shldi_epi16, _mm_maskz_shldi_epi16,
11179 _mm_shldi_epi32, _mm_mask_shldi_epi32,
11180 _mm_maskz_shldi_epi32, _mm_shldi_epi64,
11181 _mm_mask_shldi_epi64, _mm_maskz_shldi_epi64): Ditto.
11182
11183 2020-02-13 H.J. Lu <hongjiu.lu@intel.com>
11184
11185 PR target/93656
11186 * config/i386/i386.c (ix86_trampoline_init): Skip ENDBR32 at
11187 the target function entry.
11188
11189 2020-02-13 Claudiu Zissulescu <claziss@synopsys.com>
11190
11191 * common/config/arc/arc-common.c (arc_option_optimization_table):
11192 Disable if-conversion step when optimized for size.
11193
11194 2020-02-13 Claudiu Zissulescu <claziss@synopsys.com>
11195
11196 * config/arc/arc.c (arc_conditional_register_usage): R0-R3 and
11197 R12-R15 are always in ARCOMPACT16_REGS register class.
11198 * config/arc/arc.opt (mq-class): Deprecate.
11199 * config/arc/constraint.md ("q"): Remove dependency on mq-class
11200 option.
11201 * doc/invoke.texi (mq-class): Update text.
11202 * common/config/arc/arc-common.c (arc_option_optimization_table):
11203 Update list.
11204
11205 2020-02-13 Claudiu Zissulescu <claziss@synopsys.com>
11206
11207 * config/arc/arc.c (arc_insn_cost): New function.
11208 (TARGET_INSN_COST): Define.
11209 * config/arc/arc.md (cost): New attribute.
11210 (add_n): Use arc_nonmemory_operand.
11211 (ashlsi3_insn): Likewise, also update constraints.
11212 (ashrsi3_insn): Likewise.
11213 (rotrsi3): Likewise.
11214 (add_shift): Likewise.
11215 * config/arc/predicates.md (arc_nonmemory_operand): New predicate.
11216
11217 2020-02-13 Claudiu Zissulescu <claziss@synopsys.com>
11218
11219 * config/arc/arc.md (mulsidi_600): Correctly select mlo/mhi
11220 registers.
11221 (umulsidi_600): Likewise.
11222
11223 2020-02-13 Jakub Jelinek <jakub@redhat.com>
11224
11225 PR target/93696
11226 * config/i386/avx512bitalgintrin.h (_mm512_mask_popcnt_epi8,
11227 _mm512_mask_popcnt_epi16, _mm256_mask_popcnt_epi8,
11228 _mm256_mask_popcnt_epi16, _mm_mask_popcnt_epi8,
11229 _mm_mask_popcnt_epi16): Rename __B argument to __A and __A to __W,
11230 pass __A to the builtin followed by __W instead of __A followed by
11231 __B.
11232 * config/i386/avx512vpopcntdqintrin.h (_mm512_mask_popcnt_epi32,
11233 _mm512_mask_popcnt_epi64): Likewise.
11234 * config/i386/avx512vpopcntdqvlintrin.h (_mm_mask_popcnt_epi32,
11235 _mm256_mask_popcnt_epi32, _mm_mask_popcnt_epi64,
11236 _mm256_mask_popcnt_epi64): Likewise.
11237
11238 PR tree-optimization/93582
11239 * fold-const.h (shift_bytes_in_array_left,
11240 shift_bytes_in_array_right): Declare.
11241 * fold-const.c (shift_bytes_in_array_left,
11242 shift_bytes_in_array_right): New function, moved from
11243 gimple-ssa-store-merging.c, no longer static.
11244 * gimple-ssa-store-merging.c (shift_bytes_in_array): Move
11245 to gimple-ssa-store-merging.c and rename to shift_bytes_in_array_left.
11246 (shift_bytes_in_array_right): Move to gimple-ssa-store-merging.c.
11247 (encode_tree_to_bitpos): Use shift_bytes_in_array_left instead of
11248 shift_bytes_in_array.
11249 (verify_shift_bytes_in_array): Rename to ...
11250 (verify_shift_bytes_in_array_left): ... this. Use
11251 shift_bytes_in_array_left instead of shift_bytes_in_array.
11252 (store_merging_c_tests): Call verify_shift_bytes_in_array_left
11253 instead of verify_shift_bytes_in_array.
11254 * tree-ssa-sccvn.c (vn_reference_lookup_3): For native_encode_expr
11255 / native_interpret_expr where the store covers all needed bits,
11256 punt on PDP-endian, otherwise allow all involved offsets and sizes
11257 not to be byte-aligned.
11258
11259 PR target/93673
11260 * config/i386/sse.md (k<code><mode>): Drop mode from last operand and
11261 use const_0_to_255_operand predicate instead of immediate_operand.
11262 (avx512dq_fpclass<mode><mask_scalar_merge_name>,
11263 avx512dq_vmfpclass<mode><mask_scalar_merge_name>,
11264 vgf2p8affineinvqb_<mode><mask_name>,
11265 vgf2p8affineqb_<mode><mask_name>): Drop mode from
11266 const_0_to_255_operand predicated operands.
11267
11268 2020-02-12 Jeff Law <law@redhat.com>
11269
11270 * config/h8300/h8300.md (comparison shortening peepholes): Use
11271 a mode iterator to merge the HImode and SImode peepholes.
11272
11273 2020-02-12 Jakub Jelinek <jakub@redhat.com>
11274
11275 PR middle-end/93663
11276 * real.c (is_even): Make static. Function comment fix.
11277 (is_halfway_below): Make static, don't assert R is not inf/nan,
11278 instead return false for those. Small formatting fixes.
11279
11280 2020-02-12 Martin Sebor <msebor@redhat.com>
11281
11282 PR middle-end/93646
11283 * tree-ssa-strlen.c (handle_builtin_stxncpy): Rename...
11284 (handle_builtin_stxncpy_strncat): ...to this. Change first argument.
11285 Issue only -Wstringop-overflow strncat, never -Wstringop-truncation.
11286 (strlen_check_and_optimize_call): Adjust callee name.
11287
11288 2020-02-12 Jeff Law <law@redhat.com>
11289
11290 * config/h8300/h8300.md (comparison shortening peepholes): Drop
11291 (and (xor)) variant. Combine other two into single peephole.
11292
11293 2020-02-12 Wilco Dijkstra <wdijkstr@arm.com>
11294
11295 PR rtl-optimization/93565
11296 * config/aarch64/aarch64.c (aarch64_rtx_costs): Add CTZ costs.
11297
11298 2020-02-12 Wilco Dijkstra <wdijkstr@arm.com>
11299
11300 * config/aarch64/aarch64-simd.md
11301 (aarch64_zero_extend<GPI:mode>_reduc_plus_<VDQV_E:mode>): New pattern.
11302 * config/aarch64/aarch64.md (popcount<mode>2): Use it instead of
11303 generating separate ADDV and zero_extend patterns.
11304 * config/aarch64/iterators.md (VDQV_E): New iterator.
11305
11306 2020-02-12 Jeff Law <law@redhat.com>
11307
11308 * config/h8300/h8300.md (cpymemsi, movmd): Remove dead patterns,
11309 expanders, splits, etc.
11310 (movmd_internal_<mode>, movmd splitter, movstr, movsd): Likewise.
11311 (stpcpy_internal_<mode>, stpcpy splitter): Likewise.
11312 (peepholes to convert QI/HI mode pushes to SI mode pushes): Likewise.
11313 * config/h8300/h8300.c (h8300_swap_into_er6): Remove unused function.
11314 (h8300_swap_out_of_er6, h8sx_emit_movmd): Likewise
11315 * config/h8300/h8300-protos.h (h8300_swap_into_er6): Remove unused
11316 function prototype.
11317 (h8300_swap_out_of_er6, h8sx_emit_movmd): Likewise.
11318
11319 2020-02-12 Jakub Jelinek <jakub@redhat.com>
11320
11321 PR target/93670
11322 * config/i386/sse.md (VI48F_256_DQ): New mode iterator.
11323 (avx512vl_vextractf128<mode>): Use it instead of VI48F_256. Remove
11324 TARGET_AVX512DQ from condition.
11325 (vec_extract_lo_<mode><mask_name>): Use <mask_avx512dq_condition>
11326 instead of <mask_mode512bit_condition> in condition. If
11327 TARGET_AVX512DQ is false, emit vextract*64x4 instead of
11328 vextract*32x8.
11329 (vec_extract_lo_<mode><mask_name>): Drop <mask_avx512dq_condition>
11330 from condition.
11331
11332 2020-02-12 Kewen Lin <linkw@gcc.gnu.org>
11333
11334 PR target/91052
11335 * ira.c (combine_and_move_insns): Skip multiple_sets def_insn.
11336
11337 2020-02-12 Segher Boessenkool <segher@kernel.crashing.org>
11338
11339 * config/rs6000/rs6000.c (rs6000_debug_print_mode): Don't use sizeof
11340 where strlen is more legible.
11341 (rs6000_builtin_vectorized_libmass): Ditto.
11342 (rs6000_print_options_internal): Ditto.
11343
11344 2020-02-11 Martin Sebor <msebor@redhat.com>
11345
11346 PR tree-optimization/93683
11347 * tree-ssa-alias.c (stmt_kills_ref_p): Avoid using LHS when not set.
11348
11349 2020-02-11 Michael Meissner <meissner@linux.ibm.com>
11350
11351 * config/rs6000/predicates.md (cint34_operand): Rename the
11352 -mprefixed-addr option to be -mprefixed.
11353 * config/rs6000/rs6000-cpus.def (ISA_FUTURE_MASKS_SERVER): Rename
11354 the -mprefixed-addr option to be -mprefixed.
11355 (OTHER_FUTURE_MASKS): Likewise.
11356 (POWERPC_MASKS): Likewise.
11357 * config/rs6000/rs6000.c (rs6000_option_override_internal): Rename
11358 the -mprefixed-addr option to be -mprefixed. Change error
11359 messages to refer to -mprefixed.
11360 (num_insns_constant_gpr): Rename the -mprefixed-addr option to be
11361 -mprefixed.
11362 (rs6000_legitimate_offset_address_p): Likewise.
11363 (rs6000_mode_dependent_address): Likewise.
11364 (rs6000_opt_masks): Change the spelling of "-mprefixed-addr" to be
11365 "-mprefixed" for target attributes and pragmas.
11366 (address_to_insn_form): Rename the -mprefixed-addr option to be
11367 -mprefixed.
11368 (rs6000_adjust_insn_length): Likewise.
11369 * config/rs6000/rs6000.h (FINAL_PRESCAN_INSN): Rename the
11370 -mprefixed-addr option to be -mprefixed.
11371 (ASM_OUTPUT_OPCODE): Likewise.
11372 * config/rs6000/rs6000.md (prefixed insn attribute): Rename the
11373 -mprefixed-addr option to be -mprefixed.
11374 * config/rs6000/rs6000.opt (-mprefixed): Rename the
11375 -mprefixed-addr option to be prefixed. Change the option from
11376 being undocumented to being documented.
11377 * doc/invoke.texi (RS/6000 and PowerPC Options): Document the
11378 -mprefixed option. Update the -mpcrel documentation to mention
11379 -mprefixed.
11380
11381 2020-02-11 Hans-Peter Nilsson <hp@axis.com>
11382
11383 * ira-conflicts.c (print_hard_reg_set): Correct output for sets
11384 including FIRST_PSEUDO_REGISTER - 1.
11385 * ira-color.c (print_hard_reg_set): Ditto.
11386
11387 2020-02-11 Stam Markianos-Wright <stam.markianos-wright@arm.com>
11388
11389 * config/arm/arm-builtins.c (enum arm_type_qualifiers):
11390 (USTERNOP_QUALIFIERS): New define.
11391 (USMAC_LANE_QUADTUP_QUALIFIERS): New define.
11392 (SUMAC_LANE_QUADTUP_QUALIFIERS): New define.
11393 (arm_expand_builtin_args): Add case ARG_BUILTIN_LANE_QUADTUP_INDEX.
11394 (arm_expand_builtin_1): Add qualifier_lane_quadtup_index.
11395 * config/arm/arm_neon.h (vusdot_s32): New.
11396 (vusdot_lane_s32): New.
11397 (vusdotq_lane_s32): New.
11398 (vsudot_lane_s32): New.
11399 (vsudotq_lane_s32): New.
11400 * config/arm/arm_neon_builtins.def (usdot, usdot_lane,sudot_lane): New.
11401 * config/arm/iterators.md (DOTPROD_I8MM): New.
11402 (sup, opsuffix): Add <us/su>.
11403 * config/arm/neon.md (neon_usdot, <us/su>dot_lane: New.
11404 * config/arm/unspecs.md (UNSPEC_DOT_US, UNSPEC_DOT_SU): New.
11405
11406 2020-02-11 Richard Biener <rguenther@suse.de>
11407
11408 PR tree-optimization/93661
11409 PR tree-optimization/93662
11410 * tree-ssa-sccvn.c (vn_reference_lookup_3): Properly guard
11411 tree_to_poly_int64.
11412 * tree-sra.c (get_access_for_expr): Likewise.
11413
11414 2020-02-10 Jakub Jelinek <jakub@redhat.com>
11415
11416 PR target/93637
11417 * config/i386/sse.md (VI_256_AVX2): New mode iterator.
11418 (vcond_mask_<mode><sseintvecmodelower>): Use it instead of VI_256.
11419 Change condition from TARGET_AVX2 to TARGET_AVX.
11420
11421 2020-02-10 Iain Sandoe <iain@sandoe.co.uk>
11422
11423 PR other/93641
11424 * config/darwin-c.c (darwin_cfstring_ref_p): Fix up last
11425 argument of strncmp.
11426
11427 2020-02-10 Hans-Peter Nilsson <hp@axis.com>
11428
11429 Try to generate zero-based comparisons.
11430 * config/cris/cris.c (cris_reduce_compare): New function.
11431 * config/cris/cris-protos.h (cris_reduce_compare): Add prototype.
11432 * config/cris/cris.md ("cbranch<mode>4", "cbranchdi4", "cstoredi4")
11433 (cstore<mode>4"): Apply cris_reduce_compare in expanders.
11434
11435 2020-02-10 Richard Earnshaw <rearnsha@arm.com>
11436
11437 PR target/91913
11438 * config/arm/arm.md (movsi_compare0): Allow SP as a source register
11439 in Thumb state and also as a destination in Arm state. Add T16
11440 variants.
11441
11442 2020-02-10 Hans-Peter Nilsson <hp@axis.com>
11443
11444 * md.texi (Define Subst): Match closing paren in example.
11445
11446 2020-02-10 Jakub Jelinek <jakub@redhat.com>
11447
11448 PR target/58218
11449 PR other/93641
11450 * config/i386/i386.c (x86_64_elf_section_type_flags): Fix up last
11451 arguments of strncmp.
11452
11453 2020-02-10 Feng Xue <fxue@os.amperecomputing.com>
11454
11455 PR ipa/93203
11456 * ipa-cp.c (ipcp_lattice::add_value): Add source with same call edge
11457 but different source value.
11458 (adjust_callers_for_value_intersection): New function.
11459 (gather_edges_for_value): Adjust order of callers to let a
11460 non-self-recursive caller be the first element.
11461 (self_recursive_pass_through_p): Add a new parameter "simple", and
11462 check generalized self-recursive pass-through jump function.
11463 (self_recursive_agg_pass_through_p): Likewise.
11464 (find_more_scalar_values_for_callers_subset): Compute value from
11465 pass-through jump function for self-recursive.
11466 (intersect_with_plats): Cleanup previous implementation code for value
11467 itersection with self-recursive call edge.
11468 (intersect_with_agg_replacements): Likewise.
11469 (intersect_aggregates_with_edge): Deduce value from pass-through jump
11470 function for self-recursive call edge. Cleanup previous implementation
11471 code for value intersection with self-recursive call edge.
11472 (decide_whether_version_node): Remove dead callers and adjust order
11473 to let a non-self-recursive caller be the first element.
11474
11475 2020-02-09 Uroš Bizjak <ubizjak@gmail.com>
11476
11477 * recog.c: Move pass_split_before_sched2 code in front of
11478 pass_split_before_regstack.
11479 (pass_data_split_before_sched2): Rename pass to split3 from split4.
11480 (pass_data_split_before_regstack): Rename pass to split4 from split3.
11481 (rest_of_handle_split_before_sched2): Remove.
11482 (pass_split_before_sched2::execute): Unconditionally call
11483 split_all_insns.
11484 (enable_split_before_sched2): New function.
11485 (pass_split_before_sched2::gate): Use enable_split_before_sched2.
11486 (pass_split_before_regstack::gate): Ditto.
11487 * config/nds32/nds32.c (nds32_split_double_word_load_store_p):
11488 Update name check for renamed split4 pass.
11489 * config/sh/sh.c (register_sh_passes): Update pass insertion
11490 point for renamed split4 pass.
11491
11492 2020-02-09 Jakub Jelinek <jakub@redhat.com>
11493
11494 * gimplify.c (gimplify_adjust_omp_clauses_1): Promote
11495 DECL_IN_CONSTANT_POOL variables into "omp declare target" to avoid
11496 copying them around between host and target.
11497
11498 2020-02-08 Andrew Pinski <apinski@marvell.com>
11499
11500 PR target/91927
11501 * config/aarch64/aarch64-simd.md (movmisalign<mode>): Check
11502 STRICT_ALIGNMENT also.
11503
11504 2020-02-08 Jim Wilson <jimw@sifive.com>
11505
11506 PR target/93532
11507 * config/riscv/riscv.h (HARD_REGNO_CALLER_SAVE_MODE): Define.
11508
11509 2020-02-08 Uroš Bizjak <ubizjak@gmail.com>
11510 Jakub Jelinek <jakub@redhat.com>
11511
11512 PR target/65782
11513 * config/i386/i386.h (CALL_USED_REGISTERS): Make
11514 xmm16-xmm31 call-used even in 64-bit ms-abi.
11515
11516 2020-02-07 Dennis Zhang <dennis.zhang@arm.com>
11517
11518 * config/aarch64/aarch64-simd-builtins.def (simd_smmla): New entry.
11519 (simd_ummla, simd_usmmla): Likewise.
11520 * config/aarch64/aarch64-simd.md (aarch64_simd_<sur>mmlav16qi): New.
11521 * config/aarch64/arm_neon.h (vmmlaq_s32, vmmlaq_u32): New.
11522 (vusmmlaq_s32): New.
11523
11524 2020-02-07 Richard Biener <rguenther@suse.de>
11525
11526 PR middle-end/93519
11527 * tree-inline.c (fold_marked_statements): Do a PRE walk,
11528 skipping unreachable regions.
11529 (optimize_inline_calls): Skip folding stmts when we didn't
11530 inline.
11531
11532 2020-02-07 H.J. Lu <hongjiu.lu@intel.com>
11533
11534 PR target/85667
11535 * config/i386/i386.c (function_arg_ms_64): Add a type argument.
11536 Don't return aggregates with only SFmode and DFmode in SSE
11537 register.
11538 (ix86_function_arg): Pass arg.type to function_arg_ms_64.
11539
11540 2020-02-07 Jakub Jelinek <jakub@redhat.com>
11541
11542 PR target/93122
11543 * config/rs6000/rs6000-logue.c
11544 (rs6000_emit_probe_stack_range_stack_clash): Always use gen_add3_insn,
11545 if it fails, move rs into end_addr and retry. Add
11546 REG_FRAME_RELATED_EXPR note whenever it returns more than one insn or
11547 the insn pattern doesn't describe well what exactly happens to
11548 dwarf2cfi.c.
11549
11550 PR target/93594
11551 * config/i386/predicates.md (avx_identity_operand): Remove.
11552 * config/i386/sse.md (*avx_vec_concat<mode>_1): Remove.
11553 (avx_<castmode><avxsizesuffix>_<castmode>,
11554 avx512f_<castmode><avxsizesuffix>_256<castmode>): Change patterns to
11555 a VEC_CONCAT of the operand and UNSPEC_CAST.
11556 (avx512f_<castmode><avxsizesuffix>_<castmode>): Change pattern to
11557 a VEC_CONCAT of VEC_CONCAT of the operand and UNSPEC_CAST with
11558 UNSPEC_CAST.
11559
11560 PR target/93611
11561 * config/i386/i386.c (ix86_lea_outperforms): Make sure to clear
11562 recog_data.insn if distance_non_agu_define changed it.
11563
11564 2020-02-06 Michael Meissner <meissner@linux.ibm.com>
11565
11566 PR target/93569
11567 * config/rs6000/rs6000.c (reg_to_non_prefixed): Before ISA 3.0
11568 we only had X-FORM (reg+reg) addressing for vectors. Also before
11569 ISA 3.0, we only had X-FORM addressing for scalars in the
11570 traditional Altivec registers.
11571
11572 2020-02-06 <zhongyunde@huawei.com>
11573 Vladimir Makarov <vmakarov@redhat.com>
11574
11575 PR rtl-optimization/93561
11576 * lra-assigns.c (spill_for): Check that tested hard regno is not out of
11577 hard register range.
11578
11579 2020-02-06 Richard Sandiford <richard.sandiford@arm.com>
11580
11581 * config/aarch64/aarch64.md (aarch64_movk<mode>): Add a type
11582 attribute.
11583
11584 2020-02-06 Segher Boessenkool <segher@kernel.crashing.org>
11585
11586 * config/rs6000/rs6000.c (rs6000_emit_set_long_const): Handle the case
11587 where the low and the high 32 bits are equal to each other specially,
11588 with an rldimi instruction.
11589
11590 2020-02-06 Mihail Ionescu <mihail.ionescu@arm.com>
11591
11592 * config/arm/arm-cpus.in: Set profile M for armv8.1-m.main.
11593
11594 2020-02-06 Mihail Ionescu <mihail.ionescu@arm.com>
11595
11596 * config/arm/arm-tables.opt: Regenerate.
11597
11598 2020-02-06 Richard Sandiford <richard.sandiford@arm.com>
11599
11600 PR target/87763
11601 * config/aarch64/aarch64-protos.h (aarch64_movk_shift): Declare.
11602 * config/aarch64/aarch64.c (aarch64_movk_shift): New function.
11603 * config/aarch64/aarch64.md (aarch64_movk<mode>): New pattern.
11604
11605 2020-02-06 Richard Sandiford <richard.sandiford@arm.com>
11606
11607 PR rtl-optimization/87763
11608 * config/aarch64/aarch64.md (*ashiftsi_extvdi_bfiz): New pattern.
11609
11610 2020-02-06 Delia Burduv <delia.burduv@arm.com>
11611
11612 * config/aarch64/aarch64-simd-builtins.def
11613 (bfmlaq): New built-in function.
11614 (bfmlalb): New built-in function.
11615 (bfmlalt): New built-in function.
11616 (bfmlalb_lane): New built-in function.
11617 (bfmlalt_lane): New built-in function.
11618 * config/aarch64/aarch64-simd.md
11619 (aarch64_bfmmlaqv4sf): New pattern.
11620 (aarch64_bfmlal<bt>v4sf): New pattern.
11621 (aarch64_bfmlal<bt>_lane<q>v4sf): New pattern.
11622 * config/aarch64/arm_neon.h (vbfmmlaq_f32): New intrinsic.
11623 (vbfmlalbq_f32): New intrinsic.
11624 (vbfmlaltq_f32): New intrinsic.
11625 (vbfmlalbq_lane_f32): New intrinsic.
11626 (vbfmlaltq_lane_f32): New intrinsic.
11627 (vbfmlalbq_laneq_f32): New intrinsic.
11628 (vbfmlaltq_laneq_f32): New intrinsic.
11629 * config/aarch64/iterators.md (BF_MLA): New int iterator.
11630 (bt): New int attribute.
11631
11632 2020-02-06 Uroš Bizjak <ubizjak@gmail.com>
11633
11634 * config/i386/i386.md (*pushtf): Emit "#" instead of
11635 calling gcc_unreachable in insn output.
11636 (*pushxf): Ditto.
11637 (*pushdf): Ditto.
11638 (*pushsf_rex64): Ditto for alternatives other than 1.
11639 (*pushsf): Ditto for alternatives other than 1.
11640
11641 2020-02-06 Martin Liska <mliska@suse.cz>
11642
11643 PR gcov-profile/91971
11644 PR gcov-profile/93466
11645 * coverage.c (coverage_init): Revert mangling of
11646 path into filename. It can lead to huge filename length.
11647 Creation of subfolders seem more natural.
11648
11649 2020-02-06 Stam Markianos-Wright <stam.markianos-wright@arm.com>
11650
11651 PR target/93300
11652 * config/arm/arm.c (arm_block_arith_comp_libfuncs_for_mode): New.
11653 (arm_init_libfuncs): Add BFmode support to block spurious BF libfuncs.
11654 Use arm_block_arith_comp_libfuncs_for_mode for HFmode.
11655
11656 2020-02-06 Jakub Jelinek <jakub@redhat.com>
11657
11658 PR target/93594
11659 * config/i386/predicates.md (avx_identity_operand): New predicate.
11660 * config/i386/sse.md (*avx_vec_concat<mode>_1): New
11661 define_insn_and_split.
11662
11663 PR libgomp/93515
11664 * omp-low.c (use_pointer_for_field): For nested constructs, also
11665 look for map clauses on target construct.
11666 (scan_omp_1_stmt) <case GIMPLE_OMP_TARGET>: Bump temporarily
11667 taskreg_nesting_level.
11668
11669 PR libgomp/93515
11670 * gimplify.c (gimplify_scan_omp_clauses) <do_notice>: If adding
11671 shared clause, call omp_notice_variable on outer context if any.
11672
11673 2020-02-05 Jason Merrill <jason@redhat.com>
11674
11675 PR c++/92003
11676 * symtab.c (symtab_node::nonzero_address): A DECL_COMDAT decl has
11677 non-zero address even if weak and not yet defined.
11678
11679 2020-02-05 Martin Sebor <msebor@redhat.com>
11680
11681 PR tree-optimization/92765
11682 * gimple-fold.c (get_range_strlen_tree): Handle MEM_REF and PARM_DECL.
11683 * tree-ssa-strlen.c (compute_string_length): Remove.
11684 (determine_min_objsize): Remove.
11685 (get_len_or_size): Add an argument. Call get_range_strlen_dynamic.
11686 Avoid using type size as the upper bound on string length.
11687 (handle_builtin_string_cmp): Add an argument. Adjust.
11688 (strlen_check_and_optimize_call): Pass additional argument to
11689 handle_builtin_string_cmp.
11690
11691 2020-02-05 Uroš Bizjak <ubizjak@gmail.com>
11692
11693 * config/i386/i386.md (*pushdi2_rex64 peephole2): Remove.
11694 (*pushdi2_rex64 peephole2): Unconditionally split after
11695 epilogue_completed.
11696 (*ashl<mode>3_doubleword): Ditto.
11697 (*<shift_insn><mode>3_doubleword): Ditto.
11698
11699 2020-02-05 Michael Meissner <meissner@linux.ibm.com>
11700
11701 PR target/93568
11702 * config/rs6000/rs6000.c (get_vector_offset): Fix
11703
11704 2020-02-05 Andrew Stubbs <ams@codesourcery.com>
11705
11706 * config/gcn/t-gcn-hsa (MULTILIB_OPTIONS): Use / not space.
11707
11708 2020-02-05 David Malcolm <dmalcolm@redhat.com>
11709
11710 * doc/analyzer.texi
11711 (Special Functions for Debugging the Analyzer): Update description
11712 of __analyzer_dump_exploded_nodes.
11713
11714 2020-02-05 Jakub Jelinek <jakub@redhat.com>
11715
11716 PR target/92190
11717 * config/i386/i386-features.c (ix86_add_reg_usage_to_vzeroupper): Only
11718 include sets and not clobbers in the vzeroupper pattern.
11719 * config/i386/sse.md (*avx_vzeroupper): Require in insn condition that
11720 the parallel has 17 (64-bit) or 9 (32-bit) elts.
11721 (*avx_vzeroupper_1): New define_insn_and_split.
11722
11723 PR target/92190
11724 * recog.c (pass_split_after_reload::gate): For STACK_REGS targets,
11725 don't run when !optimize.
11726 (pass_split_before_regstack::gate): For STACK_REGS targets, run even
11727 when !optimize.
11728
11729 2020-02-05 Richard Biener <rguenther@suse.de>
11730
11731 PR middle-end/90648
11732 * genmatch.c (dt_node::gen_kids_1): Emit number of argument
11733 checks before matching calls.
11734
11735 2020-02-05 Jakub Jelinek <jakub@redhat.com>
11736
11737 * tree-ssa-alias.c (aliasing_matching_component_refs_p): Fix up
11738 function comment typo.
11739
11740 PR middle-end/93555
11741 * omp-simd-clone.c (expand_simd_clones): If simd_clone_mangle or
11742 simd_clone_create failed when i == 0, adjust clone->nargs by
11743 clone->inbranch.
11744
11745 2020-02-05 Martin Liska <mliska@suse.cz>
11746
11747 PR c++/92717
11748 * doc/invoke.texi: Document that one should
11749 not combine ASLR and -fpch.
11750
11751 2020-02-04 Richard Biener <rguenther@suse.de>
11752
11753 PR tree-optimization/93538
11754 * match.pd (addr EQ/NE ptr): Amend to handle &ptr->x EQ/NE ptr.
11755
11756 2020-02-04 Richard Biener <rguenther@suse.de>
11757
11758 PR tree-optimization/91123
11759 * tree-ssa-sccvn.c (vn_walk_cb_data::finish): New method.
11760 (vn_walk_cb_data::last_vuse): New member.
11761 (vn_walk_cb_data::saved_operands): Likewsie.
11762 (vn_walk_cb_data::~vn_walk_cb_data): Release saved_operands.
11763 (vn_walk_cb_data::push_partial_def): Use finish.
11764 (vn_reference_lookup_2): Update last_vuse and use finish if
11765 we've saved operands.
11766 (vn_reference_lookup_3): Use finish and update calls to
11767 push_partial_defs everywhere. When translating through
11768 memcpy or aggregate copies save off operands and alias-set.
11769 (eliminate_dom_walker::eliminate_stmt): Restore VN_WALKREWRITE
11770 operation for redundant store removal.
11771
11772 2020-02-04 Richard Biener <rguenther@suse.de>
11773
11774 PR tree-optimization/92819
11775 * tree-ssa-forwprop.c (simplify_vector_constructor): Avoid
11776 generating more stmts than before.
11777
11778 2020-02-04 Martin Liska <mliska@suse.cz>
11779
11780 * config/arm/arm.c (arm_gen_far_branch): Move the function
11781 outside of selftests.
11782
11783 2020-02-03 Michael Meissner <meissner@linux.ibm.com>
11784
11785 * config/rs6000/rs6000.c (adjust_vec_address_pcrel): New helper
11786 function to adjust PC-relative vector addresses.
11787 (rs6000_adjust_vec_address): Call adjust_vec_address_pcrel to
11788 handle vectors with PC-relative addresses.
11789
11790 2020-02-03 Michael Meissner <meissner@linux.ibm.com>
11791
11792 * config/rs6000/rs6000.c (reg_to_non_prefixed): Add forward
11793 reference.
11794 (hard_reg_and_mode_to_addr_mask): Delete.
11795 (rs6000_adjust_vec_address): If the original vector address
11796 was REG+REG or REG+OFFSET and the element is not zero, do the add
11797 of the elements in the original address before adding the offset
11798 for the vector element. Use address_to_insn_form to validate the
11799 address using the register being loaded, rather than guessing
11800 whether the address is a DS-FORM or DQ-FORM address.
11801
11802 2020-02-03 Michael Meissner <meissner@linux.ibm.com>
11803
11804 * config/rs6000/rs6000.c (get_vector_offset): New helper function
11805 to calculate the offset in memory from the start of a vector of a
11806 particular element. Add code to keep the element number in
11807 bounds if the element number is variable.
11808 (rs6000_adjust_vec_address): Move calculation of offset of the
11809 vector element to get_vector_offset.
11810 (rs6000_split_vec_extract_var): Do not do the initial AND of
11811 element here, move the code to get_vector_offset.
11812
11813 2020-02-03 Michael Meissner <meissner@linux.ibm.com>
11814
11815 * config/rs6000/rs6000.c (rs6000_adjust_vec_address): Add some
11816 gcc_asserts.
11817
11818 2020-02-03 Segher Boessenkool <segher@kernel.crashing.org>
11819
11820 * config/rs6000/constraints.md: Improve documentation.
11821
11822 2020-02-03 Richard Earnshaw <rearnsha@arm.com>
11823
11824 PR target/93548
11825 * config/arm/t-arm: ($(srcdir)/config/arm/arm-tune.md)
11826 ($(srcdir)/config/arm/arm-tables.opt): Use move-if-change.
11827
11828 2020-02-03 Andrew Stubbs <ams@codesourcery.com>
11829
11830 * config.gcc: Remove "carrizo" support.
11831 * config/gcn/gcn-opts.h (processor_type): Likewise.
11832 * config/gcn/gcn.c (gcn_omp_device_kind_arch_isa): Likewise.
11833 * config/gcn/gcn.opt (gpu_type): Likewise.
11834 * config/gcn/t-omp-device: Likewise.
11835
11836 2020-02-03 Stam Markianos-Wright <stam.markianos-wright@arm.com>
11837
11838 PR target/91816
11839 * config/arm/arm-protos.h: New function arm_gen_far_branch prototype.
11840 * config/arm/arm.c (arm_gen_far_branch): New function
11841 arm_gen_far_branch.
11842 * config/arm/arm.md: Update b<cond> for Thumb2 range checks.
11843
11844 2020-02-03 Julian Brown <julian@codesourcery.com>
11845 Tobias Burnus <tobias@codesourcery.com>
11846
11847 * doc/invoke.texi: Update mention of OpenACC version to 2.6.
11848
11849 2020-02-03 Jakub Jelinek <jakub@redhat.com>
11850
11851 PR target/93533
11852 * config/s390/s390.md (popcounthi2_z196): Fix up expander to emit
11853 valid RTL to sum up the lowest and second lowest bytes of the popcnt
11854 result.
11855
11856 2020-02-02 Vladimir Makarov <vmakarov@redhat.com>
11857
11858 PR rtl-optimization/91333
11859 * ira-color.c (struct allocno_color_data): Add member
11860 hard_reg_prefs.
11861 (init_allocno_threads): Set the member up.
11862 (bucket_allocno_compare_func): Add compare hard reg
11863 prefs.
11864
11865 2020-01-31 Sandra Loosemore <sandra@codesourcery.com>
11866
11867 nios2: Support for GOT-relative DW_EH_PE_datarel encoding.
11868
11869 * configure.ac [nios2-*-*]: Check HAVE_AS_NIOS2_GOTOFF_RELOCATION.
11870 * config.in: Regenerated.
11871 * configure: Regenerated.
11872 * config/nios2/nios2.h (ASM_PREFERRED_EH_DATA_FORMAT): Fix handling
11873 for PIC when HAVE_AS_NIOS2_GOTOFF_RELOCATION.
11874 (ASM_MAYBE_OUTPUT_ENCODED_ADDR_RTX): New.
11875
11876 2020-02-01 Andrew Burgess <andrew.burgess@embecosm.com>
11877
11878 * configure: Regenerate.
11879
11880 2020-01-31 Vladimir Makarov <vmakarov@redhat.com>
11881
11882 PR rtl-optimization/91333
11883 * ira-color.c (bucket_allocno_compare_func): Move conflict hard
11884 reg preferences comparison up.
11885
11886 2020-01-31 Richard Sandiford <richard.sandiford@arm.com>
11887
11888 * config/aarch64/aarch64.h (TARGET_SVE_BF16): New macro.
11889 * config/aarch64/aarch64-sve-builtins-sve2.h (svcvtnt): Move to
11890 aarch64-sve-builtins-base.h.
11891 * config/aarch64/aarch64-sve-builtins-sve2.cc (svcvtnt): Move to
11892 aarch64-sve-builtins-base.cc.
11893 * config/aarch64/aarch64-sve-builtins-base.h (svbfdot, svbfdot_lane)
11894 (svbfmlalb, svbfmlalb_lane, svbfmlalt, svbfmlalt_lane, svbfmmla)
11895 (svcvtnt): Declare.
11896 * config/aarch64/aarch64-sve-builtins-base.cc (svbfdot, svbfdot_lane)
11897 (svbfmlalb, svbfmlalb_lane, svbfmlalt, svbfmlalt_lane, svbfmmla)
11898 (svcvtnt): New functions.
11899 * config/aarch64/aarch64-sve-builtins-base.def (svbfdot, svbfdot_lane)
11900 (svbfmlalb, svbfmlalb_lane, svbfmlalt, svbfmlalt_lane, svbfmmla)
11901 (svcvtnt): New functions.
11902 (svcvt): Add a form that converts f32 to bf16.
11903 * config/aarch64/aarch64-sve-builtins-shapes.h (ternary_bfloat)
11904 (ternary_bfloat_lane, ternary_bfloat_lanex2, ternary_bfloat_opt_n):
11905 Declare.
11906 * config/aarch64/aarch64-sve-builtins-shapes.cc (parse_element_type):
11907 Treat B as bfloat16_t.
11908 (ternary_bfloat_lane_base): New class.
11909 (ternary_bfloat_def): Likewise.
11910 (ternary_bfloat): New shape.
11911 (ternary_bfloat_lane_def): New class.
11912 (ternary_bfloat_lane): New shape.
11913 (ternary_bfloat_lanex2_def): New class.
11914 (ternary_bfloat_lanex2): New shape.
11915 (ternary_bfloat_opt_n_def): New class.
11916 (ternary_bfloat_opt_n): New shape.
11917 * config/aarch64/aarch64-sve-builtins.cc (TYPES_cvt_bfloat): New macro.
11918 * config/aarch64/aarch64-sve.md (@aarch64_sve_<sve_fp_op>vnx4sf)
11919 (@aarch64_sve_<sve_fp_op>_lanevnx4sf): New patterns.
11920 (@aarch64_sve_<optab>_trunc<VNx4SF_ONLY:mode><VNx8BF_ONLY:mode>)
11921 (@cond_<optab>_trunc<VNx4SF_ONLY:mode><VNx8BF_ONLY:mode>): Likewise.
11922 (*cond_<optab>_trunc<VNx4SF_ONLY:mode><VNx8BF_ONLY:mode>): Likewise.
11923 (@aarch64_sve_cvtnt<VNx8BF_ONLY:mode>): Likewise.
11924 * config/aarch64/aarch64-sve2.md (@aarch64_sve2_cvtnt<mode>): Key
11925 the pattern off the narrow mode instead of the wider one.
11926 * config/aarch64/iterators.md (VNx8BF_ONLY): New mode iterator.
11927 (UNSPEC_BFMLALB, UNSPEC_BFMLALT, UNSPEC_BFMMLA): New unspecs.
11928 (sve_fp_op): Handle them.
11929 (SVE_BFLOAT_TERNARY_LONG): New int itertor.
11930 (SVE_BFLOAT_TERNARY_LONG_LANE): Likewise.
11931
11932 2020-01-31 Richard Sandiford <richard.sandiford@arm.com>
11933
11934 * config/aarch64/arm_sve.h: Include arm_bf16.h.
11935 * config/aarch64/aarch64-modes.def (BF): Move definition before
11936 VECTOR_MODES. Remove separate VECTOR_MODES for V4BF and V8BF.
11937 (SVE_MODES): Handle BF modes.
11938 * config/aarch64/aarch64.c (aarch64_classify_vector_mode): Handle
11939 BF modes.
11940 (aarch64_full_sve_mode): Likewise.
11941 * config/aarch64/iterators.md (SVE_STRUCT): Add VNx16BF, VNx24BF
11942 and VNx32BF.
11943 (SVE_FULL, SVE_FULL_HSD, SVE_ALL): Add VNx8BF.
11944 (Vetype, Vesize, Vctype, VEL, Vel, VEL_INT, V128, v128, vwcore)
11945 (V_INT_EQUIV, v_int_equiv, V_FP_EQUIV, v_fp_equiv, vector_count)
11946 (insn_length, VSINGLE, vsingle, VPRED, vpred, VDOUBLE): Handle the
11947 new SVE BF modes.
11948 * config/aarch64/aarch64-sve-builtins.h (TYPE_bfloat): New
11949 type_class_index.
11950 * config/aarch64/aarch64-sve-builtins.cc (TYPES_all_arith): New macro.
11951 (TYPES_all_data): Add bf16.
11952 (TYPES_reinterpret1, TYPES_reinterpret): Likewise.
11953 (register_tuple_type): Increase buffer size.
11954 * config/aarch64/aarch64-sve-builtins.def (svbfloat16_t): New type.
11955 (bf16): New type suffix.
11956 * config/aarch64/aarch64-sve-builtins-base.def (svabd, svadd, svaddv)
11957 (svcmpeq, svcmpge, svcmpgt, svcmple, svcmplt, svcmpne, svmad, svmax)
11958 (svmaxv, svmin, svminv, svmla, svmls, svmsb, svmul, svsub, svsubr):
11959 Change type from all_data to all_arith.
11960 * config/aarch64/aarch64-sve-builtins-sve2.def (svaddp, svmaxp)
11961 (svminp): Likewise.
11962
11963 2020-01-31 Dennis Zhang <dennis.zhang@arm.com>
11964 Matthew Malcomson <matthew.malcomson@arm.com>
11965 Richard Sandiford <richard.sandiford@arm.com>
11966
11967 * doc/invoke.texi (f32mm): Document new AArch64 -march= extension.
11968 * config/aarch64/aarch64-c.c (aarch64_update_cpp_builtins): Define
11969 __ARM_FEATURE_SVE_MATMUL_INT8, __ARM_FEATURE_SVE_MATMUL_FP32 and
11970 __ARM_FEATURE_SVE_MATMUL_FP64 as appropriate. Don't define
11971 __ARM_FEATURE_MATMUL_FP64.
11972 * config/aarch64/aarch64-option-extensions.def (fp, simd, fp16)
11973 (sve): Add AARCH64_FL_F32MM to the list of extensions that should
11974 be disabled at the same time.
11975 (f32mm): New extension.
11976 * config/aarch64/aarch64.h (AARCH64_FL_F32MM): New macro.
11977 (AARCH64_FL_F64MM): Bump to the next bit up.
11978 (AARCH64_ISA_F32MM, TARGET_SVE_I8MM, TARGET_F32MM, TARGET_SVE_F32MM)
11979 (TARGET_SVE_F64MM): New macros.
11980 * config/aarch64/iterators.md (SVE_MATMULF): New mode iterator.
11981 (UNSPEC_FMMLA, UNSPEC_SMATMUL, UNSPEC_UMATMUL, UNSPEC_USMATMUL)
11982 (UNSPEC_TRN1Q, UNSPEC_TRN2Q, UNSPEC_UZP1Q, UNSPEC_UZP2Q, UNSPEC_ZIP1Q)
11983 (UNSPEC_ZIP2Q): New unspeccs.
11984 (DOTPROD_US_ONLY, PERMUTEQ, MATMUL, FMMLA): New int iterators.
11985 (optab, sur, perm_insn): Handle the new unspecs.
11986 (sve_fp_op): Handle UNSPEC_FMMLA. Resort.
11987 * config/aarch64/aarch64-sve.md (@aarch64_sve_ld1ro<mode>): Use
11988 TARGET_SVE_F64MM instead of separate tests.
11989 (@aarch64_<DOTPROD_US_ONLY:sur>dot_prod<vsi2qi>): New pattern.
11990 (@aarch64_<DOTPROD_US_ONLY:sur>dot_prod_lane<vsi2qi>): Likewise.
11991 (@aarch64_sve_add_<MATMUL:optab><vsi2qi>): Likewise.
11992 (@aarch64_sve_<FMMLA:sve_fp_op><mode>): Likewise.
11993 (@aarch64_sve_<PERMUTEQ:optab><mode>): Likewise.
11994 * config/aarch64/aarch64-sve-builtins.cc (TYPES_s_float): New macro.
11995 (TYPES_s_float_hsd_integer, TYPES_s_float_sd_integer): Use it.
11996 (TYPES_s_signed): New macro.
11997 (TYPES_s_integer): Use it.
11998 (TYPES_d_float): New macro.
11999 (TYPES_d_data): Use it.
12000 * config/aarch64/aarch64-sve-builtins-shapes.h (mmla): Declare.
12001 (ternary_intq_uintq_lane, ternary_intq_uintq_opt_n, ternary_uintq_intq)
12002 (ternary_uintq_intq_lane, ternary_uintq_intq_opt_n): Likewise.
12003 * config/aarch64/aarch64-sve-builtins-shapes.cc (mmla_def): New class.
12004 (svmmla): New shape.
12005 (ternary_resize2_opt_n_base): Add TYPE_CLASS2 and TYPE_CLASS3
12006 template parameters.
12007 (ternary_resize2_lane_base): Likewise.
12008 (ternary_resize2_base): New class.
12009 (ternary_qq_lane_base): Likewise.
12010 (ternary_intq_uintq_lane_def): Likewise.
12011 (ternary_intq_uintq_lane): New shape.
12012 (ternary_intq_uintq_opt_n_def): New class
12013 (ternary_intq_uintq_opt_n): New shape.
12014 (ternary_qq_lane_def): Inherit from ternary_qq_lane_base.
12015 (ternary_uintq_intq_def): New class.
12016 (ternary_uintq_intq): New shape.
12017 (ternary_uintq_intq_lane_def): New class.
12018 (ternary_uintq_intq_lane): New shape.
12019 (ternary_uintq_intq_opt_n_def): New class.
12020 (ternary_uintq_intq_opt_n): New shape.
12021 * config/aarch64/aarch64-sve-builtins-base.h (svmmla, svsudot)
12022 (svsudot_lane, svtrn1q, svtrn2q, svusdot, svusdot_lane, svusmmla)
12023 (svuzp1q, svuzp2q, svzip1q, svzip2q): Declare.
12024 * config/aarch64/aarch64-sve-builtins-base.cc (svdot_lane_impl):
12025 Generalize to...
12026 (svdotprod_lane_impl): ...this new class.
12027 (svmmla_impl, svusdot_impl): New classes.
12028 (svdot_lane): Update to use svdotprod_lane_impl.
12029 (svmmla, svsudot, svsudot_lane, svtrn1q, svtrn2q, svusdot)
12030 (svusdot_lane, svusmmla, svuzp1q, svuzp2q, svzip1q, svzip2q): New
12031 functions.
12032 * config/aarch64/aarch64-sve-builtins-base.def (svmmla): New base
12033 function, with no types defined.
12034 (svmmla, svusmmla, svsudot, svsudot_lane, svusdot, svusdot_lane): New
12035 AARCH64_FL_I8MM functions.
12036 (svmmla): New AARCH64_FL_F32MM function.
12037 (svld1ro): Depend only on AARCH64_FL_F64MM, not on AARCH64_FL_V8_6.
12038 (svmmla, svtrn1q, svtrn2q, svuz1q, svuz2q, svzip1q, svzip2q): New
12039 AARCH64_FL_F64MM function.
12040 (REQUIRED_EXTENSIONS):
12041
12042 2020-01-31 Andrew Stubbs <ams@codesourcery.com>
12043
12044 * config/gcn/gcn-valu.md (addv64di3_exec): Allow one '0' in each
12045 alternative only.
12046
12047 2020-01-31 Uroš Bizjak <ubizjak@gmail.com>
12048
12049 * config/i386/i386.md (*movoi_internal_avx): Do not check for
12050 TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL. Remove MODE_V8SF handling.
12051 (*movti_internal): Do not check for
12052 TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL.
12053 (*movtf_internal): Move check for TARGET_SSE2 and size optimization
12054 just after check for TARGET_AVX.
12055 (*movdf_internal): Ditto.
12056 * config/i386/mmx.md (*mov<mode>_internal): Do not check for
12057 TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL.
12058 * config/i386/sse.md (mov<mode>_internal): Only check
12059 TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL with V2DFmode. Move check
12060 for TARGET_SSE2 and size optimization just after check for TARGET_AVX.
12061 (<sse>_andnot<mode>3<mask_name>): Move check for
12062 TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL after check for TARGET_AVX.
12063 (<code><mode>3<mask_name>): Ditto.
12064 (*andnot<mode>3): Ditto.
12065 (*andnottf3): Ditto.
12066 (*<code><mode>3): Ditto.
12067 (*<code>tf3): Ditto.
12068 (*andnot<VI:mode>3): Remove
12069 TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL handling.
12070 (<mask_codefor><code><VI48_AVX_AVX512F:mode>3<mask_name>): Ditto.
12071 (*<code><VI12_AVX_AVX512F:mode>3): Ditto.
12072 (sse4_1_blendv<ssemodesuffix>): Ditto.
12073 * config/i386/x86-tune.def (X86_TUNE_SSE_UNALIGNED_STORE_OPTIMAL):
12074 Explain that tune applies to 128bit instructions only.
12075
12076 2020-01-31 Kwok Cheung Yeung <kcy@codesourcery.com>
12077
12078 * config/gcn/mkoffload.c (process_asm): Add sgpr_count and vgpr_count
12079 to definition of hsa_kernel_description. Parse assembly to find SGPR
12080 and VGPR count of kernel and store in hsa_kernel_description.
12081
12082 2020-01-31 Tamar Christina <tamar.christina@arm.com>
12083
12084 PR rtl-optimization/91838
12085 * simplify-rtx.c (simplify_binary_operation_1): Update LSHIFTRT case
12086 to truncate if allowed or reject combination.
12087
12088 2020-01-31 Andrew Stubbs <ams@codesourcery.com>
12089
12090 * tree-ssa-loop-ivopts.c (get_iv): Use sizetype for zero-step.
12091 (find_inv_vars_cb): Likewise.
12092
12093 2020-01-31 David Malcolm <dmalcolm@redhat.com>
12094
12095 * calls.c (special_function_p): Split out the check for DECL_NAME
12096 being non-NULL and fndecl being extern at file scope into a
12097 new maybe_special_function_p and call it. Drop check for fndecl
12098 being non-NULL that was after a usage of DECL_NAME (fndecl).
12099 * tree.h (maybe_special_function_p): New inline function.
12100
12101 2020-01-30 Andrew Stubbs <ams@codesourcery.com>
12102
12103 * config/gcn/gcn-valu.md (gather<mode>_exec): Move contents ...
12104 (mask_gather_load<mode>): ... here, and zero-initialize the
12105 destination.
12106 (maskload<mode>di): Zero-initialize the destination.
12107 * config/gcn/gcn.c:
12108
12109 2020-01-30 David Malcolm <dmalcolm@redhat.com>
12110
12111 PR analyzer/93356
12112 * doc/analyzer.texi (Limitations): Note that constraints on
12113 floating-point values are currently ignored.
12114
12115 2020-01-30 Jakub Jelinek <jakub@redhat.com>
12116
12117 PR lto/93384
12118 * symtab.c (symtab_node::noninterposable_alias): If localalias
12119 already exists, but is not usable, append numbers after it until
12120 a unique name is found. Formatting fix.
12121
12122 PR middle-end/93505
12123 * combine.c (simplify_comparison) <case ROTATE>: Punt on out of range
12124 rotate counts.
12125
12126 2020-01-30 Andrew Stubbs <ams@codesourcery.com>
12127
12128 * config/gcn/gcn.c (print_operand): Handle LTGT.
12129 * config/gcn/predicates.md (gcn_fp_compare_operator): Allow ltgt.
12130
12131 2020-01-30 Richard Biener <rguenther@suse.de>
12132
12133 * tree-pretty-print.c (dump_generic_node): Wrap VECTOR_CST
12134 and CONSTRUCTOR in _Literal (type) with TDF_GIMPLE.
12135
12136 2020-01-30 John David Anglin <danglin@gcc.gnu.org>
12137
12138 * config/pa/pa.c (pa_elf_select_rtx_section): Place function pointers
12139 without a DECL in .data.rel.ro.local.
12140
12141 2020-01-30 Jakub Jelinek <jakub@redhat.com>
12142
12143 PR target/93494
12144 * config/arm/arm.md (uaddvdi4): Actually emit what gen_uaddvsi4
12145 returned.
12146
12147 PR target/91824
12148 * config/i386/sse.md
12149 (*<sse>_movmsk<ssemodesuffix><avxsizesuffix>_zext): Renamed to ...
12150 (*<sse>_movmsk<ssemodesuffix><avxsizesuffix>_<u>ext): ... this. Use
12151 any_extend code iterator instead of always zero_extend.
12152 (*<sse>_movmsk<ssemodesuffix><avxsizesuffix>_zext_lt): Renamed to ...
12153 (*<sse>_movmsk<ssemodesuffix><avxsizesuffix>_<u>ext_lt): ... this.
12154 Use any_extend code iterator instead of always zero_extend.
12155 (*<sse>_movmsk<ssemodesuffix><avxsizesuffix>_zext_shift): Renamed to ...
12156 (*<sse>_movmsk<ssemodesuffix><avxsizesuffix>_<u>ext_shift): ... this.
12157 Use any_extend code iterator instead of always zero_extend.
12158 (*sse2_pmovmskb_ext): New define_insn.
12159 (*sse2_pmovmskb_ext_lt): New define_insn_and_split.
12160
12161 PR target/91824
12162 * config/i386/i386.md (*popcountsi2_zext): New define_insn_and_split.
12163 (*popcountsi2_zext_falsedep): New define_insn.
12164
12165 2020-01-30 Dragan Mladjenovic <dmladjenovic@wavecomp.com>
12166
12167 * config.in: Regenerated.
12168 * configure: Regenerated.
12169
12170 2020-01-29 Tobias Burnus <tobias@codesourcery.com>
12171
12172 PR bootstrap/93409
12173 * config/gcn/gcn-hsa.h (ASM_SPEC): Add -mattr=-code-object-v3 as
12174 LLVM's assembler changed the default in version 9.
12175
12176 2020-01-24 Jeff Law <law@redhat.com>
12177
12178 PR tree-optimization/89689
12179 * builtins.def (BUILT_IN_OBJECT_SIZE): Make it const rather than pure.
12180
12181 2020-01-29 Richard Sandiford <richard.sandiford@arm.com>
12182
12183 Revert:
12184
12185 2020-01-28 Richard Sandiford <richard.sandiford@arm.com>
12186
12187 PR rtl-optimization/87763
12188 * simplify-rtx.c (simplify_truncation): Extend sign/zero_extract
12189 simplification to handle subregs as well as bare regs.
12190 * config/i386/i386.md (*testqi_ext_3): Match QI extracts too.
12191
12192 2020-01-29 Joel Hutton <Joel.Hutton@arm.com>
12193
12194 PR target/93221
12195 * ira.c (ira): Revert use of simplified LRA algorithm.
12196
12197 2020-01-29 Martin Jambor <mjambor@suse.cz>
12198
12199 PR tree-optimization/92706
12200 * tree-sra.c (struct access): Fields first_link, last_link,
12201 next_queued and grp_queued renamed to first_rhs_link, last_rhs_link,
12202 next_rhs_queued and grp_rhs_queued respectively, new fields
12203 first_lhs_link, last_lhs_link, next_lhs_queued and grp_lhs_queued.
12204 (struct assign_link): Field next renamed to next_rhs, new field
12205 next_lhs. Updated comment.
12206 (work_queue_head): Renamed to rhs_work_queue_head.
12207 (lhs_work_queue_head): New variable.
12208 (add_link_to_lhs): New function.
12209 (relink_to_new_repr): Also relink LHS lists.
12210 (add_access_to_work_queue): Renamed to add_access_to_rhs_work_queue.
12211 (add_access_to_lhs_work_queue): New function.
12212 (pop_access_from_work_queue): Renamed to
12213 pop_access_from_rhs_work_queue.
12214 (pop_access_from_lhs_work_queue): New function.
12215 (build_accesses_from_assign): Also add links to LHS lists and to LHS
12216 work_queue.
12217 (child_would_conflict_in_lacc): Renamed to
12218 child_would_conflict_in_acc. Adjusted parameter names.
12219 (create_artificial_child_access): New parameter set_grp_read, use it.
12220 (subtree_mark_written_and_enqueue): Renamed to
12221 subtree_mark_written_and_rhs_enqueue.
12222 (propagate_subaccesses_across_link): Renamed to
12223 propagate_subaccesses_from_rhs.
12224 (propagate_subaccesses_from_lhs): New function.
12225 (propagate_all_subaccesses): Also propagate subaccesses from LHSs to
12226 RHSs.
12227
12228 2020-01-29 Martin Jambor <mjambor@suse.cz>
12229
12230 PR tree-optimization/92706
12231 * tree-sra.c (struct access): Adjust comment of
12232 grp_total_scalarization.
12233 (find_access_in_subtree): Look for single children spanning an entire
12234 access.
12235 (scalarizable_type_p): Allow register accesses, adjust callers.
12236 (completely_scalarize): Remove function.
12237 (scalarize_elem): Likewise.
12238 (create_total_scalarization_access): Likewise.
12239 (sort_and_splice_var_accesses): Do not track total scalarization
12240 flags.
12241 (analyze_access_subtree): New parameter totally, adjust to new meaning
12242 of grp_total_scalarization.
12243 (analyze_access_trees): Pass new parameter to analyze_access_subtree.
12244 (can_totally_scalarize_forest_p): New function.
12245 (create_total_scalarization_access): Likewise.
12246 (create_total_access_and_reshape): Likewise.
12247 (total_should_skip_creating_access): Likewise.
12248 (totally_scalarize_subtree): Likewise.
12249 (analyze_all_variable_accesses): Perform total scalarization after
12250 subaccess propagation using the new functions above.
12251 (initialize_constant_pool_replacements): Output initializers by
12252 traversing the access tree.
12253
12254 2020-01-29 Martin Jambor <mjambor@suse.cz>
12255
12256 * tree-sra.c (verify_sra_access_forest): New function.
12257 (verify_all_sra_access_forests): Likewise.
12258 (create_artificial_child_access): Set parent.
12259 (analyze_all_variable_accesses): Call the verifier.
12260
12261 2020-01-28 Jan Hubicka <hubicka@ucw.cz>
12262
12263 * cgraph.c (cgraph_edge::resolve_speculation): Only lookup direct edge
12264 if called on indirect edge.
12265 (cgraph_edge::redirect_call_stmt_to_callee): Lookup indirect edge of
12266 speculative call if needed.
12267
12268 2020-01-29 Richard Biener <rguenther@suse.de>
12269
12270 PR tree-optimization/93428
12271 * tree-vect-slp.c (vect_build_slp_tree_2): Compute the load
12272 permutation when the load node is created.
12273 (vect_analyze_slp_instance): Re-use it here.
12274
12275 2020-01-28 Jan Hubicka <hubicka@ucw.cz>
12276
12277 * ipa-prop.c (update_indirect_edges_after_inlining): Fix warning.
12278
12279 2020-01-28 Vladimir Makarov <vmakarov@redhat.com>
12280
12281 PR rtl-optimization/93272
12282 * ira-lives.c (process_out_of_region_eh_regs): New function.
12283 (process_bb_node_lives): Call it.
12284
12285 2020-01-28 Jan Hubicka <hubicka@ucw.cz>
12286
12287 * coverage.c (read_counts_file): Make error message lowercase.
12288
12289 2020-01-28 Jan Hubicka <hubicka@ucw.cz>
12290
12291 * profile-count.c (profile_quality_display_names): Fix ordering.
12292
12293 2020-01-28 Jan Hubicka <hubicka@ucw.cz>
12294
12295 PR lto/93318
12296 * cgraph.c (cgraph_add_edge_to_call_site_hash): Update call site
12297 hash only when edge is first within the sequence.
12298 (cgraph_edge::set_call_stmt): Update handling of speculative calls.
12299 (symbol_table::create_edge): Do not set target_prob.
12300 (cgraph_edge::remove_caller): Watch for speculative calls when updating
12301 the call site hash.
12302 (cgraph_edge::make_speculative): Drop target_prob parameter.
12303 (cgraph_edge::speculative_call_info): Remove.
12304 (cgraph_edge::first_speculative_call_target): New member function.
12305 (update_call_stmt_hash_for_removing_direct_edge): New function.
12306 (cgraph_edge::resolve_speculation): Rewrite to new API.
12307 (cgraph_edge::speculative_call_for_target): New member function.
12308 (cgraph_edge::make_direct): Rewrite to new API; fix handling of
12309 multiple speculation targets.
12310 (cgraph_edge::redirect_call_stmt_to_callee): Likewise; fix updating
12311 of profile.
12312 (verify_speculative_call): Verify that targets form an interval.
12313 * cgraph.h (cgraph_edge::speculative_call_info): Remove.
12314 (cgraph_edge::first_speculative_call_target): New member function.
12315 (cgraph_edge::next_speculative_call_target): New member function.
12316 (cgraph_edge::speculative_call_target_ref): New member function.
12317 (cgraph_edge;:speculative_call_indirect_edge): New member funtion.
12318 (cgraph_edge): Remove target_prob.
12319 * cgraphclones.c (cgraph_node::set_call_stmt_including_clones):
12320 Fix handling of speculative calls.
12321 * ipa-devirt.c (ipa_devirt): Fix handling of speculative cals.
12322 * ipa-fnsummary.c (analyze_function_body): Likewise.
12323 * ipa-inline.c (speculation_useful_p): Use new speculative call API.
12324 * ipa-profile.c (dump_histogram): Fix formating.
12325 (ipa_profile_generate_summary): Watch for overflows.
12326 (ipa_profile): Do not require probablity to be 1/2; update to new API.
12327 * ipa-prop.c (ipa_make_edge_direct_to_target): Update to new API.
12328 (update_indirect_edges_after_inlining): Update to new API.
12329 * ipa-utils.c (ipa_merge_profiles): Rewrite merging of speculative call
12330 profiles.
12331 * profile-count.h: (profile_probability::adjusted): New.
12332 * tree-inline.c (copy_bb): Update to new speculative call API; fix
12333 updating of profile.
12334 * value-prof.c (gimple_ic_transform): Rename to ...
12335 (dump_ic_profile): ... this one; update dumping.
12336 (stream_in_histogram_value): Fix formating.
12337 (gimple_value_profile_transformations): Update.
12338
12339 2020-01-28 H.J. Lu <hongjiu.lu@intel.com>
12340
12341 PR target/91461
12342 * config/i386/i386.md (*movoi_internal_avx): Remove
12343 TARGET_SSE_TYPELESS_STORES check.
12344 (*movti_internal): Prefer TARGET_AVX over
12345 TARGET_SSE_TYPELESS_STORES.
12346 (*movtf_internal): Likewise.
12347 * config/i386/sse.md (mov<mode>_internal): Prefer TARGET_AVX over
12348 TARGET_SSE_TYPELESS_STORES. Remove "<MODE_SIZE> == 16" check
12349 from TARGET_SSE_TYPELESS_STORES.
12350
12351 2020-01-28 David Malcolm <dmalcolm@redhat.com>
12352
12353 * diagnostic-core.h (warning_at): Rename overload to...
12354 (warning_meta): ...this.
12355 (emit_diagnostic_valist): Delete decl of overload taking
12356 diagnostic_metadata.
12357 * diagnostic.c (emit_diagnostic_valist): Likewise for defn.
12358 (warning_at): Rename overload taking diagnostic_metadata to...
12359 (warning_meta): ...this.
12360
12361 2020-01-28 Richard Biener <rguenther@suse.de>
12362
12363 PR tree-optimization/93439
12364 * tree-parloops.c (create_loop_fn): Move clique bookkeeping...
12365 * tree-cfg.c (move_sese_region_to_fn): ... here.
12366 (verify_types_in_gimple_reference): Verify used cliques are
12367 tracked.
12368
12369 2020-01-28 H.J. Lu <hongjiu.lu@intel.com>
12370
12371 PR target/91399
12372 * config/i386/i386-options.c (set_ix86_tune_features): Add an
12373 argument of a pointer to struct gcc_options and pass it to
12374 parse_mtune_ctrl_str.
12375 (ix86_function_specific_restore): Pass opts to
12376 set_ix86_tune_features.
12377 (ix86_option_override_internal): Likewise.
12378 (parse_mtune_ctrl_str): Add an argument of a pointer to struct
12379 gcc_options and use it for x_ix86_tune_ctrl_string.
12380
12381 2020-01-28 Richard Sandiford <richard.sandiford@arm.com>
12382
12383 PR rtl-optimization/87763
12384 * simplify-rtx.c (simplify_truncation): Extend sign/zero_extract
12385 simplification to handle subregs as well as bare regs.
12386 * config/i386/i386.md (*testqi_ext_3): Match QI extracts too.
12387
12388 2020-01-28 Richard Sandiford <richard.sandiford@arm.com>
12389
12390 * tree-vect-loop.c (vectorizable_reduction): Fail gracefully
12391 for reduction chains that (now) include a call.
12392
12393 2020-01-28 Richard Sandiford <richard.sandiford@arm.com>
12394
12395 PR tree-optimization/92822
12396 * tree-ssa-forwprop.c (simplify_vector_constructor): When filling
12397 out the don't-care elements of a vector whose significant elements
12398 are duplicates, make the don't-care elements duplicates too.
12399
12400 2020-01-28 Richard Sandiford <richard.sandiford@arm.com>
12401
12402 PR tree-optimization/93434
12403 * tree-predcom.c (split_data_refs_to_components): Record which
12404 components have had aliasing loads removed. Prevent store-store
12405 commoning for all such components.
12406
12407 2020-01-28 Jakub Jelinek <jakub@redhat.com>
12408
12409 PR target/93418
12410 * config/i386/i386.c (ix86_fold_builtin) <do_shift>: If mask is not
12411 -1 or is_vshift is true, use new_vector with number of elts npatterns
12412 rather than new_unary_operation.
12413
12414 PR tree-optimization/93454
12415 * gimple-fold.c (fold_array_ctor_reference): Perform
12416 elt_size.to_uhwi () just once, instead of calling it in every
12417 iteration. Punt if that value is above size of the temporary
12418 buffer. Decrease third native_encode_expr argument when
12419 bufoff + elt_sz is above size of buf.
12420
12421 2020-01-27 Joseph Myers <joseph@codesourcery.com>
12422
12423 * config/mips/mips.c (mips_declare_object_name)
12424 [USE_GNU_UNIQUE_OBJECT]: Support use of gnu_unique_object.
12425
12426 2020-01-27 Martin Liska <mliska@suse.cz>
12427
12428 PR gcov-profile/93403
12429 * tree-profile.c (gimple_init_gcov_profiler): Generate
12430 both __gcov_indirect_call_profiler_v4 and
12431 __gcov_indirect_call_profiler_v4_atomic.
12432
12433 2020-01-27 Richard Sandiford <richard.sandiford@arm.com>
12434
12435 PR target/92822
12436 * config/aarch64/aarch64-simd.md (aarch64_get_half<mode>): New
12437 expander.
12438 (@aarch64_split_simd_mov<mode>): Use it.
12439 (aarch64_simd_mov_from_<mode>low): Add a GPR alternative.
12440 Leave the vec_extract patterns to handle 2-element vectors.
12441 (aarch64_simd_mov_from_<mode>high): Likewise.
12442 (vec_extract<VQMOV_NO2E:mode><Vhalf>): New expander.
12443 (vec_extractv2dfv1df): Likewise.
12444
12445 2020-01-27 Richard Sandiford <richard.sandiford@arm.com>
12446
12447 * config/aarch64/aarch64.c (aarch64_if_then_else_costs): Match
12448 jump conditions for *compare_condjump<GPI:mode>.
12449
12450 2020-01-27 David Malcolm <dmalcolm@redhat.com>
12451
12452 PR analyzer/93276
12453 * digraph.cc (test_edge::test_edge): Specify template for base
12454 class initializer.
12455
12456 2020-01-27 Claudiu Zissulescu <claziss@synopsys.com>
12457
12458 * config/arc/arc.c (arc_rtx_costs): Update mul64 cost.
12459
12460 2020-01-27 Claudiu Zissulescu <claziss@synopsys.com>
12461
12462 * config/arc/arc-protos.h (gen_mlo): Remove.
12463 (gen_mhi): Likewise.
12464 * config/arc/arc.c (AUX_MULHI): Define.
12465 (arc_must_save_reister): Special handling for r58/59.
12466 (arc_compute_frame_size): Consider mlo/mhi registers.
12467 (arc_save_callee_saves): Emit fp/sp move only when emit_move
12468 paramter is true.
12469 (arc_conditional_register_usage): Remove TARGET_BIG_ENDIAN from
12470 mlo/mhi name selection.
12471 (arc_restore_callee_saves): Don't early restore blink when ISR.
12472 (arc_expand_prologue): Add mlo/mhi saving.
12473 (arc_expand_epilogue): Add mlo/mhi restoring.
12474 (gen_mlo): Remove.
12475 (gen_mhi): Remove.
12476 * config/arc/arc.h (DBX_REGISTER_NUMBER): Correct register
12477 numbering when MUL64 option is used.
12478 (DWARF2_FRAME_REG_OUT): Define.
12479 * config/arc/arc.md (arc600_stall): New pattern.
12480 (VUNSPEC_ARC_ARC600_STALL): Define.
12481 (mulsi64): Use correct mlo/mhi registers.
12482 (mulsi_600): Clean it up.
12483 * config/arc/predicates.md (mlo_operand): Remove any dependency on
12484 TARGET_BIG_ENDIAN.
12485 (mhi_operand): Likewise.
12486
12487 2020-01-27 Claudiu Zissulescu <claziss@synopsys.com>
12488 Petro Karashchenko <petro.karashchenko@ring.com>
12489
12490 * config/arc/arc.c (arc_is_uncached_mem_p): Check struct
12491 attributes if needed.
12492 (prepare_move_operands): Generate special unspec instruction for
12493 direct access.
12494 (arc_isuncached_mem_p): Propagate uncached attribute to each
12495 structure member.
12496 * config/arc/arc.md (VUNSPEC_ARC_LDDI): Define.
12497 (VUNSPEC_ARC_STDI): Likewise.
12498 (ALLI): New mode iterator.
12499 (mALLI): New mode attribute.
12500 (lddi): New instruction pattern.
12501 (stdi): Likewise.
12502 (stdidi_split): Split instruction for architectures which are not
12503 supporting ll64 option.
12504 (lddidi_split): Likewise.
12505
12506 2020-01-27 Richard Sandiford <richard.sandiford@arm.com>
12507
12508 PR rtl-optimization/92989
12509 * lra-lives.c (process_bb_lives): Update the live-in set before
12510 processing additional clobbers.
12511
12512 2020-01-27 Richard Sandiford <richard.sandiford@arm.com>
12513
12514 PR rtl-optimization/93170
12515 * cselib.c (cselib_invalidate_regno_val): New function, split out
12516 from...
12517 (cselib_invalidate_regno): ...here.
12518 (cselib_invalidated_by_call_p): New function.
12519 (cselib_process_insn): Iterate over all the hard-register entries in
12520 REG_VALUES and invalidate any that cross call-clobbered registers.
12521
12522 2020-01-27 Richard Sandiford <richard.sandiford@arm.com>
12523
12524 * dojump.c (split_comparison): Use HONOR_NANS rather than
12525 HONOR_SNANS when splitting LTGT.
12526
12527 2020-01-27 Martin Liska <mliska@suse.cz>
12528
12529 PR driver/91220
12530 * opts.c (print_filtered_help): Exclude language-specific
12531 options from --help=common unless enabled in all FEs.
12532
12533 2020-01-27 Martin Liska <mliska@suse.cz>
12534
12535 * opts.c (print_help): Exclude params from
12536 all except --help=param.
12537
12538 2020-01-27 Martin Liska <mliska@suse.cz>
12539
12540 PR target/93274
12541 * config/i386/i386-features.c (make_resolver_func):
12542 Align the code with ppc64 target implementation.
12543 Do not generate a unique name for resolver function.
12544
12545 2020-01-27 Richard Biener <rguenther@suse.de>
12546
12547 PR tree-optimization/93397
12548 * tree-vect-slp.c (vect_analyze_slp_instance): Delay
12549 converted reduction chain SLP graph adjustment.
12550
12551 2020-01-26 Marek Polacek <polacek@redhat.com>
12552
12553 PR sanitizer/93436
12554 * sanopt.c (sanitize_rewrite_addressable_params): Avoid crash on
12555 null DECL_NAME.
12556
12557 2020-01-26 Jason Merrill <jason@redhat.com>
12558
12559 PR c++/92601
12560 * tree.c (verify_type_variant): Only verify TYPE_NEEDS_CONSTRUCTING
12561 of complete types.
12562
12563 2020-01-26 Darius Galis <darius.galis@cyberthorstudios.com>
12564
12565 * config/rx/rx.md (setmemsi): Added rx_allow_string_insns constraint
12566 (rx_setmem): Likewise.
12567
12568 2020-01-26 Jakub Jelinek <jakub@redhat.com>
12569
12570 PR target/93412
12571 * config/i386/i386.md (*addv<dwi>4_doubleword, *subv<dwi>4_doubleword):
12572 Use nonimmediate_operand instead of x86_64_hilo_general_operand and
12573 drop <di> from constraint of last operand.
12574
12575 PR target/93430
12576 * config/i386/sse.md (*avx_vperm_broadcast_<mode>): Disallow for
12577 TARGET_AVX2 and V4DFmode not in the split condition, but in the
12578 pattern condition, though allow { 0, 0, 0, 0 } broadcast always.
12579
12580 2020-01-25 Feng Xue <fxue@os.amperecomputing.com>
12581
12582 PR ipa/93166
12583 * ipa-cp.c (get_info_about_necessary_edges): Remove value
12584 check assertion.
12585
12586 2020-01-24 Jeff Law <law@redhat.com>
12587
12588 PR tree-optimization/92788
12589 * tree-ssa-threadedge.c (thread_across_edge): Check EDGE_COMPLEX
12590 not EDGE_ABNORMAL.
12591
12592 2020-01-24 Jakub Jelinek <jakub@redhat.com>
12593
12594 PR target/93395
12595 * config/i386/sse.md (*avx_vperm_broadcast_v4sf,
12596 *avx_vperm_broadcast_<mode>,
12597 <sse2_avx_avx512f>_vpermil<mode><mask_name>,
12598 *<sse2_avx_avx512f>_vpermilp<mode><mask_name>):
12599 Move before avx2_perm<mode>/avx512f_perm<mode>.
12600
12601 PR target/93376
12602 * simplify-rtx.c (simplify_const_unary_operation,
12603 simplify_const_binary_operation): Punt for mode precision above
12604 MAX_BITSIZE_MODE_ANY_INT.
12605
12606 2020-01-24 Andrew Pinski <apinski@marvell.com>
12607
12608 * config/arm/aarch-cost-tables.h (cortexa57_extra_costs): Change
12609 alu.shift_reg to 0.
12610
12611 2020-01-24 Jeff Law <law@redhat.com>
12612
12613 PR target/13721
12614 * config/h8300/h8300.c (h8300_print_operand): Only call byte_reg
12615 for REGs. Call output_operand_lossage to get more reasonable
12616 diagnostics.
12617
12618 2020-01-24 Andrew Stubbs <ams@codesourcery.com>
12619
12620 * config/gcn/gcn-valu.md (vec_cmp<mode>di): Use
12621 gcn_fp_compare_operator.
12622 (vec_cmpu<mode>di): Use gcn_compare_operator.
12623 (vec_cmp<u>v64qidi): Use gcn_compare_operator.
12624 (vec_cmp<mode>di_exec): Use gcn_fp_compare_operator.
12625 (vec_cmpu<mode>di_exec): Use gcn_compare_operator.
12626 (vec_cmp<u>v64qidi_exec): Use gcn_compare_operator.
12627 (vec_cmp<mode>di_dup): Use gcn_fp_compare_operator.
12628 (vec_cmp<mode>di_dup_exec): Use gcn_fp_compare_operator.
12629 (vcond<VEC_ALLREG_MODE:mode><VEC_ALLREG_ALT:mode>): Use
12630 gcn_fp_compare_operator.
12631 (vcond<VEC_ALLREG_MODE:mode><VEC_ALLREG_ALT:mode>_exec): Use
12632 gcn_fp_compare_operator.
12633 (vcondu<VEC_ALLREG_MODE:mode><VEC_ALLREG_INT_MODE:mode>): Use
12634 gcn_fp_compare_operator.
12635 (vcondu<VEC_ALLREG_MODE:mode><VEC_ALLREG_INT_MODE:mode>_exec): Use
12636 gcn_fp_compare_operator.
12637
12638 2020-01-24 Maciej W. Rozycki <macro@wdc.com>
12639
12640 * doc/install.texi (Cross-Compiler-Specific Options): Document
12641 `--with-toolexeclibdir' option.
12642
12643 2020-01-24 Hans-Peter Nilsson <hp@axis.com>
12644
12645 * target.def (flags_regnum): Also mention effect on delay slot filling.
12646 * doc/tm.texi: Regenerate.
12647
12648 2020-01-23 Jeff Law <law@redhat.com>
12649
12650 PR translation/90162
12651 * config/h8300/h8300.c (h8300_option_override): Fix diagnostic text.
12652
12653 2020-01-23 Mikael Tillenius <mti-1@tillenius.com>
12654
12655 PR target/92269
12656 * config/h8300/h8300.h (FUNCTION_PROFILER): Fix emission of
12657 profiling label
12658
12659 2020-01-23 Jakub Jelinek <jakub@redhat.com>
12660
12661 PR rtl-optimization/93402
12662 * postreload.c (reload_combine_recognize_pattern): Don't try to adjust
12663 USE insns.
12664
12665 2020-01-23 Dragan Mladjenovic <dmladjenovic@wavecomp.com>
12666
12667 * config.in: Regenerated.
12668 * config/mips/linux.h (NEED_INDICATE_EXEC_STACK): Define to 1
12669 for TARGET_LIBC_GNUSTACK.
12670 * configure: Regenerated.
12671 * configure.ac: Define TARGET_LIBC_GNUSTACK if glibc version is
12672 found to be 2.31 or greater.
12673
12674 2020-01-23 Dragan Mladjenovic <dmladjenovic@wavecomp.com>
12675
12676 * config/mips/linux.h (NEED_INDICATE_EXEC_STACK): Define to
12677 TARGET_SOFT_FLOAT.
12678 * config/mips/mips.c (TARGET_ASM_FILE_END): Define to ...
12679 (mips_asm_file_end): New function. Delegate to
12680 file_end_indicate_exec_stack if NEED_INDICATE_EXEC_STACK is true.
12681 * config/mips/mips.h (NEED_INDICATE_EXEC_STACK): Define to 0.
12682
12683 2020-01-23 Jakub Jelinek <jakub@redhat.com>
12684
12685 PR target/93376
12686 * config/i386/i386-modes.def (POImode): New mode.
12687 (MAX_BITSIZE_MODE_ANY_INT): Change from 128 to 160.
12688 * config/i386/i386.md (DPWI): New mode attribute.
12689 (addv<mode>4, subv<mode>4): Use <DPWI> instead of <DWI>.
12690 (QWI): Rename to...
12691 (QPWI): ... this. Use POI instead of OI for TImode.
12692 (*addv<dwi>4_doubleword, *addv<dwi>4_doubleword_1,
12693 *subv<dwi>4_doubleword, *subv<dwi>4_doubleword_1): Use <QPWI>
12694 instead of <QWI>.
12695
12696 2020-01-23 Richard Sandiford <richard.sandiford@arm.com>
12697
12698 PR target/93341
12699 * config/aarch64/aarch64.md (UNSPEC_SPECULATION_TRACKER_REV): New
12700 unspec.
12701 (speculation_tracker_rev): New pattern.
12702 * config/aarch64/aarch64-speculation.cc (aarch64_do_track_speculation):
12703 Use speculation_tracker_rev to track the inverse condition.
12704
12705 2020-01-23 Richard Biener <rguenther@suse.de>
12706
12707 PR tree-optimization/93381
12708 * tree-ssa-sccvn.c (vn_walk_cb_data::push_partial_def): Take
12709 alias-set of the def as argument and record the first one.
12710 (vn_walk_cb_data::first_set): New member.
12711 (vn_reference_lookup_3): Pass the alias-set of the current def
12712 to push_partial_def. Fix alias-set used in the aggregate copy
12713 case.
12714 (vn_reference_lookup): Consistently set *last_vuse_ptr.
12715 * real.c (clear_significand_below): Fix out-of-bound access.
12716
12717 2020-01-23 Jakub Jelinek <jakub@redhat.com>
12718
12719 PR target/93346
12720 * config/i386/i386.md (*bmi2_bzhi_<mode>3_2, *bmi2_bzhi_<mode>3_3):
12721 New define_insn patterns.
12722
12723 2020-01-23 Richard Sandiford <richard.sandiford@arm.com>
12724
12725 * doc/sourcebuild.texi (check-function-bodies): Add an
12726 optional target/xfail selector.
12727
12728 2020-01-23 Richard Sandiford <richard.sandiford@arm.com>
12729
12730 PR rtl-optimization/93124
12731 * auto-inc-dec.c (merge_in_block): Don't add auto inc/decs to
12732 bare USE and CLOBBER insns.
12733
12734 2020-01-22 Andrew Pinski <apinski@marvell.com>
12735
12736 * config/arc/arc.c (output_short_suffix): Check insn for nullness.
12737
12738 2020-01-22 David Malcolm <dmalcolm@redhat.com>
12739
12740 PR analyzer/93307
12741 * gdbinit.in (break-on-saved-diagnostic): Update for move of
12742 diagnostic_manager into "ana" namespace.
12743 * selftest-run-tests.c (selftest::run_tests): Update for move of
12744 selftest::run_analyzer_selftests to
12745 ana::selftest::run_analyzer_selftests.
12746
12747 2020-01-22 Richard Sandiford <richard.sandiford@arm.com>
12748
12749 * cfgexpand.c (union_stack_vars): Update the size.
12750
12751 2020-01-22 Richard Biener <rguenther@suse.de>
12752
12753 PR tree-optimization/93381
12754 * tree-ssa-structalias.c (find_func_aliases): Assume offsetting
12755 throughout, handle all conversions the same.
12756
12757 2020-01-22 Jakub Jelinek <jakub@redhat.com>
12758
12759 PR target/93335
12760 * config/aarch64/aarch64.c (aarch64_expand_subvti): Only use
12761 gen_subdi3_compare1_imm if low_in2 satisfies aarch64_plus_immediate
12762 predicate, not whenever it is CONST_INT. Otherwise, force_reg it.
12763 Call force_reg on high_in2 unconditionally.
12764
12765 2020-01-22 Martin Liska <mliska@suse.cz>
12766
12767 PR tree-optimization/92924
12768 * profile.c (compute_value_histograms): Divide
12769 all counter values.
12770
12771 2020-01-22 Jakub Jelinek <jakub@redhat.com>
12772
12773 PR target/91298
12774 * output.h (assemble_name_resolve): Declare.
12775 * varasm.c (assemble_name_resolve): New function.
12776 (assemble_name): Use it.
12777 * config/i386/i386.h (ASM_OUTPUT_SYMBOL_REF): Define.
12778
12779 2020-01-22 Joseph Myers <joseph@codesourcery.com>
12780
12781 * doc/sourcebuild.texi (Texinfo Manuals, Front End): Refer to
12782 update_web_docs_git instead of update_web_docs_svn.
12783
12784 2020-01-21 Andrew Pinski <apinski@marvell.com>
12785
12786 PR target/9311
12787 * config/aarch64/aarch64.md (tlsgd_small_<mode>): Have operand 0
12788 as PTR mode. Have operand 1 as being modeless, it can be P mode.
12789 (*tlsgd_small_<mode>): Likewise.
12790 * config/aarch64/aarch64.c (aarch64_load_symref_appropriately)
12791 <case SYMBOL_SMALL_TLSGD>: Call gen_tlsgd_small_* with a ptr_mode
12792 register. Convert that register back to dest using convert_mode.
12793
12794 2020-01-21 Jim Wilson <jimw@sifive.com>
12795
12796 * config/riscv/riscv-sr.c (riscv_sr_match_prologue): Use INTVAL
12797 instead of XINT.
12798
12799 2020-01-21 H.J. Lu <hongjiu.lu@intel.com>
12800 Uros Bizjak <ubizjak@gmail.com>
12801
12802 PR target/93319
12803 * config/i386/i386.c (ix86_tls_module_base): Replace Pmode
12804 with ptr_mode.
12805 (legitimize_tls_address): Do GNU2 TLS address computation in
12806 ptr_mode and zero-extend result to Pmode.
12807 * config/i386/i386.md (@tls_dynamic_gnu2_64_<mode>): Replace
12808 :P with :PTR and Pmode with ptr_mode.
12809 (*tls_dynamic_gnu2_lea_64_<mode>): Likewise.
12810 (*tls_dynamic_gnu2_call_64_<mode>): Likewise.
12811 (*tls_dynamic_gnu2_combine_64_<mode>): Likewise.
12812
12813 2020-01-21 Jakub Jelinek <jakub@redhat.com>
12814
12815 PR target/93333
12816 * config/riscv/riscv.c (riscv_rtx_costs) <case ZERO_EXTRACT>: Verify
12817 the last two operands are CONST_INT_P before using them as such.
12818
12819 2020-01-21 Richard Sandiford <richard.sandiford@arm.com>
12820
12821 * config/aarch64/aarch64-sve-builtins.def: Use get_typenode_from_name
12822 to get the integer element types.
12823
12824 2020-01-21 Richard Sandiford <richard.sandiford@arm.com>
12825
12826 * config/aarch64/aarch64-sve-builtins.h
12827 (function_expander::convert_to_pmode): Declare.
12828 * config/aarch64/aarch64-sve-builtins.cc
12829 (function_expander::convert_to_pmode): New function.
12830 (function_expander::get_contiguous_base): Use it.
12831 (function_expander::prepare_gather_address_operands): Likewise.
12832 * config/aarch64/aarch64-sve-builtins-sve2.cc
12833 (svwhilerw_svwhilewr_impl::expand): Likewise.
12834
12835 2020-01-21 Szabolcs Nagy <szabolcs.nagy@arm.com>
12836
12837 PR target/92424
12838 * config/aarch64/aarch64.c (aarch64_declare_function_name): Set
12839 cfun->machine->label_is_assembled.
12840 (aarch64_print_patchable_function_entry): New.
12841 (TARGET_ASM_PRINT_PATCHABLE_FUNCTION_ENTRY): Define.
12842 * config/aarch64/aarch64.h (struct machine_function): New field,
12843 label_is_assembled.
12844
12845 2020-01-21 David Malcolm <dmalcolm@redhat.com>
12846
12847 PR ipa/93315
12848 * ipa-profile.c (ipa_profile): Delete call_sums and set it to
12849 NULL on exit.
12850
12851 2020-01-18 Jan Hubicka <hubicka@ucw.cz>
12852
12853 PR lto/93318
12854 * cgraph.c (cgraph_edge::resolve_speculation,
12855 cgraph_edge::redirect_call_stmt_to_callee): Fix update of
12856 call_stmt_site_hash.
12857
12858 2020-01-21 Martin Liska <mliska@suse.cz>
12859
12860 * config/rs6000/rs6000.c (common_mode_defined): Remove
12861 unused variable.
12862
12863 2020-01-21 Richard Biener <rguenther@suse.de>
12864
12865 PR tree-optimization/92328
12866 * tree-ssa-sccvn.c (vn_reference_lookup_3): Preserve
12867 type when value-numbering same-sized store by inserting a
12868 VIEW_CONVERT_EXPR.
12869 (eliminate_dom_walker::eliminate_stmt): When eliminating
12870 a redundant store handle bit-reinterpretation of the same value.
12871
12872 2020-01-21 Andrew Pinski <apinski@marvel.com>
12873
12874 PR tree-opt/93321
12875 * tree-into-ssa.c (prepare_block_for_update_1): Split out
12876 from ...
12877 (prepare_block_for_update): This. Use a worklist instead of
12878 recursing.
12879
12880 2020-01-21 Mihail-Calin Ionescu <mihail.ionescu@arm.com>
12881
12882 * gcc/config/arm/arm.c (clear_operation_p):
12883 Initialise last_regno, skip first iteration
12884 based on the first_set value and use ints instead
12885 of the unnecessary HOST_WIDE_INTs.
12886
12887 2020-01-21 Jakub Jelinek <jakub@redhat.com>
12888
12889 PR target/93073
12890 * config/rs6000/rs6000.c (rs6000_emit_cmove): If using fsel, punt for
12891 compare_mode other than SFmode or DFmode.
12892
12893 2020-01-21 Kito Cheng <kito.cheng@sifive.com>
12894
12895 PR target/93304
12896 * config/riscv/riscv-protos.h (riscv_hard_regno_rename_ok): New.
12897 * config/riscv/riscv.c (riscv_hard_regno_rename_ok): New.
12898 * config/riscv/riscv.h (HARD_REGNO_RENAME_OK): Defined.
12899
12900 2020-01-20 Wilco Dijkstra <wdijkstr@arm.com>
12901
12902 * config/aarch64/aarch64.c (neoversen1_tunings): Set jump_align to 4.
12903
12904 2020-01-20 Andrew Pinski <apinski@marvell.com>
12905
12906 PR middle-end/93242
12907 * targhooks.c (default_print_patchable_function_entry): Use
12908 output_asm_insn to emit the nop instruction.
12909
12910 2020-01-20 Fangrui Song <maskray@google.com>
12911
12912 PR middle-end/93194
12913 * targhooks.c (default_print_patchable_function_entry): Align to
12914 POINTER_SIZE.
12915
12916 2020-01-20 H.J. Lu <hongjiu.lu@intel.com>
12917
12918 PR target/93319
12919 * config/i386/i386.c (legitimize_tls_address): Pass Pmode to
12920 gen_tls_dynamic_gnu2_64. Compute GNU2 TLS address in ptr_mode.
12921 * config/i386/i386.md (tls_dynamic_gnu2_64): Renamed to ...
12922 (@tls_dynamic_gnu2_64_<mode>): This. Replace DI with P.
12923 (*tls_dynamic_gnu2_lea_64): Renamed to ...
12924 (*tls_dynamic_gnu2_lea_64_<mode>): This. Replace DI with P.
12925 Remove the {q} suffix from lea.
12926 (*tls_dynamic_gnu2_call_64): Renamed to ...
12927 (*tls_dynamic_gnu2_call_64_<mode>): This. Replace DI with P.
12928 (*tls_dynamic_gnu2_combine_64): Renamed to ...
12929 (*tls_dynamic_gnu2_combine_64_<mode>): This. Replace DI with P.
12930 Pass Pmode to gen_tls_dynamic_gnu2_64.
12931
12932 2020-01-20 Wilco Dijkstra <wdijkstr@arm.com>
12933
12934 * config/aarch64/aarch64.h (SLOW_BYTE_ACCESS): Set to 1.
12935
12936 2020-01-20 Richard Sandiford <richard.sandiford@arm.com>
12937
12938 * config/aarch64/aarch64-sve-builtins-base.cc
12939 (svld1ro_impl::memory_vector_mode): Remove parameter name.
12940
12941 2020-01-20 Richard Biener <rguenther@suse.de>
12942
12943 PR debug/92763
12944 * dwarf2out.c (prune_unused_types): Unconditionally mark
12945 called function DIEs.
12946
12947 2020-01-20 Martin Liska <mliska@suse.cz>
12948
12949 PR tree-optimization/93199
12950 * tree-eh.c (struct leh_state): Add
12951 new field outer_non_cleanup.
12952 (cleanup_is_dead_in): Pass leh_state instead
12953 of eh_region. Add a checking that state->outer_non_cleanup
12954 points to outer non-clean up region.
12955 (lower_try_finally): Record outer_non_cleanup
12956 for this_state.
12957 (lower_catch): Likewise.
12958 (lower_eh_filter): Likewise.
12959 (lower_eh_must_not_throw): Likewise.
12960 (lower_cleanup): Likewise.
12961
12962 2020-01-20 Richard Biener <rguenther@suse.de>
12963
12964 PR tree-optimization/93094
12965 * tree-vectorizer.h (vect_loop_versioning): Adjust.
12966 (vect_transform_loop): Likewise.
12967 * tree-vectorizer.c (try_vectorize_loop_1): Pass down
12968 loop_vectorized_call to vect_transform_loop.
12969 * tree-vect-loop.c (vect_transform_loop): Pass down
12970 loop_vectorized_call to vect_loop_versioning.
12971 * tree-vect-loop-manip.c (vect_loop_versioning): Use
12972 the earlier discovered loop_vectorized_call.
12973
12974 2020-01-19 Eric S. Raymond <esr@thyrsus.com>
12975
12976 * doc/contribute.texi: Update for SVN -> Git transition.
12977 * doc/install.texi: Likewise.
12978
12979 2020-01-18 Jan Hubicka <hubicka@ucw.cz>
12980
12981 PR lto/93318
12982 * cgraph.c (cgraph_edge::make_speculative): Increase number of
12983 speculative targets.
12984 (verify_speculative_call): New function
12985 (cgraph_node::verify_node): Use it.
12986 * ipa-profile.c (ipa_profile): Fix formating; do not set number of
12987 speculations.
12988
12989 2020-01-18 Jan Hubicka <hubicka@ucw.cz>
12990
12991 PR lto/93318
12992 * cgraph.c (cgraph_edge::resolve_speculation): Fix foramting.
12993 (cgraph_edge::make_direct): Remove all indirect targets.
12994 (cgraph_edge::redirect_call_stmt_to_callee): Use make_direct..
12995 (cgraph_node::verify_node): Verify that only one call_stmt or
12996 lto_stmt_uid is set.
12997 * cgraphclones.c (cgraph_edge::clone): Set only one call_stmt or
12998 lto_stmt_uid.
12999 * lto-cgraph.c (lto_output_edge): Simplify streaming of stmt.
13000 (lto_output_ref): Simplify streaming of stmt.
13001 * lto-streamer-in.c (fixup_call_stmt_edges_1): Clear lto_stmt_uid.
13002
13003 2020-01-18 Tamar Christina <tamar.christina@arm.com>
13004
13005 * config/aarch64/aarch64-sve-builtins-base.cc (memory_vector_mode):
13006 Mark parameter unused.
13007
13008 2020-01-18 Hans-Peter Nilsson <hp@axis.com>
13009
13010 * config.gcc <obsolete targets>: Add crisv32-*-* and cris-*-linux*
13011
13012 2019-01-18 Gerald Pfeifer <gerald@pfeifer.com>
13013
13014 * varpool.c (ctor_useable_for_folding_p): Fix grammar.
13015
13016 2020-01-18 Iain Sandoe <iain@sandoe.co.uk>
13017
13018 * Makefile.in: Add coroutine-passes.o.
13019 * builtin-types.def (BT_CONST_SIZE): New.
13020 (BT_FN_BOOL_PTR): New.
13021 (BT_FN_PTR_PTR_CONST_SIZE_BOOL): New.
13022 * builtins.def (DEF_COROUTINE_BUILTIN): New.
13023 * coroutine-builtins.def: New file.
13024 * coroutine-passes.cc: New file.
13025 * function.h (struct GTY function): Add a bit to indicate that the
13026 function is a coroutine component.
13027 * internal-fn.c (expand_CO_FRAME): New.
13028 (expand_CO_YIELD): New.
13029 (expand_CO_SUSPN): New.
13030 (expand_CO_ACTOR): New.
13031 * internal-fn.def (CO_ACTOR): New.
13032 (CO_YIELD): New.
13033 (CO_SUSPN): New.
13034 (CO_FRAME): New.
13035 * passes.def: Add pass_coroutine_lower_builtins,
13036 pass_coroutine_early_expand_ifns.
13037 * tree-pass.h (make_pass_coroutine_lower_builtins): New.
13038 (make_pass_coroutine_early_expand_ifns): New.
13039 * doc/invoke.texi: Document the fcoroutines command line
13040 switch.
13041
13042 2020-01-18 Jakub Jelinek <jakub@redhat.com>
13043
13044 * config/arm/vfp.md (*clear_vfp_multiple): Remove unused variable.
13045
13046 PR target/93312
13047 * config/arm/arm.c (clear_operation_p): Don't use REGNO until
13048 after checking the argument is a REG. Don't use REGNO (reg)
13049 again to set last_regno, reuse regno variable instead.
13050
13051 2020-01-17 David Malcolm <dmalcolm@redhat.com>
13052
13053 * doc/analyzer.texi (Limitations): Add note about NaN.
13054
13055 2020-01-17 Mihail-Calin Ionescu <mihail.ionescu@arm.com>
13056 Sudakshina Das <sudi.das@arm.com>
13057
13058 * config/arm/arm.md (ashldi3): Generate thumb2_lsll for both reg
13059 and valid immediate.
13060 (ashrdi3): Generate thumb2_asrl for both reg and valid immediate.
13061 (lshrdi3): Generate thumb2_lsrl for valid immediates.
13062 * config/arm/constraints.md (Pg): New.
13063 * config/arm/predicates.md (long_shift_imm): New.
13064 (arm_reg_or_long_shift_imm): Likewise.
13065 * config/arm/thumb2.md (thumb2_asrl): New immediate alternative.
13066 (thumb2_lsll): Likewise.
13067 (thumb2_lsrl): New.
13068
13069 2020-01-17 Mihail-Calin Ionescu <mihail.ionescu@arm.com>
13070 Sudakshina Das <sudi.das@arm.com>
13071
13072 * config/arm/arm.md (ashldi3): Generate thumb2_lsll for TARGET_HAVE_MVE.
13073 (ashrdi3): Generate thumb2_asrl for TARGET_HAVE_MVE.
13074 * config/arm/arm.c (arm_hard_regno_mode_ok): Allocate even odd
13075 register pairs for doubleword quantities for ARMv8.1M-Mainline.
13076 * config/arm/thumb2.md (thumb2_asrl): New.
13077 (thumb2_lsll): Likewise.
13078
13079 2020-01-17 Jakub Jelinek <jakub@redhat.com>
13080
13081 * config/arm/arm.c (cmse_nonsecure_call_inline_register_clear): Remove
13082 unused variable.
13083
13084 2020-01-17 Alexander Monakov <amonakov@ispras.ru>
13085
13086 * gdbinit.in (help-gcc-hooks): New command.
13087 (pp, pr, prl, pt, pct, pgg, pgq, pgs, pge, pmz, ptc, pdn, ptn, pdd, prc,
13088 pi, pbm, pel, trt): Take $arg0 instead of $ if supplied. Update
13089 documentation.
13090
13091 2020-01-17 Matthew Malcomson <matthew.malcomson@arm.com>
13092
13093 * config/aarch64/aarch64-sve.md (@aarch64_sve_ld1ro<mode>): Use the
13094 correct target macro.
13095
13096 2020-01-17 Matthew Malcomson <matthew.malcomson@arm.com>
13097
13098 * config/aarch64/aarch64-protos.h
13099 (aarch64_sve_ld1ro_operand_p): New.
13100 * config/aarch64/aarch64-sve-builtins-base.cc
13101 (class load_replicate): New.
13102 (class svld1ro_impl): New.
13103 (class svld1rq_impl): Change to inherit from load_replicate.
13104 (svld1ro): New sve intrinsic function base.
13105 * config/aarch64/aarch64-sve-builtins-base.def (svld1ro):
13106 New DEF_SVE_FUNCTION.
13107 * config/aarch64/aarch64-sve-builtins-base.h
13108 (svld1ro): New decl.
13109 * config/aarch64/aarch64-sve-builtins.cc
13110 (function_expander::add_mem_operand): Modify assert to allow
13111 OImode.
13112 * config/aarch64/aarch64-sve.md (@aarch64_sve_ld1ro<mode>): New
13113 pattern.
13114 * config/aarch64/aarch64.c
13115 (aarch64_sve_ld1rq_operand_p): Implement in terms of ...
13116 (aarch64_sve_ld1rq_ld1ro_operand_p): This.
13117 (aarch64_sve_ld1ro_operand_p): New.
13118 * config/aarch64/aarch64.md (UNSPEC_LD1RO): New unspec.
13119 * config/aarch64/constraints.md (UOb,UOh,UOw,UOd): New.
13120 * config/aarch64/predicates.md
13121 (aarch64_sve_ld1ro_operand_{b,h,w,d}): New.
13122
13123 2020-01-17 Matthew Malcomson <matthew.malcomson@arm.com>
13124
13125 * config/aarch64/aarch64-c.c (_ARM_FEATURE_MATMUL_FLOAT64):
13126 Introduce this ACLE specified predefined macro.
13127 * config/aarch64/aarch64-option-extensions.def (f64mm): New.
13128 (fp): Disabling this disables f64mm.
13129 (simd): Disabling this disables f64mm.
13130 (fp16): Disabling this disables f64mm.
13131 (sve): Disabling this disables f64mm.
13132 * config/aarch64/aarch64.h (AARCH64_FL_F64MM): New.
13133 (AARCH64_ISA_F64MM): New.
13134 (TARGET_F64MM): New.
13135 * doc/invoke.texi (f64mm): Document new option.
13136
13137 2020-01-17 Wilco Dijkstra <wdijkstr@arm.com>
13138
13139 * config/aarch64/aarch64.c (generic_tunings): Add branch fusion.
13140 (neoversen1_tunings): Likewise.
13141
13142 2020-01-17 Wilco Dijkstra <wdijkstr@arm.com>
13143
13144 PR target/92692
13145 * config/aarch64/aarch64.c (aarch64_split_compare_and_swap)
13146 Add assert to ensure prolog has been emitted.
13147 (aarch64_split_atomic_op): Likewise.
13148 * config/aarch64/atomics.md (aarch64_compare_and_swap<mode>)
13149 Use epilogue_completed rather than reload_completed.
13150 (aarch64_atomic_exchange<mode>): Likewise.
13151 (aarch64_atomic_<atomic_optab><mode>): Likewise.
13152 (atomic_nand<mode>): Likewise.
13153 (aarch64_atomic_fetch_<atomic_optab><mode>): Likewise.
13154 (atomic_fetch_nand<mode>): Likewise.
13155 (aarch64_atomic_<atomic_optab>_fetch<mode>): Likewise.
13156 (atomic_nand_fetch<mode>): Likewise.
13157
13158 2020-01-17 Richard Sandiford <richard.sandiford@arm.com>
13159
13160 PR target/93133
13161 * config/aarch64/aarch64.h (REVERSIBLE_CC_MODE): Return false
13162 for FP modes.
13163 (REVERSE_CONDITION): Delete.
13164 * config/aarch64/iterators.md (CC_ONLY): New mode iterator.
13165 (CCFP_CCFPE): Likewise.
13166 (e): New mode attribute.
13167 * config/aarch64/aarch64.md (ccmp<GPI:mode>): Rename to...
13168 (@ccmp<CC_ONLY:mode><GPI:mode>): ...this, using CC_ONLY instead of CC.
13169 (fccmp<GPF:mode>, fccmpe<GPF:mode>): Merge into...
13170 (@ccmp<CCFP_CCFPE:mode><GPF:mode>): ...this combined pattern.
13171 (@ccmp<CC_ONLY:mode><GPI:mode>_rev): New pattern.
13172 (@ccmp<CCFP_CCFPE:mode><GPF:mode>_rev): Likewise.
13173 * config/aarch64/aarch64.c (aarch64_gen_compare_reg): Update
13174 name of generator from gen_ccmpdi to gen_ccmpccdi.
13175 (aarch64_gen_ccmp_next): Use code_for_ccmp. If we want to reverse
13176 the previous comparison but aren't able to, use the new ccmp_rev
13177 patterns instead.
13178
13179 2020-01-17 Richard Sandiford <richard.sandiford@arm.com>
13180
13181 * gimplify.c (gimplify_return_expr): Use poly_int_tree_p rather
13182 than testing directly for INTEGER_CST.
13183 (gimplify_target_expr, gimplify_omp_depend): Likewise.
13184
13185 2020-01-17 Jakub Jelinek <jakub@redhat.com>
13186
13187 PR tree-optimization/93292
13188 * tree-vect-stmts.c (vectorizable_comparison): Punt also if
13189 get_vectype_for_scalar_type returns NULL.
13190
13191 2020-01-16 Jan Hubicka <hubicka@ucw.cz>
13192
13193 * params.opt (-param=max-predicted-iterations): Increase range from 0.
13194 * predict.c (estimate_loops): Add 1 to param_max_predicted_iterations.
13195
13196 2020-01-16 Jan Hubicka <hubicka@ucw.cz>
13197
13198 * ipa-fnsummary.c (estimate_calls_size_and_time): Fix formating of
13199 dump.
13200 * params.opt: (max-predicted-iterations): Set bounds.
13201 * predict.c (real_almost_one, real_br_prob_base,
13202 real_inv_br_prob_base, real_one_half, real_bb_freq_max): Remove.
13203 (propagate_freq): Add max_cyclic_prob parameter; cap cyclic
13204 probabilities; do not truncate to reg_br_prob_bases.
13205 (estimate_loops_at_level): Pass max_cyclic_prob.
13206 (estimate_loops): Compute max_cyclic_prob.
13207 (estimate_bb_frequencies): Do not initialize real_*; update calculation
13208 of back edge prob.
13209 * profile-count.c (profile_probability::to_sreal): New.
13210 * profile-count.h (class sreal): Move up in file.
13211 (profile_probability::to_sreal): Declare.
13212
13213 2020-01-16 Stam Markianos-Wright <stam.markianos-wright@arm.com>
13214
13215 * config/arm/arm.c
13216 (arm_invalid_conversion): New function for target hook.
13217 (arm_invalid_unary_op): New function for target hook.
13218 (arm_invalid_binary_op): New function for target hook.
13219
13220 2020-01-16 Stam Markianos-Wright <stam.markianos-wright@arm.com>
13221
13222 * config.gcc: Add arm_bf16.h.
13223 * config/arm/arm-builtins.c (arm_mangle_builtin_type): Fix comment.
13224 (arm_simd_builtin_std_type): Add BFmode.
13225 (arm_init_simd_builtin_types): Define element types for vector types.
13226 (arm_init_bf16_types): New function.
13227 (arm_init_builtins): Add arm_init_bf16_types function call.
13228 * config/arm/arm-modes.def: Add BFmode and V4BF, V8BF vector modes.
13229 * config/arm/arm-simd-builtin-types.def: Add V4BF, V8BF.
13230 * config/arm/arm.c (aapcs_vfp_sub_candidate): Add BFmode.
13231 (arm_hard_regno_mode_ok): Add BFmode and tidy up statements.
13232 (arm_vector_mode_supported_p): Add V4BF, V8BF.
13233 (arm_mangle_type): Add __bf16.
13234 * config/arm/arm.h: Add V4BF, V8BF to VALID_NEON_DREG_MODE,
13235 VALID_NEON_QREG_MODE respectively. Add export arm_bf16_type_node,
13236 arm_bf16_ptr_type_node.
13237 * config/arm/arm.md: Add BFmode to movhf expand, mov pattern and
13238 define_split between ARM registers.
13239 * config/arm/arm_bf16.h: New file.
13240 * config/arm/arm_neon.h: Add arm_bf16.h and Bfloat vector types.
13241 * config/arm/iterators.md: (ANY64_BF, VDXMOV, VHFBF, HFBF, fporbf): New.
13242 (VQXMOV): Add V8BF.
13243 * config/arm/neon.md: Add BF vector types to movhf NEON move patterns.
13244 * config/arm/vfp.md: Add BFmode to movhf patterns.
13245
13246 2020-01-16 Mihail Ionescu <mihail.ionescu@arm.com>
13247 Andre Vieira <andre.simoesdiasvieira@arm.com>
13248
13249 * config/arm/arm-cpus.in (mve, mve_float): New features.
13250 (dsp, mve, mve.fp): New options.
13251 * config/arm/arm.h (TARGET_HAVE_MVE, TARGET_HAVE_MVE_FLOAT): Define.
13252 * config/arm/t-rmprofile: Map v8.1-M multilibs to v8-M.
13253 * doc/invoke.texi: Document the armv8.1-m mve and dps options.
13254
13255 2020-01-16 Mihail-Calin Ionescu <mihail.ionescu@arm.com>
13256 Thomas Preud'homme <thomas.preudhomme@arm.com>
13257
13258 * config/arm/arm-cpus.in (ARMv8_1m_main): Redefine as an extension to
13259 Armv8-M Mainline.
13260 * config/arm/arm.c (arm_options_perform_arch_sanity_checks): Remove
13261 error for using -mcmse when targeting Armv8.1-M Mainline.
13262
13263 2020-01-16 Mihail-Calin Ionescu <mihail.ionescu@arm.com>
13264 Thomas Preud'homme <thomas.preudhomme@arm.com>
13265
13266 * config/arm/arm.md (nonsecure_call_internal): Do not force memory
13267 address in r4 when targeting Armv8.1-M Mainline.
13268 (nonsecure_call_value_internal): Likewise.
13269 * config/arm/thumb2.md (nonsecure_call_reg_thumb2): Make memory address
13270 a register match_operand again. Emit BLXNS when targeting
13271 Armv8.1-M Mainline.
13272 (nonsecure_call_value_reg_thumb2): Likewise.
13273
13274 2020-01-16 Mihail-Calin Ionescu <mihail.ionescu@arm.com>
13275 Thomas Preud'homme <thomas.preudhomme@arm.com>
13276
13277 * config/arm/arm.c (arm_add_cfa_adjust_cfa_note): Declare early.
13278 (cmse_nonsecure_call_inline_register_clear): Define new lazy_fpclear
13279 variable as true when floating-point ABI is not hard. Replace
13280 check against TARGET_HARD_FLOAT_ABI by checks against lazy_fpclear.
13281 Generate VLSTM and VLLDM instruction respectively before and
13282 after a function call to cmse_nonsecure_call function.
13283 * config/arm/unspecs.md (VUNSPEC_VLSTM): Define unspec.
13284 (VUNSPEC_VLLDM): Likewise.
13285 * config/arm/vfp.md (lazy_store_multiple_insn): New define_insn.
13286 (lazy_load_multiple_insn): Likewise.
13287
13288 2020-01-16 Mihail-Calin Ionescu <mihail.ionescu@arm.com>
13289 Thomas Preud'homme <thomas.preudhomme@arm.com>
13290
13291 * config/arm/arm.c (vfp_emit_fstmd): Declare early.
13292 (arm_emit_vfp_multi_reg_pop): Likewise.
13293 (cmse_nonsecure_call_inline_register_clear): Abstract number of VFP
13294 registers to clear in max_fp_regno. Emit VPUSH and VPOP to save and
13295 restore callee-saved VFP registers.
13296
13297 2020-01-16 Mihail-Calin Ionescu <mihail.ionescu@arm.com>
13298 Thomas Preud'homme <thomas.preudhomme@arm.com>
13299
13300 * config/arm/arm.c (arm_emit_multi_reg_pop): Declare early.
13301 (cmse_nonsecure_call_clear_caller_saved): Rename into ...
13302 (cmse_nonsecure_call_inline_register_clear): This. Save and clear
13303 callee-saved GPRs as well as clear ip register before doing a nonsecure
13304 call then restore callee-saved GPRs after it when targeting
13305 Armv8.1-M Mainline.
13306 (arm_reorg): Adapt to function rename.
13307
13308 2020-01-16 Mihail-Calin Ionescu <mihail.ionescu@arm.com>
13309 Thomas Preud'homme <thomas.preudhomme@arm.com>
13310
13311 * config/arm/arm-protos.h (clear_operation_p): Adapt prototype.
13312 * config/arm/arm.c (clear_operation_p): Extend to be able to check a
13313 clear_vfp_multiple pattern based on a new vfp parameter.
13314 (cmse_clear_registers): Generate VSCCLRM to clear VFP registers when
13315 targeting Armv8.1-M Mainline.
13316 (cmse_nonsecure_entry_clear_before_return): Clear VFP registers
13317 unconditionally when targeting Armv8.1-M Mainline architecture. Check
13318 whether VFP registers are available before looking call_used_regs for a
13319 VFP register.
13320 * config/arm/predicates.md (clear_multiple_operation): Adapt to change
13321 of prototype of clear_operation_p.
13322 (clear_vfp_multiple_operation): New predicate.
13323 * config/arm/unspecs.md (VUNSPEC_VSCCLRM_VPR): New volatile unspec.
13324 * config/arm/vfp.md (clear_vfp_multiple): New define_insn.
13325
13326 2020-01-16 Mihail-Calin Ionescu <mihail.ionescu@arm.com>
13327 Thomas Preud'homme <thomas.preudhomme@arm.com>
13328
13329 * config/arm/arm-protos.h (clear_operation_p): Declare.
13330 * config/arm/arm.c (clear_operation_p): New function.
13331 (cmse_clear_registers): Generate clear_multiple instruction pattern if
13332 targeting Armv8.1-M Mainline or successor.
13333 (output_return_instruction): Only output APSR register clearing if
13334 Armv8.1-M Mainline instructions not available.
13335 (thumb_exit): Likewise.
13336 * config/arm/predicates.md (clear_multiple_operation): New predicate.
13337 * config/arm/thumb2.md (clear_apsr): New define_insn.
13338 (clear_multiple): Likewise.
13339 * config/arm/unspecs.md (VUNSPEC_CLRM_APSR): New volatile unspec.
13340
13341 2020-01-16 Mihail-Calin Ionescu <mihail.ionescu@arm.com>
13342 Thomas Preud'homme <thomas.preudhomme@arm.com>
13343
13344 * config/arm/arm.c (fp_sysreg_names): Declare and define.
13345 (use_return_insn): Also return false for Armv8.1-M Mainline.
13346 (output_return_instruction): Skip FPSCR clearing if Armv8.1-M
13347 Mainline instructions are available.
13348 (arm_compute_frame_layout): Allocate space in frame for FPCXTNS
13349 when targeting Armv8.1-M Mainline Security Extensions.
13350 (arm_expand_prologue): Save FPCXTNS if this is an Armv8.1-M
13351 Mainline entry function.
13352 (cmse_nonsecure_entry_clear_before_return): Clear IP and r4 if
13353 targeting Armv8.1-M Mainline or successor.
13354 (arm_expand_epilogue): Fix indentation of caller-saved register
13355 clearing. Restore FPCXTNS if this is an Armv8.1-M Mainline
13356 entry function.
13357 * config/arm/arm.h (TARGET_HAVE_FP_CMSE): New macro.
13358 (FP_SYSREGS): Likewise.
13359 (enum vfp_sysregs_encoding): Define enum.
13360 (fp_sysreg_names): Declare.
13361 * config/arm/unspecs.md (VUNSPEC_VSTR_VLDR): New volatile unspec.
13362 * config/arm/vfp.md (push_fpsysreg_insn): New define_insn.
13363 (pop_fpsysreg_insn): Likewise.
13364
13365 2020-01-16 Mihail-Calin Ionescu <mihail.ionescu@arm.com>
13366 Thomas Preud'homme <thomas.preudhomme@arm.com>
13367
13368 * config/arm/arm-cpus.in (armv8_1m_main): New feature.
13369 (ARMv4, ARMv4t, ARMv5t, ARMv5te, ARMv5tej, ARMv6, ARMv6j, ARMv6k,
13370 ARMv6z, ARMv6kz, ARMv6zk, ARMv6t2, ARMv6m, ARMv7, ARMv7a, ARMv7ve,
13371 ARMv7r, ARMv7m, ARMv7em, ARMv8a, ARMv8_1a, ARMv8_2a, ARMv8_3a,
13372 ARMv8_4a, ARMv8_5a, ARMv8m_base, ARMv8m_main, ARMv8r): Reindent.
13373 (ARMv8_1m_main): New feature group.
13374 (armv8.1-m.main): New architecture.
13375 * config/arm/arm-tables.opt: Regenerate.
13376 * config/arm/arm.c (arm_arch8_1m_main): Define and default initialize.
13377 (arm_option_reconfigure_globals): Initialize arm_arch8_1m_main.
13378 (arm_options_perform_arch_sanity_checks): Error out when targeting
13379 Armv8.1-M Mainline Security Extensions.
13380 * config/arm/arm.h (arm_arch8_1m_main): Declare.
13381
13382 2020-01-16 Stam Markianos-Wright <stam.markianos-wright@arm.com>
13383
13384 * config/aarch64/aarch64-simd-builtins.def (aarch64_bfdot,
13385 aarch64_bfdot_lane, aarch64_bfdot_laneq): New.
13386 * config/aarch64/aarch64-simd.md (aarch64_bfdot, aarch64_bfdot_lane,
13387 aarch64_bfdot_laneq): New.
13388 * config/aarch64/arm_bf16.h (vbfdot_f32, vbfdotq_f32,
13389 vbfdot_lane_f32, vbfdotq_lane_f32, vbfdot_laneq_f32,
13390 vbfdotq_laneq_f32): New.
13391 * config/aarch64/iterators.md (UNSPEC_BFDOT, Vbfdottype,
13392 VBFMLA_W, VBF): New.
13393 (isquadop): Add V4BF, V8BF.
13394
13395 2020-01-16 Stam Markianos-Wright <stam.markianos-wright@arm.com>
13396
13397 * config/aarch64/aarch64-builtins.c: (enum aarch64_type_qualifiers):
13398 New qualifier_lane_quadtup_index, TYPES_TERNOP_SSUS,
13399 TYPES_QUADOPSSUS_LANE_QUADTUP, TYPES_QUADOPSSSU_LANE_QUADTUP.
13400 (aarch64_simd_expand_args): Add case SIMD_ARG_LANE_QUADTUP_INDEX.
13401 (aarch64_simd_expand_builtin): Add qualifier_lane_quadtup_index.
13402 * config/aarch64/aarch64-simd-builtins.def (usdot, usdot_lane,
13403 usdot_laneq, sudot_lane,sudot_laneq): New.
13404 * config/aarch64/aarch64-simd.md (aarch64_usdot): New.
13405 (aarch64_<sur>dot_lane): New.
13406 * config/aarch64/arm_neon.h (vusdot_s32): New.
13407 (vusdotq_s32): New.
13408 (vusdot_lane_s32): New.
13409 (vsudot_lane_s32): New.
13410 * config/aarch64/iterators.md (DOTPROD_I8MM): New iterator.
13411 (UNSPEC_USDOT, UNSPEC_SUDOT): New unspecs.
13412
13413 2020-01-16 Martin Liska <mliska@suse.cz>
13414
13415 * value-prof.c (dump_histogram_value): Fix
13416 obvious spacing issue.
13417
13418 2020-01-16 Andrew Pinski <apinski@marvell.com>
13419
13420 * tree-ssa-sccvn.c(vn_reference_lookup_3): Check lhs for
13421 !storage_order_barrier_p.
13422
13423 2020-01-16 Andrew Pinski <apinski@marvell.com>
13424
13425 * sched-int.h (_dep): Add unused bit-field field for the padding.
13426 * sched-deps.c (init_dep_1): Init unused field.
13427
13428 2020-01-16 Andrew Pinski <apinski@marvell.com>
13429
13430 * optabs.h (create_expand_operand): Initialize target field also.
13431
13432 2020-01-16 Andre Vieira <andre.simoesdiasvieira@arm.com>
13433
13434 PR tree-optimization/92429
13435 * tree-ssa-loop-niter.h (simplify_replace_tree): Add parameter.
13436 * tree-ssa-loop-niter.c (simplify_replace_tree): Add parameter to
13437 control folding.
13438 * tree-vect-loop.c (update_epilogue_vinfo): Do not fold when replacing
13439 tree.
13440
13441 2020-01-16 Richard Sandiford <richard.sandiford@arm.com>
13442
13443 * config/aarch64/aarch64.c (aarch64_split_sve_subreg_move): Apply
13444 aarch64_sve_int_mode to each mode.
13445
13446 2020-01-15 David Malcolm <dmalcolm@redhat.com>
13447
13448 * doc/analyzer.texi (Overview): Add note about
13449 -fdump-ipa-analyzer.
13450
13451 2020-01-15 Wilco Dijkstra <wdijkstr@arm.com>
13452
13453 PR tree-optimization/93231
13454 * tree-ssa-forwprop.c (optimize_count_trailing_zeroes): Check
13455 input_type is unsigned. Use tree_to_shwi for shift constant.
13456 Check CST_STRING element size is CHAR_TYPE_SIZE bits.
13457 (simplify_count_trailing_zeroes): Add test to handle known non-zero
13458 inputs more efficiently.
13459
13460 2020-01-15 Uroš Bizjak <ubizjak@gmail.com>
13461
13462 * config/i386/i386.md (*movsf_internal): Do not require
13463 SSE2 ISA for alternatives 14 and 15.
13464
13465 2020-01-15 Richard Biener <rguenther@suse.de>
13466
13467 PR middle-end/93273
13468 * tree-eh.c (sink_clobbers): If we already visited the destination
13469 block do not defer insertion.
13470 (pass_lower_eh_dispatch::execute): Maintain BB_VISITED for
13471 the purpose of defered insertion.
13472
13473 2020-01-15 Jakub Jelinek <jakub@redhat.com>
13474
13475 * BASE-VER: Bump to 10.0.1.
13476
13477 2020-01-15 Richard Sandiford <richard.sandiford@arm.com>
13478
13479 PR tree-optimization/93247
13480 * tree-vect-loop.c (update_epilogue_loop_vinfo): Check the access
13481 type of the stmt that we're going to vectorize.
13482
13483 2020-01-15 Richard Sandiford <richard.sandiford@arm.com>
13484
13485 * tree-vect-slp.c (vectorize_slp_instance_root_stmt): Use a
13486 VIEW_CONVERT_EXPR if the vectorized constructor has a diffeent
13487 type from the lhs.
13488
13489 2020-01-15 Martin Liska <mliska@suse.cz>
13490
13491 * ipa-profile.c (ipa_profile_read_edge_summary): Do not allow
13492 2 calls of streamer_read_hwi in a function call.
13493
13494 2020-01-15 Richard Biener <rguenther@suse.de>
13495
13496 * alias.c (record_alias_subset): Avoid redundant work when
13497 subset is already recorded.
13498
13499 2020-01-14 David Malcolm <dmalcolm@redhat.com>
13500
13501 * doc/invoke.texi (-fdiagnostics-show-cwe): Add note that some of
13502 the analyzer options provide CWE identifiers.
13503
13504 2020-01-14 David Malcolm <dmalcolm@redhat.com>
13505
13506 * tree-diagnostic-path.cc (path_summary::event_range::print):
13507 When testing for UNKNOWN_LOCATION, look through ad-hoc wrappers
13508 using get_pure_location.
13509
13510 2020-01-15 Jakub Jelinek <jakub@redhat.com>
13511
13512 PR tree-optimization/93262
13513 * tree-ssa-dse.c (maybe_trim_memstar_call): For *_chk builtins,
13514 perform head trimming only if the last argument is constant,
13515 either all ones, or larger or equal to head trim, in the latter
13516 case decrease the last argument by head_trim.
13517
13518 PR tree-optimization/93249
13519 * tree-ssa-dse.c: Include builtins.h and gimple-fold.h.
13520 (maybe_trim_memstar_call): Move head_trim and tail_trim vars to
13521 function body scope, reindent. For BUILTIN_IN_STRNCPY*, don't
13522 perform head trim unless we can prove there are no '\0' chars
13523 from the source among the first head_trim chars.
13524
13525 2020-01-14 David Malcolm <dmalcolm@redhat.com>
13526
13527 * Makefile.in (ANALYZER_OBJS): Add analyzer/function-set.o.
13528
13529 2020-01-15 Jakub Jelinek <jakub@redhat.com>
13530
13531 PR target/93009
13532 * config/i386/sse.md
13533 (*<sd_mask_codefor>fma_fmadd_<mode><sd_maskz_name>_bcst_1,
13534 *<sd_mask_codefor>fma_fmsub_<mode><sd_maskz_name>_bcst_1,
13535 *<sd_mask_codefor>fma_fnmadd_<mode><sd_maskz_name>_bcst_1,
13536 *<sd_mask_codefor>fma_fnmsub_<mode><sd_maskz_name>_bcst_1): Use
13537 just a single alternative instead of two, make operands 1 and 2
13538 commutative.
13539
13540 2020-01-14 Jan Hubicka <hubicka@ucw.cz>
13541
13542 PR lto/91576
13543 * ipa-devirt.c (odr_types_equivalent_p): Compare TREE_ADDRESSABLE and
13544 TYPE_MODE.
13545
13546 2020-01-14 David Malcolm <dmalcolm@redhat.com>
13547
13548 * Makefile.in (lang_opt_files): Add analyzer.opt.
13549 (ANALYZER_OBJS): New.
13550 (OBJS): Add digraph.o, graphviz.o, ordered-hash-map-tests.o,
13551 tristate.o and ANALYZER_OBJS.
13552 (TEXI_GCCINT_FILES): Add analyzer.texi.
13553 * common.opt (-fanalyzer): New driver option.
13554 * config.in: Regenerate.
13555 * configure: Regenerate.
13556 * configure.ac (--disable-analyzer, ENABLE_ANALYZER): New option.
13557 (gccdepdir): Also create depdir for "analyzer" subdir.
13558 * digraph.cc: New file.
13559 * digraph.h: New file.
13560 * doc/analyzer.texi: New file.
13561 * doc/gccint.texi ("Static Analyzer") New menu item.
13562 (analyzer.texi): Include it.
13563 * doc/invoke.texi ("Static Analyzer Options"): New list and new section.
13564 ("Warning Options"): Add static analysis warnings to the list.
13565 (-Wno-analyzer-double-fclose): New option.
13566 (-Wno-analyzer-double-free): New option.
13567 (-Wno-analyzer-exposure-through-output-file): New option.
13568 (-Wno-analyzer-file-leak): New option.
13569 (-Wno-analyzer-free-of-non-heap): New option.
13570 (-Wno-analyzer-malloc-leak): New option.
13571 (-Wno-analyzer-possible-null-argument): New option.
13572 (-Wno-analyzer-possible-null-dereference): New option.
13573 (-Wno-analyzer-null-argument): New option.
13574 (-Wno-analyzer-null-dereference): New option.
13575 (-Wno-analyzer-stale-setjmp-buffer): New option.
13576 (-Wno-analyzer-tainted-array-index): New option.
13577 (-Wno-analyzer-use-after-free): New option.
13578 (-Wno-analyzer-use-of-pointer-in-stale-stack-frame): New option.
13579 (-Wno-analyzer-use-of-uninitialized-value): New option.
13580 (-Wanalyzer-too-complex): New option.
13581 (-fanalyzer-call-summaries): New warning.
13582 (-fanalyzer-checker=): New warning.
13583 (-fanalyzer-fine-grained): New warning.
13584 (-fno-analyzer-state-merge): New warning.
13585 (-fno-analyzer-state-purge): New warning.
13586 (-fanalyzer-transitivity): New warning.
13587 (-fanalyzer-verbose-edges): New warning.
13588 (-fanalyzer-verbose-state-changes): New warning.
13589 (-fanalyzer-verbosity=): New warning.
13590 (-fdump-analyzer): New warning.
13591 (-fdump-analyzer-callgraph): New warning.
13592 (-fdump-analyzer-exploded-graph): New warning.
13593 (-fdump-analyzer-exploded-nodes): New warning.
13594 (-fdump-analyzer-exploded-nodes-2): New warning.
13595 (-fdump-analyzer-exploded-nodes-3): New warning.
13596 (-fdump-analyzer-supergraph): New warning.
13597 * doc/sourcebuild.texi (dg-require-dot): New.
13598 (dg-check-dot): New.
13599 * gdbinit.in (break-on-saved-diagnostic): New command.
13600 * graphviz.cc: New file.
13601 * graphviz.h: New file.
13602 * ordered-hash-map-tests.cc: New file.
13603 * ordered-hash-map.h: New file.
13604 * passes.def (pass_analyzer): Add before
13605 pass_ipa_whole_program_visibility.
13606 * selftest-run-tests.c (selftest::run_tests): Call
13607 selftest::ordered_hash_map_tests_cc_tests.
13608 * selftest.h (selftest::ordered_hash_map_tests_cc_tests): New
13609 decl.
13610 * shortest-paths.h: New file.
13611 * timevar.def (TV_ANALYZER): New timevar.
13612 (TV_ANALYZER_SUPERGRAPH): Likewise.
13613 (TV_ANALYZER_STATE_PURGE): Likewise.
13614 (TV_ANALYZER_PLAN): Likewise.
13615 (TV_ANALYZER_SCC): Likewise.
13616 (TV_ANALYZER_WORKLIST): Likewise.
13617 (TV_ANALYZER_DUMP): Likewise.
13618 (TV_ANALYZER_DIAGNOSTICS): Likewise.
13619 (TV_ANALYZER_SHORTEST_PATHS): Likewise.
13620 * tree-pass.h (make_pass_analyzer): New decl.
13621 * tristate.cc: New file.
13622 * tristate.h: New file.
13623
13624 2020-01-14 Uroš Bizjak <ubizjak@gmail.com>
13625
13626 PR target/93254
13627 * config/i386/i386.md (*movsf_internal): Require SSE2 ISA for
13628 alternatives 9 and 10.
13629
13630 2020-01-14 David Malcolm <dmalcolm@redhat.com>
13631
13632 * attribs.c (excl_hash_traits::empty_zero_p): New static constant.
13633 * gcov.c (function_start_pair_hash::empty_zero_p): Likewise.
13634 * graphite.c (struct sese_scev_hash::empty_zero_p): Likewise.
13635 * hash-map-tests.c (selftest::test_nonzero_empty_key): New selftest.
13636 (selftest::hash_map_tests_c_tests): Call it.
13637 * hash-map-traits.h (simple_hashmap_traits::empty_zero_p):
13638 New static constant, using the value of = H::empty_zero_p.
13639 (unbounded_hashmap_traits::empty_zero_p): Likewise, using the value
13640 from default_hash_traits <Value>.
13641 * hash-map.h (hash_map::empty_zero_p): Likewise, using the value
13642 from Traits.
13643 * hash-set-tests.c (value_hash_traits::empty_zero_p): Likewise.
13644 * hash-table.h (hash_table::alloc_entries): Guard the loop of
13645 calls to mark_empty with !Descriptor::empty_zero_p.
13646 (hash_table::empty_slow): Conditionalize the memset call with a
13647 check that Descriptor::empty_zero_p; otherwise, loop through the
13648 entries calling mark_empty on them.
13649 * hash-traits.h (int_hash::empty_zero_p): New static constant.
13650 (pointer_hash::empty_zero_p): Likewise.
13651 (pair_hash::empty_zero_p): Likewise.
13652 * ipa-devirt.c (default_hash_traits <type_pair>::empty_zero_p):
13653 Likewise.
13654 * ipa-prop.c (ipa_bit_ggc_hash_traits::empty_zero_p): Likewise.
13655 (ipa_vr_ggc_hash_traits::empty_zero_p): Likewise.
13656 * profile.c (location_triplet_hash::empty_zero_p): Likewise.
13657 * sanopt.c (sanopt_tree_triplet_hash::empty_zero_p): Likewise.
13658 (sanopt_tree_couple_hash::empty_zero_p): Likewise.
13659 * tree-hasher.h (int_tree_hasher::empty_zero_p): Likewise.
13660 * tree-ssa-sccvn.c (vn_ssa_aux_hasher::empty_zero_p): Likewise.
13661 * tree-vect-slp.c (bst_traits::empty_zero_p): Likewise.
13662 * tree-vectorizer.h
13663 (default_hash_traits<scalar_cond_masked_key>::empty_zero_p):
13664 Likewise.
13665
13666 2020-01-14 Kewen Lin <linkw@gcc.gnu.org>
13667
13668 * cfgloopanal.c (average_num_loop_insns): Free bbs when early return,
13669 fix typo on return value.
13670
13671 2020-01-14 Xiong Hu Luo <luoxhu@linux.ibm.com>
13672
13673 PR ipa/69678
13674 * cgraph.c (symbol_table::create_edge): Init speculative_id and
13675 target_prob.
13676 (cgraph_edge::make_speculative): Add param for setting speculative_id
13677 and target_prob.
13678 (cgraph_edge::speculative_call_info): Update comments and find reference
13679 by speculative_id for multiple indirect targets.
13680 (cgraph_edge::resolve_speculation): Decrease the speculations
13681 for indirect edge, drop it's speculative if not direct target
13682 left. Update comments.
13683 (cgraph_edge::redirect_call_stmt_to_callee): Likewise.
13684 (cgraph_node::dump): Print num_speculative_call_targets.
13685 (cgraph_node::verify_node): Don't report error if speculative
13686 edge not include statement.
13687 (cgraph_edge::num_speculative_call_targets_p): New function.
13688 * cgraph.h (int common_target_id): Remove.
13689 (int common_target_probability): Remove.
13690 (num_speculative_call_targets): New variable.
13691 (make_speculative): Add param for setting speculative_id.
13692 (cgraph_edge::num_speculative_call_targets_p): New declare.
13693 (target_prob): New variable.
13694 (speculative_id): New variable.
13695 * ipa-fnsummary.c (analyze_function_body): Create and duplicate
13696 call summaries for multiple speculative call targets.
13697 * cgraphclones.c (cgraph_node::create_clone): Clone speculative_id.
13698 * ipa-profile.c (struct speculative_call_target): New struct.
13699 (class speculative_call_summary): New class.
13700 (class speculative_call_summaries): New class.
13701 (call_sums): New variable.
13702 (ipa_profile_generate_summary): Generate indirect multiple targets summaries.
13703 (ipa_profile_write_edge_summary): New function.
13704 (ipa_profile_write_summary): Stream out indirect multiple targets summaries.
13705 (ipa_profile_dump_all_summaries): New function.
13706 (ipa_profile_read_edge_summary): New function.
13707 (ipa_profile_read_summary_section): New function.
13708 (ipa_profile_read_summary): Stream in indirect multiple targets summaries.
13709 (ipa_profile): Generate num_speculative_call_targets from
13710 profile summaries.
13711 * ipa-ref.h (speculative_id): New variable.
13712 * ipa-utils.c (ipa_merge_profiles): Update with target_prob.
13713 * lto-cgraph.c (lto_output_edge): Remove indirect common_target_id and
13714 common_target_probability. Stream out speculative_id and
13715 num_speculative_call_targets.
13716 (input_edge): Likewise.
13717 * predict.c (dump_prediction): Remove edges count assert to be
13718 precise.
13719 * symtab.c (symtab_node::create_reference): Init speculative_id.
13720 (symtab_node::clone_references): Clone speculative_id.
13721 (symtab_node::clone_referring): Clone speculative_id.
13722 (symtab_node::clone_reference): Clone speculative_id.
13723 (symtab_node::clear_stmts_in_references): Clear speculative_id.
13724 * tree-inline.c (copy_bb): Duplicate all the speculative edges
13725 if indirect call contains multiple speculative targets.
13726 * value-prof.h (check_ic_target): Remove.
13727 * value-prof.c (gimple_value_profile_transformations):
13728 Use void function gimple_ic_transform.
13729 * value-prof.c (gimple_ic_transform): Handle topn case.
13730 Fix comment typos. Change it to a void function.
13731
13732 2020-01-13 Andrew Pinski <apinski@marvell.com>
13733
13734 * config/aarch64/aarch64-cores.def (octeontx2): New define.
13735 (octeontx2t98): New define.
13736 (octeontx2t96): New define.
13737 (octeontx2t93): New define.
13738 (octeontx2f95): New define.
13739 (octeontx2f95n): New define.
13740 (octeontx2f95mm): New define.
13741 * config/aarch64/aarch64-tune.md: Regenerate.
13742 * doc/invoke.texi (-mcpu=): Document the new cpu types.
13743
13744 2020-01-13 Jason Merrill <jason@redhat.com>
13745
13746 PR c++/33799 - destroy return value if local cleanup throws.
13747 * gimplify.c (gimplify_return_expr): Handle COMPOUND_EXPR.
13748
13749 2020-01-13 Martin Liska <mliska@suse.cz>
13750
13751 * ipa-cp.c (get_max_overall_size): Use newly
13752 renamed param param_ipa_cp_unit_growth.
13753 * params.opt: Remove legacy param name.
13754
13755 2020-01-13 Martin Sebor <msebor@redhat.com>
13756
13757 PR tree-optimization/93213
13758 * tree-ssa-strlen.c (handle_store): Only allow single-byte nul-over-nul
13759 stores to be eliminated.
13760
13761 2020-01-13 Martin Liska <mliska@suse.cz>
13762
13763 * opts.c (print_help): Do not print CL_PARAM
13764 and CL_WARNING for CL_OPTIMIZATION.
13765
13766 2020-01-13 Jonathan Wakely <jwakely@redhat.com>
13767
13768 PR driver/92757
13769 * doc/invoke.texi (Warning Options): Add caveat about some warnings
13770 depending on optimization settings.
13771
13772 2020-01-13 Jakub Jelinek <jakub@redhat.com>
13773
13774 PR tree-optimization/90838
13775 * tree-ssa-forwprop.c (simplify_count_trailing_zeroes): Use
13776 SCALAR_INT_TYPE_MODE directly in CTZ_DEFINED_VALUE_AT_ZERO macro
13777 argument rather than to initialize temporary for targets that
13778 don't use the mode argument at all. Initialize ctzval to avoid
13779 warning at -O0.
13780
13781 2020-01-10 Thomas Schwinge <thomas@codesourcery.com>
13782
13783 * tree.h (OMP_CLAUSE_USE_DEVICE_PTR_IF_PRESENT): New definition.
13784 * tree-core.h: Document it.
13785 * gimplify.c (gimplify_omp_workshare): Set it.
13786 * omp-low.c (lower_omp_target): Use it.
13787 * tree-pretty-print.c (dump_omp_clause): Print it.
13788
13789 * omp-low.c (lower_omp_target) <OMP_CLAUSE_USE_DEVICE_PTR etc.>:
13790 Assert that for OpenACC we always have 'GOMP_MAP_USE_DEVICE_PTR'.
13791
13792 2020-01-10 David Malcolm <dmalcolm@redhat.com>
13793
13794 * Makefile.in (OBJS): Add tree-diagnostic-path.o.
13795 * common.opt (fdiagnostics-path-format=): New option.
13796 (diagnostic_path_format): New enum.
13797 (fdiagnostics-show-path-depths): New option.
13798 * coretypes.h (diagnostic_event_id_t): New forward decl.
13799 * diagnostic-color.c (color_dict): Add "path".
13800 * diagnostic-event-id.h: New file.
13801 * diagnostic-format-json.cc (json_from_expanded_location): Make
13802 non-static.
13803 (json_end_diagnostic): Call context->make_json_for_path if it
13804 exists and the diagnostic has a path.
13805 (diagnostic_output_format_init): Clear context->print_path.
13806 * diagnostic-path.h: New file.
13807 * diagnostic-show-locus.c (colorizer::set_range): Special-case
13808 when printing a run of events in a diagnostic_path so that they
13809 all get the same color.
13810 (layout::m_diagnostic_path_p): New field.
13811 (layout::layout): Initialize it.
13812 (layout::print_any_labels): Don't colorize the label text for an
13813 event in a diagnostic_path.
13814 (gcc_rich_location::add_location_if_nearby): Add
13815 "restrict_to_current_line_spans" and "label" params. Pass the
13816 former to layout.maybe_add_location_range; pass the latter
13817 when calling add_range.
13818 * diagnostic.c: Include "diagnostic-path.h".
13819 (diagnostic_initialize): Initialize context->path_format and
13820 context->show_path_depths.
13821 (diagnostic_show_any_path): New function.
13822 (diagnostic_path::interprocedural_p): New function.
13823 (diagnostic_report_diagnostic): Call diagnostic_show_any_path.
13824 (simple_diagnostic_path::num_events): New function.
13825 (simple_diagnostic_path::get_event): New function.
13826 (simple_diagnostic_path::add_event): New function.
13827 (simple_diagnostic_event::simple_diagnostic_event): New ctor.
13828 (simple_diagnostic_event::~simple_diagnostic_event): New dtor.
13829 (debug): New overload taking a diagnostic_path *.
13830 * diagnostic.def (DK_DIAGNOSTIC_PATH): New.
13831 * diagnostic.h (enum diagnostic_path_format): New enum.
13832 (json::value): New forward decl.
13833 (diagnostic_context::path_format): New field.
13834 (diagnostic_context::show_path_depths): New field.
13835 (diagnostic_context::print_path): New callback field.
13836 (diagnostic_context::make_json_for_path): New callback field.
13837 (diagnostic_show_any_path): New decl.
13838 (json_from_expanded_location): New decl.
13839 * doc/invoke.texi (-fdiagnostics-path-format=): New option.
13840 (-fdiagnostics-show-path-depths): New option.
13841 (-fdiagnostics-color): Add "path" to description of default
13842 GCC_COLORS; describe it.
13843 (-fdiagnostics-format=json): Document how diagnostic paths are
13844 represented in the JSON output format.
13845 * gcc-rich-location.h (gcc_rich_location::add_location_if_nearby):
13846 Add optional params "restrict_to_current_line_spans" and "label".
13847 * opts.c (common_handle_option): Handle
13848 OPT_fdiagnostics_path_format_ and
13849 OPT_fdiagnostics_show_path_depths.
13850 * pretty-print.c: Include "diagnostic-event-id.h".
13851 (pp_format): Implement "%@" format code for printing
13852 diagnostic_event_id_t *.
13853 (selftest::test_pp_format): Add tests for "%@".
13854 * selftest-run-tests.c (selftest::run_tests): Call
13855 selftest::tree_diagnostic_path_cc_tests.
13856 * selftest.h (selftest::tree_diagnostic_path_cc_tests): New decl.
13857 * toplev.c (general_init): Initialize global_dc->path_format and
13858 global_dc->show_path_depths.
13859 * tree-diagnostic-path.cc: New file.
13860 * tree-diagnostic.c (maybe_unwind_expanded_macro_loc): Make
13861 non-static. Drop "diagnostic" param in favor of storing the
13862 original value of "where" and re-using it.
13863 (virt_loc_aware_diagnostic_finalizer): Update for dropped param of
13864 maybe_unwind_expanded_macro_loc.
13865 (tree_diagnostics_defaults): Initialize context->print_path and
13866 context->make_json_for_path.
13867 * tree-diagnostic.h (default_tree_diagnostic_path_printer): New
13868 decl.
13869 (default_tree_make_json_for_path): New decl.
13870 (maybe_unwind_expanded_macro_loc): New decl.
13871
13872 2020-01-10 Jakub Jelinek <jakub@redhat.com>
13873
13874 PR tree-optimization/93210
13875 * fold-const.h (native_encode_initializer,
13876 can_native_interpret_type_p): Declare.
13877 * fold-const.c (native_encode_string): Fix up handling with off != -1,
13878 simplify.
13879 (native_encode_initializer): New function, moved from dwarf2out.c.
13880 Adjust to native_encode_expr compatible arguments, including dry-run
13881 and partial extraction modes. Don't handle STRING_CST.
13882 (can_native_interpret_type_p): No longer static.
13883 * gimple-fold.c (fold_ctor_reference): For native_encode_expr, verify
13884 offset / BITS_PER_UNIT fits into int and don't call it if
13885 can_native_interpret_type_p fails. If suboff is NULL and for
13886 CONSTRUCTOR fold_{,non}array_ctor_reference returns NULL, retry with
13887 native_encode_initializer.
13888 (fold_const_aggregate_ref_1): Formatting fix.
13889 * dwarf2out.c (native_encode_initializer): Moved to fold-const.c.
13890 (tree_add_const_value_attribute): Adjust caller.
13891
13892 PR tree-optimization/90838
13893 * tree-ssa-forwprop.c (simplify_count_trailing_zeroes): Use
13894 SCALAR_INT_TYPE_MODE instead of TYPE_MODE as operand of
13895 CTZ_DEFINED_VALUE_AT_ZERO.
13896
13897 2020-01-10 Vladimir Makarov <vmakarov@redhat.com>
13898
13899 PR inline-asm/93027
13900 * lra-constraints.c (match_reload): Permit input operands have the
13901 same mode as output while other input operands have a different
13902 mode.
13903
13904 2020-01-10 Wilco Dijkstra <wdijkstr@arm.com>
13905
13906 PR tree-optimization/90838
13907 * tree-ssa-forwprop.c (check_ctz_array): Add new function.
13908 (check_ctz_string): Likewise.
13909 (optimize_count_trailing_zeroes): Likewise.
13910 (simplify_count_trailing_zeroes): Likewise.
13911 (pass_forwprop::execute): Try ctz simplification.
13912 * match.pd: Add matching for ctz idioms.
13913
13914 2020-01-10 Stam Markianos-Wright <stam.markianos-wright@arm.com>
13915
13916 * config/aarch64/aarch64.c (aarch64_invalid_conversion): New function
13917 for target hook.
13918 (aarch64_invalid_unary_op): New function for target hook.
13919 (aarch64_invalid_binary_op): New function for target hook.
13920
13921 2020-01-10 Stam Markianos-Wright <stam.markianos-wright@arm.com>
13922
13923 * config.gcc: Add arm_bf16.h.
13924 * config/aarch64/aarch64-builtins.c
13925 (aarch64_simd_builtin_std_type): Add BFmode.
13926 (aarch64_init_simd_builtin_types): Define element types for vector
13927 types.
13928 (aarch64_init_bf16_types): New function.
13929 (aarch64_general_init_builtins): Add arm_init_bf16_types function call.
13930 * config/aarch64/aarch64-modes.def: Add BFmode and V4BF, V8BF vector
13931 modes.
13932 * config/aarch64/aarch64-simd-builtin-types.def: Add BF SIMD types.
13933 * config/aarch64/aarch64-simd.md: Add BF vector types to NEON move
13934 patterns.
13935 * config/aarch64/aarch64.h (AARCH64_VALID_SIMD_DREG_MODE): Add V4BF.
13936 (AARCH64_VALID_SIMD_QREG_MODE): Add V8BF.
13937 * config/aarch64/aarch64.c
13938 (aarch64_classify_vector_mode): Add support for BF types.
13939 (aarch64_gimplify_va_arg_expr): Add support for BF types.
13940 (aarch64_vq_mode): Add support for BF types.
13941 (aarch64_simd_container_mode): Add support for BF types.
13942 (aarch64_mangle_type): Add support for BF scalar type.
13943 * config/aarch64/aarch64.md: Add BFmode to movhf pattern.
13944 * config/aarch64/arm_bf16.h: New file.
13945 * config/aarch64/arm_neon.h: Add arm_bf16.h and Bfloat vector types.
13946 * config/aarch64/iterators.md: Add BF types to mode attributes.
13947 (HFBF, GPF_TF_F16_MOV, VDMOV, VQMOV, VQMOV_NO2Em VALL_F16MOV): New.
13948
13949 2020-01-10 Jason Merrill <jason@redhat.com>
13950
13951 PR c++/93173 - incorrect tree sharing.
13952 * gimplify.c (copy_if_shared): No longer static.
13953 * gimplify.h: Declare it.
13954
13955 2020-01-10 Richard Sandiford <richard.sandiford@arm.com>
13956
13957 * doc/invoke.texi (-msve-vector-bits=): Document that
13958 -msve-vector-bits=128 now generates VL-specific code for
13959 little-endian targets.
13960 * config/aarch64/aarch64-sve-builtins.cc (register_builtin_types): Use
13961 build_vector_type_for_mode to construct the data vector types.
13962 * config/aarch64/aarch64.c (aarch64_convert_sve_vector_bits): Generate
13963 VL-specific code for -msve-vector-bits=128 on little-endian targets.
13964 (aarch64_simd_container_mode): Always prefer Advanced SIMD modes
13965 for 128-bit vectors.
13966
13967 2020-01-10 Richard Sandiford <richard.sandiford@arm.com>
13968
13969 * config/aarch64/aarch64.c (aarch64_evpc_sel): Fix gen_vcond_mask
13970 invocation.
13971
13972 2020-01-10 Richard Sandiford <richard.sandiford@arm.com>
13973
13974 * config/aarch64/aarch64-builtins.c
13975 (aarch64_builtin_vectorized_function): Check for specific vector modes,
13976 rather than checking the number of elements and the element mode.
13977
13978 2020-01-10 Richard Sandiford <richard.sandiford@arm.com>
13979
13980 * tree-vect-loop.c (vect_create_epilog_for_reduction): Use
13981 get_related_vectype_for_scalar_type rather than build_vector_type
13982 to create the index type for a conditional reduction.
13983
13984 2020-01-10 Richard Sandiford <richard.sandiford@arm.com>
13985
13986 * tree-vect-loop.c (update_epilogue_loop_vinfo): Update DR_REF
13987 for any type of gather or scatter, including strided accesses.
13988
13989 2020-01-10 Andre Vieira <andre.simoesdiasvieira@arm.com>
13990
13991 * tree-vectorizer.h (get_dr_vinfo_offset): Add missing function
13992 comment.
13993
13994 2020-01-10 Andre Vieira <andre.simoesdiasvieira@arm.com>
13995
13996 * tree-vect-data-refs.c (vect_create_addr_base_for_vector_ref): Use
13997 get_dr_vinfo_offset
13998 * tree-vect-loop.c (update_epilogue_loop_vinfo): Remove orig_drs_init
13999 parameter and its use to reset DR_OFFSET's.
14000 (vect_transform_loop): Remove orig_drs_init argument.
14001 * tree-vect-loop-manip.c (vect_update_init_of_dr): Update the offset
14002 member of dr_vec_info rather than the offset of the associated
14003 data_reference's innermost_loop_behavior.
14004 (vect_update_init_of_dr): Pass dr_vec_info instead of data_reference.
14005 (vect_do_peeling): Remove orig_drs_init parameter and its construction.
14006 * tree-vect-stmts.c (check_scan_store): Replace use of DR_OFFSET with
14007 get_dr_vinfo_offset.
14008 (vectorizable_store): Likewise.
14009 (vectorizable_load): Likewise.
14010
14011 2020-01-10 Richard Biener <rguenther@suse.de>
14012
14013 * gimple-ssa-store-merging
14014 (pass_store_merging::terminate_all_aliasing_chains): Cache alias info.
14015
14016 2020-01-10 Martin Liska <mliska@suse.cz>
14017
14018 PR ipa/93217
14019 * ipa-inline-analysis.c (offline_size): Make proper parenthesis
14020 encapsulation that was there before r280040.
14021
14022 2020-01-10 Richard Biener <rguenther@suse.de>
14023
14024 PR middle-end/93199
14025 * tree-eh.c (sink_clobbers): Move clobbers to out-of-IL
14026 sequences to avoid walking them again for secondary opportunities.
14027 (pass_lower_eh_dispatch::execute): Instead actually insert
14028 them here.
14029
14030 2020-01-10 Richard Biener <rguenther@suse.de>
14031
14032 PR middle-end/93199
14033 * tree-eh.c (redirect_eh_edge_1): Avoid some work if possible.
14034 (cleanup_all_empty_eh): Walk landing pads in reverse order to
14035 avoid quadraticness.
14036
14037 2020-01-10 Martin Jambor <mjambor@suse.cz>
14038
14039 * params.opt (param_ipa_sra_max_replacements): Mark as Optimization.
14040 * ipa-sra.c (pull_accesses_from_callee): New parameter caller, use it
14041 to get param_ipa_sra_max_replacements.
14042 (param_splitting_across_edge): Pass the caller to
14043 pull_accesses_from_callee.
14044
14045 2020-01-10 Martin Jambor <mjambor@suse.cz>
14046
14047 * params.opt (param_ipcp_unit_growth): Mark as Optimization.
14048 * ipa-cp.c (max_new_size): Removed.
14049 (orig_overall_size): New variable.
14050 (get_max_overall_size): New function.
14051 (estimate_local_effects): Use it. Adjust dump.
14052 (decide_about_value): Likewise.
14053 (ipcp_propagate_stage): Do not calculate max_new_size, just store
14054 orig_overall_size. Adjust dump.
14055 (ipa_cp_c_finalize): Clear orig_overall_size instead of max_new_size.
14056
14057 2020-01-10 Martin Jambor <mjambor@suse.cz>
14058
14059 * params.opt (param_ipa_max_agg_items): Mark as Optimization
14060 * ipa-cp.c (merge_agg_lats_step): New parameter max_agg_items, use
14061 instead of param_ipa_max_agg_items.
14062 (merge_aggregate_lattices): Extract param_ipa_max_agg_items from
14063 optimization info for the callee.
14064
14065 2020-01-09 Kwok Cheung Yeung <kcy@codesourcery.com>
14066
14067 * lto-streamer-in.c (input_function): Remove streamed-in inline debug
14068 markers if debug_inline_points is false.
14069
14070 2020-01-09 Richard Sandiford <richard.sandiford@arm.com>
14071
14072 * config.gcc (aarch64*-*-*): Add aarch64-sve-builtins-sve2.o to
14073 extra_objs.
14074 * config/aarch64/t-aarch64 (aarch64-sve-builtins.o): Depend on
14075 aarch64-sve-builtins-base.def, aarch64-sve-builtins-sve2.def and
14076 aarch64-sve-builtins-sve2.h.
14077 (aarch64-sve-builtins-sve2.o): New rule.
14078 * config/aarch64/aarch64.h (AARCH64_ISA_SVE2_AES): New macro.
14079 (AARCH64_ISA_SVE2_BITPERM, AARCH64_ISA_SVE2_SHA3): Likewise.
14080 (AARCH64_ISA_SVE2_SM4, TARGET_SVE2_AES, TARGET_SVE2_BITPERM): Likewise.
14081 (TARGET_SVE2_SHA, TARGET_SVE2_SM4): Likewise.
14082 * config/aarch64/aarch64-c.c (aarch64_update_cpp_builtins): Handle
14083 TARGET_SVE2_AES, TARGET_SVE2_BITPERM, TARGET_SVE2_SHA3 and
14084 TARGET_SVE2_SM4.
14085 * config/aarch64/aarch64-sve.md: Update comments with SVE2
14086 instructions that are handled here.
14087 (@cond_asrd<mode>): Generalize to...
14088 (@cond_<SVE_INT_SHIFT_IMM:sve_int_op><mode>): ...this.
14089 (*cond_asrd<mode>_2): Generalize to...
14090 (*cond_<SVE_INT_SHIFT_IMM:sve_int_op><mode>_2): ...this.
14091 (*cond_asrd<mode>_z): Generalize to...
14092 (*cond_<SVE_INT_SHIFT_IMM:sve_int_op><mode>_z): ...this.
14093 * config/aarch64/aarch64.md (UNSPEC_LDNT1_GATHER): New unspec.
14094 (UNSPEC_STNT1_SCATTER, UNSPEC_WHILEGE, UNSPEC_WHILEGT): Likewise.
14095 (UNSPEC_WHILEHI, UNSPEC_WHILEHS): Likewise.
14096 * config/aarch64/aarch64-sve2.md (@aarch64_gather_ldnt<mode>): New
14097 pattern.
14098 (@aarch64_gather_ldnt_<ANY_EXTEND:optab><SVE_FULL_SDI:mode><SVE_PARTIAL_I:mode>)
14099 (@aarch64_scatter_stnt<mode>): Likewise.
14100 (@aarch64_scatter_stnt_<SVE_FULL_SDI:mode><SVE_PARTIAL_I:mode>)
14101 (@aarch64_mul_lane_<mode>): Likewise.
14102 (@aarch64_sve_suqadd<mode>_const): Likewise.
14103 (*<sur>h<addsub><mode>): Generalize to...
14104 (@aarch64_pred_<SVE2_COND_INT_BINARY_REV:sve_int_op><mode>): ...this
14105 new pattern.
14106 (@cond_<SVE2_COND_INT_BINARY:sve_int_op><mode>): New expander.
14107 (*cond_<SVE2_COND_INT_BINARY:sve_int_op><mode>_2): New pattern.
14108 (*cond_<SVE2_COND_INT_BINARY:sve_int_op><mode>_3): Likewise.
14109 (*cond_<SVE2_COND_INT_BINARY:sve_int_op><mode>_any): Likewise.
14110 (*cond_<SVE2_COND_INT_BINARY_NOREV:sve_int_op><mode>_z): Likewise.
14111 (@aarch64_sve_<SVE2_INT_BINARY:sve_int_op><mode>):: Likewise.
14112 (@aarch64_sve_<SVE2_INT_BINARY:sve_int_op>_lane_<mode>): Likewise.
14113 (@aarch64_pred_<SVE2_COND_INT_SHIFT:sve_int_op><mode>): Likewise.
14114 (@cond_<SVE2_COND_INT_SHIFT:sve_int_op><mode>): New expander.
14115 (*cond_<SVE2_COND_INT_SHIFT:sve_int_op><mode>_2): New pattern.
14116 (*cond_<SVE2_COND_INT_SHIFT:sve_int_op><mode>_3): Likewise.
14117 (*cond_<SVE2_COND_INT_SHIFT:sve_int_op><mode>_any): Likewise.
14118 (@aarch64_sve_<SVE2_INT_TERNARY:sve_int_op><mode>): Likewise.
14119 (@aarch64_sve_<SVE2_INT_TERNARY_LANE:sve_int_op>_lane_<mode>)
14120 (@aarch64_sve_add_mul_lane_<mode>): Likewise.
14121 (@aarch64_sve_sub_mul_lane_<mode>): Likewise.
14122 (@aarch64_sve2_xar<mode>): Likewise.
14123 (@aarch64_sve2_bcax<mode>): Likewise.
14124 (*aarch64_sve2_eor3<mode>): Rename to...
14125 (@aarch64_sve2_eor3<mode>): ...this.
14126 (@aarch64_sve2_bsl<mode>): New expander.
14127 (@aarch64_sve2_nbsl<mode>): Likewise.
14128 (@aarch64_sve2_bsl1n<mode>): Likewise.
14129 (@aarch64_sve2_bsl2n<mode>): Likewise.
14130 (@aarch64_sve_add_<SHIFTRT:sve_int_op><mode>): Likewise.
14131 (*aarch64_sve2_sra<mode>): Add MOVPRFX support.
14132 (@aarch64_sve_add_<VRSHR_N:sve_int_op><mode>): New pattern.
14133 (@aarch64_sve_<SVE2_INT_SHIFT_INSERT:sve_int_op><mode>): Likewise.
14134 (@aarch64_sve2_<USMAX:su>aba<mode>): New expander.
14135 (*aarch64_sve2_<USMAX:su>aba<mode>): New pattern.
14136 (@aarch64_sve_<SVE2_INT_BINARY_WIDE:sve_int_op><mode>): Likewise.
14137 (<su>mull<bt><Vwide>): Generalize to...
14138 (@aarch64_sve_<SVE2_INT_BINARY_LONG:sve_int_op><mode>): ...this new
14139 pattern.
14140 (@aarch64_sve_<SVE2_INT_BINARY_LONG_lANE:sve_int_op>_lane_<mode>)
14141 (@aarch64_sve_<SVE2_INT_SHIFT_IMM_LONG:sve_int_op><mode>)
14142 (@aarch64_sve_add_<SVE2_INT_ADD_BINARY_LONG:sve_int_op><mode>)
14143 (@aarch64_sve_add_<SVE2_INT_ADD_BINARY_LONG_LANE:sve_int_op>_lane_<mode>)
14144 (@aarch64_sve_qadd_<SVE2_INT_QADD_BINARY_LONG:sve_int_op><mode>)
14145 (@aarch64_sve_qadd_<SVE2_INT_QADD_BINARY_LONG_LANE:sve_int_op>_lane_<mode>)
14146 (@aarch64_sve_sub_<SVE2_INT_SUB_BINARY_LONG:sve_int_op><mode>)
14147 (@aarch64_sve_sub_<SVE2_INT_SUB_BINARY_LONG_LANE:sve_int_op>_lane_<mode>)
14148 (@aarch64_sve_qsub_<SVE2_INT_QSUB_BINARY_LONG:sve_int_op><mode>)
14149 (@aarch64_sve_qsub_<SVE2_INT_QSUB_BINARY_LONG_LANE:sve_int_op>_lane_<mode>)
14150 (@aarch64_sve_<SVE2_FP_TERNARY_LONG:sve_fp_op><mode>): New patterns.
14151 (@aarch64_<SVE2_FP_TERNARY_LONG_LANE:sve_fp_op>_lane_<mode>)
14152 (@aarch64_sve_<SVE2_INT_UNARY_NARROWB:sve_int_op><mode>): Likewise.
14153 (@aarch64_sve_<SVE2_INT_UNARY_NARROWT:sve_int_op><mode>): Likewise.
14154 (@aarch64_sve_<SVE2_INT_BINARY_NARROWB:sve_int_op><mode>): Likewise.
14155 (@aarch64_sve_<SVE2_INT_BINARY_NARROWT:sve_int_op><mode>): Likewise.
14156 (<SHRNB:r>shrnb<mode>): Generalize to...
14157 (@aarch64_sve_<SVE2_INT_SHIFT_IMM_NARROWB:sve_int_op><mode>): ...this
14158 new pattern.
14159 (<SHRNT:r>shrnt<mode>): Generalize to...
14160 (@aarch64_sve_<SVE2_INT_SHIFT_IMM_NARROWT:sve_int_op><mode>): ...this
14161 new pattern.
14162 (@aarch64_pred_<SVE2_INT_BINARY_PAIR:sve_int_op><mode>): New pattern.
14163 (@aarch64_pred_<SVE2_FP_BINARY_PAIR:sve_fp_op><mode>): Likewise.
14164 (@cond_<SVE2_INT_BINARY_PAIR_LONG:sve_int_op><mode>): New expander.
14165 (*cond_<SVE2_INT_BINARY_PAIR_LONG:sve_int_op><mode>_2): New pattern.
14166 (*cond_<SVE2_INT_BINARY_PAIR_LONG:sve_int_op><mode>_z): Likewise.
14167 (@aarch64_sve_<SVE2_INT_CADD:optab><mode>): Likewise.
14168 (@aarch64_sve_<SVE2_INT_CMLA:optab><mode>): Likewise.
14169 (@aarch64_<SVE2_INT_CMLA:optab>_lane_<mode>): Likewise.
14170 (@aarch64_sve_<SVE2_INT_CDOT:optab><mode>): Likewise.
14171 (@aarch64_<SVE2_INT_CDOT:optab>_lane_<mode>): Likewise.
14172 (@aarch64_pred_<SVE2_COND_FP_UNARY_LONG:sve_fp_op><mode>): Likewise.
14173 (@cond_<SVE2_COND_FP_UNARY_LONG:sve_fp_op><mode>): New expander.
14174 (*cond_<SVE2_COND_FP_UNARY_LONG:sve_fp_op><mode>): New pattern.
14175 (@aarch64_sve2_cvtnt<mode>): Likewise.
14176 (@aarch64_pred_<SVE2_COND_FP_UNARY_NARROWB:sve_fp_op><mode>): Likewise.
14177 (@cond_<SVE2_COND_FP_UNARY_NARROWB:sve_fp_op><mode>): New expander.
14178 (*cond_<SVE2_COND_FP_UNARY_NARROWB:sve_fp_op><mode>_any): New pattern.
14179 (@aarch64_sve2_cvtxnt<mode>): Likewise.
14180 (@aarch64_pred_<SVE2_U32_UNARY:sve_int_op><mode>): Likewise.
14181 (@cond_<SVE2_U32_UNARY:sve_int_op><mode>): New expander.
14182 (*cond_<SVE2_U32_UNARY:sve_int_op><mode>): New pattern.
14183 (@aarch64_pred_<SVE2_COND_INT_UNARY_FP:sve_fp_op><mode>): Likewise.
14184 (@cond_<SVE2_COND_INT_UNARY_FP:sve_fp_op><mode>): New expander.
14185 (*cond_<SVE2_COND_INT_UNARY_FP:sve_fp_op><mode>): New pattern.
14186 (@aarch64_sve2_pmul<mode>): Likewise.
14187 (@aarch64_sve_<SVE2_PMULL:optab><mode>): Likewise.
14188 (@aarch64_sve_<SVE2_PMULL_PAIR:optab><mode>): Likewise.
14189 (@aarch64_sve2_tbl2<mode>): Likewise.
14190 (@aarch64_sve2_tbx<mode>): Likewise.
14191 (@aarch64_sve_<SVE2_INT_BITPERM:sve_int_op><mode>): Likewise.
14192 (@aarch64_sve2_histcnt<mode>): Likewise.
14193 (@aarch64_sve2_histseg<mode>): Likewise.
14194 (@aarch64_pred_<SVE2_MATCH:sve_int_op><mode>): Likewise.
14195 (*aarch64_pred_<SVE2_MATCH:sve_int_op><mode>_cc): Likewise.
14196 (*aarch64_pred_<SVE2_MATCH:sve_int_op><mode>_ptest): Likewise.
14197 (aarch64_sve2_aes<CRYPTO_AES:aes_op>): Likewise.
14198 (aarch64_sve2_aes<CRYPTO_AESMC:aesmc_op>): Likewise.
14199 (*aarch64_sve2_aese_fused, *aarch64_sve2_aesd_fused): Likewise.
14200 (aarch64_sve2_rax1, aarch64_sve2_sm4e, aarch64_sve2_sm4ekey): Likewise.
14201 (<su>mulh<r>s<mode>3): Update after above pattern name changes.
14202 * config/aarch64/iterators.md (VNx16QI_ONLY, VNx4SF_ONLY)
14203 (SVE_STRUCT2, SVE_FULL_BHI, SVE_FULL_HSI, SVE_FULL_HDI)
14204 (SVE2_PMULL_PAIR_I): New mode iterators.
14205 (UNSPEC_ADCLB, UNSPEC_ADCLT, UNSPEC_ADDHNB, UNSPEC_ADDHNT, UNSPEC_BDEP)
14206 (UNSPEC_BEXT, UNSPEC_BGRP, UNSPEC_CADD90, UNSPEC_CADD270, UNSPEC_CDOT)
14207 (UNSPEC_CDOT90, UNSPEC_CDOT180, UNSPEC_CDOT270, UNSPEC_CMLA)
14208 (UNSPEC_CMLA90, UNSPEC_CMLA180, UNSPEC_CMLA270, UNSPEC_COND_FCVTLT)
14209 (UNSPEC_COND_FCVTNT, UNSPEC_COND_FCVTX, UNSPEC_COND_FCVTXNT)
14210 (UNSPEC_COND_FLOGB, UNSPEC_EORBT, UNSPEC_EORTB, UNSPEC_FADDP)
14211 (UNSPEC_FMAXP, UNSPEC_FMAXNMP, UNSPEC_FMLALB, UNSPEC_FMLALT)
14212 (UNSPEC_FMLSLB, UNSPEC_FMLSLT, UNSPEC_FMINP, UNSPEC_FMINNMP)
14213 (UNSPEC_HISTCNT, UNSPEC_HISTSEG, UNSPEC_MATCH, UNSPEC_NMATCH)
14214 (UNSPEC_PMULLB, UNSPEC_PMULLB_PAIR, UNSPEC_PMULLT, UNSPEC_PMULLT_PAIR)
14215 (UNSPEC_RADDHNB, UNSPEC_RADDHNT, UNSPEC_RSUBHNB, UNSPEC_RSUBHNT)
14216 (UNSPEC_SLI, UNSPEC_SRI, UNSPEC_SABDLB, UNSPEC_SABDLT, UNSPEC_SADDLB)
14217 (UNSPEC_SADDLBT, UNSPEC_SADDLT, UNSPEC_SADDWB, UNSPEC_SADDWT)
14218 (UNSPEC_SBCLB, UNSPEC_SBCLT, UNSPEC_SMAXP, UNSPEC_SMINP)
14219 (UNSPEC_SQCADD90, UNSPEC_SQCADD270, UNSPEC_SQDMULLB, UNSPEC_SQDMULLBT)
14220 (UNSPEC_SQDMULLT, UNSPEC_SQRDCMLAH, UNSPEC_SQRDCMLAH90)
14221 (UNSPEC_SQRDCMLAH180, UNSPEC_SQRDCMLAH270, UNSPEC_SQRSHRNB)
14222 (UNSPEC_SQRSHRNT, UNSPEC_SQRSHRUNB, UNSPEC_SQRSHRUNT, UNSPEC_SQSHRNB)
14223 (UNSPEC_SQSHRNT, UNSPEC_SQSHRUNB, UNSPEC_SQSHRUNT, UNSPEC_SQXTNB)
14224 (UNSPEC_SQXTNT, UNSPEC_SQXTUNB, UNSPEC_SQXTUNT, UNSPEC_SSHLLB)
14225 (UNSPEC_SSHLLT, UNSPEC_SSUBLB, UNSPEC_SSUBLBT, UNSPEC_SSUBLT)
14226 (UNSPEC_SSUBLTB, UNSPEC_SSUBWB, UNSPEC_SSUBWT, UNSPEC_SUBHNB)
14227 (UNSPEC_SUBHNT, UNSPEC_TBL2, UNSPEC_UABDLB, UNSPEC_UABDLT)
14228 (UNSPEC_UADDLB, UNSPEC_UADDLT, UNSPEC_UADDWB, UNSPEC_UADDWT)
14229 (UNSPEC_UMAXP, UNSPEC_UMINP, UNSPEC_UQRSHRNB, UNSPEC_UQRSHRNT)
14230 (UNSPEC_UQSHRNB, UNSPEC_UQSHRNT, UNSPEC_UQXTNB, UNSPEC_UQXTNT)
14231 (UNSPEC_USHLLB, UNSPEC_USHLLT, UNSPEC_USUBLB, UNSPEC_USUBLT)
14232 (UNSPEC_USUBWB, UNSPEC_USUBWT): New unspecs.
14233 (UNSPEC_SMULLB, UNSPEC_SMULLT, UNSPEC_UMULLB, UNSPEC_UMULLT)
14234 (UNSPEC_SMULHS, UNSPEC_SMULHRS, UNSPEC_UMULHS, UNSPEC_UMULHRS)
14235 (UNSPEC_RSHRNB, UNSPEC_RSHRNT, UNSPEC_SHRNB, UNSPEC_SHRNT): Move
14236 further down file.
14237 (VNARROW, Ventype): New mode attributes.
14238 (Vewtype): Handle VNx2DI. Fix typo in comment.
14239 (VDOUBLE): New mode attribute.
14240 (sve_lane_con): Handle VNx8HI.
14241 (SVE_INT_UNARY): Include ss_abs and ss_neg for TARGET_SVE2.
14242 (SVE_INT_BINARY): Likewise ss_plus, us_plus, ss_minus and us_minus.
14243 (sve_int_op, sve_int_op_rev): Handle the above codes.
14244 (sve_pred_int_rhs2_operand): Likewise.
14245 (MULLBT, SHRNB, SHRNT): Delete.
14246 (SVE_INT_SHIFT_IMM): New int iterator.
14247 (SVE_WHILE): Add UNSPEC_WHILEGE, UNSPEC_WHILEGT, UNSPEC_WHILEHI
14248 and UNSPEC_WHILEHS for TARGET_SVE2.
14249 (SVE2_U32_UNARY, SVE2_INT_UNARY_NARROWB, SVE2_INT_UNARY_NARROWT)
14250 (SVE2_INT_BINARY, SVE2_INT_BINARY_LANE, SVE2_INT_BINARY_LONG)
14251 (SVE2_INT_BINARY_LONG_LANE, SVE2_INT_BINARY_NARROWB)
14252 (SVE2_INT_BINARY_NARROWT, SVE2_INT_BINARY_PAIR, SVE2_FP_BINARY_PAIR)
14253 (SVE2_INT_BINARY_PAIR_LONG, SVE2_INT_BINARY_WIDE): New int iterators.
14254 (SVE2_INT_SHIFT_IMM_LONG, SVE2_INT_SHIFT_IMM_NARROWB): Likewise.
14255 (SVE2_INT_SHIFT_IMM_NARROWT, SVE2_INT_SHIFT_INSERT, SVE2_INT_CADD)
14256 (SVE2_INT_BITPERM, SVE2_INT_TERNARY, SVE2_INT_TERNARY_LANE): Likewise.
14257 (SVE2_FP_TERNARY_LONG, SVE2_FP_TERNARY_LONG_LANE, SVE2_INT_CMLA)
14258 (SVE2_INT_CDOT, SVE2_INT_ADD_BINARY_LONG, SVE2_INT_QADD_BINARY_LONG)
14259 (SVE2_INT_SUB_BINARY_LONG, SVE2_INT_QSUB_BINARY_LONG): Likewise.
14260 (SVE2_INT_ADD_BINARY_LONG_LANE, SVE2_INT_QADD_BINARY_LONG_LANE)
14261 (SVE2_INT_SUB_BINARY_LONG_LANE, SVE2_INT_QSUB_BINARY_LONG_LANE)
14262 (SVE2_COND_INT_UNARY_FP, SVE2_COND_FP_UNARY_LONG): Likewise.
14263 (SVE2_COND_FP_UNARY_NARROWB, SVE2_COND_INT_BINARY): Likewise.
14264 (SVE2_COND_INT_BINARY_NOREV, SVE2_COND_INT_BINARY_REV): Likewise.
14265 (SVE2_COND_INT_SHIFT, SVE2_MATCH, SVE2_PMULL): Likewise.
14266 (optab): Handle the new unspecs.
14267 (su, r): Remove entries for UNSPEC_SHRNB, UNSPEC_SHRNT, UNSPEC_RSHRNB
14268 and UNSPEC_RSHRNT.
14269 (lr): Handle the new unspecs.
14270 (bt): Delete.
14271 (cmp_op, while_optab_cmp, sve_int_op): Handle the new unspecs.
14272 (sve_int_op_rev, sve_int_add_op, sve_int_qadd_op, sve_int_sub_op)
14273 (sve_int_qsub_op): New int attributes.
14274 (sve_fp_op, rot): Handle the new unspecs.
14275 * config/aarch64/aarch64-sve-builtins.h
14276 (function_resolver::require_matching_pointer_type): Declare.
14277 (function_resolver::resolve_unary): Add an optional boolean argument.
14278 (function_resolver::finish_opt_n_resolution): Add an optional
14279 type_suffix_index argument.
14280 (gimple_folder::redirect_call): Declare.
14281 (gimple_expander::prepare_gather_address_operands): Add an optional
14282 bool parameter.
14283 * config/aarch64/aarch64-sve-builtins.cc: Include
14284 aarch64-sve-builtins-sve2.h.
14285 (TYPES_b_unsigned, TYPES_b_integer, TYPES_bh_integer): New macros.
14286 (TYPES_bs_unsigned, TYPES_hs_signed, TYPES_hs_integer): Likewise.
14287 (TYPES_hd_unsigned, TYPES_hsd_signed): Likewise.
14288 (TYPES_hsd_integer): Use TYPES_hsd_signed.
14289 (TYPES_s_float_hsd_integer, TYPES_s_float_sd_integer): New macros.
14290 (TYPES_s_unsigned): Likewise.
14291 (TYPES_s_integer): Use TYPES_s_unsigned.
14292 (TYPES_sd_signed, TYPES_sd_unsigned): New macros.
14293 (TYPES_sd_integer): Use them.
14294 (TYPES_d_unsigned): New macro.
14295 (TYPES_d_integer): Use it.
14296 (TYPES_d_data, TYPES_cvt_long, TYPES_cvt_narrow_s): New macros.
14297 (TYPES_cvt_narrow): Likewise.
14298 (DEF_SVE_TYPES_ARRAY): Include the new types macros above.
14299 (preds_mx): New variable.
14300 (function_builder::add_overloaded_function): Allow the new feature
14301 set to be more restrictive than the original one.
14302 (function_resolver::infer_pointer_type): Remove qualifiers from
14303 the pointer type before printing it.
14304 (function_resolver::require_matching_pointer_type): New function.
14305 (function_resolver::resolve_sv_displacement): Handle functions
14306 that don't support 32-bit vector indices or svint32_t vector offsets.
14307 (function_resolver::finish_opt_n_resolution): Take the inferred type
14308 as a separate argument.
14309 (function_resolver::resolve_unary): Optionally treat all forms in
14310 the same way as normal merging functions.
14311 (gimple_folder::redirect_call): New function.
14312 (function_expander::prepare_gather_address_operands): Add an argument
14313 that says whether scaled forms are available. If they aren't,
14314 handle scaling of vector indices and don't add the extension and
14315 scaling operands.
14316 (function_expander::map_to_unspecs): If aarch64_sve isn't available,
14317 fall back to using cond_* instead.
14318 * config/aarch64/aarch64-sve-builtins-functions.h (rtx_code_function):
14319 Split out the member variables into...
14320 (rtx_code_function_base): ...this new base class.
14321 (rtx_code_function_rotated): Inherit rtx_code_function_base.
14322 (unspec_based_function): Split out the member variables into...
14323 (unspec_based_function_base): ...this new base class.
14324 (unspec_based_function_rotated): Inherit unspec_based_function_base.
14325 (unspec_based_function_exact_insn): New class.
14326 (unspec_based_add_function, unspec_based_add_lane_function)
14327 (unspec_based_lane_function, unspec_based_pred_function)
14328 (unspec_based_qadd_function, unspec_based_qadd_lane_function)
14329 (unspec_based_qsub_function, unspec_based_qsub_lane_function)
14330 (unspec_based_sub_function, unspec_based_sub_lane_function): New
14331 typedefs.
14332 (unspec_based_fused_function): New class.
14333 (unspec_based_mla_function, unspec_based_mls_function): New typedefs.
14334 (unspec_based_fused_lane_function): New class.
14335 (unspec_based_mla_lane_function, unspec_based_mls_lane_function): New
14336 typedefs.
14337 (CODE_FOR_MODE1): New macro.
14338 (fixed_insn_function): New class.
14339 (while_comparison): Likewise.
14340 * config/aarch64/aarch64-sve-builtins-shapes.h (binary_long_lane)
14341 (binary_long_opt_n, binary_narrowb_opt_n, binary_narrowt_opt_n)
14342 (binary_to_uint, binary_wide, binary_wide_opt_n, compare, compare_ptr)
14343 (load_ext_gather_index_restricted, load_ext_gather_offset_restricted)
14344 (load_gather_sv_restricted, shift_left_imm_long): Declare.
14345 (shift_left_imm_to_uint, shift_right_imm_narrowb): Likewise.
14346 (shift_right_imm_narrowt, shift_right_imm_narrowb_to_uint): Likewise.
14347 (shift_right_imm_narrowt_to_uint, store_scatter_index_restricted)
14348 (store_scatter_offset_restricted, tbl_tuple, ternary_long_lane)
14349 (ternary_long_opt_n, ternary_qq_lane_rotate, ternary_qq_rotate)
14350 (ternary_shift_left_imm, ternary_shift_right_imm, ternary_uint)
14351 (unary_convert_narrowt, unary_long, unary_narrowb, unary_narrowt)
14352 (unary_narrowb_to_uint, unary_narrowt_to_uint, unary_to_int): Likewise.
14353 * config/aarch64/aarch64-sve-builtins-shapes.cc (apply_predication):
14354 Also add an initial argument for unary_convert_narrowt, regardless
14355 of the predication type.
14356 (build_32_64): Allow loads and stores to specify MODE_none.
14357 (build_sv_index64, build_sv_uint_offset): New functions.
14358 (long_type_suffix): New function.
14359 (binary_imm_narrowb_base, binary_imm_narrowt_base): New classes.
14360 (binary_imm_long_base, load_gather_sv_base): Likewise.
14361 (shift_right_imm_narrow_wrapper, ternary_shift_imm_base): Likewise.
14362 (ternary_resize2_opt_n_base, ternary_resize2_lane_base): Likewise.
14363 (unary_narrowb_base, unary_narrowt_base): Likewise.
14364 (binary_long_lane_def, binary_long_lane): New shape.
14365 (binary_long_opt_n_def, binary_long_opt_n): Likewise.
14366 (binary_narrowb_opt_n_def, binary_narrowb_opt_n): Likewise.
14367 (binary_narrowt_opt_n_def, binary_narrowt_opt_n): Likewise.
14368 (binary_to_uint_def, binary_to_uint): Likewise.
14369 (binary_wide_def, binary_wide): Likewise.
14370 (binary_wide_opt_n_def, binary_wide_opt_n): Likewise.
14371 (compare_def, compare): Likewise.
14372 (compare_ptr_def, compare_ptr): Likewise.
14373 (load_ext_gather_index_restricted_def,
14374 load_ext_gather_index_restricted): Likewise.
14375 (load_ext_gather_offset_restricted_def,
14376 load_ext_gather_offset_restricted): Likewise.
14377 (load_gather_sv_def): Inherit from load_gather_sv_base.
14378 (load_gather_sv_restricted_def, load_gather_sv_restricted): New shape.
14379 (shift_left_imm_def, shift_left_imm): Likewise.
14380 (shift_left_imm_long_def, shift_left_imm_long): Likewise.
14381 (shift_left_imm_to_uint_def, shift_left_imm_to_uint): Likewise.
14382 (store_scatter_index_restricted_def,
14383 store_scatter_index_restricted): Likewise.
14384 (store_scatter_offset_restricted_def,
14385 store_scatter_offset_restricted): Likewise.
14386 (tbl_tuple_def, tbl_tuple): Likewise.
14387 (ternary_long_lane_def, ternary_long_lane): Likewise.
14388 (ternary_long_opt_n_def, ternary_long_opt_n): Likewise.
14389 (ternary_qq_lane_def): Inherit from ternary_resize2_lane_base.
14390 (ternary_qq_lane_rotate_def, ternary_qq_lane_rotate): New shape
14391 (ternary_qq_opt_n_def): Inherit from ternary_resize2_opt_n_base.
14392 (ternary_qq_rotate_def, ternary_qq_rotate): New shape.
14393 (ternary_shift_left_imm_def, ternary_shift_left_imm): Likewise.
14394 (ternary_shift_right_imm_def, ternary_shift_right_imm): Likewise.
14395 (ternary_uint_def, ternary_uint): Likewise.
14396 (unary_convert): Fix typo in comment.
14397 (unary_convert_narrowt_def, unary_convert_narrowt): New shape.
14398 (unary_long_def, unary_long): Likewise.
14399 (unary_narrowb_def, unary_narrowb): Likewise.
14400 (unary_narrowt_def, unary_narrowt): Likewise.
14401 (unary_narrowb_to_uint_def, unary_narrowb_to_uint): Likewise.
14402 (unary_narrowt_to_uint_def, unary_narrowt_to_uint): Likewise.
14403 (unary_to_int_def, unary_to_int): Likewise.
14404 * config/aarch64/aarch64-sve-builtins-base.cc (unspec_cmla)
14405 (unspec_fcmla, unspec_cond_fcmla, expand_mla_mls_lane): New functions.
14406 (svasrd_impl): Delete.
14407 (svcadd_impl::expand): Handle integer operations too.
14408 (svcmla_impl::expand, svcmla_lane::expand): Likewise, using the
14409 new functions to derive the unspec numbers.
14410 (svmla_svmls_lane_impl): Replace with...
14411 (svmla_lane_impl, svmls_lane_impl): ...these new classes. Handle
14412 integer operations too.
14413 (svwhile_impl): Rename to...
14414 (svwhilelx_impl): ...this and inherit from while_comparison.
14415 (svasrd): Use unspec_based_function.
14416 (svmla_lane): Use svmla_lane_impl.
14417 (svmls_lane): Use svmls_lane_impl.
14418 (svrecpe, svrsqrte): Handle unsigned integer operations too.
14419 (svwhilele, svwhilelt): Use svwhilelx_impl.
14420 * config/aarch64/aarch64-sve-builtins-sve2.h: New file.
14421 * config/aarch64/aarch64-sve-builtins-sve2.cc: Likewise.
14422 * config/aarch64/aarch64-sve-builtins-sve2.def: Likewise.
14423 * config/aarch64/aarch64-sve-builtins.def: Include
14424 aarch64-sve-builtins-sve2.def.
14425
14426 2020-01-09 Richard Sandiford <richard.sandiford@arm.com>
14427
14428 * config/aarch64/aarch64-protos.h (aarch64_sve_arith_immediate_p)
14429 (aarch64_sve_sqadd_sqsub_immediate_p): Add a machine_mode argument.
14430 * config/aarch64/aarch64.c (aarch64_sve_arith_immediate_p)
14431 (aarch64_sve_sqadd_sqsub_immediate_p): Likewise. Handle scalar
14432 immediates as well as vector ones.
14433 * config/aarch64/predicates.md (aarch64_sve_arith_immediate)
14434 (aarch64_sve_sub_arith_immediate, aarch64_sve_qadd_immediate)
14435 (aarch64_sve_qsub_immediate): Update calls accordingly.
14436
14437 2020-01-09 Richard Sandiford <richard.sandiford@arm.com>
14438
14439 * config/aarch64/aarch64-sve2.md: Add banner comments.
14440 (<su>mulh<r>s<mode>3): Move further up file.
14441 (<su>mull<bt><Vwide>, <r>shrnb<mode>, <r>shrnt<mode>)
14442 (*aarch64_sve2_sra<mode>): Move further down file.
14443 * config/aarch64/t-aarch64 (s-check-sve-md): Check aarch64-sve2.md too.
14444
14445 2020-01-09 Richard Sandiford <richard.sandiford@arm.com>
14446
14447 * config/aarch64/iterators.md (SVE_WHILE): Add UNSPEC_WHILERW
14448 and UNSPEC_WHILEWR.
14449 (while_optab_cmp): Handle them.
14450 * config/aarch64/aarch64-sve.md
14451 (*while_<while_optab_cmp><GPI:mode><PRED_ALL:mode>_ptest): Make public
14452 and add a "@" marker.
14453 * config/aarch64/aarch64-sve2.md (check_<raw_war>_ptrs<mode>): Use it
14454 instead of gen_aarch64_sve2_while_ptest.
14455 (@aarch64_sve2_while<cmp_op><GPI:mode><PRED_ALL:mode>_ptest): Delete.
14456
14457 2020-01-09 Richard Sandiford <richard.sandiford@arm.com>
14458
14459 * config/aarch64/aarch64.md (UNSPEC_WHILE_LE): Rename to...
14460 (UNSPEC_WHILELE): ...this.
14461 (UNSPEC_WHILE_LO): Rename to...
14462 (UNSPEC_WHILELO): ...this.
14463 (UNSPEC_WHILE_LS): Rename to...
14464 (UNSPEC_WHILELS): ...this.
14465 (UNSPEC_WHILE_LT): Rename to...
14466 (UNSPEC_WHILELT): ...this.
14467 * config/aarch64/iterators.md (SVE_WHILE): Update accordingly.
14468 (cmp_op, while_optab_cmp): Likewise.
14469 * config/aarch64/aarch64.c (aarch64_sve_move_pred_via_while): Likewise.
14470 * config/aarch64/aarch64-sve-builtins-base.cc (svwhilele): Likewise.
14471 (svwhilelt): Likewise.
14472
14473 2020-01-09 Richard Sandiford <richard.sandiford@arm.com>
14474
14475 * config/aarch64/aarch64-sve-builtins-shapes.h (unary_count): Delete.
14476 (unary_to_uint): Define.
14477 * config/aarch64/aarch64-sve-builtins-shapes.cc (unary_count_def)
14478 (unary_count): Rename to...
14479 (unary_to_uint_def, unary_to_uint): ...this.
14480 * config/aarch64/aarch64-sve-builtins-base.def: Update accordingly.
14481
14482 2020-01-09 Richard Sandiford <richard.sandiford@arm.com>
14483
14484 * config/aarch64/aarch64-sve-builtins-functions.h
14485 (code_for_mode_function): New class.
14486 (CODE_FOR_MODE0, QUIET_CODE_FOR_MODE0): New macros.
14487 * config/aarch64/aarch64-sve-builtins-base.cc (svcompact_impl)
14488 (svext_impl, svmul_lane_impl, svsplice_impl, svtmad_impl): Delete.
14489 (svcompact, svext, svsplice): Use QUIET_CODE_FOR_MODE0.
14490 (svmul_lane, svtmad): Use CODE_FOR_MODE0.
14491
14492 2020-01-09 Richard Sandiford <richard.sandiford@arm.com>
14493
14494 * config/aarch64/iterators.md (addsub): New code attribute.
14495 * config/aarch64/aarch64-simd.md (aarch64_<su_optab><optab><mode>):
14496 Re-express as...
14497 (aarch64_<su_optab>q<addsub><mode>): ...this, making the same change
14498 in the asm string and attributes. Fix indentation.
14499 * config/aarch64/aarch64-sve.md (@aarch64_<su_optab><optab><mode>):
14500 Re-express as...
14501 (@aarch64_sve_<optab><mode>): ...this.
14502 * config/aarch64/aarch64-sve-builtins.h
14503 (function_expander::expand_signed_unpred_op): Delete.
14504 * config/aarch64/aarch64-sve-builtins.cc
14505 (function_expander::expand_signed_unpred_op): Likewise.
14506 (function_expander::map_to_rtx_codes): If the optab isn't defined,
14507 try using code_for_aarch64_sve instead.
14508 * config/aarch64/aarch64-sve-builtins-base.cc (svqadd_impl): Delete.
14509 (svqsub_impl): Likewise.
14510 (svqadd, svqsub): Use rtx_code_function instead.
14511
14512 2020-01-09 Richard Sandiford <richard.sandiford@arm.com>
14513
14514 * config/aarch64/iterators.md (SRHSUB, URHSUB): Delete.
14515 (HADDSUB, sur, addsub): Remove them.
14516
14517 2020-01-09 Richard Sandiford <richard.sandiford@arm.com>
14518
14519 * tree-nrv.c (pass_return_slot::execute): Handle all internal
14520 functions the same way, rather than singling out those that
14521 aren't mapped directly to optabs.
14522
14523 2020-01-09 Richard Sandiford <richard.sandiford@arm.com>
14524
14525 * target.def (compatible_vector_types_p): New target hook.
14526 * hooks.h (hook_bool_const_tree_const_tree_true): Declare.
14527 * hooks.c (hook_bool_const_tree_const_tree_true): New function.
14528 * doc/tm.texi.in (TARGET_COMPATIBLE_VECTOR_TYPES_P): New hook.
14529 * doc/tm.texi: Regenerate.
14530 * gimple-expr.c: Include target.h.
14531 (useless_type_conversion_p): Use targetm.compatible_vector_types_p.
14532 * config/aarch64/aarch64.c (aarch64_compatible_vector_types_p): New
14533 function.
14534 (TARGET_COMPATIBLE_VECTOR_TYPES_P): Define.
14535 * config/aarch64/aarch64-sve-builtins.cc (gimple_folder::convert_pred):
14536 Use the original predicate if it already has a suitable type.
14537
14538 2020-01-09 Martin Jambor <mjambor@suse.cz>
14539
14540 * cgraph.h (cgraph_edge): Make remove, set_call_stmt, make_direct,
14541 resolve_speculation and redirect_call_stmt_to_callee static. Change
14542 return type of set_call_stmt to cgraph_edge *.
14543 * auto-profile.c (afdo_indirect_call): Adjust call to
14544 redirect_call_stmt_to_callee.
14545 * cgraph.c (cgraph_edge::set_call_stmt): Make return cgraph-edge *,
14546 make the this pointer explicit, adjust self-recursive calls and the
14547 call top make_direct. Return the resulting edge.
14548 (cgraph_edge::remove): Make this pointer explicit.
14549 (cgraph_edge::resolve_speculation): Likewise, adjust call to remove.
14550 (cgraph_edge::make_direct): Likewise, adjust call to
14551 resolve_speculation.
14552 (cgraph_edge::redirect_call_stmt_to_callee): Likewise, also adjust
14553 call to set_call_stmt.
14554 (cgraph_update_edges_for_call_stmt_node): Update call to
14555 set_call_stmt and remove.
14556 * cgraphclones.c (cgraph_node::set_call_stmt_including_clones):
14557 Renamed edge to master_edge. Adjusted calls to set_call_stmt.
14558 (cgraph_node::create_edge_including_clones): Moved "first" definition
14559 of edge to the block where it was used. Adjusted calls to
14560 set_call_stmt.
14561 (cgraph_node::remove_symbol_and_inline_clones): Adjust call to
14562 cgraph_edge::remove.
14563 * cgraphunit.c (walk_polymorphic_call_targets): Adjusted calls to
14564 make_direct and redirect_call_stmt_to_callee.
14565 * ipa-fnsummary.c (redirect_to_unreachable): Adjust calls to
14566 resolve_speculation and make_direct.
14567 * ipa-inline-transform.c (inline_transform): Adjust call to
14568 redirect_call_stmt_to_callee.
14569 (check_speculations_1):: Adjust call to resolve_speculation.
14570 * ipa-inline.c (resolve_noninline_speculation): Adjust call to
14571 resolve-speculation.
14572 (inline_small_functions): Adjust call to resolve_speculation.
14573 (ipa_inline): Likewise.
14574 * ipa-prop.c (ipa_make_edge_direct_to_target): Adjust call to
14575 make_direct.
14576 * ipa-visibility.c (function_and_variable_visibility): Make iteration
14577 safe with regards to edge removal, adjust calls to
14578 redirect_call_stmt_to_callee.
14579 * ipa.c (walk_polymorphic_call_targets): Adjust calls to make_direct
14580 and redirect_call_stmt_to_callee.
14581 * multiple_target.c (create_dispatcher_calls): Adjust call to
14582 redirect_call_stmt_to_callee
14583 (redirect_to_specific_clone): Likewise.
14584 * tree-cfgcleanup.c (delete_unreachable_blocks_update_callgraph):
14585 Adjust calls to cgraph_edge::remove.
14586 * tree-inline.c (copy_bb): Adjust call to set_call_stmt.
14587 (redirect_all_calls): Adjust call to redirect_call_stmt_to_callee.
14588 (expand_call_inline): Adjust call to cgraph_edge::remove.
14589
14590 2020-01-09 Martin Liska <mliska@suse.cz>
14591
14592 * params.opt: Set Optimization for
14593 param_max_speculative_devirt_maydefs.
14594
14595 2020-01-09 Martin Sebor <msebor@redhat.com>
14596
14597 PR middle-end/93200
14598 PR fortran/92956
14599 * builtins.c (compute_objsize): Avoid handling MEM_REFs of vector type.
14600
14601 2020-01-09 Martin Liska <mliska@suse.cz>
14602
14603 * auto-profile.c (auto_profile): Use opt_for_fn
14604 for a parameter.
14605 * ipa-cp.c (ipcp_lattice::add_value): Likewise.
14606 (propagate_vals_across_arith_jfunc): Likewise.
14607 (hint_time_bonus): Likewise.
14608 (incorporate_penalties): Likewise.
14609 (good_cloning_opportunity_p): Likewise.
14610 (perform_estimation_of_a_value): Likewise.
14611 (estimate_local_effects): Likewise.
14612 (ipcp_propagate_stage): Likewise.
14613 * ipa-fnsummary.c (decompose_param_expr): Likewise.
14614 (set_switch_stmt_execution_predicate): Likewise.
14615 (analyze_function_body): Likewise.
14616 * ipa-inline-analysis.c (offline_size): Likewise.
14617 * ipa-inline.c (early_inliner): Likewise.
14618 * ipa-prop.c (ipa_analyze_node): Likewise.
14619 (ipcp_transform_function): Likewise.
14620 * ipa-sra.c (process_scan_results): Likewise.
14621 (ipa_sra_summarize_function): Likewise.
14622 * params.opt: Rename ipcp-unit-growth to
14623 ipa-cp-unit-growth. Add Optimization for various
14624 IPA-related parameters.
14625
14626 2020-01-09 Richard Biener <rguenther@suse.de>
14627
14628 PR middle-end/93054
14629 * gimplify.c (gimplify_expr): Deal with NOP definitions.
14630
14631 2020-01-09 Richard Biener <rguenther@suse.de>
14632
14633 PR tree-optimization/93040
14634 * gimple-ssa-store-merging.c (find_bswap_or_nop): Raise search limit.
14635
14636 2020-01-09 Georg-Johann Lay <avr@gjlay.de>
14637
14638 * common/config/avr/avr-common.c (avr_option_optimization_table)
14639 [OPT_LEVELS_1_PLUS]: Set -fsplit-wide-types-early.
14640
14641 2020-01-09 Martin Liska <mliska@suse.cz>
14642
14643 * cgraphclones.c (symbol_table::materialize_all_clones):
14644 Use cgraph_node::dump_name.
14645
14646 2020-01-09 Jakub Jelinek <jakub@redhat.com>
14647
14648 PR inline-asm/93202
14649 * config/riscv/riscv.c (riscv_print_operand_reloc): Use
14650 output_operand_lossage instead of gcc_unreachable.
14651 * doc/md.texi (riscv f constraint): Fix typo.
14652
14653 PR target/93141
14654 * config/i386/i386.md (subv<mode>4): Use SWIDWI iterator instead of
14655 SWI. Use <general_hilo_operand> instead of <general_operand>. Use
14656 CONST_SCALAR_INT_P instead of CONST_INT_P.
14657 (*subv<mode>4_1): Rename to ...
14658 (subv<mode>4_1): ... this.
14659 (*subv<dwi>4_doubleword, *addv<dwi>4_doubleword_1): New
14660 define_insn_and_split patterns.
14661 (*subv<mode>4_overflow_1, *addv<mode>4_overflow_2): New define_insn
14662 patterns.
14663
14664 2020-01-08 David Malcolm <dmalcolm@redhat.com>
14665
14666 * vec.c (class selftest::count_dtor): New class.
14667 (selftest::test_auto_delete_vec): New test.
14668 (selftest::vec_c_tests): Call it.
14669 * vec.h (class auto_delete_vec): New class template.
14670 (auto_delete_vec<T>::~auto_delete_vec): New dtor.
14671
14672 2020-01-08 David Malcolm <dmalcolm@redhat.com>
14673
14674 * sbitmap.h (auto_sbitmap): Add operator const_sbitmap.
14675
14676 2020-01-08 Jim Wilson <jimw@sifive.com>
14677
14678 * config/riscv/riscv.c (riscv_legitimize_tls_address): Ifdef out
14679 use of TLS_MODEL_LOCAL_EXEC when not pic.
14680
14681 2020-01-08 David Malcolm <dmalcolm@redhat.com>
14682
14683 * hash-map-tests.c (selftest::test_map_of_strings_to_int): Fix
14684 memory leak.
14685
14686 2020-01-08 Jakub Jelinek <jakub@redhat.com>
14687
14688 PR target/93187
14689 * config/i386/i386.md (*stack_protect_set_2_<mode> peephole2,
14690 *stack_protect_set_3 peephole2): Also check that the second
14691 insns source is general_operand.
14692
14693 PR target/93174
14694 * config/i386/i386.md (addcarry<mode>_0): Use nonimmediate_operand
14695 predicate for output operand instead of register_operand.
14696 (addcarry<mode>, addcarry<mode>_1): Likewise. Add alternative with
14697 memory destination and non-memory operands[2].
14698
14699 2020-01-08 Martin Liska <mliska@suse.cz>
14700
14701 * cgraph.c (cgraph_node::dump): Use ::dump_name or
14702 ::dump_asm_name instead of (::name or ::asm_name).
14703 * cgraphclones.c (symbol_table::materialize_all_clones): Likewise.
14704 * cgraphunit.c (walk_polymorphic_call_targets): Likewise.
14705 (analyze_functions): Likewise.
14706 (expand_all_functions): Likewise.
14707 * ipa-cp.c (ipcp_cloning_candidate_p): Likewise.
14708 (propagate_bits_across_jump_function): Likewise.
14709 (dump_profile_updates): Likewise.
14710 (ipcp_store_bits_results): Likewise.
14711 (ipcp_store_vr_results): Likewise.
14712 * ipa-devirt.c (dump_targets): Likewise.
14713 * ipa-fnsummary.c (analyze_function_body): Likewise.
14714 * ipa-hsa.c (check_warn_node_versionable): Likewise.
14715 (process_hsa_functions): Likewise.
14716 * ipa-icf.c (sem_item_optimizer::merge_classes): Likewise.
14717 (set_alias_uids): Likewise.
14718 * ipa-inline-transform.c (save_inline_function_body): Likewise.
14719 * ipa-inline.c (recursive_inlining): Likewise.
14720 (inline_to_all_callers_1): Likewise.
14721 (ipa_inline): Likewise.
14722 * ipa-profile.c (ipa_propagate_frequency_1): Likewise.
14723 (ipa_propagate_frequency): Likewise.
14724 * ipa-prop.c (ipa_make_edge_direct_to_target): Likewise.
14725 (remove_described_reference): Likewise.
14726 * ipa-pure-const.c (worse_state): Likewise.
14727 (check_retval_uses): Likewise.
14728 (analyze_function): Likewise.
14729 (propagate_pure_const): Likewise.
14730 (propagate_nothrow): Likewise.
14731 (dump_malloc_lattice): Likewise.
14732 (propagate_malloc): Likewise.
14733 (pass_local_pure_const::execute): Likewise.
14734 * ipa-visibility.c (optimize_weakref): Likewise.
14735 (function_and_variable_visibility): Likewise.
14736 * ipa.c (symbol_table::remove_unreachable_nodes): Likewise.
14737 (ipa_discover_variable_flags): Likewise.
14738 * lto-streamer-out.c (output_function): Likewise.
14739 (output_constructor): Likewise.
14740 * tree-inline.c (copy_bb): Likewise.
14741 * tree-ssa-structalias.c (ipa_pta_execute): Likewise.
14742 * varpool.c (symbol_table::remove_unreferenced_decls): Likewise.
14743
14744 2020-01-08 Richard Biener <rguenther@suse.de>
14745
14746 PR middle-end/93199
14747 * tree-eh.c (sink_clobbers): Update virtual operands for
14748 the first and last stmt only. Add a dry-run capability.
14749 (pass_lower_eh_dispatch::execute): Perform clobber sinking
14750 after CFG manipulations and in RPO order to catch all
14751 secondary opportunities reliably.
14752
14753 2020-01-08 Georg-Johann Lay <avr@gjlay.de>
14754
14755 PR target/93182
14756 * doc/invoke.texi (AVR Options) <-nodevicespecs>: Document.
14757
14758 2019-01-08 Richard Biener <rguenther@suse.de>
14759
14760 PR middle-end/93199
14761 * gimple-fold.c (rewrite_to_defined_overflow): Mark stmt modified.
14762 * tree-ssa-loop-im.c (move_computations_worker): Properly adjust
14763 virtual operand, also updating SSA use.
14764 * gimple-loop-interchange.cc (loop_cand::undo_simple_reduction):
14765 Update stmt after resetting virtual operand.
14766 (tree_loop_interchange::move_code_to_inner_loop): Likewise.
14767 * gimple-iterator.c (gsi_remove): When not removing the stmt
14768 permanently do not delink immediate uses or mark the stmt modified.
14769
14770 2020-01-08 Martin Liska <mliska@suse.cz>
14771
14772 * ipa-fnsummary.c (dump_ipa_call_summary): Use symtab_node::dump_name.
14773 (ipa_call_context::estimate_size_and_time): Likewise.
14774 (inline_analyze_function): Likewise.
14775
14776 2020-01-08 Martin Liska <mliska@suse.cz>
14777
14778 * cgraph.c (cgraph_node::dump): Use systematically
14779 dump_asm_name.
14780
14781 2020-01-08 Georg-Johann Lay <avr@gjlay.de>
14782
14783 Add -nodevicespecs option for avr.
14784
14785 PR target/93182
14786 * config/avr/avr.opt (-nodevicespecs): New driver option.
14787 * config/avr/driver-avr.c (avr_devicespecs_file): Only issue
14788 "-specs=device-specs/..." if that option is not set.
14789 * doc/invoke.texi (AVR Options) <-nodevicespecs>: Document.
14790
14791 2020-01-08 Georg-Johann Lay <avr@gjlay.de>
14792
14793 Implement 64-bit double functions for avr.
14794
14795 PR target/92055
14796 * config.gcc (tm_defines) [target=avr]: Support --with-libf7,
14797 --with-double-comparison.
14798 * doc/install.texi: Document them.
14799 * config/avr/avr-c.c (avr_cpu_cpp_builtins)
14800 <WITH_LIBF7_LIBGCC, WITH_LIBF7_MATH, WITH_LIBF7_MATH_SYMBOLS>
14801 <WITH_DOUBLE_COMPARISON>: New built-in defines.
14802 * doc/invoke.texi (AVR Built-in Macros): Document them.
14803 * config/avr/avr-protos.h (avr_float_lib_compare_returns_bool): New.
14804 * config/avr/avr.c (avr_float_lib_compare_returns_bool): New function.
14805 * config/avr/avr.h (FLOAT_LIB_COMPARE_RETURNS_BOOL): New macro.
14806
14807 2020-01-08 Richard Earnshaw <rearnsha@arm.com>
14808
14809 PR target/93188
14810 * config/arm/t-multilib (MULTILIB_MATCHES): Add rules to match
14811 armv7-a{+mp,+sec,+mp+sec} to appropriate armv7 multilib variants
14812 when only building rm-profile multilibs.
14813
14814 2020-01-08 Feng Xue <fxue@os.amperecomputing.com>
14815
14816 PR ipa/93084
14817 * ipa-cp.c (self_recursively_generated_p): Find matched aggregate
14818 lattice for a value to check.
14819 (propagate_vals_across_arith_jfunc): Add an assertion to ensure
14820 finite propagation in self-recursive scc.
14821
14822 2020-01-08 Luo Xiong Hu <luoxhu@linux.ibm.com>
14823
14824 * ipa-inline.c (caller_growth_limits): Restore the AND.
14825
14826 2020-01-07 Andrew Stubbs <ams@codesourcery.com>
14827
14828 * config/gcn/gcn-valu.md (VEC_1REG_INT_ALT): Delete iterator.
14829 (VEC_ALLREG_ALT): New iterator.
14830 (VEC_ALLREG_INT_MODE): New iterator.
14831 (VCMP_MODE): New iterator.
14832 (VCMP_MODE_INT): New iterator.
14833 (vec_cmpu<mode>di): Use VCMP_MODE_INT.
14834 (vec_cmp<u>v64qidi): New define_expand.
14835 (vec_cmp<mode>di_exec): Use VCMP_MODE.
14836 (vec_cmpu<mode>di_exec): New define_expand.
14837 (vec_cmp<u>v64qidi_exec): New define_expand.
14838 (vec_cmp<mode>di_dup): Use VCMP_MODE.
14839 (vec_cmp<mode>di_dup_exec): Use VCMP_MODE.
14840 (vcond<VEC_ALL1REG_MODE:mode><VEC_1REG_ALT:mode>): Rename ...
14841 (vcond<VEC_ALLREG_MODE:mode><VEC_ALLREG_ALT:mode>): ... to this.
14842 (vcond<VEC_ALL1REG_MODE:mode><VEC_1REG_ALT:mode>_exec): Rename ...
14843 (vcond<VEC_ALLREG_MODE:mode><VEC_ALLREG_ALT:mode>_exec): ... to this.
14844 (vcondu<VEC_ALL1REG_MODE:mode><VEC_1REG_INT_ALT:mode>): Rename ...
14845 (vcondu<VEC_ALLREG_MODE:mode><VEC_ALLREG_INT_MODE:mode>): ... to this.
14846 (vcondu<VEC_ALL1REG_MODE:mode><VEC_1REG_INT_ALT:mode>_exec): Rename ...
14847 (vcondu<VEC_ALLREG_MODE:mode><VEC_ALLREG_INT_MODE:mode>_exec): ... to
14848 this.
14849 * config/gcn/gcn.c (print_operand): Fix 8 and 16 bit suffixes.
14850 * config/gcn/gcn.md (expander): Add sign_extend and zero_extend.
14851
14852 2020-01-07 Andrew Stubbs <ams@codesourcery.com>
14853
14854 * config/gcn/constraints.md (DA): Update description and match.
14855 (DB): Likewise.
14856 (Db): New constraint.
14857 * config/gcn/gcn-protos.h (gcn_inline_constant64_p): Add second
14858 parameter.
14859 * config/gcn/gcn.c (gcn_inline_constant64_p): Add 'mixed' parameter.
14860 Implement 'Db' mixed immediate type.
14861 * config/gcn/gcn-valu.md (addcv64si3<exec_vcc>): Rework constraints.
14862 (addcv64si3_dup<exec_vcc>): Delete.
14863 (subcv64si3<exec_vcc>): Rework constraints.
14864 (addv64di3): Rework constraints.
14865 (addv64di3_exec): Rework constraints.
14866 (subv64di3): Rework constraints.
14867 (addv64di3_dup): Delete.
14868 (addv64di3_dup_exec): Delete.
14869 (addv64di3_zext): Rework constraints.
14870 (addv64di3_zext_exec): Rework constraints.
14871 (addv64di3_zext_dup): Rework constraints.
14872 (addv64di3_zext_dup_exec): Rework constraints.
14873 (addv64di3_zext_dup2): Rework constraints.
14874 (addv64di3_zext_dup2_exec): Rework constraints.
14875 (addv64di3_sext_dup2): Rework constraints.
14876 (addv64di3_sext_dup2_exec): Rework constraints.
14877
14878 2020-01-07 Andre Vieira <andre.simoesdiasvieira@arm.com>
14879
14880 * doc/sourcebuild.texi (arm_little_endian, arm_nothumb): Documented
14881 existing target checks.
14882
14883 2020-01-07 Richard Biener <rguenther@suse.de>
14884
14885 * doc/install.texi: Bump minimal supported MPC version.
14886
14887 2020-01-07 Richard Sandiford <richard.sandiford@arm.com>
14888
14889 * langhooks-def.h (lhd_simulate_enum_decl): Declare.
14890 (LANG_HOOKS_SIMULATE_ENUM_DECL): Use it.
14891 * langhooks.c: Include stor-layout.h.
14892 (lhd_simulate_enum_decl): New function.
14893 * config/aarch64/aarch64-sve-builtins.cc (init_builtins): Call
14894 handle_arm_sve_h for the LTO frontend.
14895 (register_vector_type): Cope with null returns from pushdecl.
14896
14897 2020-01-07 Richard Sandiford <richard.sandiford@arm.com>
14898
14899 * config/aarch64/aarch64-protos.h (aarch64_sve::svbool_type_p)
14900 (aarch64_sve::nvectors_if_data_type): Replace with...
14901 (aarch64_sve::builtin_type_p): ...this.
14902 * config/aarch64/aarch64-sve-builtins.cc: Include attribs.h.
14903 (find_vector_type): Delete.
14904 (add_sve_type_attribute): New function.
14905 (lookup_sve_type_attribute): Likewise.
14906 (register_builtin_types): Add an "SVE type" attribute to each type.
14907 (register_tuple_type): Likewise.
14908 (svbool_type_p, nvectors_if_data_type): Delete.
14909 (mangle_builtin_type): Use lookup_sve_type_attribute.
14910 (builtin_type_p): Likewise. Add an overload that returns the
14911 number of constituent vector and predicate registers.
14912 * config/aarch64/aarch64.c (aarch64_sve_argument_p): Delete.
14913 (aarch64_returns_value_in_sve_regs_p): Use aarch64_sve::builtin_type_p
14914 instead of aarch64_sve_argument_p.
14915 (aarch64_takes_arguments_in_sve_regs_p): Likewise.
14916 (aarch64_pass_by_reference): Likewise.
14917 (aarch64_function_value_1): Likewise.
14918 (aarch64_return_in_memory): Likewise.
14919 (aarch64_layout_arg): Likewise.
14920
14921 2020-01-07 Jakub Jelinek <jakub@redhat.com>
14922
14923 PR tree-optimization/93156
14924 * tree-ssa-ccp.c (bit_value_binop): For x * x note that the second
14925 least significant bit is always clear.
14926
14927 PR tree-optimization/93118
14928 * match.pd ((x >> c) << c -> x & (-1<<c)): Add nop_convert?. Add new
14929 simplifier with two intermediate conversions.
14930
14931 2020-01-07 Martin Liska <mliska@suse.cz>
14932
14933 * params.opt: Add Optimization for various parameters.
14934
14935 2020-01-07 Martin Liska <mliska@suse.cz>
14936
14937 PR ipa/83411
14938 * doc/extend.texi: Explain cloning for target_clone
14939 attribute.
14940
14941 2020-01-07 Martin Liska <mliska@suse.cz>
14942
14943 PR tree-optimization/92860
14944 * common.opt: Make in Optimization option
14945 as it is affected by -O0, which is an Optimization
14946 option.
14947 * tree-inline.c (tree_inlinable_function_p):
14948 Use opt_for_fn for warn_inline.
14949 (expand_call_inline): Likewise.
14950
14951 2020-01-07 Martin Liska <mliska@suse.cz>
14952
14953 PR tree-optimization/92860
14954 * common.opt: Make flag_ree as optimization
14955 attribute.
14956
14957 2020-01-07 Martin Liska <mliska@suse.cz>
14958
14959 PR optimization/92860
14960 * params.opt: Mark param_min_crossjump_insns with Optimization
14961 keyword.
14962
14963 2020-01-07 Luo Xiong Hu <luoxhu@linux.ibm.com>
14964
14965 * ipa-inline-analysis.c (estimate_growth): Fix typo.
14966 * ipa-inline.c (caller_growth_limits): Use OR instead of AND.
14967
14968 2020-01-06 Michael Meissner <meissner@linux.ibm.com>
14969
14970 * config/rs6000/rs6000.c (hard_reg_and_mode_to_addr_mask): New
14971 helper function to return the valid addressing formats for a given
14972 hard register and mode.
14973 (rs6000_adjust_vec_address): Call hard_reg_and_mode_to_addr_mask.
14974
14975 * config/rs6000/constraints.md (Q constraint): Update
14976 documentation.
14977 * doc/md.texi (RS/6000 constraints): Update 'Q' cosntraint
14978 documentation.
14979
14980 * config/rs6000/vsx.md (vsx_extract_<mode>_var, VSX_D iterator):
14981 Use 'Q' for doing vector extract from memory.
14982 (vsx_extract_v4sf_var): Use 'Q' for doing vector extract from
14983 memory.
14984 (vsx_extract_<mode>_var, VSX_EXTRACT_I iterator): Use 'Q' for
14985 doing vector extract from memory.
14986 (vsx_extract_<mode>_<VS_scalar>mode_var): Use 'Q' for doing vector
14987 extract from memory.
14988
14989 * config/rs6000/rs6000.c (rs6000_adjust_vec_address): Add support
14990 for the offset being 34-bits when -mcpu=future is used.
14991
14992 2020-01-06 John David Anglin <danglin@gcc.gnu.org>
14993
14994 * config/pa/pa.md: Revert change to use ordered_comparison_operator
14995 instead of cmpib_comparison_operator in cmpib patterns.
14996 * config/pa/predicates.md (cmpib_comparison_operator): Revert removal
14997 of cmpib_comparison_operator. Revise comment.
14998
14999 2020-01-06 Richard Sandiford <richard.sandiford@arm.com>
15000
15001 * tree-vect-slp.c (vect_build_slp_tree_1): Require all shifts
15002 in an IFN_DIV_POW2 node to be equal.
15003
15004 2020-01-06 Richard Sandiford <richard.sandiford@arm.com>
15005
15006 * tree-vect-stmts.c (vect_check_load_store_mask): Rename to...
15007 (vect_check_scalar_mask): ...this.
15008 (vectorizable_store, vectorizable_load): Update call accordingly.
15009 (vectorizable_call): Use vect_check_scalar_mask to check the mask
15010 argument in calls to conditional internal functions.
15011
15012 2020-01-06 Andrew Stubbs <ams@codesourcery.com>
15013
15014 * config/gcn/gcn-valu.md (subv64di3): Use separate alternatives for
15015 '0' matching inputs.
15016 (subv64di3_exec): Likewise.
15017
15018 2020-01-06 Bryan Stenson <bryan@siliconvortex.com>
15019
15020 * config/mips/mips.c (vr4130_align_insns): Fix typo.
15021 * doc/md.texi (movstr): Likewise.
15022
15023 2020-01-06 Andrew Stubbs <ams@codesourcery.com>
15024
15025 * config/gcn/gcn-valu.md (vec_extract<mode><scalar_mode>): Add early
15026 clobber.
15027
15028 2020-01-06 Richard Sandiford <richard.sandiford@arm.com>
15029
15030 * config/aarch64/t-aarch64 ($(srcdir)/config/aarch64/aarch64-tune.md):
15031 Depend on...
15032 (s-aarch64-tune-md): ...this new stamp file. Pipe the new contents
15033 to a temporary file and use move-if-change to update the real
15034 file where necessary.
15035
15036 2020-01-06 Richard Sandiford <richard.sandiford@arm.com>
15037
15038 * config/aarch64/aarch64-sve.md (@aarch64_sel_dup<mode>): Use Upl
15039 rather than Upa for CPY /M.
15040
15041 2020-01-06 Andrew Stubbs <ams@codesourcery.com>
15042
15043 * config/gcn/gcn.c (gcn_inline_constant_p): Allow 64 as an inline
15044 immediate.
15045
15046 2020-01-06 Martin Liska <mliska@suse.cz>
15047
15048 PR tree-optimization/92860
15049 * params.opt: Mark param_max_combine_insns with Optimization
15050 keyword.
15051
15052 2020-01-05 Jakub Jelinek <jakub@redhat.com>
15053
15054 PR target/93141
15055 * config/i386/i386.md (SWIDWI): New mode iterator.
15056 (DWI, dwi): Add TImode variants.
15057 (addv<mode>4): Use SWIDWI iterator instead of SWI. Use
15058 <general_hilo_operand> instead of <general_operand>. Use
15059 CONST_SCALAR_INT_P instead of CONST_INT_P.
15060 (*addv<mode>4_1): Rename to ...
15061 (addv<mode>4_1): ... this.
15062 (QWI): New mode attribute.
15063 (*addv<dwi>4_doubleword, *addv<dwi>4_doubleword_1): New
15064 define_insn_and_split patterns.
15065 (*addv<mode>4_overflow_1, *addv<mode>4_overflow_2): New define_insn
15066 patterns.
15067 (uaddv<mode>4): Use SWIDWI iterator instead of SWI. Use
15068 <general_hilo_operand> instead of <general_operand>.
15069 (*addcarry<mode>_1): New define_insn.
15070 (*add<dwi>3_doubleword_cc_overflow_1): New define_insn_and_split.
15071
15072 2020-01-03 Konstantin Kharlamov <Hi-Angel@yandex.ru>
15073
15074 * gdbinit.in (pr, prl, pt, pct, pgg, pgq, pgs, pge, pmz, pdd, pbs, pbm):
15075 Use "call" instead of "set".
15076
15077 2020-01-03 Martin Jambor <mjambor@suse.cz>
15078
15079 PR ipa/92917
15080 * ipa-cp.c (print_all_lattices): Skip functions without info.
15081
15082 2020-01-03 Jakub Jelinek <jakub@redhat.com>
15083
15084 PR target/93089
15085 * config/i386/i386-options.c (ix86_simd_clone_adjust): If
15086 TARGET_PREFER_AVX128, use prefer-vector-width=256 for 'c' and 'd'
15087 simd clones. If TARGET_PREFER_AVX256, use prefer-vector-width=512
15088 for 'e' simd clones.
15089
15090 PR target/93089
15091 * config/i386/i386.opt (x_prefer_vector_width_type): Remove TargetSave
15092 entry.
15093 (mprefer-vector-width=): Add Save.
15094 * config/i386/i386-options.c (ix86_target_string): Add PVW argument, print
15095 -mprefer-vector-width= if non-zero. Fix up -mfpmath= comment.
15096 (ix86_debug_options, ix86_function_specific_print): Adjust
15097 ix86_target_string callers.
15098 (ix86_valid_target_attribute_inner_p): Handle prefer-vector-width=.
15099 (ix86_valid_target_attribute_tree): Likewise.
15100 * config/i386/i386-options.h (ix86_target_string): Add PVW argument.
15101 * config/i386/i386-expand.c (ix86_expand_builtin): Adjust
15102 ix86_target_string caller.
15103
15104 PR target/93110
15105 * config/i386/i386.md (abs<mode>2): Use expand_simple_binop instead of
15106 emitting ASHIFTRT, XOR and MINUS by hand. Use gen_int_mode with QImode
15107 instead of gen_int_shift_amount + convert_modes.
15108
15109 PR rtl-optimization/93088
15110 * loop-iv.c (find_single_def_src): Punt after looking through
15111 128 reg copies for regs with single definitions. Move definitions
15112 to first uses.
15113
15114 2020-01-02 Dennis Zhang <dennis.zhang@arm.com>
15115
15116 * config/arm/arm-c.c (arm_cpu_builtins): Define
15117 __ARM_FEATURE_MATMUL_INT8, __ARM_FEATURE_BF16_VECTOR_ARITHMETIC,
15118 __ARM_FEATURE_BF16_SCALAR_ARITHMETIC, and
15119 __ARM_BF16_FORMAT_ALTERNATIVE when enabled.
15120 * config/arm/arm-cpus.in (armv8_6, i8mm, bf16): New features.
15121 * config/arm/arm-tables.opt: Regenerated.
15122 * config/arm/arm.c (arm_option_reconfigure_globals): Initialize
15123 arm_arch_i8mm and arm_arch_bf16 when enabled.
15124 * config/arm/arm.h (TARGET_I8MM): New macro.
15125 (TARGET_BF16_FP, TARGET_BF16_SIMD): Likewise.
15126 * config/arm/t-aprofile: Add matching rules for -march=armv8.6-a.
15127 * config/arm/t-arm-elf (all_v8_archs): Add armv8.6-a.
15128 * config/arm/t-multilib: Add matching rules for -march=armv8.6-a.
15129 (v8_6_a_simd_variants): New.
15130 (v8_*_a_simd_variants): Add i8mm and bf16.
15131 * doc/invoke.texi (armv8.6-a, i8mm, bf16): Document new options.
15132
15133 2020-01-02 Jakub Jelinek <jakub@redhat.com>
15134
15135 PR ipa/93087
15136 * predict.c (compute_function_frequency): Don't call
15137 warn_function_cold on functions that already have cold attribute.
15138
15139 2020-01-01 John David Anglin <danglin@gcc.gnu.org>
15140
15141 PR target/67834
15142 * config/pa/pa.c (pa_elf_select_rtx_section): New. Put references to
15143 COMDAT group function labels in .data.rel.ro.local section.
15144 * config/pa/pa32-linux.h (TARGET_ASM_SELECT_RTX_SECTION): Define.
15145
15146 PR target/93111
15147 * config/pa/pa.md (scc): Use ordered_comparison_operator instead of
15148 comparison_operator in B and S integer comparisons. Likewise, use
15149 ordered_comparison_operator instead of cmpib_comparison_operator in
15150 cmpib patterns.
15151 * config/pa/predicates.md (cmpib_comparison_operator): Remove.
15152
15153 2020-01-01 Jakub Jelinek <jakub@redhat.com>
15154
15155 Update copyright years.
15156
15157 * gcc.c (process_command): Update copyright notice dates.
15158 * gcov-dump.c (print_version): Ditto.
15159 * gcov.c (print_version): Ditto.
15160 * gcov-tool.c (print_version): Ditto.
15161 * gengtype.c (create_file): Ditto.
15162 * doc/cpp.texi: Bump @copying's copyright year.
15163 * doc/cppinternals.texi: Ditto.
15164 * doc/gcc.texi: Ditto.
15165 * doc/gccint.texi: Ditto.
15166 * doc/gcov.texi: Ditto.
15167 * doc/install.texi: Ditto.
15168 * doc/invoke.texi: Ditto.
15169
15170 2020-01-01 Jan Hubicka <hubicka@ucw.cz>
15171
15172 * ipa.c (walk_polymorphic_call_targets): Fix updating of overall
15173 summary.
15174
15175 2020-01-01 Jakub Jelinek <jakub@redhat.com>
15176
15177 PR tree-optimization/93098
15178 * match.pd (popcount): For shift amounts, use integer_onep
15179 or wi::to_widest () == cst instead of tree_to_uhwi () == cst
15180 tests. Make sure that precision is power of two larger than or equal
15181 to 16. Ensure shift is never negative. Use HOST_WIDE_INT_UC macro
15182 instead of ULL suffixed constants. Formatting fixes.
15183 \f
15184 Copyright (C) 2020 Free Software Foundation, Inc.
15185
15186 Copying and distribution of this file, with or without modification,
15187 are permitted in any medium without royalty provided the copyright
15188 notice and this notice are preserved.