1. 04 Mar, 2019 9 commits
    • Baokun Lee's avatar
      os: remove unreadable directories in RemoveAll · c7465929
      Baokun Lee authored
      Fixes #30555
      
      Change-Id: Ib894b4f3cdba23a18a69c9470cf69ceb83591a4d
      Reviewed-on: https://go-review.googlesource.com/c/go/+/165057
      Run-TryBot: Baokun Lee <nototon@gmail.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
      c7465929
    • Josh Bleecher Snyder's avatar
      math/big: optimize shlVU_g and shrVU_g · 87cc5671
      Josh Bleecher Snyder authored
      Special case shifts by zero.
      Provide hints to the compiler that shifts are bounded.
      
      There are no existing benchmarks for shifts,
      but the Float implementation uses shifts,
      so we can use those.
      
      Benchmarks on amd64 with -tags=math_big_pure_go.
      
      name                  old time/op    new time/op    delta
      FloatString/100-8        869ns ± 3%     872ns ± 4%   +0.40%  (p=0.001 n=94+83)
      FloatString/1000-8      26.5µs ± 1%    26.4µs ± 1%   -0.46%  (p=0.000 n=87+96)
      FloatString/10000-8     2.18ms ± 2%    2.18ms ± 2%     ~     (p=0.687 n=90+89)
      FloatString/100000-8     200ms ± 7%     197ms ± 5%   -1.47%  (p=0.000 n=100+90)
      FloatAdd/10-8           65.9ns ± 4%    64.0ns ± 4%   -2.94%  (p=0.000 n=92+93)
      FloatAdd/100-8          71.3ns ± 4%    67.4ns ± 4%   -5.51%  (p=0.000 n=96+93)
      FloatAdd/1000-8          128ns ± 1%     121ns ± 0%   -5.69%  (p=0.000 n=91+80)
      FloatAdd/10000-8         718ns ± 4%     626ns ± 4%  -12.83%  (p=0.000 n=99+99)
      FloatAdd/100000-8       6.43µs ± 3%    5.50µs ± 1%  -14.50%  (p=0.000 n=98+83)
      FloatSub/10-8           57.7ns ± 2%    57.0ns ± 4%   -1.20%  (p=0.000 n=89+96)
      FloatSub/100-8          59.9ns ± 3%    58.7ns ± 4%   -2.10%  (p=0.000 n=100+98)
      FloatSub/1000-8         94.5ns ± 1%    88.6ns ± 0%   -6.16%  (p=0.000 n=74+70)
      FloatSub/10000-8         456ns ± 1%     416ns ± 5%   -8.83%  (p=0.000 n=87+95)
      FloatSub/100000-8       4.00µs ± 1%    3.57µs ± 1%  -10.87%  (p=0.000 n=68+85)
      FloatSqrt/64-8           585ns ± 1%     579ns ± 1%   -0.99%  (p=0.000 n=92+90)
      FloatSqrt/128-8         1.26µs ± 1%    1.23µs ± 2%   -2.42%  (p=0.000 n=91+81)
      FloatSqrt/256-8         1.45µs ± 3%    1.40µs ± 1%   -3.61%  (p=0.000 n=96+90)
      FloatSqrt/1000-8        4.03µs ± 1%    3.91µs ± 1%   -3.05%  (p=0.000 n=90+93)
      FloatSqrt/10000-8       48.0µs ± 0%    47.3µs ± 1%   -1.55%  (p=0.000 n=90+90)
      FloatSqrt/100000-8      1.23ms ± 3%    1.22ms ± 4%   -1.00%  (p=0.000 n=99+99)
      FloatSqrt/1000000-8     96.7ms ± 4%    98.0ms ±10%     ~     (p=0.322 n=89+99)
      
      Change-Id: I0f941c05b7c324256d7f0674559b6ba906e92ba8
      Reviewed-on: https://go-review.googlesource.com/c/go/+/164967
      Run-TryBot: Josh Bleecher Snyder <josharian@gmail.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarRobert Griesemer <gri@golang.org>
      87cc5671
    • Michael Anthony Knyszek's avatar
      runtime: use MADV_FREE_REUSABLE on darwin · abf8e355
      Michael Anthony Knyszek authored
      Currently on darwin we use MADV_FREE, which unfortunately doesn't result
      in a change in the process's RSS until pages actually get kicked out,
      which the OS is free to do lazily (e.g. until it finds itself under
      memory pressure).
      
      To remedy this, we instead use MADV_FREE_REUSABLE which has similar
      semantics, except that it also sets a reusable bit on each page so the
      process's RSS gets reported more accurately. The one caveat is for every
      time we call MADV_FREE_REUSABLE on a region we must call MADV_FREE_REUSE
      to keep the kernel's accounting updated.
      
      Also, because this change requires adding new constants that only exist
      on darwin, it splits mem_bsd.go into mem_bsd.go and mem_darwin.go.
      
      Fixes #29844.
      
      Change-Id: Idb6421698511138a430807bcbbd1516cd57557c8
      Reviewed-on: https://go-review.googlesource.com/c/go/+/159117Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      Run-TryBot: Michael Knyszek <mknyszek@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      abf8e355
    • Agniva De Sarker's avatar
      misc/git: remove pre-commit file · 0c7cdb49
      Agniva De Sarker authored
      All hook files are automatically set up when any git-codereview command is run.
      And since the contribution guidelines point to installing git-codereview,
      this file does not serve any purpose any more.
      
      Change-Id: I165f6905ca03fd3d512c59e2654ef79e76de934c
      Reviewed-on: https://go-review.googlesource.com/c/go/+/158677Reviewed-by: default avatarAndrew Bonventre <andybons@golang.org>
      0c7cdb49
    • Carrie Bynon's avatar
      doc: make path platform dependent · 88da9ccb
      Carrie Bynon authored
      Path should now appear with the correct slash, depending on which
      platform install document is being viewed - keeping in line with the
      rest of the document.
      
      Fixes #30160
      
      Change-Id: Ib10e5a4adf366c700bff6f8d246bd5e3111ed61c
      Reviewed-on: https://go-review.googlesource.com/c/go/+/162918Reviewed-by: default avatarAndrew Bonventre <andybons@golang.org>
      88da9ccb
    • Baokun Lee's avatar
      cmd/api: fix no go files package panic · 68eb3ccd
      Baokun Lee authored
      Fixes #29837
      
      Change-Id: I7d57c24d2133932c076df6f41dd6589f777b65dd
      Reviewed-on: https://go-review.googlesource.com/c/158877
      Run-TryBot: Baokun Lee <nototon@gmail.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      68eb3ccd
    • Daniel Martí's avatar
      os/exec: less allocs in the common case · d1887676
      Daniel Martí authored
      When Stdin, Stdout, and Stderr are nil, there are no goroutines to keep
      track of, so we don't need a channel.
      
      And in startProcess, preallocate the right size for sysattr.Files,
      saving a bit of space and a couple of slice growth allocs.
      
      name            old time/op    new time/op    delta
      ExecHostname-8     419µs ± 0%     417µs ± 1%    ~     (p=0.093 n=6+6)
      
      name            old alloc/op   new alloc/op   delta
      ExecHostname-8    6.40kB ± 0%    6.28kB ± 0%  -1.86%  (p=0.002 n=6+6)
      
      name            old allocs/op  new allocs/op  delta
      ExecHostname-8      34.0 ± 0%      31.0 ± 0%  -8.82%  (p=0.002 n=6+6)
      
      Change-Id: Ic1d617f29e9c6431cdcadc7f9bb992750a6d5f48
      Reviewed-on: https://go-review.googlesource.com/c/164801
      Run-TryBot: Daniel Martí <mvdan@mvdan.cc>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      d1887676
    • 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 1 commit