• Austin Clements's avatar
    runtime: YIELD in procyield on ARM · bdc64183
    Austin Clements authored
    ARM currently does not use a hardware yield instruction in the spin
    loop in procyield because the YIELD instruction was only added in
    ARMv6K. However, it appears earlier ARM chips will interpret the YIELD
    encoding as an effective NOP (specifically an MSR instruction that
    ultimately has no effect on the CPSR register).
    
    Hence, use YIELD in procyield on ARM since it should be, at worst,
    harmless.
    
    Fixes #16663.
    
    Change-Id: Id1787ac48862b785b92c28f1ac84cb4908d2173d
    Reviewed-on: https://go-review.googlesource.com/45250
    Run-TryBot: Austin Clements <austin@google.com>
    TryBot-Result: Gobot Gobot <gobot@golang.org>
    Reviewed-by: 's avatarCherry Zhang <cherryyz@google.com>
    bdc64183
asm_arm.s 25.3 KB