Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/lib/librefuse lib/librefuse: Implement logging API appeared ...



details:   https://anonhg.NetBSD.org/src/rev/2309b0ca972d
branches:  trunk
changeset: 359757:2309b0ca972d
user:      pho <pho%NetBSD.org@localhost>
date:      Sat Jan 22 07:38:45 2022 +0000

description:
lib/librefuse: Implement logging API appeared on FUSE 3.7

diffstat:

 distrib/sets/lists/comp/mi |    3 +-
 lib/librefuse/Makefile     |    7 +-
 lib/librefuse/fuse_log.h   |   63 ++++++++++++++++++++++++++++
 lib/librefuse/refuse_log.c |  100 +++++++++++++++++++++++++++++++++++++++++++++
 4 files changed, 169 insertions(+), 4 deletions(-)

diffs (211 lines):

diff -r 813962832bb1 -r 2309b0ca972d distrib/sets/lists/comp/mi
--- a/distrib/sets/lists/comp/mi        Sat Jan 22 07:35:26 2022 +0000
+++ b/distrib/sets/lists/comp/mi        Sat Jan 22 07:38:45 2022 +0000
@@ -1,4 +1,4 @@
-#      $NetBSD: mi,v 1.2403 2022/01/17 22:49:43 christos Exp $
+#      $NetBSD: mi,v 1.2404 2022/01/22 07:38:45 pho Exp $
 #
 # Note: don't delete entries from here - mark them as "obsolete" instead.
 ./etc/mtree/set.comp                           comp-sys-root
@@ -992,6 +992,7 @@
 ./usr/include/fts.h                            comp-c-include
 ./usr/include/ftw.h                            comp-c-include
 ./usr/include/fuse.h                           comp-refuse-include
+./usr/include/fuse_log.h                       comp-refuse-include
 ./usr/include/fuse_lowlevel.h                  comp-refuse-include
 ./usr/include/fuse_opt.h                       comp-refuse-include
 ./usr/include/g++/ACG.h                                comp-obsolete           obsolete
diff -r 813962832bb1 -r 2309b0ca972d lib/librefuse/Makefile
--- a/lib/librefuse/Makefile    Sat Jan 22 07:35:26 2022 +0000
+++ b/lib/librefuse/Makefile    Sat Jan 22 07:38:45 2022 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: Makefile,v 1.12 2021/12/04 06:42:39 pho Exp $
+# $NetBSD: Makefile,v 1.13 2022/01/22 07:38:45 pho Exp $
 
 USE_FORT?=     yes     # data driven bugs?
 
@@ -12,10 +12,11 @@
 
 CFLAGS+=       ${FUSE_OPT_DEBUG_FLAGS}
 CPPFLAGS+=     -I${.CURDIR}
-SRCS=          refuse.c refuse_opt.c refuse_lowlevel.c
+SRCS=          refuse.c refuse_log.c refuse_lowlevel.c
+SRCS+=         refuse_opt.c
 MAN=           refuse.3
 WARNS?=                5
-INCS=           fuse.h fuse_opt.h fuse_lowlevel.h
+INCS=           fuse.h fuse_opt.h fuse_log.h fuse_lowlevel.h
 INCSDIR=        /usr/include
 
 .include <bsd.lib.mk>
diff -r 813962832bb1 -r 2309b0ca972d lib/librefuse/fuse_log.h
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/lib/librefuse/fuse_log.h  Sat Jan 22 07:38:45 2022 +0000
@@ -0,0 +1,63 @@
+/* $NetBSD: fuse_log.h,v 1.1 2022/01/22 07:39:22 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_LOG_H_)
+#define _FUSE_LOG_H_
+
+/* FUSE logging API, appeared on FUSE 3.7. */
+
+#include <stdarg.h>
+#include <sys/cdefs.h>
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+enum fuse_log_level {
+       FUSE_LOG_EMERG,
+       FUSE_LOG_ALERT,
+       FUSE_LOG_CRIT,
+       FUSE_LOG_ERR,
+       FUSE_LOG_WARNING,
+       FUSE_LOG_NOTICE,
+       FUSE_LOG_INFO,
+       FUSE_LOG_DEBUG
+};
+
+typedef void (*fuse_log_func_t)(enum fuse_log_level level, const char *fmt, va_list ap);
+
+void fuse_set_log_func(fuse_log_func_t func);
+void fuse_log(enum fuse_log_level level, const char *fmt, ...) __printflike(2, 3);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
diff -r 813962832bb1 -r 2309b0ca972d lib/librefuse/refuse_log.c
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/lib/librefuse/refuse_log.c        Sat Jan 22 07:38:45 2022 +0000
@@ -0,0 +1,100 @@
+/* $NetBSD: refuse_log.c,v 1.1 2022/01/22 07:39:22 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: refuse_log.c,v 1.1 2022/01/22 07:39:22 pho Exp $");
+#endif /* !lint */
+
+#include <assert.h>
+#include <fuse_log.h>
+#if defined(MULTITHREADED_REFUSE)
+#      include <pthread.h>
+#endif
+#include <stdio.h>
+
+static void
+default_log_func(enum fuse_log_level level __attribute__((__unused__)),
+                 const char *fmt, va_list ap) {
+    /* This function needs to be thread-safe. Calling vfprintf(3)
+     * should be okay because POSIX mandates locking FILE* objects
+     * internally. */
+    vfprintf(stderr, fmt, ap);
+}
+
+#if defined(MULTITHREADED_REFUSE)
+static pthread_mutex_t log_func_mutex = PTHREAD_MUTEX_INITIALIZER;
+#endif
+static fuse_log_func_t log_func = default_log_func;
+
+void
+fuse_set_log_func(fuse_log_func_t func) {
+#if defined(MULTITHREADED_REFUSE)
+    /* What we really need here is merely a memory barrier, but
+     * locking a mutex is the easiest way to achieve that. */
+    int rv;
+
+    rv = pthread_mutex_lock(&log_func_mutex);
+    assert(rv == 0);
+#endif
+
+    if (func)
+        log_func = func;
+    else
+        log_func = default_log_func;
+
+#if defined(MULTITHREADED_REFUSE)
+    rv = pthread_mutex_unlock(&log_func_mutex);
+    assert(rv == 0);
+#endif
+}
+
+void
+fuse_log(enum fuse_log_level level, const char *fmt, ...) {
+    va_list ap;
+#if defined(MULTITHREADED_REFUSE)
+    /* What we really need here is merely a memory barrier, but
+     * locking a mutex is the easiest way to achieve that. */
+    int rv;
+
+    rv = pthread_mutex_lock(&log_func_mutex);
+    assert(rv == 0);
+#endif
+
+    va_start(ap, fmt);
+    log_func(level, fmt, ap);
+    va_end(ap);
+
+#if defined(MULTITHREADED_REFUSE)
+    rv = pthread_mutex_unlock(&log_func_mutex);
+    assert(rv == 0);
+#endif
+}



Home | Main Index | Thread Index | Old Index