platform/upstream/gcc.git
6 years agore PR target/85281 (Assembler messages: Error: operand size mismatch for `vpbroadcast...
Jakub Jelinek [Tue, 17 Apr 2018 07:08:06 +0000 (09:08 +0200)]
re PR target/85281 (Assembler messages: Error: operand size mismatch for `vpbroadcastb' with -mavx512bw -masm=intel)

PR target/85281
* config/i386/sse.md (reduces<mode><mask_scalar_name>,
avx512f_vmcmp<mode>3<round_saeonly_name>,
avx512f_vmcmp<mode>3_mask<round_saeonly_name>,
avx512f_sgetexp<mode><mask_scalar_name><round_saeonly_scalar_name>,
avx512f_rndscale<mode><round_saeonly_name>,
avx512dq_ranges<mode><mask_scalar_name><round_saeonly_scalar_name>,
avx512f_vgetmant<mode><mask_scalar_name><round_saeonly_scalar_name>):
Use %<iptr>2 instead of %2 for -masm=intel.
(avx512f_vcvtss2usi<round_name>, avx512f_vcvtss2usiq<round_name>,
avx512f_vcvttss2usi<round_saeonly_name>,
avx512f_vcvttss2usiq<round_saeonly_name>): Use %k1 instead of %1 for
-masm=intel.
(avx512f_vcvtsd2usi<round_name>, avx512f_vcvtsd2usiq<round_name>,
avx512f_vcvttsd2usi<round_saeonly_name>,
avx512f_vcvttsd2usiq<round_saeonly_name>, ufloatv2siv2df2<mask_name>):
Use %q1 instead of %1 for -masm=intel.
(avx512f_sfixupimm<mode><sd_maskz_name><round_saeonly_name>,
avx512f_sfixupimm<mode>_mask<round_saeonly_name>): Use %<iptr>3 instead
of %3 for -masm=intel.
(sse2_shufpd_v2df_mask): Fix a typo, change %{6%} to %{%6%} for
-masm=intel.
(*avx512vl_<code>v2div2qi2_store): Use %w0 instead of %0 for
-masm=intel.
(*avx512vl_<code><mode>v4qi2_store): Use %k0 instead of %0 for
-masm=intel.
(avx512vl_<code><mode>v4qi2_mask_store): Use a single pattern with
%k0 and %1 for -masm=intel rather than two patterns, one with %0 and
%g1.
(*avx512vl_<code><mode>v8qi2_store): Use %q0 instead of %0 for
-masm=intel.
(avx512vl_<code><mode>v8qi2_mask_store): Use a single pattern with
%q0 and %1 for -masm=intel rather than two patterns, one with %0 and
%g1 and one with %0 and %1.
(avx512er_vmrcp28<mode><round_saeonly_name>,
avx512er_vmrsqrt28<mode><round_saeonly_name>): Use %<iptr>1 instead of
%1 for -masm=intel.
(avx5124fmaddps_4fmaddps_mask, avx5124fmaddps_4fmaddss_mask,
avx5124fmaddps_4fnmaddps_mask, avx5124fmaddps_4fnmaddss_mask,
avx5124vnniw_vp4dpwssd_mask, avx5124vnniw_vp4dpwssds_mask): Swap order
of %0 and %{%4%} for -masm=intel.
(avx5124fmaddps_4fmaddps_maskz, avx5124fmaddps_4fmaddss_maskz,
avx5124fmaddps_4fnmaddps_maskz, avx5124fmaddps_4fnmaddss_maskz,
avx5124vnniw_vp4dpwssd_maskz, avx5124vnniw_vp4dpwssds_maskz): Swap
order of %0 and %{%5%}%{z%} for -masm=intel.

From-SVN: r259430

6 years agoSupport bitfields in Wodr machinery (PR lto/85405).
Martin Liska [Tue, 17 Apr 2018 05:41:40 +0000 (05:41 +0000)]
Support bitfields in Wodr machinery (PR lto/85405).

2018-04-17  Jan Hubicka  <jh@suse.cz>

PR lto/85405
* ipa-devirt.c (odr_types_equivalent_p): Handle bit fields.
2018-04-17  Martin Liska  <mliska@suse.cz>

PR lto/85405
* g++.dg/lto/pr85405_0.C: New test.
* g++.dg/lto/pr85405_1.C: New test.

From-SVN: r259429

6 years agoMake redirection only for target_clones: V3 (PR ipa/85329).
Martin Liska [Tue, 17 Apr 2018 05:40:39 +0000 (07:40 +0200)]
Make redirection only for target_clones: V3 (PR ipa/85329).

2018-04-17  Martin Liska  <mliska@suse.cz>

PR ipa/85329
* multiple_target.c (create_dispatcher_calls): Set apostrophes
for target_clone error message.  Make default implementation
        clone to be a local declaration.
(separate_attrs): Add new argument and check for an empty
string.
(expand_target_clones): Handle it.
(ipa_target_clone): Make redirection just for target_clones
functions.
2018-04-17  Martin Liska  <mliska@suse.cz>

PR ipa/85329
* g++.dg/ext/pr85329-2.C: New test.
* g++.dg/ext/pr85329.C: New test.
* gcc.target/i386/mvc12.c: New test.

From-SVN: r259428

6 years agoDaily bump.
GCC Administrator [Tue, 17 Apr 2018 00:16:14 +0000 (00:16 +0000)]
Daily bump.

From-SVN: r259426

6 years ago[PR c++/85039] no type definitions in builtin offsetof
Alexandre Oliva [Mon, 16 Apr 2018 21:35:34 +0000 (21:35 +0000)]
[PR c++/85039] no type definitions in builtin offsetof

Types defined within a __builtin_offsetof argument don't always get
properly recorded as members of their context types, so if they're
anonymous, we may fail to assign them an anon type index for mangling
and ICE.

We shouldn't allow types to be introduced in __builtin_offsetof, I
think, and Jason says the std committee agrees, so I've arranged for
us to reject them.

Even then, we still parse the definitions and attempt to assign
mangled names to its member functions, so the ICE remains.  Since
we've already reported an error, we might as well complete the name
assignment with an arbitrary index, thus avoiding the ICE.

We used to have a test that expected to be able to define types in
__builtin_offsetof; this patch removes that specific test.

for  gcc/cp/ChangeLog

PR c++/85039
* parser.c (cp_parser_builtin_offset): Reject type definitions.
* mangle.c (nested_anon_class_index): Avoid crash returning -1
if we've seen errors.

for  gcc/testsuite/ChangeLog

PR c++/85039
* g++.dg/pr85039-1.C: New.
* g++.dg/pr85039-2.C: New.
* g++.dg/parse/semicolon3.C: Remove test_offsetof.

From-SVN: r259423

6 years agore PR target/85080 (gcc.dg/vect/costmodel/ppc/costmodel-pr37194.c fails starting...
Bill Schmidt [Mon, 16 Apr 2018 18:18:42 +0000 (18:18 +0000)]
re PR target/85080 (gcc.dg/vect/costmodel/ppc/costmodel-pr37194.c fails starting with r248678)

[gcc/testsuite]

2018-04-16  Bill Schmidt  <wschmidt@linux.ibm.com>

PR target/85080
* gcc.dg/vect/costmodel/ppc/costmodel-pr37194.c: Skip dump checks
if the target supports efficient unaligned storage accesses.

From-SVN: r259407

6 years ago[openacc] Fix ICE when compiling tile loop containing infinite loop
Cesar Philippidis [Mon, 16 Apr 2018 18:01:09 +0000 (11:01 -0700)]
[openacc] Fix ICE when compiling tile loop containing infinite loop

2018-04-16  Cesar Philippidis  <cesar@codesourcery.com>
    Tom de Vries  <tom@codesourcery.com>

PR middle-end/84955
* omp-expand.c (expand_oacc_for): Add dummy false branch for
tiled basic blocks without omp continue statements.

* testsuite/libgomp.oacc-c-c++-common/pr84955.c: New test.
* testsuite/libgomp.oacc-fortran/pr84955.f90: New test.

Co-Authored-By: Tom de Vries <tom@codesourcery.com>
From-SVN: r259406

6 years agore PR target/83660 (ICE with vec_extract inside expression statement)
Aaron Sawdey [Mon, 16 Apr 2018 14:50:06 +0000 (14:50 +0000)]
re PR target/83660 (ICE with vec_extract inside expression statement)

2018-04-16  Aaron Sawdey  <acsawdey@linux.ibm.com>

PR target/83660
* config/rs6000/rs6000-c.c (altivec_resolve_overloaded_builtin): Mark
vec_extract expression as having side effects to make sure it gets
a cleanup point.

2018-04-16  Aaron Sawdey  <acsawdey@linux.ibm.com>

PR target/83660
* gcc.target/powerpc/pr83660.C: New test.

From-SVN: r259403

6 years agoi386: Check error_mark_node in multiversioning
H.J. Lu [Mon, 16 Apr 2018 11:31:22 +0000 (11:31 +0000)]
i386: Check error_mark_node in multiversioning

Since CET is applied to the whole program, it is correct to disallow
-fcf-protection=full without -mcet.  But compiler shouldn't crash.

gcc/

PR target/85403
* config/i386/i386.c (get_builtin_code_for_version): Check
error_mark_node.

gcc/testsuite/

PR target/85403
* gcc.target/i386/pr85403.c: New test.
---
 gcc/config/i386/i386.c                            |  2 ++
 gcc/testsuite/g++.dg/ext/mv1.C                    |  2 +-
 gcc/testsuite/g++.dg/ext/mv14.C                   |  2 +-
 gcc/testsuite/g++.dg/ext/mv15.C                   |  2 +-
 gcc/testsuite/g++.dg/ext/mv16.C                   |  2 +-
 gcc/testsuite/g++.dg/ext/mv17.C                   |  2 +-
 gcc/testsuite/g++.dg/ext/mv18.C                   |  2 +-
 gcc/testsuite/g++.dg/ext/mv19.C                   |  2 +-
 gcc/testsuite/g++.dg/ext/mv20.C                   |  2 +-
 gcc/testsuite/g++.dg/ext/mv21.C                   |  2 +-
 gcc/testsuite/g++.dg/ext/mv22.C                   |  2 +-
 gcc/testsuite/g++.dg/ext/mv23.C                   |  2 +-
 gcc/testsuite/g++.dg/ext/mv26.C                   |  1 +
 gcc/testsuite/g++.dg/ext/mv6.C                    |  2 +-
 gcc/testsuite/g++.dg/ext/mvc1.C                   |  1 +
 gcc/testsuite/gcc.target/i386/cet-notrack-icf-1.c |  2 +-
 gcc/testsuite/gcc.target/i386/cet-notrack-icf-3.c |  2 +-
 gcc/testsuite/gcc.target/i386/cet-property-2.c    |  2 +-
 gcc/testsuite/gcc.target/i386/mvc1.c              |  1 +
 gcc/testsuite/gcc.target/i386/mvc10.c             |  1 +
 gcc/testsuite/gcc.target/i386/mvc11.c             |  2 +-
 gcc/testsuite/gcc.target/i386/mvc6.c              |  2 +-
 gcc/testsuite/gcc.target/i386/mvc7.c              |  1 +
 gcc/testsuite/gcc.target/i386/mvc8.c              |  2 +-
 gcc/testsuite/gcc.target/i386/mvc9.c              |  2 +-
 gcc/testsuite/gcc.target/i386/pr81213.c           |  1 +
 gcc/testsuite/gcc.target/i386/pr81214.c           |  1 +
 gcc/testsuite/gcc.target/i386/pr85403.c           | 10 ++++++++++
 gcc/testsuite/gcc.target/i386/sse-26.c            |  2 +-
 29 files changed, 39 insertions(+), 20 deletions(-)
 create mode 100644 gcc/testsuite/gcc.target/i386/pr85403.c

diff --git a/gcc/config/i386/i386.c b/gcc/config/i386/i386.c
index 6fa5b0add02..8a73fc0d316 100644
--- a/gcc/config/i386/i386.c
+++ b/gcc/config/i386/i386.c
@@ -32344,6 +32344,8 @@ get_builtin_code_for_version (tree decl, tree *predicate_list)
        &global_options_set);

       gcc_assert (target_node);
+      if (target_node == error_mark_node)
+ return 0;
       new_target = TREE_TARGET_OPTION (target_node);
       gcc_assert (new_target);

diff --git a/gcc/testsuite/gcc.target/i386/pr85403.c b/gcc/testsuite/gcc.target/i386/pr85403.c
new file mode 100644
index 00000000000..f4fb12dd4e2
--- /dev/null
+++ b/gcc/testsuite/gcc.target/i386/pr85403.c
@@ -0,0 +1,10 @@
+/* { dg-do compile } */
+/* { dg-options "-fcf-protection -mcet" } */
+/* { dg-require-ifunc "" } */
+
+__attribute__((target_clones("avx","arch=slm","arch=core-avx2","default")))
+int
+foo ()
+{
+  return -2;
+} /* { dg-error "requires Intel CET support" } */

From-SVN: r259400

6 years agoFixed g++.dg/ext/mv16.C with -march=native.
Olga Makhotina [Mon, 16 Apr 2018 11:23:55 +0000 (11:23 +0000)]
Fixed g++.dg/ext/mv16.C with -march=native.

gcc/
PR target/84331
* gcc/config.gcc: Support "skylake".
* gcc/config/i386/i386-c.c (ix86_target_macros_internal): Handle
PROCESSOR_SKYLAKE.
* gcc/config/i386/i386.c (m_SKYLAKE): Define.
(processor_target_table): Add "skylake".
(ix86_option_override_internal): Add "skylake".
(get_builtin_code_for_version): Handle PROCESSOR_SKYLAKE,
PROCESSOR_CANNONLAKE.
(get_builtin_code_for_version): Fix priority for
PROCESSOR_ICELAKE_CLIENT, PROCESSOR_ICELAKE_SERVER,
PROCESSOR_SKYLAKE-AVX512.
* gcc/config/i386/i386.h (processor_costs): Define TARGET_SKYLAKE.
(processor_type): Add PROCESSOR_SKYLAKE.

gcc/testsuite/
PR target/84331
* gcc/testsuite/gcc.target/i386/funcspec-56.inc: Test arch=skylake.

From-SVN: r259399

6 years agore PR target/84945 (UBSAN: gcc/config/i386/i386.c:33312:22: runtime error: shift...
Jakub Jelinek [Mon, 16 Apr 2018 11:22:40 +0000 (13:22 +0200)]
re PR target/84945 (UBSAN: gcc/config/i386/i386.c:33312:22: runtime error: shift exponent 32 is too large for 32-bit type 'int')

PR target/84945
* config/i386/cpuinfo.c (set_feature): Wrap into do while (0) to avoid
-Wdangling-else warnings.  Mask shift counts to avoid
-Wshift-count-negative and -Wshift-count-overflow false positives.

From-SVN: r259398

6 years agore PR c++/85112 (ICE with invalid constexpr)
Paolo Carlini [Mon, 16 Apr 2018 08:31:23 +0000 (08:31 +0000)]
re PR c++/85112 (ICE with invalid constexpr)

2018-04-16  Paolo Carlini  <paolo.carlini@oracle.com>
    Jason Merrill  <jason@redhat.com>

PR c++/85112
* convert.c (convert_to_integer_1): Use direct recursion for
enumeral types and types with a precision less than the number
of bits in their mode.

/testsuite
2018-04-16  Paolo Carlini  <paolo.carlini@oracle.com>
    Jason Merrill  <jason@redhat.com>

PR c++/85112
* g++.dg/cpp0x/pr85112.C: New.

Co-Authored-By: Jason Merrill <jason@redhat.com>
From-SVN: r259397

6 years agoMake Filesystem TS tests pass in C++17 mode
Jonathan Wakely [Mon, 16 Apr 2018 08:24:40 +0000 (09:24 +0100)]
Make Filesystem TS tests pass in C++17 mode

The <testsuite_fs.h> header defaults to using std::filesystem in C++17
mode. The Filesystem TS tests need to define the macro that causes
std::experimental::filesystem to be used instead.

* testsuite/experimental/filesystem/file_status/1.cc: Add
-DUSE_FILESYSTEM_TS to dg-options.
* testsuite/experimental/filesystem/iterators/directory_iterator.cc:
Likewise.
* testsuite/experimental/filesystem/iterators/pop.cc: Likewise.
* testsuite/experimental/filesystem/iterators/
recursive_directory_iterator.cc: Likewise.
* testsuite/experimental/filesystem/operations/absolute.cc: Likewise.
* testsuite/experimental/filesystem/operations/canonical.cc: Likewise.
* testsuite/experimental/filesystem/operations/copy.cc: Likewise.
* testsuite/experimental/filesystem/operations/copy_file.cc: Likewise.
* testsuite/experimental/filesystem/operations/create_directories.cc:
Likewise.
* testsuite/experimental/filesystem/operations/create_directory.cc:
Likewise.
* testsuite/experimental/filesystem/operations/create_symlink.cc:
Likewise.
* testsuite/experimental/filesystem/operations/current_path.cc:
Likewise.
* testsuite/experimental/filesystem/operations/equivalent.cc: Likewise.
* testsuite/experimental/filesystem/operations/exists.cc: Likewise.
* testsuite/experimental/filesystem/operations/file_size.cc: Likewise.
* testsuite/experimental/filesystem/operations/is_empty.cc: Likewise.
* testsuite/experimental/filesystem/operations/last_write_time.cc:
Likewise.
* testsuite/experimental/filesystem/operations/permissions.cc:
Likewise.
* testsuite/experimental/filesystem/operations/read_symlink.cc:
Likewise.
* testsuite/experimental/filesystem/operations/remove.cc: Likewise.
* testsuite/experimental/filesystem/operations/remove_all.cc: Likewise.
* testsuite/experimental/filesystem/operations/status.cc: Likewise.
* testsuite/experimental/filesystem/operations/temp_directory_path.cc:
Likewise.
* testsuite/experimental/filesystem/path/append/path.cc: Likewise.
* testsuite/experimental/filesystem/path/assign/assign.cc: Likewise.
* testsuite/experimental/filesystem/path/assign/copy.cc: Likewise.
* testsuite/experimental/filesystem/path/compare/compare.cc: Likewise.
* testsuite/experimental/filesystem/path/compare/path.cc: Likewise.
* testsuite/experimental/filesystem/path/compare/strings.cc: Likewise.
* testsuite/experimental/filesystem/path/concat/path.cc: Likewise.
* testsuite/experimental/filesystem/path/concat/strings.cc: Likewise.
* testsuite/experimental/filesystem/path/construct/copy.cc: Likewise.
* testsuite/experimental/filesystem/path/construct/default.cc:
Likewise.
* testsuite/experimental/filesystem/path/construct/locale.cc: Likewise.
* testsuite/experimental/filesystem/path/construct/range.cc: Likewise.
* testsuite/experimental/filesystem/path/construct/string_view.cc:
Likewise.
* testsuite/experimental/filesystem/path/decompose/extension.cc:
Likewise.
* testsuite/experimental/filesystem/path/decompose/filename.cc:
Likewise.
* testsuite/experimental/filesystem/path/decompose/parent_path.cc:
Likewise.
* testsuite/experimental/filesystem/path/decompose/relative_path.cc:
Likewise.
* testsuite/experimental/filesystem/path/decompose/root_directory.cc:
Likewise.
* testsuite/experimental/filesystem/path/decompose/root_name.cc:
Likewise.
* testsuite/experimental/filesystem/path/decompose/root_path.cc:
Likewise.
* testsuite/experimental/filesystem/path/decompose/stem.cc: Likewise.
* testsuite/experimental/filesystem/path/generic/generic_string.cc:
Likewise.
* testsuite/experimental/filesystem/path/itr/traversal.cc: Likewise.
* testsuite/experimental/filesystem/path/modifiers/clear.cc: Likewise.
* testsuite/experimental/filesystem/path/modifiers/make_preferred.cc:
Likewise.
* testsuite/experimental/filesystem/path/modifiers/remove_filename.cc:
Likewise.
* testsuite/experimental/filesystem/path/modifiers/replace_extension.cc:
Likewise.
* testsuite/experimental/filesystem/path/modifiers/replace_filename.cc:
Likewise.
* testsuite/experimental/filesystem/path/modifiers/swap.cc: Likewise.
* testsuite/experimental/filesystem/path/native/string.cc: Likewise.
* testsuite/experimental/filesystem/path/nonmember/hash_value.cc:
Likewise.
* testsuite/experimental/filesystem/path/query/empty.cc: Likewise.
* testsuite/experimental/filesystem/path/query/has_extension.cc:
Likewise.
* testsuite/experimental/filesystem/path/query/has_filename.cc:
Likewise.
* testsuite/experimental/filesystem/path/query/has_parent_path.cc:
Likewise.
* testsuite/experimental/filesystem/path/query/has_relative_path.cc:
Likewise.
* testsuite/experimental/filesystem/path/query/has_root_directory.cc:
Likewise.
* testsuite/experimental/filesystem/path/query/has_root_name.cc:
Likewise.
* testsuite/experimental/filesystem/path/query/has_root_path.cc:
Likewise.
* testsuite/experimental/filesystem/path/query/has_stem.cc: Likewise.
* testsuite/experimental/filesystem/path/query/is_relative.cc:
Likewise.

From-SVN: r259396

6 years agoAdd sse_unaligned_load_optimal and sse_unaligned_store_optimal to Skylake.
Julia Koval [Mon, 16 Apr 2018 05:59:52 +0000 (07:59 +0200)]
Add sse_unaligned_load_optimal and sse_unaligned_store_optimal to Skylake.

gcc/
PR target/84413
* config/i386/x86-tune.def (X86_TUNE_SSE_UNALIGNED_LOAD_OPTIMAL,
X86_TUNE_SSE_UNALIGNED_STORE_OPTIMAL): Add m_SKYLAKE_AVX512

From-SVN: r259395

6 years agore PR testsuite/85326 (`make check` fails with `--disable-bootstrap` and `--enable...
Bill Schmidt [Mon, 16 Apr 2018 02:00:43 +0000 (02:00 +0000)]
re PR testsuite/85326 (`make check` fails with `--disable-bootstrap` and `--enable-languages=c`)

[gcc/testsuite]

2018-04-15  Bill Schmidt  <wschmidt@linux.ibm.com>

PR testsuite/85326
* g++.dg/ext/undef-bool-1.C: New file.
* gcc.target/powerpc/powerpc.exp: Remove .C support.
* gcc.target/powerpc/undef-bool-1.C: Remove file.

From-SVN: r259393

6 years agoDaily bump.
GCC Administrator [Mon, 16 Apr 2018 00:16:14 +0000 (00:16 +0000)]
Daily bump.

From-SVN: r259392

6 years agoDaily bump.
GCC Administrator [Sun, 15 Apr 2018 00:16:22 +0000 (00:16 +0000)]
Daily bump.

From-SVN: r259389

6 years agors6000: Disable -m[no-]direct-move (PR85293)
Segher Boessenkool [Sat, 14 Apr 2018 21:13:20 +0000 (23:13 +0200)]
rs6000: Disable -m[no-]direct-move (PR85293)

The -mno-direct-move option causes a lot of problems, since it forces
us to be able to generate code for p8 and up with some crucial
instructions missing.  This patch removes the -m[no-]direct-move
options so that the user cannot put us into this unexpected situation
anymore.  Internally we still have all the same flags, and they are
automatically set based on -mcpu; getting rid of that is a lot more
work and will have to wait for GCC 9 (in some places the flag is used
to see if we are compiling for a p8 _at all_).

PR target/85293
* config/rs6000/rs6000.opt (mdirect-move): Make deprecated.
* doc/invoke.texi (RS/6000 and PowerPC Options): Remove -mdirect-move
and -mno-direct-move.

gcc/testsuite/
PR target/85293
* gcc.target/powerpc/pr80098-2.c: Remove -mdirect-move.  Remove the
corresponding dg-error clause.
* gcc.target/powerpc/pr80098-3.c: Ditto.
* gcc.target/powerpc/pr80103-1.c: Delete.

From-SVN: r259386

6 years agore PR fortran/81773 ([Coarray] Get with vector index on lhs leads to incorrect caf_ge...
Andre Vehreschild [Sat, 14 Apr 2018 14:45:59 +0000 (16:45 +0200)]
re PR fortran/81773 ([Coarray] Get with vector index on lhs leads to incorrect caf_get_by_ref() call.)

gcc/fortran/ChangeLog:

2018-04-14  Andre Vehreschild  <vehre@gcc.gnu.org>

PR fortran/81773
PR fortran/83606
* dependency.c (gfc_dep_resolver): Coarray indexes are to be ignored
during dependency computation.  They define no data dependency.
* trans-array.c (conv_array_index_offset): The stride can not be set
here, prevent fail.
* trans-intrinsic.c (conv_caf_send): Add creation of temporary array
for caf_get's result and copying to the array with vectorial
indexing.

gcc/testsuite/ChangeLog:

2018-04-14  Andre Vehreschild  <vehre@gcc.gnu.org>

PR fortran/81773
PR fortran/83606
* gfortran.dg/coarray/get_to_indexed_array_1.f90: New test.
* gfortran.dg/coarray/get_to_indirect_array.f90: New test.

From-SVN: r259385

6 years agore PR fortran/85387 (incorrect output with optimization /= 0)
Thomas Koenig [Sat, 14 Apr 2018 13:38:41 +0000 (13:38 +0000)]
re PR fortran/85387 (incorrect output with optimization /= 0)

2018-04-14  Thomas Koenig  <tkoenig@gcc.gnu.org>

PR fortran/85387
* frontend-passes.c (traverse_io_block): Check for start, end or
stride being defined by an outer implied DO loop.

2018-04-14  Thomas Koenig  <tkoenig@gcc.gnu.org>

PR fortran/85387
* gfortran.dg/implied_do_io_5.f90: New test.

From-SVN: r259384

6 years agoDaily bump.
GCC Administrator [Sat, 14 Apr 2018 00:16:23 +0000 (00:16 +0000)]
Daily bump.

From-SVN: r259383

6 years agors6000: Fix _mm_slli_epi{32,64} for shift values 16 through 31 and negative (PR84302)
Paul A. Clarke [Fri, 13 Apr 2018 23:13:40 +0000 (23:13 +0000)]
rs6000: Fix _mm_slli_epi{32,64} for shift values 16 through 31 and negative (PR84302)

The powerpc versions of _mm_slli_epi32 and __mm_slli_epi64 in emmintrin.h
do not properly handle shift values between 16 and 31, inclusive.
These are setting up the shift with vec_splat_s32, which only accepts
*5 bit signed* shift values, or a range of -16 to 15.  Values above 15
produce an error:

  error: argument 1 must be a 5-bit signed literal

Fix is to effectively reduce the range for which vec_splat_s32 is used
to < 32 and use vec_splats otherwise.

Also, __mm_slli_epi{16,32,64}, when given a negative shift value,
should always return a vector of {0}.

PR target/83402
* config/rs6000/emmintrin.h (_mm_slli_epi{16,32,64}):
Ensure that vec_splat_s32 is only called with 0 <= shift < 16.
Ensure negative shifts result in {0}.

gcc/testsuite/
PR target/83402
* gcc.target/powerpc/sse2-psllw-1.c: Refactor and add tests for
several values:  positive, negative, and zero.
* gcc.target/powerpc/sse2-pslld-1.c: Same.
* gcc.target/powerpc/sse2-psllq-1.c: Same.

From-SVN: r259380

6 years agore PR rtl-optimization/79916 (ICE in Max. number of generated reload insns per insn...
Vladimir Makarov [Fri, 13 Apr 2018 22:55:16 +0000 (22:55 +0000)]
re PR rtl-optimization/79916 (ICE in Max. number of generated reload insns per insn is achieved (90))

2018-04-13  Vladimir Makarov  <vmakarov@redhat.com>

PR rtl-optimization/79916
* config/rs6000/rs6000.c (rs6000_emit_move): Use assigned hard
regs (if any) to define how to gnerate SD moves when LRA is in
progress.

2018-04-13  Vladimir Makarov  <vmakarov@redhat.com>

PR rtl-optimization/79916
* gcc.target/powerpc/pr79916.c: New.

From-SVN: r259379

6 years agore PR rtl-optimization/85393 (Miscompilation with hot/cold partitioning starting...
Jakub Jelinek [Fri, 13 Apr 2018 19:55:15 +0000 (21:55 +0200)]
re PR rtl-optimization/85393 (Miscompilation with hot/cold partitioning starting with r254832)

PR rtl-optimization/85393
* except.h (expand_dw2_landing_pad_for_region): Remove declaration.
* except.c (expand_dw2_landing_pad_for_region): Make static.
* bb-reorder.c (fix_up_crossing_landing_pad): In new_bb emit just
a label and unconditional jump to old_bb, rather than
expand_dw2_landing_pad_for_region insn(s) and jump to single_succ
basic block.

* g++.dg/opt/pr85393.C: New test.
* g++.dg/opt/pr85393-aux.cc: New file.

From-SVN: r259378

6 years agore PR rtl-optimization/85376 (wrong code with -Og -fno-dce -fgcse -fno-tree-ccp ...
Jakub Jelinek [Fri, 13 Apr 2018 19:39:11 +0000 (21:39 +0200)]
re PR rtl-optimization/85376 (wrong code with -Og -fno-dce -fgcse -fno-tree-ccp -fno-tree-copy-prop)

PR rtl-optimization/85376
* simplify-rtx.c (simplify_const_unary_operation): For CLZ and CTZ and
zero op0, if C?Z_DEFINED_VALUE_AT_ZERO is false, return NULL_RTX
instead of a specific value.

* gcc.dg/pr85376.c: New test.

From-SVN: r259377

6 years agoFix broken sed command from previous commit
Jonathan Wakely [Fri, 13 Apr 2018 10:55:29 +0000 (11:55 +0100)]
Fix broken sed command from previous commit

* src/c++11/Makefile.am: Fix sed command.
* src/c++11/Makefile.in: Regenerate.

From-SVN: r259374

6 years agore PR rtl-optimization/83852 (ICE in sel_redirect_edge_and_branch, at sel-sched-ir...
Andrey Belevantsev [Fri, 13 Apr 2018 10:24:02 +0000 (13:24 +0300)]
re PR rtl-optimization/83852 (ICE in sel_redirect_edge_and_branch, at sel-sched-ir.c:5644 on 32-bit BE powerpc targets)

        PR rtl-optimization/83852
        * gcc.dg/pr83852.c: New testcase.

From-SVN: r259373

6 years agoFix __iosfail_type_info hack to work on darwin
Jonathan Wakely [Fri, 13 Apr 2018 10:06:21 +0000 (11:06 +0100)]
Fix __iosfail_type_info hack to work on darwin

* src/c++11/Makefile.am: Rewrite sed rule to be less fragile and to
handle mangled names starting with double underscores on darwin.
* src/c++11/Makefile.in: Regenerate.

From-SVN: r259371

6 years agoIBM Z: Get rid of target specific C++ testcase
Andreas Krebbel [Fri, 13 Apr 2018 09:14:32 +0000 (09:14 +0000)]
IBM Z: Get rid of target specific C++ testcase

gcc/testsuite/ChangeLog:

2018-04-13  Andreas Krebbel  <krebbel@linux.ibm.com>

        PR testsuite/85326
        * gcc.target/s390/pr77822-1.C: Rename to ...
        * gcc.target/s390/pr77822-1.c: ... this. Add asm scan check.
        * gcc.target/s390/pr77822-2.c: Add asm scan check.
        * gcc.target/s390/s390.exp: Remove C from testcase regexps.

From-SVN: r259369

6 years agore PR tree-optimization/82965 (gcc.dg/vect/pr79347.c starts failing after r254379)
Jan Hubicka [Fri, 13 Apr 2018 08:59:05 +0000 (10:59 +0200)]
re PR tree-optimization/82965 (gcc.dg/vect/pr79347.c starts failing after r254379)

PR tree-optimization/82965
PR tree-optimization/83991
* cfgloopanal.c (expected_loop_iterations_unbounded): Add
by_profile_only parameter.
* cfgloopmanip.c (scale_loop_profile): Further scale loop's profile
        information if the loop was predicted to iterate too many times.
* cfgloop.h (expected_loop_iterations_unbounded): Update prototype

Co-Authored-By: Bin Cheng <bin.cheng@arm.com>
From-SVN: r259368

6 years agore PR target/71991 (Inconsistency for __attribute__ ((__always_inline__)) among LTO...
Jan Hubicka [Fri, 13 Apr 2018 08:51:47 +0000 (10:51 +0200)]
re PR target/71991 (Inconsistency for __attribute__ ((__always_inline__)) among LTO and non-LTO compilation)

PR lto/71991
* config/i386/i386.c (ix86_can_inline_p): Allow safe transitions for
always inline.
* gcc.target/i386/pr71991.c: New testcase.

From-SVN: r259367

6 years agore PR middle-end/81657 (FAIL: gcc.dg/20050503-1.c scan-assembler-not call)
Martin Liska [Fri, 13 Apr 2018 08:35:32 +0000 (10:35 +0200)]
re PR middle-end/81657 (FAIL: gcc.dg/20050503-1.c scan-assembler-not call)

PR middle-end/81657
* expr.h (enum block_op_methods): Add BLOCK_OP_NO_LIBCALL_RET.
* expr.c (emit_block_move_hints): Handle BLOCK_OP_NO_LIBCALL_RET.
* builtins.c (expand_builtin_memory_copy_args): Use
BLOCK_OP_NO_LIBCALL_RET method for mempcpy with non-ignored target,
handle dest_addr == pc_rtx.

* gcc.dg/string-opt-1.c: Remove bogus comment.  Expect a mempcpy
call.

Co-Authored-By: Jakub Jelinek <jakub@redhat.com>
From-SVN: r259366

6 years agoFix gcc.dg/debug/pr41893-1.c with Solaris ld (PR lto/81968)
Rainer Orth [Fri, 13 Apr 2018 08:02:15 +0000 (08:02 +0000)]
Fix gcc.dg/debug/pr41893-1.c with Solaris ld (PR lto/81968)

PR lto/81968
* simple-object.c (handle_lto_debug_sections): Keep .comment
section.

From-SVN: r259364

6 years agoDaily bump.
GCC Administrator [Fri, 13 Apr 2018 00:16:17 +0000 (00:16 +0000)]
Daily bump.

From-SVN: r259363

6 years agoPrevent erroneous "macro had not yet been defined" messages (PR c++/85385)
David Malcolm [Thu, 12 Apr 2018 23:44:09 +0000 (23:44 +0000)]
Prevent erroneous "macro had not yet been defined" messages (PR c++/85385)

PR c++/85385 reports an issue where we emit bogus "macro had not yet been
defined" notes when a macro is mis-used:

  $ cat test.c
  #define MACRO(X,Y)

  void test ()
  {
    MACRO(42);
  }

  $ ./xg++ -B. -c test.c
  test.c:5:11: error: macro "MACRO" requires 2 arguments, but only 1 given
     MACRO(42);
             ^
  test.c: In function â€˜void test()’:
  test.c:5:3: error: â€˜MACRO’ was not declared in this scope
     MACRO(42);
     ^~~~~
  test.c:5:3: note:
  test.c:1: note: it was later defined here
   #define MACRO(X,Y)

The macro *had* been defined, it was merely misused.

This patch fixes the issue by only issuing the note if the use location
is before the definition location (using linemap_location_before_p).

gcc/cp/ChangeLog:
PR c++/85385
* name-lookup.c (macro_use_before_def::maybe_make): New function,
checking that the use is indeed before the definition.
(macro_use_before_def::macro_use_before_def): Make private.
(macro_use_before_def::~macro_use_before_def): Make private.  Move
check for UNKNOWN_LOCATION to macro_use_before_def::maybe_make.
(lookup_name_fuzzy): Call macro_use_before_def::maybe_make rather
than using new directly.

gcc/testsuite/ChangeLog:
PR c++/85385
* g++.dg/diagnostic/macro-arg-count.C: New test.

From-SVN: r259360

6 years agore PR fortran/83064 (DO CONCURRENT and auto-parallelization)
Thomas Koenig [Thu, 12 Apr 2018 21:58:54 +0000 (21:58 +0000)]
re PR fortran/83064 (DO CONCURRENT and auto-parallelization)

2018-04-12  Thomas Koenig  <tkoenig@gcc.gnu.org>

PR fortran/83064
PR testsuite/85346
* trans-stmt.c (gfc_trans_forall_loop): Use annot_expr_ivdep_kind
for annotation and remove dependence on -ftree-parallelize-loops.

2018-04-12  Thomas Koenig  <tkoenig@gcc.gnu.org>

PR fortran/83064
PR testsuite/85346
* gfortran.dg/do_concurrent_5.f90: Dynamically allocate main work
array and move test to libgomp/testsuite/libgomp.fortran.
* gfortran.dg/do_concurrent_6.f90: New test.

2018-04-12  Thomas Koenig  <tkoenig@gcc.gnu.org>

PR fortran/83064
PR testsuite/85346
* testsuite/libgomp.fortran/do_concurrent_5.f90: Move modified
test from gfortran.dg to here.

From-SVN: r259359

6 years agoFix comments that misspell names of files and classes
Jonathan Wakely [Thu, 12 Apr 2018 20:55:02 +0000 (21:55 +0100)]
Fix comments that misspell names of files and classes

* src/c++11/Makefile.am: Fix comment.
* src/c++11/Makefile.in: Regenerate.
* src/c++11/cxx11-ios_failure.cc: Fix comment.
* src/c++98/ios_failure.cc: Likewise.

From-SVN: r259357

6 years agoPR c++/85356 - ICE with pointer to member function.
Jason Merrill [Thu, 12 Apr 2018 20:03:33 +0000 (16:03 -0400)]
PR c++/85356 - ICE with pointer to member function.

* pt.c (maybe_instantiate_noexcept): Do instantiate in templates if
flag_noexcept_type.  Build the new spec within the function context.
* except.c (build_noexcept_spec): Do get constant value in templates
if flag_noexcept_type.
* decl.c (check_redeclaration_exception_specification): Don't
instantiate noexcept on a dependent declaration.

From-SVN: r259356

6 years agore PR c++/85258 (ICE with invalid range-based for-loop)
Marek Polacek [Thu, 12 Apr 2018 20:02:47 +0000 (20:02 +0000)]
re PR c++/85258 (ICE with invalid range-based for-loop)

PR c++/85258
* constexpr.c (reduced_constant_expression_p): Return false for null
trees.

* g++.dg/parse/error61.C: New test.

From-SVN: r259355

6 years agors6000: Fix an ICE with -mno-direct-move (PR85291)
Segher Boessenkool [Thu, 12 Apr 2018 20:01:37 +0000 (22:01 +0200)]
rs6000: Fix an ICE with -mno-direct-move (PR85291)

PR target/85291
* config/rs6000/rs6000.md (fix_trunc<mode>si2): Use legacy code if
asked to not generate direct moves.
(fix_trunc<mode>si2_stfiwx): Similar.
(fix_trunc<mode>si2_internal): Similar.

From-SVN: r259354

6 years agore PR debug/83157 (gcc.dg/guality/pr41616-1.c fail, inline instances refer to concret...
Jakub Jelinek [Thu, 12 Apr 2018 19:30:00 +0000 (21:30 +0200)]
re PR debug/83157 (gcc.dg/guality/pr41616-1.c fail, inline instances refer to concrete instance as abstract origin)

PR debug/83157
* var-tracking.c (add_stores): Handle STRICT_LOW_PART SET_DEST.
* cselib.c (cselib_record_sets): For STRICT_LOW_PART dest,
lookup if dest in some wider mode is known to be const0_rtx and
if so, record permanent equivalence for it to be ZERO_EXTEND of
the narrower mode destination.

From-SVN: r259353

6 years agoRevert 259346.
Cesar Philippidis [Thu, 12 Apr 2018 18:48:56 +0000 (11:48 -0700)]
Revert 259346.

gcc/
* lto-streamer-out.c (output_function): Revert 259346.
* omp-expand.c (expand_oacc_for): Likewise.

libgomp/
* testsuite/libgomp.oacc-c-c++-common/pr84955.c: Revert 259346.
* testsuite/libgomp.oacc-fortran/pr84955.f90:Likewise.

From-SVN: r259351

6 years agore PR target/85347 (New testcase vec-ldl-1.c FAILs on powerpc64-linux)
Kelvin Nilsen [Thu, 12 Apr 2018 16:16:08 +0000 (16:16 +0000)]
re PR target/85347 (New testcase vec-ldl-1.c FAILs on powerpc64-linux)

gcc/testsuite/ChangeLog:

2018-04-12  Kelvin Nilsen  <kelvin@gcc.gnu.org>

PR target/85347
* gcc.target/powerpc/vec-ldl-1.c: Change dejagnu directives to
specify -mvsx on gcc command line.

From-SVN: r259350

6 years agoRemove #define made redundant by r259281
Jonathan Wakely [Thu, 12 Apr 2018 16:06:03 +0000 (17:06 +0100)]
Remove #define made redundant by r259281

The definition of __throw_ios_failure is no longer in this file, so
setting the macro here is unnecessary.

* src/c++11/ios.cc: Remove redundant macro definition.

From-SVN: r259349

6 years agosel-sched: move cleanup_cfg before calculate_dominance_info (PR 85354)
Alexander Monakov [Thu, 12 Apr 2018 15:40:44 +0000 (18:40 +0300)]
sel-sched: move cleanup_cfg before calculate_dominance_info (PR 85354)

PR rtl-optimization/85354
* sel-sched-ir.c (sel_init_pipelining): Move cfg_cleanup call...
* sel-sched.c (sel_global_init): ... here.

From-SVN: r259348

6 years agore PR target/85238 (lto-wrapper: fatal error: simple_object_copy_lto_debug_sections...
Eric Botcazou [Thu, 12 Apr 2018 14:18:17 +0000 (14:18 +0000)]
re PR target/85238 (lto-wrapper: fatal error:  simple_object_copy_lto_debug_sections not implemented: Invalid argument  on Cygwin)

PR target/85238
* lto-wrapper.c (debug_objcopy): Open the files in binary mode.
* dwarf2out.c (dwarf2out_early_finish): Do not generate assembly in LTO
mode for PE-COFF targets.
* config/i386/i386-protos.h (i386_pe_asm_lto_start): Declare.
(i386_pe_asm_lto_end): Likewise.
* config/i386/cygming.h (TARGET_ASM_LTO_START): Define.
(TARGET_ASM_LTO_END): Likewise.
* config/i386/winnt.c (saved_debug_info_level): New static variable.
(i386_pe_asm_lto_start): New function.
(i386_pe_asm_lto_end): Likewise.

From-SVN: r259347

6 years agore PR middle-end/84955 (Incorrect OpenACC tile expansion)
Cesar Philippidis [Thu, 12 Apr 2018 13:15:45 +0000 (06:15 -0700)]
re PR middle-end/84955 (Incorrect OpenACC tile expansion)

PR middle-end/84955

gcc/
* lto-streamer-out.c (output_function): Fix CFG loop state before
streaming out.
* omp-expand.c (expand_oacc_for): Handle calls to internal
functions like regular functions.

libgomp/
* testsuite/libgomp.oacc-c-c++-common/pr84955.c: New test.
* testsuite/libgomp.oacc-fortran/pr84955.f90: New test.

Co-Authored-By: Richard Biener <rguenther@suse.de>
From-SVN: r259346

6 years agore PR lto/85371 (Compiling code with -g -flto gives an ICE on darwin after revision...
Richard Biener [Thu, 12 Apr 2018 12:27:14 +0000 (12:27 +0000)]
re PR lto/85371 (Compiling code with -g -flto gives an ICE on darwin after revision r259317)

2018-04-12  Richard Biener  <rguenther@suse.de>

PR lto/85371
* dwarf2out.c (init_sections_and_labels): Use debug_line_section[_label]
for the early LTO debug to properly generate references to it
during DIE emission.  Do not re-use that for the skeleton for
split-dwarf.
(dwarf2out_early_finish): Likewise.

From-SVN: r259345

6 years agore PR target/85328 (accessing ymm16 with non-avx512 instruction form)
Jakub Jelinek [Thu, 12 Apr 2018 11:17:23 +0000 (13:17 +0200)]
re PR target/85328 (accessing ymm16 with non-avx512 instruction form)

PR target/85328
* config/i386/sse.md
(<mask_codefor>avx512dq_vextract<shuffletype>64x2_1<mask_name> split,
<mask_codefor>avx512f_vextract<shuffletype>32x4_1<mask_name> split,
vec_extract_lo_<mode><mask_name> split, vec_extract_lo_v32hi,
vec_extract_lo_v64qi): For non-AVX512VL if input is xmm16+ reg
and output is a reg, avoid creating invalid lowpart subreg, but
instead split into a 512-bit move.  Don't split if not AVX512VL,
input is xmm16+ reg and output is a mem.
(vec_extract_lo_<mode><mask_name>, vec_extract_lo_v32hi,
vec_extract_lo_v64qi): Don't require split if not AVX512VL, input is
xmm16+ reg and output is a mem.

* gcc.target/i386/pr85328.c: New test.

From-SVN: r259344

6 years agoIBM Z: Spectre: Prevent thunk cfi to be emitted with -fno-dwarf2-cfi-asm
Andreas Krebbel [Thu, 12 Apr 2018 09:14:57 +0000 (09:14 +0000)]
IBM Z: Spectre: Prevent thunk cfi to be emitted with -fno-dwarf2-cfi-asm

The CFI magic we emit as part of the indirect branch thunks in order to
have somewhat sane unwind information must not be emitted with
-fno-dwarf2-cfi-asm.

gcc/ChangeLog:

2018-04-12  Andreas Krebbel  <krebbel@linux.vnet.ibm.com>

* config/s390/s390.c (s390_output_indirect_thunk_function): Check
also for flag_dwarf2_cfi_asm.

gcc/testsuite/ChangeLog:

2018-04-12  Andreas Krebbel  <krebbel@linux.vnet.ibm.com>

* gcc.target/s390/nobp-no-dwarf2-cfi.c: New test.

From-SVN: r259340

6 years agoWzero-as-null-pointer-constant-7.C: Move...
Paolo Carlini [Thu, 12 Apr 2018 08:44:47 +0000 (08:44 +0000)]
Wzero-as-null-pointer-constant-7.C: Move...

2018-04-11  Paolo Carlini  <paolo.carlini@oracle.com>

* g++.dg/warn/Wzero-as-null-pointer-constant-7.C: Move...
* g++.dg/cpp0x/Wzero-as-null-pointer-constant-3.C: ... here.

From-SVN: r259339

6 years agore PR rtl-optimization/85342 (ICE: SIGSEGV in copyprop_hardreg_forward_1 (regcprop...
Jakub Jelinek [Thu, 12 Apr 2018 08:39:50 +0000 (10:39 +0200)]
re PR rtl-optimization/85342 (ICE: SIGSEGV in copyprop_hardreg_forward_1 (regcprop.c:995) with -O2 -mavx512vl)

PR rtl-optimization/85342
* regcprop.c (copyprop_hardreg_forward_1): Remove replaced array, use
a bool scalar var inside of the loop instead.  Don't try to update
recog_data.operand after failed apply_change_group.

* gcc.target/i386/pr85342.c: New test.

From-SVN: r259338

6 years ago[nvptx] Fix handling of extern var with flexible array member
Tom de Vries [Thu, 12 Apr 2018 07:17:29 +0000 (07:17 +0000)]
[nvptx] Fix handling of extern var with flexible array member

2018-04-12  Tom de Vries  <tom@codesourcery.com>

PR target/85296
* config/nvptx/nvptx.c (flexible_array_member_type_p): New function.
(nvptx_assemble_decl_begin): Add undefined param.  Declare undefined
array with flexible array member as array without given dimension.
(nvptx_assemble_undefined_decl): Set nvptx_assemble_decl_begin call
argument for undefined param to true.

From-SVN: r259337

6 years agoDaily bump.
GCC Administrator [Thu, 12 Apr 2018 00:16:14 +0000 (00:16 +0000)]
Daily bump.

From-SVN: r259336

6 years ago* lib/asan-dg.exp: Don't run tests if ulimit -v is set.
Jason Merrill [Wed, 11 Apr 2018 23:43:28 +0000 (19:43 -0400)]
* lib/asan-dg.exp: Don't run tests if ulimit -v is set.

From-SVN: r259333

6 years agoWzero-as-null-pointer-constant-7.C: Move...
Paolo Carlini [Wed, 11 Apr 2018 18:14:07 +0000 (18:14 +0000)]
Wzero-as-null-pointer-constant-7.C: Move...

2018-04-11  Paolo Carlini  <paolo.carlini@oracle.com>

* g++.dg/warn/Wzero-as-null-pointer-constant-7.C: Move...
* g++.dg/cpp0x/Wzero-as-null-pointer-constant-3.C: ... here.

From-SVN: r259327

6 years agore PR testsuite/85190 (gcc.dg/vect/pr81196.c FAILs)
Bin Cheng [Wed, 11 Apr 2018 16:50:16 +0000 (16:50 +0000)]
re PR testsuite/85190 (gcc.dg/vect/pr81196.c FAILs)

gcc/testsuite
PR testsuite/85190
* gcc.dg/vect/pr81196.c: Remove function with undefined behavior.

From-SVN: r259326

6 years agore PR c++/70808 (Spurious -Wzero-as-null-pointer-constant for nullptr_t)
Jakub Jelinek [Wed, 11 Apr 2018 15:55:15 +0000 (17:55 +0200)]
re PR c++/70808 (Spurious -Wzero-as-null-pointer-constant for nullptr_t)

PR c++/70808
* g++.dg/warn/Wzero-as-null-pointer-constant-7.C: Require c++11
effective target.

From-SVN: r259325

6 years agore PR target/85321 (Missing documentation and option misc for ppc64le)
Aaron Sawdey [Wed, 11 Apr 2018 15:25:42 +0000 (15:25 +0000)]
re PR target/85321 (Missing documentation and option misc for ppc64le)

2018-04-11  Aaron Sawdey  <acsawdey@linux.ibm.com>

PR target/85321
* doc/invoke.texi (RS/6000 and PowerPC Options): Document options
-mcall- and -mtraceback=. Remove options -mabi=spe and -mabi=no-spe
from PowerPC section.
* config/rs6000/sysv4.opt (mcall-): Improve help text.
* config/rs6000/rs6000.opt (mblock-compare-inline-limit=): Trim
help text that is too long.
* config/rs6000/rs6000.opt (mblock-compare-inline-loop-limit=): Trim
help text that is too long.
* config/rs6000/rs6000.opt (mstring-compare-inline-limit=): Trim
help text that is too long.

From-SVN: r259324

6 years agoalpha.md (stack_probe_internal): Rename from "probe_stack".
Uros Bizjak [Wed, 11 Apr 2018 15:06:12 +0000 (17:06 +0200)]
alpha.md (stack_probe_internal): Rename from "probe_stack".

* config/alpha/alpha.md (stack_probe_internal): Rename
from "probe_stack".  Update all callers.

From-SVN: r259323

6 years agosched-deps: respect deps->readonly in macro-fusion (PR 84566)
Alexander Monakov [Wed, 11 Apr 2018 14:36:04 +0000 (17:36 +0300)]
sched-deps: respect deps->readonly in macro-fusion (PR 84566)

PR rtl-optimization/84566
* sched-deps.c (sched_analyze_insn): Check deps->readonly when invoking
sched_macro_fuse_insns.

From-SVN: r259322

6 years agosched-rgn: run add_branch_dependencies for sel-sched (PR 84301)
Alexander Monakov [Wed, 11 Apr 2018 14:32:32 +0000 (17:32 +0300)]
sched-rgn: run add_branch_dependencies for sel-sched (PR 84301)

PR target/84301
* sched-rgn.c (add_branch_dependences): Move sel_sched_p check here...
(compute_block_dependences): ... from here.

testsuite/
* gcc.target/i386/pr84301.c: New test.

From-SVN: r259321

6 years agore PR tree-optimization/85331 (during GIMPLE pass, internal compiler error: Segmentat...
Jakub Jelinek [Wed, 11 Apr 2018 13:35:13 +0000 (15:35 +0200)]
re PR tree-optimization/85331 (during GIMPLE pass, internal compiler error: Segmentation fault (-O1 and above))

PR tree-optimization/85331
* vec-perm-indices.h (vec_perm_indices::clamp): Change input type
from int to HOST_WIDE_INT.

* gcc.c-torture/execute/pr85331.c: New test.

From-SVN: r259320

6 years agoImprove IPA-CP handling of self-recursive calls
Martin Jambor [Wed, 11 Apr 2018 13:30:53 +0000 (15:30 +0200)]
Improve IPA-CP handling of self-recursive calls

2018-04-11  Martin Jambor  <mjambor@suse.cz>

PR ipa/84149
* ipa-cp.c (propagate_vals_across_pass_through): Expand comment.
(cgraph_edge_brings_value_p): New parameter dest_val, check if it is
not the same as the source val.
(cgraph_edge_brings_value_p): New parameter.
(gather_edges_for_value): Pass destination value to
cgraph_edge_brings_value_p.
(perhaps_add_new_callers): Likewise.
(get_info_about_necessary_edges): Likewise and exclude values brought
only by self-recursive edges.
(create_specialized_node): Redirect only clones of self-calling edges.
(+self_recursive_pass_through_p): New function.
(find_more_scalar_values_for_callers_subset): Use it.
(find_aggregate_values_for_callers_subset): Likewise.
(known_aggs_to_agg_replacement_list): Removed.
(decide_whether_version_node): Re-calculate known constants for all
remaining context clones.

From-SVN: r259319

6 years agore PR c++/85032 (Wrong non-constant condition for static assertion)
Marek Polacek [Wed, 11 Apr 2018 13:10:16 +0000 (13:10 +0000)]
re PR c++/85032 (Wrong non-constant condition for static assertion)

PR c++/85032
* constexpr.c (potential_constant_expression_1): Consider conversions
from classes to literal types potentially constant.

* g++.dg/cpp0x/pr51225.C: Adjust error message.
* g++.dg/cpp1z/constexpr-if21.C: New test.

From-SVN: r259318

6 years agore PR lto/85339 (With early LTO debug the early DWARF misses line-info)
Richard Biener [Wed, 11 Apr 2018 13:05:35 +0000 (13:05 +0000)]
re PR lto/85339 (With early LTO debug the early DWARF misses line-info)

2018-04-11  Richard Biener  <rguenther@suse.de>

PR lto/85339
* dwarf2out.c (dwarf2out_finish): Remove DW_AT_stmt_list attribute
from early DWARF output.
(dwarf2out_early_finish): Output line info unconditionally into
early DWARF and add reference to it.

From-SVN: r259317

6 years agore PR target/85281 (Assembler messages: Error: operand size mismatch for `vpbroadcast...
Jakub Jelinek [Wed, 11 Apr 2018 11:37:01 +0000 (13:37 +0200)]
re PR target/85281 (Assembler messages: Error: operand size mismatch for `vpbroadcastb' with -mavx512bw -masm=intel)

PR target/85281
* config/i386/sse.md (iptr): Add V16SFmode and V8DFmode cases.
(<avx512>_vec_dup<mode><mask_name>): Use a single pattern for modes
other than V2DFmode using iptr mode attribute.
(<avx512>_vec_dup<mode><mask_name>): Use iptr mode attribute.

* gcc.target/i386/pr85281.c: New test.

From-SVN: r259316

6 years agofix PR 84659 references in ChangeLog files
Alexander Monakov [Wed, 11 Apr 2018 10:48:42 +0000 (13:48 +0300)]
fix PR 84659 references in ChangeLog files

From-SVN: r259314

6 years agosel-sched: run cleanup_cfg just before loop_optimizer_init (PR 84659)
Alexander Monakov [Wed, 11 Apr 2018 10:40:07 +0000 (13:40 +0300)]
sel-sched: run cleanup_cfg just before loop_optimizer_init (PR 84659)

PR rtl-optimization/85659
* sel-sched-ir.c (sel_init_pipelining): Invoke cleanup_cfg.

testsuite/
* gcc.dg/pr84659.c: New test.

From-SVN: r259313

6 years agoClean up attribute value comparison in lto-symtab.c.
Martin Liska [Wed, 11 Apr 2018 10:33:46 +0000 (12:33 +0200)]
Clean up attribute value comparison in lto-symtab.c.

2018-04-11  Martin Liska  <mliska@suse.cz>

* lto-symtab.c (lto_symtab_merge_p): Use attribute_value_equal
function.

From-SVN: r259312

6 years agore PR rtl-optimization/85302 (ICE in size_of_loc_descr, at dwarf2out.c:1771 on i686...
Jakub Jelinek [Wed, 11 Apr 2018 10:22:36 +0000 (12:22 +0200)]
re PR rtl-optimization/85302 (ICE in size_of_loc_descr, at dwarf2out.c:1771 on i686-linux-gnu)

PR debug/85302
* dwarf2out.c (skip_loc_list_entry): Don't call size_of_locs if
SIZEP is NULL.
(output_loc_list): Pass address of a dummy size variable even in the
locview handling loop.
(index_location_lists): Add comment on why skip_loc_list_entry can't
call size_of_locs.

* g++.dg/debug/dwarf2/pr85302.C: New test.

From-SVN: r259311

6 years ago[ARM] Fix PR85261: ICE with FPSCR setter builtin
Thomas Preud'homme [Wed, 11 Apr 2018 10:07:25 +0000 (10:07 +0000)]
[ARM] Fix PR85261: ICE with FPSCR setter builtin

Instruction pattern for setting the FPSCR expects the input value to be
in a register. However, __builtin_arm_set_fpscr expander does not ensure
that this is the case and as a result GCC ICEs when the builtin is
called with a constant literal.

This commit fixes the builtin to force the input value into a register.
It also remove the unneeded volatile in the existing fpscr test and
fixes the function prototype.

2018-04-11  Thomas Preud'homme  <thomas.preudhomme@arm.com>

    gcc/
    PR target/85261
    * config/arm/arm-builtins.c (arm_expand_builtin): Force input operand
    into register.

    gcc/testsuite/
    PR target/85261
    * config/arm/arm-builtins.c (arm_expand_builtin): Force input operand
    into register.

From-SVN: r259310

6 years agoUpdate libstdc++ manual in preparation for GCC 8 release
Jonathan Wakely [Wed, 11 Apr 2018 00:21:35 +0000 (01:21 +0100)]
Update libstdc++ manual in preparation for GCC 8 release

* doc/xml/manual/abi.xml: Document header locations in recent
releases.
* doc/xml/manual/evolution.xml: Add API changes since GCC 5.
* doc/xml/manual/spine.xml: Update copyright years.
* doc/xml/manual/strings.xml: Adjust tolower example to avoid
undefined behaviour.
* doc/xml/manual/test.xml: Update outdated notes on VERIFY in tests.
* doc/html/*: Regenerate.

From-SVN: r259308

6 years agoDaily bump.
GCC Administrator [Wed, 11 Apr 2018 00:16:14 +0000 (00:16 +0000)]
Daily bump.

From-SVN: r259307

6 years agore PR c++/70808 (Spurious -Wzero-as-null-pointer-constant for nullptr_t)
Paolo Carlini [Tue, 10 Apr 2018 22:34:06 +0000 (22:34 +0000)]
re PR c++/70808 (Spurious -Wzero-as-null-pointer-constant for nullptr_t)

/cp
2018-04-10  Paolo Carlini  <paolo.carlini@oracle.com>

PR c++/70808
* init.c (build_zero_init_1): Handle NULLPTR_TYPE_P being true of
the type like TYPE_PTR_OR_PTRMEM_P.

/testsuite
2018-04-10  Paolo Carlini  <paolo.carlini@oracle.com>

PR c++/70808
* g++.dg/warn/Wzero-as-null-pointer-constant-7.C: New.

From-SVN: r259303

6 years agore PR target/85321 (Missing documentation and option misc for ppc64le)
Aaron Sawdey [Tue, 10 Apr 2018 22:05:41 +0000 (22:05 +0000)]
re PR target/85321 (Missing documentation and option misc for ppc64le)

2018-04-10  Aaron Sawdey  <acsawdey@linux.ibm.com>

PR target/85321
* doc/invoke.texi (RS/6000 and PowerPC Options): Document options
-mblock-compare-inline-limit, -mblock-compare-inline-loop-limit,
and -mstring-compare-inline-limit.

From-SVN: r259302

6 years agoMAINTAINERS: Update my email address.
Aaron Sawdey [Tue, 10 Apr 2018 21:57:12 +0000 (21:57 +0000)]
MAINTAINERS: Update my email address.

2018-04-10  Aaron Sawdey  <acsawdey@linux.ibm.com>

* MAINTAINERS: Update my email address.

From-SVN: r259301

6 years agoforgot the PR marker in the changelog
Segher Boessenkool [Tue, 10 Apr 2018 21:38:31 +0000 (23:38 +0200)]
forgot the PR marker in the changelog

From-SVN: r259300

6 years agors6000: Fix stack clash for big residuals (PR85287)
Segher Boessenkool [Tue, 10 Apr 2018 21:37:34 +0000 (23:37 +0200)]
rs6000: Fix stack clash for big residuals (PR85287)

The stack clash protection code had a logic error in how it decided
whether to put the final update size in a register, or to emit it
directly in an insn.  This fixes it.  It also tidies some surrounding
code.

PR target/85287
* gcc/config/rs6000/rs6000.md (allocate_stack): Put the residual size
for stack clash protection in a register whenever we need it to be in
a register.

From-SVN: r259299

6 years agors6000: Enable -fasynchronous-unwind-tables by default
Segher Boessenkool [Tue, 10 Apr 2018 21:09:30 +0000 (23:09 +0200)]
rs6000: Enable -fasynchronous-unwind-tables by default

To find out where on-entry register values live at any point in a
program, GDB currently tries to parse to parse the executable code.
This does not work very well, for example it gets confused if some
accesses to the stack use the frame pointer (r31) and some use the
stack pointer (r1).  A symptom is that backtraces can be cut short.

This patch enables -fasynchronous-unwind-tables by default for rs6000,
which causes us to emit DWARF unwind tables for all functions, solving
these problems.

This not do anything for sub-targets without DWARF, and only for ELF
sub-targets for now.

It increases executable size, but only modestly, and does not change
memory use, only the disk image.

* common/config/rs6000/rs6000-common.c (rs6000_option_init_struct):
Enable -fasynchronous-unwind-tables by default if OBJECT_FORMAT_ELF.

gcc/testsuite/
* gcc.target/powerpc/dfmode_off.c: Add -fno-asynchronous-unwind-tables.
* gcc.target/powerpc/dimode_off.c: Ditto.
* gcc.target/powerpc/tfmode_off.c: Ditto.
* gcc.target/powerpc/timode_off.c: Ditto.

From-SVN: r259298

6 years agors6000: Improve --help=target (PR85321)
Segher Boessenkool [Tue, 10 Apr 2018 18:54:08 +0000 (20:54 +0200)]
rs6000: Improve --help=target (PR85321)

This updates the help text for some options to mention the allowed
values for -mXX=XX.

PR target/85321
* config/rs6000/rs6000.opt (mtraceback=): Show the allowed values in
the help text.
(mlong-double-): Ditto.
* config/rs6000/sysv4.opt (msdata=): Ditto.
(mtls-size=): Ditto.

From-SVN: r259296

6 years agors6000-c.c (altivec_overloaded_builtins): Remove erroneous entries for "vector int...
Kelvin Nilsen [Tue, 10 Apr 2018 17:59:52 +0000 (17:59 +0000)]
rs6000-c.c (altivec_overloaded_builtins): Remove erroneous entries for "vector int vec_ldl (int...

gcc/ChangeLog:

2018-04-10  Kelvin Nilsen  <kelvin@gcc.gnu.org>

* config/rs6000/rs6000-c.c (altivec_overloaded_builtins): Remove
erroneous entries for
"vector int vec_ldl (int, long int *)", and
"vector unsigned int vec_ldl (int, unsigned long int *)".
Add comments and entries for
"vector bool char vec_ldl (int, bool char *)",
"vector bool short vec_ldl (int, bool short *)",
"vector bool int vec_ldl (int, bool int *)",
"vector bool long long vec_ldl (int, bool long long *)",
"vector pixel vec_ldl (int, pixel *)",
"vector long long vec_ldl (int, long long *)",
"vector unsigned long long vec_ldl (int, unsigned long long *)".
* config/rs6000/rs6000.c (rs6000_init_builtins): Initialize new
type tree bool_long_long_type_node and correct definition of
bool_V2DI_type_node to make reference to this new type tree.
(rs6000_mangle_type): Replace erroneous reference to
bool_long_type_node with bool_long_long_type_node.
* config/rs6000/rs6000.h (enum rs6000_builtin_type_index): Add
comments to emphasize sign distinctions for char and int types and
replace RS6000_BTI_bool_long constant with
RS6000_BTI_bool_long_long constant.  Also add comment to restrict
use of RS6000_BTI_pixel.
(bool_long_type_node): Remove this macro definition.
(bool_long_long_type_node): New macro definition

gcc/testsuite/ChangeLog:

2018-04-10  Kelvin Nilsen  <kelvin@gcc.gnu.org>

* gcc.target/powerpc/vec-ldl-1.c: New test.
* gcc.dg/vmx/ops-long-1.c: Correct test programs to reflect
corrections to ABI implementation.

From-SVN: r259294

6 years agoPR debug/65821 - wrong location for main().
Jason Merrill [Tue, 10 Apr 2018 17:19:09 +0000 (13:19 -0400)]
PR debug/65821 - wrong location for main().

* call.c (clear_location_r, convert_default_arg): Revert.
* tree.c (break_out_target_exprs): Add clear_location parm.
(struct bot_data): New.
(bot_manip): Clear location if requested.
* init.c (get_nsdmi): Pass clear_location.

From-SVN: r259291

6 years ago[PR target/85056] Address -Wmaybe-uninitialized diagnostic
Thomas Schwinge [Tue, 10 Apr 2018 16:55:02 +0000 (18:55 +0200)]
[PR target/85056] Address -Wmaybe-uninitialized diagnostic

gcc/testsuite/
* gcc.target/nvptx/pr85056.c (main): Initialize "sum".

From-SVN: r259288

6 years agocppopts.texi: Use "side effect" instead of side-effect.
Martin Sebor [Tue, 10 Apr 2018 15:49:59 +0000 (09:49 -0600)]
cppopts.texi: Use "side effect" instead of side-effect.

gcc/ChangeLog:

* doc/cppopts.texi: Use "side effect" instead of side-effect.
* doc/extend.texi: Same.
* doc/generic.texi: Same.
* doc/implement-c.texi: Same.
* doc/invoke.texi: Same.
* doc/md.texi: Same.
* doc/rtl.texi: Same.
* doc/tree-ssa.texi: Same.

From-SVN: r259287

6 years agoUpdate links to archived copy of SGI STL docs
Jonathan Wakely [Tue, 10 Apr 2018 15:49:26 +0000 (16:49 +0100)]
Update links to archived copy of SGI STL docs

* doc/xml/faq.xml: Update links to archived copy of SGI STL docs.
* doc/xml/manual/backwards_compatibility.xml: Likewise.
* doc/xml/manual/containers.xml: Likewise.
* doc/xml/manual/debug_mode.xml: Likewise.
* doc/xml/manual/extensions.xml: Likewise.
* doc/xml/manual/policy_data_structures_biblio.xml: Likewise.
* doc/xml/manual/using.xml: Likewise.
* doc/xml/manual/utilities.xml: Likewise.

From-SVN: r259286

6 years agore PR rtl-optimization/85300 (ICE in exact_int_to_float_conversion_p, at simplify...
Jakub Jelinek [Tue, 10 Apr 2018 15:31:57 +0000 (17:31 +0200)]
re PR rtl-optimization/85300 (ICE in exact_int_to_float_conversion_p, at simplify-rtx.c:895)

PR rtl-optimization/85300
* combine.c (subst): Handle subst of CONST_SCALAR_INT_P new_rtx also
into FLOAT and UNSIGNED_FLOAT like ZERO_EXTEND, return a CLOBBER if
simplify_unary_operation fails.

* gcc.dg/pr85300.c: New test.

From-SVN: r259285

6 years agogdbhooks: Add new pretty-printers for: varpool_node, symtab_node, cgraph_edge and...
Martin Liska [Tue, 10 Apr 2018 14:43:09 +0000 (16:43 +0200)]
gdbhooks: Add new pretty-printers for: varpool_node, symtab_node, cgraph_edge and ipa_ref.

2018-04-10  Martin Liska  <mliska@suse.cz>

* gdbhooks.py: Add pretty-printers for varpool_node, symtab_node,
cgraph_edge and ipa_ref.

From-SVN: r259283

6 years agoShow pertinent parameter (PR c++/85110)
David Malcolm [Tue, 10 Apr 2018 14:37:09 +0000 (14:37 +0000)]
Show pertinent parameter (PR c++/85110)

gcc/cp/ChangeLog:
PR c++/85110
* call.c (get_fndecl_argument_location): Make non-static.
* cp-tree.h (get_fndecl_argument_location): New decl.
* typeck.c (convert_for_assignment): When complaining due to
conversions for an argument, show the location of the parameter
within the decl.

gcc/testsuite/ChangeLog:
PR c++/85110
* g++.dg/cpp1z/direct-enum-init1.C: Update for the cases
where we now show the pertinent parameter.
* g++.dg/diagnostic/aka2.C: Likewise.
* g++.dg/diagnostic/param-type-mismatch-2.C: Likewise.

From-SVN: r259282

6 years agoPR libstdc++/85222 allow catching iostream errors as gcc4-compatible ios::failure
Jonathan Wakely [Tue, 10 Apr 2018 14:36:09 +0000 (15:36 +0100)]
PR libstdc++/85222 allow catching iostream errors as gcc4-compatible ios::failure

Define a new exception type derived from std::ios::failure[abi:cxx11]
which also aggregates an object of the gcc4-compatible ios::failure
type. Make __throw_ios_failure throw this new type for iostream errors
that raise exceptions. Provide custom type info for the new type so that
it can be caught by handlers for the gcc4-compatible ios::failure type
as well as handlers for ios::failure[abi:cxx11] and its bases.

PR libstdc++/85222
* src/c++11/Makefile.am [ENABLE_DUAL_ABI]: Add special rules for
cxx11-ios_failure.cc to rewrite type info for __ios_failure.
* src/c++11/Makefile.in: Regenerate.
* src/c++11/cxx11-ios_failure.cc (__ios_failure, __iosfail_type_info):
New types.
[_GLIBCXX_USE_DUAL_ABI] (__throw_ios_failure): Define here.
* src/c++11/ios.cc (__throw_ios_failure): Remove definition.
* src/c++98/ios_failure.cc (__construct_ios_failure)
(__destroy_ios_failure, is_ios_failure_handler): New functions.
[!_GLIBCXX_USE_DUAL_ABI] (__throw_ios_failure): Define here.
* testsuite/27_io/ios_base/failure/dual_abi.cc: New.
* testsuite/27_io/basic_ios/copyfmt/char/1.cc: Revert changes to
handler types, to always catch std::ios_base::failure.
* testsuite/27_io/basic_ios/exceptions/char/1.cc: Likewise.
* testsuite/27_io/basic_istream/extractors_arithmetic/char/
exceptions_failbit.cc: Likewise.
* testsuite/27_io/basic_istream/extractors_arithmetic/wchar_t/
exceptions_failbit.cc: Likewise.
* testsuite/27_io/basic_istream/extractors_other/char/
exceptions_null.cc: Likewise.
* testsuite/27_io/basic_istream/extractors_other/wchar_t/
exceptions_null.cc: Likewise.
* testsuite/27_io/basic_istream/sentry/char/12297.cc: Likewise.
* testsuite/27_io/basic_istream/sentry/wchar_t/12297.cc: Likewise.
* testsuite/27_io/basic_ostream/inserters_other/char/
exceptions_null.cc: Likewise.
* testsuite/27_io/basic_ostream/inserters_other/wchar_t/
exceptions_null.cc: Likewise.
* testsuite/27_io/ios_base/storage/2.cc: Likewise.

From-SVN: r259281

6 years agoPR c++/85312 - P0962 cleanup
Jakub Jelinek [Tue, 10 Apr 2018 14:28:54 +0000 (16:28 +0200)]
PR c++/85312 - P0962 cleanup

PR c++/85312 - P0962 cleanup
* parser.c (cp_parser_perform_range_for_lookup): Remove unreachable
diagnostics.

From-SVN: r259279

6 years agoPR debug/65821 - wrong location for main().
Jason Merrill [Tue, 10 Apr 2018 14:24:00 +0000 (10:24 -0400)]
PR debug/65821 - wrong location for main().

* call.c (clear_location_r): New.
(convert_default_arg): Use it.
* tree.c (bot_manip): Remove builtin_LINE/FILE handling.

From-SVN: r259278

6 years agoPR c++/85285 - ICE with flexible array after substitution.
Jason Merrill [Tue, 10 Apr 2018 14:23:54 +0000 (10:23 -0400)]
PR c++/85285 - ICE with flexible array after substitution.

* pt.c (instantiate_class_template_1): Check for flexible array in
union.

From-SVN: r259277

6 years ago* parser.c (cp_parser_check_template_parameters): Improve comment.
Jason Merrill [Tue, 10 Apr 2018 14:23:49 +0000 (10:23 -0400)]
* parser.c (cp_parser_check_template_parameters): Improve comment.

From-SVN: r259276

6 years agore PR fortran/85313 (gcc/fortran/openmp.c: 2 * confused logic ?)
Jakub Jelinek [Tue, 10 Apr 2018 14:04:37 +0000 (16:04 +0200)]
re PR fortran/85313 (gcc/fortran/openmp.c: 2 * confused logic ?)

PR fortran/85313
* openmp.c (resolve_omp_do): Remove bogus if (j < i) break;.
(resolve_oacc_nested_loops): Likewise.  Formatting fix.

* gfortran.dg/gomp/pr85313.f90: New test.

From-SVN: r259275

6 years agoFix obvious error in handling of error attribute (PR lto/85248).
Martin Liska [Tue, 10 Apr 2018 13:52:23 +0000 (15:52 +0200)]
Fix obvious error in handling of error attribute (PR lto/85248).

2018-04-10  Martin Liska  <mliska@suse.cz>

PR lto/85248
* lto-symtab.c (lto_symtab_merge_p): Do not check for
TREE_VALUES of error attributes.

From-SVN: r259274

6 years agore PR c++/24314 (Extra "template<>" in partial specialization is compiled successfuly.)
Paolo Carlini [Tue, 10 Apr 2018 13:40:35 +0000 (13:40 +0000)]
re PR c++/24314 (Extra "template<>" in partial specialization is compiled successfuly.)

2018-04-10  Paolo Carlini  <paolo.carlini@oracle.com>

PR c++/24314
* g++.dg/parse/template29.C: New.

From-SVN: r259273

6 years agore PR testsuite/85190 (gcc.dg/vect/pr81196.c FAILs)
Bin Cheng [Tue, 10 Apr 2018 13:11:40 +0000 (13:11 +0000)]
re PR testsuite/85190 (gcc.dg/vect/pr81196.c FAILs)

gcc/testsuite
PR testsuite/85190
* gcc.dg/vect/pr81196.c: Adjust pointer for aligned access.

From-SVN: r259272

6 years agore PR target/85177 (wrong code with -O -fno-tree-ccp -fno-tree-sra -mavx512f)
Jakub Jelinek [Tue, 10 Apr 2018 12:37:36 +0000 (14:37 +0200)]
re PR target/85177 (wrong code with -O -fno-tree-ccp -fno-tree-sra -mavx512f)

PR target/85177
PR target/85255
* config/i386/sse.md
(<extract_type>_vinsert<shuffletype><extract_suf>_mask): Fix
computation of the VEC_MERGE selector from mask.
(<extract_type>_vinsert<shuffletype><extract_suf>_1<mask_name>):
Fix decoding of the VEC_MERGE selector into mask.

* gcc.target/i386/avx512f-pr85177.c: New test.
* gcc.target/i386/avx512f-pr85255.c: New test.

From-SVN: r259269

6 years agoAdd missing cases to vect_get_smallest_scalar_type (PR 85286)
Richard Sandiford [Tue, 10 Apr 2018 10:28:33 +0000 (10:28 +0000)]
Add missing cases to vect_get_smallest_scalar_type (PR 85286)

In this PR we used WIDEN_SUM_EXPR to vectorise:

  short i, y;
  int sum;
  [...]
  for (i = x; i > 0; i--)
    sum += y;

with 4 ints and 8 shorts per vector.  The problem was that we set
the VF based only on the ints, then calculated the number of vector
copies based on the shorts, giving 4/8.  Previously that led to
ncopies==0, but after r249897 we pick it up as an ICE.

In this particular case we could vectorise the reduction by setting
ncopies based on the output type rather than the input type, but it
doesn't seem worth adding a special "optimisation" for such a
pathological case.  I think it's really an instance of the more general
problem that we can't vectorise using combinations of (say) 64-bit and
128-bit vectors on targets that support both.

2018-04-10  Richard Sandiford  <richard.sandiford@linaro.org>

gcc/
PR tree-optimization/85286
* tree-vect-data-refs.c (vect_get_smallest_scalar_type):

gcc/testsuite/
PR tree-optimization/85286
* gcc.dg/vect/pr85286.c: New test.

From-SVN: r259268