1. 04 Mar, 2019 2 commits
    • Brian Kessler's avatar
      encoding/csv: document that Writer is buffered · 0db5534d
      Brian Kessler authored
      Add documentation that individual Write calls are buffered and
      copy documentation from bufio.Writer notifying the user to call
      Flush and Error when all writes are complete. Remove reference
      to "file" since the implementation is general and allows any
      io.Writer.
      
      Fixes #30045
      
      Change-Id: I50165470e548f296494e764707fbabe36c665015
      Reviewed-on: https://go-review.googlesource.com/c/160680Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      0db5534d
    • Josh Bleecher Snyder's avatar
      internal/poll: copy and use errnoErr to avoid allocations · 4fb900e9
      Josh Bleecher Snyder authored
      Converting a syscall.Errno to an interface is
      a significant source of allocations in os/exec.
      
      Elsewhere in the tree, we have pre-allocated errors
      for common errno values. Use the same trick here.
      
      This CL makes yet another copy of this code.
      The problem is that there isn't really a great place to share it.
      
      The existing copies are in:
      
      cmd/vendor/golang.org/x/sys/unix
      cmd/vendor/golang.org/x/sys/windows
      cmd/vendor/golang.org/x/sys/windows/registry
      internal/syscall/windows
      internal/syscall/windows/registry
      syscall
      
      internal/poll can't import from cmd/vendor, and cmd/vendor
      can't import from internal/*, so we can ignore cmd/vendor.
      
      We could put the unix version in internal/syscall/unix
      and then have a platform-independent wrapper in internal/syscall.
      But syscall couldn't use it; internal/syscall/* depends on syscall.
      So that only allows code re-use with internal/syscall/windows/*.
      
      We could create a new very low level internal package, internal/errno.
      But syscall couldn't use it, because it has to import syscall
      to get access to syscall.Errno.
      So that only allows code re-use with internal/syscall/windows/*.
      
      It's not clear that that any of these options pulls its weight.
      
      The obvious and "correct" place for this is syscall.
      But we can't export syscall's version, because package syscall is frozen.
      
      So just copy the code. There's not much of it.
      
      name            old alloc/op   new alloc/op   delta
      ExecHostname-8    6.15kB ± 0%    6.13kB ± 0%  -0.38%  (p=0.000 n=20+19)
      
      name            old allocs/op  new allocs/op  delta
      ExecHostname-8      34.0 ± 0%      31.0 ± 0%  -8.82%  (p=0.000 n=20+20)
      
      Fixes #30535
      
      Change-Id: Idd31c7cced6e15387acc698ffc011e1b7b479903
      Reviewed-on: https://go-review.googlesource.com/c/164971
      Run-TryBot: Josh Bleecher Snyder <josharian@gmail.com>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      4fb900e9
  2. 03 Mar, 2019 8 commits
    • Richard Musiol's avatar
      all: rename WebAssembly instructions according to spec changes · c0d82bb0
      Richard Musiol authored
      The names of some instructions have been updated in the WebAssembly
      specification to be more consistent, see
      https://github.com/WebAssembly/spec/commit/994591e51c9df9e7ef980b04d660709b79982f75.
      This change to the spec is possible because it is still in a draft
      state.
      
      Go's support for WebAssembly is still experimental and thus excempt from
      the compatibility promise. Being consistent with the spec should
      warrant this breaking change to the assembly instruction names.
      
      Change-Id: Iafb8b18ee7f55dd0e23c6c7824aa1fad43117ef1
      Reviewed-on: https://go-review.googlesource.com/c/153797
      Run-TryBot: Richard Musiol <neelance@gmail.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarCherry Zhang <cherryyz@google.com>
      c0d82bb0
    • erifan01's avatar
      cmd/compile: optimize math/bits.Div32 for arm64 · 159b2de4
      erifan01 authored
      Benchmark:
      name     old time/op  new time/op  delta
      Div-8    22.0ns ± 0%  22.0ns ± 0%     ~     (all equal)
      Div32-8  6.51ns ± 0%  3.00ns ± 0%  -53.90%  (p=0.000 n=10+8)
      Div64-8  22.5ns ± 0%  22.5ns ± 0%     ~     (all equal)
      
      Code:
      func div32(hi, lo, y uint32) (q, r uint32) {return bits.Div32(hi, lo, y)}
      
      Before:
              0x0020 00032 (test.go:24)       MOVWU   "".y+8(FP), R0
              0x0024 00036 ($GOROOT/src/math/bits/bits.go:472)        CBZW    R0, 132
              0x0028 00040 ($GOROOT/src/math/bits/bits.go:472)        MOVWU   "".hi(FP), R1
              0x002c 00044 ($GOROOT/src/math/bits/bits.go:472)        CMPW    R1, R0
              0x0030 00048 ($GOROOT/src/math/bits/bits.go:472)        BLS     96
              0x0034 00052 ($GOROOT/src/math/bits/bits.go:475)        MOVWU   "".lo+4(FP), R2
              0x0038 00056 ($GOROOT/src/math/bits/bits.go:475)        ORR     R1<<32, R2, R1
              0x003c 00060 ($GOROOT/src/math/bits/bits.go:476)        CBZ     R0, 140
              0x0040 00064 ($GOROOT/src/math/bits/bits.go:476)        UDIV    R0, R1, R2
              0x0044 00068 (test.go:24)       MOVW    R2, "".q+16(FP)
              0x0048 00072 ($GOROOT/src/math/bits/bits.go:476)        UREM    R0, R1, R0
              0x0050 00080 (test.go:24)       MOVW    R0, "".r+20(FP)
              0x0054 00084 (test.go:24)       MOVD    -8(RSP), R29
              0x0058 00088 (test.go:24)       MOVD.P  32(RSP), R30
              0x005c 00092 (test.go:24)       RET     (R30)
      
      After:
              0x001c 00028 (test.go:24)       MOVWU   "".y+8(FP), R0
              0x0020 00032 (test.go:24)       CBZW    R0, 92
              0x0024 00036 (test.go:24)       MOVWU   "".hi(FP), R1
              0x0028 00040 (test.go:24)       CMPW    R0, R1
              0x002c 00044 (test.go:24)       BHS     84
              0x0030 00048 (test.go:24)       MOVWU   "".lo+4(FP), R2
              0x0034 00052 (test.go:24)       ORR     R1<<32, R2, R4
              0x0038 00056 (test.go:24)       UDIV    R0, R4, R3
              0x003c 00060 (test.go:24)       MSUB    R3, R4, R0, R4
              0x0040 00064 (test.go:24)       MOVW    R3, "".q+16(FP)
              0x0044 00068 (test.go:24)       MOVW    R4, "".r+20(FP)
              0x0048 00072 (test.go:24)       MOVD    -8(RSP), R29
              0x004c 00076 (test.go:24)       MOVD.P  16(RSP), R30
              0x0050 00080 (test.go:24)       RET     (R30)
      
      UREM instruction in the previous assembly code will be converted to UDIV and MSUB instructions
      on arm64. However the UDIV instruction in UREM is unnecessary, because it's a duplicate of the
      previous UDIV. This CL adds a rule to have this extra UDIV instruction removed by CSE.
      
      Change-Id: Ie2508784320020b2de022806d09f75a7871bb3d7
      Reviewed-on: https://go-review.googlesource.com/c/159577Reviewed-by: default avatarKeith Randall <khr@golang.org>
      Reviewed-by: default avatarCherry Zhang <cherryyz@google.com>
      Run-TryBot: Bryan C. Mills <bcmills@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      159b2de4
    • Daniel Martí's avatar
      os/exec: don't use the echo binary for a benchmark · 83610c90
      Daniel Martí authored
      Most notably, it's missing on Windows machines. For example,
      windows-amd64-race started failing consistently:
      
      	--- FAIL: BenchmarkExecEcho
      	    bench_test.go:15: could not find echo: exec: "echo": executable file not found in %PATH%
      
      We can also reproduce this from Linux with Wine:
      
      	$ GOOS=windows go test -bench=. -benchtime=1x -run=- -exec wine
      	--- FAIL: BenchmarkExecEcho
      	    bench_test.go:15: could not find echo: exec: "echo": executable file not found in %PATH%
      
      Instead, use the "hostname" program, which is available on Windows too.
      Interestingly enough, it's also slightly faster than "echo". Any program
      is fine as long as it's close enough to a no-op, though.
      
      	name        old time/op    new time/op    delta
      	ExecEcho-8     422µs ± 0%     395µs ± 0%  -6.39%  (p=0.004 n=6+5)
      
      	name        old alloc/op   new alloc/op   delta
      	ExecEcho-8    6.39kB ± 0%    6.42kB ± 0%  +0.53%  (p=0.002 n=6+6)
      
      	name        old allocs/op  new allocs/op  delta
      	ExecEcho-8      36.0 ± 0%      36.0 ± 0%    ~     (all equal)
      
      Change-Id: I772864d69979172b5cf807552c84d0e165e73051
      Reviewed-on: https://go-review.googlesource.com/c/164704
      Run-TryBot: Daniel Martí <mvdan@mvdan.cc>
      Reviewed-by: default avatarJosh Bleecher Snyder <josharian@gmail.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      83610c90
    • Richard Musiol's avatar
      misc/wasm: better adapt to different JavaScript environments · 42b79f08
      Richard Musiol authored
      This change adds support for using wasm with Electron. It refactors
      environment detection to a more modular approach instead of explicitly
      testing for Node.js.
      
      Fixes #29404
      
      Change-Id: I882a9c56523744e7fd7cb2013d158df91cf91d14
      Reviewed-on: https://go-review.googlesource.com/c/164665
      Run-TryBot: Richard Musiol <neelance@gmail.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      42b79f08
    • Alberto Donizetti's avatar
      doc: fix bad lib/time link in 1.12 release notes · 0dc62565
      Alberto Donizetti authored
      There's a "lib/time" sub-section in the Go 1.12 relase notes that
      points to a non-existent golang.org/pkg/lib/time page.
      
      The note is about a change in the tz database in the src/lib/time
      directory, but the section's title (and the link) should probably just
      refer to the time package.
      
      Change-Id: Ibf9dacd710e72886f14ad0b7415fea1e8d25b83a
      Reviewed-on: https://go-review.googlesource.com/c/164977Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      0dc62565
    • Daniel Martí's avatar
      os/exec: preallocate for Cmd.childFiles · 59712fd0
      Daniel Martí authored
      We're always going to add stdin, stdout, and stderr to childFiles, so
      its length will be at least three. The final length will be those three
      elements plus however many files were given via ExtraFiles.
      
      Allocate for that final length directly, saving two slice growth allocs
      in the common case where ExtraFiles is empty.
      
      name        old time/op    new time/op    delta
      ExecEcho-8     435µs ± 0%     435µs ± 0%    ~     (p=0.394 n=6+6)
      
      name        old alloc/op   new alloc/op   delta
      ExecEcho-8    6.39kB ± 0%    6.37kB ± 0%  -0.39%  (p=0.002 n=6+6)
      
      name        old allocs/op  new allocs/op  delta
      ExecEcho-8      36.0 ± 0%      34.0 ± 0%  -5.56%  (p=0.002 n=6+6)
      
      Change-Id: Ib702c0da1e43f0a55ed937af6d45fca6a170e8f3
      Reviewed-on: https://go-review.googlesource.com/c/164898
      Run-TryBot: Daniel Martí <mvdan@mvdan.cc>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      59712fd0
    • Leon Klingele's avatar
      cmd/internal/obj/mips: use r instead of p.Reg in call to OP_IRR · ec01d8f7
      Leon Klingele authored
      Change-Id: Id77764ed2d693e632e2a7b4e4638c17e0caf2276
      GitHub-Last-Rev: 9ebe28252086ddcd530905eb9cf50b4a66413291
      GitHub-Pull-Request: golang/go#30003
      Reviewed-on: https://go-review.googlesource.com/c/160427Reviewed-by: default avatarCherry Zhang <cherryyz@google.com>
      Run-TryBot: Cherry Zhang <cherryyz@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      ec01d8f7
    • Daniel Martí's avatar
      encoding/base64: lift nil check out of encode loop · fc42cf8b
      Daniel Martí authored
      Most of the encoding time is spent in the first Encode loop, since the
      rest of the function only deals with the few remaining bytes. Any
      unnecessary work done in that loop body matters tremendously.
      
      One such unnecessary bottleneck was the use of the enc.encode table.
      Since enc is a pointer receiver, and the field is first used within the
      loop, the encoder must perform a nil check at every iteration.
      
      Add a dummy use of the field before the start of the loop, to move the
      nil check there. After that line, the compiler now knows that enc can't
      be nil, and thus the hot loop is free of nil checks.
      
      name              old time/op    new time/op    delta
      EncodeToString-4    14.7µs ± 0%    13.7µs ± 1%  -6.53%  (p=0.000 n=10+10)
      
      name              old speed      new speed      delta
      EncodeToString-4   559MB/s ± 0%   598MB/s ± 1%  +6.99%  (p=0.000 n=10+10)
      
      Updates #20206.
      
      Change-Id: Icbb523a7bd9e470a8be0a448d1d78ade97ed4ff6
      Reviewed-on: https://go-review.googlesource.com/c/151158
      Run-TryBot: Daniel Martí <mvdan@mvdan.cc>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      fc42cf8b
  3. 02 Mar, 2019 22 commits
  4. 01 Mar, 2019 8 commits