1
0
mirror of https://github.com/golang/go synced 2024-11-20 04:04:41 -07:00
go/misc/cgo/test/issue9400/asm_arm64.s

34 lines
578 B
ArmAsm
Raw Normal View History

#include "textflag.h"
TEXT ·RewindAndSetgid(SB),NOSPLIT,$-8-0
// Save link register
MOVD R30, R9
// Rewind stack pointer so anything that happens on the stack
// will clobber the test pattern created by the caller
ADD $(1024 * 8), RSP
// Ask signaller to setgid
MOVD $·Baton(SB), R0
MOVD $1, R1
storeloop:
LDAXRW (R0), R2
STLXRW R1, (R0), R3
CBNZ R3, storeloop
// Wait for setgid completion
MOVW $0, R1
MOVW $0, R2
loop:
LDAXRW (R0), R3
CMPW R1, R3
BNE loop
STLXRW R2, (R0), R3
CBNZ R3, loop
// Restore stack
SUB $(1024 * 8), RSP
MOVD R9, R30
RET