]> git.ipfire.org Git - thirdparty/gcc.git/log
thirdparty/gcc.git
7 years ago2018-04-19 Richard Biener <rguenther@suse.de>
rguenth [Thu, 19 Apr 2018 12:41:42 +0000 (12:41 +0000)] 
2018-04-19  Richard Biener  <rguenther@suse.de>

PR tree-optimization/84737
* tree-vect-data-refs.c (vect_copy_ref_info): New function
copying restrict info.
(vect_setup_realignment): Use it.
* tree-vectorizer.h (vect_copy_ref_info): Declare.
* tree-vect-stmts.c (vectorizable_store): Copy ref info from
the first DR to all generated stores.
(vectorizable_load): Likewise for loads.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259493 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago[testsuite] Fix tests for pr84805 and pr85405.
clyon [Thu, 19 Apr 2018 08:59:36 +0000 (08:59 +0000)] 
[testsuite] Fix tests for pr84805 and pr85405.

2018-04-19  Christophe Lyon  <christophe.lyon@linaro.org>

* g++.dg/lto/pr85405_0.C: Require shared and fpic effective
targets.
* g++.dg/lto/pr85405b_0.C: Likewise.
* g++.dg/lto/pr84805_0.C: Likewise.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259492 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoPR85463 '[nvptx] "exit" in offloaded region doesn't terminate process'
tschwinge [Thu, 19 Apr 2018 08:53:38 +0000 (08:53 +0000)] 
PR85463 '[nvptx] "exit" in offloaded region doesn't terminate process'

libgomp/
PR libfortran/85166
* testsuite/libgomp.oacc-fortran/abort-1.f90: Switch back to "call
abort".
* testsuite/libgomp.oacc-fortran/abort-2.f90: Likewise.

libgfortran/
PR libfortran/85166
PR libgomp/85463
* runtime/minimal.c (stop_numeric): Reimplement.
(stop_string, error_stop_string, error_stop_numeric): New
functions.
libgomp/
PR libgomp/85463
* testsuite/libgomp.oacc-fortran/error_stop-1.f: New file.
* testsuite/libgomp.oacc-fortran/error_stop-2.f: Likewise.
* testsuite/libgomp.oacc-fortran/error_stop-3.f: Likewise.
* testsuite/libgomp.oacc-fortran/stop-1.f: Likewise.
* testsuite/libgomp.oacc-fortran/stop-2.f: Likewise.
* testsuite/libgomp.oacc-fortran/stop-3.f: Likewise.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259491 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoDo not bail out for multiple PREVAILING_DEF_IRONLY for common symbols.
marxin [Thu, 19 Apr 2018 08:42:52 +0000 (08:42 +0000)] 
Do not bail out for multiple PREVAILING_DEF_IRONLY for common symbols.

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

* lto-symtab.c (lto_symtab_resolve_symbols): Do not bail out
for multiple PREVAILING_DEF_IRONLY for common symbols.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259490 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR tree-optimization/85446
jakub [Thu, 19 Apr 2018 07:46:54 +0000 (07:46 +0000)] 
PR tree-optimization/85446
* match.pd ((intptr_t) x eq/ne CST to x eq/ne (typeof x) cst): Require
the integral and pointer types to have the same precision.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259488 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago * config/cet.m4 (GCC_CET_FLAGS): Default to --disable-cet, replace
jakub [Thu, 19 Apr 2018 07:45:51 +0000 (07:45 +0000)] 
* config/cet.m4 (GCC_CET_FLAGS): Default to --disable-cet, replace
--enable-cet=default with --enable-cet=auto.

* doc/install.texi: Document --disable-cet being the default and
--enable-cet=auto.

* configure: Regenerated.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259487 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoPR c++/80290
aoliva [Thu, 19 Apr 2018 06:39:06 +0000 (06:39 +0000)] 
PR c++/80290
* cp-tree.h (tinst_level::free): Fix whitespace.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259486 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoDaily bump.
gccadmin [Thu, 19 Apr 2018 00:16:23 +0000 (00:16 +0000)] 
Daily bump.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259483 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoFix coding style and typos.
marxin [Wed, 18 Apr 2018 20:09:33 +0000 (20:09 +0000)] 
Fix coding style and typos.

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

* ipa-devirt.c (odr_subtypes_equivalent_p): Fix GNU coding
style.
2018-04-18  Martin Liska  <mliska@suse.cz>

* lto.c (lto_read_decls): Fix GNU coding style and typos.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259480 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoMake Wodr warnings stable.
marxin [Wed, 18 Apr 2018 20:08:44 +0000 (20:08 +0000)] 
Make Wodr warnings stable.

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

PR ipa/83983
PR ipa/85391
* lto.c (cmp_type_location): New function.
(lto_read_decls): First collect all types, then
sort them according by location before register_odr_type
is called.
2018-04-18  Martin Liska  <mliska@suse.cz>

PR ipa/83983
PR ipa/85391
* g++.dg/lto/pr83121_1.C (struct Environment): Adjust expected
output.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259479 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoRevert r258133.
marxin [Wed, 18 Apr 2018 20:06:07 +0000 (20:06 +0000)] 
Revert r258133.

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

Revert
2018-03-02  Eric Botcazou  <ebotcazou@adacore.com>

PR ipa/83983
* ipa-devirt.c (odr_subtypes_equivalent_p): Get the ODR type of both
arguments if they are comparable.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259478 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoRevert r25841.
marxin [Wed, 18 Apr 2018 20:05:10 +0000 (20:05 +0000)] 
Revert r25841.

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

Revert
2018-03-13  Eric Botcazou  <ebotcazou@adacore.com>

PR lto/84805
* ipa-devirt.c (odr_subtypes_equivalent_p): Do not get the ODR type of
incomplete types.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259477 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoi386: Insert ENDBR after __morestack call
hjl [Wed, 18 Apr 2018 19:14:28 +0000 (19:14 +0000)] 
i386: Insert ENDBR after __morestack call

Since __morestack will jump back to its callee via indirect call, we
need to insert ENDBR after calling __morestack.

gcc/

PR target/85388
* config/i386/i386.c (ix86_expand_split_stack_prologue): Insert
ENDBR after calling __morestack.

gcc/testsuite/

PR target/85388
* gcc.dg/pr85388-1.c: New test.
* gcc.dg/pr85388-2.c: Likewise.
* gcc.dg/pr85388-3.c: Likewise.
* gcc.dg/pr85388-4.c: Likewise.
* gcc.dg/pr85388-5.c: Likewise.
* gcc.dg/pr85388-6.c: Likewise.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259475 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoPR libstdc++/85442 fix duplicate debuginfo for cxx11-ios_failure.cc
redi [Wed, 18 Apr 2018 12:14:58 +0000 (12:14 +0000)] 
PR libstdc++/85442 fix duplicate debuginfo for cxx11-ios_failure.cc

2018-04-18  Jonathan Wakely  <jwakely@redhat.com>
    Jakub Jelinek  <jakub@redhat.com>

PR libstdc++/85442
* src/c++11/Makefile.am: Don't generate debuginfo again for
cxx11-ios_failure-lt.s and cxx11-ios_failure.s files.
* src/c++11/Makefile.in: Regenerate.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259467 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR lto/85391
hubicka [Wed, 18 Apr 2018 11:29:26 +0000 (11:29 +0000)] 
PR lto/85391
* lto.c (lto_read_decls): Do not test TYPE_CANONICAL before registering odr
types.
* g++.dg/lto/pr83121_0.C: Update template.
* g++.dg/lto/pr83121_1.C: Update template.
* g++.dg/lto/pr84805_0.C: Update template.
* g++.dg/lto/pr84805_1.C: Update template.
* g++.dg/lto/pr84805_2.C: Update template.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259464 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoPR libstdc++/84442 if _Exit isn't declared then use _exit instead
redi [Wed, 18 Apr 2018 11:15:38 +0000 (11:15 +0000)] 
PR libstdc++/84442 if _Exit isn't declared then use _exit instead

PR libstdc++/84442
* testsuite/30_threads/thread/cons/terminate.cc
[!_GLIBCXX_USE_C99_STDLIB] : Use _exit or std::exit instead of _Exit.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259463 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR jit/85384
jakub [Wed, 18 Apr 2018 09:46:58 +0000 (09:46 +0000)] 
PR jit/85384
* acx.m4 (GCC_BASE_VER): Remove \$\$ from sed expression.

* configure.ac (gcc-driver-name.h): Honor --with-gcc-major-version
by using gcc_base_ver to generate a gcc_driver_version, and use
it when generating GCC_DRIVER_NAME.
* configure: Regenerate.

* configure: Regenerate.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259462 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR target/81084
jakub [Wed, 18 Apr 2018 08:47:26 +0000 (08:47 +0000)] 
PR target/81084
* config.gcc: Obsolete powerpc*-*-*spe*.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259461 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago/cp
paolo [Wed, 18 Apr 2018 08:03:45 +0000 (08:03 +0000)] 
/cp
2018-04-18  Paolo Carlini  <paolo.carlini@oracle.com>

PR c++/84630
* pt.c (tsubst_lambda_expr): Check begin_lambda_type return value
for error_mark_node.

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

PR c++/84630
* g++.dg/cpp0x/pr84630.C: New.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259460 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR sanitizer/85389
jakub [Wed, 18 Apr 2018 07:02:40 +0000 (07:02 +0000)] 
PR sanitizer/85389
* asan/asan_allocator.h (kAllocatorSpace): For __powerpc64__ change
from 0xa0000000000ULL to ~(uptr)0.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259459 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR c++/84463
jakub [Wed, 18 Apr 2018 06:57:45 +0000 (06:57 +0000)] 
PR c++/84463
* typeck.c (cp_build_addr_expr_1): Move handling of offsetof-like
tricks from here to ...
* cp-gimplify.c (cp_fold) <case ADDR_EXPR>: ... here.  Only use it
if INDIRECT_REF's operand is INTEGER_CST cast to pointer type.

* g++.dg/cpp0x/constexpr-nullptr-1.C: Add -O1 to dg-options.
* g++.dg/cpp0x/constexpr-nullptr-2.C: Expect different diagnostics
in two cases.  Uncomment two other tests and add expected dg-error for
them.
* g++.dg/init/struct2.C: Cast to int rather than long to avoid
-Wnarrowing diagnostics on some targets for c++11.
* g++.dg/parse/array-size2.C: Remove xfail.
* g++.dg/cpp0x/constexpr-84463.C: New test.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259458 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago[PR c++/80290] recycle tinst garbage sooner
aoliva [Wed, 18 Apr 2018 05:17:26 +0000 (05:17 +0000)] 
[PR c++/80290] recycle tinst garbage sooner

tinst_level objects are created during template instantiation, and
they're most often quite short-lived, but since there's no intervening
garbage collection, they accumulate throughout the pass while most by
far could be recycled after a short while.  The original testcase in
PR80290, for example, creates almost 55 million tinst_level objects,
all but 10 thousand of them without intervening GC, but we don't need
more than 284 of them live at a time.

Furthermore, in many cases, TREE_LIST objects are created to stand for
the decl in tinst_level.  In most cases, those can be recycled as soon
as the tinst_level object is recycled; in some relatively common
cases, they are modified and reused in up to 3 tinst_level objects.
In the same testcase, TREE_LISTs are used in all but 3 thousand of the
tinst_level objects, and we don't need more than 89 tinst_level
objects with TREE_LISTs live at a time.  Furthermore, all but 2
thousand of those are created without intervening GC.

This patch arranges for tinst_level objects to be refcounted (I've
seen as many as 20 live references to a single tinst_level object in
my testing), and for pending_template, tinst_level and TREE_LIST
objects that can be recycled to be added to freelists; that's much
faster than ggc_free()ing them and reallocating them shortly
thereafter.  In fact, the introduction of such freelists is what makes
this entire patch lighter-weight, when it comes to memory use, and
faster.  With refcounting alone, the total memory footprint was still
about the same, and we spent more time.

In order to further reduce memory use, I've arranged for us to create
TREE_LISTs lazily, only at points that really need them (when printing
error messages).  This grows tinst_level by an additional pointer, but
since a TREE_LIST holds a lot more than an extra pointer, and
tinst_levels with TREE_LISTs used to be allocated tens of thousands of
times more often than plain decl ones, we still save memory overall.

I was still not quite happy about growing memory use in cases that
used template classes but not template overload resolution, so I
changed the type of the errors field to unsigned short, from int.
With that change, in_system_header_p and refcount move into the same
word or half-word that used to hold errors, releasing a full word,
bringing tinst_level back to its original size, now without any
padding.

The errors field is only used to test whether we've had any errors
since the expansion of some template, to skip the expansion of further
templates.  If we get 2^16 errors or more, it is probably reasonable
to refrain from expanding further templates, even if we would expand
them before this change.

With these changes, compile time for the original testcase at -O0,
with default checking enabled, is cut down by some 3.7%, total GCable
memory allocation is cut down by almost 20%, and total memory use (as
reported by GNU time as maxresident) is cut down by slightly over 15%.

for  gcc/cp/ChangeLog

PR c++/80290
* cp-tree.h (struct tinst_level): Split decl into tldcl and
targs.  Add private split_list_p, tree_list_p, and not_list_p
inline const predicates; to_list private member function
declaration; free public member function declaration; list_p,
get_node and maybe_get_node accessors, and refcount data
member.  Narrow errors to unsigned short.
* error.c (print_instantiation_full_context): Use new
accessors.
(print_instantiation_partial_context_line): Likewise.  Drop
const from tinst_level-typed parameter.
* mangle.c (mangle_decl_string): Likewise.
* pt.c (freelist): New template class.
(tree_list_freelist_head): New var.
(tree_list_freelist): New fn, along with specializations.
(tinst_level_freelist_head): New var.
(pending_template_freelist_head): Likewise.
(tinst_level_freelist, pending_template_freelist): New fns.
(tinst_level::to_list, tinst_level::free): Define.
(inc_refcount_use, dec_refcount_use): New fns for tinst_level.
(set_refcount_ptr): New template fn.
(add_pending_template): Adjust for refcounting, freelists and
new accessors.
(neglectable_inst_p): Take a NULL d as a non-DECL.
(limit_bad_template_recursion): Use new accessors.
(push_tinst_level): New overload to create the list.
(push_tinst_level_loc): Make it static, split decl into two
args, adjust tests and initialization to cope with split
lists, use freelist, adjust for refcounting.
(push_tinst_level_loc): New wrapper with the old interface.
(pop_tinst_level): Adjust for refcounting.
(record_last_problematic_instantiation): Likewise.
(reopen_tinst_level): Likewise.  Use new accessors.
(instantiate_alias_template): Adjust for split list.
(fn_type_unification): Likewise.
(get_partial_spec_bindings): Likewise.
(instantiate_pending_templates): Use new accessors.  Adjust
for refcount.  Release pending_template to freelist.
(instantiating_current_function_p): Use new accessors.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259457 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago[gcc/testsuite]
wschmidt [Wed, 18 Apr 2018 01:56:59 +0000 (01:56 +0000)] 
[gcc/testsuite]

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

* gcc.target/powerpc/undef-bool-2.c: Add -mvsx.
* gcc.target/g++.dg/ext/undef-bool-1.C: Likewise.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259456 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoDaily bump.
gccadmin [Wed, 18 Apr 2018 00:16:22 +0000 (00:16 +0000)] 
Daily bump.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259455 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago os/signal: disable loading of history during test
ian [Tue, 17 Apr 2018 23:55:17 +0000 (23:55 +0000)] 
os/signal: disable loading of history during test

    Bring in https://golang.org/cl/98616 from gc tip.

    Original CL description:

        This change modifies Go to disable loading of users' shell history for
        TestTerminalSignal tests. TestTerminalSignal, as part of its workload,
        will execute a new interactive bash shell. Bash will attempt to load the
        user's history from the file pointed to by the HISTFILE environment
        variable. For users with large histories that may take up to several
        seconds, pushing the whole test past the 5 second timeout and causing
        it to fail.

    Reviewed-on: https://go-review.googlesource.com/107624

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259452 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR debug/84637
jakub [Tue, 17 Apr 2018 22:18:47 +0000 (22:18 +0000)] 
PR debug/84637
* dbxout.c (dbxout_int): Perform negation in unsigned int type.
(stabstr_D): Change type of unum from unsigned int to
unsigned HOST_WIDE_INT.  Perform negation in unsigned HOST_WIDE_INT
type.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259451 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoRISC-V: Fix 32-bit stack pointer alignment problem.
wilson [Tue, 17 Apr 2018 21:41:07 +0000 (21:41 +0000)] 
RISC-V: Fix 32-bit stack pointer alignment problem.

gcc/
PR 84856
* config/riscv/riscv.c (riscv_compute_frame_info): Add calls to
RISCV_STACK_ALIGN when using outgoing_args_size and pretend_args_size.
Set arg_pointer_offset after using pretend_args_size.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259449 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR rtl-optimization/85431
jakub [Tue, 17 Apr 2018 21:38:45 +0000 (21:38 +0000)] 
PR rtl-optimization/85431
* dse.c (record_store): Ignore zero width stores.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259448 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR testsuite/85326
jakub [Tue, 17 Apr 2018 20:43:49 +0000 (20:43 +0000)] 
PR testsuite/85326
* g++.dg/other/pr81422.C: Require effective target tls and c++11.
* g++.dg/other/pr60675.C: Likewise.  Remove -std=c++11 from dg-options.
* g++.dg/other/sve_tls_2.C: Require effective target tls.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259447 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR sanitizer/85230
jakub [Tue, 17 Apr 2018 20:22:50 +0000 (20:22 +0000)] 
PR sanitizer/85230
* asan.c (handle_builtin_stack_restore): Adjust comment.  Emit
__asan_allocas_unpoison call and last_alloca_addr = new_sp before
__builtin_stack_restore rather than after it.
* builtins.c (expand_asan_emit_allocas_unpoison): Pass
arg1 + (virtual_dynamic_stack_rtx - stack_pointer_rtx) as second
argument instead of virtual_dynamic_stack_rtx.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259446 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago gccgo: suppress "ar rcD" and "-zdefs" on AIX
ian [Tue, 17 Apr 2018 20:10:49 +0000 (20:10 +0000)] 
gccgo: suppress "ar rcD" and "-zdefs" on AIX

    Reviewed-on: https://go-review.googlesource.com/100955

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259445 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoUpdate gcc .po files.
jsm28 [Tue, 17 Apr 2018 19:25:30 +0000 (19:25 +0000)] 
Update gcc .po files.

* be.po, da.po, de.po, el.po, es.po, fi.po, fr.po, hr.po, id.po,
ja.po, nl.po, ru.po, sr.po, sv.po, tr.po, uk.po, vi.po, zh_CN.po,
zh_TW.po: Update.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259443 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agogcc/ChangeLog:
kelvin [Tue, 17 Apr 2018 18:58:08 +0000 (18:58 +0000)] 
gcc/ChangeLog:

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

* config/rs6000/rs6000-protos.h (rs6000_builtin_is_supported_p):
New prototype.
* config/rs6000/rs6000-c.c (altivec_resolve_overloaded_builtin):
Add note to error message to explain internal mapping of overloaded
built-in function name to non-overloaded built-in function name.
* config/rs6000/rs6000.c (rs6000_builtin_is_supported_p): New
function.

gcc/testsuite/ChangeLog:

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

* gcc.target/powerpc/bfp/scalar-extract-sig-5.c: Simplify to
prevent cascading of errors and change expected error message.
* gcc.target/powerpc/bfp/scalar-test-neg-4.c: Restrict this test
to 64-bit targets.
* gcc.target/powerpc/bfp/scalar-test-data-class-8.c: Likewise.
* gcc.target/powerpc/bfp/scalar-test-data-class-9.c: Likewise.
* gcc.target/powerpc/bfp/scalar-test-data-class-10.c: Likewise.
* gcc.target/powerpc/bfp/scalar-insert-exp-11.c: Change expected
error message.
* gcc.target/powerpc/bfp/scalar-extract-exp-5.c: Likewise.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259442 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago2018-04-17 Michael Meissner <meissner@linux.vnet.ibm.com>
meissner [Tue, 17 Apr 2018 18:22:08 +0000 (18:22 +0000)] 
2018-04-17  Michael Meissner  <meissner@linux.vnet.ibm.com>

PR target/85424
* config/rs6000/rs6000.md (pack<mode>): Do not try handle a pack
where the inputs overlap with the output.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259441 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago * backtrace.c: Revert last two changes. Don't call mmap
ian [Tue, 17 Apr 2018 17:58:05 +0000 (17:58 +0000)] 
* backtrace.c: Revert last two changes.  Don't call mmap
directly.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259440 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago * backtrace.c: Include backtrace-supported.h before checking
ian [Tue, 17 Apr 2018 17:29:27 +0000 (17:29 +0000)] 
* backtrace.c: Include backtrace-supported.h before checking
BACKTRACE_USES_MALLOC.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259439 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago * config/i386/sse.md (vec_extract_lo_<mode><mask_name>): Add
jakub [Tue, 17 Apr 2018 17:18:20 +0000 (17:18 +0000)] 
* config/i386/sse.md (vec_extract_lo_<mode><mask_name>): Add
(=v, v) alternative and explicit "memory" attribute.
(vec_extract_lo_<mode><mask_name>): Likewise.  Also add
"type", "prefix", "prefix_extra", "length_immediate" and "mode"
attributes.
(vec_extract_lo_<mode><mask_name>): Add (=v, v) alternative and use
"sselog1" type instead of "sselog".
(vec_extract_hi_<mode><mask_name>): Use "sselog1" type instead of
"sselog".  Remove explicit "memory" attribute.
(vec_extract_lo_v32hi): Add (=v, v) alternative and explicit "memory",
"type", "prefix", "prefix_extra", "length_immediate" and "mode"
attributes.
(vec_extract_hi_v32hi): Merge all alternatives into one, use
"sselog1" type instead of "sselog".  Remove explicit "memory"
attribute.
(vec_extract_hi_v16hi): Merge each pair of alternatives into one,
use "sselog1" type instead of "sselog".  Remove explicit "memory"
attribute.
(vec_extract_lo_v64qi): Add (=v, v) alternative and explicit "memory",
"type", "prefix", "prefix_extra", "length_immediate" and "mode"
attributes.
(vec_extract_hi_v64qi): Merge all alternatives into one, use
"sselog1" type instead of "sselog".  Remove explicit "memory"
attribute.
(vec_extract_hi_v32qi): Merge each pair of alternatives into one,
use "sselog1" type instead of "sselog".  Remove explicit "memory"
attribute.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259438 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoPR testsuite/85326
ktkachov [Tue, 17 Apr 2018 17:06:36 +0000 (17:06 +0000)] 
PR testsuite/85326

Commit missing hunk from r259435.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259437 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR target/85430
jakub [Tue, 17 Apr 2018 17:01:31 +0000 (17:01 +0000)] 
PR target/85430
* config/i386/i386.md (*ashlqi3_1_slp): Use alu1 type instead of alu.

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

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259436 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago[AArch64/arm] PR testsuite/85326 Avoid C++ tests when C++ compiler not present
ktkachov [Tue, 17 Apr 2018 16:34:56 +0000 (16:34 +0000)] 
[AArch64/arm] PR testsuite/85326 Avoid C++ tests when C++ compiler not present

PR testsuite/85326
* gcc.target/arm/pr54300.C: Move to...
* g++.dg/other/pr54300.C: ... Here.  Add target directives.
* gcc.target/arm/pr55073.C: Move to...
* g++.dg/other/pr55073.C: ... Here.  Add target directives.
* gcc.target/arm/pr56184.C: Move to...
* g++.dg/other/pr56184.C: ... Here.  Add target directives.
* gcc.target/arm/pr59985.C: Move to...
* g++.dg/other/pr59985.C: ... Here.  Add target directives.
* gcc.target/aarch64/pr60675.C: Move to...
* g++.dg/other/pr60675.C: ... Here.  Add target directives.
* gcc.target/aarch64/pr81422.C: Move to...
* g++.dg/other/pr81422.C: ... Here.  Add target directives.
* gcc.target/aarch64/sve/const_pred_1.C: Move to...
* g++.dg/other/sve_const_pred_1.C: ... Here.  Add target directives.
* gcc.target/aarch64/sve/const_pred_2.C: Move to...
* g++.dg/other/sve_const_pred_2.C: ... Here.  Add target directives.
* gcc.target/aarch64/sve/const_pred_3.C: Move to...
* g++.dg/other/sve_const_pred_3.C: ... Here.  Add target directives.
* gcc.target/aarch64/sve/const_pred_4.C: Move to...
* g++.dg/other/sve_const_pred_4.C: ... Here.  Add target directives.
* gcc.target/aarch64/sve/tls_2.C: Move to...
* g++.dg/other/sve_tls_2.C: ... Here.  Add target directives.
* gcc.target/aarch64/pr81414.C: Rename to...
* gcc.target/aarch64/pr81414.c: ... This.
* gcc.target/aarch64/simd/pr67896.C: Rename to...
* gcc.target/aarch64/simd/pr67896.c: ... This.  Update error expected
messages.
* gcc.target/aarch64/sve/vcond_1.C: Rename to...
* gcc.target/aarch64/sve/vcond_1.c: ... This.  Avoid use of stdint.h.
* gcc.target/aarch64/sve/vcond_1_run.C: Rename to...
* gcc.target/aarch64/sve/vcond_1_run.c: ... This.  Update include
file name.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259435 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago * backtrace.c (backtrace_full): When testing whether we can
ian [Tue, 17 Apr 2018 13:59:38 +0000 (13:59 +0000)] 
* backtrace.c (backtrace_full): When testing whether we can
allocate memory, call mmap directly, and munmap the memory.

Fixes https://github.com/ianlancetaylor/libbacktrace/issues/13 .

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259434 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR middle-end/85414
jakub [Tue, 17 Apr 2018 09:16:48 +0000 (09:16 +0000)] 
PR middle-end/85414
* rtlhooks.c (gen_lowpart_if_possible): Don't call gen_lowpart_SUBREG
on a SUBREG.

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

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259433 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoCall expand_all_artificial_thunks in ipa-cp if necessary
jamborm [Tue, 17 Apr 2018 08:48:41 +0000 (08:48 +0000)] 
Call expand_all_artificial_thunks in ipa-cp if necessary

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

PR ipa/85421
* ipa-cp.c (create_specialized_node): Call
expand_all_artificial_thunks if necessary.

testsuite/
* g++.dg/ipa/pr85421.C: New test.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259432 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoFix coding style and add a new test-case (PR lto/85405).
marxin [Tue, 17 Apr 2018 08:28:21 +0000 (08:28 +0000)] 
Fix coding style and add a new test-case (PR lto/85405).

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

PR lto/85405
* ipa-devirt.c (odr_types_equivalent_p): Remove trailing
in message, remote space in between '_G' and '('.
2018-04-17  Martin Liska  <mliska@suse.cz>

PR lto/85405
* g++.dg/lto/pr85405b_0.C: New test.
* g++.dg/lto/pr85405b_1.C: New test.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259431 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR target/85281
jakub [Tue, 17 Apr 2018 07:08:06 +0000 (07:08 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259430 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoSupport bitfields in Wodr machinery (PR lto/85405).
marxin [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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259429 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoMake redirection only for target_clones: V3 (PR ipa/85329).
marxin [Tue, 17 Apr 2018 05:40:39 +0000 (05:40 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259428 138bc75d-0d04-0410-961f-82ee72b054a4

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

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259426 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago[PR c++/85039] no type definitions in builtin offsetof
aoliva [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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259423 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago[gcc/testsuite]
wschmidt [Mon, 16 Apr 2018 18:18:42 +0000 (18:18 +0000)] 
[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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259407 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago[openacc] Fix ICE when compiling tile loop containing infinite loop
vries [Mon, 16 Apr 2018 18:01:09 +0000 (18:01 +0000)] 
[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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259406 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago2018-04-16 Aaron Sawdey <acsawdey@linux.ibm.com>
acsawdey [Mon, 16 Apr 2018 14:50:06 +0000 (14:50 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259403 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoi386: Check error_mark_node in multiversioning
hjl [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" } */

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259400 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoFixed g++.dg/ext/mv16.C with -march=native.
jkoval [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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259399 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR target/84945
jakub [Mon, 16 Apr 2018 11:22:40 +0000 (11:22 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259398 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago2018-04-16 Paolo Carlini <paolo.carlini@oracle.com>
paolo [Mon, 16 Apr 2018 08:31:23 +0000 (08:31 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259397 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoMake Filesystem TS tests pass in C++17 mode
redi [Mon, 16 Apr 2018 08:24:40 +0000 (08:24 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259396 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoAdd sse_unaligned_load_optimal and sse_unaligned_store_optimal to Skylake.
jkoval [Mon, 16 Apr 2018 05:59:52 +0000 (05:59 +0000)] 
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

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259395 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago[gcc/testsuite]
wschmidt [Mon, 16 Apr 2018 02:00:43 +0000 (02:00 +0000)] 
[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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259393 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoDaily bump.
gccadmin [Mon, 16 Apr 2018 00:16:14 +0000 (00:16 +0000)] 
Daily bump.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259392 138bc75d-0d04-0410-961f-82ee72b054a4

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

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259389 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agors6000: Disable -m[no-]direct-move (PR85293)
segher [Sat, 14 Apr 2018 21:13:20 +0000 (21:13 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259386 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agogcc/fortran/ChangeLog:
vehre [Sat, 14 Apr 2018 14:45:59 +0000 (14:45 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259385 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago2018-04-14 Thomas Koenig <tkoenig@gcc.gnu.org>
tkoenig [Sat, 14 Apr 2018 13:38:41 +0000 (13:38 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259384 138bc75d-0d04-0410-961f-82ee72b054a4

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

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259383 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agors6000: Fix _mm_slli_epi{32,64} for shift values 16 through 31 and negative (PR84302)
segher [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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259380 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago2018-04-13 Vladimir Makarov <vmakarov@redhat.com>
vmakarov [Fri, 13 Apr 2018 22:55:16 +0000 (22:55 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259379 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR rtl-optimization/85393
jakub [Fri, 13 Apr 2018 19:55:15 +0000 (19:55 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259378 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR rtl-optimization/85376
jakub [Fri, 13 Apr 2018 19:39:11 +0000 (19:39 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259377 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoFix broken sed command from previous commit
redi [Fri, 13 Apr 2018 10:55:29 +0000 (10:55 +0000)] 
Fix broken sed command from previous commit

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

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259374 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR rtl-optimization/83852
abel [Fri, 13 Apr 2018 10:24:02 +0000 (10:24 +0000)] 
    PR rtl-optimization/83852
        * gcc.dg/pr83852.c: New testcase.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259373 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoFix __iosfail_type_info hack to work on darwin
redi [Fri, 13 Apr 2018 10:06:21 +0000 (10:06 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259371 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoIBM Z: Get rid of target specific C++ testcase
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259369 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR tree-optimization/82965
hubicka [Fri, 13 Apr 2018 08:59:05 +0000 (08:59 +0000)] 
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

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259368 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR lto/71991
hubicka [Fri, 13 Apr 2018 08:51:47 +0000 (08:51 +0000)] 
PR lto/71991
* config/i386/i386.c (ix86_can_inline_p): Allow safe transitions for
always inline.
* gcc.target/i386/pr71991.c: New testcase.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259367 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR middle-end/81657
jakub [Fri, 13 Apr 2018 08:35:32 +0000 (08:35 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259366 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoFix gcc.dg/debug/pr41893-1.c with Solaris ld (PR lto/81968)
ro [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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259364 138bc75d-0d04-0410-961f-82ee72b054a4

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

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259363 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoPrevent erroneous "macro had not yet been defined" messages (PR c++/85385)
dmalcolm [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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259360 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago2018-04-12 Thomas Koenig <tkoenig@gcc.gnu.org>
tkoenig [Thu, 12 Apr 2018 21:58:54 +0000 (21:58 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259359 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoFix comments that misspell names of files and classes
redi [Thu, 12 Apr 2018 20:55:02 +0000 (20:55 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259357 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR c++/85356 - ICE with pointer to member function.
jason [Thu, 12 Apr 2018 20:03:33 +0000 (20:03 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259356 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR c++/85258
mpolacek [Thu, 12 Apr 2018 20:02:47 +0000 (20:02 +0000)] 
PR c++/85258
* constexpr.c (reduced_constant_expression_p): Return false for null
trees.

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

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259355 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agors6000: Fix an ICE with -mno-direct-move (PR85291)
segher [Thu, 12 Apr 2018 20:01:37 +0000 (20:01 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259354 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR debug/83157
jakub [Thu, 12 Apr 2018 19:30:00 +0000 (19:30 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259353 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoRevert 259346.
cesar [Thu, 12 Apr 2018 18:48:56 +0000 (18:48 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259351 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agogcc/testsuite/ChangeLog:
kelvin [Thu, 12 Apr 2018 16:16:08 +0000 (16:16 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259350 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoRemove #define made redundant by r259281
redi [Thu, 12 Apr 2018 16:06:03 +0000 (16:06 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259349 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agosel-sched: move cleanup_cfg before calculate_dominance_info (PR 85354)
amonakov [Thu, 12 Apr 2018 15:40:44 +0000 (15:40 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259348 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR target/85238
ebotcazou [Thu, 12 Apr 2018 14:18:17 +0000 (14:18 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259347 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoPR middle-end/84955
cesar [Thu, 12 Apr 2018 13:15:45 +0000 (13:15 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259346 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago2018-04-12 Richard Biener <rguenther@suse.de>
rguenth [Thu, 12 Apr 2018 12:27:14 +0000 (12:27 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259345 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR target/85328
jakub [Thu, 12 Apr 2018 11:17:23 +0000 (11:17 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259344 138bc75d-0d04-0410-961f-82ee72b054a4

7 years agoIBM Z: Spectre: Prevent thunk cfi to be emitted with -fno-dwarf2-cfi-asm
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259340 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago2018-04-11 Paolo Carlini <paolo.carlini@oracle.com>
paolo [Thu, 12 Apr 2018 08:44:47 +0000 (08:44 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259339 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago PR rtl-optimization/85342
jakub [Thu, 12 Apr 2018 08:39:50 +0000 (08:39 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259338 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago[nvptx] Fix handling of extern var with flexible array member
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259337 138bc75d-0d04-0410-961f-82ee72b054a4

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

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259336 138bc75d-0d04-0410-961f-82ee72b054a4

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

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259333 138bc75d-0d04-0410-961f-82ee72b054a4

7 years ago2018-04-11 Paolo Carlini <paolo.carlini@oracle.com>
paolo [Wed, 11 Apr 2018 18:14:07 +0000 (18:14 +0000)] 
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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259327 138bc75d-0d04-0410-961f-82ee72b054a4