1. 26 Apr, 2018 8 commits
    • Makefile.tpl (STAGE1_TFLAGS): Add -fno-checking. · ae05281f
      2018-04-26  Richard Biener  <rguenther@suse.de>
      
      	* Makefile.tpl (STAGE1_TFLAGS): Add -fno-checking.
      	(STAGE2_CFLAGS): Likewise.
      	(STAGE2_TFLAGS): Likewise.
      	(STAGE3_CFLAGS): Add -fchecking.
      	(STAGE3_TFLAGS): Likewise.
      	(STAGEtrain_CFLAGS): Filter out -fchecking.
      	(STAGEtrain_TFLAGS): Likewise.
      	* Makefile.in: Re-generate.
      
      From-SVN: r259669
      Richard Biener committed
    • tree-vect-data-refs.c (vect_get_data_access_cost): Get prologue cost vector and… · c76d9edb
      tree-vect-data-refs.c (vect_get_data_access_cost): Get prologue cost vector and pass it to vect_get_load_cost.
      
      2018-04-26  Richard Biener  <rguenther@suse.de>
      
      	* tree-vect-data-refs.c (vect_get_data_access_cost): Get
      	prologue cost vector and pass it to vect_get_load_cost.
      	(vect_get_peeling_costs_all_drs): Likewise.
      	(vect_peeling_hash_get_lowest_cost): Likewise.
      	(vect_enhance_data_refs_alignment): Likewise.
      
      From-SVN: r259668
      Richard Biener committed
    • re PR middle-end/85450 (ICE: invalid types in nop conversion during GIMPLE pass: ompexp) · bde84d51
      2018-04-26  Richard Biener  <rguenther@suse.de>
      
      	PR middle-end/85450
      	* tree-cfg.c (verify_gimple_assign_unary): Restore proper
      	checking of integer<->pointer conversions.
      	* omp-expand.c (expand_omp_for_static_nochunk): Avoid
      	sign-/zero-extending pointer types.
      	(expand_omp_for_static_chunk): Likewise.
      
      From-SVN: r259667
      Richard Biener committed
    • mips.c (mips_asan_shadow_offset): New function. · e9230659
      	* config/mips/mips.c (mips_asan_shadow_offset): New function.
      	(TARGET_ASAN_SHADOW_OFFSET): Define.
      	* config/mips/mips.h (FRAME_GROWS_DOWNWARD): Augment to also be
      	true for -fsanitize=address.
      
      Co-Authored-By: Jean Lee <xiaoyur347@gmail.com>
      
      From-SVN: r259666
      Hans-Peter Nilsson committed
    • If someone has access to a 64-bit mips-linux system to test this (with the… · 752361c9
      If someone has access to a 64-bit mips-linux system to test this (with the obvious edit), that'd be really nice.
      
      If someone has access to a 64-bit mips-linux system to test
      this (with the obvious edit), that'd be really nice.  Until
      then, best to not introduce possible build failures.
      
      	* configure.tgt <mips*-*-linux*>: Enable build, excluding
      	mips*64*-*-linux*.
      
      From-SVN: r259665
      Hans-Peter Nilsson committed
    • As mentioned in <http://gcc.gnu.org/ml/gcc/2018-03/msg00133.html> the bogus… · 9f943b24
      As mentioned in <http://gcc.gnu.org/ml/gcc/2018-03/msg00133.html> the bogus adjustment to 160 from 144 (which is reverted here)...
      
      As mentioned in <http://gcc.gnu.org/ml/gcc/2018-03/msg00133.html>
      the bogus adjustment to 160 from 144 (which is reverted here),
      is a single-token commit in upstream r301307, an attempt to
      correct a failed build due to an upstream change to compile the
      runtime with D_FILE_OFFSET_BITS=64.  The correct fix is here:
      just use the right include.  Yes, user-struct-stat64-as-stat is
      actually 160 for MIPS o32 and I hear user-struct-stat is also
      160 for n32.  There are additional fields appended for
      user-struct-stat!  I guess for MIPS it's as bad as it gets for
      mixing up kernel and user struct stat.  The context of the patch
      doesn't show that in the #else there's the correct include, the
      one for <asm/stat.h> to get the kernel-struct-stat.  If you
      can't compile it, IMHO the kernel headers are just too old; 3.2
      is fine for example.
      
      	* sanitizer_common/sanitizer_platform_limits_linux.cc: Do not
      	take the shortcut to #include <sys/stat.h> for MIPS instead of
      	the kernel <asm/stat.h>.  Explain why sys/stat.h is misleading
      	or wrong to get the kernel struct stat.
      	* sanitizer_common/sanitizer_platform_limits_posix.h [__mips__]:
      	Correct the value for 32-bit non-android struct_kernel_stat_sz.
      
      From-SVN: r259664
      Hans-Peter Nilsson committed
    • This appears to be present in compiler-rt upstream, but as part of more intrusive changes. · bc40f166
      This appears to be present in compiler-rt upstream, but as part
      of more intrusive changes.  For gcc, the lack of this results in
      a fatal warning (-Werror) at build-time.
      
      	* sanitizer_common/sanitizer_atomic_clang_other.h [_MIPS_SIM
      	&& _MIPS_SIM == _ABIO32] (lock): Add initializer for .pad member.
      
      From-SVN: r259663
      Hans-Peter Nilsson committed
    • Daily bump. · 3ce4730b
      From-SVN: r259662
      GCC Administrator committed
  2. 25 Apr, 2018 17 commits
  3. 24 Apr, 2018 15 commits
    • re PR fortran/85520 (Out of memory when declaring a character with len << 0) · 58da192e
      2018-04-24  Steven G. Kargl  <kargl@gcc.gnu.org>
      
      	PR fortran/85520
      	* decl.c (gfc_match_char_spec): Check for negative length and set to 0.
      
      2018-04-24  Steven G. Kargl  <kargl@gcc.gnu.org>
      
      	PR fortran/85520
      	* gfortran.dg/pr85520.f90: New test.
      
      From-SVN: r259623
      Steven G. Kargl committed
    • rs6000: Fix __powikf2 and __abskf2 spelling · 08417efa
      Both of these libfuncs had a "tkf" misspelling, which caused
      gcc.target/powerpc/pr85456.c to fail (there is no test for __abskf2).
      
      
      	* config/rs6000/rs6000.c (init_float128_ieee): Fix spelling mistakes
      	in __abskf2 and __powikf2.
      
      From-SVN: r259622
      Segher Boessenkool committed
    • x86: Update __CET__ check · ffc2fc06
      __CET__ has been changed by revision 259522:
      
      commit d59cfa9a4064339cf2bd2da828c4c133f13e57f0
      Author: hjl <hjl@138bc75d-0d04-0410-961f-82ee72b054a4>
      Date:   Fri Apr 20 13:30:13 2018 +0000
      
          Define __CET__ for -fcf-protection and remove -mibt
      
      to
      
          (__CET__ & 1) != 0: -fcf-protection=branch or -fcf-protection=full
          (__CET__ & 2) != 0: -fcf-protection=return or -fcf-protection=full
      
      We should check (__CET__ & 2) != 0 for shadow stack.
      
      libgcc/
      
      	* config/i386/linux-unwind.h: Add (__CET__ & 2) != 0 check
      	when including "config/i386/shadow-stack-unwind.h".
      
      libitm/
      
      	* config/x86/sjlj.S (_ITM_beginTransaction): Add
      	(__CET__ & 2) != 0 check for shadow stack.
      	(GTM_longjmp): Likewise.
      
      From-SVN: r259621
      H.J. Lu committed
    • x86/CET: Add -fcf-protection to STAGE4_CFLAGS · e59133c3
      Since profiledbootstrap uses
      
      STAGEfeedback_CFLAGS = $(STAGE4_CFLAGS) -fprofile-use
      
      add
      
      STAGE4_CFLAGS += -fcf-protection -mcet
      
      to bootstrap-cet.mk to support profiledbootstrap with CET.
      
      	PR bootstrap/85490
      	* bootstrap-cet.mk (STAGE4_CFLAGS): New.
      
      From-SVN: r259620
      H.J. Lu committed
    • [AArch64] PR target/85512: Tighten SIMD right shift immediate constraints · 0603375c
      In this testcase it is possible to generate an invalid SISD shift of zero:
      Error: immediate value out of range 1 to 64 at operand 3 -- `sshr v9.2s,v0.2s,0'
      
      The SSHR and USHR instructions require a shift from 1 up to the element size.
      However our constraints on the scalar shifts that generate these patterns
      allow a shift amount of zero as well. The pure GP-reg ASR and LSR instructions allow a shift amount of zero.
      
      It is unlikely that a shift of zero will survive till the end of compilation, but it's not impossible, as this PR shows.
      
      The patch tightens up the constraints in the offending patterns by adding two new constraints
      that allow shift amounts [1,32] and [1,64] and using them in *aarch64_ashr_sisd_or_int_<mode>3
      and *aarch64_lshr_sisd_or_int_<mode>3.
      The left-shift SISD instructions SHL and USHL allow a shift amount of zero so don't need adjustment
      The vector shift patterns that map down to SSHR and USHR already enforce the correct immediate range. 
      
              PR target/85512
              * config/aarch64/constraints.md (Usg, Usj): New constraints.
              * config/aarch64/iterators.md (cmode_simd): New mode attribute.
              * config/aarch64/aarch64.md (*aarch64_ashr_sisd_or_int_<mode>3):
              Use the above on operand 2.  Reindent.
              (*aarch64_lshr_sisd_or_int_<mode>3): Likewise.
      
              * gcc.dg/pr85512.c: New test.
      
      From-SVN: r259614
      Kyrylo Tkachov committed
    • x86/CET: Remove the -mcet command-lint option · 231baae2
      With revision 259496:
      
      commit b1384095a7c1d06a44b70853372ebe037b2f7867
      Author: hjl <hjl@138bc75d-0d04-0410-961f-82ee72b054a4>
      Date:   Thu Apr 19 15:15:04 2018 +0000
      
          x86: Enable -fcf-protection with multi-byte NOPs
      
      -fcf-protection no longer depens on -mcet and with revision 259522:
      
      commit d59cfa9a4064339cf2bd2da828c4c133f13e57f0
      Author: hjl <hjl@138bc75d-0d04-0410-961f-82ee72b054a4>
      Date:   Fri Apr 20 13:30:13 2018 +0000
      
          Define __CET__ for -fcf-protection and remove -mibt
      
      -mcet becomes an alias for -mshstk.  Since all usages of -mcet and
      -mno-cet have either been removed or replaced, we can remove the -mcet
      command-lint option.
      
      	PR target/85485
      	* common/config/i386/i386-common.c (ix86_handle_option): Don't
      	handle OPT_mcet.
      	* config/i386/i386.opt (mcet): Removed.
      	* doc/install.texi: Remove -mcet documentation.
      	* doc/invoke.texi: Likewise.
      
      From-SVN: r259613
      H.J. Lu committed
    • x86/CET tests: Remove -mcet/-mno-cet or replace -mcet with -mshstk · d16d033b
      With revision 259496:
      
      commit b1384095a7c1d06a44b70853372ebe037b2f7867
      Author: hjl <hjl@138bc75d-0d04-0410-961f-82ee72b054a4>
      Date:   Thu Apr 19 15:15:04 2018 +0000
      
          x86: Enable -fcf-protection with multi-byte NOPs
      
      -fcf-protection no longer depens on -mcet and with revision 259522:
      
      commit d59cfa9a4064339cf2bd2da828c4c133f13e57f0
      Author: hjl <hjl@138bc75d-0d04-0410-961f-82ee72b054a4>
      Date:   Fri Apr 20 13:30:13 2018 +0000
      
          Define __CET__ for -fcf-protection and remove -mibt
      
      -mcet becomes an alias for -mshstk.
      
      We can remove -mcet/-mno-cet where they are unused and replace -mcet
      with -mshstk where -mcet is used as an alias for -mshstk.
      
      	PR target/85485
      	* g++.dg/cet-notrack-1.C (dg-options): Remove -mcet.
      	* g++.dg/torture/pr85334.C (dg-additional-options): Likwise.
      	* gcc.dg/pr85388-1.c (dg-options): Likwise.
      	* gcc.dg/pr85388-2.c (dg-options): Likwise.
      	* gcc.dg/pr85388-3.c (dg-options): Likwise.
      	* gcc.dg/pr85388-4.c (dg-options): Likwise.
      	* gcc.dg/pr85388-5.c (dg-options): Likwise.
      	* gcc.dg/pr85388-6.c (dg-options): Likwise.
      	* gcc.dg/torture/pr85397-1.c (dg-additional-options): Likwise.
      	* gcc.target/i386/attr-nocf-check-1a.c (dg-options): Likwise.
      	* gcc.target/i386/attr-nocf-check-3a.c (dg-options): Likwise.
      	* gcc.target/i386/cet-label.c (dg-options): Likwise.
      	* gcc.target/i386/cet-label-2.c (dg-options): Likwise.
      	* gcc.target/i386/cet-notrack-1b.c (dg-options): Likwise.
      	* gcc.target/i386/cet-notrack-2a.c (dg-options): Likwise.
      	* gcc.target/i386/cet-notrack-2b.c (dg-options): Likwise.
      	* gcc.target/i386/cet-notrack-3.c (dg-options): Likwise.
      	* gcc.target/i386/cet-notrack-4b.c (dg-options): Likwise.
      	* gcc.target/i386/cet-notrack-5a.c (dg-options): Likwise.
      	* gcc.target/i386/cet-notrack-5b.c (dg-options): Likwise.
      	* gcc.target/i386/cet-notrack-6a.c (dg-options): Likwise.
      	* gcc.target/i386/cet-notrack-6b.c (dg-options): Likwise.
      	* gcc.target/i386/cet-notrack-7.c (dg-options): Likwise.
      	* gcc.target/i386/cet-notrack-icf-2.c (dg-options): Likwise.
      	* gcc.target/i386/cet-notrack-icf-4.c (dg-options): Likwise.
      	* gcc.target/i386/cet-property-1.c (dg-options): Likwise.
      	* gcc.target/i386/cet-property-2.c (dg-options): Likwise.
      	* gcc.target/i386/cet-sjlj-1.c (dg-options): Likwise.
      	* gcc.target/i386/cet-sjlj-2.c (dg-options): Likwise.
      	* gcc.target/i386/cet-sjlj-3.c (dg-options): Likwise.
      	* gcc.target/i386/cet-sjlj-4.c (dg-options): Likwise.
      	* gcc.target/i386/cet-sjlj-5.c (dg-options): Likwise.
      	* gcc.target/i386/cet-sjlj-6a.c (dg-options): Likwise.
      	* gcc.target/i386/cet-sjlj-6b.c (dg-options): Likwise.
      	* gcc.target/i386/cet-switch-1.c (dg-options): Likwise.
      	* gcc.target/i386/cet-switch-2.c (dg-options): Likwise.
      	* gcc.target/i386/cet-switch-3.c (dg-options): Likwise.
      	* gcc.target/i386/indirect-thunk-11.c (dg-options): Likwise.
      	* gcc.target/i386/indirect-thunk-12.c (dg-options): Likwise.
      	* gcc.target/i386/indirect-thunk-attr-12.c (dg-options): Likwise.
      	* gcc.target/i386/indirect-thunk-attr-13.c (dg-options): Likwise.
      	* gcc.target/i386/indirect-thunk-attr-14.c (dg-options): Likwise.
      	* gcc.target/i386/indirect-thunk-attr-15.c (dg-options): Likwise.
      	* gcc.target/i386/indirect-thunk-attr-16.c (dg-options): Likwise.
      	* gcc.target/i386/indirect-thunk-extern-8.c (dg-options): Likwise.
      	* gcc.target/i386/indirect-thunk-extern-9.c (dg-options): Likwise.
      	* gcc.target/i386/indirect-thunk-extern-10.c (dg-options): Likwise.
      	* gcc.target/i386/pr82659-1.c (dg-options): Likwise.
      	* gcc.target/i386/pr82659-2.c (dg-options): Likwise.
      	* gcc.target/i386/pr82659-3.c (dg-options): Likwise.
      	* gcc.target/i386/pr82659-4.c (dg-options): Likwise.
      	* gcc.target/i386/pr82659-5.c (dg-options): Likwise.
      	* gcc.target/i386/pr82659-6.c (dg-options): Likwise.
      	* gcc.target/i386/pr84146.c (dg-options): Likwise.
      	* gcc.target/i386/pr85403.c (dg-options): Likwise.
      	* gcc.target/i386/pr85404.c (dg-options): Likwise.
      	* gcc.target/i386/cet-intrin-3.c (dg-options): Replace -mcet
      	with -mshstk.
      	* gcc.target/i386/cet-intrin-5.c (dg-options): Likwise.
      	* gcc.target/i386/cet-intrin-6.c (dg-options): Likwise.
      	* gcc.target/i386/cet-intrin-7.c (dg-options): Likwise.
      	* gcc.target/i386/cet-intrin-8.c (dg-options): Likwise.
      	* gcc.target/i386/cet-intrin-9.c (dg-options): Likwise.
      	* gcc.target/i386/cet-intrin-10.c (dg-options): Likwise.
      	* gcc.target/i386/cet-rdssp-1.c (dg-options): Likwise.
      	* (dg-options): Likwise.
      	* gcc.target/i386/cet-notrack-1a.c (dg-options): Remove
      	-mno-cet.
      	* gcc.target/i386/cet-notrack-4a.c (dg-options): Likwise.
      	* gcc.target/i386/cet-label-3.c: Removed.
      	* gcc.target/i386/cet-property-3.c: Likwise.
      	* gcc.target/i386/cet-sjlj-7.c: Likwise.
      
      From-SVN: r259612
      H.J. Lu committed
    • Don't bootstrap GCC with -mcet · 48f64e05
      With revision 259496:
      
      commit b1384095a7c1d06a44b70853372ebe037b2f7867
      Author: hjl <hjl@138bc75d-0d04-0410-961f-82ee72b054a4>
      Date:   Thu Apr 19 15:15:04 2018 +0000
      
          x86: Enable -fcf-protection with multi-byte NOPs
      
      -fcf-protection no longer requires -mcet.
      
      config/
      
      	PR target/85485
      	* bootstrap-cet.mk (STAGE2_CFLAGS): Remove -mcet.
      	(STAGE3_CFLAGS): Likewise.
      
      gcc/
      
      	PR target/85485
      	* doc/install.texi: Remove -mcet from bootstrap-cet.
      
      From-SVN: r259611
      H.J. Lu committed
    • Regenerate configure of target libraries · 7b47ecf2
      	* configure: Regenerated.
      
      From-SVN: r259610
      H.J. Lu committed
    • re PR target/85511 ([X86] Using __builtin_ia32_writeeflags_u32 in 64-bit mode… · e8ac3359
      re PR target/85511 ([X86] Using __builtin_ia32_writeeflags_u32 in 64-bit mode causes internal compiler error)
      
      	PR target/85511
      	* config/i386/i386.c (ix86_init_mmx_sse_builtins): Don't define
      	__builtin_ia32_readeflags_u32 and __builtin_ia32_writeeflags_u32
      	if TARGET_64BIT.
      
      	* gcc.target/i386/pr85511.c: New test.
      
      From-SVN: r259609
      Jakub Jelinek committed
    • x86/CET: Build target libraries with -mshstk · 8624f868
      With revision 259522:
      
      commit d59cfa9a4064339cf2bd2da828c4c133f13e57f0
      Author: hjl <hjl@138bc75d-0d04-0410-961f-82ee72b054a4>
      Date:   Fri Apr 20 13:30:13 2018 +0000
      
          Define __CET__ for -fcf-protection and remove -mibt
      
      -mcet becomes an alias for -mshstk.
      
      	PR target/85485
      	* cet.m4 (GCC_CET_FLAGS): Replace -mcet with -mshstk.
      
      From-SVN: r259608
      H.J. Lu committed
    • re PR target/85503 (ICE in replace_swapped_load_constant, at… · c61199f2
      re PR target/85503 (ICE in replace_swapped_load_constant, at config/rs6000/rs6000-p8swap.c:1853 on powerpc64le-linux-gnu)
      
      	PR target/85503
      	* config/rs6000/rs6000-p8swap.c (const_load_sequence_p): Punt if
      	const_vector is not CONST_VECTOR or SYMBOL_REF for a constant pool
      	containing a CONST_VECTOR.
      
      	* g++.dg/ext/pr85503.C: New test.
      
      From-SVN: r259607
      Jakub Jelinek committed
    • Testsuite fixes for C++11 alignof change. · 7f3c03bf
      gcc/testsuite:
      	* c-c++-common/attr-aligned-1.c: Use __alignof__ in C++11.
      	* g++.dg/cpp0x/alignas4.C: Expect 4-byte alignment on x86.
      
      From-SVN: r259606
      Jason Merrill committed
    • [nvptx] Update newlib dependency. · 8ff02f96
      	gcc/
      	* doc/install.texi: Update newlib dependency for nvptx.
      
      From-SVN: r259596
      Cesar Philippidis committed
    • re PR target/85508 (runtime error in config/i386/i386.c) · 1704194a
      	PR target/85508
      	* config/i386/i386.c (ix86_expand_vector_init_one_var): Use UINTVAL
      	instead of INTVAL when shifting x left.
      
      	* gcc.target/i386/pr85508.c: New test.
      
      From-SVN: r259594
      Jakub Jelinek committed