From: Tobias Klauser Date: Mon, 22 May 2023 18:37:05 +0000 (+0200) Subject: os: avoid second fcntl syscall in NewFile on unix X-Git-Tag: go1.21rc1~322 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=3c3a883667390c2f03dffb3fdcb4fa4172cb23e6;p=gostls13.git os: avoid second fcntl syscall in NewFile on unix CL 494915 introduced an additional fcntl(F_GETFL) syscall to determine whether the file is in append-only mode. The existing unix.IsNonblock call also issues an fcntl(F_GETFL) syscall. The two can be combined and both the append-only mode and the non-blocking flags can be determined from that syscall's result. Change-Id: I915589ed94e079f6abaa2fd0032ef01f78698f7f Reviewed-on: https://go-review.googlesource.com/c/go/+/497075 Reviewed-by: Ian Lance Taylor Reviewed-by: Bryan Mills Auto-Submit: Tobias Klauser TryBot-Result: Gopher Robot Run-TryBot: Tobias Klauser --- diff --git a/src/os/file_unix.go b/src/os/file_unix.go index 25ce83bf9d..a34de8333d 100644 --- a/src/os/file_unix.go +++ b/src/os/file_unix.go @@ -104,13 +104,15 @@ func (f *File) Fd() uintptr { // constraints apply. func NewFile(fd uintptr, name string) *File { kind := kindNewFile - if nb, err := unix.IsNonblock(int(fd)); err == nil && nb { - kind = kindNonBlock - } - f := newFile(fd, name, kind) + appendMode := false if flags, err := unix.Fcntl(int(fd), syscall.F_GETFL, 0); err == nil { - f.appendMode = flags&syscall.O_APPEND != 0 + if unix.HasNonblockFlag(flags) { + kind = kindNonBlock + } + appendMode = flags&syscall.O_APPEND != 0 } + f := newFile(fd, name, kind) + f.appendMode = appendMode return f }