platform/upstream/gcc.git
6 years ago[multiple changes]
Pierre-Marie de Rodat [Thu, 16 Nov 2017 09:50:19 +0000 (09:50 +0000)]
[multiple changes]

2017-11-16  Hristian Kirtchev  <kirtchev@adacore.com>

* atree.ads (Nkind_In): Add 10 and 11 parameter versions.
* checks.adb (Install_Primitive_Elaboration_Check): Mark the setting of
the elaboration flag as elaboration code.
* einfo.adb (Contract): Update the comments.
(Ignore_SPARK_Mode_Pragmas): Update the comments.
(SPARK_Aux_Pragma): Update the comments.
(SPARK_Aux_Pragma_Inherited): Update the comments.
(SPARK_Pragma): Update the comments. The attribute now applies
to all types and abstract states.
(SPARK_Pragma_Inherited): Update the comments. The attribute now
applies to all types and abstract states.
(Set_Contract): Update the comments.
(Set_Ignore_SPARK_Mode_Pragmas): Update the comments.
(Set_SPARK_Aux_Pragma): Update the comments.
(Set_SPARK_Aux_Pragma_Inherited): Update the comments.
(Set_SPARK_Pragma): Update the comments. The attribute now applies to
all types and abstract states.
(Set_SPARK_Pragma_Inherited): Update the comments. The attribute now
applies to all types and abstract states.
(Write_Field40_Name): Add output for SPARK_Pragma when it appears on a
type and abstract states.
* einfo.ads: Update the documentation of attributes SPARK_Pragma and
SPARK_Pragma_Inherited.  Both of them now apply to all types and
abstract states.
* exp_util.adb (Set_Elaboration_Flag): Mark the setting of the
elaboration flag as elaboration code.
* sem_ch3.adb: Add with and use clauses for Sem_Elab.
(Analyze_Full_Type_Declaration): Set the SPARK_Mode of the type. Record
a derived type for later processing by the ABE mechanism.
(Analyze_Incomplete_Type_Decl): Set the SPARK_Mode of the type.
(Analyze_Private_Extension_Declaration): Set the SPARK_Mode of the
type.
* sem_ch7.adb (Analyze_Private_Type_Declaration): Set the SPARK_Mode of
the type.
* sem_elab.adb: Define the term "early call region".  Update the
terminology for "scenario" and "target".  Update the architecture of
the ABE mechanism.  Update the steps which must be taken when adding a
new scenario.  Update the section on debugging ABE issues.  Add new
hash tables Early_Call_Regions and Recorded_SPARK_Scenarios.  Add new
table SPARK_Scenarios.  Hash table Elaboration_Context is now
Elaboration_Statuses.  The majority of Process_xxx routines have been
updated to better reflect their role.
(Add_Unit): Reimplemented.
(Check_Elaboration_Constituent): New routine.
(Check_Elaboration_Scenarios): Verify previously recorded scenarios for
conditional ABE issues. Verify previously recorded SPARK scenarios.
(Check_SPARK_Derived_Type): New routine.
(Check_SPARK_Instantiation): New routine.
(Check_SPARK_Scenario): New routine.
(Check_SPARK_Refined_State_Pragma): New routine.
(Early_Call_Region): New routine.
(Elaboration_Status): New routine.
(Ensure_Prior_Elaboration): Add new formal parameter Prag_Nam. The
implicit Elabotate[_All] pragma is now specified via Prag_Nam.
(Find_Early_Call_Region): New routine.
(Info_Scenario): Add output for refinement constituents.
(Is_Recorded_SPARK_Scenario): New routine.
(Is_Suitable_SPARK_Derived_Type): New routine.
(Is_Suitable_SPARK_Instantiation): New routine.
(Is_Suitable_SPARK_Refined_State_Pragma): New routine.
(Is_Visited_Body): New routine.
(Kill_Elaboration_Scenario): Reimplemented.
(Output_Active_Scenarios): Add output for pragma Refined_State.
(Output_SPARK_Refined_State_Pragma): New routine.
(Process_Conditional_ABE_Call): Remove the use of -gnatd.v. The effect
is now achieved by different means.
(Process_Conditional_ABE_Call_SPARK): Verify that a call which precedes
the subprogram body appears within the early call region of the body.
Either ensure the prior elaboration of external subprograms or verify
that the context meets the suitable elaboration requirement.
(Process_Conditional_ABE_Instantiation_SPARK): New routine.
(Record_Elaboration_Scenario): Reimplement the portion which enforces
the level restrictions of the static model. Add support for SPARK
scenarios.
(Record_SPARK_Elaboration_Scenario): New routine.
(Reset_Visited_Bodies): New routine.
(Set_Early_Call_Region): New routine.
(Set_Elaboration_Status): New routine.
(Set_Is_Recorded_SPARK_Scenario): New routine.
(Update_Elaboration_Scenario): Reimplemented.
* sem_elab.ads: Add new subtype Library_Or_Instantiation_Level.
* sem_prag.adb (Analyze_Refined_State_In_Decl_Part): Save the pragma
for examination by the ABE Processing phase.
(Create_Abstract_State): Save the SPARK_Mode from the context.
* sem_util.adb (Is_Non_Preelaborable_Construct): New routine.
* sem_util.ads (Is_Non_Preelaborable_Construct): New routine.
* sinfo.adb (Is_Elaboration_Code): New routine.
(Set_Is_Elaboration_Code): New routine.
(Nkind_In): Add 10 and 11 parameter versions.
* sinfo.ads: Add new attribute Is_Elaboration_Code along with
occurrences in nodes.
(Is_Elaboration_Code): New routine along with pragma Inline.
(Set_Is_Elaboration_Code): New routine along with pragma Inline.
(Nkind_In): Add 10 and 11 parameter versions.

2017-11-16  Justin Squirek  <squirek@adacore.com>

* sem.adb (Analyze): Remove requirement that the original node of N be
an operator in the case that analysis on the node yields the relevant
operator - so prefer it instead.

From-SVN: r254802

6 years agosem_ch6.adb (Create_Extra_Formals): The type of the BIP_Object_Access formal must...
Bob Duff [Thu, 16 Nov 2017 09:43:24 +0000 (09:43 +0000)]
sem_ch6.adb (Create_Extra_Formals): The type of the BIP_Object_Access formal must not have a designated type that...

2017-11-16  Bob Duff  <duff@adacore.com>

* sem_ch6.adb (Create_Extra_Formals): The type of the BIP_Object_Access
formal must not have a designated type that is the full view coming
from a limited-with'ed package.
* sem_util.adb,sem_util.ads (Incomplete_View_From_Limited_With): New
function called from sem_ch6.
* sem_ch5.adb (Analyze_Assignment): Treat user-defined concatenation
specially for b-i-p cases.

From-SVN: r254801

6 years agoProvide more constraints for future use.
Chung-Ju Wu [Thu, 16 Nov 2017 09:38:11 +0000 (09:38 +0000)]
Provide more constraints for future use.

gcc/
* config/nds32/constraints.md: Provide more constraints.
* config/nds32/nds32.h (enum reg_class, REG_CLASS_NAMES,
REG_CLASS_CONTENTS): Define R5_REG, R8_REG, and FRAME_POINTER_REG to
support constraints usage.

Co-Authored-By: Kito Cheng <kito.cheng@gmail.com>
From-SVN: r254800

6 years agoRemove the useless constant UNSPEC_VOLATILE_FUNC_RETURN.
Chung-Ju Wu [Thu, 16 Nov 2017 09:23:12 +0000 (09:23 +0000)]
Remove the useless constant UNSPEC_VOLATILE_FUNC_RETURN.

gcc/
* config/nds32/constants.md (UNSPEC_VOLATILE_FUNC_RETURN): Remove.

From-SVN: r254799

6 years agoAdd new options: -mext-perf, -mext-perf2, -mext-string.
Chung-Ju Wu [Thu, 16 Nov 2017 09:15:21 +0000 (09:15 +0000)]
Add new options: -mext-perf, -mext-perf2, -mext-string.

gcc/
* config/nds32/nds32.opt: Add mext-perf, mext-perf2, mext-string.
* config/nds32/nds32.opt: Refine the layout.
* config/nds32/nds32.c (TARGET_EXT_PERF, TARGET_EXT_PERF2,
TARGET_EXT_STRING): Support new options.
* config/nds32/nds32.h: Likewise.
* config/nds32/nds32.md: Likewise.
* config/nds32/nds32-predicates.c: Likewise.
* config/nds32/constraints.md: Likewise.
* common/config/nds32/nds32-common.c: Likewise.

Co-Authored-By: Kito Cheng <kito.cheng@gmail.com>
From-SVN: r254798

6 years agoFix GFNI check which didn't work properly in gfni+sse case
Julia Koval [Thu, 16 Nov 2017 06:14:54 +0000 (07:14 +0100)]
Fix GFNI check which didn't work properly in gfni+sse case

gcc/
PR target/82983
* config/i386/gfniintrin.h: Add sse check.
* config/i386/i386.c (ix86_expand_builtin): Fix gfni check.

From-SVN: r254797

6 years agoEnable VBMI2 support [1/7]
Julia Koval [Thu, 16 Nov 2017 06:07:00 +0000 (07:07 +0100)]
Enable VBMI2 support [1/7]

gcc/
* common/config/i386/i386-common.c (OPTION_MASK_ISA_AVX512VBMI2_SET,
OPTION_MASK_ISA_AVX512VBMI2_UNSET): New.
(ix86_handle_option): Handle -mavx512vbmi2.
* config/i386/cpuid.h: Add bit_AVX512VBMI2.
* config/i386/driver-i386.c (host_detect_local_cpu): Handle new bit.
* config/i386/i386-c.c (__AVX512VBMI2__): New.
* config/i386/i386.c (ix86_target_string): Handle -mavx512vbmi2.
(ix86_valid_target_attribute_inner_p): Ditto.
* config/i386/i386.h (TARGET_AVX512VBMI2, TARGET_AVX512VBMI2_P): New.
* config/i386/i386.opt (mavx512vbmi2): New option.
* doc/invoke.texi: Add new option.

From-SVN: r254796

6 years agoGFNI enabling [4/4]
Julia Koval [Thu, 16 Nov 2017 05:59:51 +0000 (06:59 +0100)]
GFNI enabling [4/4]

gcc/
* config/i386/gfniintrin.h (_mm_gf2p8mul_epi8, _mm256_gf2p8mul_epi8,
_mm_mask_gf2p8mul_epi8, _mm_maskz_gf2p8mul_epi8,
_mm256_mask_gf2p8mul_epi8, _mm256_maskz_gf2p8mul_epi8,
_mm512_mask_gf2p8mul_epi8, _mm512_maskz_gf2p8mul_epi8,
_mm512_gf2p8mul_epi8): New intrinsics.
* config/i386/i386-builtin-types.def
(V64QI_FTYPE_V64QI_V64QI): New type.
* config/i386/i386-builtin.def (__builtin_ia32_vgf2p8mulb_v64qi,
__builtin_ia32_vgf2p8mulb_v64qi_mask, __builtin_ia32_vgf2p8mulb_v32qi,
__builtin_ia32_vgf2p8mulb_v32qi_mask, __builtin_ia32_vgf2p8mulb_v16qi,
__builtin_ia32_vgf2p8mulb_v16qi_mask): New builtins.
* config/i386/sse.md (vgf2p8mulb_*): New pattern.
* config/i386/i386.c (ix86_expand_args_builtin): Handle new type.
gcc/testsuite/
* gcc.target/i386/avx512f-gf2p8mulb-2.c: New runtime tests.
* gcc.target/i386/avx512vl-gf2p8mulb-2.c: Ditto.
* gcc.target/i386/gfni-1.c: Add tests for GF2P8MUL.
* gcc.target/i386/gfni-2.c: Ditto.
* gcc.target/i386/gfni-3.c: Ditto.
* gcc.target/i386/gfni-4.c: Ditto.

From-SVN: r254795

6 years ago* include/std/numeric (gcd): Fix typo.
Jason Merrill [Thu, 16 Nov 2017 05:13:16 +0000 (00:13 -0500)]
* include/std/numeric (gcd): Fix typo.

From-SVN: r254794

6 years agoDaily bump.
GCC Administrator [Thu, 16 Nov 2017 00:16:18 +0000 (00:16 +0000)]
Daily bump.

From-SVN: r254793

6 years agoi386.c (x86_print_call_or_nop): Emit 5 byte nop explicitly as a stream of bytes.
Uros Bizjak [Wed, 15 Nov 2017 22:26:46 +0000 (23:26 +0100)]
i386.c (x86_print_call_or_nop): Emit 5 byte nop explicitly as a stream of bytes.

* config/i386/i386.c (x86_print_call_or_nop): Emit 5 byte nop
explicitly as a stream of bytes.

From-SVN: r254788

6 years agoaltivec.h (vec_xst_be): New #define.
Bill Schmidt [Wed, 15 Nov 2017 21:21:32 +0000 (21:21 +0000)]
altivec.h (vec_xst_be): New #define.

[gcc]

2017-11-15  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>

* config/rs6000/altivec.h (vec_xst_be): New #define.
* config/rs6000/altivec.md (altivec_vperm_<mode>_direct): Rename
and externalize from *altivec_vperm_<mode>_internal.
* config/rs6000/rs6000-builtin.def (XL_BE_V16QI): Remove macro
instantiation.
(XL_BE_V8HI): Likewise.
(XL_BE_V4SI): Likewise.
(XL_BE_V4SI): Likewise.
(XL_BE_V2DI): Likewise.
(XL_BE_V4SF): Likewise.
(XL_BE_V2DF): Likewise.
(XST_BE): Add BU_VSX_OVERLOAD_X macro instantiation.
* config/rs6000/rs6000-c.c (altivec_overloaded_builtins): Correct
all array entries with these keys: VSX_BUILTIN_VEC_XL,
VSX_BUILTIN_VEC_XL_BE, VSX_BUILTIN_VEC_XST.  Add entries for key
VSX_BUILTIN_VEC_XST_BE.
* config/rs6000/rs6000.c (altivec_expand_xl_be_builtin): Remove.
(altivec_expand_builtin): Remove handling for VSX_BUILTIN_XL_BE_*
built-ins.
(altivec_init_builtins): Replace conditional calls to def_builtin
for __builtin_vsx_ld_elemrev_{v8hi,v16qi} and
__builtin_vsx_st_elemrev_{v8hi,v16qi} based on TARGET_P9_VECTOR
with unconditional calls.  Remove calls to def_builtin for
__builtin_vsx_le_be_<mode>.  Add a call to def_builtin for
__builtin_vec_xst_be.
* config/rs6000/vsx.md (vsx_ld_elemrev_v8hi): Convert define_insn
to define_expand, and add alternate RTL generation for P8.
(*vsx_ld_elemrev_v8hi_internal): New define_insn based on
vsx_ld_elemrev_v8hi.
(vsx_ld_elemrev_v16qi): Convert define_insn to define_expand, and
add alternate RTL generation for P8.
(*vsx_ld_elemrev_v16qi_internal): New define_insn based on
vsx_ld_elemrev_v16qi.
(vsx_st_elemrev_v8hi): Convert define_insn
to define_expand, and add alternate RTL generation for P8.
(*vsx_st_elemrev_v8hi_internal): New define_insn based on
vsx_st_elemrev_v8hi.
(vsx_st_elemrev_v16qi): Convert define_insn to define_expand, and
add alternate RTL generation for P8.
(*vsx_st_elemrev_v16qi_internal): New define_insn based on
vsx_st_elemrev_v16qi.

[gcc/testsuite]

2017-11-15  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>

* gcc.target/powerpc/swaps-p8-26.c: Modify expected code
generation.

From-SVN: r254787

6 years agoPR testsuite/82988 - g++.dg/cpp0x/lambda/lambda-switch.C fail
Martin Sebor [Wed, 15 Nov 2017 20:57:10 +0000 (20:57 +0000)]
PR testsuite/82988 - g++.dg/cpp0x/lambda/lambda-switch.C fail

gcc/testsuite/ChangeLog:

PR testsuite/82988
* g++.dg/cpp0x/lambda/lambda-switch.C: Prune unimportant warning.

From-SVN: r254786

6 years agoFix gcd breakage.
Ville Voutilainen [Wed, 15 Nov 2017 20:42:58 +0000 (22:42 +0200)]
Fix gcd breakage.

* include/std/numeric (gcd): Use remove_cv_t, not remove_cv.

From-SVN: r254785

6 years agoMove gcc/testsuite entries to gcc/testsuite/ChangeLog
H.J. Lu [Wed, 15 Nov 2017 19:34:26 +0000 (11:34 -0800)]
Move gcc/testsuite entries to gcc/testsuite/ChangeLog

From-SVN: r254784

6 years agoi386: Add X86_TUNE_EMIT_VZEROUPPER
H.J. Lu [Wed, 15 Nov 2017 19:30:58 +0000 (19:30 +0000)]
i386: Add X86_TUNE_EMIT_VZEROUPPER

Add X86_TUNE_EMIT_VZEROUPPER to indicate if vzeroupper instruction should
be inserted before a transfer of control flow out of the function.  It is
turned on by default unless we are tuning for KNL.  Users can always use
-mzeroupper or -mno-zeroupper to override X86_TUNE_EMIT_VZEROUPPER.

gcc/

PR target/82990
* config/i386/i386.c (pass_insert_vzeroupper::gate): Remove
TARGET_AVX512ER check.
(ix86_option_override_internal): Set MASK_VZEROUPPER if
neither -mzeroupper nor -mno-zeroupper is used and
TARGET_EMIT_VZEROUPPER is set.
* config/i386/i386.h (TARGET_EMIT_VZEROUPPER): New.
* config/i386/x86-tune.def: Add X86_TUNE_EMIT_VZEROUPPER.

gcc/testsuite/

PR target/82990
* gcc.target/i386/pr82942-2.c: Add -mtune=knl.
* gcc.target/i386/pr82990-1.c: New test.
* gcc.target/i386/pr82990-2.c: Likewise.
* gcc.target/i386/pr82990-3.c: Likewise.
* gcc.target/i386/pr82990-4.c: Likewise.
* gcc.target/i386/pr82990-5.c: Likewise.
* gcc.target/i386/pr82990-6.c: Likewise.
* gcc.target/i386/pr82990-7.c: Likewise.

From-SVN: r254783

6 years agors6000.c (rs6000_gimple_fold_builtin): Add support for folding of vector compares.
Will Schmidt [Wed, 15 Nov 2017 19:26:21 +0000 (19:26 +0000)]
rs6000.c (rs6000_gimple_fold_builtin): Add support for folding of vector compares.

2017-11-15  Will Schmidt  <will_schmidt@vnet.ibm.com>

[gcc]

* config/rs6000/rs6000.c (rs6000_gimple_fold_builtin): Add support for
folding of vector compares.
(fold_build_vec_cmp): New helper function.
(fold_compare_helper): New helper function.
(builtin_function_type): Add compare builtins to the list of functions
having unsigned arguments.  Cosmetic updates to comment indentation.
* config/rs6000/vsx.md (vcmpneb, vcmpneh, vcmpnew): Update to specify
the not+eq combination.

[testsuite]

* gcc.target/powerpc/builtins-3-p9.c: Add -O1, update
expected codegen checks.
* gcc.target/powerpc/vec-cmp-sel.c: Mark vars as volatile.
* gcc.target/powerpc/vsu/vec-cmpne-0.c: Add -O1.
* gcc.target/powerpc/vsu/vec-cmpne-1.c: Add -O1.
* gcc.target/powerpc/vsu/vec-cmpne-2.c: Add -O1.
* gcc.target/powerpc/vsu/vec-cmpne-3.c: Add -O1.
* gcc.target/powerpc/vsu/vec-cmpne-4.c: Add -O1.
* gcc.target/powerpc/vsu/vec-cmpne-5.c: Add -O1.
* gcc.target/powerpc/vsu/vec-cmpne-6.c: Add -O1.

From-SVN: r254782

6 years agoMinor improvements to Filesystem tests
Jonathan Wakely [Wed, 15 Nov 2017 18:22:43 +0000 (18:22 +0000)]
Minor improvements to Filesystem tests

* testsuite/27_io/filesystem/iterators/directory_iterator.cc: Leave
error_code unset.
* testsuite/27_io/filesystem/iterators/recursive_directory_iterator.cc:
Check for past-the-end before dereferencing.
* testsuite/experimental/filesystem/iterators/
recursive_directory_iterator.cc: Likewise.

From-SVN: r254781

6 years agore PR fortran/78240 (ICE in match_clist_expr, at fortran/decl.c:728)
Steven G. Kargl [Wed, 15 Nov 2017 18:14:14 +0000 (18:14 +0000)]
re PR fortran/78240 (ICE in match_clist_expr, at fortran/decl.c:728)

2017-11-15  Steven G. Kargl  <kargl@gcc.gnu.org>

PR fortran/78240
gfortran.dg/pr78240.f90: Prune run-on errors.

From-SVN: r254780

6 years agoAdd noexcept to generic std::size, std::empty and std::data
Jonathan Wakely [Wed, 15 Nov 2017 17:50:42 +0000 (17:50 +0000)]
Add noexcept to generic std::size, std::empty and std::data

* include/bits/range_access.h (size, empty, data): Add conditional
noexcept to generic overloads.

From-SVN: r254779

6 years agore PR tree-optimization/82726 (ICE in verify_ssa during GIMPLE pass: pcom)
Bin Cheng [Wed, 15 Nov 2017 16:20:21 +0000 (16:20 +0000)]
re PR tree-optimization/82726 (ICE in verify_ssa during GIMPLE pass: pcom)

PR tree-optimization/82726
PR tree-optimization/70754
* tree-predcom.c (order_drefs_by_pos): New function.
(combine_chains): Move code setting has_max_use_after to...
(try_combine_chains): ...here.  New parameter.  Sort combined chains
according to position information.
(tree_predictive_commoning_loop): Update call to above function.
(update_pos_for_combined_chains, pcom_stmt_dominates_stmt_p): New.

gcc/testsuite
* gcc.dg/tree-ssa/pr82726.c: New test.

From-SVN: r254778

6 years agore PR tree-optimization/82726 (ICE in verify_ssa during GIMPLE pass: pcom)
Bin Cheng [Wed, 15 Nov 2017 16:16:49 +0000 (16:16 +0000)]
re PR tree-optimization/82726 (ICE in verify_ssa during GIMPLE pass: pcom)

PR tree-optimization/82726
Revert
2017-01-23  Bin Cheng  <bin.cheng@arm.com>

PR tree-optimization/70754
* tree-predcom.c (stmt_combining_refs): New parameter INSERT_BEFORE.
(reassociate_to_the_same_stmt): New parameter INSERT_BEFORE.  Insert
combined stmt before it if not NULL.
(combine_chains): Process refs reversely and compute dominance point
for root ref.

Revert
2017-02-23  Bin Cheng  <bin.cheng@arm.com>

PR tree-optimization/79663
* tree-predcom.c (combine_chains): Process refs in reverse order
only for ZERO length chains, and add explaining comment.

From-SVN: r254777

6 years agoarm-cpus.in (armv8_3, [...]): New
Tamar Christina [Wed, 15 Nov 2017 16:11:07 +0000 (16:11 +0000)]
arm-cpus.in (armv8_3, [...]): New

2017-11-15  Tamar Christina  <tamar.christina@arm.com>

        * config/arm/arm-cpus.in (armv8_3, ARMv8_3a, armv8.3-a): New
        * config/arm/arm-tables.opt (armv8.3-a): Regenerated.
        * doc/invoke.texi (ARM Options): Add armv8.3-a.

From-SVN: r254776

6 years agoarm.h (TARGET_DOTPROD): Add arm_arch8_2.
Tamar Christina [Wed, 15 Nov 2017 16:05:07 +0000 (16:05 +0000)]
arm.h (TARGET_DOTPROD): Add arm_arch8_2.

2017-11-15  Tamar Christina  <tamar.christina@arm.com>

* config/arm/arm.h (TARGET_DOTPROD): Add arm_arch8_2.

From-SVN: r254775

6 years agoRISC-V: Add Jim Wilson as a maintainer
Palmer Dabbelt [Wed, 15 Nov 2017 15:58:52 +0000 (15:58 +0000)]
RISC-V: Add Jim Wilson as a maintainer

Jim has recently started working at SiFive, where he'll be contributing
to our GCC port.  Andrew, Kito and I would like him to be a mainatiner.
My understand is that this is the right place to ask.

I've also changed my address to my SiFive one, where I also work -- it
seems cleaner to have everyone use our proper email address.

ChangeLog

2017-11-15  Palmer Dabbelt  <palmer@sifive.com>

        * MAINTAINERS (RISC-V): Add Jim Wilson as a maintainer.
        Use my SiFive email address.

From-SVN: r254774

6 years ago[ARM] Fix more -Wreturn-type fallout
Sudakshina Das [Wed, 15 Nov 2017 15:21:03 +0000 (15:21 +0000)]
[ARM] Fix more -Wreturn-type fallout

This patch fixes a couple of more tests that are giving out warnings with -Wreturn-type:
- g++.dg/ext/pr57735.C
- gcc.target/arm/pr54300.C

*** gcc/testsuite/ChangeLog ***

2017-11-10  Sudakshina Das  <sudi.das@arm.com>

        * g++.dg/ext/pr57735.C: Add -Wno-return-type for test.
        * gcc.target/arm/pr54300.C (main): Add return type and
        return a value.

From-SVN: r254773

6 years agoCompile strncpy-fix-1.c with -Wno-stringop-truncation
Tom de Vries [Wed, 15 Nov 2017 15:00:59 +0000 (15:00 +0000)]
Compile strncpy-fix-1.c with -Wno-stringop-truncation

2017-11-15  Tom de Vries  <tom@codesourcery.com>

* gcc.dg/strncpy-fix-1.c: Add -Wno-stringop-truncation to dg-options.

From-SVN: r254772

6 years agopr81706.c: Adjust asm for darwin.
Dominique d'Humieres [Wed, 15 Nov 2017 14:00:49 +0000 (15:00 +0100)]
pr81706.c: Adjust asm for darwin.

2017-11-15  Dominique d'Humieres  <dominiq@lps.ens.fr>

* gcc.target/i386/pr81706.c: Adjust asm for darwin.
* g++.dg/ext/pr81706.C: Likewise.

From-SVN: r254770

6 years agoAdd libgomp.oacc-c-c++-common/f-asyncwait-{1,2,3}.c
Tom de Vries [Wed, 15 Nov 2017 13:40:58 +0000 (13:40 +0000)]
Add libgomp.oacc-c-c++-common/f-asyncwait-{1,2,3}.c

2017-11-15  Tom de Vries  <tom@codesourcery.com>

* testsuite/libgomp.oacc-c-c++-common/f-asyncwait-1.c: New test, copied
from asyncwait-1.f90.  Rewrite into C.  Rewrite from float to int.
* testsuite/libgomp.oacc-c-c++-common/f-asyncwait-2.c: New test, copied
from asyncwait-2.f90.  Rewrite into C.  Rewrite from float to int.
* testsuite/libgomp.oacc-c-c++-common/f-asyncwait-3.c: New test, copied
from asyncwait-3.f90.  Rewrite into C.  Rewrite from float to int.

From-SVN: r254769

6 years ago[PR c++/81574] lambda capture of function reference
Nathan Sidwell [Wed, 15 Nov 2017 13:18:09 +0000 (13:18 +0000)]
[PR c++/81574] lambda capture of function reference

https://gcc.gnu.org/ml/gcc-patches/2017-11/msg01200.html
PR c++/81574
* lambda.c (lambda_capture_field_type): Function references are
always catured by reference.

PR c++/81574
* g++.dg/cpp1y/pr81574.C: New.

From-SVN: r254768

6 years agore PR tree-optimization/82985 (ICC: in vn_nary_build_or_lookup_1, at tree-ssa-sccvn...
Richard Biener [Wed, 15 Nov 2017 12:53:21 +0000 (12:53 +0000)]
re PR tree-optimization/82985 (ICC: in vn_nary_build_or_lookup_1, at tree-ssa-sccvn.c:1722)

2017-11-15  Richard Biener  <rguenther@suse.de>

PR tree-optimization/82985
* g++.dg/torture/pr82985.C: Likewise.

From-SVN: r254767

6 years agoFix fallout of -fsanitize=vptr.
Martin Liska [Wed, 15 Nov 2017 12:40:07 +0000 (13:40 +0100)]
Fix fallout of -fsanitize=vptr.

2017-11-15  Martin Liska  <mliska@suse.cz>

* decl.c (begin_destructor_body): Use cp_build_fold_indirect_ref
instead of cp_build_indirect_ref.

From-SVN: r254765

6 years agoDisable -Wreturn-type by default in all languages other from C++.
Martin Liska [Wed, 15 Nov 2017 12:39:06 +0000 (13:39 +0100)]
Disable -Wreturn-type by default in all languages other from C++.

2017-11-15  Martin Liska  <mliska@suse.cz>

* tree-cfg.c (pass_warn_function_return::execute):
Compare warn_return_type for greater than zero.
2017-11-15  Martin Liska  <mliska@suse.cz>

* options.c (gfc_post_options):
Do not set default value of warn_return_type.
* trans-decl.c (gfc_trans_deferred_vars):
Compare warn_return_type for greater than zero.
(generate_local_decl): Likewise
(gfc_generate_function_code): Likewise.

From-SVN: r254764

6 years agoFix PR82941 and PR82942 by adding proper vzeroupper generation on SKX.
Sebastian Peryt [Wed, 15 Nov 2017 12:27:31 +0000 (13:27 +0100)]
Fix PR82941 and PR82942 by adding proper vzeroupper generation on SKX.

2017-11-15  Sebastian Peryt  <sebastian.peryt@intel.com>

gcc/

PR target/82941
PR target/82942
* config/i386/i386.c (pass_insert_vzeroupper): Modify gate condition
to return true on Xeon and not on Xeon Phi.
(ix86_check_avx256_register): Changed to ...
(ix86_check_avx_upper_register): ... this. Add extra check for
VALID_AVX512F_REG_OR_XI_MODE.
(ix86_avx_u128_mode_needed): Changed
ix86_check_avx256_register to ix86_check_avx_upper_register.
(ix86_check_avx256_stores): Changed to ...
(ix86_check_avx_upper_stores): ... this. Changed
ix86_check_avx256_register to ix86_check_avx_upper_register.
(ix86_avx_u128_mode_after): Changed
avx_reg256_found to avx_upper_reg_found. Changed
ix86_check_avx256_stores to ix86_check_avx_upper_stores.
(ix86_avx_u128_mode_entry): Changed
ix86_check_avx256_register to ix86_check_avx_upper_register.
(ix86_avx_u128_mode_exit): Ditto.
* config/i386/i386.h: (host_detect_local_cpu): New define.

2017-11-15  Sebastian Peryt  <sebastian.peryt@intel.com>

gcc/testsuite/

PR target/82941
PR target/82942
* gcc.target/i386/pr82941-1.c: New test.
* gcc.target/i386/pr82941-2.c: New test.
* gcc.target/i386/pr82942-1.c: New test.
* gcc.target/i386/pr82942-2.c: New test.

From-SVN: r254763

6 years agoMAINTAINERS (write after approval): Add myself.
Sebastian Peryt [Wed, 15 Nov 2017 12:04:05 +0000 (13:04 +0100)]
MAINTAINERS (write after approval): Add myself.

* MAINTAINERS (write after approval): Add myself.

From-SVN: r254762

6 years agoFix -Wreturn-type fallout in g++.dg/cpp0x/rv-trivial-bug.C on Solaris 10
Rainer Orth [Wed, 15 Nov 2017 09:50:59 +0000 (09:50 +0000)]
Fix -Wreturn-type fallout in g++.dg/cpp0x/rv-trivial-bug.C on Solaris 10

* g++.dg/cpp0x/rv-trivial-bug.C (test2): Return a value.

From-SVN: r254760

6 years ago[AArch64] Improve scheduling model for X-Gene
Dominik Infuehr [Wed, 15 Nov 2017 09:24:01 +0000 (09:24 +0000)]
[AArch64] Improve scheduling model for X-Gene

2017-11-15  Dominik Infuehr  <dominik.infuehr@theobroma-systems.com>

* config/arm/xgene1.md (xgene1): Split into automatons
xgene1_main, xgene1_decoder, xgene1_div, xgene1_simd.
(xgene1_f_load): Adjust reservations and/or types.
(xgene1_f_store): Likewise.
(xgene1_load_pair): Likewise.
(xgene1_store_pair): Likewise.
(xgene1_fp_load1): Likewise.
(xgene1_load1): Likewise.
(xgene1_store1): Likewise.
(xgene1_move): Likewise.
(xgene1_alu): Likewise.
(xgene1_simd): Likewise.
(xgene1_bfm): Likewise.
(xgene1_neon_load1): Likewise.
(xgene1_neon_store1): Likewise.
(xgene1_neon_logic): Likewise.
(xgene1_neon_st1): Likewise.
(xgene1_neon_ld1r): Likewise.
(xgene1_alu_cond): Added.
(xgene1_shift_reg): Likwise.
(xgene1_bfx): Likewise.
(xgene1_mul): Split into xgene1_mul32, xgene1_mul64.

From-SVN: r254759

6 years agore PR target/82981 (unnecessary __multi3 call for mips64r6 linux kernel)
Jakub Jelinek [Wed, 15 Nov 2017 09:01:42 +0000 (10:01 +0100)]
re PR target/82981 (unnecessary __multi3 call for mips64r6 linux kernel)

PR target/82981
* internal-fn.c: Include gimple-ssa.h, tree-phinodes.h and
ssa-iterators.h.
(can_widen_mult_without_libcall): New function.
(expand_mul_overflow): If only checking unsigned mul overflow,
not result, and can do efficiently MULT_HIGHPART_EXPR, emit that.
Don't use WIDEN_MULT_EXPR if it would involve a libcall, unless
no other way works.  Add MULT_HIGHPART_EXPR + MULT_EXPR support.
(expand_DIVMOD): Formatting fix.
* expmed.h (expand_mult): Add NO_LIBCALL argument.
* expmed.c (expand_mult): Likewise.  Use OPTAB_WIDEN rather
than OPTAB_LIB_WIDEN if NO_LIBCALL is true, and allow it to fail.

* gcc.target/mips/pr82981.c: New test.

From-SVN: r254758

6 years agore PR tree-optimization/82977 (AddressSanitizer: heap-use-after-free in strlen_optimi...
Jakub Jelinek [Wed, 15 Nov 2017 08:40:32 +0000 (09:40 +0100)]
re PR tree-optimization/82977 (AddressSanitizer: heap-use-after-free in strlen_optimize_stmt .././../gcc/tree-ssa-strlen.c:2971)

PR tree-optimization/82977
* tree-ssa-strlen.c (strlen_optimize_stmt): Pass a reference to a copy
constructed temporary to strlen_to_stridx.put.

From-SVN: r254757

6 years agoCoverage: remove -fkeep-inline-functions from coverage_flags.
Martin Liska [Wed, 15 Nov 2017 07:25:40 +0000 (08:25 +0100)]
Coverage: remove -fkeep-inline-functions from coverage_flags.

2017-11-15  Martin Liska  <mliska@suse.cz>

* configure.ac: Remove -fkeep-inline-functions from coverage_flags.
* configure: Regenerate.

From-SVN: r254756

6 years agoUse proper probability (PR target/82927)
Martin Liska [Wed, 15 Nov 2017 07:11:59 +0000 (08:11 +0100)]
Use proper probability (PR target/82927)

2017-11-15  Martin Liska  <mliska@suse.cz>

PR target/82927
* config/sh/sh-mem.cc: Use proper probability for
REG_BR_PROB_NOTE.

From-SVN: r254755

6 years agoZero vptr in dtor for -fsanitize=vptr.
Martin Liska [Wed, 15 Nov 2017 07:01:01 +0000 (08:01 +0100)]
Zero vptr in dtor for -fsanitize=vptr.

2017-11-15  Martin Liska  <mliska@suse.cz>

* decl.c (begin_destructor_body): In case of VPTR sanitization
(with disabled recovery), zero vptr in order to catch virtual calls
after lifetime of an object.
2017-11-15  Martin Liska  <mliska@suse.cz>

* g++.dg/ubsan/vptr-12.C: New test.

From-SVN: r254754

6 years agoexplow.c (anti_adjust_stack_and_probe_stack_clash): Avoid probing the red zone for...
Jeff Law [Wed, 15 Nov 2017 06:30:31 +0000 (23:30 -0700)]
explow.c (anti_adjust_stack_and_probe_stack_clash): Avoid probing the red zone for stack_clash_protection_final_dynamic_probe...

* explow.c (anti_adjust_stack_and_probe_stack_clash): Avoid probing
the red zone for stack_clash_protection_final_dynamic_probe targets
when the total dynamic stack size is zero bytes.

From-SVN: r254753

6 years agotree-ssa-threadupdate.c (thread_through_all_blocks): Thread blocks is post order.
Jeff Law [Wed, 15 Nov 2017 03:45:03 +0000 (20:45 -0700)]
tree-ssa-threadupdate.c (thread_through_all_blocks): Thread blocks is post order.

* tree-ssa-threadupdate.c (thread_through_all_blocks): Thread
blocks is post order.

From-SVN: r254752

6 years agointroduce TDF_compare_debug, omit OBJ_TYPE_REF casts with it
Alexandre Oliva [Wed, 15 Nov 2017 03:11:48 +0000 (03:11 +0000)]
introduce TDF_compare_debug, omit OBJ_TYPE_REF casts with it

for  gcc/ChangeLog

* dumpfile.h (TDF_COMPARE_DEBUG): New.
* final.c (rest_of_clean_state): Set it for the
-fcompare-debug dump.
* tree-pretty-print.c (dump_generic_node): Omit OBJ_TYPE_REF
class when TDF_COMPARE_DEBUG is set.

From-SVN: r254751

6 years agoUse compare-debug for bootstrap-debug-lean to ignore != DW_AT_producer
Alexandre Oliva [Wed, 15 Nov 2017 03:11:37 +0000 (03:11 +0000)]
Use compare-debug for bootstrap-debug-lean to ignore != DW_AT_producer

Unlike bootstrap-debug, bootstrap-debug-lean used to pass compare using
the traditional compare command, because it compiled both stage2 and
stage3 with options that used to generate identical output
(-fcompare-debug= in stage2 vs -fcompare-debug in stage3).

Since we started adding relevant command-line flags to DW_AT_producer,
this is no longer the case, and stages 2 and 3 object files that differ
in nothing but the DW_AT_producer strings.

-fcompare-debug is short for -fcompare-debug=-gtoggle, so stage3
compiles twice, once with the normal options, once with toggled -g, to
then compare the temporary final dumps.  When enabled, both compilations
get from the driver an additional -frandom-seed flag (if none is given
explicitly).

-fcompare-debug= is short for -fno-compare-debug, disabling the second
compilation.

The difference between the DW_AT_producer lines are the different
-fcompare-debug flags, and the presence of the -frandom-seed flag in the
stage3 compilation.

It is easy and sensible enough to filter the -fcompare-debug flags out
of the DW_AT_producer string.  This option should never affect the
compilation output, it just determines whether or not to perform an
additional compilation that should produce the same executable output.

However, dropping -frandom-seed is not quite correct, in that it might
have other consequences on the compilation.  So, it makes little sense
to make the effort to drop it when it's implicit; for those comparing
compiler output differences, it might even hint at what causes, and
could fix, difficult to explain differences, namely, explicitly
supplying -frandom-seed options.

They don't seem to matter for compiler bootstraps, though, at least
for now, so we can safely refrain from issuing -frandom-seed (or maybe
we already issue it where needed :-), and then, for
bootstrap-debug-lean, use the compare-debug script, that strips out
debug information before comparing the object files.

for  config/ChangeLog

* bootstrap-debug-lean.mk (do-compare): Use the
contrib/compare-debug script.

for  gcc/ChangeLog

* dwarf2out.c (gen_producer_string): Discard
OPT_fcompare_debug.

From-SVN: r254750

6 years agoAdd __builtin_tgmath for better tgmath.h implementation (bug 81156).
Joseph Myers [Wed, 15 Nov 2017 01:53:45 +0000 (01:53 +0000)]
Add __builtin_tgmath for better tgmath.h implementation (bug 81156).

Various implementations of C99/C11 <tgmath.h> have the property that
their macro expansions contain many copies of the macro arguments, so
resulting in exponential blowup of the size of macro expansions where
a call to such a macro contains other such calls in the macro
arguments.

This patch adds a (C-only) language feature __builtin_tgmath designed
to avoid this problem by implementing the <tgmath.h> function
selection rules directly in the compiler.  The effect is that
type-generic macros can be defined simply as

#define pow(a, b) __builtin_tgmath (powf, pow, powl, \
                                    cpowf, cpow, cpowl, a, b)

as in the example added to the manual, with each macro argument
expanded exactly once.  The details of __builtin_tgmath are as
described in the manual.  This is C-only since C++ uses function
overloading and just defines <ctgmath> to include <ccomplex> and
<cmath>.

__builtin_tgmath handles C99/C11 type-generic macros, and _FloatN,
_FloatNx and decimal floating-point types (following the proposed
resolution to the floating-point TS DR#9 that makes the rules for
finding a common type from arguments to a type-generic macro follow
the usual arithmetic conversions after adjustment of integer arguments
to _Decimal64 or double - or to _Complex double in the case of GNU
complex integer arguments).

Type-generic macros for functions from TS 18661 that round their
results to a narrower type are handled, but there are still some
unresolved questions regarding such macros so further changes in that
regard may be needed in future.  The current implementation follows an
older version of the DR#13 resolution (allowing a function for a
wide-enough argument type to be selected if no exactly-matching
function is available), but with appropriate calls to __builtin_tgmath
is still fully compatible with the latest version of the resolution
(not yet in the DR log), and allowing such not-exactly-matching
argument types to be chosen in that case avoids needing another
special case to treat integers as _Float64 instead of double in
certain cases.

Regarding other possible language/library features, not currently
implemented in GCC:

* Imaginary types could be naturally supported by allowing cases where
  the type-generic type is an imaginary type T and arguments or return
  types may be T (as at present), or the corresponding real type to T
  (as at present), or (new) the corresponding real type if T is real
  or imaginary but T if T is complex.  (tgmath.h would need a series
  of functions such as

  static inline _Imaginary double
  __sin_imag (_Imaginary double __x)
  {
    return _Imaginary_I * sinh (__imag__ __x);
  }

  to be used in __builtin_tgmath calls.)

* __builtin_tgmath would use the constant rounding direction in the
  presence of support for the FENV_ROUND / FENV_DEC_ROUND pragmas.
  Support for those would also require a new __builtin_<something> to
  cause a non-type-generic call to use the constant rounding
  direction (it seems cleaner to add a new __builtin_<something> when
  required than to make __builtin_tgmath handle a non-type-generic
  case with only one function argument).

* TS 18661-5 __STDC_TGMATH_OPERATOR_EVALUATION__ would require new
  __builtin_<something> that evaluates with excess range and precision
  like arithmetic operators do.

* The proposed C bindings for IEEE 754-2018 augmented arithmetic
  operations involve struct return types.  As currently implemented
  __builtin_tgmath does not handle those, but support could be added.

There are many error cases that the implementation diagnoses.  I've
tried to ensure reasonable error messages for erroneous uses of
__builtin_tgmath, but the errors for erroneous uses of the resulting
type-generic macros (that is, when the non-function arguments have
inappropriate types) are more important as they are more likely to be
seen by users.

GCC's own tgmath.h, as used for some targets, is updated in this
patch.  I've tested those changes minimally, via adjusting
gcc.dg/c99-tgmath-* locally to use that tgmath.h version.  I've also
run the glibc testsuite (which has much more thorough tests of
correctness of tgmath.h function selection) with a glibc patch to use
__builtin_tgmath in glibc's tgmath.h.

Bootstrapped with no regressions on x86_64-pc-linux-gnu.

PR c/81156

gcc:
* doc/extend.texi (Other Builtins): Document __builtin_tgmath.
* ginclude/tgmath.h (__tg_cplx, __tg_ldbl, __tg_dbl, __tg_choose)
(__tg_choose_2, __tg_choose_3, __TGMATH_REAL_1_2)
(__TGMATH_REAL_2_3): Remove macros.
(__TGMATH_CPLX, __TGMATH_CPLX_2, __TGMATH_REAL, __TGMATH_REAL_2)
(__TGMATH_REAL_3, __TGMATH_CPLX_ONLY): Define using
__builtin_tgmath.
(frexp, ldexp, nexttoward, scalbn, scalbln): Define using
__TGMATH_REAL_2.
(remquo): Define using __TGMATH_REAL_3.

gcc/c:
* c-parser.c (check_tgmath_function): New function.
(enum tgmath_parm_kind): New enum.
(c_parser_postfix_expression): Handle __builtin_tgmath.

gcc/c-family:
* c-common.c (c_common_reswords): Add __builtin_tgmath.
* c-common.h (enum rid): Add RID_BUILTIN_TGMATH.

gcc/testsuite:
* gcc.dg/builtin-tgmath-1.c, gcc.dg/builtin-tgmath-2.c,
gcc.dg/builtin-tgmath-err-1.c, gcc.dg/builtin-tgmath-err-2.c,
gcc.dg/dfp/builtin-tgmath-dfp-err.c,
gcc.dg/dfp/builtin-tgmath-dfp.c: New tests.

From-SVN: r254749

6 years agocompiler: remove LHS/RHS context determination for var exprs
Than McIntosh [Wed, 15 Nov 2017 01:52:45 +0000 (01:52 +0000)]
compiler: remove LHS/RHS context determination for var exprs

    Remove the code that determined LHS/RHS context for var expressions
    (was needed previously for some instances of the back end). LHS/RHS
    context is computed by the back end in all cases, so no need to have
    this code in the front end any more.

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

* go-gcc.cc (var_expression): Remove Varexpr_context parameter.

From-SVN: r254748

6 years agovr-values.c: New file with contents extracted from tree-vrp.c.
Jeff Law [Wed, 15 Nov 2017 00:18:45 +0000 (17:18 -0700)]
vr-values.c: New file with contents extracted from tree-vrp.c.

* vr-values.c: New file with contents extracted from tree-vrp.c.
* Makefile.in (OBJS): Add vr-values.o
* tree-vrp.h (set_value_range_to_nonnull): Prototype.
(set_value_range, set_and_canonicalize_value_range): Likewise.
(vrp_bitmap_equal_p, range_is_nonnull): Likewise.
(value_range_constant_singleton, symbolic_range_p): Likewise.
(compare_values, compare_values_warnv, vrp_val_is_min): Likewise.
(vrp_val_is_max, copy_value_range, set_value_range_to_value): Likewise.
(extract_range_from_binary_expr_1, vrp_val_min, vrp_val_max): Likewise.
(set_value_range_to_null, range_int_cst_p, opreand_less_p): Likewise.
(find_case_label_range, find_case_label_index): Likewise.
(zero_nonzero_bits_from_vr, overflow_comparison_p): Likewise.
(range_int_cst_singleton_p, value_inside_range): Likewise.
(get_single_symbol): Likewise.
(switch_update): Move structure definition here.
(to_remove_edges, to_update_switch_stmts): Provide externs.
* tree-vrp.c: Move all methods for vr-values class to vr-values.c
(vrp_val_max, vrp_val_min, vrp_val_is_max): Make externally visible.
(vrp_val_is_min, set_value_range): Likewise.
(set_and_canonicalize_value_range, copy_value_range): Likewise.
(set_value_range_to_value, set_value_range_to_nonnull): Likewise.
(set_value_range_to_null, vrp_bitmap_equal_p): Likewise.
(range_is_nonnull, range_int_cst_p): Likewwise.
(range_int_cst_singleton_p, symbolic_range_p): Likewise.
(get_single_symbol, operand_less_p): Likewise
(compare_values_warnv, compare_values): Likewise.
(value_inside_range, value_range_constant_singleton): Likewise.
(zero_nonzero_bitgs_from_vr): Likewise.
(extract_range_from_binary_expr_1): Likewise.
(overflow_comparison_p): Likewise.
(to_remove_edges, to_update_switch_stmts): Likewise.
(find_case_label-index, find_case_label_range): Likewise.
(switch_update, set_value_range_to_nonnegative): Remove.
(set_value_range_to_truthvalue): Likewise.
(symbolic_range_based_on_p, gimple_assign_nonzero_p): Likewise.
(gimple_stmt_nonzero_p, compare_ranges): Likewise.
(compare_range_with_value, vrp_valueize, vrp_valueize_1): Likewise.
(find_case_label_ranges, test_for_singularity): Likewise.
(range_fits_type_p, simplify_conversion_using_ranges): LIkewise.
(x_vr_values): Move to its remaining use site.

From-SVN: r254747

6 years agoDaily bump.
GCC Administrator [Wed, 15 Nov 2017 00:16:19 +0000 (00:16 +0000)]
Daily bump.

From-SVN: r254746

6 years agors6000.md (bswapdi2): On 32-bit ISA 3.0, don't generate the XXBRD instruction.
Michael Meissner [Tue, 14 Nov 2017 23:04:27 +0000 (23:04 +0000)]
rs6000.md (bswapdi2): On 32-bit ISA 3.0, don't generate the XXBRD instruction.

2017-11-14  Michael Meissner  <meissner@linux.vnet.ibm.com>

* config/rs6000/rs6000.md (bswapdi2): On 32-bit ISA 3.0, don't
generate the XXBRD instruction.

From-SVN: r254742

6 years agors6000-c.c (is_float128_p): New helper function.
Michael Meissner [Tue, 14 Nov 2017 19:53:28 +0000 (19:53 +0000)]
rs6000-c.c (is_float128_p): New helper function.

[gcc]
2017-11-14  Michael Meissner  <meissner@linux.vnet.ibm.com>

* config/rs6000/rs6000-c.c (is_float128_p): New helper function.
(rs6000_builtin_type_compatible): Treat _Float128 and long double
as being compatible if -mabi=ieeelongdouble.
* config/rs6000/rs6000-builtin.def (BU_FLOAT128_HW_1): New macros
to setup float128 built-ins with hardware support.
(BU_FLOAT128_HW_2): Likewise.
(BU_FLOAT128_HW_3): Likewise.
(BU_FLOAT128_HW_VSX_1): Likewise.
(BU_FLOAT128_HW_VSX_2): Likewise.
(scalar_extract_expq): Change float128 built-in functions to
accommodate having both KFmode and TFmode functions.  Use the
KFmode variant as the default.
(scalar_extract_sigq): Likewise.
(scalar_test_neg_qp): Likewise.
(scalar_insert_exp_q): Likewise.
(scalar_insert_exp_qp): Likewise.
(scalar_test_data_class_qp): Likewise.
(sqrtf128_round_to_odd): Delete processing the round to odd
built-in functions as special built-in functions, and define them
as float128 built-ins.  Use the KFmode variant as the default.
(truncf128_round_to_odd): Likewise.
(addf128_round_to_odd): Likewise.
(subf128_round_to_odd): Likewise.
(mulf128_round_to_odd): Likewise.
(divf128_round_to_odd): Likewise.
(fmaf128_round_to_odd): Likewise.
* config/rs6000/rs6000.c (rs6000_expand_binop_builtin): Add
support for KFmode and TFmode xststdcqp calls.
(rs6000_expand_builtin): If long double is IEEE 128-bit floating
point, switch the built-in handlers for the get/set float128
exponent, get float128 mantissa, float128 test built-ins, and the
float128 round to odd built-in functions.  Eliminate creating the
float128 round to odd built-in functions as special built-ins.
(rs6000_init_builtins): Eliminate special creation of the float128
round to odd built-in functions.
* config/rs6000/vsx.md (xsxexpqp_<mode>): Change float128 built-in
function insns to support both TFmode and KFmode variants.
(xsxsigqp_<mode>): Likewise.
(xsiexpqpf_<mode>): Likewise.
(xsiexpqp_<mode>): Likewise.
(xststdcqp_<mode>): Likewise.
(xststdcnegqp_<mode>): Likewise.
(xststdcqp_<mode>): Likewise.

[gcc/testsuite]
2017-11-14  Michael Meissner  <meissner@linux.vnet.ibm.com>

* gcc.target/powerpc/float128-hw4.c: New test.

From-SVN: r254740

6 years agotree-ssa-threadupdate.c (compute_path_counts): Remove unused path_in_freq_ptr parameter.
Jan Hubicka [Tue, 14 Nov 2017 19:34:29 +0000 (20:34 +0100)]
tree-ssa-threadupdate.c (compute_path_counts): Remove unused path_in_freq_ptr parameter.

* tree-ssa-threadupdate.c (compute_path_counts): Remove
unused path_in_freq_ptr parameter.
(ssa_fix_duplicate_block_edges): Do not pass around path_in_freq

From-SVN: r254739

6 years agoipa-inline.c (edge_badness): Dump sreal frequency.
Jan Hubicka [Tue, 14 Nov 2017 19:30:59 +0000 (20:30 +0100)]
ipa-inline.c (edge_badness): Dump sreal frequency.

* ipa-inline.c (edge_badness): Dump sreal frequency.
(compute_inlined_call_time): Match natural implementaiton ...
* ipa-fnsummary.c (estimate_edge_size_and_time): ... here; remove
forgotten division by CGRAPH_FREQ_BASE.

From-SVN: r254738

6 years agoAdapt Solaris 12 references
Rainer Orth [Tue, 14 Nov 2017 18:31:01 +0000 (18:31 +0000)]
Adapt Solaris 12 references

libgcc:
* config.host (*-*-solaris2*): Adapt comment for Solaris 12
renaming.
* config/sol2/crtpg.c (__start_crt_compiler): Likewise.
* configure.ac (libgcc_cv_solaris_crts): Likewise.
* configure: Regenerate.

gcc:
* config.gcc (*-*-solaris2*): Enable default_use_cxa_atexit since
Solaris 11.  Update comment.
* configure.ac (gcc_cv_ld_pid): Adapt comment for Solaris 12
renaming.
* config/sol2.h (STARTFILE_SPEC): Likewise.
* configure: Regenerate.

gcc/testsuite:
* lib/target-supports.exp (check_effective_target_pie): Adapt
comment for Solaris 12 renaming.

* gcc.dg/torture/pr60092.c: Remove *-*-solaris2.11* dg-xfail-run-if.

From-SVN: r254737

6 years agoImplement LWG 2733 and LWG 2759
Ville Voutilainen [Tue, 14 Nov 2017 18:11:33 +0000 (20:11 +0200)]
Implement LWG 2733 and LWG 2759

* include/experimental/numeric (gcd): Reject cv-qualified bool.
(lcm): Likewise.
* include/std/numeric (gcd): Likewise.
(lcm): Likewise.
* testsuite/26_numerics/gcd/gcd_neg.cc: Add tests and adjust.
* testsuite/26_numerics/lcm/lcm_neg.cc: Likewise.

From-SVN: r254736

6 years agoFix typo in std::wbuffer_convert
Jonathan Wakely [Tue, 14 Nov 2017 18:00:53 +0000 (18:00 +0000)]
Fix typo in std::wbuffer_convert

* include/bits/locale_conv.h (wbuffer_convert::_M_conv_get): Fix typo.
* testsuite/22_locale/conversions/buffer/3.cc: New test.

From-SVN: r254735

6 years agors6000.c (swap_endian_selector_for_mode): Remove le_ and be_ prefixes to swap* variables.
Carl Love [Tue, 14 Nov 2017 17:23:08 +0000 (17:23 +0000)]
rs6000.c (swap_endian_selector_for_mode): Remove le_ and be_ prefixes to swap* variables.

gcc/ChangeLog:

2017-11-14  Carl Love  <cel@us.ibm.com>

* config/rs6000/rs6000.c (swap_endian_selector_for_mode): Remove
le_ and be_ prefixes to swap* variables.  Remove
if (VECTOR_ELT_ORDER_BIG) statement. Remove E_V16QImode case
statements.

gcc/testsuite/ChangeLog:

2017-11-14  Carl Love  <cel@us.ibm.com>

* builtins-revb-runnable.c (dg-do run): Add lp64 directive.  Fix
indentation of printf and abort statements.
* p9-xxbr-1.c (dg-do compile): Add lp64 && p9vector_h directives.

From-SVN: r254732

6 years agoSupport GTY((cache)) on hash_map.
Jason Merrill [Tue, 14 Nov 2017 16:02:57 +0000 (11:02 -0500)]
Support GTY((cache)) on hash_map.

gcc/
* hash-traits.h (ggc_remove): Add ggc_maybe_mx member function.
(ggc_cache_remove): Override it instead of ggc_mx.
* hash-table.h (gt_ggc_mx): Call it instead of ggc_mx.
(gt_cleare_cache): Call ggc_mx instead of gt_ggc_mx.
* hash-map-traits.h (simple_hashmap_traits): Add maybe_mx member.
(simple_cache_map_traits): Override maybe_mx.
* hash-map.h (hash_entry): Add ggc_maybe_mx and keep_cache_entry.
(hash_map): Friend gt_cleare_cache.
(gt_cleare_cache): New.
* tree.h (tree_cache_traits): New hash_map traits class.
(tree_cache_map): New typedef.
gcc/cp/
* decl.c (decomp_type_table): Use tree_cache_map.
* init.c (nsdmi_inst): Likewise.
* pt.c (defarg_ints): Likewise.
* cp-objcp-common.c (cp_get_debug_type): Likewise.

From-SVN: r254731

6 years agotree-cfgcleanup.c (cleanup_control_expr_graph): Remove first_p paramter and handling.
Richard Biener [Tue, 14 Nov 2017 14:43:43 +0000 (14:43 +0000)]
tree-cfgcleanup.c (cleanup_control_expr_graph): Remove first_p paramter and handling.

2017-11-14  Richard Biener  <rguenther@suse.de>

* tree-cfgcleanup.c (cleanup_control_expr_graph): Remove first_p
paramter and handling.
(cleanup_control_flow_bb): Likewise.
(cleanup_control_flow_pre): New helper performing a DFS walk
to call cleanup_control_flow_bb in PRE order.
(cleanup_tree_cfg_1): Do the first phase of cleanup_control_flow_bb
via cleanup_control_flow_pre.

From-SVN: r254730

6 years agolibgo: adapt Solaris 12 references
Ian Lance Taylor [Tue, 14 Nov 2017 14:26:04 +0000 (14:26 +0000)]
libgo: adapt Solaris 12 references

    With the change in the Solaris release model (no more major releases
    like Solaris 12 but only minor ones like 11.4), the Solaris 12
    references in GCC need to be adapted.

    Patch by Rainer Orth.

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

From-SVN: r254729

6 years ago[Patch AArch64] Stop generating BSL for simple integer code
James Greenhalgh [Tue, 14 Nov 2017 14:09:57 +0000 (14:09 +0000)]
[Patch AArch64] Stop generating BSL for simple integer code

Turn aarch64_simd_bsldi_internal in to an insn_and_split that
knows to split back to integer operations if the register allocation
falls that way. Do this to avoid having to move between integer and
Advanced SIMD register files just for a single BSL.

---
gcc/

* config/aarch64/aarch64-simd.md
(aarch64_simd_bsl<mode>_internal): Remove DImode.
(*aarch64_simd_bsl<mode>_alt): Likewise.
(aarch64_simd_bsldi_internal): New.
(aarch64_simd_bsldi_alt): Likewise.

gcc/testsuite/

* gcc.target/aarch64/bsl-idiom.c: New.
* gcc.target/aarch64/copysign-bsl.c: New.

From-SVN: r254727

6 years agotracer.c (better_p): Do not compare frequencies.
Jan Hubicka [Tue, 14 Nov 2017 09:22:49 +0000 (10:22 +0100)]
tracer.c (better_p): Do not compare frequencies.

* tracer.c (better_p): Do not compare frequencies.
* reg-stack.c (better_edge): Likewise.
* shrink-wrap.c (try_shrink_wrapping): Do not convert to gcov counts
and back.

From-SVN: r254726

6 years agoauto-profile.c (afdo_annotate_cfg): Use update_max_bb_count.
Jan Hubicka [Tue, 14 Nov 2017 09:18:35 +0000 (10:18 +0100)]
auto-profile.c (afdo_annotate_cfg): Use update_max_bb_count.

* auto-profile.c (afdo_annotate_cfg): Use update_max_bb_count.
* cgraphunit.c (cgraph_node::expand_thunk): Use update_max_bb_count.
* ipa-utils.c (ipa_merge_profiles): Use update_max_bb_count.
* lto-streamer-in.c (input_function): Use update_max_bb_count.
* omp-expand.c (expand_omp_taskreg): Use update_max_bb_count.
* predict.c (maybe_hot_frequency_p): Inline to ...
(maybe_hot_count_p): ... here; rewrite to counts.
(counts_to_freqs): Rename to ...
(update_max_bb_count): ... this one.
(expensive_function_p): Use counts.
(estimate_bb_frequencies): Update.
(rebuild_frequencies): Update.
* predict.h (counts_to_freqs): Rename to ...
(update_max_bb_count): ... this one.
* profile.c (compute_branch_probabilities): Add debug info
* tree-inline.c (expand_call_inline): Update debug info.
(optimize_inline_calls): Use update_max_bb_count..
(tree_function_versioning): Use update_max_bb_count..
* value-prof.c (gimple_value_profile_transformations):
Do not use update_max_bb_count.

From-SVN: r254725

6 years agoipa-inline.c (compute_uninlined_call_time, [...]): always use frequencies.
Jan Hubicka [Tue, 14 Nov 2017 09:12:46 +0000 (10:12 +0100)]
ipa-inline.c (compute_uninlined_call_time, [...]): always use frequencies.

* ipa-inline.c (compute_uninlined_call_time, compute_inlined_call_time):
always use frequencies.

From-SVN: r254724

6 years agoAllow asyncwait-1.c to run for non-nvidia devices
Tom de Vries [Tue, 14 Nov 2017 09:12:14 +0000 (09:12 +0000)]
Allow asyncwait-1.c to run for non-nvidia devices

2017-11-14  Tom de Vries  <tom@codesourcery.com>

* testsuite/libgomp.oacc-c-c++-common/asyncwait-1.c: Allow to run for
non-nvidia devices.

From-SVN: r254723

6 years agoRequire alloca for c-c++-common/Wstringop-truncation.c
Tom de Vries [Tue, 14 Nov 2017 09:12:05 +0000 (09:12 +0000)]
Require alloca for c-c++-common/Wstringop-truncation.c

2017-11-14  Tom de Vries  <tom@codesourcery.com>

* c-c++-common/Wstringop-truncation.c: Require effective target alloca.

From-SVN: r254722

6 years agobb-reorder.c: Remove frequencies from comments.
Jan Hubicka [Tue, 14 Nov 2017 09:09:20 +0000 (10:09 +0100)]
bb-reorder.c: Remove frequencies from comments.

* bb-reorder.c: Remove frequencies from comments.
(better_edge_p): Use profile counts.
(find_traces): Dump profile counts.
(rotate_loop): Use profile counts.
(find_traces_1_round): Likewise.
(connect_better_edge_p): Use counts instead of probabilities for
reverse walk.
(copy_bb_p): Drop early check for non-0 frequency.
(sanitize_hot_paths): Update comments.

From-SVN: r254721

6 years agoipa-split.c (struct split_point): Add count.
Jan Hubicka [Tue, 14 Nov 2017 09:06:12 +0000 (10:06 +0100)]
ipa-split.c (struct split_point): Add count.

* ipa-split.c (struct split_point): Add count.
(consider_split): Do not compute incoming frequency; compute incoming
count and store it to split_point.
(split_function): Set count of the call to split part correctly.

* testsuite/gcc.dg/tree-ssa/fnsplit-2.c: New testcase.

From-SVN: r254720

6 years agore PR fortran/78240 (ICE in match_clist_expr, at fortran/decl.c:728)
Fritz Reese [Tue, 14 Nov 2017 01:25:26 +0000 (01:25 +0000)]
re PR fortran/78240 (ICE in match_clist_expr, at fortran/decl.c:728)

2017-11-13  Fritz Reese <fritzoreese@gmail.com>

    PR fortran/78240

    gcc/fortran/ChangeLog:

PR fortran/78240
* decl.c (match_clist_expr): Replace gcc_assert with proper
handling of bad result from spec_size().
* resolve.c (check_data_variable): Avoid NULL dereference when passing
locus to gfc_error.

    gcc/testsuite/ChangeLog:

PR fortran/78240
* gfortran.dg/dec_structure_23.f90: New.
* gfortran.dg/pr78240.f90: New.

From-SVN: r254718

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

From-SVN: r254717

6 years agoaltivec.md (altivec_vsumsws_be): Add define_expand.
Carl Love [Mon, 13 Nov 2017 22:40:18 +0000 (22:40 +0000)]
altivec.md (altivec_vsumsws_be): Add define_expand.

gcc/ChangeLog:

2017-11-13  Carl Love  <cel@us.ibm.com>

* config/rs6000/altivec.md (altivec_vsumsws_be): Add define_expand.

gcc/testsuite/ChangeLog:

2017-11-13 Carl Love  <cel@us.ibm.com>

* gcc.target/powerpc/builtin-vec-sums-be-int.c: New test file.

From-SVN: r254714

6 years agoCapture adjustments for P0588R1.
Jason Merrill [Mon, 13 Nov 2017 22:34:38 +0000 (17:34 -0500)]
Capture adjustments for P0588R1.

* semantics.c (process_outer_var_ref): Capture variables when
they are named; complain about non-capture uses when odr-used.
* expr.c (mark_use): Rvalue use looks through capture proxy.
* constexpr.c (potential_constant_expression_1): Improve error about
use of captured variable.
* lambda.c (need_generic_capture, dependent_capture_r)
(do_dependent_capture, processing_nonlambda_template): Remove.
* call.c (build_this): Remove uses of the above.
* decl.c (cp_finish_decl): Likewise.
* semantics.c (maybe_cleanup_point_expr)
(maybe_cleanup_point_expr_void, finish_goto_stmt)
(maybe_convert_cond): Likewise.
* typeck.c (check_return_expr): Likewise.

From-SVN: r254713

6 years agoDefer folding of *&.
Jason Merrill [Mon, 13 Nov 2017 22:12:55 +0000 (17:12 -0500)]
Defer folding of *&.

* typeck.c (cp_build_fold_indirect_ref): New.
(cp_build_indirect_ref_1): Split out from cp_build_indirect_ref.
Add 'fold' parameter.
* cp-tree.h: Declare cp_build_fold_indirect_ref.
* call.c, class.c, cp-ubsan.c, decl.c, except.c, init.c, lambda.c,
parser.c, rtti.c, tree.c, typeck.c, typeck2.c: Use it.
* parser.c (do_range_for_auto_deduction): Use RO_UNARY_STAR.
(cp_convert_range_for): Likewise.
* typeck2.c (build_x_arrow): Use RO_ARROW.

From-SVN: r254712

6 years agoFix cp-ubsan typo.
Jason Merrill [Mon, 13 Nov 2017 22:12:49 +0000 (17:12 -0500)]
Fix cp-ubsan typo.

* cp-ubsan.c (cp_ubsan_check_member_access_r): Fix handling of
INDIRECT_REF of ADDR_EXPR.

From-SVN: r254711

6 years agoPR c++/82360 - ICE with static_cast in template.
Jason Merrill [Mon, 13 Nov 2017 21:49:16 +0000 (16:49 -0500)]
PR c++/82360 - ICE with static_cast in template.

* call.c (perform_direct_initialization_if_possible): Check
processing_template_decl.
* typeck.c (build_static_cast_1): Likewise.

From-SVN: r254710

6 years agoImplement __VA_OPT__
Tom Tromey [Mon, 13 Nov 2017 20:17:42 +0000 (20:17 +0000)]
Implement __VA_OPT__

This implements __VA_OPT__, a new preprocessor feature added in C++2A.
The paper can be found here:

http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2017/p0306r4.html

gcc/ChangeLog

        * doc/cpp.texi (Variadic Macros): Document __VA_OPT__.

gcc/testsuite/ChangeLog

        * c-c++-common/cpp/va-opt-pedantic.c: New file.
        * c-c++-common/cpp/va-opt.c: New file.
        * c-c++-common/cpp/va-opt-error.c: New file.

libcpp/ChangeLog

        * pch.c (cpp_read_state): Set n__VA_OPT__.
        * macro.c (vaopt_state): New class.
        (_cpp_arguments_ok): Check va_opt flag.
        (replace_args, create_iso_definition): Use vaopt_state.
        * lex.c (lex_identifier_intern): Possibly issue errors for
        __VA_OPT__.
        (lex_identifier): Likewise.
        (maybe_va_opt_error): New function.
        * internal.h (struct lexer_state) <va_args_ok>: Update comment.
        (struct spec_nodes) <n__VA_OPT__>: New field.
        * init.c (struct lang_flags) <va_opt>: New field.
        (lang_defaults): Add entries for C++2A.  Update all entries for
        va_opt.
        (cpp_set_lang): Initialize va_opt.
        * include/cpplib.h (struct cpp_options) <va_opt>: New field.
        * identifiers.c (_cpp_init_hashtable): Initialize n__VA_OPT__.

From-SVN: r254707

6 years agors6000-c.c (altivec_overloaded_builtins): Add support for builtins...
Carl Love [Mon, 13 Nov 2017 19:26:54 +0000 (19:26 +0000)]
rs6000-c.c (altivec_overloaded_builtins): Add support for builtins...

gcc/ChangeLog:

2017-11-13  Carl Love  <cel@us.ibm.com>

* config/rs6000/rs6000-c.c (altivec_overloaded_builtins):
Add support for builtins:
unsigned int vec_first_{,miss}_match_{,or_eos}index,
vector {un,}signed {char,int,short},
vector {un,}signed {char,int,short}) arguments.
* config/rs6000/rs6000-builtin.def (VFIRSTMATCHINDEX,
VFIRSTMATCHOREOSINDEX, VFIRSTMISMATCHINDEX, VFIRSTMISMATCHOREOSINDEX):
Add BU_P9V_AV_2 expansions for the builtins.
* config/rs6000/altivec.h (vec_first_match_index,
vec_first_mismatch_index, vec_first_match_or_eos_index,
vec_first_mismatch_or_eos_index): Add #defines for the builtins.
* config/rs6000/rs6000-protos.h (bytes_in_mode): Add
new extern declaration.
* config/rs6000/rs6000.c (bytes_in_mode): Add new function.
* config/rs6000/vsx.md (first_match_index_<mode>,
first_match_or_eos_index_<mode>, first_mismatch_index_<mode>,
first_mismatch_or_eos_index_<mode>): Add define expand.
(vctzlsbb_<mode>): Add mode field to define_insn for vctzlsbb.
* doc/extend.texi: Update the built-in documenation file for the new
built-in functions.

gcc/testsuite/ChangeLog:

2017-11-13  Carl Love  <cel@us.ibm.com>

* gcc.target/powerpc/builtins-6-p9-runnable.c: Add new runnable test.
* gcc.target/powerpc/vsu/vec-cnttz-lsbb-2.c: Update expected error
message.

From-SVN: r254704

6 years agolibcpp: move line typedef and column-numbering comment to top of file
David Malcolm [Mon, 13 Nov 2017 19:07:26 +0000 (19:07 +0000)]
libcpp: move line typedef and column-numbering comment to top of file

The description of our 1-based column-numbering convention was in
a non-obvious place withn line-map.h; this patch moves it to the top
of that header.

libcpp/ChangeLog:
* include/line-map.h (linenum_type): Move this typedef and the
comment describing column numbering to near the top of the file.

From-SVN: r254703

6 years agomatch.pd: Convert fminf<N>...
Michael Meissner [Mon, 13 Nov 2017 19:06:49 +0000 (19:06 +0000)]
match.pd: Convert fminf<N>...

[gcc]
2017-11-13  Michael Meissner  <meissner@linux.vnet.ibm.com>

* match.pd: Convert fminf<N>, fminf<N>x, fmax<N>, and fmax<N>x
into the min/max operations for _Float<N> and _Float<N>X types.

[gcc/testsuite]
2017-11-13  Michael Meissner  <meissner@linux.vnet.ibm.com>

* gcc.target/powerpc/float128-minmax.c: New test.

From-SVN: r254702

6 years agore PR lto/81351 (Many LTO testcases FAIL)
Eric Botcazou [Mon, 13 Nov 2017 17:29:37 +0000 (17:29 +0000)]
re PR lto/81351 (Many LTO testcases FAIL)

PR lto/81351
* dwarf2out.c (do_eh_frame): New static variable.
(dwarf2out_begin_prologue): Set it.
(dwarf2out_frame_finish): Test it instead of dwarf2out_do_eh_frame.

From-SVN: r254700

6 years ago* tree-ssa-coalesce.c (coalesce_cost): Fix formating.
Jan Hubicka [Mon, 13 Nov 2017 17:28:01 +0000 (18:28 +0100)]
* tree-ssa-coalesce.c (coalesce_cost): Fix formating.

From-SVN: r254699

6 years ago* tree-ssa-sink.c (select_best_block): Do not use frequencies.
Jan Hubicka [Mon, 13 Nov 2017 17:27:13 +0000 (18:27 +0100)]
* tree-ssa-sink.c (select_best_block): Do not use frequencies.

From-SVN: r254698

6 years agore PR lto/81351 (Many LTO testcases FAIL)
Eric Botcazou [Mon, 13 Nov 2017 17:26:41 +0000 (17:26 +0000)]
re PR lto/81351 (Many LTO testcases FAIL)

PR lto/81351
* debug.h (dwarf2out_do_eh_frame): Declare.
* dwarf2cfi.c (dwarf2out_do_eh_frame): New predicate.
(dwarf2out_do_frame): Use it.
(dwarf2out_do_cfi_asm): Likewise.
* dwarf2out.c (dwarf2out_frame_finish): Likewise.
(dwarf2out_assembly_start): Likewise.
(dwarf2out_begin_prologue): Fix comment.
* toplev.c (compile_file): Always call dwarf2out_frame_finish
if the target needs either debug or unwind DWARF2 info.
* lto-opts.c (lto_write_options): Do not save -fexceptions,
-fnon-call-exceptions, -ffp-contract, -fmath-errno, -fsigned-zeros,
-ftrapping-math, -ftrapv and -fwrapv.

From-SVN: r254697

6 years agocgraph.c (cgraph_edge::sreal_frequency): New function.
Jan Hubicka [Mon, 13 Nov 2017 17:23:25 +0000 (18:23 +0100)]
cgraph.c (cgraph_edge::sreal_frequency): New function.

* cgraph.c (cgraph_edge::sreal_frequency): New function.
* cgraph.h (cgraph_edge::sreal_frequency): Declare.
* ipa-fnsummary.c (dump_ipa_call_summary): Use sreal_frequency.
(estimate_edge_size_and_time): Likewise.
(ipa_merge_fn_summary_after_inlining): Likewise.
* ipa-inline.c (cgraph_freq_base_rec): Remove.
(compute_uninlined_call_time): Use sreal_frequency.
(compute_inlined_call_time): Likewise.
(ipa_inline): Do not initialize cgraph_freq_base_rec.
* profile-count.c: Include sreal.h.
(profile_count::to_sreal_scale): New.
* profile-count.h: Forward declare sreal.
(profile_count::to_sreal_scale): Declare.

From-SVN: r254696

6 years agoRemove the null check from placement new in all modes
Ville Voutilainen [Mon, 13 Nov 2017 17:02:06 +0000 (19:02 +0200)]
Remove the null check from placement new in all modes

gcc/cp/

Remove the null check from placement new in all modes
* init.c (build_new_1): Don't do a null check for
a namespace-scope non-replaceable placement new
in any mode unless -fcheck-new is provided.

testsuite/

Remove the null check from placement new in all modes
* g++.dg/init/pr35878_1.C: Adjust.
* g++.dg/init/pr35878_4.C: New.
* g++.dg/torture/pr48695.C: Adjust.
* g++.dg/tree-ssa/pr31146-2.C: Likewise.
* g++.dg/tree-ssa/pr41428.C: Adjust.

From-SVN: r254694

6 years ago[ARM] Fix more -Wreturn-type fallout (gcc.target/arm/pr67989.C).
Christophe Lyon [Mon, 13 Nov 2017 16:36:10 +0000 (16:36 +0000)]
[ARM] Fix more -Wreturn-type fallout (gcc.target/arm/pr67989.C).

2017-11-13  Christophe Lyon  <christophe.lyon@linaro.org>

* gcc.target/arm/pr67989.C: Add -Wno-return-type to
dg-additional-options.

From-SVN: r254692

6 years ago[Diagnostic Patch] don't print column zero
Nathan Sidwell [Mon, 13 Nov 2017 15:32:34 +0000 (15:32 +0000)]
[Diagnostic Patch] don't print column zero

https://gcc.gnu.org/ml/gcc-patches/2017-10/msg01911.html
* diagnostic.c (maybe_line_and_column): New.
(diagnostic_get_location_text): Use it.
(diagnostic_report_current_module): Likewise.
(test_diagnostic_get_location_text): Add tests.

* lib/gcc-dg.exp (process-message): Use -: for no column.
* c-c++-common/cilk-plus/CK/cilk_for_grain_errors.c: Mark elided
column messages.
* c-c++-common/cpp/pr58844-1.c: Likewise.
* c-c++-common/cpp/pr58844-2.c: Likewise.
* c-c++-common/cpp/warning-zero-location.c: Likewise.
* g++.dg/diagnostic/pr77949.C: Likewise.
* g++.dg/gomp/macro-4.C: Likewise.
* gcc.dg/Wunknownprag.c: Likewise.
* gcc.dg/builtin-redefine.c: Likewise.
* gcc.dg/cpp/Wunknown-pragmas-1.c: Likewise.
* gcc.dg/cpp/Wunused.c: Likewise.
* gcc.dg/cpp/misspelled-directive-1.c: Likewise.
* gcc.dg/cpp/redef2.c: Likewise.
* gcc.dg/cpp/redef3.c: Likewise.
* gcc.dg/cpp/redef4.c: Likewise.
* gcc.dg/cpp/trad/Wunused.c: Likewise.
* gcc.dg/cpp/trad/argcount.c: Likewise.
* gcc.dg/cpp/trad/comment-3.c: Likewise.
* gcc.dg/cpp/trad/comment.c: Likewise.
* gcc.dg/cpp/trad/defined.c: Likewise.
* gcc.dg/cpp/trad/directive.c: Likewise.
* gcc.dg/cpp/trad/funlike-3.c: Likewise.
* gcc.dg/cpp/trad/funlike.c: Likewise.
* gcc.dg/cpp/trad/literals-2.c: Likewise.
* gcc.dg/cpp/trad/macro.c: Likewise.
* gcc.dg/cpp/trad/pr65238-4.c: Likewise.
* gcc.dg/cpp/trad/recurse-1.c: Likewise.
* gcc.dg/cpp/trad/recurse-2.c: Likewise.
* gcc.dg/cpp/trad/redef2.c: Likewise.
* gcc.dg/cpp/ucnid-11.c: Likewise.
* gcc.dg/cpp/unc1.c: Likewise.
* gcc.dg/cpp/unc2.c: Likewise.
* gcc.dg/cpp/unc3.c: Likewise.
* gcc.dg/cpp/unc4.c: Likewise.
* gcc.dg/cpp/undef2.c: Likewise.
* gcc.dg/cpp/warn-redefined-2.c: Likewise.
* gcc.dg/cpp/warn-redefined.c: Likewise.
* gcc.dg/cpp/warn-unused-macros-2.c: Likewise.
* gcc.dg/cpp/warn-unused-macros.c: Likewise.
* gcc.dg/empty-source-2.c: Likewise.
* gcc.dg/empty-source-3.c: Likewise.
* gcc.dg/gomp/macro-4.c: Likewise.
* gcc.dg/noncompile/pr35447-1.c: Likewise.
* gcc.dg/plugin/location-overflow-test-1.c: Likewise.
* gcc.dg/pr20245-1.c: Likewise.
* gcc.dg/pr28419.c: Likewise.
* gcc.dg/rtl/truncated-rtl-file.c: Likewise.
* gcc.dg/unclosed-init.c: Likewise.

From-SVN: r254691

6 years agoieee_8.f90: xfail for aarch64*-*-gnu*
Charles Baylis [Mon, 13 Nov 2017 13:38:16 +0000 (13:38 +0000)]
ieee_8.f90: xfail for aarch64*-*-gnu*

gcc/testsuite/ChangeLog:

2017-11-13  Charles Baylis  <charles.baylis@linaro.org>

        * gfortran.dg/ieee/ieee_8.f90: xfail for aarch64*-*-gnu*

From-SVN: r254689

6 years ago[Documentation] Fix latency in pipeline description example
Luis Machado [Mon, 13 Nov 2017 10:29:33 +0000 (10:29 +0000)]
[Documentation] Fix latency in pipeline description example

2017-11-09  Luis Machado  <luis.machado@linaro.org>

gcc/
* doc/md.texi (Specifying processor pipeline description): Fix
incorrect latency for the div instruction example.

From-SVN: r254680

6 years agore PR tree-optimization/78821 (GCC7: Copying whole 32 bits structure field by field...
Jakub Jelinek [Mon, 13 Nov 2017 10:26:13 +0000 (11:26 +0100)]
re PR tree-optimization/78821 (GCC7: Copying whole 32 bits structure field by field not optimised into copying whole 32 bits at once)

PR tree-optimization/78821
* gimple-ssa-store-merging.c (compatible_load_p): Don't require
that bit_not_p is the same.
(imm_store_chain_info::coalesce_immediate_stores): Likewise.
(split_group): Count precisely bit_not_p bits in each statement.
(invert_op): New function.
(imm_store_chain_info::output_merged_store): Use invert_op to
emit BIT_XOR_EXPR with a xor_mask instead of BIT_NOT_EXPR if some
but not all orig_stores have BIT_NOT_EXPR in the corresponding spots.

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

From-SVN: r254679

6 years agoGCOV: remove typedef of coverage_t.
Martin Liska [Mon, 13 Nov 2017 09:06:54 +0000 (10:06 +0100)]
GCOV: remove typedef of coverage_t.

2017-11-13  Martin Liska  <mliska@suse.cz>

* gcov.c (struct coverage_info): Remove typedef of coverage_t.
(struct source_info): Likewise.
(add_branch_counts): Likewise.
(add_line_counts): Likewise.
(function_summary): Likewise.
(output_intermediate_line): Likewise.
(generate_results): Likewise.

From-SVN: r254678

6 years agoGCOV: remove typedef for block_t
Martin Liska [Mon, 13 Nov 2017 09:06:43 +0000 (10:06 +0100)]
GCOV: remove typedef for block_t

2017-11-13  Martin Liska  <mliska@suse.cz>

* gcov.c (struct block_info): Remove typedef for block_t.
(struct line_info): Likewise.
(line_info::has_block): Likewise.
(EXIT_BLOCK): Likewise.
(unblock): Likewise.
(circuit): Likewise.
(get_cycles_count): Likewise.
(process_file): Likewise.
(read_graph_file): Likewise.
(solve_flow_graph): Likewise.
(find_exception_blocks): Likewise.
(add_line_counts): Likewise.
(accumulate_line_info): Likewise.
(output_line_details): Likewise.

From-SVN: r254677

6 years agoGCOV: remove typedef for arc_t
Martin Liska [Mon, 13 Nov 2017 09:06:26 +0000 (10:06 +0100)]
GCOV: remove typedef for arc_t

2017-11-13  Martin Liska  <mliska@suse.cz>

* gcov.c (struct arc_info): Remove typedef for arc_t.
(struct line_info): Likewise.
(add_branch_counts): Likewise.
(output_branch_count): Likewise.
(function_info::~function_info): Likewise.
(circuit): Likewise.
(output_intermediate_line): Likewise.
(read_graph_file): Likewise.
(solve_flow_graph): Likewise.
(find_exception_blocks): Likewise.
(add_line_counts): Likewise.
(accumulate_line_info): Likewise.
(output_line_details): Likewise.
(output_function_details): Likewise.

From-SVN: r254676

6 years agoGCOV: remove typedef for function_t
Martin Liska [Mon, 13 Nov 2017 09:06:13 +0000 (10:06 +0100)]
GCOV: remove typedef for function_t

2017-11-13  Martin Liska  <mliska@suse.cz>

* gcov.c (struct function_info): Remove typedef for function_t.
(struct source_info): Likewise.
(source_info::get_functions_at_location): Likewise.
(solve_flow_graph): Likewise.
(find_exception_blocks): Likewise.
(add_line_counts): Likewise.
(output_intermediate_file): Likewise.
(process_file): Likewise.
(generate_results): Likewise.
(release_structures): Likewise.
(read_graph_file): Likewise.
(read_count_file): Likewise.
(accumulate_line_counts): Likewise.
(output_lines): Likewise.

From-SVN: r254675

6 years agoGCOV: introduce vector for function_info::counts.
Martin Liska [Mon, 13 Nov 2017 09:05:55 +0000 (10:05 +0100)]
GCOV: introduce vector for function_info::counts.

2017-11-13  Martin Liska  <mliska@suse.cz>

* gcov.c (function_info::function_info): Remove num_counts
and add vector<gcov_type>.
(function_info::~function_info): Use the vector.
(process_file): Likewise.
(read_graph_file): Likewise.
(read_count_file): Likewise.
(solve_flow_graph): Likewise.

From-SVN: r254674

6 years agoGCOV: simplify usage of function_info::artificial.
Martin Liska [Mon, 13 Nov 2017 09:05:38 +0000 (10:05 +0100)]
GCOV: simplify usage of function_info::artificial.

2017-11-13  Martin Liska  <mliska@suse.cz>

* gcov.c (function_info::is_artificial): New function.
(process_file): Erase all artificial early.
(generate_results): Skip as all artificial are already
removed.

From-SVN: r254673

6 years agoGCOV: introduce global vector of functions
Martin Liska [Mon, 13 Nov 2017 09:05:20 +0000 (10:05 +0100)]
GCOV: introduce global vector of functions

2017-11-13  Martin Liska  <mliska@suse.cz>

* gcov.c (read_graph_file): Store to global vector of functions.
(read_count_file): Iterate the vector.
(process_file): Likewise.
(generate_results): Likewise.
(release_structures): Likewise.

From-SVN: r254672

6 years agore PR tree-optimization/82954 (ICE in fold_binary_loc, at fold-const.c:9061)
Jakub Jelinek [Mon, 13 Nov 2017 09:01:24 +0000 (10:01 +0100)]
re PR tree-optimization/82954 (ICE in fold_binary_loc, at fold-const.c:9061)

PR tree-optimization/82954
* gimple-ssa-store-merging.c
(imm_store_chain_info::coalesce_immediate_stores): If
!infof->ops[N].base_addr, split group if info->ops[N].base_addr.

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

From-SVN: r254671

6 years ago[AArch64] More aarch64_endian_lane_rtx
Richard Sandiford [Mon, 13 Nov 2017 08:21:16 +0000 (08:21 +0000)]
[AArch64] More aarch64_endian_lane_rtx

r254466 failed to update some uses of ENDIAN_LANE_N that were added after
the patch was initially written, which meant that we were treating the
mode number as an element count.

2017-11-13  Richard Sandiford  <richard.sandiford@linaro.org>

gcc/
* config/aarch64/aarch64-simd.md (aarch64_store_lane0<mode>):
Upddate call to ENDIAN_LANE_N.
(aarch64_<sur>dot_lane<vsi2qi>): Use aarch64_endian_lane_rtx.
(aarch64_<sur>dot_laneq<vsi2qi>): Likewise.
(*aarch64_simd_vec_copy_lane<mode>): Update calls to ENDIAN_LANE_N
and use aarch64_endian_lane_rtx.
(*aarch64_simd_vec_copy_lane_<vswap_width_name><mode>): Likewise.

From-SVN: r254670