mirror of
https://github.com/ostreedev/ostree.git
synced 2025-01-25 10:04:14 +03:00
rofiles-fuse: Build using FUSE 3 if possible, falling back to FUSE 2
This adds build-time configuration logic to automatically detect and switch between libfuse 2.x and 3.x. Signed-off-by: Simon McVittie <smcv@collabora.com> Co-authored-by: Luca BRUNO <luca.bruno@coreos.com>
This commit is contained in:
parent
4d47733f98
commit
43859b58f6
6
.github/workflows/tests.yml
vendored
6
.github/workflows/tests.yml
vendored
@ -44,22 +44,24 @@ jobs:
|
|||||||
# oldstable-backports and unstable.
|
# oldstable-backports and unstable.
|
||||||
#
|
#
|
||||||
# https://hub.docker.com/_/debian
|
# https://hub.docker.com/_/debian
|
||||||
- name: Debian Stable with sign-ed25519
|
- name: Debian Stable with sign-ed25519 and FUSE 2
|
||||||
image: debian:stable-slim
|
image: debian:stable-slim
|
||||||
pre-checkout-setup: |
|
pre-checkout-setup: |
|
||||||
apt-get update
|
apt-get update
|
||||||
apt-get install -y git
|
apt-get install -y git
|
||||||
extra-packages: >-
|
extra-packages: >-
|
||||||
|
libfuse-dev
|
||||||
libsodium-dev
|
libsodium-dev
|
||||||
configure-options: >-
|
configure-options: >-
|
||||||
--with-ed25519-libsodium
|
--with-ed25519-libsodium
|
||||||
|
|
||||||
- name: Debian Stable with curl, sign-ed25519 and no gpgme
|
- name: Debian Stable with curl, sign-ed25519, no gpgme, FUSE 3
|
||||||
image: debian:stable-slim
|
image: debian:stable-slim
|
||||||
pre-checkout-setup: |
|
pre-checkout-setup: |
|
||||||
apt-get update
|
apt-get update
|
||||||
apt-get install -y git
|
apt-get install -y git
|
||||||
extra-packages: >-
|
extra-packages: >-
|
||||||
|
libfuse3-dev
|
||||||
libsodium-dev
|
libsodium-dev
|
||||||
configure-options: >-
|
configure-options: >-
|
||||||
--with-curl
|
--with-curl
|
||||||
|
@ -43,6 +43,19 @@ case "$ID" in
|
|||||||
# Ubuntu package data:
|
# Ubuntu package data:
|
||||||
# https://packages.ubuntu.com/source/impish/ostree
|
# https://packages.ubuntu.com/source/impish/ostree
|
||||||
#
|
#
|
||||||
|
# Use libfuse3-dev unless otherwise specified
|
||||||
|
case " $* " in
|
||||||
|
(*\ libfuse-dev\ *)
|
||||||
|
;;
|
||||||
|
|
||||||
|
(*\ libfuse3-dev\ *)
|
||||||
|
;;
|
||||||
|
|
||||||
|
(*)
|
||||||
|
set -- "$@" libfuse3-dev
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
# TODO: fetch this list from the Debian packaging git repository?
|
# TODO: fetch this list from the Debian packaging git repository?
|
||||||
|
|
||||||
# First construct a list of Build-Depends common to all
|
# First construct a list of Build-Depends common to all
|
||||||
|
17
configure.ac
17
configure.ac
@ -254,6 +254,7 @@ AS_IF([test x$with_ed25519_libsodium != xno], [
|
|||||||
AM_CONDITIONAL(USE_LIBSODIUM, test "x$have_libsodium" = xyes)
|
AM_CONDITIONAL(USE_LIBSODIUM, test "x$have_libsodium" = xyes)
|
||||||
|
|
||||||
LIBARCHIVE_DEPENDENCY="libarchive >= 2.8.0"
|
LIBARCHIVE_DEPENDENCY="libarchive >= 2.8.0"
|
||||||
|
FUSE3_DEPENDENCY="fuse3 >= 3.1.1"
|
||||||
# What's in RHEL7.2.
|
# What's in RHEL7.2.
|
||||||
FUSE_DEPENDENCY="fuse >= 2.9.2"
|
FUSE_DEPENDENCY="fuse >= 2.9.2"
|
||||||
|
|
||||||
@ -448,7 +449,21 @@ AC_ARG_ENABLE(rofiles-fuse,
|
|||||||
[generate rofiles-fuse helper [default=yes]])],,
|
[generate rofiles-fuse helper [default=yes]])],,
|
||||||
enable_rofiles_fuse=yes)
|
enable_rofiles_fuse=yes)
|
||||||
AS_IF([ test x$enable_rofiles_fuse != xno ], [
|
AS_IF([ test x$enable_rofiles_fuse != xno ], [
|
||||||
PKG_CHECK_MODULES(BUILDOPT_FUSE, $FUSE_DEPENDENCY)
|
PKG_CHECK_MODULES([FUSE3], [$FUSE3_DEPENDENCY],
|
||||||
|
[
|
||||||
|
FUSE_USE_VERSION=31
|
||||||
|
BUILDOPT_FUSE_CFLAGS="$FUSE3_CFLAGS"
|
||||||
|
BUILDOPT_FUSE_LIBS="$FUSE3_LIBS"
|
||||||
|
],
|
||||||
|
[PKG_CHECK_MODULES([FUSE], [$FUSE_DEPENDENCY],
|
||||||
|
[
|
||||||
|
FUSE_USE_VERSION=26
|
||||||
|
BUILDOPT_FUSE_CFLAGS="$FUSE_CFLAGS"
|
||||||
|
BUILDOPT_FUSE_LIBS="$FUSE_LIBS"
|
||||||
|
])])
|
||||||
|
AC_DEFINE_UNQUOTED([FUSE_USE_VERSION], [$FUSE_USE_VERSION], [Define to the FUSE API version])
|
||||||
|
AC_SUBST([BUILDOPT_FUSE_CFLAGS])
|
||||||
|
AC_SUBST([BUILDOPT_FUSE_LIBS])
|
||||||
], [enable_rofiles_fuse=no])
|
], [enable_rofiles_fuse=no])
|
||||||
AM_CONDITIONAL(BUILDOPT_FUSE, test x$enable_rofiles_fuse = xyes)
|
AM_CONDITIONAL(BUILDOPT_FUSE, test x$enable_rofiles_fuse = xyes)
|
||||||
|
|
||||||
|
@ -17,7 +17,11 @@
|
|||||||
* License along with this library. If not, see <https://www.gnu.org/licenses/>.
|
* License along with this library. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define FUSE_USE_VERSION 26
|
#include "config.h"
|
||||||
|
|
||||||
|
#ifndef FUSE_USE_VERSION
|
||||||
|
#error config.h needs to define FUSE_USE_VERSION
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
@ -55,7 +59,11 @@ ENSURE_RELPATH (const char *path)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
|
#if FUSE_USE_VERSION >= 31
|
||||||
|
callback_getattr (const char *path, struct stat *st_data, struct fuse_file_info *finfo)
|
||||||
|
#else
|
||||||
callback_getattr (const char *path, struct stat *st_data)
|
callback_getattr (const char *path, struct stat *st_data)
|
||||||
|
#endif
|
||||||
{
|
{
|
||||||
path = ENSURE_RELPATH (path);
|
path = ENSURE_RELPATH (path);
|
||||||
if (!*path)
|
if (!*path)
|
||||||
@ -89,8 +97,13 @@ callback_readlink (const char *path, char *buf, size_t size)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
|
#if FUSE_USE_VERSION >= 31
|
||||||
|
callback_readdir (const char *path, void *buf, fuse_fill_dir_t filler,
|
||||||
|
off_t offset, struct fuse_file_info *fi, enum fuse_readdir_flags flags)
|
||||||
|
#else
|
||||||
callback_readdir (const char *path, void *buf, fuse_fill_dir_t filler,
|
callback_readdir (const char *path, void *buf, fuse_fill_dir_t filler,
|
||||||
off_t offset, struct fuse_file_info *fi)
|
off_t offset, struct fuse_file_info *fi)
|
||||||
|
#endif
|
||||||
{
|
{
|
||||||
DIR *dp;
|
DIR *dp;
|
||||||
struct dirent *de;
|
struct dirent *de;
|
||||||
@ -123,8 +136,14 @@ callback_readdir (const char *path, void *buf, fuse_fill_dir_t filler,
|
|||||||
memset (&st, 0, sizeof (st));
|
memset (&st, 0, sizeof (st));
|
||||||
st.st_ino = de->d_ino;
|
st.st_ino = de->d_ino;
|
||||||
st.st_mode = de->d_type << 12;
|
st.st_mode = de->d_type << 12;
|
||||||
|
|
||||||
|
#if FUSE_USE_VERSION >= 31
|
||||||
|
if (filler (buf, de->d_name, &st, 0, 0))
|
||||||
|
break;
|
||||||
|
#else
|
||||||
if (filler (buf, de->d_name, &st, 0))
|
if (filler (buf, de->d_name, &st, 0))
|
||||||
break;
|
break;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
(void) closedir (dp);
|
(void) closedir (dp);
|
||||||
@ -184,11 +203,21 @@ callback_symlink (const char *from, const char *to)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
|
#if FUSE_USE_VERSION >= 31
|
||||||
|
callback_rename (const char *from, const char *to, unsigned int flags)
|
||||||
|
#else
|
||||||
callback_rename (const char *from, const char *to)
|
callback_rename (const char *from, const char *to)
|
||||||
|
#endif
|
||||||
{
|
{
|
||||||
|
#if FUSE_USE_VERSION < 31
|
||||||
|
unsigned int flags = 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
from = ENSURE_RELPATH (from);
|
from = ENSURE_RELPATH (from);
|
||||||
to = ENSURE_RELPATH (to);
|
to = ENSURE_RELPATH (to);
|
||||||
if (renameat (basefd, from, basefd, to) == -1)
|
|
||||||
|
/* This assumes Linux 3.15+ */
|
||||||
|
if (renameat2 (basefd, from, basefd, to, flags) == -1)
|
||||||
return -errno;
|
return -errno;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -299,7 +328,11 @@ verify_write_or_copyup (const char *path, const struct stat *stbuf,
|
|||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
static int
|
static int
|
||||||
|
#if FUSE_USE_VERSION >= 31
|
||||||
|
callback_chmod (const char *path, mode_t mode, struct fuse_file_info *finfo)
|
||||||
|
#else
|
||||||
callback_chmod (const char *path, mode_t mode)
|
callback_chmod (const char *path, mode_t mode)
|
||||||
|
#endif
|
||||||
{
|
{
|
||||||
PATH_WRITE_ENTRYPOINT (path);
|
PATH_WRITE_ENTRYPOINT (path);
|
||||||
|
|
||||||
@ -313,7 +346,11 @@ callback_chmod (const char *path, mode_t mode)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
|
#if FUSE_USE_VERSION >= 31
|
||||||
|
callback_chown (const char *path, uid_t uid, gid_t gid, struct fuse_file_info *finfo)
|
||||||
|
#else
|
||||||
callback_chown (const char *path, uid_t uid, gid_t gid)
|
callback_chown (const char *path, uid_t uid, gid_t gid)
|
||||||
|
#endif
|
||||||
{
|
{
|
||||||
PATH_WRITE_ENTRYPOINT (path);
|
PATH_WRITE_ENTRYPOINT (path);
|
||||||
|
|
||||||
@ -323,7 +360,11 @@ callback_chown (const char *path, uid_t uid, gid_t gid)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
|
#if FUSE_USE_VERSION >= 31
|
||||||
|
callback_truncate (const char *path, off_t size, struct fuse_file_info *finfo)
|
||||||
|
#else
|
||||||
callback_truncate (const char *path, off_t size)
|
callback_truncate (const char *path, off_t size)
|
||||||
|
#endif
|
||||||
{
|
{
|
||||||
PATH_WRITE_ENTRYPOINT (path);
|
PATH_WRITE_ENTRYPOINT (path);
|
||||||
|
|
||||||
@ -338,7 +379,11 @@ callback_truncate (const char *path, off_t size)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
|
#if FUSE_USE_VERSION >= 31
|
||||||
|
callback_utimens (const char *path, const struct timespec tv[2], struct fuse_file_info *finfo)
|
||||||
|
#else
|
||||||
callback_utimens (const char *path, const struct timespec tv[2])
|
callback_utimens (const char *path, const struct timespec tv[2])
|
||||||
|
#endif
|
||||||
{
|
{
|
||||||
/* This one isn't write-verified, we support changing times
|
/* This one isn't write-verified, we support changing times
|
||||||
* even for hardlinked files.
|
* even for hardlinked files.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user