1. 02 Nov, 2019 15 commits
    • Austin Clements's avatar
      runtime: add a test for asynchronous safe points · 7955eceb
      Austin Clements authored
      This adds a test of preempting a loop containing no synchronous safe
      points for STW and stack scanning.
      
      We couldn't add this test earlier because it requires scheduler, STW,
      and stack scanning preemption to all be working.
      
      For #10958, #24543.
      
      Change-Id: I73292db78ca3d14aab11bdafd26d03986920ef0a
      Reviewed-on: https://go-review.googlesource.com/c/go/+/201777
      Run-TryBot: Austin Clements <austin@google.com>
      Reviewed-by: default avatarCherry Zhang <cherryyz@google.com>
      7955eceb
    • Austin Clements's avatar
      runtime: implement async scheduler preemption · 177a36a5
      Austin Clements authored
      This adds signal-based preemption to preemptone.
      
      Since STW and forEachP ultimately use preemptone, this also makes
      these work with async preemption.
      
      This also makes freezetheworld more robust so tracebacks from fatal
      panics should be far less likely to report "goroutine running on other
      thread; stack unavailable".
      
      For #10958, #24543. (This doesn't fix it yet because asynchronous
      preemption only works on POSIX platforms on 386 and amd64 right now.)
      
      Change-Id: If776181dd5a9b3026a7b89a1b5266521b95a5f61
      Reviewed-on: https://go-review.googlesource.com/c/go/+/201762
      Run-TryBot: Austin Clements <austin@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarCherry Zhang <cherryyz@google.com>
      177a36a5
    • Austin Clements's avatar
      runtime: use signals to preempt Gs for suspendG · 62e53b79
      Austin Clements authored
      This adds support for pausing a running G by sending a signal to its
      M.
      
      The main complication is that we want to target a G, but can only send
      a signal to an M. Hence, the protocol we use is to simply mark the G
      for preemption (which we already do) and send the M a "wake up and
      look around" signal. The signal checks if it's running a G with a
      preemption request and stops it if so in the same way that stack check
      preemptions stop Gs. Since the preemption may fail (the G could be
      moved or the signal could arrive at an unsafe point), we keep a count
      of the number of received preemption signals. This lets stopG detect
      if its request failed and should be retried without an explicit
      channel back to suspendG.
      
      For #10958, #24543.
      
      Change-Id: I3e1538d5ea5200aeb434374abb5d5fdc56107e53
      Reviewed-on: https://go-review.googlesource.com/c/go/+/201760
      Run-TryBot: Austin Clements <austin@google.com>
      Reviewed-by: default avatarCherry Zhang <cherryyz@google.com>
      62e53b79
    • Austin Clements's avatar
      runtime: scan stacks conservatively at async safe points · d16ec137
      Austin Clements authored
      This adds support for scanning the stack when a goroutine is stopped
      at an async safe point. This is not yet lit up because asyncPreempt is
      not yet injected, but prepares us for that.
      
      This works by conservatively scanning the registers dumped in the
      frame of asyncPreempt and its parent frame, which was stopped at an
      asynchronous safe point.
      
      Conservative scanning works by only marking words that are pointers to
      valid, allocated heap objects. One complication is pointers to stack
      objects. In this case, we can't determine if the stack object is still
      "allocated" or if it was freed by an earlier GC. Hence, we need to
      propagate the conservative-ness of scanning stack objects: if all
      pointers found to a stack object were found via conservative scanning,
      then the stack object itself needs to be scanned conservatively, since
      its pointers may point to dead objects.
      
      For #10958, #24543.
      
      Change-Id: I7ff84b058c37cde3de8a982da07002eaba126fd6
      Reviewed-on: https://go-review.googlesource.com/c/go/+/201761
      Run-TryBot: Austin Clements <austin@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarCherry Zhang <cherryyz@google.com>
      d16ec137
    • Austin Clements's avatar
      runtime: asynchronous preemption function for x86 · a3ffb0d9
      Austin Clements authored
      This adds asynchronous preemption function for amd64 and 386. These
      functions spill and restore all register state that can be used by
      user Go code.
      
      For the moment we stub out the other arches.
      
      For #10958, #24543.
      
      Change-Id: I6f93fabe9875f4834922a5712362e79045c00aca
      Reviewed-on: https://go-review.googlesource.com/c/go/+/201759
      Run-TryBot: Austin Clements <austin@google.com>
      Reviewed-by: default avatarCherry Zhang <cherryyz@google.com>
      a3ffb0d9
    • Austin Clements's avatar
      runtime: support for injecting calls at signals on x86 · 2d031dc5
      Austin Clements authored
      This adds a sigctxt.pushCall method that pushes a call at the signaled
      site. We'll use this to inject asynchronous preemptions and in some
      places we use it to clean up preparePanic.
      
      For the moment this only works on 386 and amd64. We stub it out on
      other platforms and will avoid calling the stubbed version.
      
      For #10958, #24543.
      
      Change-Id: I49e0e853f935d32dd67a70c6cafbae44ee68af8e
      Reviewed-on: https://go-review.googlesource.com/c/go/+/201758
      Run-TryBot: Austin Clements <austin@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarCherry Zhang <cherryyz@google.com>
      2d031dc5
    • Austin Clements's avatar
      cmd/compile: fix missing unsafe-points · 61fa7988
      Austin Clements authored
      Currently, the compiler fails to mark any unsafe-points in the initial
      instructions of a function as unsafe points. This happens because
      unsafe points are encoded as a stack map index of -2 and the compiler
      emits PCDATA instructions when there's a change in the stack map
      index, but I had set the initial stack map index to -2. The actual
      initial PCDATA value assumed by the PCDATA encoder and the runtime is
      -1. Hence, if the first instructions had a stack map index of -2, no
      PCDATA was emitted, which cause the runtime to assume the index was -1
      instead.
      
      This was particularly problematic in the runtime, where the compiler
      was supposed to mark only calls as safe-points and everything else as
      unsafe-points. Runtime leaf functions, for example, should have been
      marked as entirely unsafe-points, but were instead marked entirely as
      safe-points.
      
      Fix this by making the PCDATA instruction generator assume the initial
      PCDATA value is -1 instead of -2, so it will emit a PCDATA instruction
      right away if the first real instruction is an unsafe-point.
      
      This increases the size of the cmd/go binary by 0.02% since we now
      emit slightly more PCDATA than before.
      
      For #10958, #24543.
      
      Change-Id: I92222107f799130072b36d49098d2686f1543699
      Reviewed-on: https://go-review.googlesource.com/c/go/+/202084
      Run-TryBot: Austin Clements <austin@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarCherry Zhang <cherryyz@google.com>
      61fa7988
    • Austin Clements's avatar
      runtime: add GODEBUG=asyncpreemptoff=1 · 40b74558
      Austin Clements authored
      This doesn't do anything yet, but it will provide a way to disable
      non-cooperative preemption.
      
      For #10958, #24543.
      
      Change-Id: Ifdef303f103eabd0922ced8d9bebbd5f0aa2cda4
      Reviewed-on: https://go-review.googlesource.com/c/go/+/201757
      Run-TryBot: Austin Clements <austin@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      40b74558
    • Harshavardhana's avatar
      net/http/httputil: fix missing Transfer-Encoding header · bdb5e9d1
      Harshavardhana authored
      Current implementation of httputil.DumpRequestOut
      incorrectly resets the Request.Body prematurely
      before Content-Length/Transfer-Encoding detection
      in newTransferWriter()
      
      This fix avoids resetting the Request.Body when
      Request.ContentLength is set to '0' by the caller
      and Request.Body is set to a custom reader. To allow
      newTransferWriter() to treat this situation as
      'Transfer-Encoding: chunked'.
      
      Fixes #34504
      
      Change-Id: Ieab6bf876ced28c32c084e0f4c8c4432964181f5
      Reviewed-on: https://go-review.googlesource.com/c/go/+/197898Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      bdb5e9d1
    • Alberto Donizetti's avatar
      doc: update ports list description to reflect current status · afe50c11
      Alberto Donizetti authored
      This change updates the GOARCH/GOOS discussion at the top of the
      "Installing Go from source" document to better reflect the current
      status. In particular:
      
      - The GOARCH list now focuses on simply listing the supported
      architectures, with no notes about their supposed "maturity", since
      the same GOARCH can be mature on a GOOS and not so mature on another.
      
      - Outdated notes about some archs being new and "not well-exercised"
      have been removed in favour of a following list of which ports are
      first class.
      
      - The list of supported OS has been updated (added: AIX, Illumos),
      and sorted in alphabetical order.
      
      - A note about the runtime support being the same for all ARCHS,
      "including garbage collection and efficient array slicing and" etc etc
      has been removed, since it doesn't seem particularly relevant in a
      "install from source" instruction page, and it's likely a leftover
      from the time this doc page was the landing place for new people and
      it felt the need to "sell" Go.
      
      Updates #27689
      Fixes #35009
      
      Change-Id: Ic4eca91dca3135adc7bed4fe00b4f157768f0e81
      Reviewed-on: https://go-review.googlesource.com/c/go/+/202197Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      afe50c11
    • Keith Randall's avatar
      hash/maphash: move bytes/hash to hash/maphash · 35cfe059
      Keith Randall authored
      Fixes #34778
      
      Change-Id: If8225a7c41cb2af3f67157fb9670eef86272e85e
      Reviewed-on: https://go-review.googlesource.com/c/go/+/204997
      Run-TryBot: Keith Randall <khr@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      35cfe059
    • Katie Hockman's avatar
      crypto/dsa: change bitwise checks to mod operations · dc0c23ec
      Katie Hockman authored
      Even though bitwise operations may be slightly more
      performant, the readability improvement of a mod
      operation is worth the tradeoff.
      
      Change-Id: I352c92ad355c6eb6ef99e3da00e1eff2d2ea5812
      Reviewed-on: https://go-review.googlesource.com/c/go/+/204739Reviewed-by: default avatarFilippo Valsorda <filippo@golang.org>
      Run-TryBot: Filippo Valsorda <filippo@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      dc0c23ec
    • Ian Lance Taylor's avatar
      runtime: clear preemptStop in dropm · 8de0bb77
      Ian Lance Taylor authored
      Updates #10958
      Updates #24543
      Fixes #35294
      
      Change-Id: I60f024d08451565df6d9751dab9832b50cbf637a
      Reviewed-on: https://go-review.googlesource.com/c/go/+/204957
      Run-TryBot: Ian Lance Taylor <iant@golang.org>
      Reviewed-by: default avatarCherry Zhang <cherryyz@google.com>
      8de0bb77
    • Joshua M. Clulow's avatar
      runtime: check for events when port_getn fails with ETIME · 971ec872
      Joshua M. Clulow authored
      On illumos systems, and at least historically on Solaris systems, it is
      possible for port_getn(3C) calls to return some number of events and
      then fail with error ETIME.
      
      Generally we expect this to happen if the caller passes an nget value
      larger than 1 and calls with a timeout; if less than the requested
      number of events accumulate the system will still return them after
      timeout failure so the caller must check the updated nget value in the
      ETIME case.  Note that although less likely this can still happen even
      when requesting just 1 event, especially with a short timeout value or
      on a busy system.
      
      Fixes #35261
      
      Change-Id: I0d83251b69a2fadc64c4e8e280aa596e2e1548ba
      Reviewed-on: https://go-review.googlesource.com/c/go/+/204801Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      971ec872
    • Constantin Konstantinidis's avatar
      net/http: deflake TestCancelRequestWithChannelBeforeDo_Cancel · 1e4a3584
      Constantin Konstantinidis authored
      Goroutines clean up takes longer when using deprecated CloseNotifier.
      
      Fixes #35122
      
      Change-Id: Id820a3012b5c781ddfb294b38ee3b009624e398c
      Reviewed-on: https://go-review.googlesource.com/c/go/+/204661
      Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      1e4a3584
  2. 01 Nov, 2019 17 commits
  3. 31 Oct, 2019 8 commits