1. 04 Sep, 2018 6 commits
    • Alessandro Arzilli's avatar
      cmd/link: move dwarf part of DWARF generation before type name mangling · 9c833831
      Alessandro Arzilli authored
      Splits part of dwarfgeneratedebugsyms into a new function,
      dwarfGenerateDebugInfo which is called between deadcode elimination
      and type name mangling.
      This function takes care of collecting and processing the DIEs for
      all functions and package-level variables and also generates DIEs
      for all types used in the program.
      
      Fixes #23733
      
      Change-Id: I75ef0608fbed2dffc3be7a477f1b03e7e740ec61
      Reviewed-on: https://go-review.googlesource.com/111237
      Run-TryBot: Heschi Kreinick <heschi@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarHeschi Kreinick <heschi@google.com>
      9c833831
    • Alexey Naidonov's avatar
      cmd/compile: remove unnecessary nil-check · 669fa8f3
      Alexey Naidonov authored
      Removes unnecessary nil-check when referencing offset from an
      address. Suggested by Keith Randall in golang/go#27180.
      
      Updates golang/go#27180
      
      Change-Id: I326ed7fda7cfa98b7e4354c811900707fee26021
      Reviewed-on: https://go-review.googlesource.com/131735Reviewed-by: default avatarKeith Randall <khr@golang.org>
      Run-TryBot: Keith Randall <khr@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      669fa8f3
    • Josh Bleecher Snyder's avatar
      cmd/compile: prefer rematerializeable arg0 for HMUL · 24e51bbe
      Josh Bleecher Snyder authored
      This prevents accidental regalloc regressions
      that otherwise can occur from unrelated changes.
      
      Change-Id: Iea356fb1a24766361fce13748dc1b46e57b21cea
      Reviewed-on: https://go-review.googlesource.com/129375
      Run-TryBot: Josh Bleecher Snyder <josharian@gmail.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarCherry Zhang <cherryyz@google.com>
      24e51bbe
    • Josh Bleecher Snyder's avatar
      encoding/binary: simplify Read and Write · 2179e495
      Josh Bleecher Snyder authored
      There's no need to manually manage the backing slice for bs.
      Removing it simplifies the code, removes some allocations,
      and speeds it up slightly.
      
      Fixes #27403
      
      name                     old time/op    new time/op    delta
      ReadSlice1000Int32s-8      6.39µs ± 1%    6.31µs ± 1%   -1.37%  (p=0.000 n=27+27)
      ReadStruct-8               1.25µs ± 2%    1.23µs ± 2%   -1.06%  (p=0.003 n=30+29)
      ReadInts-8                  301ns ± 0%     297ns ± 1%   -1.21%  (p=0.000 n=27+30)
      WriteInts-8                 325ns ± 1%     320ns ± 1%   -1.59%  (p=0.000 n=26+29)
      WriteSlice1000Int32s-8     6.60µs ± 0%    6.52µs ± 0%   -1.23%  (p=0.000 n=28+27)
      PutUint16-8                0.72ns ± 2%    0.71ns ± 2%     ~     (p=0.286 n=30+30)
      PutUint32-8                0.71ns ± 1%    0.71ns ± 0%   -0.42%  (p=0.003 n=30+25)
      PutUint64-8                0.78ns ± 2%    0.78ns ± 0%   -0.55%  (p=0.001 n=30+27)
      LittleEndianPutUint16-8    0.57ns ± 0%    0.57ns ± 0%     ~     (all equal)
      LittleEndianPutUint32-8    0.57ns ± 0%    0.57ns ± 0%     ~     (all equal)
      LittleEndianPutUint64-8    0.57ns ± 0%    0.57ns ± 0%     ~     (all equal)
      PutUvarint32-8             23.1ns ± 1%    23.1ns ± 1%     ~     (p=0.925 n=26+29)
      PutUvarint64-8             57.5ns ± 2%    57.3ns ± 1%     ~     (p=0.338 n=30+26)
      [Geo mean]                 23.0ns         22.9ns        -0.61%
      
      name                     old speed      new speed      delta
      ReadSlice1000Int32s-8     626MB/s ± 1%   634MB/s ± 1%   +1.38%  (p=0.000 n=27+27)
      ReadStruct-8             60.2MB/s ± 2%  60.8MB/s ± 2%   +1.08%  (p=0.002 n=30+29)
      ReadInts-8                100MB/s ± 1%   101MB/s ± 1%   +1.24%  (p=0.000 n=27+30)
      WriteInts-8              92.2MB/s ± 1%  93.6MB/s ± 1%   +1.56%  (p=0.000 n=26+29)
      WriteSlice1000Int32s-8    606MB/s ± 0%   614MB/s ± 0%   +1.24%  (p=0.000 n=28+27)
      PutUint16-8              2.80GB/s ± 1%  2.80GB/s ± 1%     ~     (p=0.095 n=28+29)
      PutUint32-8              5.61GB/s ± 1%  5.62GB/s ± 1%     ~     (p=0.069 n=27+28)
      PutUint64-8              10.2GB/s ± 1%  10.2GB/s ± 0%   +0.15%  (p=0.039 n=27+27)
      LittleEndianPutUint16-8  3.50GB/s ± 1%  3.50GB/s ± 1%     ~     (p=0.552 n=30+29)
      LittleEndianPutUint32-8  7.01GB/s ± 1%  7.02GB/s ± 1%     ~     (p=0.160 n=29+27)
      LittleEndianPutUint64-8  14.0GB/s ± 1%  14.0GB/s ± 1%     ~     (p=0.413 n=29+29)
      PutUvarint32-8            174MB/s ± 1%   173MB/s ± 1%     ~     (p=0.648 n=25+30)
      PutUvarint64-8            139MB/s ± 2%   140MB/s ± 1%     ~     (p=0.271 n=30+26)
      [Geo mean]                906MB/s        911MB/s        +0.55%
      
      name                     old alloc/op   new alloc/op   delta
      ReadSlice1000Int32s-8      4.14kB ± 0%    4.13kB ± 0%   -0.19%  (p=0.000 n=30+30)
      ReadStruct-8                 200B ± 0%      200B ± 0%     ~     (all equal)
      ReadInts-8                  64.0B ± 0%     32.0B ± 0%  -50.00%  (p=0.000 n=30+30)
      WriteInts-8                  112B ± 0%       64B ± 0%  -42.86%  (p=0.000 n=30+30)
      WriteSlice1000Int32s-8     4.14kB ± 0%    4.13kB ± 0%   -0.19%  (p=0.000 n=30+30)
      PutUint16-8                 0.00B          0.00B          ~     (all equal)
      PutUint32-8                 0.00B          0.00B          ~     (all equal)
      PutUint64-8                 0.00B          0.00B          ~     (all equal)
      LittleEndianPutUint16-8     0.00B          0.00B          ~     (all equal)
      LittleEndianPutUint32-8     0.00B          0.00B          ~     (all equal)
      LittleEndianPutUint64-8     0.00B          0.00B          ~     (all equal)
      PutUvarint32-8              0.00B          0.00B          ~     (all equal)
      PutUvarint64-8              0.00B          0.00B          ~     (all equal)
      [Geo mean]                   476B           370B       -22.22%
      
      name                     old allocs/op  new allocs/op  delta
      ReadSlice1000Int32s-8        3.00 ± 0%      2.00 ± 0%  -33.33%  (p=0.000 n=30+30)
      ReadStruct-8                 16.0 ± 0%      16.0 ± 0%     ~     (all equal)
      ReadInts-8                   8.00 ± 0%      8.00 ± 0%     ~     (all equal)
      WriteInts-8                  14.0 ± 0%      14.0 ± 0%     ~     (all equal)
      WriteSlice1000Int32s-8       3.00 ± 0%      2.00 ± 0%  -33.33%  (p=0.000 n=30+30)
      PutUint16-8                  0.00           0.00          ~     (all equal)
      PutUint32-8                  0.00           0.00          ~     (all equal)
      PutUint64-8                  0.00           0.00          ~     (all equal)
      LittleEndianPutUint16-8      0.00           0.00          ~     (all equal)
      LittleEndianPutUint32-8      0.00           0.00          ~     (all equal)
      LittleEndianPutUint64-8      0.00           0.00          ~     (all equal)
      PutUvarint32-8               0.00           0.00          ~     (all equal)
      PutUvarint64-8               0.00           0.00          ~     (all equal)
      [Geo mean]                   6.94           5.90       -14.97%
      
      Change-Id: I3790b93e4190d98621d5f2c47e42929a18f56c2e
      Reviewed-on: https://go-review.googlesource.com/133135
      Run-TryBot: Josh Bleecher Snyder <josharian@gmail.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      2179e495
    • Agniva De Sarker's avatar
      misc/wasm: handle error during instantiateStreaming · e2e44a5d
      Agniva De Sarker authored
      The same catch block is there in wasm_exec.js for node processes.
      Added it in browser invocations too, to prevent uncaught exceptions.
      
      Change-Id: Icab577ec585fa86df3c76db508b49401bcdb52ae
      Reviewed-on: https://go-review.googlesource.com/132916Reviewed-by: default avatarRichard Musiol <neelance@gmail.com>
      Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      e2e44a5d
    • Leigh McCulloch's avatar
      go/types: correct misspelling in function doc · db3f52db
      Leigh McCulloch authored
      The indirectType function comment uses the phrase 'layed out'. In the
      context of that phrase, where something is being placed or sprawled,
      the word should be 'laid'. 'Layed' is a misspelling of 'laid'.
      
      Change-Id: I05ecb97637276e2252c47e92a0bd678130714889
      GitHub-Last-Rev: 6ee67371b42c12ceaf4c6c245319748008ac7e7b
      GitHub-Pull-Request: golang/go#27444
      Reviewed-on: https://go-review.googlesource.com/132779Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
      db3f52db
  2. 03 Sep, 2018 7 commits
  3. 02 Sep, 2018 3 commits
    • Phil Pearl's avatar
      strings: simplify Join using Builder · 317afdc3
      Phil Pearl authored
      The existing implementation has a bunch of special cases and
      suffers an additional allocation for longer arrays. We can replace
      this code with a simple implementation using Builder, improve
      performance and reduce complexity.
      
      name      old time/op    new time/op    delta
      Join/0-8    3.53ns ± 3%    3.72ns ± 2%   +5.56%  (p=0.000 n=10+10)
      Join/1-8    3.94ns ± 4%    3.40ns ± 4%  -13.57%  (p=0.000 n=10+10)
      Join/2-8    57.0ns ± 3%    51.0ns ± 1%  -10.48%  (p=0.000 n=10+9)
      Join/3-8    74.9ns ± 2%    65.5ns ± 4%  -12.60%  (p=0.000 n=10+10)
      Join/4-8     105ns ± 0%      79ns ± 4%  -24.63%  (p=0.000 n=6+10)
      Join/5-8     116ns ± 2%      91ns ± 4%  -21.95%  (p=0.000 n=10+10)
      Join/6-8     131ns ± 1%     104ns ± 1%  -20.66%  (p=0.000 n=10+10)
      Join/7-8     141ns ± 0%     114ns ± 4%  -18.82%  (p=0.000 n=9+10)
      
      name      old alloc/op   new alloc/op   delta
      Join/0-8     0.00B          0.00B          ~     (all equal)
      Join/1-8     0.00B          0.00B          ~     (all equal)
      Join/2-8     16.0B ± 0%     16.0B ± 0%     ~     (all equal)
      Join/3-8     32.0B ± 0%     32.0B ± 0%     ~     (all equal)
      Join/4-8     96.0B ± 0%     48.0B ± 0%  -50.00%  (p=0.000 n=10+10)
      Join/5-8     96.0B ± 0%     48.0B ± 0%  -50.00%  (p=0.000 n=10+10)
      Join/6-8      128B ± 0%       64B ± 0%  -50.00%  (p=0.000 n=10+10)
      Join/7-8      128B ± 0%       64B ± 0%  -50.00%  (p=0.000 n=10+10)
      
      name      old allocs/op  new allocs/op  delta
      Join/0-8      0.00           0.00          ~     (all equal)
      Join/1-8      0.00           0.00          ~     (all equal)
      Join/2-8      1.00 ± 0%      1.00 ± 0%     ~     (all equal)
      Join/3-8      1.00 ± 0%      1.00 ± 0%     ~     (all equal)
      Join/4-8      2.00 ± 0%      1.00 ± 0%  -50.00%  (p=0.000 n=10+10)
      Join/5-8      2.00 ± 0%      1.00 ± 0%  -50.00%  (p=0.000 n=10+10)
      Join/6-8      2.00 ± 0%      1.00 ± 0%  -50.00%  (p=0.000 n=10+10)
      Join/7-8      2.00 ± 0%      1.00 ± 0%  -50.00%  (p=0.000 n=10+10)
      
      Change-Id: I866a50e809c398512cb87648c955eaa4bf4d8606
      Reviewed-on: https://go-review.googlesource.com/132895Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      317afdc3
    • Giovanni Bajo's avatar
      cmd/compile: add testcase for #24876 · dd5e9b32
      Giovanni Bajo authored
      This is still not fixed, the testcase reflects that there are still
      a few boundchecks. Let's fix the good alternative with an explicit
      test though.
      
      Updates #24876
      
      Change-Id: I4da35eb353e19052bd7b69ea6190a69ced8b9b3d
      Reviewed-on: https://go-review.googlesource.com/107355Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      Run-TryBot: Giovanni Bajo <rasky@develer.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      dd5e9b32
    • Giovanni Bajo's avatar
      test: relax whitespaces matching in codegen tests · f02cc88f
      Giovanni Bajo authored
      The codegen testsuite uses regexp to parse the syntax, but it doesn't
      have a way to tell line comments containing checks from line comments
      containing English sentences. This means that any syntax error (that
      is, non-matching regexp) is currently ignored and not reported.
      
      There were some tests in memcombine.go that had an extraneous space
      and were thus effectively disabled. It would be great if we could
      report it as a syntax error, but for now we just punt and swallow the
      spaces as a workaround, to avoid the same mistake again.
      
      Fixes #25452
      
      Change-Id: Ic7747a2278bc00adffd0c199ce40937acbbc9cf0
      Reviewed-on: https://go-review.googlesource.com/113835
      Run-TryBot: Giovanni Bajo <rasky@develer.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarKeith Randall <khr@golang.org>
      f02cc88f
  4. 01 Sep, 2018 2 commits
  5. 31 Aug, 2018 11 commits
  6. 30 Aug, 2018 11 commits
    • Robert Griesemer's avatar
      go/types: better names for internal helper functions (cleanup) · 770e37d2
      Robert Griesemer authored
      Internal helper functions for type-checking type expressions were
      renamed to make it clearer when they should be used:
      
      	typExpr (w/o def) -> typ
      	typExpr (w/  def) -> definedType
      	typ               -> indirectType
      	typExprInternal   -> typInternal
      
      The rename emphasizes that in most cases Checker.typ should be used
      to compute the types.Type from an ast.Type. If the type is defined,
      definedType should be used. For composite type elements which are
      not "inlined" in memory, indirectType should be used.
      
      In the process, implicitly changed several uses of indirectType
      (old: typ) to typ (old: typExpr) by not changing the respective
      function call source. These implicit changes are ok in those
      places because either call is fine where we are not concerned
      about composite type elements. But using typ (old: typExpr) is
      more efficient than using indirectType (old: typ).
      
      Change-Id: I4ad14d5357c5f94b6f1c33173de575c4cd05c703
      Reviewed-on: https://go-review.googlesource.com/130595Reviewed-by: default avatarAlan Donovan <adonovan@google.com>
      770e37d2
    • Robert Griesemer's avatar
      go/types: remove explicit path parameter from most type-checker functions (cleanup) · 43469ddf
      Robert Griesemer authored
      Now that most of the type-checker is using the object-coloring mechanism
      to detect cycles, remove the explicit path parameter from the functions
      that don't rely on it anymore.
      
      Some of the syntactic-based resolver code (for aliases, interfaces)
      still use an explicit path; leaving those unchanged for now.
      
      The function cycle was moved from typexpr.go (where it is not used
      anymore) to resolver.go (where it's still used). It has not changed.
      
      Fixes #25773.
      
      Change-Id: I2100adc8d66d5da9de9277dee94a1f08e5a88487
      Reviewed-on: https://go-review.googlesource.com/130476Reviewed-by: default avatarAlan Donovan <adonovan@google.com>
      43469ddf
    • Robert Griesemer's avatar
      go/types: track local cycles using same mechanism as for global objects · ce2e883a
      Robert Griesemer authored
      For Go 1.11, cycle tracking of global (package-level) objects was changed
      to use a Checker-level object path rather than relying on the explicit
      path parameter that is passed around to some (but not all) type-checker
      functions.
      
      This change now uses the same mechanism for the detection of local
      type cycles (local non-type objects cannot create cycles by definition
      of the spec).
      
      As a result, local alias cycles are now correctly detected as well
      (issue #27106).
      
      The path parameter that is explicitly passed around to some type-checker
      methods is still present and will be removed in a follow-up CL.
      
      Also:
      - removed useCycleMarking flag and respective dead code
      - added a couple more tests
      - improved documentation
      
      Fixes #27106.
      Updates #25773.
      
      Change-Id: I7cbf304bceb43a8d52e6483dcd0fa9ef7e1ea71c
      Reviewed-on: https://go-review.googlesource.com/130455
      Run-TryBot: Robert Griesemer <gri@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarAlan Donovan <adonovan@google.com>
      ce2e883a
    • Andrew Bonventre's avatar
      cmd/compile: make math/bits.RotateLeft* an intrinsic on amd64 · 5ac24767
      Andrew Bonventre authored
      Previously, pattern matching was good enough to achieve good performance
      for the RotateLeft* functions, but the inlining cost for them was much
      too high. Make RotateLeft* intrinsic on amd64 as a stop-gap for now to
      reduce inlining costs.
      
      This should be done (or at least looked at) for other architectures
      as well.
      
      Updates golang/go#17566
      
      Change-Id: I6a106ff00b6c4e3f490650af3e083ed2be00c819
      Reviewed-on: https://go-review.googlesource.com/132435
      Run-TryBot: Andrew Bonventre <andybons@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarDavid Chase <drchase@google.com>
      5ac24767
    • Leigh McCulloch's avatar
      crypto/x509: clarify docs for SystemCertPool · 8201b92a
      Leigh McCulloch authored
      The sentence in the docs for SystemCertPool that states that mutations
      to a returned pool do not affect any other pool is ambiguous as to who
      the any other pools are, because pools can be created in multiple ways
      that have nothing to do with the system certificate pool. Also the use
      of the word 'the' instead of 'a' early in the sentence implies there is
      only one shared pool ever returned.
      
      Fixes #27385
      
      Change-Id: I43adbfca26fdd66c4adbf06eb85361139a1dea93
      GitHub-Last-Rev: 2f1ba09fa403d31d2d543dca15727c6c2f896ec7
      GitHub-Pull-Request: golang/go#27388
      Reviewed-on: https://go-review.googlesource.com/132378Reviewed-by: default avatarFilippo Valsorda <filippo@golang.org>
      8201b92a
    • Kevin Burke's avatar
      fmt: remove spelling mistake in example · 3eb0b2e8
      Kevin Burke authored
      "someting" is misspelled and the error handling both clobbers the
      error that occurs and distracts from the point of the example, which
      is to demonstrate how Printf works. It's better to just panic with the
      error.
      
      Change-Id: I5fb0a4a1a8b4772cbe0302582fa878d95e3a4060
      Reviewed-on: https://go-review.googlesource.com/132376Reviewed-by: default avatarDaniel Martí <mvdan@mvdan.cc>
      Run-TryBot: Daniel Martí <mvdan@mvdan.cc>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      3eb0b2e8
    • Agniva De Sarker's avatar
      cmd/dist: wait for run jobs to finish in case of a compiler error · 04bee230
      Agniva De Sarker authored
      Instead of calling run synchronously, we pass it through bgrun
      and immediately wait for it to finish. This pushes all jobs
      to execute through the bgwork channel and therefore causes
      them to exit cleanly in case of a compiler error.
      
      Fixes #25981
      
      Change-Id: I789a85d23fabf32d144ab85a3c9f53546cb7765a
      Reviewed-on: https://go-review.googlesource.com/127776
      Run-TryBot: Ian Lance Taylor <iant@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
      04bee230
    • Rebecca Stambler's avatar
      go/types: fix crash following misuse of [...]T in composite literal · 6c0b8b5f
      Rebecca Stambler authored
      The type-checker currently crashes when checking code such as:
      
      	_ = map[string][...]int{"": {1, 2, 3}}
      
      In this case, the type checker reports an error for map[string][...]int,
      then proceeds to type-check the values of the map literal using a hint
      type of [...]int. When type-checking the inner composite (array) literal,
      the length of the open array type is computed from the elements,
      then the array type is recorded, but the literal has no explicit type
      syntax against which to record the type, so this code causes the
      type-checker to panic. Add a nil check before calling
      check.recordTypeAndValue to avoid that.
      
      Updates #22467
      
      Change-Id: Ic4453ba485b7b88ede2a89f209365eda9e032abc
      Reviewed-on: https://go-review.googlesource.com/132355Reviewed-by: default avatarAlan Donovan <adonovan@google.com>
      6c0b8b5f
    • Andrei Tudor Călin's avatar
      net: refactor readerAtEOF splice test · bd49b3d5
      Andrei Tudor Călin authored
      Refactor TestSplice/readerAtEOF to handle cases where we disable
      splice on older kernels better.
      
      If splice is disabled, net.splice and poll.Splice do not get to
      observe EOF on the reader, because poll.Splice returns immediately
      with EINVAL. The test fails unexpectedly, because the splice operation
      is reported as not handled.
      
      This change refactors the test to handle the aforementioned case
      correctly, by not calling net.splice directly, but using a higher
      level check.
      
      Fixes #27355.
      
      Change-Id: I0d5606b4775213f2dbbb84ef82ddfc3bab662a31
      Reviewed-on: https://go-review.googlesource.com/132096
      Run-TryBot: Ian Lance Taylor <iant@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
      bd49b3d5
    • Dylan Waits's avatar
      fmt: add example for Fprintln · 796e4bdc
      Dylan Waits authored
      Change-Id: Idc4aa53e443b89eeba496d00f6b409268e29ec21
      Reviewed-on: https://go-review.googlesource.com/132241
      Run-TryBot: Ian Lance Taylor <iant@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      796e4bdc
    • ianzapolsky's avatar
      fmt: add an example for Errorf · d5c7abf7
      ianzapolsky authored
      The errors package has an example for Errorf, but the fmt
      package does not. Copy the Errorf example from errors to
      fmt. Move existing Stringer example into separate file, so as
      not to break the assumption that the entire file will be
      presented as the example.
      
      Change-Id: I8a210a69362017fa08615a8c3feccdeee8427e22
      Reviewed-on: https://go-review.googlesource.com/132239Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      d5c7abf7