• Austin Clements's avatar
    runtime: don't hold global gcBitsArenas lock over allocation · 6c4a8d19
    Austin Clements authored
    Currently, newArena holds the gcBitsArenas lock across allocating
    memory from the OS for a new gcBits arena. This is a global lock and
    allocating physical memory can be expensive, so this has the potential
    to cause high lock contention, especially since every single span
    sweep operation calls newArena (via newMarkBits).
    
    Improve the situation by temporarily dropping the lock across
    allocation. This means the caller now has to revalidate its
    assumptions after the lock is dropped, so this also factors out that
    code path and reinvokes it after the lock is acquired.
    
    Change-Id: I1113200a954ab4aad16b5071512583cfac744bdc
    Reviewed-on: https://go-review.googlesource.com/34594
    Run-TryBot: Austin Clements <austin@google.com>
    Reviewed-by: 's avatarRick Hudson <rlh@golang.org>
    6c4a8d19
Name
Last commit
Last update
.github Loading commit data...
api Loading commit data...
doc Loading commit data...
lib/time Loading commit data...
misc Loading commit data...
src Loading commit data...
test Loading commit data...
.gitattributes Loading commit data...
.gitignore Loading commit data...
AUTHORS Loading commit data...
CONTRIBUTING.md Loading commit data...
CONTRIBUTORS Loading commit data...
LICENSE Loading commit data...
PATENTS Loading commit data...
README.md Loading commit data...
favicon.ico Loading commit data...
robots.txt Loading commit data...