commit:     5edfb351c0192a34bbbbacd38a9c7fb7de1cf26d
Author:     Kai Krakow <kai <AT> kaishome <DOT> de>
AuthorDate: Thu Nov 28 21:33:53 2019 +0000
Commit:     Joonas Niilola <juippis <AT> gentoo <DOT> org>
CommitDate: Sat Nov 30 07:48:55 2019 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5edfb351

sys-fs/bees: Bump to v0.6.1-r2

Closes: https://bugs.gentoo.org/701422
Package-Manager: Portage-2.3.76, Repoman-2.3.16
Signed-off-by: Kai Krakow <kai <AT> kaishome.de>
Signed-off-by: Joonas Niilola <juippis <AT> gentoo.org>

 sys-fs/bees/bees-0.6.1-r2.ebuild                   | 98 ++++++++++++++++++++++
 ...cess-Fix-gettid-ambiguity-with-glibc-2.30.patch | 97 +++++++++++++++++++++
 2 files changed, 195 insertions(+)

diff --git a/sys-fs/bees/bees-0.6.1-r2.ebuild b/sys-fs/bees/bees-0.6.1-r2.ebuild
new file mode 100644
index 00000000000..38c83939e49
--- /dev/null
+++ b/sys-fs/bees/bees-0.6.1-r2.ebuild
@@ -0,0 +1,98 @@
+# Copyright 1999-2019 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=7
+
+inherit linux-info systemd
+
+DESCRIPTION="Best-Effort Extent-Same, a btrfs dedup agent"
+HOMEPAGE="https://github.com/Zygo/bees";
+
+if [[ ${PV} == "9999" ]] ; then
+       EGIT_REPO_URI="https://github.com/Zygo/bees.git";
+       inherit git-r3
+else
+       SRC_URI="https://github.com/Zygo/bees/archive/v${PV}.tar.gz -> 
${P}.tar.gz"
+       KEYWORDS="~amd64"
+fi
+
+LICENSE="GPL-3"
+SLOT="0"
+IUSE="tools"
+
+DEPEND="
+       >=sys-apps/util-linux-2.30.2
+       >=sys-fs/btrfs-progs-4.20.2
+"
+RDEPEND="${DEPEND}"
+
+CONFIG_CHECK="~BTRFS_FS"
+ERROR_BTRFS_FS="CONFIG_BTRFS_FS: bees does currently only work with btrfs"
+
+PATCHES=(
+       
"${FILESDIR}/6001-lib-fix-non-local-lambda-expression-cannot-have-a-ca.patch"
+       
"${FILESDIR}/6002-context-workaround-to-prevent-LOGICAL_INO-and-btrfs-.patch"
+       "${FILESDIR}/6003-process-Fix-gettid-ambiguity-with-glibc-2.30.patch"
+)
+
+pkg_pretend() {
+       if [[ ${MERGE_TYPE} != buildonly ]]; then
+               if kernel_is -lt 4 4 3; then
+                       ewarn "Kernel versions below 4.4.3 lack critical 
features needed for bees to"
+                       ewarn "properly operate, so it won't work. It's 
recommended to run at least"
+                       ewarn "kernel version 4.11 for best performance and 
reliability."
+                       ewarn
+               elif kernel_is -lt 4 11; then
+                       ewarn "With kernel versions below 4.11, bees may 
severely degrade system performance"
+                       ewarn "and responsiveness. Especially, the kernel may 
deadlock while bees is"
+                       ewarn "running, it's recommended to run at least kernel 
4.11."
+                       ewarn
+               elif kernel_is -lt 4 14 29; then
+                       ewarn "With kernel versions below 4.14.29, bees may 
generate a lot of bogus WARN_ON()"
+                       ewarn "messages in the kernel log. These messages can 
be ignored and this is fixed"
+                       ewarn "with more recent kernels:"
+                       ewarn "# WARNING: CPU: 3 PID: 18172 at 
fs/btrfs/backref.c:1391 find_parent_nodes+0xc41/0x14e0"
+                       ewarn
+               fi
+
+               if kernel_is -lt 5 3 4; then
+                       ewarn "With kernel versions below 5.3.4, bees may 
trigger a btrfs bug when running"
+                       ewarn "btrfs-balance in parallel. This may lead to 
meta-data corruption in the worst"
+                       ewarn "case. Especially, kernels 5.1.21 and 5.2.21 
should be avoided. Kernels 5.0.x"
+                       ewarn "after 5.0.21 should be safe. In the best case, 
affected kernels may force"
+                       ewarn "the device RO without writing corrupted 
meta-data. More details:"
+                       ewarn 
"https://github.com/Zygo/bees/blob/master/docs/btrfs-kernel.md";
+                       ewarn
+               fi
+
+               if kernel_is -lt 5 0 4; then
+                       ewarn "IMPORTANT: With kernel versions below 5.0.4, you 
may experience data corruption"
+                       ewarn "due to bees using compression in btrfs. You are 
adviced to use a chronologically"
+                       ewarn "later kernel, that includes older LTS versions 
released after 5.0.4:"
+                       ewarn "Fixed in: 5.1+, 5.0.4+, 4.19.31+, 4.14.108+, 
4.9.165+, 4.4.177+, 3.18.137+"
+                       ewarn "# commit 8e92821 btrfs: fix corruption reading 
shared and compressed extents after hole punching"
+                       ewarn
+               fi
+
+               elog "Bees recommends running the latest current kernel for 
performance and"
+               elog "reliability reasons, see README.md."
+       fi
+}
+
+src_configure() {
+       cat >localconf <<-EOF || die
+               LIBEXEC_PREFIX=/usr/libexec
+               PREFIX=/usr
+               LIBDIR="$(get_libdir)"
+               SYSTEMD_SYSTEM_UNIT_DIR="$(systemd_get_systemunitdir)"
+               DEFAULT_MAKE_TARGET=all
+       EOF
+       if [[ ${PV} != "9999" ]] ; then
+               cat >>localconf <<-EOF || die
+                       BEES_VERSION=v${PV}
+               EOF
+       fi
+       if use tools; then
+               echo OPTIONAL_INSTALL_TARGETS=install_tools >>localconf || die
+       fi
+}

diff --git 
a/sys-fs/bees/files/6003-process-Fix-gettid-ambiguity-with-glibc-2.30.patch 
b/sys-fs/bees/files/6003-process-Fix-gettid-ambiguity-with-glibc-2.30.patch
new file mode 100644
index 00000000000..9f53e5b37da
--- /dev/null
+++ b/sys-fs/bees/files/6003-process-Fix-gettid-ambiguity-with-glibc-2.30.patch
@@ -0,0 +1,97 @@
+From 0b7cf9c0f11722c7cb8a816e9118602b43d9a3f5 Mon Sep 17 00:00:00 2001
+From: Zygo Blaxell <[email protected]>
+Date: Tue, 29 Oct 2019 23:34:36 -0400
+Subject: [PATCH 3/3] process: Fix gettid() ambiguity with glibc >= 2.30
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+In version 2.30 glibc added it's own gettid() function. This resulted in
+"error: call of overloaded ‘gettid()’ is ambiguous" because gettid()
+now exists in both namespace crucible and std.
+
+For now, use explicit references to namespace crucible.  This continues
+to work with new and old libc without having to test specific library
+versions.
+
+At some point, glibc gettid() will be deployed widely enough that we can
+remove the crucible version entirely.
+
+Signed-off-by: Zygo Blaxell <[email protected]>
+---
+ include/crucible/lockset.h | 4 ++--
+ lib/chatter.cc             | 4 ++--
+ src/bees.cc                | 6 +++---
+ 3 files changed, 7 insertions(+), 7 deletions(-)
+
+diff --git a/include/crucible/lockset.h b/include/crucible/lockset.h
+index 856c55e..99500b7 100644
+--- a/include/crucible/lockset.h
++++ b/include/crucible/lockset.h
+@@ -117,7 +117,7 @@ namespace crucible {
+               while (full() || locked(name)) {
+                       m_condvar.wait(lock);
+               }
+-              auto rv = m_set.insert(make_pair(name, gettid()));
++              auto rv = m_set.insert(make_pair(name, crucible::gettid()));
+               THROW_CHECK0(runtime_error, rv.second);
+       }
+ 
+@@ -129,7 +129,7 @@ namespace crucible {
+               if (full() || locked(name)) {
+                       return false;
+               }
+-              auto rv = m_set.insert(make_pair(name, gettid()));
++              auto rv = m_set.insert(make_pair(name, crucible::gettid()));
+               THROW_CHECK1(runtime_error, name, rv.second);
+               return true;
+       }
+diff --git a/lib/chatter.cc b/lib/chatter.cc
+index cbd5adb..e5a24f9 100644
+--- a/lib/chatter.cc
++++ b/lib/chatter.cc
+@@ -69,14 +69,14 @@ namespace crucible {
+                       DIE_IF_ZERO(strftime(buf, sizeof(buf), "%Y-%m-%d 
%H:%M:%S", &ltm));
+ 
+                       header_stream << buf;
+-                      header_stream << " " << getpid() << "." << gettid() << 
"<" << m_loglevel << ">";
++                      header_stream << " " << getpid() << "." << 
crucible::gettid() << "<" << m_loglevel << ">";
+                       if (!m_name.empty()) {
+                               header_stream << " " << m_name;
+                       }
+               } else {
+                       header_stream << "<" << m_loglevel << ">";
+                       header_stream << (m_name.empty() ? "thread" : m_name);
+-                      header_stream << "[" << gettid() << "]";
++                      header_stream << "[" << crucible::gettid() << "]";
+               }
+ 
+               header_stream << ": ";
+diff --git a/src/bees.cc b/src/bees.cc
+index 08c3fd7..aa55af0 100644
+--- a/src/bees.cc
++++ b/src/bees.cc
+@@ -115,9 +115,9 @@ BeesNote::~BeesNote()
+       tl_next = m_prev;
+       unique_lock<mutex> lock(s_mutex);
+       if (tl_next) {
+-              s_status[gettid()] = tl_next;
++              s_status[crucible::gettid()] = tl_next;
+       } else {
+-              s_status.erase(gettid());
++              s_status.erase(crucible::gettid());
+       }
+ }
+ 
+@@ -128,7 +128,7 @@ BeesNote::BeesNote(function<void(ostream &os)> f) :
+       m_prev = tl_next;
+       tl_next = this;
+       unique_lock<mutex> lock(s_mutex);
+-      s_status[gettid()] = tl_next;
++      s_status[crucible::gettid()] = tl_next;
+ }
+ 
+ void
+-- 
+2.23.0
+

Reply via email to