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:
Jakob Unterwurzacher 2018-08-26 13:00:00 +02:00
parent 91dc44c8b4
commit 658cc4aebb

View File

@ -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.