aboutsummaryrefslogtreecommitdiff
path: root/src/os/file.go
diff options
context:
space:
mode:
authorPeter Collingbourne <pcc@google.com>2024-03-11 20:10:48 -0700
committerGopher Robot <gobot@golang.org>2024-03-16 00:34:52 +0000
commitb822f098c557ea3d9200fd2d8a2e2b4d641e83e4 (patch)
treeff5bd7207c526885f741ba5d99ee65e7a83765de /src/os/file.go
parentbedda245740d766bfad36b2d91a22781575fe463 (diff)
downloadgo-b822f098c557ea3d9200fd2d8a2e2b4d641e83e4.tar.xz
os: don't try to make the directory FD non-blocking in os.ReadDir
This will fail because epoll_ctl() fails on directory FDs, so we end up issuing unnecessary syscalls. My test program that calls filepath.WalkDir on a large directory tree runs 1.23 ± 0.04 times faster than with the original implementation. Change-Id: Ie33d798c48057a7b2d0bacac80fcdde5b5a8bb1b Reviewed-on: https://go-review.googlesource.com/c/go/+/570877 LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com> Auto-Submit: Ian Lance Taylor <iant@google.com> Reviewed-by: Ian Lance Taylor <iant@google.com>
Diffstat (limited to 'src/os/file.go')
-rw-r--r--src/os/file.go8
1 files changed, 8 insertions, 0 deletions
diff --git a/src/os/file.go b/src/os/file.go
index c0c972bbd7..fae7bf1039 100644
--- a/src/os/file.go
+++ b/src/os/file.go
@@ -380,6 +380,14 @@ func OpenFile(name string, flag int, perm FileMode) (*File, error) {
return f, nil
}
+// openDir opens a file which is assumed to be a directory. As such, it skips
+// the syscalls that make the file descriptor non-blocking as these take time
+// and will fail on file descriptors for directories.
+func openDir(name string) (*File, error) {
+ testlog.Open(name)
+ return openDirNolog(name)
+}
+
// lstat is overridden in tests.
var lstat = Lstat