ref: bf4f158707ebfeacb15826ad4283ff247d7d81ae
dir: /sys/src/ape/lib/ap/power/setjmp.s/
TEXT setjmp(SB), 1, $-4 MOVW LR, R4 MOVW R1, (R3) MOVW R4, 4(R3) MOVW $0, R3 RETURN TEXT sigsetjmp(SB), 1, $-4 MOVW savemask+4(FP), R4 MOVW R4, 0(R3) MOVW $_psigblocked(SB), R4 MOVW R4, 4(R3) MOVW LR, R4 MOVW R1, 8(R3) MOVW R4, 12(R3) MOVW $0, R3 RETURN TEXT longjmp(SB), 1, $-4 MOVW R3, R4 MOVW r+4(FP), R3 CMP R3, $0 BNE ok /* ansi: "longjmp(0) => longjmp(1)" */ MOVW $1, R3 /* bless their pointed heads */ ok: MOVW (R4), R1 MOVW 4(R4), R4 MOVW R4, LR BR (LR) /* * trampoline functions because the kernel smashes r1 * in the uregs given to notejmp */ TEXT __noterestore(SB), 1, $-4 MOVW R4, R3 MOVW R5, LR BR (LR)