Text file
src/syscall/asm_linux_arm64.s
1 // Copyright 2015 The Go Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style
3 // license that can be found in the LICENSE file.
4
5 #include "textflag.h"
6
7 // func rawVforkSyscall(trap, a1, a2, a3 uintptr) (r1, err uintptr)
8 TEXT ·rawVforkSyscall(SB),NOSPLIT,$0-48
9 MOVD a1+8(FP), R0
10 MOVD a2+16(FP), R1
11 MOVD a3+24(FP), R2
12 MOVD $0, R3
13 MOVD $0, R4
14 MOVD $0, R5
15 MOVD trap+0(FP), R8 // syscall entry
16 SVC
17 CMN $4095, R0
18 BCC ok
19 MOVD $-1, R4
20 MOVD R4, r1+32(FP) // r1
21 NEG R0, R0
22 MOVD R0, err+40(FP) // errno
23 RET
24 ok:
25 MOVD R0, r1+32(FP) // r1
26 MOVD ZR, err+40(FP) // errno
27 RET
28
29 // func rawSyscallNoError(trap uintptr, a1, a2, a3 uintptr) (r1, r2 uintptr);
30 TEXT ·rawSyscallNoError(SB),NOSPLIT,$0-48
31 MOVD a1+8(FP), R0
32 MOVD a2+16(FP), R1
33 MOVD a3+24(FP), R2
34 MOVD $0, R3
35 MOVD $0, R4
36 MOVD $0, R5
37 MOVD trap+0(FP), R8 // syscall entry
38 SVC
39 MOVD R0, r1+32(FP)
40 MOVD R1, r2+40(FP)
41 RET
42
View as plain text