1. 22 Apr, 2019 10 commits
    • Benoit Sigoure's avatar
      net/http: document that Basic Auth may require URL encoding · 415da714
      Benoit Sigoure authored
      Explicitly warn callers that no URL encoding is performed and
      that they might need to do it.
      
      Fixes #31577
      
      Change-Id: I52dc3fd2798ba8c3652d4a967b1c5c48eb69f43b
      Reviewed-on: https://go-review.googlesource.com/c/go/+/173319Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      415da714
    • Tyler Bui-Palsulich's avatar
      cmd/go: expand cannot determine module path error · 1f0c102a
      Tyler Bui-Palsulich authored
      See suggestion 2 of #31543 by thepudds.
      
      We may want to expand 'go help mod init' in the future to document what
      the module path should look like.
      
      Change-Id: Ia559fa96fda871e011d53f42a803175abc512202
      Reviewed-on: https://go-review.googlesource.com/c/go/+/173318
      Run-TryBot: Jay Conrod <jayconrod@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarJay Conrod <jayconrod@google.com>
      1f0c102a
    • Shawn Elliott's avatar
      cmd/go/internal/generate: stop premature variable substitution in commands · e6ae4e86
      Shawn Elliott authored
      go:generate commands passed no arguments are currently subject
      to premature variable substitution due to mistakenly assuming append
      guarantees a copy.  The change fixes this by forcing a slice copy at
      each invocation of a command.
      
      The previous code assumed that append would always generate a
      copy of its inputs. However, append wouldn't create a copy if there was
      no need to increase capacity and it would just return the original
      input slice. This resulted in premature variable substitutions in
      the "master word list" of generate commands, thus yielding incorrect
      results across multiple invocations of the same command when the
      body contained substitutions e.g. environment variables, moreover
      these can change during the lifetime of go:generate processing a
      file.
      
      Note that this behavior would not manifest itself if any arguments were
      passed to the command, because append would make a copy of the slice
      as it needed to increase its capacity.   The "hacky" work-around was to
      always pass at least one argument to any command, even if the
      command ignores it.  e.g.,
             //go:generate MyNoArgsCmd ' '
      
      This CL fixes that issue and removes the need for the hack mentioned
      above.
      
      Fixes #31608
      
      Change-Id: I782ac2234bd7035a37f61c101ee4aee38ed8d29f
      GitHub-Last-Rev: 796d3430191f183c123c450a60b4a7987cc85e20
      GitHub-Pull-Request: golang/go#31527
      Reviewed-on: https://go-review.googlesource.com/c/go/+/172580
      Run-TryBot: Jay Conrod <jayconrod@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarJay Conrod <jayconrod@google.com>
      e6ae4e86
    • Keith Randall's avatar
      cmd/compile: use correct package name for stack object symbol · 43001a0d
      Keith Randall authored
      Stack object generation code was always using the local package name
      for its symbol. Normally that doesn't matter, as we usually only
      compile functions in the local package. But for wrappers, the compiler
      generates functions which live in other packages. When there are two
      other packages with identical functions to wrap, the same name appears
      twice, and the compiler goes boom.
      
      Fixes #31252
      
      Change-Id: I7026eebabe562cb159b8b6046cf656afd336ba25
      Reviewed-on: https://go-review.googlesource.com/c/go/+/171464
      Run-TryBot: Keith Randall <khr@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarMatthew Dempsky <mdempsky@google.com>
      43001a0d
    • Maya Rashish's avatar
      runtime: use named macros on NetBSD · d1f43cce
      Maya Rashish authored
      It will use the full names that appear in netbsd's /usr/include/sys/syscall.h names.
      This adds some compat-goo (sys_sigprocmask->SYS_sigprocmask14), which might not be pretty, but the information about whether the compat version is used is probably important, as Go will keep using interfaces even after they are considered compatibility, which has caused problems in the past.
      also, the same names appear in ktrace (with the numbers).
      
      Change-Id: Idc1bb254ee33757a39ba224d91e8fbb0331e2149
      GitHub-Last-Rev: b915e8f8a323cdc2d03119c3cf18e35d08c63d18
      GitHub-Pull-Request: golang/go#31594
      Reviewed-on: https://go-review.googlesource.com/c/go/+/173158Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      d1f43cce
    • Austin Clements's avatar
      runtime: improve mstart comments · 744fcfec
      Austin Clements authored
      Some of the comments were unclear or outdated.
      
      Change-Id: I02e01bf60def0074c1fa760e94aa992e9e4969b9
      Reviewed-on: https://go-review.googlesource.com/c/go/+/172987
      Run-TryBot: Austin Clements <austin@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarMichael Knyszek <mknyszek@google.com>
      744fcfec
    • Daniel Martí's avatar
      encoding/json: avoid work when unquoting strings · fe1afe8d
      Daniel Martí authored
      We can work out how many bytes can be unquoted trivially in
      rescanLiteral, which already iterates over a string's bytes.
      
      Removing the extra loop in unquoteBytes simplifies the function and
      speeds it up, especially when decoding simple strings, which are common.
      
      While at it, we can remove unnecessary checks like len(s)<2 and
      s[0]=='"'. Add a comment explaining why.
      
      name           old time/op    new time/op    delta
      CodeDecoder-8    11.2ms ± 0%    11.1ms ± 1%  -1.63%  (p=0.000 n=9+10)
      
      name           old speed      new speed      delta
      CodeDecoder-8   173MB/s ± 0%   175MB/s ± 1%  +1.66%  (p=0.000 n=9+10)
      
      Updates #28923.
      
      Change-Id: I2436a3a7f8148a2f7a6a4cdbd7dec6b32ef5e20c
      Reviewed-on: https://go-review.googlesource.com/c/go/+/151157
      Run-TryBot: Daniel Martí <mvdan@mvdan.cc>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      fe1afe8d
    • erifan01's avatar
      math/big: optimize mulAddVWW on arm64 for better performance · d17d41e5
      erifan01 authored
      Unroll the cycle 4 times to reduce load overhead.
      
      Benchmarks:
      name                old time/op    new time/op    delta
      MulAddVWW/1-8         15.9ns ± 0%    11.9ns ± 0%  -24.92%  (p=0.000 n=8+8)
      MulAddVWW/2-8         16.1ns ± 0%    13.9ns ± 1%  -13.82%  (p=0.000 n=8+8)
      MulAddVWW/3-8         18.9ns ± 0%    17.3ns ± 0%   -8.47%  (p=0.000 n=8+8)
      MulAddVWW/4-8         21.7ns ± 0%    19.5ns ± 0%  -10.14%  (p=0.000 n=8+8)
      MulAddVWW/5-8         25.1ns ± 0%    22.5ns ± 0%  -10.27%  (p=0.000 n=8+8)
      MulAddVWW/10-8        41.6ns ± 0%    40.0ns ± 0%   -3.79%  (p=0.000 n=8+8)
      MulAddVWW/100-8        368ns ± 0%     363ns ± 0%   -1.36%  (p=0.000 n=8+8)
      MulAddVWW/1000-8      3.52µs ± 0%    3.52µs ± 0%   -0.14%  (p=0.000 n=8+8)
      MulAddVWW/10000-8     35.1µs ± 0%    35.1µs ± 0%   -0.01%  (p=0.000 n=7+6)
      MulAddVWW/100000-8     351µs ± 0%     351µs ± 0%   +0.15%  (p=0.038 n=8+8)
      
      Change-Id: I052a4db286ac6e4f3293289c7e9a82027da0405e
      Reviewed-on: https://go-review.googlesource.com/c/go/+/155780
      Run-TryBot: Cherry Zhang <cherryyz@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarCherry Zhang <cherryyz@google.com>
      d17d41e5
    • erifan01's avatar
      cmd/compile: intrinsify math/bits.Sub64 for arm64 · f8f265b9
      erifan01 authored
      This CL instrinsifies Sub64 with arm64 instruction sequence NEGS, SBCS,
      NGC and NEG, and optimzes the case of borrowing chains.
      
      Benchmarks:
      name              old time/op       new time/op       delta
      Sub-64            2.500000ns +- 0%  2.048000ns +- 1%  -18.08%  (p=0.000 n=10+10)
      Sub32-64          2.500000ns +- 0%  2.500000ns +- 0%     ~     (all equal)
      Sub64-64          2.500000ns +- 0%  2.080000ns +- 0%  -16.80%  (p=0.000 n=10+7)
      Sub64multiple-64  7.090000ns +- 0%  2.090000ns +- 0%  -70.52%  (p=0.000 n=10+10)
      
      Change-Id: I3d2664e009a9635e13b55d2c4567c7b34c2c0655
      Reviewed-on: https://go-review.googlesource.com/c/go/+/159018Reviewed-by: default avatarCherry Zhang <cherryyz@google.com>
      Run-TryBot: Cherry Zhang <cherryyz@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      f8f265b9
    • Austin Clements's avatar
      runtime: error formatting fix · db42bb3b
      Austin Clements authored
      g.m is an muintptr, but we want to print it in hex like a pointer.
      
      Change-Id: Ifc48ed77fb2e93cff7a49d98adc7b9679d26c3b1
      Reviewed-on: https://go-review.googlesource.com/c/go/+/172988
      Run-TryBot: Austin Clements <austin@google.com>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      db42bb3b
  2. 20 Apr, 2019 3 commits
  3. 19 Apr, 2019 23 commits
    • Bryan C. Mills's avatar
      cmd/go: only add a 'go' directive on 'go mod tidy' or when a conversion occurs · a1c481d8
      Bryan C. Mills authored
      If the go.mod file exists and is empty, we initialize it from any of
      various formats supported by legacy dependency-management tools.
      
      We also initialize the 'go' directive at that point: we know that the
      go.mod file is incomplete, because it does not reflect the information
      in the legacy configuration file, and since we know that the go.mod
      file is incomplete, we should complete it with as much information as
      we have — including the version of the language currently in use.
      
      However, if there is no legacy configuration file present, then we
      cannot infer that the go.mod file is incomplete: it may correctly
      specify a module without external dependencies. In that case, we
      should not initialize the 'go' directive either: the user will not be
      expecting unnecessary edits to the go.mod file, and we generally do
      not make unnecessary-but-helpful edits unless 'go mod tidy' is invoked
      explicitly.
      
      Fixes #30790
      Fixes #31100
      
      Change-Id: I05a7872bce54a917c10d910cd9a616cab52e2730
      Reviewed-on: https://go-review.googlesource.com/c/go/+/169877
      Run-TryBot: Bryan C. Mills <bcmills@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
      a1c481d8
    • Matthew Dempsky's avatar
      cmd/compile: fix ICE from go/defer call to variadic function · 9f9e17a8
      Matthew Dempsky authored
      The special case logic for go/defer arguments in Escape.call was
      scattered around a bit and was somewhat inconsistently handled across
      different types of function calls and parameters. This CL pulls the
      logic out into a separate callStmt method that's used uniformly for
      all kinds of function calls and arguments.
      
      Fixes #31573.
      
      Change-Id: Icdcdf611754dc3fcf1af7cb52879fb4b73a7a31f
      Reviewed-on: https://go-review.googlesource.com/c/go/+/173019
      Run-TryBot: Matthew Dempsky <mdempsky@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarCherry Zhang <cherryyz@google.com>
      9f9e17a8
    • David Chase's avatar
      cmd/compile: shortcut intrinsic inlining AFTER getcallerXX check · 376ce8c8
      David Chase authored
      A check in inl.go to prevent inlining of functions calling
      either getcallerpc or getcallersp does not work when these
      functions are intrinsics. Swap checks to fix.
      
      Includes test.
      
      No bug, this was discovered in the course of a ridiculous
      experiment with inlining.
      
      Change-Id: Ie1392523bb89882d586678f2674e1a4eadc5e431
      Reviewed-on: https://go-review.googlesource.com/c/go/+/172217
      Run-TryBot: David Chase <drchase@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarKeith Randall <khr@golang.org>
      376ce8c8
    • Than McIntosh's avatar
      go/internal/gccgoimporter: improve alias handling for anonymous fields · dc193dee
      Than McIntosh authored
      The code in the parser that deals with anonymous structure fields
      records the fact that a field is anonymous, then tries to install a proxy
      name for the field based on the name of the type used to declare
      the field. If that type was an alias, the current recipe for determining
      the proxy name was not working properly; enhance the code to recover
      and report the alias name used.
      
      Fixes #31540.
      
      Change-Id: I9b7369ed558a288b56d85170c6f1144daf5228eb
      Reviewed-on: https://go-review.googlesource.com/c/go/+/172603Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
      dc193dee
    • Than McIntosh's avatar
      cmd/link: adjust whitelist for -strictdups checking for plan9 · 4590abe0
      Than McIntosh authored
      Add a couple of additional entries to the white list used to screen
      out errors for builtin functions; these correspond to cases
      that appear to come up only on the plan9 builder.
      
      Updates #31503.
      
      Change-Id: I48ab942ab2894240efe651ec7b7eace7aa5cb45e
      Reviewed-on: https://go-review.googlesource.com/c/go/+/172986Reviewed-by: default avatarDavid du Colombier <0intro@gmail.com>
      Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
      Run-TryBot: Than McIntosh <thanm@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      4590abe0
    • Yuval Pavel Zholkover's avatar
      os: disable the use of netpoll on directories as well on *BSDs · 059f2d4a
      Yuval Pavel Zholkover authored
      Follow up CL 156379.
      
      Updates #19093
      
      Change-Id: I5ea3177fc5911d3af71cbb32584249e419e9d4a3
      Reviewed-on: https://go-review.googlesource.com/c/go/+/172937
      Run-TryBot: Ian Lance Taylor <iant@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
      059f2d4a
    • Bryan C. Mills's avatar
      cmd/go/internal/modload: fix boundary conditions in matchPackages · 14b5b4a2
      Bryan C. Mills authored
      This makes the boundary logic of matchPackages consistent with
      modload.dirInModule.
      
      Previously, matchPackages always stopped at go.mod file, even within
      the vendor tree. However, we do not guarantee that the vendor tree is
      free of such files in general.
      
      matchPackages also issued needless stat operations for modules in the
      module cach, which we already know to be free of nested modules. On
      systems with slow filesystems (such as macOS), those extra calls could
      potentially slow package matching considerably.
      
      Change-Id: I71979ab752e1d3971b370b37085d30502690413b
      Reviewed-on: https://go-review.googlesource.com/c/go/+/172985
      Run-TryBot: Bryan C. Mills <bcmills@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarJay Conrod <jayconrod@google.com>
      14b5b4a2
    • Cherry Zhang's avatar
      cmd/link: mmap object data · dbe32284
      Cherry Zhang authored
      This resurrects CL 121198, except that this time we map read-only.
      
      In case that we need to apply relocations to the symbol's
      content that is backed by read-only memory, we do our own copy-
      on-write. This can happen if we failed to mmap the output file,
      or we build for Wasm.
      
      Memory profile for building k8s.io/kubernetes/cmd/kube-apiserver
      on Linux/AMD64:
      
      Old (before this sequence of CLs):
      inuse_space 1598.75MB total
      669.87MB 41.90% 41.90%   669.87MB 41.90%  cmd/link/internal/objfile.(*objReader).readSlices
      
      New:
      inuse_space 1280.45MB total
      441.18MB 34.46% 34.46%   441.18MB 34.46%  cmd/link/internal/objfile.(*objReader).readSlices
      
      Change-Id: I6b4d29d6eee9828089ea3120eb38c212db21330b
      Reviewed-on: https://go-review.googlesource.com/c/go/+/170741
      Run-TryBot: Cherry Zhang <cherryyz@google.com>
      Reviewed-by: default avatarAustin Clements <austin@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      dbe32284
    • Cherry Zhang's avatar
      cmd/link: apply relocations later · f957a7e3
      Cherry Zhang authored
      Move the phase of applying relocations later, after the sections
      and segments are written to the mmap'd output region. Then apply
      relocations directly in the output region, instead of the input.
      So the input slices we read in don't need to be modified.
      
      This is in preparation for mmap'ing input files read-only.
      
      Change-Id: If9c80657b4469da36aec5a9ab6acf664f5af8fa0
      Reviewed-on: https://go-review.googlesource.com/c/go/+/170739
      Run-TryBot: Cherry Zhang <cherryyz@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarAustin Clements <austin@google.com>
      f957a7e3
    • Cherry Zhang's avatar
      cmd/link: apply DWARF relocations while doing compression · 248444d5
      Cherry Zhang authored
      We are preparing for applying relocations to the output buffer.
      However, for DWARF compression, relocations need to be applied
      before compression, but we don't have an output buffer at that
      time. We also cannot delay DWARF compression to when we mmap the
      output file, because we need the size of the DWARF sections to
      compute the file size.
      
      Instead of applying all the relocations together, we apply
      relocations in DWARF sections one symbol at a time, right before
      it is writing out for compression. As the symbol content may be
      in read-only memory (in the future), we use a temporary buffer
      for applying the relocations, and immediately write it out.
      
      If compression is not used, relocations are still applied all
      together.
      
      This is in preparation for mmap'ing input files read-only.
      
      Change-Id: Iae6d2dd71313897d5054bcc458d3bb78075b30c3
      Reviewed-on: https://go-review.googlesource.com/c/go/+/171397
      Run-TryBot: Cherry Zhang <cherryyz@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarAustin Clements <austin@google.com>
      248444d5
    • Cherry Zhang's avatar
      cmd/link: apply R_DWARFFILEREF later · 15a31bd9
      Cherry Zhang authored
      Apply R_DWARFFILEREF relocations later, along with other
      relocations, so that we don't modify symbols' contents before
      they are written to the output buffer.
      
      This is in preparation for mmap'ing input files read-only.
      
      Change-Id: I8e9ffb2f05acf8f198589b8770f277beb3847541
      Reviewed-on: https://go-review.googlesource.com/c/go/+/170740
      Run-TryBot: Cherry Zhang <cherryyz@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarAustin Clements <austin@google.com>
      15a31bd9
    • Cherry Zhang's avatar
      cmd/link: mmap output file · b2f94d3e
      Cherry Zhang authored
      Use mmap for writing most of the output file content,
      specifically, the sections and segments. After layout, we
      already know the sizes and file offsets for the sections and
      segments. So we can just write the bytes by copying to a mmap'd
      backing store.
      
      The writing of the output file is split into two parts. The first
      part writes the sections and segments to the mmap'd region. The
      second part writes some extra content, for which we don't know
      the size, so we use direct file IO.
      
      This is in preparation for mmap'ing input files read-only.
      
      Change-Id: I9f3b4616a9f96bfd5c940d74c50aacd6d330f7d2
      Reviewed-on: https://go-review.googlesource.com/c/go/+/170738
      Run-TryBot: Cherry Zhang <cherryyz@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarAustin Clements <austin@google.com>
      b2f94d3e
    • Bryan C. Mills's avatar
      cmd/go/internal/modfetch: comment on known bug in isVendoredPackage · 47150aaf
      Bryan C. Mills authored
      Fixes #31562
      
      Change-Id: Ida30dd8071eccb6b490ab89a1de087038fe26796
      Reviewed-on: https://go-review.googlesource.com/c/go/+/172977
      Run-TryBot: Bryan C. Mills <bcmills@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarJay Conrod <jayconrod@google.com>
      47150aaf
    • Brad Fitzpatrick's avatar
      internal/goversion: add new package, move Go 1.x constant there out of go/build · 64e29f94
      Brad Fitzpatrick authored
      Found by Josh, who says in the bug that it shrinks cmd/compile by 1.6 MB (6.5%).
      
      Fixes #31563
      
      Change-Id: I35127af539630e628a0a4f2273af519093536c38
      Reviewed-on: https://go-review.googlesource.com/c/go/+/172997Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
      Reviewed-by: default avatarJosh Bleecher Snyder <josharian@gmail.com>
      64e29f94
    • Cherry Zhang's avatar
      runtime: suppress thread event prints in gdb test · 97252f62
      Cherry Zhang authored
      Pass "set print thread-events off" to gdb to suppress thread
      event prints, like "[New Thread 0xe7b83b40 (LWP 18609)]". We
      don't check them, and the extra output may confuse our other
      checks, in particular, checkCleanBacktrace.
      
      Hopefully fixes #31569.
      
      Change-Id: I6549e1280da7afa1d2e38da2b2fa7cc18c2f0373
      Reviewed-on: https://go-review.googlesource.com/c/go/+/172980
      Run-TryBot: Cherry Zhang <cherryyz@google.com>
      Reviewed-by: default avatarBryan C. Mills <bcmills@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      97252f62
    • Ian Lance Taylor's avatar
      bootstrap.bash: make source writable before cleaning · 4a119141
      Ian Lance Taylor authored
      Otherwise the "git clean" command fails with errors like
          rm: cannot remove '/home/iant/go-linux-ppc64-bootstrap/pkg/mod/golang.org/x/text@v0.0.0-20170915032832-14c0d48ead0c/encoding/simplifiedchinese/all.go': Permission denied
      
      Change-Id: Iecfb1fed6d59819d7fdceb9e391a2b3f81ea620c
      Reviewed-on: https://go-review.googlesource.com/c/go/+/172998
      Run-TryBot: Ian Lance Taylor <iant@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      4a119141
    • Ian Lance Taylor's avatar
      cmd/link: require cgo support for TestSectionsWithSameName · 4c236b9b
      Ian Lance Taylor authored
      The test doesn't really require cgo, but it does require that we know
      the right flags to use to run the C compiler, and that is not
      necessarily correct if we don't support cgo.
      
      Fixes #31565
      
      Change-Id: I04dc8db26697caa470e91ad712376aa621cf765d
      Reviewed-on: https://go-review.googlesource.com/c/go/+/172981
      Run-TryBot: Ian Lance Taylor <iant@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      4c236b9b
    • Kai Dong's avatar
      sync: update comment · 5ccaf2c6
      Kai Dong authored
      Comment update.
      
      Change-Id: If0d054216f9953f42df04647b85c38008b85b026
      GitHub-Last-Rev: 133b4670be6dd1c94d16361c3a7a4bbdf8a355ab
      GitHub-Pull-Request: golang/go#31539
      Reviewed-on: https://go-review.googlesource.com/c/go/+/172700Reviewed-by: default avatarAustin Clements <austin@google.com>
      5ccaf2c6
    • Josh Bleecher Snyder's avatar
      runtime, cmd/compile: re-order PCDATA and FUNCDATA indices · 4aeac68c
      Josh Bleecher Snyder authored
      The pclntab encoding supports writing only some PCDATA and FUNCDATA values.
      However, the encoding is dense: The max index in use determines the space used.
      We should thus choose a numbering in which frequently used indices are smaller.
      
      This change re-orders the PCDATA and FUNCDATA indices using that principle,
      using a quick and dirty instrumentation to measure index frequency.
      
      It shrinks binaries by about 0.5%.
      
      Updates #6853
      
      file      before    after     Δ       %       
      go        14745044  14671316  -73728  -0.500% 
      addr2line 4305128   4280552   -24576  -0.571% 
      api       6095800   6058936   -36864  -0.605% 
      asm       4930928   4906352   -24576  -0.498% 
      buildid   2881520   2861040   -20480  -0.711% 
      cgo       4896584   4867912   -28672  -0.586% 
      compile   25868408  25770104  -98304  -0.380% 
      cover     5319656   5286888   -32768  -0.616% 
      dist      3654528   3634048   -20480  -0.560% 
      doc       4719672   4691000   -28672  -0.607% 
      fix       3418312   3393736   -24576  -0.719% 
      link      6137952   6109280   -28672  -0.467% 
      nm        4250536   4225960   -24576  -0.578% 
      objdump   4665192   4636520   -28672  -0.615% 
      pack      2297488   2285200   -12288  -0.535% 
      pprof     14735332  14657508  -77824  -0.528% 
      test2json 2834952   2818568   -16384  -0.578% 
      trace     11679964  11618524  -61440  -0.526% 
      vet       8452696   8403544   -49152  -0.581% 
      
      Change-Id: I30665dce57ec7a52e7d3c6718560b3aa5b83dd0b
      Reviewed-on: https://go-review.googlesource.com/c/go/+/171760
      Run-TryBot: Josh Bleecher Snyder <josharian@gmail.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarAustin Clements <austin@google.com>
      4aeac68c
    • Josh Bleecher Snyder's avatar
      cmd/compile: move phi tighten after critical · c1544ff9
      Josh Bleecher Snyder authored
      The phi tighten pass moves rematerializable phi args
      to the immediate predecessor of the phis.
      This reduces value lifetimes for regalloc.
      
      However, the critical edge removal pass can introduce
      new blocks, which can change what a block's
      immediate precedessor is. This can result in tightened
      phi args being spilled unnecessarily.
      
      This change moves the phi tighten pass after the
      critical edge pass, when the block structure is stable.
      
      This improves the code generated for
      
      func f(s string) bool { return s == "abcde" }
      
      Before this change:
      
      "".f STEXT nosplit size=44 args=0x18 locals=0x0
      	0x0000 00000 (x.go:3)	MOVQ	"".s+16(SP), AX
      	0x0005 00005 (x.go:3)	CMPQ	AX, $5
      	0x0009 00009 (x.go:3)	JNE	40
      	0x000b 00011 (x.go:3)	MOVQ	"".s+8(SP), AX
      	0x0010 00016 (x.go:3)	CMPL	(AX), $1684234849
      	0x0016 00022 (x.go:3)	JNE	36
      	0x0018 00024 (x.go:3)	CMPB	4(AX), $101
      	0x001c 00028 (x.go:3)	SETEQ	AL
      	0x001f 00031 (x.go:3)	MOVB	AL, "".~r1+24(SP)
      	0x0023 00035 (x.go:3)	RET
      	0x0024 00036 (x.go:3)	XORL	AX, AX
      	0x0026 00038 (x.go:3)	JMP	31
      	0x0028 00040 (x.go:3)	XORL	AX, AX
      	0x002a 00042 (x.go:3)	JMP	31
      
      Observe the duplicated blocks at the end.
      After this change:
      
      "".f STEXT nosplit size=40 args=0x18 locals=0x0
      	0x0000 00000 (x.go:3)	MOVQ	"".s+16(SP), AX
      	0x0005 00005 (x.go:3)	CMPQ	AX, $5
      	0x0009 00009 (x.go:3)	JNE	36
      	0x000b 00011 (x.go:3)	MOVQ	"".s+8(SP), AX
      	0x0010 00016 (x.go:3)	CMPL	(AX), $1684234849
      	0x0016 00022 (x.go:3)	JNE	36
      	0x0018 00024 (x.go:3)	CMPB	4(AX), $101
      	0x001c 00028 (x.go:3)	SETEQ	AL
      	0x001f 00031 (x.go:3)	MOVB	AL, "".~r1+24(SP)
      	0x0023 00035 (x.go:3)	RET
      	0x0024 00036 (x.go:3)	XORL	AX, AX
      	0x0026 00038 (x.go:3)	JMP	31
      
      Change-Id: I12c81aa53b89456cb5809aa5396378245f3beda9
      Reviewed-on: https://go-review.googlesource.com/c/go/+/172597
      Run-TryBot: Josh Bleecher Snyder <josharian@gmail.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarKeith Randall <khr@golang.org>
      c1544ff9
    • Bryan C. Mills's avatar
      {,cmd/}vendor: rerun 'go mod vendor' to prune ignored files · d68ac591
      Bryan C. Mills authored
      Updates #31088
      
      Change-Id: Ia126e4e83ac5cb12c2c4151d5e5c975497598f24
      Reviewed-on: https://go-review.googlesource.com/c/go/+/172979Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      d68ac591
    • Bryan C. Mills's avatar
      cmd/go/internal/modcmd: skip files with the "ignore" constraint in 'go mod vendor' · 7f161265
      Bryan C. Mills authored
      'go mod vendor' already drops test files and testdata directories, so
      users should not expect the vendored module to include unnecessary
      files in general.
      
      Files tagged "ignore" are typically only used to refresh or regenerate
      source files within the module to be vendored, so users of that module
      do not need them.
      
      Fixes #31088
      
      Change-Id: I1ce9545e9b37c8e779a1826a9d494ac29d2cbfb8
      Reviewed-on: https://go-review.googlesource.com/c/go/+/172978
      Run-TryBot: Bryan C. Mills <bcmills@google.com>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      7f161265
    • LE Manh Cuong's avatar
      cmd/compile: remove unused func nodfltconst · bdd7bb55
      LE Manh Cuong authored
      Its only usage was removed in golang.org/cl/103860
      
      Change-Id: I2a230b9475b0aadf3892b89f5e4ee6d4c5b70394
      Reviewed-on: https://go-review.googlesource.com/c/go/+/172917Reviewed-by: default avatarKeith Randall <khr@golang.org>
      Run-TryBot: Keith Randall <khr@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      bdd7bb55
  4. 18 Apr, 2019 4 commits