1. 23 Jun, 2017 21 commits
    • Testcase for FSF GCC bug 79794. · d3f062be
      	gcc/testsuite/
      	PR middle-end/79794
      	* gcc.target/aarch64/pr79794.c: New.
      
      From-SVN: r249612
      Jim Wilson committed
    • runtime: complete defer handling in CgocallBackDone · f1857c63
          
          When C code calls a Go function, it actually calls a function
          generated by cgo. That function is written in Go, and, among other
          things, it calls the real Go function like this:
                  CgocallBack()
                  defer CgocallBackDone()
                  RealGoFunction()
          The deferred CgocallBackDone function enters syscall mode as we return
          to C. Typically the C function will then eventually return to Go.
          
          However, in the case where the C function is running on a thread
          created in C, it will not return to Go. For that case we will have
          allocated an m struct, with an associated g struct, for the duration
          of the Go code, and when the Go is complete we will return the m and g
          to a free list.
          
          That all works, but we are running in a deferred function, which means
          that we have been invoked by deferreturn, and deferreturn expects to
          do a bit of cleanup to record that the defer has been completed. Doing
          that cleanup while using an m and g that have already been returned to
          the free list is clearly a bad idea. It was kind of working because
          deferreturn was holding the g pointer in a local variable, but there
          were races with some other thread picking up and using the newly freed g.
          It was also kind of working because of a special check in freedefer;
          that check is no longer necessary.
          
          This patch changes the special case of releasing the m and g to do the
          defer cleanup in CgocallBackDone itself.
          
          This patch also checks for the special case of a panic through
          CgocallBackDone. In that special case, we don't want to release the m
          and g. Since we are returning to C code that was not called by Go
          code, we know that the panic is not going to be caught and we are
          going to exit the program. So for that special case we keep the m and
          g structs so that the rest of the panic code can use them.
          
          Reviewed-on: https://go-review.googlesource.com/46530
      
      From-SVN: r249611
      Ian Lance Taylor committed
    • rs6000-string.c: (expand_block_clear... · 8845cb37
      2017-06-23  Aaron Sawdey  <acsawdey@linux.vnet.ibm.com>
      
      	* config/rs6000/rs6000-string.c: (expand_block_clear,
      	do_load_for_compare, select_block_compare_mode,
      	compute_current_alignment, expand_block_compare,
      	expand_strncmp_align_check, expand_strn_compare,
      	expand_block_move, rs6000_output_load_multiple)
      	Move functions related to string/block move/compare
      	to a separate file.
      	* config/rs6000/rs6000.c: Move above functions to rs6000-string.c.
      	* config/rs6000/rs6000-protos.h (rs6000_emit_dot_insn): Add prototype
      	for this function which is now used in two files.
      	* config/rs6000/t-rs6000: Add rule to compile rs6000-string.o.
      	* config.gcc: Add rs6000-string.o to extra_objs for
      	targets powerpc*-*-* and rs6000*-*-*.
      
      From-SVN: r249608
      Aaron Sawdey committed
    • re PR target/80510 (Optimize Power7/power8 Altivec load/stores) · 37416b69
      [gcc]
      2017-06-23  Michael Meissner  <meissner@linux.vnet.ibm.com>
      
      	PR target/80510
      	* config/rs6000/rs6000.md (ALTIVEC_DFORM): Do not allow DImode in
      	32-bit, since indexed is not valid for DImode.
      	(mov<mode>_hardfloat32): Reorder ISA 2.07 load/stores before ISA
      	3.0 d-form load/stores to be the same as mov<mode>_hardfloat64.
      	(define_peephole2 for Altivec d-form load): Add 32-bit support.
      	(define_peephole2 for Altivec d-form store): Likewise.
      
      [gcc/testsuite]
      2017-06-23  Michael Meissner  <meissner@linux.vnet.ibm.com>
      
      	PR target/80510
      	* gcc.target/powerpc/pr80510-1.c: Allow test to run on 32-bit.
      	* gcc.target/powerpc/pr80510-2.c: Likewise.
      
      From-SVN: r249607
      Michael Meissner committed
    • re PR ipa/81185 (Target clones support generates awkward names) · 9761349c
      2017-06-23  Michael Meissner  <meissner@linux.vnet.ibm.com>
      
      	PR ipa/81185
      	* multiple_target.c (create_dispatcher_calls): Only create the
      	dispatcher call if the function is the default clone of a
      	versioned function.
      
      From-SVN: r249605
      Michael Meissner committed
    • trans.c (gnat_to_gnu): Initialize sync to false to avoid UB. · aa9ace3e
      	* gcc-interface/trans.c (gnat_to_gnu): Initialize sync to false to
      	avoid UB.
      
      From-SVN: r249604
      Jakub Jelinek committed
    • Fix expand_builtin_atomic_fetch_op for pre-op (PR80902) · 08c273bb
      __atomic_add_fetch adds a value to some memory, and returns the result.
      If there is no direct support for this, expand_builtin_atomic_fetch_op
      is asked to implement this as __atomic_fetch_add (which returns the
      original value of the mem), followed by the addition.  Now, the
      __atomic_add_fetch could have been a tail call, but we shouldn't
      perform the __atomic_fetch_add as a tail call: following code would
      not be executed, and in fact thrown away because there is a barrier
      after tail calls.
      
      This fixes it.
      
      
      	PR middle-end/80902
      	* builtins.c (expand_builtin_atomic_fetch_op): If emitting code after
      	a call, force the call to not be a tail call.
      
      From-SVN: r249603
      Segher Boessenkool committed
    • os-unix-sysdep.c (__cilkrts_getticks): Adjust preprocessor test for SPARC/Linux. · eded3fe5
      	* runtime/config/sparc/os-unix-sysdep.c (__cilkrts_getticks): Adjust
      	preprocessor test for SPARC/Linux.
      	* runtime/jmpbuf.h (CILK_[UN]ADJUST_SP): Likewise.
      
      From-SVN: r249601
      Eric Botcazou committed
    • os: align siginfo argument to waitid · 3c76bd92
          
          Backport https://golang.org/cl/46511 from gc trunk, as it may fix a
          bug reported for gccgo running on MIPS
          (https://groups.google.com/d/msg/golang-dev/sDg-t1_DPw0/-AJmLxgPBQAJ).
          
          Reviewed-on: https://go-review.googlesource.com/46571
      
      From-SVN: r249599
      Ian Lance Taylor committed
    • runtime: don't crash if no p in kickoff · bb96aa67
          
          The kickoff function for g0 can be invoked without a p, for example
          from mcall(exitsyscall0) in exitsyscall after exitsyscall has cleared
          the p field. The assignment gp.param = nil will invoke a write barrier.
          If gp.param is not already nil, this will require a p. Avoid the problem
          for a specific case that is known to be OK: when the value in gp.param
          is a *g.
          
          Reviewed-on: https://go-review.googlesource.com/46512
      
      From-SVN: r249595
      Ian Lance Taylor committed
    • compiler: add go:notinheap magic comment · 5f0b897b
          
          Implement go:notinheap as the gc compiler does. A type marked as
          go:notinheap may not live in the heap, and does not require a write
          barrier. Struct and array types that incorporate notinheap types are
          themselves notinheap. Allocating a value of a notinheap type on the
          heap is an error.
          
          This is not just an optimization. There is code where a write barrier
          may not occur that was getting a write barrier with gccgo but not gc,
          because the types in question were notinheap. The case I found was
          setting the mcache field in exitsyscallfast.
          
          Reviewed-on: https://go-review.googlesource.com/46490
      
      From-SVN: r249594
      Ian Lance Taylor committed
    • contrib.texi: Add entry for Steven Pemberton's work on enquire. · ef2361cb
      	* doc/contrib.texi: Add entry for Steven Pemberton's work on
      	enquire.
      
      From-SVN: r249593
      Jeff Law committed
    • rs6000.c: Add include of ssa-propagate.h for update_call_from_tree(). · 52607f7e
      [gcc]
      
      2017-06-23  Will Schmidt  <will_schmidt@vnet.ibm.com>
      
      	* config/rs6000/rs6000.c: Add include of ssa-propagate.h for
      	update_call_from_tree().  (rs6000_gimple_fold_builtin): Add
      	handling for early expansion of vector shifts (sl,sr,sra,rl).
      	(builtin_function_type): Add vector shift right instructions
      	to the unsigned argument list.
      
      [gcc/testsuite]
      
      2017-06-23  Will Schmidt  <will_schmidt@vnet.ibm.com>
      
      	* gcc.target/powerpc/fold-vec-shift-char.c: New.
      	* gcc.target/powerpc/fold-vec-shift-int.c: New.
      	* gcc.target/powerpc/fold-vec-shift-longlong.c: New.
      	* gcc.target/powerpc/fold-vec-shift-short.c: New.
      	* gcc.target/powerpc/fold-vec-shift-left.c: New.
      	* gcc.target/powerpc/fold-vec-shift-left-fwrapv.c: New.
      	* gcc.target/powerpc/fold-vec-shift-left-longlong-fwrapv.c: New.
      	* gcc.target/powerpc/fold-vec-shift-left-longlong.c: New.
      
      From-SVN: r249591
      Will Schmidt committed
    • runtime: improve handling of panic during deferred function · 54357b3b
          
          When a panic occurs while processing a deferred function that
          recovered an earlier panic, we shouldn't report the recovered panic
          in the panic stack trace. Stop doing so by keeping track of the panic
          that triggered a defer, marking it as aborted if we see the defer again,
          and discarding aborted panics when a panic is recovered. This is what
          the gc runtime does.
          
          The test for this is TestRecursivePanic in runtime/crash_test.go.
          We don't run that test yet, but we will soon.
          
          Reviewed-on: https://go-review.googlesource.com/46461
      
      From-SVN: r249590
      Ian Lance Taylor committed
    • go-test.exp (go-set-goarch): Update MIPS architecture names. · fb68f296
      	* go.test/go-test.exp (go-set-goarch): Update MIPS architecture
              names.
      
      From-SVN: r249589
      James Cowgill committed
    • ira.c (update_equiv_regs): Revert to using may_trap_or_fault_p again. · 08f42414
      2017-06-23  Bernd Edlinger  <bernd.edlinger@hotmail.de>
      
              rtl-optimizatoin/79286
              * ira.c (update_equiv_regs): Revert to using may_trap_or_fault_p again.
              * rtlanal.c (rtx_addr_can_trap_p_1): SYMBOL_REF_FUNCTION_P can never
              trap.  PIC register plus a const unspec without offset can never trap.
      
      From-SVN: r249588
      Bernd Edlinger committed
    • Refactor fileptr_type_node handling · 2db9b7cd
      2017-06-23  Marc Glisse  <marc.glisse@inria.fr>
      
      gcc/
      	* tree.h (builtin_structptr_type): New type.
      	(builtin_structptr_types): Declare new array.
      	* tree.c (builtin_structptr_types): New array.
      	(free_lang_data, build_common_tree_nodes): Use it.
      
      gcc/c-family/
      	* c-common.c (c_common_nodes_and_builtins): Use builtin_structptr_types.
      
      gcc/cp/
      	* decl.c (duplicate_decls): Use builtin_structptr_types.
      
      gcc/lto/
      	* lto-lang.c (lto_init): Use builtin_structptr_types.
      
      From-SVN: r249585
      Marc Glisse committed
    • PR c++/81187 fix -Wnoexcept-type entry in manual · 70fdc808
      	PR c++/81187
      	* doc/invoke.texi (-Wnoexcept-type): Fix name of option, from
      	-Wnoexcept.
      
      From-SVN: r249584
      Jonathan Wakely committed
    • Daily bump. · 3e207313
      From-SVN: r249583
      GCC Administrator committed
  2. 22 Jun, 2017 19 commits
    • runtime: uncomment check for gchelper on g0 stack · c8a0d1c3
          
          Now that systemstack changes to the g0 stack, this check passes.
          
          Reviewed-on: https://go-review.googlesource.com/46460
      
      From-SVN: r249578
      Ian Lance Taylor committed
    • runtime: mark dropm and callees nowritebarrierrec · b34391e0
          
          The CgocallbackDone function calls dropm after it calls entersyscall,
          which means that dropm must not have any write barriers. Mark it
          accordingly.
          
          Reviewed-on: https://go-review.googlesource.com/46464
      
      From-SVN: r249577
      Ian Lance Taylor committed
    • runtime: export getm function · f384e12a
          
          Use go:linkname to export the getm function. This makes it visible to
          runtime/testdata/testprogcgo/dropm_stub.go, which uses it as part of
          the TestEnsureDropM test in runtime/crash_cgo_test.go. That test is
          not run today, but it will be soon.
          
          Reviewed-on: https://go-review.googlesource.com/46462
      
      From-SVN: r249576
      Ian Lance Taylor committed
    • runtime: fix type cast in assignment to gcnextsp in C code · 61fbdfbe
          
          Patch from Rainer Orth.
          
          Reviewed-on: https://go-review.googlesource.com/46459
      
      From-SVN: r249575
      Ian Lance Taylor committed
    • driver-i386.c (host_detect_local_cpu): Add Kaby Lake models to skylake case. · 60edf8bb
      gcc/
      
      2017-06-22  Matt Turner  <mattst88@gmail.com>
      
      	* config/i386/driver-i386.c (host_detect_local_cpu): Add Kaby
      	Lake models to skylake case.  Assume skylake for unknown
      	models with clflushopt.
      
      gcc/testsuite/
      
      2017-06-22  Matt Turner  <mattst88@gmail.com>
      
      	* gcc.target/i386/builtin_target.c: Add Kaby Lake models to
      	skylake check.
      
      libgcc/
      
      2017-06-22  Matt Turner  <mattst88@gmail.com>
      
      	* config/i386/cpuinfo.c (get_intel_cpu): Add Kaby Lake models to
      	skylake case.
      
      From-SVN: r249574
      Matt Turner committed
    • builtins-3.c (vmulosh, [...]): Fix scan-assembler-times should check for word… · 4333d74b
      builtins-3.c (vmulosh, [...]): Fix scan-assembler-times should check for word not half word instructions.
      
      gcc/testsuite/ChangeLog:
      
      2017-06-22 Carl Love  <cel@us.ibm.com>
      
      	* gcc.target/powerpc/builtins-3.c (vmulosh, vmulouh, vmulesh,
      	vmuleuh): Fix scan-assembler-times should check for word not half word
      	instructions.
      
      From-SVN: r249572
      Carl Love committed
    • Reorder IDENTIFIER flags · 84c0088f
      	Reorder IDENTIFIER flags
      	gcc/cp/
      	* cp-tree.h (enum cp_identifier_kind): New.
      	(IDENTIFIER_KIND_BIT_0, IDENTIFIER_KIND_BIT_1,
      	IDENTIFIER_KIND_BIT_2): New.
      	(IDENTIFIER_MARKED): Move to TREE_LANG_FLAG_4.
      	(IDENTIFIER_VIRTUAL_P, IDENTIFIER_REPO_CHOSEN): Add
      	IDENTIFIER_CHECK.
      	(C_IS_RESERVED_WORD): Replace with ...
      	(IDENTIFIER_KEYWORD_P): ... this.
      	(IDENTIFIER_CTOR_OR_DTOR_P): Replace with ...
      	(IDENTIFIER_CDTOR_P): ... this.
      	(IDENTIFIER_CTOR_P, IDENTIFIER_DTOR_P): New.
      	(IDENTIFIER_OPNAME_P): Replace with ...
      	(IDENTIFIER_ANY_OP_P): ... this.
      	(IDENTIFIER_ASSIGN_OP_P): New.
      	(IDENTIFIER_TYPENAME_P): Replace with ...
      	(IDENTIFIER_CONV_OP_P): ... this.
      	(NEW_DELETE_OPNAME_P): Replace with ...
      	(IDENTIFIER_NEWDEL_OP_P): ... this.
      	(DECL_CONV_FN_P, DECL_OVERLOADED_OPERATOR_P): Adjust.
      	(get_identifier_kind_name, set_identifier_kind): Declare.
      	* lex.c (get_identifier_kind_name, set_identifier_kind): New.
      	(init_operators): Adjust to avoid keywords, use
      	set_identifier_kind. Copy TYPE_EXPR slot.
      	(init_reswords): Call set_identifier_kind.
      	(unqualified_name_lookup_error): Adjust.
      	* operators.def (TYPE_EXPR): Remove.
      	* decl.c (struct predefined_identifier): Move into ...
      	(initialize_predefined_identifiers): ... here.  Call
      	set_identifier_kind.
      	(grokfndecl, check_var_type, grokdeclarator): Adjust.
      	(grok_op_properties): Use IDENTIFIER_ANY_ASSIGN_OP to halve search
      	space.  Adjust.
      	* call.c (name_as_c_string): Adjust.
      	(build_new_method_call_1): Likewise.
      	* cp-cilkplus.c (is_conversion_operator_function_decl_p):
      	Likewise.
      	* cxx-pretty-print.c (pp_cxx_unqualified_id): Adjust.
      	* dump.c (cp_dump_tree): Adjust.
      	* error.c (dump_decl_name): Adjust.
      	* mangle.c (write_unqualified_id, write_member_name)
      	write_expression): Adjust.
      	(mangle_conv_op_name_for_type): Use set_identifier_kind.
      	* name-lookup.c (do_class_using_decl): Adjust.
      	(lookup_name_fuzzy, lookup_name_real_1): Likewise.
      	* parser.c (cp_lexer_get_preprocessor_token)
      	cp_parser_direct_declarator): Likewise.
      	* pt.c (push_template_decl_real, tsubst_decl, tsubst_baselink)
      	tsubst_copy, tsubst_copy_and_build): Adjust.
      	* ptree.c (cxx_print_identifier): Print identifier kind.
      	* search.c (lookup_field_r, lookup_member)
      	lookup_fnfields_idx_nolazy): Adjust.
      	* semantics.c (finish_id_expression): Adjust..
      	* typeck.c (cp_build_addr_expr_1): Adjust.
      
      From-SVN: r249571
      Nathan Sidwell committed
    • aarch64.c (aarch64_emit_probe_stack_range): Handle frame sizes that do not… · 13f752b2
      aarch64.c (aarch64_emit_probe_stack_range): Handle frame sizes that do not satisfy aarch64_uimm12_shift.
      
      	* config/aarch64/aarch64.c (aarch64_emit_probe_stack_range): Handle
      	frame sizes that do not satisfy aarch64_uimm12_shift.
      
      	* gcc.c-torture/compile/stack-check-1.c: New test.
      
      From-SVN: r249566
      Jeff Law committed
    • runtime: make NumGoroutine wait for system goroutines to register · 47f68dc2
          
          In libgo system goroutines register themselves after they start.
          That means that there is a small race between the goroutine being
          seen by the scheduler and the scheduler knowing that the goroutine
          is a system goroutine. That in turn means that runtime.NumGoroutines
          can overestimate the number of goroutines at times.
          
          This patch fixes the overestimate by counting the number of system
          goroutines waiting to start, and pausing NumGoroutines until those
          goroutines have all registered.
          
          This is kind of a lot of mechanism for this not very important
          problem, but I couldn't think of a better approach.
          
          The test for this is TestNumGoroutine in runtime/proc_test.go.
          The test is not currently run, but it will be soon.
          
          Reviewed-on: https://go-review.googlesource.com/46457
      
      From-SVN: r249565
      Ian Lance Taylor committed
    • compiler: fix stale comment in lexer · b8f70831
          
          Remove stale comment in code that accepts "go:nowritebarrier"
          pragma. Update comment for "go:nowritebarrierrec".
          
          Reviewed-on: https://go-review.googlesource.com/46416
      
      From-SVN: r249564
      Ian Lance Taylor committed
    • profile-count.h (apply_probability, [...]): Fix checks for zero. · eaee472d
      
      	* profile-count.h (apply_probability,
      	apply_scale, probability_in): Fix checks for zero.
      
      From-SVN: r249563
      Jan Hubicka committed
    • runtime: don't assume that _ = *s will panic if s is nil · c016fd32
          
          With the gc toolchain apparently
                  var s *string
                  _ = *s
          is enough to panic with a nil pointer dereference. The gccgo compiler
          will simply discard the dereference, which I think is a reasonable and
          acceptable optimization. Change the tests to use an exported variable
          instead. The tests are not currently run, but they will be with a
          later patch to gotools.
          
          Reviewed-on: https://go-review.googlesource.com/46450
      
      From-SVN: r249562
      Ian Lance Taylor committed
    • runtime: change some stack fields to uintptr · 3b0ddadf
          
          Because of how gccgo implements cgo calls, the code in dropm may not
          have any write barriers.  As a step toward implementing that, change
          the gcstack, gcnextsegment, and gcnextsp fields of the g struct to
          uintptr, so that assignments to them do not require write barriers.
          The gcinitialsp field remains unsafe.Pointer, as on 32-bit systems
          that do not support split stack it points to a heap allocated space
          used for the goroutine stack.
          
          The test for this is runtime tests like TestCgoCallbackGC, which are
          not run today but will be run with a future gotools patch.
          
          Reviewed-on: https://go-review.googlesource.com/46396
      
      From-SVN: r249561
      Ian Lance Taylor committed
    • Support $SYSROOT for = in -I etc. · a055692a
      	* incpath.c (add_sysroot_to_chain): Allow for $SYSROOT prefix.
      	* doc/cppdiropts.texi (-I @var{dir}): Document it.
      
      From-SVN: r249560
      Rainer Orth committed
    • runtime: avoid write barriers when calling deferred function · c8a47c48
          
          Calling a deferred function currently requires changing from a uintptr
          to the function code to a Go function value. That is done by setting
          the value of a func local variable using unsafe.Pointer. The local
          variable will always be on the stack. Adjust the code that sets the
          local variable to avoid generating a write barrier.
          
          A write barrier is never needed here. Also, for deferreturn, we must
          avoid write barriers entirely when called from a cgo function; that
          requires more than just this, but this is a start.
          
          The test for this is runtime tests that use the go tool; these are not
          currently run, but they will be in the future.
          
          Reviewed-on: https://go-review.googlesource.com/46455
      
      From-SVN: r249559
      Ian Lance Taylor committed
    • runtime: rename _defer struct _panic field to panicStack · b92e4dff
          
          The gc version of the _defer struct has a _panic field that has a
          completely different meaning. We are going to want that bring that new
          meaning into the gofrontend to improve panic reports with nested
          panic calls. Simplify that by first renaming the existing _panic field.
          
          Reviewed-on: https://go-review.googlesource.com/46454
      
      From-SVN: r249558
      Ian Lance Taylor committed
    • runtime: adjust tests for gofrontend · ed99905e
          
          - don't run tests that depend on SetCgoTraceback
          - don't expect a '(' after the function name in a traceback
          - change the expected name of nested functions in a traceback
          
          These tests are not currently run, but they will be soon.
          
          Reviewed-on: https://go-review.googlesource.com/46453
      
      From-SVN: r249557
      Ian Lance Taylor committed
    • runtime: don't build test files that use SetCgoTraceback for gccgo · 2a208bc2
          
          The gofrontend doesn't support the runtime.SetCgoTraceback function,
          which is specifically for handling mixed Go and C tracebacks.
          Use a build tag to avoid compiling the runtime/testdata/testprogcgo
          files that refer to SetCgoTraceback. These files are not currently
          compiled anyhow, but they will be with a future gotools patch.
          
          Reviewed-on: https://go-review.googlesource.com/46452
      
      From-SVN: r249556
      Ian Lance Taylor committed
    • runtime: build testprogcgo with -pthread · 7d8c7b26
          
          Building this test with gccgo requires an explicit -pthread option to
          be passed to the C compiler, so that it links against -lpthread.
          This test is not built today, but it will be soon with a future patch.
          
          Reviewed-on: https://go-review.googlesource.com/46451
      
      From-SVN: r249555
      Ian Lance Taylor committed