Module Name:    src
Committed By:   pho
Date:           Sat Jan 22 07:57:31 UTC 2022

Modified Files:
        src/distrib/sets/lists/comp: mi
        src/lib/librefuse: fuse.h refuse.c
        src/lib/librefuse/refuse: Makefile.inc
Added Files:
        src/lib/librefuse/refuse: legacy.c legacy.h

Log Message:
lib/librefuse: Add support for legacy types and functions


To generate a diff of this commit:
cvs rdiff -u -r1.2407 -r1.2408 src/distrib/sets/lists/comp/mi
cvs rdiff -u -r1.27 -r1.28 src/lib/librefuse/fuse.h
cvs rdiff -u -r1.104 -r1.105 src/lib/librefuse/refuse.c
cvs rdiff -u -r1.3 -r1.4 src/lib/librefuse/refuse/Makefile.inc
cvs rdiff -u -r0 -r1.1 src/lib/librefuse/refuse/legacy.c \
    src/lib/librefuse/refuse/legacy.h

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/distrib/sets/lists/comp/mi
diff -u src/distrib/sets/lists/comp/mi:1.2407 src/distrib/sets/lists/comp/mi:1.2408
--- src/distrib/sets/lists/comp/mi:1.2407	Sat Jan 22 07:56:15 2022
+++ src/distrib/sets/lists/comp/mi	Sat Jan 22 07:57:30 2022
@@ -1,4 +1,4 @@
-#	$NetBSD: mi,v 1.2407 2022/01/22 07:56:15 pho Exp $
+#	$NetBSD: mi,v 1.2408 2022/01/22 07:57:30 pho Exp $
 #
 # Note: don't delete entries from here - mark them as "obsolete" instead.
 ./etc/mtree/set.comp				comp-sys-root
@@ -3093,6 +3093,7 @@
 ./usr/include/readline/history.h		comp-c-include
 ./usr/include/readline/readline.h		comp-c-include
 ./usr/include/refuse/buf.h			comp-refuse-include
+./usr/include/refuse/legacy.h			comp-refuse-include
 ./usr/include/refuse/poll.h			comp-refuse-include
 ./usr/include/refuse/session.h			comp-refuse-include
 ./usr/include/regex.h				comp-c-include

Index: src/lib/librefuse/fuse.h
diff -u src/lib/librefuse/fuse.h:1.27 src/lib/librefuse/fuse.h:1.28
--- src/lib/librefuse/fuse.h:1.27	Sat Jan 22 07:56:16 2022
+++ src/lib/librefuse/fuse.h	Sat Jan 22 07:57:30 2022
@@ -1,4 +1,4 @@
-/* $NetBSD: fuse.h,v 1.27 2022/01/22 07:56:16 pho Exp $ */
+/* $NetBSD: fuse.h,v 1.28 2022/01/22 07:57:30 pho Exp $ */
 
 /*
  * Copyright © 2007 Alistair Crooks.  All rights reserved.
@@ -31,6 +31,7 @@
 #define FUSE_H_	20211204
 
 #include <refuse/buf.h>
+#include <refuse/legacy.h>
 #include <refuse/poll.h>
 #include <refuse/session.h>
 #include <sys/cdefs.h>
@@ -110,7 +111,6 @@ struct fuse_args {
  */
 #define FUSE_ARGS_INIT(argc, argv) { argc, argv, 0 }
 
-typedef struct puffs_fuse_dirh *fuse_dirh_t;
 
 typedef int (*fuse_fill_dir_t)(void *, const char *, const struct stat *, off_t);
 typedef int (*fuse_dirfil_t)(fuse_dirh_t, const char *, int, ino_t);
@@ -166,6 +166,8 @@ struct fuse_operations {
 
 struct fuse *fuse_new(struct fuse_args *,
 	const struct fuse_operations *, size_t, void *);
+/* Invalidate cache for a given path. Appeared on FUSE 3.2. */
+int fuse_invalidate_path(struct fuse *fuse, const char *path);
 
 int fuse_mount(struct fuse *, const char *);
 void fuse_unmount(struct fuse *);

Index: src/lib/librefuse/refuse.c
diff -u src/lib/librefuse/refuse.c:1.104 src/lib/librefuse/refuse.c:1.105
--- src/lib/librefuse/refuse.c:1.104	Sat Jan 22 07:53:06 2022
+++ src/lib/librefuse/refuse.c	Sat Jan 22 07:57:30 2022
@@ -1,4 +1,4 @@
-/*	$NetBSD: refuse.c,v 1.104 2022/01/22 07:53:06 pho Exp $	*/
+/*	$NetBSD: refuse.c,v 1.105 2022/01/22 07:57:30 pho Exp $	*/
 
 /*
  * Copyright © 2007 Alistair Crooks.  All rights reserved.
@@ -31,7 +31,7 @@
 
 #include <sys/cdefs.h>
 #if !defined(lint)
-__RCSID("$NetBSD: refuse.c,v 1.104 2022/01/22 07:53:06 pho Exp $");
+__RCSID("$NetBSD: refuse.c,v 1.105 2022/01/22 07:57:30 pho Exp $");
 #endif /* !lint */
 
 /* We emit a compiler warning for anyone including <fuse.h> without
@@ -1392,7 +1392,24 @@ fuse_unmount_compat22(const char *mp)
 }
 
 int
+fuse_invalidate_path(struct fuse *fuse __attribute__((__unused__)),
+		     const char *path __attribute__((__unused__)))
+{
+    /* ReFUSE doesn't cache anything at the moment. No need to do
+     * anything. */
+    return -ENOENT;
+}
+
+int
 fuse_version(void)
 {
 	return FUSE_VERSION;
 }
+
+/* This is a legacy function that has been removed from the FUSE API,
+ * but is defined here because it needs to access refuse_opts. */
+int
+fuse_is_lib_option(const char *opt)
+{
+	return fuse_opt_match(refuse_opts, opt);
+}

Index: src/lib/librefuse/refuse/Makefile.inc
diff -u src/lib/librefuse/refuse/Makefile.inc:1.3 src/lib/librefuse/refuse/Makefile.inc:1.4
--- src/lib/librefuse/refuse/Makefile.inc:1.3	Sat Jan 22 07:56:16 2022
+++ src/lib/librefuse/refuse/Makefile.inc	Sat Jan 22 07:57:30 2022
@@ -1,11 +1,13 @@
-# $NetBSD: Makefile.inc,v 1.3 2022/01/22 07:56:16 pho Exp $
+# $NetBSD: Makefile.inc,v 1.4 2022/01/22 07:57:30 pho Exp $
 
 .PATH: ${.CURDIR}/refuse
 
 SRCS+=	buf.c
+SRCS+=	legacy.c
 SRCS+=	poll.c
 SRCS+=	session.c
 
 INCS+=	refuse/buf.h
+INCS+=	refuse/legacy.h
 INCS+=	refuse/poll.h
 INCS+=	refuse/session.h

Added files:

Index: src/lib/librefuse/refuse/legacy.c
diff -u /dev/null src/lib/librefuse/refuse/legacy.c:1.1
--- /dev/null	Sat Jan 22 07:57:31 2022
+++ src/lib/librefuse/refuse/legacy.c	Sat Jan 22 07:57:30 2022
@@ -0,0 +1,54 @@
+/* $NetBSD: legacy.c,v 1.1 2022/01/22 07:57:30 pho Exp $ */
+
+/*
+ * Copyright (c) 2021 The NetBSD Foundation, Inc.
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ * 3. The name of the author may not be used to endorse or promote
+ *    products derived from this software without specific prior written
+ *    permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS
+ * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
+ * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
+ * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
+ * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#include <sys/cdefs.h>
+#if !defined(lint)
+__RCSID("$NetBSD: legacy.c,v 1.1 2022/01/22 07:57:30 pho Exp $");
+#endif /* !lint */
+
+#include <errno.h>
+#include <fuse_internal.h>
+
+int
+fuse_invalidate(struct fuse *fuse __attribute__((__unused__)),
+                const char *path __attribute__((__unused__)))
+{
+    int res = fuse_invalidate_path(fuse, path);
+
+    switch (res) {
+    case -ENOENT:
+        /* There was no entry to be invalidated. This isn't an
+         * error. */
+        return 0;
+    default:
+        return res;
+    }
+}
Index: src/lib/librefuse/refuse/legacy.h
diff -u /dev/null src/lib/librefuse/refuse/legacy.h:1.1
--- /dev/null	Sat Jan 22 07:57:31 2022
+++ src/lib/librefuse/refuse/legacy.h	Sat Jan 22 07:57:30 2022
@@ -0,0 +1,93 @@
+/* $NetBSD: legacy.h,v 1.1 2022/01/22 07:57:30 pho Exp $ */
+
+/*
+ * Copyright (c) 2021 The NetBSD Foundation, Inc.
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ * 3. The name of the author may not be used to endorse or promote
+ *    products derived from this software without specific prior written
+ *    permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS
+ * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
+ * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
+ * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
+ * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+#if !defined(_FUSE_LEGACY_H_)
+#define _FUSE_LEGACY_H_
+
+#include <sys/fstypes.h>
+
+/* Legacy data types and functions that had once existed but have been
+ * removed from the FUSE API. */
+
+#if !defined(FUSE_H_)
+#  error Do not include this header directly. Include <fuse.h> instead.
+#endif
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/* statfs structure used by FUSE < 1.9. On 2.1 it's been replaced with
+ * "struct statfs" and later replaced again with struct statvfs on
+ * 2.5. */
+struct fuse_statfs {
+	long block_size;
+	long blocks;
+	long blocks_free;
+	long files;
+	long files_free;
+	long namelen;
+};
+
+/* Linux-specific struct statfs; used by FUSE >= 2.1 && < 2.5. */
+struct statfs {
+	long		f_type;
+	long		f_bsize;
+	fsblkcnt_t	f_blocks;
+	fsblkcnt_t	f_bfree;
+	fsblkcnt_t	f_bavail;
+	fsfilcnt_t	f_files;
+	fsfilcnt_t	f_ffree;
+	fsid_t		f_fsid;
+	long		f_namelen;
+	long		f_frsize;
+	long		f_flags;
+};
+
+/* Handle for a getdir() operation. Removed as of FUSE 3.0. */
+typedef void *fuse_dirh_t;
+
+/* Enable debugging output. Removed on FUSE 3.0. */
+#define FUSE_DEBUG	(1 << 1)
+
+/* Invalidate cached data of a file. Added on FUSE 1.9 and removed on
+ * FUSE 3.0. Not to be confused with fuse_invalidate_path() appeared
+ * on FUSE 3.2. */
+int fuse_invalidate(struct fuse *f, const char *path);
+
+/* Check whether a mount option should be passed to the kernel or the
+ * library. Added on FUSE 1.9 and removed on FUSE 3.0. */
+int fuse_is_lib_option(const char *opt);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif

Reply via email to