1From cee6de8d6619aeeb70f3318dfd35f2fdf5e43848 Mon Sep 17 00:00:00 2001 2From: Luis Henriques <luis-henrix@users.noreply.github.com> 3Date: Sat, 20 Nov 2021 10:09:25 +0000 4Subject: [PATCH] test/test_syscalls.c: allow EBADF in fcheck_stat() (#631) 5MIME-Version: 1.0 6Content-Type: text/plain; charset=UTF-8 7Content-Transfer-Encoding: 8bit 8 9Test test/test_examples.py::test_passthrough_hp[False] fails because, on 10kernels >= 5.14, fstat() will return -EBADF: 11 123 [check_unlinked_testfile] fcheck_stat() - fstat: Bad file descriptor 134 [check_unlinked_testfile] fcheck_stat() - fstat: Bad file descriptor 145 [check_unlinked_testfile] fcheck_stat() - fstat: Bad file descriptor 159 [check_unlinked_testfile] fcheck_stat() - fstat: Bad file descriptor 16... 17 18This patch simply whitelists the EBADF errno code. 19 20Signed-off-by: Luís Henriques <lhenriques@suse.de> 21Co-authored-by: Luís Henriques <lhenriques@suse.de> 22 23Upstream-Status: Backport [https://github.com/libfuse/libfuse/commit/cee6de8d6619aeeb70f3318dfd35f2fdf5e43848] 24Signed-off-by: Changqing Li <changqing.li@windriver.com> 25--- 26 test/test_syscalls.c | 3 ++- 27 1 file changed, 2 insertions(+), 1 deletion(-) 28 29diff --git a/test/test_syscalls.c b/test/test_syscalls.c 30index 160a2ac..65292ed 100644 31--- a/test/test_syscalls.c 32+++ b/test/test_syscalls.c 33@@ -277,7 +277,8 @@ static int fcheck_stat(int fd, int flags, struct stat *st) 34 if (flags & O_PATH) { 35 // With O_PATH fd, the server does not have to keep 36 // the inode alive so FUSE inode may be stale or bad 37- if (errno == ESTALE || errno == EIO || errno == ENOENT) 38+ if (errno == ESTALE || errno == EIO || 39+ errno == ENOENT || errno == EBADF) 40 return 0; 41 } 42 PERROR("fstat"); 43-- 442.25.1 45 46