diff options
Diffstat (limited to 'llgo/third_party/gofrontend/libgo/go/net/sys_cloexec.go')
| -rw-r--r-- | llgo/third_party/gofrontend/libgo/go/net/sys_cloexec.go | 21 |
1 files changed, 12 insertions, 9 deletions
diff --git a/llgo/third_party/gofrontend/libgo/go/net/sys_cloexec.go b/llgo/third_party/gofrontend/libgo/go/net/sys_cloexec.go index 898fb7c0c2c..ba266e6534c 100644 --- a/llgo/third_party/gofrontend/libgo/go/net/sys_cloexec.go +++ b/llgo/third_party/gofrontend/libgo/go/net/sys_cloexec.go @@ -9,24 +9,27 @@ package net -import "syscall" +import ( + "os" + "syscall" +) // Wrapper around the socket system call that marks the returned file // descriptor as nonblocking and close-on-exec. func sysSocket(family, sotype, proto int) (int, error) { // See ../syscall/exec_unix.go for description of ForkLock. syscall.ForkLock.RLock() - s, err := syscall.Socket(family, sotype, proto) + s, err := socketFunc(family, sotype, proto) if err == nil { syscall.CloseOnExec(s) } syscall.ForkLock.RUnlock() if err != nil { - return -1, err + return -1, os.NewSyscallError("socket", err) } if err = syscall.SetNonblock(s, true); err != nil { - syscall.Close(s) - return -1, err + closeFunc(s) + return -1, os.NewSyscallError("setnonblock", err) } return s, nil } @@ -39,16 +42,16 @@ func accept(s int) (int, syscall.Sockaddr, error) { // because we have put fd.sysfd into non-blocking mode. // However, a call to the File method will put it back into // blocking mode. We can't take that risk, so no use of ForkLock here. - ns, sa, err := syscall.Accept(s) + ns, sa, err := acceptFunc(s) if err == nil { syscall.CloseOnExec(ns) } if err != nil { - return -1, nil, err + return -1, nil, os.NewSyscallError("accept", err) } if err = syscall.SetNonblock(ns, true); err != nil { - syscall.Close(ns) - return -1, nil, err + closeFunc(ns) + return -1, nil, os.NewSyscallError("setnonblock", err) } return ns, sa, nil } |

