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