1. 02 Nov, 2016 3 commits
  2. 01 Nov, 2016 33 commits
  3. 31 Oct, 2016 4 commits
    • Matthew Dempsky's avatar
      cmd/compile: move parser.go remnants into noder.go · 2d4d22af
      Matthew Dempsky authored
      Change-Id: I54f8788a4703283b9aa3904e2e610097ac3e3586
      Reviewed-on: https://go-review.googlesource.com/32471
      Run-TryBot: Matthew Dempsky <mdempsky@google.com>
      Reviewed-by: 's avatarRobert Griesemer <gri@golang.org>
      2d4d22af
    • Austin Clements's avatar
      runtime: perform write barriers on direct channel receive · f2d05389
      Austin Clements authored
      Currently we have write barriers for direct channel sends, where the
      receiver is blocked and the sender is writing directly to the
      receiver's stack; but not for direct channel receives, where the
      sender is blocked and the receiver is reading directly from the
      sender's stack.
      
      This was okay with the old write barrier because either 1) the
      receiver would write the received pointer into the heap (causing it to
      be shaded), 2) the pointer would still be on the receiver's stack at
      mark termination and we would rescan it, or 3) the receiver dropped
      the pointer so it wasn't necessarily reachable anyway.
      
      This is not okay with the write barrier because it lets a grey stack
      send a white pointer to a black stack and then remove it from its own
      stack. If the grey stack was the sole grey-protector of this pointer,
      this hides the object from the garbage collector.
      
      Fix this by making direct receives perform a stack-to-stack write
      barrier just like direct sends do.
      
      Fixes #17694.
      
      Change-Id: I1a4cb904e4138d2ac22f96a3e986635534a5ae41
      Reviewed-on: https://go-review.googlesource.com/32450Reviewed-by: 's avatarRick Hudson <rlh@golang.org>
      f2d05389
    • Dhananjay Nakrani's avatar
      cmd/compile: avoid nil-ing out a node's Type in typecheckcomplit() on error · 9a8bf2d6
      Dhananjay Nakrani authored
      typecheckcomplit nils out node's type, upon finding new errors.
      This hides new errors in children's node as well as the type info
      of current node. This change fixes that.
      
      Fixes #17645.
      
      Change-Id: Ib473291f31c7e8fa0307cb1d494e0c112ddd3583
      Reviewed-on: https://go-review.googlesource.com/32324Reviewed-by: 's avatarMatthew Dempsky <mdempsky@google.com>
      Run-TryBot: Matthew Dempsky <mdempsky@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      9a8bf2d6
    • Austin Clements's avatar
      runtime: make assists perform root jobs · d35dfd40
      Austin Clements authored
      Currently, assists can only perform heap marking jobs. However, at the
      beginning of GC, there are only root jobs and no heap marking jobs. As
      a result, there's often a period at the beginning of a GC cycle where
      no goroutine has accumulated assist credit, but at the same time it
      can't get any credit because there are no heap marking jobs for it to
      do yet. As a result, many goroutines often block on the assist queue
      at the very beginning of the GC cycle.
      
      This commit fixes this by allowing assists to perform root marking
      jobs. The tricky part of this (and the reason we haven't done this
      before) is that stack scanning jobs can lead to deadlocks if the
      goroutines performing the stack scanning are themselves
      non-preemptible, since two non-preemptible goroutines may try to scan
      each other. To address this, we use the same insight d6625caf used to
      simplify the mark worker stack scanning: as long as we're careful with
      the stacks and only drain jobs while on the system stack, we can put
      the goroutine into a preemptible state while we drain jobs. This means
      an assist's user stack can be scanned while it continues to do work.
      
      This reduces the rate of assist blocking in the x/benchmarks HTTP
      benchmark by a factor of 3 and all remaining blocking happens towards
      the *end* of the GC cycle, when there may genuinely not be enough work
      to go around.
      
      Ideally, assists would get credit for working on root jobs. Currently
      they do not; however, this change prioritizes heap work over root jobs
      in assists, so they're likely to mostly perform heap work. In contrast
      with mark workers, for assists, the root jobs act only as a backstop
      to create heap work when there isn't enough heap work.
      
      Fixes #15361.
      
      Change-Id: If6e169863e4ad75710b0c8dc00f6125b41e9a595
      Reviewed-on: https://go-review.googlesource.com/32432Reviewed-by: 's avatarRick Hudson <rlh@golang.org>
      d35dfd40