Commit e6982fad authored by Austin Clements's avatar Austin Clements

Revert "runtime: fix trigger for concurrent GC"

This reverts commit 44529d93.

Change-Id: I7671e2cd6f6a476efffa16e8110500a98258c0c1
Reviewed-on: https://go-review.googlesource.com/3130Reviewed-by: default avatarAustin Clements <austin@google.com>
parent 44529d93
...@@ -31,12 +31,10 @@ type pageID uintptr ...@@ -31,12 +31,10 @@ type pageID uintptr
// base address for all 0-byte allocations // base address for all 0-byte allocations
var zerobase uintptr var zerobase uintptr
// triggers the concurrent GC when 1/triggerratio memory is available to allocate.
// Adjust this ratio as part of a scheme to ensure that mutators have enough
// memory to allocate in durring a concurrent GC cycle.
var triggerratio = uint64(8)
// Determine whether to initiate a GC. // Determine whether to initiate a GC.
// Currently the primitive heuristic we use will start a new
// concurrent GC when approximately half the available space
// made available by the last GC cycle has been used.
// If the GC is already working no need to trigger another one. // If the GC is already working no need to trigger another one.
// This should establish a feedback loop where if the GC does not // This should establish a feedback loop where if the GC does not
// have sufficient time to complete then more memory will be // have sufficient time to complete then more memory will be
...@@ -46,7 +44,7 @@ var triggerratio = uint64(8) ...@@ -46,7 +44,7 @@ var triggerratio = uint64(8)
// A false negative simple does not start a GC, a false positive // A false negative simple does not start a GC, a false positive
// will start a GC needlessly. Neither have correctness issues. // will start a GC needlessly. Neither have correctness issues.
func shouldtriggergc() bool { func shouldtriggergc() bool {
return memstats.heap_alloc+memstats.heap_alloc/triggerratio >= memstats.next_gc && atomicloaduint(&bggc.working) == 0 return memstats.heap_alloc+memstats.heap_alloc*3/4 >= memstats.next_gc && atomicloaduint(&bggc.working) == 0
} }
// Allocate an object of size bytes. // Allocate an object of size bytes.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment