1. 04 Jun, 2018 18 commits
    • * es.po, fr.po: Update. · 9be91885
      From-SVN: r261159
      Joseph Myers committed
    • rs6000: Fix absif2 · 7638d8b6
      Without this patch absif2 always FAILs.  There is no testcase for
      that, nor do we see it during bootstrap, but it is obvious.
      
      
      	* config/rs6000/rs6000.md (abs<mode>2 for FLOAT128): Handle IFmode.
      
      From-SVN: r261158
      Segher Boessenkool committed
    • Define std::fpos special members as defaulted · 389f7757
      	* include/bits/postypes.h (fpos): Define special members as defaulted.
      
      From-SVN: r261156
      Jonathan Wakely committed
    • PR libstdc++/85930 fix misaligned reference · dbda636d
      	PR libstdc++/85930
      	* include/bits/shared_ptr_base.h (_Sp_make_shared_tag::_S_ti): Align
      	the static variable correctly.
      
      From-SVN: r261155
      Jonathan Wakely committed
    • re PR fortran/85981 (ICE in gfc_trans_string_copy, at fortran/trans-expr.c:6539) · 20ce6ade
      2018-06-04  Steven G. Kargl  <kargl@gcc.gnu.org>
      
      	PR fortran/85981
      	* resolve.c (resolve_allocate_deallocate): Check errmsg is default
      	character kind.
      
      2018-06-04  Steven G. Kargl  <kargl@gcc.gnu.org>
      
      	PR fortran/85981
      	* gfortran.dg/allocate_alloc_opt_14.f90: New test.
      	* gfortran.dg/allocate_alloc_opt_1.f90: Update error string.
      	* gfortran.dg/allocate_stat_2.f90: Ditto.
      	* gfortran.dg/deallocate_alloc_opt_1.f90: Ditto.
      
      From-SVN: r261154
      Steven G. Kargl committed
    • [MAINTAINERS] Update email address · 37cca345
      	* MAINTAINERS: Update my email address.
      
      From-SVN: r261153
      Matthew Fortune committed
    • PR c++/61806 - missed SFINAE with partial specialization. · ae177d35
      	* cp-tree.h (deferring_access_check_sentinel): Add deferring_kind
      	parameter to constructor.
      	* pt.c (instantiate_class_template_1): Enable access checking
      	before call to most_specialized_partial_spec.
      
      From-SVN: r261151
      Jason Merrill committed
    • Fix expand_expr_real_1 handling of BLKmode bitfield references · 8566678b
      The handling of bitfield references in expand_expr_real_1 includes:
      
                  machine_mode ext_mode = mode;
      
                  if (ext_mode == BLKmode
                      && ! (target != 0 && MEM_P (op0)
                            && MEM_P (target)
                            && multiple_p (bitpos, BITS_PER_UNIT)))
                    ext_mode = int_mode_for_size (bitsize, 1).else_blk ();
      
                  if (ext_mode == BLKmode)
                    {
                      [...]
                      gcc_assert (MEM_P (op0)
      
      Here "mode" is the TYPE_MODE of the result, so when mode == BLKmode,
      the target must be a MEM if nonnull, since no other rtl objects can
      have BLKmode.  But there's no guarantee that the source value op0 is also
      BLKmode and thus also a MEM: we can reach the assert for any source if
      the bitsize being extracted is larger than the largest integer mode
      (or larger than MAX_FIXED_MODE_SIZE).
      
      This triggered for SVE with -msve-vector-bits=512, where we could
      sometimes try to extract a BLKmode value from a 512-bit vector,
      and where int_mode_for_size would rightly fail for large bitsizes.
      
      The patch reuses the existing:
      
      	/* Otherwise, if this is a constant or the object is not in memory
      	   and need be, put it there.  */
      	else if (CONSTANT_P (op0) || (!MEM_P (op0) && must_force_mem))
      	  {
      	    memloc = assign_temp (TREE_TYPE (tem), 1, 1);
      	    emit_move_insn (memloc, op0);
      	    op0 = memloc;
      	    clear_mem_expr = true;
      	  }
      
      to handle this case.
      
      2018-05-29  Richard Sandiford  <richard.sandiford@linaro.org>
      
      gcc/
      	* expr.c (expand_expr_real_1): Force the operand into memory if
      	its TYPE_MODE is BLKmode and if there is no integer mode for
      	the number of bits being extracted.
      
      gcc/testsuite/
      	* gcc.target/aarch64/sve/extract_5.c: New test.
      
      From-SVN: r261150
      Richard Sandiford committed
    • re PR target/85832 ([AVX512] possible shorter code when comparing with vector of zeros) · 1fc9aa54
      	PR target/85832
      	PR target/86036
      	* config/i386/sse.md (<avx512>_eq<mode>3<mask_scalar_merge_name>_1):
      	Use vptestnm rather than vptestm in (=Yc,v,C) variant.
      
      	* gcc.target/i386/avx512f-pr85832.c: Expect vptestnm rather than
      	vptestm.
      	* gcc.target/i386/avx512vl-pr85832.c: Likewise.
      	* gcc.target/i386/avx512vlbw-pr85832.c: Likewise.
      	* gcc.target/i386/avx512bw-pr85832.c: Likewise.
      	* gcc.target/i386/avx512bw-pr86036.c: New test.
      
      From-SVN: r261148
      Jakub Jelinek committed
    • PR c++/85765 - SFINAE and non-type default template arg. · 92a38cfd
      	* pt.c (type_unification_real): Do full semantic processing if
      	substituting a partial args list replaces all template parms.
      
      From-SVN: r261146
      Jason Merrill committed
    • tree-cfgcleanup.c (cleanup_tree_cfg_1): Fold into... · 1ccaa21f
      2018-06-04  Richard Biener  <rguenther@suse.de>
      
      	* tree-cfgcleanup.c (cleanup_tree_cfg_1): Fold into...
      	(cleanup_tree_cfg_noloop): ... single caller.  Do
      	start_recording_case_labels later.
      
      From-SVN: r261145
      Richard Biener committed
    • cldemoteintrin.h: Change define from _X86INTRIN_H_INCLUDED to _IMMINTRIN_H_INCLUDED. · 5a6e3d79
      2018-06-04  Sebastian Peryt  <sebastian.peryt@intel.com>
      
              * config/i386/cldemoteintrin.h: Change define from _X86INTRIN_H_INCLUDED
              to _IMMINTRIN_H_INCLUDED.
              * config/i386/pconfigintrin.h: Ditto.
              * config/i386/waitpkgintrin.h: Ditto.
              * config/i386/immintrin.h: Add includes for sgxintrin.h,
              pconfigintrin.h, waitpkgintrin.h and cldemoteintrin.h.
              * config/i386/x86intrin.h: Remove includes for mintrin.h, xmmintrin.h,
              emmintrin.h, pmmintrin.h, tmmintrin.h, smmintrin.h, wmmintrin.h,
              bmiintrin.h, bmi2intrin.h, lzcntintrin.h, sgxintrin.h, pconfigintrin.h,
              waitpkgintrin.h and cldemoteintrin.h.
      
      From-SVN: r261144
      Sebastian Peryt committed
    • [MAINTAINERS] Remove redundant write-after-approval entries · 74386680
      2018-06-04  Tom de Vries  <tdevries@suse.de>
      
      	* MAINTAINERS: Remove write-after-approval entries for component
      	maintainers.
      
      From-SVN: r261143
      Tom de Vries committed
    • re PR tree-optimization/86038 (ICE in to_reg_br_prob_base, at profile-count.h:242) · c77bb674
      2018-06-04  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/86038
      	* tracer.c (find_best_successor): Check probability for
      	being initialized, bail out if not.
      
      	* gcc.dg/pr86038.c: New testcase.
      
      From-SVN: r261142
      Richard Biener committed
    • [arm] PR target/86003 build failures with --with-cpu=xscale · 34a1d5c2
      The XScale cpu configuration in GCC has always been somewhat
      non-conforming.  Although XScale isn't an architecture (it's simply an
      implementation of ARMv5te), we do by tradition emit a specific
      pre-define for it.  We achieve this effect by adding an additional
      feature bit to the xscale CPU definition that isn't part of the base
      architecture.
      
      When I restructured the options last year I overlooked this oddity and
      the result, of course, is that this configuration now fails to build
      as intended.
      
      What happens is that the driver (correctly) constructs an architecture
      for the xscale cpu name (as armv5te) and passes it in addition to the
      CPU name.  The backend code, on finding both a cpu and an architecture
      specifies attempts to correlate the two and finds a difference due to
      the additional feature bit and reports an inconsistency (fatally if
      -werror is specified).
      
      I think the best fix to this is to treat the xscale feature bit using
      the same mechanism that we use for other 'quirks' in CPU
      implementations and simply filter it out before comparing the
      capabilities.  It has the additional benefit that it's also the
      simplest fix.
      
      	PR target/86003
      	* config/arm/arm-cpus.in (ALL_QUIRKS): Add xscale feature to the list
      	of bits to ignore when comparing architectures.
      
      From-SVN: r261140
      Richard Earnshaw committed
    • re PR tree-optimization/69615 (0 to limit signed range checks don't always use unsigned compare) · 261ef15d
      	PR tree-optimization/69615
      	* fold-const.c (merge_ranges): If range1 is - [x, x] and x is the
      	maximum or minimum of the type, try to merge it also as if
      	range1 is + [-, x - 1] or + [x + 1, -].
      
      	* gcc.dg/pr69615.c: New test.
      
      From-SVN: r261139
      Jakub Jelinek committed
    • re PR c++/86025 (ICE with -Wduplicated-branches and OpenMP critical) · 20b11fd4
      	PR c++/86025
      	* tree.c (inchash::add_expr): Handle IDENTIFIER_NODE.
      
      	* c-c++-common/gomp/pr86025.c: New test.
      
      From-SVN: r261137
      Jakub Jelinek committed
    • Daily bump. · ea476799
      From-SVN: r261136
      GCC Administrator committed
  2. 03 Jun, 2018 10 commits
  3. 02 Jun, 2018 11 commits
    • [NDS32] Support Linux target for nds32. · cf3cd43d
      gcc/
      	* config.gcc (nds32*): Use nds32-linux.opt and nds32-elf.opt.
      	(nds32le-*-*, nds32be-*-*): Integrate checking process.
      	(nds32*-*-*): Add glibc and uclibc conditions.
      	* common/config/nds32/nds32-common.c (nds32_except_unwind_info): New.
      	(TARGET_EXCEPT_UNWIND_INFO): Define.
      	* config/nds32/elf.h: New file.
      	* config/nds32/linux.h: New file.
      	* config/nds32/nds32-elf.opt: New file.
      	* config/nds32/nds32-linux.opt: New file.
      	* config/nds32/nds32-fp-as-gp.c
      	(pass_nds32_fp_as_gp::gate): Consider TARGET_LINUX_ABI.
      	* config/nds32/nds32.c (nds32_conditional_register_usage): Consider
      	TARGET_LINUX_ABI.
      	(nds32_asm_file_end): Ditto.
      	(nds32_print_operand): Ditto.
      	(nds32_insert_attributes): Ditto.
      	(nds32_init_libfuncs): New function.
      	(TARGET_HAVE_TLS): Define.
      	(TARGET_INIT_LIBFUNCS): Define.
      	* config/nds32/nds32.h (TARGET_DEFAULT_RELAX): Apply different relax
      	spec content.
      	(TARGET_ELF): Apply different mcmodel setting.
      	(LINK_SPEC, LIB_SPEC, STARTFILE_SPEC, ENDFILE_SPEC): The content has
      	been migrated into elf.h and linux.h files.
      	* config/nds32/nds32.md (add_pc): Consider TARGET_LINUX_ABI.
      	* config/nds32/nds32.opt (mvh): Consider TARGET_LINUX_ABI.
      	(mcmodel): The content has been migrated into nds32-elf.opt and
      	nds32-linux.opt files.
      	* config/nds32/t-elf: New file.
      	* config/nds32/t-linux: New file.
      
      libgcc/
      	* config.host (nds32*-linux*): New.
      	* config/nds32/linux-atomic.c: New file.
      	* config/nds32/linux-unwind.h: New file.
      
      Co-Authored-By: Kito Cheng <kito.cheng@gmail.com>
      Co-Authored-By: Monk Chiang <sh.chiang04@gmail.com>
      
      From-SVN: r261116
      Chung-Ju Wu committed
    • [NDS32] Implement fp-as-gp optimization. · 2140297c
      gcc/
      	* config/nds32/constants.md (unspec_volatile_element): Add
      	UNSPEC_VOLATILE_OMIT_FP_BEGIN and UNSPEC_VOLATILE_OMIT_FP_END.
      	* config/nds32/nds32-fp-as-gp.c: New implementation of fp_as_gp
      	optimization.
      	* config/nds32/nds32-protos.h (nds32_naked_function_p): Declare.
      	(make_pass_nds32_fp_as_gp): Declare.
      	* config/nds32/nds32.c (nds32_register_passes): Add fp_as_gp as one
      	optmization pass.
      	(nds32_asm_function_end_prologue): Remove unused asm output.
      	(nds32_asm_function_begin_epilogue): Remove unused asm output.
      	(nds32_asm_file_start): Output necessary fp_as_gp information.
      	(nds32_option_override): Adjust register usage.
      	(nds32_expand_prologue): Consider fp_as_gp situation.
      	(nds32_expand_prologue_v3push): Consider fp_as_gp situation.
      	* config/nds32/nds32.md (prologue): Check fp_as_gp_p and naked_p.
      	(epilogue): Ditto.
      	(return): Ditto.
      	(simple_return): Ditto.
      	(omit_fp_begin): Output special directive for fp_as_gp.
      	(omit_fp_end): Output special directive for fp_as_gp.
      	* config/nds32/nds32.opt (mfp-as-gp, mno-fp-as-gp, mforce-fp-as-gp,
      	mforbid-fp-as-gp): New options.
      
      Co-Authored-By: Shiva Chen <shiva0217@gmail.com>
      
      From-SVN: r261115
      Chung-Ju Wu committed
    • decl.c (gnat_to_gnu_entity): If this is not a definition... · e812d4dd
      	* gcc-interface/decl.c (gnat_to_gnu_entity) <E_Constant>: If this is
      	not a definition, retrieve the expression only if it's a compile-time
      	known value if we are just annotating types.
      
      	* gcc-interface/utils.c (convert): Do not try to upcast properly for a
      	conversion between tagged types in type_annotate_only mode.
      
      From-SVN: r261113
      Eric Botcazou committed
    • Add missing directive · fcf7081c
      From-SVN: r261109
      Eric Botcazou committed
    • ada-tree.h (TYPE_PADDING_FOR_COMPONENT): New macro. · 988ee9bc
      	* gcc-interface/ada-tree.h (TYPE_PADDING_FOR_COMPONENT): New macro.
      	* gcc-interface/decl.c (gnat_to_gnu_component_type): Cache the padding
      	type built for an aliased component with variable size.
      
      From-SVN: r261106
      Eric Botcazou committed
    • discr53.ad[sb]: New test. · 82b33777
      	* gnat.dg/discr53.ad[sb]: New test.
      	* gnat.dg/discr53_pkg.ads: New helper.
      
      From-SVN: r261102
      Eric Botcazou committed
    • PR c++/85764 - bogus 'this' not captured error. · 4cda703e
      	* lambda.c (resolvable_dummy_lambda): Use nonlambda_method_basetype.
      	(nonlambda_method_basetype): Handle NSDMI.
      
      From-SVN: r261101
      Jason Merrill committed
    • * g++.dg/cpp1z/feat-cxx1z.C: Update __cpp_deduction_guides. · 946d79a6
      From-SVN: r261100
      Jason Merrill committed
    • Commit 260294 on 2018-05-16 by Carl Love was supposed to add the following files. · 69311919
      gcc/testsuite/ChangeLog:
      
      2018-06-01  Carl Love  <cel@us.ibm.com>
      
      Commit 260294 on 2018-05-16 by Carl Love was supposed to add the
      following files.
      
      	* gcc.target/powerpc/vsx-vector-6-be.p7.c: New test file.
      	* gcc.target/powerpc/vsx-vector-6-be.p8.c: New test file.
      
      From-SVN: r261098
      Carl Love committed
    • altivec-12.c (main): Fix declaration of ucz to make it consistent with the… · fb289175
      altivec-12.c (main): Fix declaration of ucz to make it consistent with the naming convention in the file.
      
      gcc/testsuite/ChangeLog:
      
      2018-06-01  Carl Love  <cel@us.ibm.com>
      
      	* gcc.target/powerpc/altivec-12.c (main): Fix declaration of ucz
      	to make it consistent with the naming convention in the file.
      	* gcc.target/powerpc/altivec-7-be.c: Move BE specific checks
      	to altivec-7.c.  Delete file.
      	* gcc.target/powerpc/altivec-7-le.c: Move LE specific checks
      	to altivec-7.c.  Delete file.
      	* gcc.target/powerpc/altivec-7.h: Move to altivec-7.c.
      	* gcc.target/powerpc/altivec-7.c (main): Add vec_unpackh and
      	vec_unpackl tests.  Update instruction counts.
      	* gcc.target/powerpc/builtins-1-le.c: Move LE specific checks to
      	tests to builtins-1.c.
      	* gcc.target/powerpc/builtins-1-be.c: Move BE specific
      	tests to builtins-1.c.
      	* gcc.target/powerpc/builtins-1.h: Move to file builtins-1.c.
      	* gcc.target/powerpc/builtins-1.c (main): Add test case for vec_and.
      	vec_round, vec_rsqrt, vec_rsqrte, vec_mergee, vec_mergh, vec_mergo.
      	Remove vec_ctf tests returning double.  Remove vec_cts with
      	double args. Remove vec_sel with invalid arguments. Add tests for
      	vec_splat.
      	Add instruction counts for new tests.
      	* gcc.target/powerpc/builtins-3-runnable.c (main): Add test for
      	vec_doublee, vec_doubleo, vec_doublel, vec_doubleh, vec_signed,
      	vec_unsigned.
      	* gcc.target/powerpc/builtins-3.c: Add tests test_sll_vuill_vuill_vuc,
      	test_sll_vsill_vsill_vuc.
      	* gcc.target/powerpc/p9-xxbr-2.c (rev_bool_long_long): Added test for
      	vec_revb.
      	* gcc.target/powerpc/vsx-7.h: Rename to vsx-7.c. Remove redundant
      	tests from altivec-7.h.
      	* gcc.target/powerpc/vsx-7-be.c: Remove file.
      	* gcc.target/powerpc/vsx-builtin-7.c: Add test functions splat_sc_s8,
      	splat_uc_u8, splat_ssi_s16, splat_usi_s16, splat_si_s32, splat_ui_u32,
      	splat_sll, splat_uc, splat_int128, splat_uint128.
      	Make second argument of vec_extract and vec_insert a signed int.
      	* gcc.target/powerpc/vsx-vector-5.c (vrint): Add vrint test for float
      	argument.
      
      From-SVN: r261097
      Carl Love committed
    • Daily bump. · a2b8cef0
      From-SVN: r261096
      GCC Administrator committed
  4. 01 Jun, 2018 1 commit
    • DWARF5: Don't generate DW_AT_loclists_base for split compile unit DIEs. · 38a2b7ec
      The loclists_base attribute is used to point to the beginning of the
      loclists index of a DWARF5 loclists table when using DW_FORM_loclistsx.
      For split compile units the base is not given by the attribute, but is
      either the first (and only) index in the .debug_loclists.dwo section,
      or (when placed in a .dwp file) given by the DW_SECT_LOCLISTS row in
      the .debug_cu_index section.
      
      The loclists_base attribute is only valid for the full (or skeleton)
      compile unit DIE in the main (relocatable) object. But GCC only ever
      generates a loclists table index for the .debug_loclists section put
      into the split DWARF .dwo file.
      
      For split compile unit DIEs it is confusing (and not according to spec)
      to also have a DW_AT_loclists_base attribute (which might be wrong,
      since its relocatable offset won't actually be relocated).
      
      gcc/ChangeLog
      
      	* dwarf2out.c (dwarf2out_finish): Remove generation of
      	DW_AT_loclists_base.
      
      From-SVN: r261092
      Mark Wielaard committed