1. 31 Mar, 2017 24 commits
    • Robert Griesemer's avatar
      cmd/compile: use std "DO NOT EDIT" comment for generated files · 9e28ea0c
      Robert Griesemer authored
      Also: Fix (testdata/gen/) copyGen.go, zeroGen.go, and arithConstGen.go
      to actually match (testdata/) copy.go, zero.go, and arithConst.go, all
      of which were manually edited in https://go-review.googlesource.com/20823
      and https://go-review.googlesource.com/22748 despite the 'do not edit'
      (or perhaps because it was missing in the case of arithConst.go).
      
      For #13560.
      
      Change-Id: I366e1b521e51885e0d318ae848760e5e14ccd488
      Reviewed-on: https://go-review.googlesource.com/39172Reviewed-by: default avatarRob Pike <r@golang.org>
      9e28ea0c
    • Josh Bleecher Snyder's avatar
      runtime/race: print output when TestRace parsing fails · 654c977b
      Josh Bleecher Snyder authored
      Change-Id: I986f0c106e059455874692f5bfe2b5af25cf470e
      Reviewed-on: https://go-review.googlesource.com/39090
      Run-TryBot: Josh Bleecher Snyder <josharian@gmail.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      654c977b
    • Josh Bleecher Snyder's avatar
      cmd/compile: catch and report nowritebarrier violations later · 0323895c
      Josh Bleecher Snyder authored
      Prior to this CL, the SSA backend reported violations
      of the //go:nowritebarrier annotation immediately.
      This necessitated emitting errors during SSA compilation,
      which is not compatible with a concurrent backend.
      
      Instead, check for such violations later.
      We already save the data required to do a late check
      for violations of the //go:nowritebarrierrec annotation.
      Use the same data, and check //go:nowritebarrier at the same time.
      
      One downside to doing this is that now only a single
      violation will be reported per function.
      Given that this is for the runtime only,
      and violations are rare, this seems an acceptable cost.
      
      While we are here, remove several 'nerrors != 0' checks
      that are rendered pointless.
      
      Updates #15756
      Fixes #19250 (as much as it ever can be)
      
      Change-Id: Ia44c4ad5b6fd6f804d9f88d9571cec8d23665cb3
      Reviewed-on: https://go-review.googlesource.com/38973
      Run-TryBot: Josh Bleecher Snyder <josharian@gmail.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarCherry Zhang <cherryyz@google.com>
      0323895c
    • Josh Bleecher Snyder's avatar
      cmd/compile: rework reporting of oversized stack frames · ca33e109
      Josh Bleecher Snyder authored
      We don't support stack frames over 2GB.
      Rather than detect this during backend compilation,
      check for it at the end of compilation.
      This is arguably a more accurate check anyway,
      since it takes into account the full frame,
      including local stack, arguments, and arch-specific
      rounding, although it's unlikely anyone would ever notice.
      
      Also, rather than reporting the error right away,
      take note of it and report it later, at the top level.
      This is not relevant now, but it will help with making
      the backend concurrent, as the append to the list of
      oversized functions can be cheaply protected by a plain mutex.
      
      Updates #15756
      Updates #19250
      
      Change-Id: Id3fa21906616d62e9dc66e27a17fd5f83304e96e
      Reviewed-on: https://go-review.googlesource.com/38972
      Run-TryBot: Josh Bleecher Snyder <josharian@gmail.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarCherry Zhang <cherryyz@google.com>
      ca33e109
    • Ben Shi's avatar
      cmd/compile/internal: Optimization with RBIT and REV · 8577f81a
      Ben Shi authored
      By checking GOARM in ssa/gen/ARM.rules, each intermediate operator
      can be implemented via different instruction serials.
      
      It is up to the user to choose between compitability and efficiency.
      
      The Bswap32(x) is optimized to REV(x) when GOARM >= 6.
      The CTZ(x) is optimized to CLZ(RBIT x) when GOARM == 7.
      
      Change-Id: Ie9ee645fa39333fa79ad84ed4d1cefac30422814
      Reviewed-on: https://go-review.googlesource.com/35610
      Run-TryBot: Cherry Zhang <cherryyz@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarCherry Zhang <cherryyz@google.com>
      8577f81a
    • Carlos Eduardo Seo's avatar
      math/big: Unify divWW implementation for ppc64 and ppc64le. · 4a114047
      Carlos Eduardo Seo authored
      Starting in go1.9, the minimum processor requirement for ppc64 is POWER8. So it
      may now use the same divWW implementation as ppc64le.
      
      Updates #19074
      
      Change-Id: If1a85f175cda89eee06a1024ccd468da6124c844
      Reviewed-on: https://go-review.googlesource.com/39010
      Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      Reviewed-by: default avatarLynn Boger <laboger@linux.vnet.ibm.com>
      4a114047
    • Daniel Theophanes's avatar
      database/sql: support scanning into user defined string types · 5a45a157
      Daniel Theophanes authored
      User defined numeric types such as "type Int int64" have
      been able to be scanned into without a custom scanner by
      using the reflect scan code path used to convert between
      various numeric types. Add in a path for string types
      for symmetry and least surprise.
      
      Fixes #18101
      
      Change-Id: I00553bcf021ffe6d95047eca0067ee94b54ff501
      Reviewed-on: https://go-review.googlesource.com/39031
      Run-TryBot: Daniel Theophanes <kardianos@gmail.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      5a45a157
    • Dave Cheney's avatar
      cmd/asm/internal/arch: use generic obj.Rconv function everywhere · bfd8093c
      Dave Cheney authored
      Rather than using arm64.Rconv directly in the archArm64 constructor
      use the generic obj.Rconv helper. This removes the only use of
      arm64.Rconv outside the arm64 package itself.
      
      Change-Id: I99e9e7156b52cd26dc134f610f764ec794264e2c
      Reviewed-on: https://go-review.googlesource.com/38756
      Run-TryBot: Dave Cheney <dave@cheney.net>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarJosh Bleecher Snyder <josharian@gmail.com>
      bfd8093c
    • Brad Fitzpatrick's avatar
      syscall: skip test on TestUnshareMountNameSpace permission error · 3e4afe23
      Brad Fitzpatrick authored
      TestUnshareMountNameSpace fails on arm64 due to permission problems.
      
      Skip that test for now when permission problems are encountered, so we
      don't regress elsewhere in the meantime.
      
      Updates #19698
      
      Change-Id: I9058928afa474b813652c9489f343b8957160a6c
      Reviewed-on: https://go-review.googlesource.com/39052
      Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
      Reviewed-by: default avatarJosh Bleecher Snyder <josharian@gmail.com>
      3e4afe23
    • Austin Clements's avatar
      runtime: make runtime.GC() trigger a concurrent GC · 9ffbdabd
      Austin Clements authored
      Currently runtime.GC() triggers a STW GC. For common uses in tests and
      benchmarks, it doesn't matter whether it's STW or concurrent, but for
      uses in servers for things like collecting heap profiles and
      controlling memory footprint, this pause can be a bit problem for
      latency.
      
      This changes runtime.GC() to trigger a concurrent GC. In order to
      remain as close as possible to its current meaning, we define it to
      always perform a full mark/sweep GC cycle before returning (even if
      that means it has to finish up a cycle we're in the middle of first)
      and to publish the heap profile as of the triggered mark termination.
      While it must perform a full cycle, simultaneous runtime.GC() calls
      can be consolidated into a single full cycle.
      
      Fixes #18216.
      
      Change-Id: I9088cc5deef4ab6bcf0245ed1982a852a01c44b5
      Reviewed-on: https://go-review.googlesource.com/37520
      Run-TryBot: Austin Clements <austin@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarRick Hudson <rlh@golang.org>
      9ffbdabd
    • Austin Clements's avatar
      runtime: track the number of active sweepone calls · 44ed88a5
      Austin Clements authored
      sweepone returns ^uintptr(0) when there are no more spans to *start*
      sweeping, but there may be spans being swept concurrently at the time
      and there's currently no efficient way to tell when the sweeper is
      done sweeping all the spans.
      
      We'll need this for concurrent runtime.GC(), so add a count of the
      number of active sweepone calls to make it possible to block until
      sweeping is truly done.
      
      This is also useful for more accurately printing the gcpacertrace,
      since that should be printed after all of the sweeping stats are in
      (currently we can print it slightly too early).
      
      For #18216.
      
      Change-Id: I06e6240c9e7b40aca6fd7b788bb6962107c10a0f
      Reviewed-on: https://go-review.googlesource.com/37716
      Run-TryBot: Austin Clements <austin@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarRick Hudson <rlh@golang.org>
      44ed88a5
    • Austin Clements's avatar
      runtime: don't adjust GC trigger on forced GC · 2919132e
      Austin Clements authored
      Forced GCs don't provide good information about how to adjust the GC
      trigger. Currently we avoid adjusting the trigger on forced GC because
      forced GC is also STW and we don't adjust the trigger on STW GC.
      However, this will become a problem when forced GC is concurrent.
      
      Fix this by skipping trigger adjustment if the GC was user-forced.
      
      For #18216.
      
      Change-Id: I03dfdad12ecd3cfeca4573140a0768abb29aac5e
      Reviewed-on: https://go-review.googlesource.com/38951
      Run-TryBot: Austin Clements <austin@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarRick Hudson <rlh@golang.org>
      2919132e
    • Austin Clements's avatar
      runtime: track forced GCs independent of gcMode · 29fdbcfe
      Austin Clements authored
      Currently gcMode != gcBackgroundMode implies this was a user-forced GC
      cycle. This is no longer going to be true when we make runtime.GC()
      trigger a concurrent GC, so replace this with an explicit
      work.userForced bit.
      
      For #18216.
      
      Change-Id: If7d71bbca78b5f0b35641b070f9d457f5c9a52bd
      Reviewed-on: https://go-review.googlesource.com/37519
      Run-TryBot: Austin Clements <austin@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarRick Hudson <rlh@golang.org>
      29fdbcfe
    • Austin Clements's avatar
      runtime: make debug.FreeOSMemory call runtime.GC() · 786eb5b7
      Austin Clements authored
      Currently freeOSMemory calls gcStart directly, but we really just want
      it to behave like runtime.GC() and then perform a scavenge, so make it
      call runtime.GC() rather than gcStart.
      
      For #18216.
      
      Change-Id: I548ec007afc788e87d383532a443a10d92105937
      Reviewed-on: https://go-review.googlesource.com/37518
      Run-TryBot: Austin Clements <austin@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarRick Hudson <rlh@golang.org>
      786eb5b7
    • Austin Clements's avatar
      runtime: simplify forced GC triggering · 3d58498f
      Austin Clements authored
      Now that the gcMode is no longer involved in the GC trigger condition,
      we can simplify the triggering of forced GCs. By making the trigger
      condition for forced GCs true even if gcphase is not _GCoff, we don't
      need any special case path in gcStart to ensure that forced GCs don't
      get consolidated.
      
      Change-Id: I6067a13d76e40ff2eef8fade6fc14adb0cb58ee5
      Reviewed-on: https://go-review.googlesource.com/37517
      Run-TryBot: Austin Clements <austin@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarRick Hudson <rlh@golang.org>
      3d58498f
    • Austin Clements's avatar
      runtime: generalize GC trigger · 29be3f19
      Austin Clements authored
      Currently the GC triggering condition is an awkward combination of the
      gcMode (whether or not it's gcBackgroundMode) and a boolean
      "forceTrigger" flag.
      
      Replace this with a new gcTrigger type that represents the range of
      transition predicates we need. This has several advantages:
      
      1. We can remove the awkward logic that affects the trigger behavior
         based on the gcMode. Now gcMode purely controls whether to run a
         STW GC or not and the gcTrigger controls whether this is a forced
         GC that cannot be consolidated with other GC cycles.
      
      2. We can lift the time-based triggering logic in sysmon to just
         another type of GC trigger and move the logic to the trigger test.
      
      3. This sets us up to have a cycle count-based trigger, which we'll
         use to make runtime.GC trigger concurrent GC with the desired
         consolidation properties.
      
      For #18216.
      
      Change-Id: If9cd49349579a548800f5022ae47b8128004bbfc
      Reviewed-on: https://go-review.googlesource.com/37516
      Run-TryBot: Austin Clements <austin@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarRick Hudson <rlh@golang.org>
      29be3f19
    • Austin Clements's avatar
      runtime: check transition condition before triggering periodic GC · 640cd3b3
      Austin Clements authored
      Currently sysmon triggers periodic GC if GC is not currently running
      and it's been long enough since the last GC. This misses some
      important conditions; for example, whether GC is enabled at all by
      GOGC. As a result, if GOGC is off, once we pass the timeout for
      periodic GC, sysmon will attempt to trigger a GC every 10ms. This GC
      will be a no-op because gcStart will check all of the appropriate
      conditions and do nothing, but it still goes through the motions of
      waking the forcegc goroutine and printing a gctrace line.
      
      Fix this by making sysmon call gcShouldStart to check *all* of the
      appropriate transition conditions before attempting to trigger a
      periodic GC.
      
      Fixes #19247.
      
      Change-Id: Icee5521ce175e8419f934723849853d53773af31
      Reviewed-on: https://go-review.googlesource.com/37515
      Run-TryBot: Austin Clements <austin@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarRick Hudson <rlh@golang.org>
      640cd3b3
    • Austin Clements's avatar
      runtime: simplify heap profile flushing · 1be3e76e
      Austin Clements authored
      Currently the heap profile is flushed by *either* gcSweep in STW mode
      or by gcMarkTermination in concurrent mode. Simplify this by making
      gcMarkTermination always flush the heap profile and by making gcSweep
      do one extra flush (instead of two) in STW mode.
      
      Change-Id: I62147afb2a128e1f3d92ef4bb8144c8a345f53c4
      Reviewed-on: https://go-review.googlesource.com/37715
      Run-TryBot: Austin Clements <austin@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarRick Hudson <rlh@golang.org>
      1be3e76e
    • Austin Clements's avatar
      runtime: snapshot heap profile during mark termination · eee85fc5
      Austin Clements authored
      Currently we snapshot the heap profile just *after* mark termination
      starts the world because it's a relatively expensive operation.
      However, this means any alloc or free events that happen between
      starting the world and snapshotting the heap profile can be accounted
      to the wrong cycle. In the worst case, a free can be accounted to the
      cycle before the alloc; if the heap is small, this can result
      temporarily in a negative "in use" count in the profile.
      
      Fix this without making STW more expensive by using a global heap
      profile cycle counter. This lets us split up the operation into a two
      parts: 1) a super-cheap snapshot operation that simply increments the
      global cycle counter during STW, and 2) a more expensive cleanup
      operation we can do after starting the world that frees up a slot in
      all buckets for use by the next heap profile cycle.
      
      Fixes #19311.
      
      Change-Id: I6bdafabf111c48b3d26fe2d91267f7bef0bd4270
      Reviewed-on: https://go-review.googlesource.com/37714
      Run-TryBot: Austin Clements <austin@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarRick Hudson <rlh@golang.org>
      eee85fc5
    • Austin Clements's avatar
      runtime: pull heap profile cycle into a type · 3ebe7d7d
      Austin Clements authored
      Currently memRecord has the same set of four fields repeated three
      times. Pull these into a type and use this type three times. This
      cleans up and simplifies the code a bit and will make it easier to
      switch to a globally tracked heap profile cycle for #19311.
      
      Change-Id: I414d15673feaa406a8366b48784437c642997cf2
      Reviewed-on: https://go-review.googlesource.com/37713
      Run-TryBot: Austin Clements <austin@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarRick Hudson <rlh@golang.org>
      3ebe7d7d
    • Robert Griesemer's avatar
      cmd/compile: remove confusing comment, fix comment for symExport · 42aa608f
      Robert Griesemer authored
      The symExport flag tells whether a symbol is in the export list
      already or not (and it's also used to avoid being added to that
      list). Exporting is based on that export list - no need to check
      again.
      
      Change-Id: I6056f97aa5c24a19376957da29199135c8da35f9
      Reviewed-on: https://go-review.googlesource.com/39033Reviewed-by: default avatarDave Cheney <dave@cheney.net>
      42aa608f
    • Austin Clements's avatar
      runtime: diagram flow of stats through heap profile · 673a8fdf
      Austin Clements authored
      Every time I modify heap profiling, I find myself redrawing this
      diagram, so add it to the comments. This shows how allocations and
      frees are accounted, how we arrive at consistent profile snapshots,
      and when those snapshots are published to the user.
      
      Change-Id: I106aba1200af3c773b46e24e5f50205e808e2c69
      Reviewed-on: https://go-review.googlesource.com/37514
      Run-TryBot: Austin Clements <austin@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarRick Hudson <rlh@golang.org>
      673a8fdf
    • Austin Clements's avatar
      runtime: improve TestMemStats checks · ef1829d1
      Austin Clements authored
      Now that we have a nice predicate system, improve the tests performed
      by TestMemStats. We add some more non-zero checks (now that we force a
      GC, things like NumGC must be non-zero), checks for trivial boolean
      fields, and a few more range checks.
      
      Change-Id: I6da46d33fa0ce5738407ee57d587825479413171
      Reviewed-on: https://go-review.googlesource.com/37513
      Run-TryBot: Austin Clements <austin@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarRick Hudson <rlh@golang.org>
      ef1829d1
    • Austin Clements's avatar
      runtime: make TestMemStats failure messages useful · bda74b0e
      Austin Clements authored
      Currently most TestMemStats failures dump the whole MemStats object if
      anything is amiss without telling you what is amiss, or even which
      field is wrong. This makes it hard to figure out what the actual
      problem is.
      
      Replace this with a reflection walk over MemStats and a map of
      predicates to check. If one fails, we can construct a detailed and
      descriptive error message. The predicates are a direct translation of
      the current tests.
      
      Change-Id: I5a7cafb8e6a1eeab653d2e18bb74e2245eaa5444
      Reviewed-on: https://go-review.googlesource.com/37512
      Run-TryBot: Austin Clements <austin@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarRick Hudson <rlh@golang.org>
      bda74b0e
  2. 30 Mar, 2017 16 commits