1. 02 Aug, 2013 6 commits
    • Russ Cox's avatar
      runtime: in newstack, double-check calling goroutine · ebc5513b
      Russ Cox authored
      Checking this condition helped me find the arm problem last night.
      
      R=golang-dev, bradfitz
      CC=golang-dev
      https://golang.org/cl/12267043
      ebc5513b
    • Brad Fitzpatrick's avatar
      misc/dist: don't ship cmd/api · b8b48abe
      Brad Fitzpatrick authored
      cmd/api is a tool to prevent the Go developers from breaking
      the Go 1 API promise. It has no utility to end users and
      doesn't run on arbitrary packages (it's always been full of
      hacks for its bespoke type checker to work on the standard
      library)
      
      Robert's in-progress rewrite depends on the go.tools repo for
      go/types, so we won't be able to ship this tool later
      anyway. Just remove it from binary distributions.
      
      A future change to run.bash can conditionally build & run
      cmd/api, perhaps automatically fetching go/types if
      necessary. I assume people don't want to vendor go/types into
      a private gopath just for cmd/api.
      
      I will need help with run.bat.
      
      R=golang-dev, adg, dsymonds, rsc
      CC=golang-dev
      https://golang.org/cl/12316043
      b8b48abe
    • Alex Brainman's avatar
      6f8acd5f
    • Nigel Tao's avatar
      image/draw: fix typos found by "go vet". · 97863bb8
      Nigel Tao authored
      R=r, adg, bradfitz
      CC=golang-dev
      https://golang.org/cl/12312043
      97863bb8
    • Rob Pike's avatar
      fmt: clean up some errors found by vet · fba7b04d
      Rob Pike authored
      Includes deleting some unused items.
      
      R=golang-dev, adg
      CC=golang-dev
      https://golang.org/cl/12305043
      fba7b04d
    • Russ Cox's avatar
      runtime: disable preemption during software fp routines · e03dd079
      Russ Cox authored
      It's okay to preempt at ordinary function calls because
      compilers arrange that there are no live registers to save
      on entry to the function call.
      
      The software floating point routines are function calls
      masquerading as individual machine instructions. They are
      expected to keep all the registers intact. In particular,
      they are expected not to clobber all the floating point
      registers.
      
      The floating point registers are kept per-M, because they
      are not live at non-preemptive goroutine scheduling events,
      and so keeping them per-M reduces the number of 132-byte
      register blocks we are keeping in memory.
      
      Because they are per-M, allowing the goroutine to be
      rescheduled during software floating point simulation
      would mean some other goroutine could overwrite the registers
      or perhaps the goroutine would continue running on a different
      M entirely.
      
      Disallow preemption during the software floating point
      routines to make sure that a function full of floating point
      instructions has the same floating point registers throughout
      its execution.
      
      R=golang-dev, dave
      CC=golang-dev
      https://golang.org/cl/12298043
      e03dd079
  2. 01 Aug, 2013 31 commits
  3. 31 Jul, 2013 3 commits