From: Markus Volk <[email protected] <mailto:[email protected]>>
Snapper is a tool for Linux file system snapshot management. Apart
from
the obvious creation and deletion of snapshots it can compare
snapshots
and revert differences between them. In simple terms, this allows
root
and non-root users to view older versions of files and revert
changes.
Signed-off-by: Markus Volk <[email protected]
<mailto:[email protected]>>
Signed-off-by: Khem Raj <[email protected]
<mailto:[email protected]>>
---
v3: More fixes for musl
...x-types.h-for-__u16-__u32-__u64-type.patch | 30 ++++++++++++++
...002-Use-statvfs-instead-of-statvfs64.patch | 37
+++++++++++++++++
.../recipes-support/snapper/snapper_0.11.2.bb | 41
+++++++++++++++++++
3 files changed, 108 insertions(+)
create mode 100644
meta-oe/recipes-support/snapper/snapper/0001-Include-linux-types.h-for-__u16-__u32-__u64-type.patch
create mode 100644
meta-oe/recipes-support/snapper/snapper/0002-Use-statvfs-instead-of-statvfs64.patch
create mode 100644
meta-oe/recipes-support/snapper/snapper_0.11.2.bb
diff --git
a/meta-oe/recipes-support/snapper/snapper/0001-Include-linux-types.h-for-__u16-__u32-__u64-type.patch
b/meta-oe/recipes-support/snapper/snapper/0001-Include-linux-types.h-for-__u16-__u32-__u64-type.patch
new file mode 100644
index 0000000000..ec8594629e
--- /dev/null
+++
b/meta-oe/recipes-support/snapper/snapper/0001-Include-linux-types.h-for-__u16-__u32-__u64-type.patch
@@ -0,0 +1,30 @@
+From d103eaeae169708ca567f092182a89b79e5ab9db Mon Sep 17 00:00:00
2001
+From: Khem Raj <[email protected] <mailto:[email protected]>>
+Date: Sun, 20 Oct 2024 07:52:33 -0700
+Subject: [PATCH 1/2] Include linux/types.h for __u16/__u32/__u64
type
+
+This header is included indirectly with glibc but when using musl
+it ends up with compilation failure
+
+BcachefsUtils.cc:85:20: error: use of undeclared identifier '__u32'
+ 85 | args.dirfd = (__u32) fddst;
+ | ^
+
+Upstream-Status: Submitted
[<https://github.com/openSUSE/snapper/pull/945>]
+Signed-off-by: Khem Raj <[email protected]
<mailto:[email protected]>>
+---
+ snapper/BcachefsUtils.cc | 1 +
+ 1 file changed, 1 insertion(+)
+
+diff --git a/snapper/BcachefsUtils.cc b/snapper/BcachefsUtils.cc
+index e9163ffb..1d328a78 100644
+--- a/snapper/BcachefsUtils.cc
++++ b/snapper/BcachefsUtils.cc
+@@ -24,6 +24,7 @@
+
+ #include <cstring>
+ #include <cerrno>
++#include <linux/types.h>
+ #include <sys/stat.h>
+ #include <sys/ioctl.h>
+
diff --git
a/meta-oe/recipes-support/snapper/snapper/0002-Use-statvfs-instead-of-statvfs64.patch
b/meta-oe/recipes-support/snapper/snapper/0002-Use-statvfs-instead-of-statvfs64.patch
new file mode 100644
index 0000000000..b915fda257
--- /dev/null
+++
b/meta-oe/recipes-support/snapper/snapper/0002-Use-statvfs-instead-of-statvfs64.patch
@@ -0,0 +1,37 @@
+From 0b39f4484553c796cb300fb4933ea314e91d913b Mon Sep 17 00:00:00
2001
+From: Khem Raj <[email protected] <mailto:[email protected]>>
+Date: Sun, 20 Oct 2024 07:55:23 -0700
+Subject: [PATCH 2/2] Use statvfs instead of statvfs64
+
+when using LFS64 these functions are same and also
+on 64bit systems they are same. musl is using 64bit off_t
+by default and does not define LFS64 variants of these functions
+and it ends up in build errors
+
+Taken from Alpine Linux:
[<https://gitlab.alpinelinux.org/alpine/aports/-/blob/master/testing/snapper/statvfs64.patch>]
+
+Upstream-Status: Submitted
[<https://github.com/openSUSE/snapper/pull/945>]
+
+Signed-off-by: Markus Volk <[email protected]
<mailto:[email protected]>>
+Signed-off-by: Khem Raj <[email protected]
<mailto:[email protected]>>
+---
+ snapper/FileUtils.cc | 6 +++---
+ 1 file changed, 3 insertions(+), 3 deletions(-)
+
+diff --git a/snapper/FileUtils.cc b/snapper/FileUtils.cc
+index d4034279..4c8578a1 100644
+--- a/snapper/FileUtils.cc
++++ b/snapper/FileUtils.cc
+@@ -387,9 +387,9 @@ namespace snapper
+ std::pair<unsigned long long, unsigned long long>
+ SDir::statvfs() const
+ {
+- struct statvfs64 fsbuf;
+- if (fstatvfs64(dirfd, &fsbuf) != 0)
+- SN_THROW(IOErrorException(sformat("statvfs64 failed
path:%s errno:%d (%s)", base_path.c_str(),
++ struct statvfs fsbuf;
++ if (fstatvfs(dirfd, &fsbuf) != 0)
++ SN_THROW(IOErrorException(sformat("statvfs failed
path:%s errno:%d (%s)", base_path.c_str(),
+ errno,
stringerror(errno).c_str())));
+
+ // f_bavail is used (not f_bfree) since df seems to do the
diff --git a/meta-oe/recipes-support/snapper/snapper_0.11.2.bb
b/meta-oe/recipes-support/snapper/snapper_0.11.2.bb
new file mode 100644
index 0000000000..840c607309
--- /dev/null
+++ b/meta-oe/recipes-support/snapper/snapper_0.11.2.bb
@@ -0,0 +1,41 @@
+SUMMARY = "Snapper is a tool for Linux file system snapshot
management"
+HOMEPAGE = "<https://github.com/openSUSE/snapper>"
+LICENSE = "GPL-2.0-only"
+LIC_FILES_CHKSUM =
"file://COPYING;md5=751419260aa954499f7abaabaa882bbe"
<file://copying;md5=751419260aa954499f7abaabaa882bbe/>
+
+DEPENDS = "acl boost btrfs-tools dbus e2fsprogs json-c libxml2
lvm2 ncurses zlib"
+
+# Build separation is slightly broken
+inherit autotools-brokensep pkgconfig gettext
+
+SRC_URI = " \
+
git://github.com/openSUSE/snapper.git;protocol=https;branch=master \
+
file://0001-Include-linux-types.h-for-__u16-__u32-__u64-type.patch
<file://0001-include-linux-types.h-for-__u16-__u32-__u64-type.patch/>
\
+ file://0002-Use-statvfs-instead-of-statvfs64.patch
<file://0002-use-statvfs-instead-of-statvfs64.patch/> \
+"
+SRCREV = "6c603565f36e9996d85045c8012cd04aba5f3708"
+
+S = "${WORKDIR}/git"
+
+EXTRA_OECONF += "--disable-zypp"
+
+PACKAGECONFIG ?= "${@bb.utils.filter
<mailto:${@bb.utils.filter>('DISTRO_FEATURES', 'api-documentation
systemd pam', d)}"
+PACKAGECONFIG[pam] = "--enable-pam,--disable-pam,libpam"
+PACKAGECONFIG[systemd] = "--enable-systemd,--disable-systemd"
+PACKAGECONFIG[api-documentation] =
"--enable-doc,--disable-doc,libxslt-native
docbook-xsl-stylesheets-native"
+
+# Avoid HOSTTOOLS path in binaries
+export DIFFBIN = "${bindir}/diff"
+export RMBIN = "${bindir}/rm"
+export TOUCHBIN = "${bindir}/touch"
+export CPBIN = "${bindir}/cp"
+
+
+do_install:append() {
+ install -d ${D}${sysconfdir}/sysconfig
+ install -m0644 ${S}/data/default-config
${D}${sysconfdir}/sysconfig/snapper
+}
+
+FILES:${PN} += "${libdir}/pam_snapper ${libdir}/systemd
${libdir}/security ${datadir}"
+# bash is needed for the testsuite
+RDEPENDS:${PN} = "bash diffutils util-linux util-linux-mount"