1. 19 Oct, 2018 4 commits
    • Filippo Valsorda's avatar
      crypto/tls: replace net.Pipe in tests with real TCP connections · be0f3c28
      Filippo Valsorda authored
      crypto/tls is meant to work over network connections with buffering, not
      synchronous connections, as explained in #24198. Tests based on net.Pipe
      are unrealistic as reads and writes are matched one to one. Such tests
      worked just thanks to the implementation details of the tls.Conn
      internal buffering, and would break if for example the flush of the
      first flight of the server was not entirely assimilated by the client
      rawInput buffer before the client attempted to reply to the ServerHello.
      
      Note that this might run into the Darwin network issues at #25696.
      
      Fixed a few test races that were either hidden or synchronized by the
      use of the in-memory net.Pipe.
      
      Also, this gets us slightly more realistic benchmarks, reflecting some
      syscall cost of Read and Write operations.
      
      Change-Id: I5a597b3d7a81b8ccc776030cc837133412bf50f8
      Reviewed-on: https://go-review.googlesource.com/c/142817
      Run-TryBot: Filippo Valsorda <filippo@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      be0f3c28
    • Seebs's avatar
      text/template: drop unused sortKeys function · 628403fd
      Seebs authored
      Recent change golang.org/cl/142737 drops the only call site for the
      sortKeys function. If it's not in use, it should probably not be there in
      the code, lurking and preparing to bite us when someone calls that instead
      of the new key sorter in fmtsort, resulting in strange inconsistencies.
      
      Since the function isn't called, this should have no impact.
      Related to, but does not fix, #21095.
      
      Change-Id: I4695503ef4d5ce90d989ec952f01ea00cc15c79d
      Reviewed-on: https://go-review.googlesource.com/c/143178Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      628403fd
    • Rob Pike's avatar
      flag: return a consistent parse error if the flag value is invalid · ae0c4358
      Rob Pike authored
      Return a consistently formatted error string that reports either
      a parse error or a range error.
      
      Before:
      	invalid boolean value "3" for -debug: strconv.ParseBool: parsing "3": invalid syntax
      
      After:
      	invalid boolean value "3" for -debug: parse error
      
      Fixes #26822
      
      Change-Id: I60992bf23da32a4c0cf32472a8af486a3c9674ad
      Reviewed-on: https://go-review.googlesource.com/c/143257Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
      ae0c4358
    • Ben Shi's avatar
      cmd/compile: optimize store combination on 386/amd64 · 95dda75b
      Ben Shi authored
      This CL add 3 rules to combine byte-store to word-store on386 and
      amd64.
      
      Change-Id: Iffd9cda42f1961680c81def4edc773ad58f211b3
      Reviewed-on: https://go-review.googlesource.com/c/143057
      Run-TryBot: Ben Shi <powerman1st@163.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarKeith Randall <khr@golang.org>
      95dda75b
  2. 18 Oct, 2018 11 commits
  3. 17 Oct, 2018 18 commits
    • Umang Parmar's avatar
      database/sql: remove commented debug prints · 830f424c
      Umang Parmar authored
      Fixes #28234
      
      Change-Id: I89090ffb8285c4936b0c9b5c2475849c0643186a
      GitHub-Last-Rev: 4dd0ec162d0ce1548045d4119fd3295570f65d85
      GitHub-Pull-Request: golang/go#28246
      Reviewed-on: https://go-review.googlesource.com/c/142877Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      830f424c
    • Alan Donovan's avatar
      cmd/go: make go vet query cmd/vet for its flags · 398b54df
      Alan Donovan authored
      Add -flags flag to cmd/vet that causes it to describe its flags as JSON.
      
      go vet's "-vettool" flag has been replaced with an environment
      variable, GOVETTOOL, for two reasons:
      
        1) we need its value before flag processing,
           because we must run vet to discover its flags.
      
        2) users may change the env var to opt in/out of the new vet tool
           during the upcoming transition to vet based on the analysis API.
      
      Change-Id: I5d8f90817623022f4170b88fab3c92c9b2fbdc37
      Reviewed-on: https://go-review.googlesource.com/c/142617
      Run-TryBot: Alan Donovan <adonovan@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarBryan C. Mills <bcmills@google.com>
      398b54df
    • Robert Griesemer's avatar
      go/internal/gccgoimporter: backport from x/tools to ensure identical code · 4bea6c65
      Robert Griesemer authored
      This change backports a minor modification of the x/tools version of this
      code back into the std library. It simply ensures that both versions of
      the code are the same and will simplify keeping them in sync down the
      road.
      
      While this is an API change, this is an internal package, so we're ok.
      
      Updates #27891.
      
      Change-Id: Ib153141382f727a2692ca80179ae09c4a383ba4f
      Reviewed-on: https://go-review.googlesource.com/c/142894Reviewed-by: default avatarAlan Donovan <adonovan@google.com>
      4bea6c65
    • Robert Griesemer's avatar
      spec: clarify rules for receiver base types · bb3e2117
      Robert Griesemer authored
      The spec currently provides a syntactic rule for receiver base types,
      and a strict reading of those rules prohibits the use of type aliases
      referring to pointer types as receiver types.
      
      This strict interpretation breaks an assumed rule for aliases, which
      is that a type literal can always be replaced by an alias denoting
      that literal.
      
      Furthermore, cmd/compile always accepted this new formulation of the
      receiver type rules and so this change will simply validate what has
      been implemented all along.
      
      Fixes #27995.
      
      Change-Id: I032289c926a4f070d6f7795431d86635fe64d907
      Reviewed-on: https://go-review.googlesource.com/c/142757Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
      Reviewed-by: default avatarRob Pike <r@golang.org>
      Reviewed-by: default avatarMatthew Dempsky <mdempsky@google.com>
      bb3e2117
    • Ian Lance Taylor's avatar
      os/signal: wait for goroutine in TestTerminalSignal · dc75744f
      Ian Lance Taylor authored
      Fixes #28169
      
      Change-Id: I187d9effea56357bbb04d4971d284a52ffae61f8
      Reviewed-on: https://go-review.googlesource.com/c/142889
      Run-TryBot: Ian Lance Taylor <iant@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      dc75744f
    • Ian Lance Taylor's avatar
      cmd/cgo: write a string rather than building an AST · 1d18f66d
      Ian Lance Taylor authored
      This generates the same code as before, but does so directly rather
      than building an AST and printing that. This is in preparation for
      later changes.
      
      Change-Id: Ifec141120bcc74847f0bff8d3d47306bfe69b454
      Reviewed-on: https://go-review.googlesource.com/c/142883
      Run-TryBot: Ian Lance Taylor <iant@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      1d18f66d
    • Ian Lance Taylor's avatar
      cmd/cgo: split name rewriting out of rewriteRef · af951994
      Ian Lance Taylor authored
      This is in preparation for later changes.
      
      Change-Id: I2b9b77a782cf65a2fcec5e700ec6bb8b1476f6b5
      Reviewed-on: https://go-review.googlesource.com/c/142882
      Run-TryBot: Ian Lance Taylor <iant@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      af951994
    • Ian Lance Taylor's avatar
      cmd/cgo: mangle names before rewriting calls · 19b264e7
      Ian Lance Taylor authored
      Move name mangling before rewriting calls rather than after.
      This is in preparation for later changes.
      
      Change-Id: I74bc351f4290dad7ebf6d0d361bb684087786053
      Reviewed-on: https://go-review.googlesource.com/c/142881
      Run-TryBot: Ian Lance Taylor <iant@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      19b264e7
    • Jordan Rhee's avatar
      os: change UserHomeDir to use USERPROFILE on windows · 5ddec248
      Jordan Rhee authored
      Fixes #28182
      
      Change-Id: I49c2117fba6325c234512f937ff2edfa9477f52f
      Reviewed-on: https://go-review.googlesource.com/c/142886Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      5ddec248
    • Matthew Dempsky's avatar
      cmd/compile: remove obsolete "safe" mode · 51857449
      Matthew Dempsky authored
      Nowadays there are better ways to safely run untrusted Go programs, like
      NaCl and gVisor.
      
      Change-Id: I20c45f13a50dbcf35c343438b720eb93e7b4e13a
      Reviewed-on: https://go-review.googlesource.com/c/142717
      Run-TryBot: Matthew Dempsky <mdempsky@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      Reviewed-by: default avatarRuss Cox <rsc@golang.org>
      51857449
    • Josh Bleecher Snyder's avatar
      test: limit runoutput concurrency with -v · f2a67653
      Josh Bleecher Snyder authored
      This appears to have simply been an oversight.
      
      Change-Id: Ia5d1309b3ebc99c9abbf0282397693272d8178aa
      Reviewed-on: https://go-review.googlesource.com/c/142885
      Run-TryBot: Josh Bleecher Snyder <josharian@gmail.com>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      f2a67653
    • Michael Anthony Knyszek's avatar
      runtime: use only treaps for tracking spans · 07e738ec
      Michael Anthony Knyszek authored
      Currently, mheap tracks spans in both mSpanLists and mTreaps, but
      mSpanLists, while they tend to be smaller, complicate the
      implementation. Here we simplify the implementation by removing
      free and busy from mheap and renaming freelarge -> free and busylarge
      -> busy.
      
      This change also slightly changes the reclamation policy. Previously,
      for allocations under 1MB we would attempt to find a small span of the
      right size. Now, we just try to find any number of spans totaling the
      right size. This may increase heap fragmentation, but that will be dealt
      with using virtual memory tricks in follow-up CLs.
      
      For #14045.
      
      Garbage-heavy benchmarks show very little change, except what appears
      to be a decrease in STW times and peak RSS.
      
      name                      old STW-ns/GC       new STW-ns/GC       delta
      Garbage/benchmem-MB=64-8           263k ±64%           217k ±24%  -17.66%  (p=0.028 n=25+23)
      
      name                      old STW-ns/op       new STW-ns/op       delta
      Garbage/benchmem-MB=64-8          9.39k ±65%          7.80k ±24%  -16.88%  (p=0.037 n=25+23)
      
      name                      old peak-RSS-bytes  new peak-RSS-bytes  delta
      Garbage/benchmem-MB=64-8           281M ± 0%           249M ± 4%  -11.40%  (p=0.000 n=19+18)
      
      https://perf.golang.org/search?q=upload:20181005.1
      
      Go1 benchmarks perform roughly the same, the most notable regression
      being the JSON encode/decode benchmark with worsens by ~2%.
      
      name                     old time/op    new time/op    delta
      BinaryTree17-8              3.02s ± 2%     2.99s ± 2%  -1.18%  (p=0.000 n=25+24)
      Fannkuch11-8                3.05s ± 1%     3.02s ± 2%  -1.20%  (p=0.000 n=25+25)
      FmtFprintfEmpty-8          43.6ns ± 5%    43.4ns ± 3%    ~     (p=0.528 n=25+25)
      FmtFprintfString-8         74.9ns ± 3%    73.4ns ± 1%  -2.03%  (p=0.001 n=25+24)
      FmtFprintfInt-8            79.3ns ± 3%    77.9ns ± 1%  -1.73%  (p=0.003 n=25+25)
      FmtFprintfIntInt-8          119ns ± 6%     116ns ± 0%  -2.68%  (p=0.000 n=25+18)
      FmtFprintfPrefixedInt-8     134ns ± 4%     132ns ± 1%  -1.52%  (p=0.004 n=25+25)
      FmtFprintfFloat-8           240ns ± 1%     241ns ± 1%    ~     (p=0.403 n=24+23)
      FmtManyArgs-8               543ns ± 1%     537ns ± 1%  -1.00%  (p=0.000 n=25+25)
      GobDecode-8                6.88ms ± 1%    6.92ms ± 4%    ~     (p=0.088 n=24+22)
      GobEncode-8                5.92ms ± 1%    5.93ms ± 1%    ~     (p=0.898 n=25+24)
      Gzip-8                      267ms ± 2%     266ms ± 2%    ~     (p=0.213 n=25+24)
      Gunzip-8                   35.4ms ± 1%    35.6ms ± 1%  +0.70%  (p=0.000 n=25+25)
      HTTPClientServer-8          104µs ± 2%     104µs ± 2%    ~     (p=0.686 n=25+25)
      JSONEncode-8               9.67ms ± 1%    9.80ms ± 4%  +1.32%  (p=0.000 n=25+25)
      JSONDecode-8               47.7ms ± 1%    48.8ms ± 5%  +2.33%  (p=0.000 n=25+25)
      Mandelbrot200-8            4.87ms ± 1%    4.91ms ± 1%  +0.79%  (p=0.000 n=25+25)
      GoParse-8                  3.59ms ± 4%    3.55ms ± 1%    ~     (p=0.199 n=25+24)
      RegexpMatchEasy0_32-8      90.3ns ± 1%    89.9ns ± 1%  -0.47%  (p=0.000 n=25+21)
      RegexpMatchEasy0_1K-8       204ns ± 1%     204ns ± 1%    ~     (p=0.914 n=25+24)
      RegexpMatchEasy1_32-8      84.9ns ± 0%    84.6ns ± 1%  -0.36%  (p=0.000 n=24+25)
      RegexpMatchEasy1_1K-8       350ns ± 1%     348ns ± 3%  -0.59%  (p=0.007 n=25+25)
      RegexpMatchMedium_32-8      122ns ± 1%     121ns ± 0%  -1.08%  (p=0.000 n=25+18)
      RegexpMatchMedium_1K-8     36.1µs ± 1%    34.6µs ± 1%  -4.02%  (p=0.000 n=25+25)
      RegexpMatchHard_32-8       1.69µs ± 2%    1.65µs ± 1%  -2.38%  (p=0.000 n=25+25)
      RegexpMatchHard_1K-8       50.8µs ± 1%    49.4µs ± 1%  -2.69%  (p=0.000 n=25+24)
      Revcomp-8                   453ms ± 2%     449ms ± 3%  -0.74%  (p=0.022 n=25+24)
      Template-8                 63.2ms ± 2%    63.4ms ± 1%    ~     (p=0.127 n=25+24)
      TimeParse-8                 313ns ± 1%     315ns ± 3%    ~     (p=0.924 n=24+25)
      TimeFormat-8                294ns ± 1%     292ns ± 2%  -0.65%  (p=0.004 n=23+24)
      [Geo mean]                 49.9µs         49.6µs       -0.65%
      
      name                     old speed      new speed      delta
      GobDecode-8               112MB/s ± 1%   110MB/s ± 4%  -1.00%  (p=0.036 n=24+24)
      GobEncode-8               130MB/s ± 1%   129MB/s ± 1%    ~     (p=0.894 n=25+24)
      Gzip-8                   72.7MB/s ± 2%  73.0MB/s ± 2%    ~     (p=0.208 n=25+24)
      Gunzip-8                  549MB/s ± 1%   545MB/s ± 1%  -0.70%  (p=0.000 n=25+25)
      JSONEncode-8              201MB/s ± 1%   198MB/s ± 3%  -1.29%  (p=0.000 n=25+25)
      JSONDecode-8             40.7MB/s ± 1%  39.8MB/s ± 5%  -2.23%  (p=0.000 n=25+25)
      GoParse-8                16.2MB/s ± 4%  16.3MB/s ± 1%    ~     (p=0.211 n=25+24)
      RegexpMatchEasy0_32-8     354MB/s ± 1%   356MB/s ± 1%  +0.47%  (p=0.000 n=25+21)
      RegexpMatchEasy0_1K-8    5.00GB/s ± 0%  4.99GB/s ± 1%    ~     (p=0.588 n=24+24)
      RegexpMatchEasy1_32-8     377MB/s ± 1%   378MB/s ± 1%  +0.39%  (p=0.000 n=25+25)
      RegexpMatchEasy1_1K-8    2.92GB/s ± 1%  2.94GB/s ± 3%  +0.65%  (p=0.008 n=25+25)
      RegexpMatchMedium_32-8   8.14MB/s ± 1%  8.22MB/s ± 1%  +0.98%  (p=0.000 n=25+24)
      RegexpMatchMedium_1K-8   28.4MB/s ± 1%  29.6MB/s ± 1%  +4.19%  (p=0.000 n=25+25)
      RegexpMatchHard_32-8     18.9MB/s ± 2%  19.4MB/s ± 1%  +2.43%  (p=0.000 n=25+25)
      RegexpMatchHard_1K-8     20.2MB/s ± 1%  20.7MB/s ± 1%  +2.76%  (p=0.000 n=25+24)
      Revcomp-8                 561MB/s ± 2%   566MB/s ± 3%  +0.75%  (p=0.021 n=25+24)
      Template-8               30.7MB/s ± 2%  30.6MB/s ± 1%    ~     (p=0.131 n=25+24)
      [Geo mean]                120MB/s        121MB/s       +0.48%
      
      https://perf.golang.org/search?q=upload:20181004.6
      
      Change-Id: I97f9fee34577961a116a8ddd445c6272253f0f95
      Reviewed-on: https://go-review.googlesource.com/c/139837
      Run-TryBot: Michael Knyszek <mknyszek@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarAustin Clements <austin@google.com>
      07e738ec
    • Michael Anthony Knyszek's avatar
      runtime: de-duplicate span scavenging · e508a5f0
      Michael Anthony Knyszek authored
      Currently, span scavenging was done nearly identically in two different
      locations. This change deduplicates that into one shared routine.
      
      For #14045.
      
      Change-Id: I15006b2c9af0e70b7a9eae9abb4168d3adca3860
      Reviewed-on: https://go-review.googlesource.com/c/139297
      Run-TryBot: Michael Knyszek <mknyszek@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarAustin Clements <austin@google.com>
      e508a5f0
    • Yury Smolsky's avatar
      cmd/compile: make tabs narrow in src column of ssa.html · de31f637
      Yury Smolsky authored
      Too deeply nested code is hard to fit in ssa.html.
      This CL reduces the tab size to 4 characters.
      
      Change-Id: I08643b0868bce3439567084c7d701654655f23d7
      Reviewed-on: https://go-review.googlesource.com/c/142857Reviewed-by: default avatarDavid Chase <drchase@google.com>
      de31f637
    • Rob Pike's avatar
      cmd/doc: fix repeated header bug added in previous CL · a2381f59
      Rob Pike authored
      One too many lines was deleted, and it would print a header multiple times.
      Add a test.
      
      Change-Id: I4906b454dbb66193d515ffacf43849ffdc2dede6
      Reviewed-on: https://go-review.googlesource.com/c/142937Reviewed-by: default avatarRalph Corderoy <ralph@inputplus.co.uk>
      Reviewed-by: default avatarDaniel Martí <mvdan@mvdan.cc>
      Run-TryBot: Daniel Martí <mvdan@mvdan.cc>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      a2381f59
    • Rob Pike's avatar
      cmd/doc: add -all flag to print all documentation for package · 101a677e
      Rob Pike authored
      Unlike the one for the old godoc, you need the -u flag to see
      unexported symbols. This seems like the right behavior: it's
      consistent.
      
      For now at least, the argument must be a package, not a symbol.
      This is also different from old godoc.
      
      Required a little refactoring but also cleaned up a few things.
      
      Update #25595
      
      Leaving the bug open for now until we tackle
      	go doc -all symbol
      
      Change-Id: Ibc1975bfa592cb1e92513eb2e5e9e11e01a60095
      Reviewed-on: https://go-review.googlesource.com/c/141977
      Run-TryBot: Rob Pike <r@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarRuss Cox <rsc@golang.org>
      101a677e
    • Filippo Valsorda's avatar
      crypto/tls,crypto/x509: normalize RFC references · ee769922
      Filippo Valsorda authored
      Use the format "RFC XXXX, Section X.X" (or "Appendix Y.X") as it fits
      more properly in prose than a link, is more future-proof, and as there
      are multiple ways to render an RFC. Capital "S" to follow the quoting
      standard of RFCs themselves.
      
      Applied the new goimports grouping to all files in those packages, too.
      
      Change-Id: I01267bb3a3b02664f8f822e97b129075bb14d404
      Reviewed-on: https://go-review.googlesource.com/c/141918Reviewed-by: default avatarDmitri Shuralyov <dmitshur@golang.org>
      ee769922
    • Rijnard van Tonder's avatar
      crypto/aes: remove redundant nil check around loop · 9c039ea2
      Rijnard van Tonder authored
      Change-Id: I8cc4b5efe798e74b6daabd64fc2dd5486dcb7c5e
      GitHub-Last-Rev: 694509e33df7c5729ec0bf7b053ff18ebd87c36b
      GitHub-Pull-Request: golang/go#28115
      Reviewed-on: https://go-review.googlesource.com/c/140998
      Run-TryBot: Ian Lance Taylor <iant@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
      9c039ea2
  4. 16 Oct, 2018 7 commits
    • Robert Griesemer's avatar
      cmd/compile: simplified test case (cleanup) · e861c3e0
      Robert Griesemer authored
      Follow-up on https://golang.org/cl/124595; no semantic changes.
      
      Updates #26411.
      
      Change-Id: Ic1c4622dbf79529ff61530f9c25ec742c2abe5ca
      Reviewed-on: https://go-review.googlesource.com/c/142720
      Run-TryBot: Robert Griesemer <gri@golang.org>
      Reviewed-by: default avatarEmmanuel Odeke <emm.odeke@gmail.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      e861c3e0
    • Emmanuel T Odeke's avatar
      cmd/compile: fix label redefinition error column numbers · 0b63086f
      Emmanuel T Odeke authored
      Ensure that label redefinition error column numbers
      print the actual start of the label instead of the
      position of the label's delimiting token ":".
      
      For example, given this program:
      
      package main
      
      func main() {
      
                  foo:
         foo:
      foo:
      foo            :
      }
      
      * Before:
      main.go:5:13: label foo defined and not used
      main.go:6:7: label foo already defined at main.go:5:13
      main.go:7:4: label foo already defined at main.go:5:13
      main.go:8:16: label foo already defined at main.go:5:13
      
      * After:
      main.go:5:13: label foo defined and not used
      main.go:6:4: label foo already defined at main.go:5:13
      main.go:7:1: label foo already defined at main.go:5:13
      main.go:8:1: label foo already defined at main.go:5:13
      
      Fixes #26411
      
      Change-Id: I8eb874b97fdc8862547176d57ac2fa0f075f2367
      Reviewed-on: https://go-review.googlesource.com/c/124595
      Run-TryBot: Emmanuel Odeke <emm.odeke@gmail.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarRobert Griesemer <gri@golang.org>
      0b63086f
    • Ilya Tocar's avatar
      cmd/compile/internal/gc: inline autogenerated (*T).M wrappers · fa913a36
      Ilya Tocar authored
      Currently all inlining of autogenerated wrappers is disabled,
      because it causes build failures, when indexed export format is enabled.
      Turns out we can reenable it for common case of (*T).M wrappers.
      This fixes most performance degradation of 1.11 vs 1.10.
      
      encoding/binary:
      name                    old time/op   new time/op   delta
      ReadSlice1000Int32s-6    14.8µs ± 2%   11.5µs ± 2%  -22.01%  (p=0.000 n=10+10)
      WriteSlice1000Int32s-6   14.8µs ± 2%   11.7µs ± 2%  -20.95%  (p=0.000 n=10+10)
      
      bufio:
      name           old time/op    new time/op    delta
      WriterFlush-6    32.4ns ± 1%    28.8ns ± 0%  -11.17%  (p=0.000 n=9+10)
      
      sort:
      SearchWrappers-6       231ns ± 1%   231ns ± 0%     ~     (p=0.129 n=9+10)
      SortString1K-6         365µs ± 1%   298µs ± 1%  -18.43%  (p=0.000 n=9+10)
      SortString1K_Slice-6   274µs ± 2%   276µs ± 1%     ~     (p=0.105 n=10+10)
      StableString1K-6       490µs ± 1%   373µs ± 1%  -23.73%  (p=0.000 n=10+10)
      SortInt1K-6            210µs ± 1%   142µs ± 1%  -32.69%  (p=0.000 n=10+10)
      StableInt1K-6          243µs ± 0%   151µs ± 1%  -37.75%  (p=0.000 n=10+10)
      StableInt1K_Slice-6    130µs ± 1%   130µs ± 0%     ~     (p=0.237 n=10+8)
      SortInt64K-6          19.9ms ± 1%  13.5ms ± 1%  -32.32%  (p=0.000 n=10+10)
      SortInt64K_Slice-6    11.5ms ± 1%  11.5ms ± 1%     ~     (p=0.912 n=10+10)
      StableInt64K-6        21.5ms ± 0%  13.5ms ± 1%  -37.30%  (p=0.000 n=9+10)
      Sort1e2-6              108µs ± 2%    83µs ± 3%  -23.26%  (p=0.000 n=10+10)
      Stable1e2-6            218µs ± 0%   161µs ± 1%  -25.99%  (p=0.000 n=8+9)
      Sort1e4-6             22.6ms ± 1%  16.8ms ± 0%  -25.45%  (p=0.000 n=10+7)
      Stable1e4-6           67.6ms ± 1%  49.7ms ± 0%  -26.48%  (p=0.000 n=10+10)
      Sort1e6-6              3.44s ± 0%   2.55s ± 1%  -26.05%  (p=0.000 n=8+9)
      Stable1e6-6            13.7s ± 0%    9.9s ± 1%  -27.68%  (p=0.000 n=8+10)
      
      Fixes #27621
      Updates #25338
      
      Change-Id: I6fe633202f63fa829a6ab849c44d7e45f8835dff
      Reviewed-on: https://go-review.googlesource.com/c/135697
      Run-TryBot: Ilya Tocar <ilya.tocar@intel.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarMatthew Dempsky <mdempsky@google.com>
      fa913a36
    • Filippo Valsorda's avatar
      Revert "fmt: fix incorrect format of whole-number floats when using %#v" · a52289ef
      Filippo Valsorda authored
      Numbers without decimals are valid Go representations of whole-number
      floats. That is, "var x float64 = 5" is valid Go. Avoid breakage in
      tests that expect a certain output from %#v by reverting to it.
      
      To guarantee the right type is generated by a print use %T(%#v) instead.
      
      Added a test to lock in this behavior.
      
      This reverts commit 7c7cecc1.
      
      Fixes #27634
      Updates #26363
      
      Change-Id: I544c400a0903777dd216452a7e86dfe60b0b0283
      Reviewed-on: https://go-review.googlesource.com/c/142597
      Run-TryBot: Filippo Valsorda <filippo@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarRob Pike <r@golang.org>
      Reviewed-by: default avatarBryan C. Mills <bcmills@google.com>
      a52289ef
    • Matthew Dempsky's avatar
      cmd/compile: remove -dolinkobj flag · 965fa3b1
      Matthew Dempsky authored
      This used to be used by cmd/vet and some assembly generation tests, but
      those were removed in CL 37691 and CL 107336. No point in keeping an
      unneeded flag around.
      
      Fixes #28220.
      
      Change-Id: I59f8546954ab36ea61ceba81c10d6e16d74b966a
      Reviewed-on: https://go-review.googlesource.com/c/142677
      Run-TryBot: Matthew Dempsky <mdempsky@google.com>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      965fa3b1
    • Matthew Dempsky's avatar
      cmd/compile/internal/gc: simplify typechecking definitions · 62c52a5e
      Matthew Dempsky authored
      There are only a handful of nodes that we need to pass to
      typecheckdef (OLITERAL, ONAME, OTYPE, and ONONAME), but typecheck1
      takes the awkward approach of calling typecheckdef on every node with
      Sym != nil, and then excluding a long list of uninteresting Ops that
      have a non-nil Sym.
      
      Passes toolstash-check.
      
      Change-Id: I0271d2faff0208ad57ddc1f1a540a5fbed870234
      Reviewed-on: https://go-review.googlesource.com/c/142657
      Run-TryBot: Matthew Dempsky <mdempsky@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      62c52a5e
    • Lynn Boger's avatar
      test/codegen: enable more tests for ppc64/ppc64le · 39fa301b
      Lynn Boger authored
      Adding cases for ppc64,ppc64le to the codegen tests
      where appropriate.
      
      Change-Id: Idf8cbe88a4ab4406a4ef1ea777bd15a58b68f3ed
      Reviewed-on: https://go-review.googlesource.com/c/142557
      Run-TryBot: Lynn Boger <laboger@linux.vnet.ibm.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      39fa301b