1. 19 Dec, 2018 1 commit
    • Michael Anthony Knyszek's avatar
      runtime: avoid write barrier in startpanic_m · 9ed9df6c
      Michael Anthony Knyszek authored
      startpanic_m could be called correctly in a context where there's a
      valid G, a valid M, but no P, for example in a signal handler which
      panics. Currently, startpanic_m has write barriers enabled because
      write barriers are permitted if a G's M is dying. However, all the
      current write barrier implementations assume the current G has a P.
      
      Therefore, in this change we disable write barriers in startpanic_m,
      remove the only pointer write which clears g.writebuf, and fix up gwrite
      to ignore the writebuf if the current G's M is dying, rather than
      relying on it being nil in the dying case.
      
      Fixes #26575.
      
      Change-Id: I9b29e6b9edf00d8e99ffc71770c287142ebae086
      Reviewed-on: https://go-review.googlesource.com/c/154837
      Run-TryBot: Michael Knyszek <mknyszek@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarAustin Clements <austin@google.com>
      9ed9df6c
  2. 18 Dec, 2018 18 commits
  3. 17 Dec, 2018 19 commits
  4. 16 Dec, 2018 1 commit
  5. 15 Dec, 2018 1 commit