1. 28 Aug, 2019 24 commits
  2. 27 Aug, 2019 16 commits
    • PR tree-optimization/91567 - Spurious -Wformat-overflow warnings building glibc (32-bit only) · 407b92bc
      gcc/ChangeLog:
      
      	PR tree-optimization/91567
      	* gimple-ssa-sprintf.c (get_string_length): Handle more forms of lengths
      	of unknown strings.
      	* vr-values.c (vr_values::extract_range_basic): Set strlen upper bound
      	to PTRDIFF_MAX - 2.
      
      gcc/testsuite/ChangeLog:
      
      	PR tree-optimization/91567
      	* gcc.dg/tree-ssa/builtin-snprintf-6.c: Xfail a subset of assertions
      	on targets other than x86_64 to work around PR 83543.
      	* gcc.dg/tree-ssa/builtin-sprintf-warn-22.c: New test.
      
      From-SVN: r274976
      Martin Sebor committed
    • tree-ssa-strlen.c (printf_strlen_execute): Initialize the loop optimizer and… · 2d8ba441
      tree-ssa-strlen.c (printf_strlen_execute): Initialize the loop optimizer and SCEV before sizing ssa_ver_to_stridx.
      
      	* tree-ssa-strlen.c (printf_strlen_execute): Initialize
      	the loop optimizer and SCEV before sizing ssa_ver_to_stridx.
      
      	* gcc.c-torture/compile/20190827-1.c: New test.
      
      From-SVN: r274975
      Jeff Law committed
    • re PR fortran/91496 (!GCC$ directives error if mistyped or unknown) · 2bd86b95
      2019-08-27  Harald Anlauf  <anlauf@gmx.de>
      
      	PR fortran/91496
      	* gfortran.h: Extend struct gfc_iterator for loop annotations.
      	* array.c (gfc_copy_iterator): Copy loop annotations by IVDEP,
      	VECTOR, and NOVECTOR pragmas.
      	* decl.c (gfc_match_gcc_ivdep, gfc_match_gcc_vector)
      	(gfc_match_gcc_novector): New matcher functions handling IVDEP,
      	VECTOR, and NOVECTOR pragmas.
      	* match.h: Declare prototypes of matcher functions handling IVDEP,
      	VECTOR, and NOVECTOR pragmas.
      	* parse.c (decode_gcc_attribute, parse_do_block)
      	(parse_executable): Decode IVDEP, VECTOR, and NOVECTOR pragmas;
      	emit warning for unrecognized pragmas instead of error.
      	* trans-stmt.c (gfc_trans_simple_do, gfc_trans_do): Add code to
      	emit annotations for IVDEP, VECTOR, and NOVECTOR pragmas.
      	* gfortran.texi: Document IVDEP, VECTOR, and NOVECTOR pragmas.
      
      	PR fortran/91496
      	* gfortran.dg/pr91496.f90: New testcase.
      
      From-SVN: r274966
      Harald Anlauf committed
    • sse4_1-round-roundeven-1.c (dg-options): Add -mfpmath=sse. · 340d34bf
      	* gcc.target/i386/sse4_1-round-roundeven-1.c (dg-options):
      	Add -mfpmath=sse.
      	* gcc.target/i386/sse4_1-round-roundeven-2.c (dg-options): Ditto.
      
      From-SVN: r274964
      Uros Bizjak committed
    • re PR target/91528 (ICE in ix86_expand_prologue at i386.c:7844 since r274481) · c1441faf
      	PR target/91528
      	* config/i386/i386-features.c (convert_scalars_to_vector):
      	Update crtl->stack_realign_needed, crtl->stack_realign_tried and
      	crtl->stack_realign_processed.  Update crtl->drap_reg by calling
      	targetm.calls.get_drap_rtx.  If drap_rtx is non-null then
      	Update crtl->args.internal_arg_pointer and call fixup_tail_calls.
      
      testsuite/ChangeLog:
      
      	PR target/91528
      	* gcc.target/i386/pr91528.c: New test.
      
      From-SVN: r274962
      Uros Bizjak committed
    • re PR c++/83431 (-Wformat-truncation may incorrectly report truncation) · c8935981
      gcc/testsuite/ChangeLog:
      
      	PR c++/83431
      	PR testsuite/91562
      	* gcc.dg/strlenopt-8.c: Adjust pass/dump name.
      
      From-SVN: r274961
      Martin Sebor committed
    • Options documentation fixes. · f4436343
      Ensure that options lists fit cleanly inside the margins of a PDF page.
      Reword description of option -ffrontend-loop-interchange so that it fits
      cleanly inside the margins of a PDF page. Add options to those enabled
      by -fdec.
      
      From-SVN: r274958
      Mark Eggleston committed
    • libgo: rebuild runtime.inc if mkruntimeinc.sh changes · 433f84bf
          
          The Makefile was missing a dependency.
          
          Also remove runtime.inc.raw in mostlyclean.
          
          Reviewed-on: https://go-review.googlesource.com/c/gofrontend/+/191958
      
      From-SVN: r274956
      Ian Lance Taylor committed
    • Share a prevailing name for remove debug info symbols w/ LTO. · d23db385
      2019-08-27  Martin Liska  <mliska@suse.cz>
      
      	PR lto/91478
      	* simple-object-elf.c (simple_object_elf_copy_lto_debug_sections):
      	First find a WEAK HIDDEN symbol in symbol table that will be
      	preserved.  Later, use the symbol name for all removed symbols.
      
      From-SVN: r274955
      Martin Liska committed
    • 2019-08-27 Richard Biener <rguenther@suse.de> · b5a6addb
      	* config/i386/i386-features.h
      	(general_scalar_chain::~general_scalar_chain): Add.
      	(general_scalar_chain::insns_conv): New bitmap.
      	(general_scalar_chain::n_sse_to_integer): New.
      	(general_scalar_chain::n_integer_to_sse): Likewise.
      	(general_scalar_chain::make_vector_copies): Adjust signature.
      	* config/i386/i386-features.c
      	(general_scalar_chain::general_scalar_chain): Outline,
      	initialize new members.
      	(general_scalar_chain::~general_scalar_chain): New.
      	(general_scalar_chain::mark_dual_mode_def): Record insns
      	we need to insert conversions at and count them.
      	(general_scalar_chain::compute_convert_gain): Account
      	for conversion instructions at chain boundary.
      	(general_scalar_chain::make_vector_copies): Generate a single
      	copy for a def by a specific insn.
      	(general_scalar_chain::convert_registers): First populate
      	defs_map, then make copies at out-of chain insns.
      
      From-SVN: r274953
      Richard Biener committed
    • re PR c++/91415 (Invalid warning for C++17 sequencing of shift operator E1<<E2.) · 6a074892
      	PR c++/91415
      	* c-common.c (verify_tree): For LSHIFT_EXPR, RSHIFT_EXPR,
      	COMPONENT_REF and ARRAY_REF in cxx_dialect >= cxx17 mode handle it
      	like COMPOUND_EXPR rather than normal expression.
      
      	* g++.dg/warn/sequence-pt-4.C: New test.
      
      From-SVN: r274952
      Jakub Jelinek committed
    • re PR testsuite/91549 (gcc.dg/wrapped-binop-simplify.c fails starting with r274925) · 6c14d008
      PR testsuite/91549
      
      gcc/testsuite/ChangeLog:
      	* gcc.dg/wrapped-binop-simplify.c: Test only on x86, s390 with lp64.
      
      From-SVN: r274951
      Robin Dapp committed
    • re PR libgomp/91530 (Several libgomp.*/scan-* tests FAIL without avx_runtime) · 0ad7981c
      	PR libgomp/91530
      	* testsuite/libgomp.c/scan-11.c: Add -msse2 option for sse2_runtime
      	targets.
      	* testsuite/libgomp.c/scan-12.c: Likewise.
      	* testsuite/libgomp.c/scan-13.c: Likewise.
      	* testsuite/libgomp.c/scan-14.c: Likewise.
      	* testsuite/libgomp.c/scan-15.c: Likewise.
      	* testsuite/libgomp.c/scan-16.c: Likewise.
      	* testsuite/libgomp.c/scan-17.c: Likewise.
      	* testsuite/libgomp.c/scan-18.c: Likewise.
      	* testsuite/libgomp.c/scan-19.c: Likewise.
      	* testsuite/libgomp.c/scan-20.c: Likewise.
      	* testsuite/libgomp.c++/scan-9.C: Likewise.
      	* testsuite/libgomp.c++/scan-10.C: Likewise.
      	* testsuite/libgomp.c++/scan-11.C: Likewise.
      	* testsuite/libgomp.c++/scan-12.C: Likewise.
      	* testsuite/libgomp.c++/scan-14.C: Likewise.
      	* testsuite/libgomp.c++/scan-15.C: Likewise.
      	* testsuite/libgomp.c++/scan-13.C: Likewise.  Use sse2_runtime
      	instead of i?86-*-* x86_64-*-* as target for scan-tree-dump-times.
      	* testsuite/libgomp.c++/scan-16.C: Likewise.
      
      From-SVN: r274947
      Jakub Jelinek committed
    • [arm/aarch64] Add comments warning that stack-protector initializer insns shouldn't be split · a7e73b41
      Following the publication of https://kb.cert.org/vuls/id/129209/ I've
      been having a look at GCC's implementation for Arm and AArch64.  I
      haven't identified any issues yet, but it's a bit early to be
      completely sure.
      
      One observation, however, is that the instruction sequence that
      initializes the stack canary might be vulnerable to producing a
      reusable value if it were ever split early.  I don't think we ever
      would, because the memory locations involved with the stack protector
      are all marked volatile to ensure that the values are only loaded at
      the point in time when the test is intended to happen, and that also
      has the effect of making it unlikely that the value would be reused
      without reloading.  Nevertheless, defence in depth is probably
      warranted here.
      
      So this patch just adds some comments warning that the patterns should
      not be split.
      
      	* config/arm/arm.md (stack_protect_set_insn): Add security-related
      	comment.
      	* config/aarch64/aarch64.md (stack_protect_set_<mode>): Likewise.
      
      From-SVN: r274946
      Richard Earnshaw committed
    • Fix new clang warnings. · 72bb85f8
      2019-08-27  Martin Liska  <mliska@suse.cz>
      
      	* cgraph.c (cgraph_node::remove): Remove dead assignment before
      	loop.
      	* config/i386/i386-features.c (scalar_chain::emit_conversion_insns):
      	Enclose in anonymous namespace.
      	* config/i386/x86-tune-costs.h (struct processor_costs): Wrap
      	hard_register initialization in braces.
      	* tree-vrp.h (value_range_base::supports_type_p): Return false
      	for function with boolean return type.
      
      From-SVN: r274945
      Martin Liska committed
    • Daily bump. · e80f4068
      From-SVN: r274944
      GCC Administrator committed