1. 24 Apr, 2018 5 commits
  2. 23 Apr, 2018 10 commits
  3. 22 Apr, 2018 10 commits
  4. 21 Apr, 2018 2 commits
  5. 20 Apr, 2018 13 commits
    • PR c/85365 - -Wrestrict false positives with -fsanitize=undefined · 8cd95cec
      gcc/ChangeLog:
      
      	PR c/85365
      	* gimple-fold.c (gimple_fold_builtin_strcpy): Suppress -Wrestrict
      	for null pointers.
      	(gimple_fold_builtin_stxcpy_chk): Same.
      	* gimple-ssa-warn-restrict.c (check_bounds_or_overlap): Same.
      
      gcc/testsuite/ChangeLog:
      
      	PR c/85365
      	* gcc.dg/Wrestrict-15.c: New test.
      
      From-SVN: r259535
      Martin Sebor committed
    • re PR target/85456 (PowerPC: Using -mabi=ieeelongdouble calls wrong function for __builtin_powi.) · 661eb8f9
      [libgcc]
      2018-04-20  Michael Meissner  <meissner@linux.ibm.com>
      
      	PR target/85456
      	* config/rs6000/_powikf2.c: New file.  Add support for the
      	__builtin_powil function when long double is IEEE 128-bit floating
      	point.
      	* config/rs6000/float128-ifunc.c (__powikf2_resolve): Add
      	__powikf2 support.
      	(__powikf2): Likewise.
      	* config/rs6000/quad-float128.h (__powikf2_sw): Likewise.
      	(__powikf2_hw): Likewise.
      	(__powikf2): Likewise.
      	* config/rs6000/t-float128 (fp128_ppc_funcs): Likewise.
      	* config/rs6000/t-float128-hw (fp128_hw_func): Likewise.
      	(_powikf2-hw.c): Likewise.
      
      [gcc]
      2018-04-20  Michael Meissner  <meissner@linux.ibm.com>
      
      	PR target/85456
      	* config/rs6000/rs6000.c (init_float128_ieee): Add support to call
      	__powikf2 when long double is IEEE 128-bit.
      
      [gcc/testsuite]
      2018-04-20  Michael Meissner  <meissner@linux.ibm.com>
      
      	PR target/85456
      	* gcc.target/powerpc/pr85456.c: New test.
      
      From-SVN: r259533
      Michael Meissner committed
    • undef-bool-1.C: Require lp64. · 8833e667
      [gcc/testsuite]
      
      2018-04-20  Bill Schmidt  <wschmidt@linux.ibm.com>
      
      	* g++.dg/ext/undef-bool-1.C: Require lp64.
      	* gcc.target/powerpc/undef-bool-2.c: Likewise.
      
      From-SVN: r259532
      Bill Schmidt committed
    • RISC-V: Make sure stack is always aligned during adjusting stack. · 9b922d6a
      	gcc/
      	2018-04-20  Kito Cheng  <kito.cheng@gmail.com>
      	* config/riscv/riscv.c (riscv_first_stack_step): Round up min
      	step to make sure stack always aligned.
      
      From-SVN: r259530
      Kito Cheng committed
    • stack-check-5.c: Improve dg-skip-if selector for the stack protector. · b593a195
             * gcc.dg/stack-check-5.c: Improve dg-skip-if selector for the
              stack protector.
              * gcc.dg/stack-check-6.c: Likewise.
              * gcc.dg/stack-check-6a.c: Likewise.
              * gcc.target/i386/stack-check-17.c: Add dg-skip-if selector.
              * gcc.target/i386/stack-check-18.c: Likewise.
              * gcc.target/i386/stack-check-19.c: Likewise.
      
      From-SVN: r259528
      Jeff Law committed
    • Fix missing hunk from previous commit · f04fb28e
      From-SVN: r259527
      Kyrylo Tkachov committed
    • PR testsuite/85483: Move aarch64/sve/vcond_1.c test to g++.dg/other/ · db994ead
      I totally botched up this sve test file in 259437.
      It needs C++, so move it to g++.dg/other and make it a .C file.
      Also adds the target guards to prevent it from running on non-aarch64 targets.
      
      Tested that it passes on aarch64-none-elf and doesn't get run on arm-none-eabi.
      
      Committing to trunk as obvious.
      
      	PR testsuite/85483
      	* gcc.target/aarch64/sve/vcond_1.c: Move to...
      	* g++.dg/other/sve_vcond_1.C: ... Here.  Add target directives.
      	* gcc.target/aarch64/sve/vcond_1_run.c: Move to...
      	* g++.dg/other/sve_vcond_1_run.C: ... Here.  Change include file name.
      
      From-SVN: r259526
      Kyrylo Tkachov committed
    • re PR target/83402 (PPC64 implementation of ./rs6000/emmintrin.h gives out of… · a3b82e15
      re PR target/83402 (PPC64 implementation of ./rs6000/emmintrin.h gives out of range for _mm_slli_epi32)
      
      
      gcc/ChangeLog:
      
      2018-04-20  Carl Love  <cel@us.ibm.com>
      
              PR target/83402
              * config/rs6000/rs6000-c.c (rs6000_gimple_fold_builtin): Add
              size check for arg0.
      
      From-SVN: r259524
      Carl Love committed
    • [nvptx] Fix calls to vector and worker routines · e91eba31
      2018-04-20  Nathan Sidwell  <nathan@codesourcery.com>
      	    Tom de Vries  <tom@codesourcery.com>
      
      	PR target/85445
      	* config/nvptx/nvptx.c (nvptx_emit_forking, nvptx_emit_joining):
      	Emit insns for calls too.
      	(nvptx_find_par): Always look for worker-level predecessor insn.
      	(nvptx_propagate): Add is_call parm, return bool.  Copy frame for
      	calls.
      	(nvptx_vpropagate, nvptx_wpropagate): Adjust.
      	(nvptx_process_pars): Propagate frames for calls.
      
      	* testsuite/libgomp.oacc-c++/ref-1.C: New.
      
      Co-Authored-By: Tom de Vries <tom@codesourcery.com>
      
      From-SVN: r259523
      Nathan Sidwell committed
    • Define __CET__ for -fcf-protection and remove -mibt · e95dda95
      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
      
      -mibt does nothing and can be removed.  Define __CET__ to indicate level
      protection with -fcf-protection:
      
      (__CET__ & 1) != 0: -fcf-protection=branch or -fcf-protection=full
      (__CET__ & 2) != 0: -fcf-protection=return or -fcf-protection=full
      
      gcc/
      
      	PR target/85469
      	* common/config/i386/i386-common.c (OPTION_MASK_ISA_IBT_SET):
      	Removed.
      	(OPTION_MASK_ISA_IBT_UNSET): Likewise.
      	(ix86_handle_option): Don't handle OPT_mibt.
      	* config/i386/cet.h: Check __CET__ instead of __IBT__ and
      	__SHSTK__.
      	* config/i386/driver-i386.c (host_detect_local_cpu): Remove
      	has_ibt and ibt.
      	* config/i386/i386-c.c (ix86_target_macros_internal): Don't
      	check OPTION_MASK_ISA_IBT nor flag_cf_protection.
      	(ix86_target_macros): Define __CET__ with flag_cf_protection
      	for -fcf-protection.
      	* config/i386/i386.c (isa2_opts): Remove -mibt.
      	* config/i386/i386.h (TARGET_IBT): Removed.
      	(TARGET_IBT_P): Likewise.
      	(ix86_valid_target_attribute_inner_p): Don't check OPT_mibt.
      	* config/i386/i386.md (nop_endbr): Don't check TARGET_IBT.
      	* config/i386/i386.opt (mcet): Update help message.
      	(mshstk): Likewise.
      	(mibt): Removed.
      	* doc/invoke.texi: Remove -mibt.  Document __CET__.  Document
      	-mcet as an alias for -mshstk.
      
      gcc/testsuite/
      
      	PR target/85469
      	* gcc.target/i386/pr85044.c (dg-options): Remove -mibt.
      	* gcc.target/i386/sse-26.c (dg-options): Remove -mno-ibt.
      
      From-SVN: r259522
      H.J. Lu committed
    • Do not overflow string buffer (PR objc/85476). · fffefbf8
      2018-04-20  Martin Liska  <mliska@suse.cz>
      
      	PR objc/85476
      	* objc-act.c (finish_class): Do not overflow string buffer.
      
      From-SVN: r259521
      Martin Liska committed
    • re PR tree-optimization/85475 (Compile time hog w/ -O1 -fpeel-loops) · b46ebc6c
      2018-04-20  Richard Biener <rguenther@suse.de>
      
      	PR middle-end/85475
      	* match.pd ((X * CST) * Y -> (X * Y) * CST): Avoid exponential
      	complexity by forcing a single use of the multiply operand.
      
      	* gcc.dg/torture/pr85475.c: New testcase.
      
      From-SVN: r259519
      Richard Biener committed