• Russ Cox's avatar
    runtime: disable preemption during software fp routines · e03dd079
    Russ Cox authored
    It's okay to preempt at ordinary function calls because
    compilers arrange that there are no live registers to save
    on entry to the function call.
    
    The software floating point routines are function calls
    masquerading as individual machine instructions. They are
    expected to keep all the registers intact. In particular,
    they are expected not to clobber all the floating point
    registers.
    
    The floating point registers are kept per-M, because they
    are not live at non-preemptive goroutine scheduling events,
    and so keeping them per-M reduces the number of 132-byte
    register blocks we are keeping in memory.
    
    Because they are per-M, allowing the goroutine to be
    rescheduled during software floating point simulation
    would mean some other goroutine could overwrite the registers
    or perhaps the goroutine would continue running on a different
    M entirely.
    
    Disallow preemption during the software floating point
    routines to make sure that a function full of floating point
    instructions has the same floating point registers throughout
    its execution.
    
    R=golang-dev, dave
    CC=golang-dev
    https://golang.org/cl/12298043
    e03dd079
Name
Last commit
Last update
api Loading commit data...
doc Loading commit data...
include Loading commit data...
lib Loading commit data...
misc Loading commit data...
src Loading commit data...
test Loading commit data...
.hgignore Loading commit data...
.hgtags Loading commit data...
AUTHORS Loading commit data...
CONTRIBUTORS Loading commit data...
LICENSE Loading commit data...
PATENTS Loading commit data...
README Loading commit data...
favicon.ico Loading commit data...
robots.txt Loading commit data...