1. 30 Apr, 2018 1 commit
  2. 29 Apr, 2018 3 commits
    • lto-partition.c: Include sreal.h · ddb0b824
      
      	* lto-partition.c: Include sreal.h
      	(add_symbol_to_partition_1): Use size instead of self_size
      	for size estimate.
      	(account_reference_p): New.
      	(lto_balanced_map): Use 64bit arithmetics for size calculatoins; cleanup;
      	fix accounting errors in boundary size; add debug output; combine cost
      	as cost/size instead of cost/internal; reduce the partitioning error to
      	+- 1/8 of the parttion size.
      
      From-SVN: r259749
      Jan Hubicka committed
    • [openacc, testsuite] Fix undefined behaviour in atomic_capture-1.c · 8d70b61e
      2018-04-29  Julian Brown  <julian@codesourcery.com>
      	    Tom de Vries  <tom@codesourcery.com>
      
      	PR testsuite/85527
      	* testsuite/libgomp.oacc-c-c++-common/atomic_capture-1.c: Allow
      	arbitrary order for iterations of atomic subtract check.
      
      Co-Authored-By: Tom de Vries <tom@codesourcery.com>
      
      From-SVN: r259748
      Julian Brown committed
    • Daily bump. · e7d32421
      From-SVN: r259747
      GCC Administrator committed
  3. 28 Apr, 2018 4 commits
    • DWARF: Add .debug_addr table header for dwarf_version >= 5. · 171b0a01
      GNU DebugFission didn't add table headers for the .debug_addr
      tables, but DWARF5 does. The table header makes it possible
      for a DWARF consumer to parse the address tables without having
      to index all .debug_info CUs first.
      
      We can keep using the .debug_addr section label as is, because the
      DW_AT_[GNU_]addr_base attribute points at the actual address index,
      which starts right after the table header. So the label is generated
      at the correct location whether the header is added first or not.
      
      Add DW_AT_addr_base instead of DW_AT_GNU_addr_base to the skeleton
      CU DIE for DWARF5.
      
      gcc/ChangeLog
      
      	* dwarf2out.c (dwarf2out_finish): Add .debug_addr table header for
      	dwarf_version >= 5.
      	(dwarf_AT): Handle DW_AT_addr_base.
      	(add_top_level_skeleton_die_attrs): Use dwarf_AT for DW_AT_addr_base.
      
      From-SVN: r259743
      Mark Wielaard committed
    • re PR target/84431 (Suboptimal code for masked shifts (x86/x86-64)) · 6754dfa2
      	PR target/84431
      	* config/i386/i386.md (*ashl<dwi>3_doubleword_mask): New pattern.
      	(*ashl<dwi>3_doubleword_mask_1): Ditto.
      	(*<shift_insn><dwi>3_doubleword_mask): Ditto.
      	(*<shift_insn><dwi>3_doubleword_mask_1): Ditto.
      
      testsuite/ChangeLog:
      
      	PR target/84431
      	* gcc.target/i386/pr84431.c: New test.
      
      From-SVN: r259739
      Uros Bizjak committed
    • tree-cfg.c (verify_gimple_phi): Take a gphi * argument. · 782e4764
      2018-04-28  Richard Biener  <rguenther@suse.de>
      
      	* tree-cfg.c (verify_gimple_phi): Take a gphi * argument.
      	(verify_gimple_in_cfg): Rename visited_stmts to visited_throwing_stmts
      	to reflect use.  Only add interesting stmts.
      
      From-SVN: r259738
      Richard Biener committed
    • Daily bump. · 5c2cab46
      From-SVN: r259737
      GCC Administrator committed
  4. 27 Apr, 2018 23 commits
  5. 26 Apr, 2018 9 commits
    • MIPS/GCC/testsuite: Fix data-sym-pool.c for n64 code · b4d62b40
      With the soft-float n64 ABI and the data-sym-pool.c test case code like 
      below is produced:
      
      	.file	1 "data-sym-pool.c"
      	.section .mdebug.abi64
      	.previous
      	.nan	legacy
      	.module	softfloat
      	.module	oddspreg
      	.abicalls
      	.option	pic0
      	.text
      	.align	2
      	.globl	frob
      	.set	mips16
      	.set	nomicromips
      	.ent	frob
      	.type	frob, @function
      frob:
      	.frame	$17,16,$31		# vars= 0, regs= 1/0, args= 0, gp= 0
      	.mask	0x00020000,-8
      	.fmask	0x00000000,0
      	daddiu	$sp,-16
      	sd	$17,8($sp)
      	move	$17,$sp
      	ld	$2,.L3
      	move	$sp,$17
      	ld	$17,8($sp)
      	daddiu	$sp,16
      	jr	$31
      	.type	__pool_frob_3, @object
      __pool_frob_3:
      	.align	3
      .L3:
      	.dword	305419896
      	.type	__pend_frob_3, @function
      __pend_frob_3:
      	.insn
      	.end	frob
      	.size	frob, .-frob
      	.ident	"GCC: (GNU) 8.0.1 20180410 (experimental)"
      
      (we have no support for hard-float n64 MIPS16 code generation), which 
      means that the test case will fail, as the regular expression pattern 
      expects `lw' and `.word' rather than `ld' and `.dword' respectively to 
      appear in assembly code generation.  Correct the pattern in an obvious 
      way then making it accept both intructions and pseudo-ops.
      
      	gcc/testsuite/
      	* gcc.target/mips/data-sym-pool.c (dg-options): Match `ld' and
      	`.dword' in addition to `lw' and `.word'.
      
      From-SVN: r259691
      Maciej W. Rozycki committed
    • MIPS/GCC/testsuite: Fix data-sym-pool.c for SVR4 model at -O0 · 7dc5410a
      With GCC configurations using the SVR4 rather than the PLT dynamic 
      executable model and the o32 ABI with the data-sym-pool.c test case code 
      like below is produced:
      
      	.file	1 "data-sym-pool.c"
      	.section .mdebug.abi32
      	.previous
      	.nan	legacy
      	.module	fp=xx
      	.module	nooddspreg
      	.abicalls
      	.text
      	.align	2
      	.globl	frob
      	.set	mips16
      	.set	nomicromips
      	.ent	frob
      	.type	frob, @function
      frob:
      	.frame	$17,8,$31		# vars= 0, regs= 1/0, args= 0, gp= 0
      	.mask	0x00020000,-4
      	.fmask	0x00000000,0
      	save	8,$17
      	move	$17,$sp
      	lw	$2,$L4
      	move	$sp,$17
      	restore	8,$17
      	jr	$31
      	.type	__pool_frob_3, @object
      __pool_frob_3:
      	.align	2
      $L3:
      	.word	__gnu_local_gp
      $L4:
      	.word	305419896
      	.type	__pend_frob_3, @function
      __pend_frob_3:
      	.insn
      	.end	frob
      	.size	frob, .-frob
      	.ident	"GCC: (GNU) 8.0.1 20180410 (experimental)"
      
      causing a failure due to the unexpected `__gnu_local_gp' entry in the 
      constant pool, even though there is nothing wrong with it as far as the 
      annotation being examined is concerned.
      
      Given that the SVR4 vs PLT code model consideration is irrelevant for 
      this test case rather than rewriting the regular expression to match 
      this variant of code just enforce the PLT model by using the `-mplt' 
      option.  It is safe to use this option unconditionally as it is silently 
      ignored with configurations that do not support this model, e.g. bare 
      metal ELF.
      
      	gcc/testsuite/
      	* gcc.target/mips/data-sym-pool.c (dg-options): Add `-mplt'.
      
      From-SVN: r259690
      Maciej W. Rozycki committed
    • PR c++/85545 - ICE with noexcept PMF conversion. · 128d29a5
      	* cvt.c (cp_fold_convert): Handle PMF CONSTRUCTORs directly.
      
      From-SVN: r259689
      Jason Merrill committed
    • cgraph.h (symbol_table): Just declare debug method here. · e94497fb
      	* cgraph.h (symbol_table): Just declare debug method here.
      	* symtab.c (symbol_table::debug): Define.
      
      Co-Authored-By: Jakub Jelinek <jakub@redhat.com>
      
      From-SVN: r259685
      Richard Biener committed
    • i386.md ("isa" attribute): Add x64_sse2. · b1ea8387
      	* config/i386/i386.md ("isa" attribute): Add x64_sse2.
      	("enabled" attribute): Handle "isa" attribute.
      	(*movdi_internal): Substitute Yi and Yj constraint with x
      	and Ym and Yn constraint with y constraint.  Update "isa"
      	attribute and set "preferred_for_speed" attribute from
      	TARGET_INTER_UNIT_MOVES_{FROM,TO}_VEC for updated alternatives.
      	(*movsi_internal): Ditto.
      	(*movdf_internal): Ditto.
      	(*movsf_internal): Ditto.
      	(*zero_extendsidi2): Ditto.
      	* config/i386/sse.md (vec_set<mode>_0): Ditto.
      	(sse2_loadld): Ditto.
      	(*vec_extract<ssevecmodelower>_0): Ditto.
      	(*vec_extractv4si_0_zext_sse4): Ditto.
      	(vec_concatv2di): Ditto.
      	(*vec_dup<mode>): Ditto.
      	* config/i386/mmx.md (*mov<mode>_internal): Ditto.
      	* config/i386/constraints.md (Yi): Remove.
      	(Yj): Remove.
      	(Ym): Remove.
      	(Yn): Remove.
      
      From-SVN: r259682
      Uros Bizjak committed
    • dumpfile cleanup · 5d8b352a
      https://gcc.gnu.org/ml/gcc-patches/2018-04/msg01173.html
      	* dumpfile.c (dump_open): New.
      	(dump_open_alternate_stream, dump_start, dump_begin): Call it.
      	(dump_finish): Detect stdio/stderr by value not name.
      
      From-SVN: r259681
      Nathan Sidwell committed
    • Document that -Wreturn-type is enabled by default for C++ · 030b3bdd
      	* doc/invoke.texi (-Wreturn-type): Document default status for C++.
      
      From-SVN: r259679
      Jonathan Wakely committed
    • [nvptx, libgomp] Add GOMP_NVPTX_JIT=-O[0-4] in nvptx libgomp plugin · df36a3d3
      2018-04-26  Tom de Vries  <tom@codesourcery.com>
      
      	PR libgomp/84020
      	* plugin/cuda/cuda.h (CUjit_option): Add CU_JIT_OPTIMIZATION_LEVEL.
      	* plugin/plugin-nvptx.c (_GNU_SOURCE): Define.
      	(process_GOMP_NVPTX_JIT): New function.
      	(link_ptx): Use process_GOMP_NVPTX_JIT.
      
      From-SVN: r259678
      Tom de Vries committed