aboutsummaryrefslogtreecommitdiff
path: root/src/syscall
diff options
context:
space:
mode:
authorAndy Pan <panjf2000@gmail.com>2024-02-01 09:07:43 +0800
committerGopher Robot <gobot@golang.org>2024-03-04 17:26:21 +0000
commitdff3a00ceaf63385bcde984e1ce7013e0d6ab7c3 (patch)
treeb36b746387da88879e66452621d0ff5510e98caa /src/syscall
parent5cbea577533dd15a7fcb7c8962f41e179931f14e (diff)
downloadgo-dff3a00ceaf63385bcde984e1ce7013e0d6ab7c3.tar.xz
syscall: call internal/runtime/syscall.Syscall6 in RawSyscall6
For #65355 Change-Id: I9168d9a767e3b2ece65ac6dcab6827ab6f6b11bb Reviewed-on: https://go-review.googlesource.com/c/go/+/560136 Reviewed-by: Michael Knyszek <mknyszek@google.com> LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com> Reviewed-by: Michael Pratt <mpratt@google.com> Auto-Submit: Ian Lance Taylor <iant@golang.org>
Diffstat (limited to 'src/syscall')
-rw-r--r--src/syscall/syscall_linux.go22
1 files changed, 13 insertions, 9 deletions
diff --git a/src/syscall/syscall_linux.go b/src/syscall/syscall_linux.go
index 7186d13748..6547c517a7 100644
--- a/src/syscall/syscall_linux.go
+++ b/src/syscall/syscall_linux.go
@@ -13,17 +13,11 @@ package syscall
import (
"internal/itoa"
+ runtimesyscall "internal/runtime/syscall"
"runtime"
"unsafe"
)
-// N.B. RawSyscall6 is provided via linkname by internal/runtime/syscall.
-//
-// Errno is uintptr and thus compatible with the internal/runtime/syscall
-// definition.
-
-func RawSyscall6(trap, a1, a2, a3, a4, a5, a6 uintptr) (r1, r2 uintptr, err Errno)
-
// Pull in entersyscall/exitsyscall for Syscall/Syscall6.
//
// Note that this can't be a push linkname because the runtime already has a
@@ -40,8 +34,7 @@ func runtime_exitsyscall()
// N.B. For the Syscall functions below:
//
// //go:uintptrkeepalive because the uintptr argument may be converted pointers
-// that need to be kept alive in the caller (this is implied for RawSyscall6
-// since it has no body).
+// that need to be kept alive in the caller.
//
// //go:nosplit because stack copying does not account for uintptrkeepalive, so
// the stack must not grow. Stack copying cannot blindly assume that all
@@ -64,6 +57,17 @@ func RawSyscall(trap, a1, a2, a3 uintptr) (r1, r2 uintptr, err Errno) {
//go:uintptrkeepalive
//go:nosplit
+//go:norace
+//go:linkname RawSyscall6
+func RawSyscall6(trap, a1, a2, a3, a4, a5, a6 uintptr) (r1, r2 uintptr, err Errno) {
+ var errno uintptr
+ r1, r2, errno = runtimesyscall.Syscall6(trap, a1, a2, a3, a4, a5, a6)
+ err = Errno(errno)
+ return
+}
+
+//go:uintptrkeepalive
+//go:nosplit
//go:linkname Syscall
func Syscall(trap, a1, a2, a3 uintptr) (r1, r2 uintptr, err Errno) {
runtime_entersyscall()