mirror of
https://github.com/golang/sys.git
synced 2026-02-08 11:46:04 +03:00
Revert "unix: add openat2 for linux"
This reverts CL 227280. Reason for revert: causes failures on ARM builders Fixes golang/go#38357 Change-Id: Ie80ff37205ff12c3b74d00ff46b7222e34363d86 Reviewed-on: https://go-review.googlesource.com/c/sys/+/227846 Run-TryBot: Andrew Bonventre <andybons@golang.org> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Bryan C. Mills <bcmills@google.com>
This commit is contained in:
@@ -107,7 +107,6 @@ struct termios2 {
|
||||
#include <linux/netfilter.h>
|
||||
#include <linux/netlink.h>
|
||||
#include <linux/nexthop.h>
|
||||
#include <linux/openat2.h>
|
||||
#include <linux/perf_event.h>
|
||||
#include <linux/random.h>
|
||||
#include <linux/rtc.h>
|
||||
@@ -835,18 +834,6 @@ const (
|
||||
AT_EACCESS = C.AT_EACCESS
|
||||
)
|
||||
|
||||
type OpenHow C.struct_open_how
|
||||
|
||||
const SizeofOpenHow = C.sizeof_struct_open_how
|
||||
|
||||
const (
|
||||
RESOLVE_BENEATH = C.RESOLVE_BENEATH
|
||||
RESOLVE_IN_ROOT = C.RESOLVE_IN_ROOT
|
||||
RESOLVE_NO_MAGICLINKS = C.RESOLVE_NO_MAGICLINKS
|
||||
RESOLVE_NO_SYMLINKS = C.RESOLVE_NO_SYMLINKS
|
||||
RESOLVE_NO_XDEV = C.RESOLVE_NO_XDEV
|
||||
)
|
||||
|
||||
type PollFd C.struct_pollfd
|
||||
|
||||
const (
|
||||
|
||||
@@ -133,12 +133,6 @@ func Openat(dirfd int, path string, flags int, mode uint32) (fd int, err error)
|
||||
return openat(dirfd, path, flags|O_LARGEFILE, mode)
|
||||
}
|
||||
|
||||
//sys openat2(dirfd int, path string, open_how *OpenHow, size int) (fd int, err error)
|
||||
|
||||
func Openat2(dirfd int, path string, how *OpenHow) (fd int, err error) {
|
||||
return openat2(dirfd, path, how, SizeofOpenHow)
|
||||
}
|
||||
|
||||
//sys ppoll(fds *PollFd, nfds int, timeout *Timespec, sigmask *Sigset_t) (n int, err error)
|
||||
|
||||
func Ppoll(fds []PollFd, timeout *Timespec, sigmask *Sigset_t) (n int, err error) {
|
||||
|
||||
@@ -663,24 +663,3 @@ func TestPrctlRetInt(t *testing.T) {
|
||||
t.Fatalf("unexpected return from prctl; got %v, expected %v", v, 1)
|
||||
}
|
||||
}
|
||||
|
||||
func TestOpenat2(t *testing.T) {
|
||||
how := &unix.OpenHow{
|
||||
Flags: unix.O_RDONLY,
|
||||
Resolve: unix.RESOLVE_NO_MAGICLINKS,
|
||||
}
|
||||
fd, err := unix.Openat2(-1, "/proc/self/fd/1", how)
|
||||
switch err {
|
||||
case nil:
|
||||
unix.Close(fd)
|
||||
t.Fatal("expected ELOOP, got nil")
|
||||
case unix.ELOOP:
|
||||
return
|
||||
case unix.ENOSYS:
|
||||
t.Skip("old kernel? (need Linux >= 5.6)")
|
||||
case unix.ENOENT:
|
||||
t.Skipf("openat2: %v, skipping test", err)
|
||||
default:
|
||||
t.Fatalf("unexpected error from openat2: %v", err)
|
||||
}
|
||||
}
|
||||
|
||||
@@ -83,22 +83,6 @@ func openat(dirfd int, path string, flags int, mode uint32) (fd int, err error)
|
||||
|
||||
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
|
||||
|
||||
func openat2(dirfd int, path string, open_how *OpenHow, size int) (fd int, err error) {
|
||||
var _p0 *byte
|
||||
_p0, err = BytePtrFromString(path)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
r0, _, e1 := Syscall6(SYS_OPENAT2, uintptr(dirfd), uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(open_how)), uintptr(size), 0, 0)
|
||||
fd = int(r0)
|
||||
if e1 != 0 {
|
||||
err = errnoErr(e1)
|
||||
}
|
||||
return
|
||||
}
|
||||
|
||||
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
|
||||
|
||||
func ppoll(fds *PollFd, nfds int, timeout *Timespec, sigmask *Sigset_t) (n int, err error) {
|
||||
r0, _, e1 := Syscall6(SYS_PPOLL, uintptr(unsafe.Pointer(fds)), uintptr(nfds), uintptr(unsafe.Pointer(timeout)), uintptr(unsafe.Pointer(sigmask)), 0, 0)
|
||||
n = int(r0)
|
||||
|
||||
@@ -691,22 +691,6 @@ const (
|
||||
AT_EACCESS = 0x200
|
||||
)
|
||||
|
||||
type OpenHow struct {
|
||||
Flags uint64
|
||||
Mode uint64
|
||||
Resolve uint64
|
||||
}
|
||||
|
||||
const SizeofOpenHow = 0x18
|
||||
|
||||
const (
|
||||
RESOLVE_BENEATH = 0x8
|
||||
RESOLVE_IN_ROOT = 0x10
|
||||
RESOLVE_NO_MAGICLINKS = 0x2
|
||||
RESOLVE_NO_SYMLINKS = 0x4
|
||||
RESOLVE_NO_XDEV = 0x1
|
||||
)
|
||||
|
||||
type PollFd struct {
|
||||
Fd int32
|
||||
Events int16
|
||||
|
||||
Reference in New Issue
Block a user