syscallcompat: drop Fchmodat flags
These were silently ignored until now (!) but are rejected by Go 1.11 stdlib. Drop the flags so the tests work again, until we figure out a better solution. https://github.com/golang/go/issues/20130
This commit is contained in:
parent
91dc44c8b4
commit
658cc4aebb
@ -84,12 +84,12 @@ func Dup3(oldfd int, newfd int, flags int) (err error) {
|
|||||||
|
|
||||||
// Fchmodat syscall.
|
// Fchmodat syscall.
|
||||||
func Fchmodat(dirfd int, path string, mode uint32, flags int) (err error) {
|
func Fchmodat(dirfd int, path string, mode uint32, flags int) (err error) {
|
||||||
// Why would we ever want to call this without AT_SYMLINK_NOFOLLOW?
|
// Linux does not support passing flags to fchmodat! From the man page:
|
||||||
if flags&unix.AT_SYMLINK_NOFOLLOW == 0 {
|
// AT_SYMLINK_NOFOLLOW ... This flag is not currently implemented.
|
||||||
tlog.Warn.Printf("Fchmodat: adding missing AT_SYMLINK_NOFOLLOW flag")
|
// Linux ignores any flags, but Go stdlib rejects them with EOPNOTSUPP starting
|
||||||
flags |= unix.AT_SYMLINK_NOFOLLOW
|
// with Go 1.11. See https://github.com/golang/go/issues/20130 for more info.
|
||||||
}
|
// TODO: Use fchmodat2 once available on Linux.
|
||||||
return syscall.Fchmodat(dirfd, path, mode, flags)
|
return syscall.Fchmodat(dirfd, path, mode, 0)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fchownat syscall.
|
// Fchownat syscall.
|
||||||
|
Loading…
Reference in New Issue
Block a user