diff options
author | iggy <iggy@theiggy.com> | 2019-10-08 18:46:37 -0700 |
---|---|---|
committer | Natanael Copa <ncopa@alpinelinux.org> | 2019-10-09 15:51:26 +0000 |
commit | 286830029a1b232dcfdbfd7db48f1a0a8377fe7b (patch) | |
tree | 8301724cb1025d54e9a861c527aae6c9948b0d94 /community | |
parent | 4baa78b267965664b1804d062d29a71a30520455 (diff) | |
download | aports-286830029a1b232dcfdbfd7db48f1a0a8377fe7b.tar.bz2 aports-286830029a1b232dcfdbfd7db48f1a0a8377fe7b.tar.xz |
main/ceph: Move ceph from community
Move ceph from community to main
This move should allow us to enable ceph support in Qemu
Diffstat (limited to 'community')
-rw-r--r-- | community/ceph/APKBUILD | 524 | ||||
-rw-r--r-- | community/ceph/allperms.patch | 13 | ||||
-rw-r--r-- | community/ceph/boost-1.70.patch | 105 | ||||
-rw-r--r-- | community/ceph/ceph-user.pre-install | 5 | ||||
-rw-r--r-- | community/ceph/musl-fixes.patch | 229 |
5 files changed, 0 insertions, 876 deletions
diff --git a/community/ceph/APKBUILD b/community/ceph/APKBUILD deleted file mode 100644 index d15cbd9da6..0000000000 --- a/community/ceph/APKBUILD +++ /dev/null @@ -1,524 +0,0 @@ -# Contributor: John Coyle <dx9err@gmail.com> -# Maintainer: Iggy Jackson <iggy@kws1.com> -pkgname=ceph -pkgver=14.2.3 -pkgrel=0 -pkgdesc="Ceph is a distributed object store and file system" -pkgusers="ceph" -pkggroups="ceph" -url="https://ceph.com/" -arch="x86_64 aarch64" -# https://github.com/ceph/ceph/blob/master/COPYING -license="LGPL-2.1-only AND LGPL-2.0-or-later AND GPL-2.0-only AND GPL-3.0-only AND CC-BY-SA-1.0 AND BSL-1.0 AND GPL-2.0 WITH Autoconf-exception-2.0 AND BSD-3-Clause AND MIT AND custom" -depends="ceph-osd ceph-mds ceph-mon" -options="!checkroot" -_base_deps=" - cryptsetup - e2fsprogs - logrotate - parted - util-linux - xfsprogs - " -_osd_daemon_deps="fuse snappy lz4-libs" -_osd_tools_deps="lz4-libs" -_ceph_volume_deps="lvm2" -_ceph_test_deps="xmlstarlet" -makedepends=" - acl-dev - argp-standalone - bc - boost-dev - btrfs-progs - bzip2-dev - cmake - coreutils - cunit-dev - curl-dev - cython3 - diffutils - eudev-dev - expat-dev - fcgi-dev - flex - fuse - fuse-dev - git - grep - gperf - jq - keyutils-dev - leveldb-dev - libaio-dev - libatomic_ops-dev - libedit-dev - openssl-dev - libtirpc-dev - libtool - libxml2-dev - linux-headers - lvm2-dev - lz4-dev - nodejs - nss-dev - oath-toolkit-dev - openldap-dev - procps - python3-dev - py3-pip - py3-nose - py3-setuptools - py3-sphinx - py3-virtualenv - rabbitmq-c-dev - readline-dev - rpcgen - snappy-dev - userspace-rcu-dev - xfsprogs-dev - xmlstarlet - yasm - $_base_deps - $_osd_daemon_deps - $_osd_tools_deps - $_ceph_volume_deps - $_ceph_test_deps -" - -source="https://download.ceph.com/tarballs/ceph_$pkgver.orig.tar.gz - allperms.patch - musl-fixes.patch - boost-1.70.patch - " -subpackages=" - $pkgname-doc - $pkgname-base - $pkgname-common - $pkgname-mds - $pkgname-mgr - $pkgname-mon - $pkgname-mon-daemon:mon_daemon - $pkgname-mon-tools:mon_tools - $pkgname-fuse:ceph_fuse - $pkgname-openrc - $pkgname-osd - $pkgname-osd-daemon:osd_daemon - $pkgname-osd-tools:osd_tools - $pkgname-volume:ceph_volume:noarch - $pkgname-radosgw - $pkgname-bash-completion:bash_completion:noarch - $pkgname-dev - $pkgname-user - rbd-fuse:rbd_fuse - rbd-mirror:rbd_mirror - rbd-nbd:rbd_nbd - librbd - libcephfs - librados - py3-rados:_py3_rados - libradosstriper - py3-rbd:_py3_rbd - py3-cephfs:_py3_cephfs -" - -_ceph_uid=167 -_ceph_gid=167 - -_prefix=/usr -_bindir=$_prefix/bin -_datadir=$_prefix/share -_docdir=$_datadir/doc -_includedir=$_prefix/include -_libdir=$_prefix/lib -_libexecdir=$_prefix/libexec -_localstatedir=/var -_mandir=$_datadir/man -_sbindir=/usr/sbin -_syssbindir=/sbin -_sysconfdir=/etc - -_udevrulesdir=/etc/udev/rules.d - -_py3_sitelib() { - python3 -c "import site; print(site.getsitepackages()[0])" -} - -build() { - export CEPH_BUILD_VIRTUALENV="$builddir" - - PY_INC_PATH="$(python3-config --includes | cut -f2 -d' ' | sed 's:^-I::')" - PY_LIB_PATH="/usr/lib/lib$(python3-config --libs | cut -f1 -d' ' | sed 's:^-l::').so" - mkdir -p "$builddir"/build - cd "$builddir"/build - - cmake .. \ - -DALLOCATOR=libc \ - -DCMAKE_INSTALL_PREFIX=$_prefix \ - -DCMAKE_INSTALL_LIBDIR=$_libdir \ - -DCMAKE_INSTALL_LIBEXECDIR=$_libexecdir \ - -DCMAKE_INSTALL_LOCALSTATEDIR=$_localstatedir \ - -DCMAKE_INSTALL_SYSCONFDIR=$_sysconfdir \ - -DCMAKE_INSTALL_DOCDIR=$_docdir/ceph \ - -DCMAKE_INSTALL_MANDIR=$_mandir \ - -DWITH_REENTRANT_STRSIGNAL=ON \ - -DWITH_THREAD_SAFE_RES_QUERY=ON \ - -DWITH_MANPAGE=ON \ - -DWITH_SYSTEM_BOOST=ON \ - -DPYTHON_EXECUTABLE:FILEPATH=/usr/bin/python3 \ - -DPYTHON_INCLUDE_DIR:PATH=$PY_INC_PATH \ - -DPYTHON_LIBRARY:FILEPATH=$PY_LIB_PATH \ - -DWITH_PYTHON2=OFF \ - -DWITH_PYTHON3=ON \ - -DMGR_PYTHON_VERSION=3 \ - -DWITH_LTTNG=OFF \ - -DWITH_RDMA=OFF \ - -DWITH_SYSTEMD=OFF \ - -DWITH_SPDK=OFF \ - -DWITH_BABELTRACE=OFF \ - -DWITH_RADOSGW_AMQP_ENDPOINT=OFF \ - -DWITH_TESTS=OFF - make - -} - -package() { - cd "$builddir"/build - make DESTDIR="$pkgdir" install - cd .. - - rm -f "$pkgdir"$_sysconfdir/init.d/ceph - - # Move mount.* binaries to /sbin - mkdir -p "$pkgdir"$_syssbindir - mv "$pkgdir"$_sbindir/mount.* "$pkgdir"$_syssbindir - - # We need to clean this out before packaging as it's freaking huge - rm -rf "$pkgdir"$_datadir/ceph/mgr/dashboard/frontend/node_modules - - install -m 0644 -D src/etc-rbdmap "$pkgdir"$_sysconfdir/ceph/rbdmap - install -m 0644 -D src/logrotate.conf "$pkgdir"$_sysconfdir/logrotate.d/ceph - install -m 0644 -D etc/sysctl/90-ceph-osd.conf "$pkgdir"/$_sysconfdir/sysctl.d/90-ceph-osd.conf - chmod 0644 "$pkgdir"$_docdir/ceph/sample.ceph.conf - - # udev rules - install -m 0644 -D udev/50-rbd.rules "$pkgdir"$_udevrulesdir/50-rbd.rules - - # sudoers.d - install -m 0600 -D sudoers.d/ceph-osd-smartctl "$pkgdir"/$_sysconfdir/sudoers.d/ceph-osd-smartctl -} - -check() { - cd "$builddir"/build - ctest -} - -# This subpackage is a little weird and a side effect of trying to keep -# the daemon packages as small as possible. We might be able to roll this into -# the base/common package later if we can slim those down or break them up in a -# different way -user() { - pkgdesc="Minimal package to create a user for other ceph packages." - depends="" - install="$pkgname-user.pre-install" - mkdir -p "$subpkgdir" -} - -base() { - pkgdesc="Base is the package that includes all the files shared amongst ceph servers" - depends="$_base_deps - $pkgname-user=$pkgver-r$pkgrel - $pkgname-common=$pkgver-r$pkgrel - librbd=$pkgver-r$pkgrel - librados=$pkgver-r$pkgrel - libcephfs=$pkgver-r$pkgrel - " - - _pkg $_bindir \ - ceph-crash \ - crushtool \ - monmaptool \ - osdmaptool \ - ceph-kvstore-tool \ - ceph-run - _pkg $_sbindir ceph-create-keys - _pkg $_libexecdir/ceph ceph_common.sh - _pkg $_libdir/rados-classes '*.so*' - _pkg $_libdir/ceph/erasure-code 'libec_*.so*' - _pkg $_libdir/ceph/compressor 'libceph_*.so*' - _pkg $_libdir/ceph/crypto 'libceph_*.so*' - _pkg $_sysconfdir/logrotate.d ceph - for dir in crash crash/posted tmp bootstrap-osd bootstrap-mds \ - bootstrap-rgw bootstrap-mgr bootstrap-rbd \ - bootstrap-rbd-mirror; do - - install -m 750 -o $_ceph_uid -g $_ceph_gid -d \ - "$subpkgdir"$_localstatedir/lib/ceph/$dir - done -} - -common() { - pkgdesc="Common utilities to mount and interact with a ceph storage cluster." - depends="py3-rados py3-rbd py3-cephfs" - - _pkg $_bindir ceph \ - ceph-authtool \ - ceph-conf \ - ceph-dencoder \ - ceph-rbdnamer \ - ceph-syn \ - cephfs-data-scan \ - cephfs-journal-tool \ - cephfs-table-tool \ - rados \ - rbd \ - rbd-replay \ - rbd-replay-many \ - rbdmap \ - ceph-post-file - _pkg $_syssbindir mount.ceph - _pkg $_datadir/ceph known_hosts_drop.ceph.com \ - id_rsa_drop.ceph.com \ - id_rsa_drop.ceph.com.pub - _pkg $_sysconfdir/ceph rbdmap - - _pkg "$(_py3_sitelib)" ceph_argparse.py* ceph_daemon.py* - - _pkg $_udevrulesdir 50-rbd.rules - install -m 3770 -o $_ceph_uid -g $_ceph_gid -d \ - "$subpkgdir"$_localstatedir/log/ceph - install -m 750 -o $_ceph_uid -g $_ceph_gid -d \ - "$subpkgdir"$_localstatedir/lib/ceph -} - -mds() { - pkgdesc="Metadata server daemon for the Ceph distributed file system." - depends="ceph-base" - - _pkg $_bindir ceph-mds - install -m 750 -o $_ceph_uid -g $_ceph_gid -d \ - "$subpkgdir"$_localstatedir/lib/ceph/mds -} - -mon() { - pkgdesc="Cluster monitor daemon virtual package for the Ceph distributed file system." - depends="$pkgname-base - $pkgname-mon-daemon=$pkgver-r$pkgrel - $pkgname-mon-tools=$pkgver-r$pkgrel" - - mkdir -p "$subpkgdir" -} - -mon_daemon() { - pkgdesc="Cluster monitor daemon for the Ceph distributed file system." - depends="$pkgname-user=$pkgver-r$pkgrel" - - _pkg $_bindir ceph-mon - install -m 750 -o $_ceph_uid -g $_ceph_gid -d \ - "$subpkgdir"$_localstatedir/lib/ceph/mon -} - -mon_tools() { - pkgdesc="Cluster monitor tools for the Ceph distributed file system." - - _pkg $_bindir ceph-monstore-tool - install -m 750 -o $_ceph_uid -g $_ceph_gid -d \ - "$subpkgdir"$_localstatedir/lib/ceph/mon -} - -ceph_fuse() { - pkgdesc="FUSE based client for Ceph distributed network file system." - depends= - _pkg $_bindir ceph-fuse - _pkg $_syssbindir mount.fuse.ceph -} - -rbd_fuse() { - pkgdesc="FUSE based client to map Ceph rbd images to files." - depends= - _pkg $_bindir rbd-fuse -} - -rbd_mirror() { - pkgdesc="Daemon for mirroring RBD images between Ceph clusters." - depends="ceph-common=$pkgver-r$pkgrel" - _pkg $_bindir rbd-mirror -} - -rbd_nbd() { - pkgdesc="NBD based client to map Ceph rbd images to local device." - depends= - _pkg $_bindir rbd-nbd -} - -radosgw() { - pkgdesc="Rados REST gateway which implements Amazon's S3 and OpenStack's Swift APIs." - depends="ceph-common oath-toolkit-liboath" - _pkg $_bindir radosgw \ - radosgw-admin \ - radosgw-es \ - radosgw-object-expirer \ - radosgw-token - mkdir -p "$subpkgdir"$_localstatedir/lib/ceph/radosgw -} - -osd() { - pkgdesc="Object storage daemon virtual package for the Ceph distributed file system." - depends="$pkgname-osd-daemon=$pkgver-r$pkgrel - $pkgname-osd-tools=$pkgver-r$pkgrel - $pkgname-volume=$pkgver-r$pkgrel" - - mkdir -p "$subpkgdir" -} - -osd_daemon() { - pkgdesc="Object storage daemon for the Ceph distributed file system." - depends="$_osd_daemon_deps $pkgname-user=$pkgver-r$pkgrel" - - _pkg $_bindir ceph-osd - _pkg $_libexecdir/ceph ceph-osd-prestart.sh - _pkg $_sysconfdir/sudoers.d ceph-osd-smartctl - _pkg $_sysconfdir/sysctl.d 90-ceph-osd.conf - install -m 750 -o $_ceph_uid -g $_ceph_gid -d \ - "$subpkgdir"$_localstatedir/lib/ceph/osd -} - -osd_tools() { - pkgdesc="Object storage daemon tools for the Ceph distributed file system." - depends="$pkgname-base=$pkgver-r$pkgrel $_osd_tools_deps" - - _pkg $_bindir ceph-clsinfo \ - ceph-bluestore-tool \ - ceph-objectstore-tool \ - ceph-osdomap-tool - install -m 750 -o $_ceph_uid -g $_ceph_gid -d \ - "$subpkgdir"$_localstatedir/lib/ceph/osd -} - -ceph_volume() { - pkgdesc="ceph-volume tool for the Ceph distributed file system." - depends="$_ceph_volume_deps" - - _pkg $_sbindir ceph-volume - _pkg "$(_py3_sitelib)" ceph_volume 'ceph_volume-*' -} - -librados() { - pkgdesc="RADOS distributed object store client library" - depends= - _pkg $_libdir librados.so.* - _pkg $_libdir/ceph libceph-common.so.* -} - -_py3_rados() { - pkgdesc="Python libraries for the RADOS object store" - depends= - - _pkg "$(_py3_sitelib)" rados*.so rados-*.egg-info -} - -libradosstriper() { - pkgdesc="RADOS striping library" - depends= - - _pkg $_libdir libradosstriper.so.* -} - -librbd() { - pkgdesc="RADOS block device client library" - depends= - _pkg $_libdir librbd.so.* -} - -_py3_rbd() { - pkgdesc="Python libraries for the RADOS block device" - depends="py3-rados" - - _pkg "$(_py3_sitelib)" rbd*.so rbd-*.egg-info -} - -libcephfs() { - pkgdesc="Ceph distributed file system client library" - depends= - _pkg $_libdir libcephfs.so.* -} - -_py3_cephfs() { - pkgdesc="Python libraries for Ceph distributed file system" - depends="py3-rados" - - _pkg "$(_py3_sitelib)" cephfs*.so cephfs-*.egg-info ceph_volume_client.py* -} - -ceph_test() { - pkgdesc="Ceph benchmarks and test tools" - depends="ceph-common=$pkgver-r$pkgrel $_ceph_test_deps" - - _pkg $_bindir ceph-client-debug \ - ceph_bench_log \ - ceph_kvstorebench \ - ceph_multi_stress_watch \ - ceph_erasure_code \ - ceph_erasure_code_benchmark \ - ceph_omapbench \ - ceph_objectstore_bench \ - ceph_perf_objectstore \ - ceph_perf_local \ - ceph_perf_msgr_client \ - ceph_perf_msgr_server \ - ceph_psim \ - ceph_radosacl \ - ceph_rgw_jsonparser \ - ceph_rgw_multiparser \ - ceph_scratchtool \ - ceph_scratchtoolpp \ - ceph_smalliobench \ - ceph_smalliobenchdumb \ - ceph_smalliobenchfs \ - ceph_smalliobenchrbd \ - ceph_test_* \ - ceph_tpbench \ - ceph_xattr_bench \ - ceph-coverage \ - ceph-monstore-tool \ - ceph-osdomap-tool \ - ceph-kvstore-tool \ - ceph-debugpack - - _pkg $_libdir ceph/ceph-monstore-update-crush.sh -} - -bash_completion() { - pkgdesc="Bash completions for Ceph" - depends= - install_if="ceph=$pkgver-r$pkgrel bash-completion" - _pkg $_sysconfdir/bash_completion.d '*' -} - -mgr() { - pkgdesc="Ceph Manager Daemon" - depends="ceph-base=$pkgver-r$pkgrel" - - _pkg $_bindir ceph-mgr - _pkg $_datadir/ceph mgr - - install -m 750 -o $_ceph_uid -g $_ceph_gid -d \ - "$subpkgdir"$_localstatedir/lib/ceph/mgr -} - -_pkg() { - local path=$1 - shift - if ! [ -d "$pkgdir"/$path ]; then - error "$pkgdir/$path is not a directory" - return 1 - fi - mkdir -p "$subpkgdir"$path - for _file in "$@"; do - mv "$pkgdir"$path/$_file "$subpkgdir"$path - done -} - -sha512sums="3d02e766a1d53d39355ee88738dd0233dc02f8a3cb44935194cb538b888507de8f8acdd99bf7890895f68795a310f53e2a8652305d5f2be5212efbd9046bd3a9 ceph_14.2.3.orig.tar.gz -e1becd813ed3f28e2e4a6bef78b3b5117c1c0bb9cabe0ba9c912e0a20b551b6b2667495cddb94acd64192e287144911ff1c11e0d636fe04cc458146cfb0daca8 allperms.patch -35722b11ad52a3145153635b6a96abda2a23ae9c7e63e2eac006c1e5b8014452c4a1a11bbe0292fd731e4c43aa38e27dd75d2ff9d25bcf52290278f71e868570 musl-fixes.patch -0211c84da189f71af7914350ebbfa6fc588c854bad501453344a8d13a18a56ea895118d576bed65b592ea2925efe92b86c769ebc85156a559b2acd0ee884157b boost-1.70.patch" diff --git a/community/ceph/allperms.patch b/community/ceph/allperms.patch deleted file mode 100644 index a5ce1c031d..0000000000 --- a/community/ceph/allperms.patch +++ /dev/null @@ -1,13 +0,0 @@ ---- ceph-11.1.1/src/test/libcephfs/test.cc.orig 2017-01-16 00:17:44.154815630 +0000 -+++ ceph-11.1.1/src/test/libcephfs/test.cc 2017-01-16 00:18:09.642520993 +0000 -@@ -31,6 +31,10 @@ - #include <map> - #include <vector> - -+#ifndef ALLPERMS -+#define ALLPERMS (S_ISUID|S_ISGID|S_ISVTX|S_IRWXU|S_IRWXG|S_IRWXO) -+#endif -+ - TEST(LibCephFS, OpenEmptyComponent) { - - pid_t mypid = getpid(); diff --git a/community/ceph/boost-1.70.patch b/community/ceph/boost-1.70.patch deleted file mode 100644 index 149c65bc10..0000000000 --- a/community/ceph/boost-1.70.patch +++ /dev/null @@ -1,105 +0,0 @@ -From 064f142746ae97f54865069cdacf5aae2b1b14f6 Mon Sep 17 00:00:00 2001 -From: Casey Bodley <cbodley@redhat.com> -Date: Tue, 23 Apr 2019 15:40:01 -0400 -Subject: [PATCH] rgw: beast handle_connection() takes io_context - -as of boost 1.70, the socket no longer has a get_io_context(), so we -have to pass it in as an argument - -Signed-off-by: Casey Bodley <cbodley@redhat.com> ---- - src/rgw/rgw_asio_frontend.cc | 9 +++++---- - 1 file changed, 5 insertions(+), 4 deletions(-) - -diff --git a/src/rgw/rgw_asio_frontend.cc b/src/rgw/rgw_asio_frontend.cc -index e4be074ec74f..4af3695dc1ce 100644 ---- a/src/rgw/rgw_asio_frontend.cc -+++ b/src/rgw/rgw_asio_frontend.cc -@@ -81,7 +81,8 @@ class StreamIO : public rgw::asio::ClientIO { - using SharedMutex = ceph::async::SharedMutex<boost::asio::io_context::executor_type>; - - template <typename Stream> --void handle_connection(RGWProcessEnv& env, Stream& stream, -+void handle_connection(boost::asio::io_context& context, -+ RGWProcessEnv& env, Stream& stream, - boost::beast::flat_buffer& buffer, bool is_ssl, - SharedMutex& pause_mutex, - rgw::dmclock::Scheduler *scheduler, -@@ -152,7 +153,7 @@ void handle_connection(RGWProcessEnv& env, Stream& stream, - rgw::io::add_conlen_controlling( - &real_client)))); - RGWRestfulIO client(cct, &real_client_io); -- auto y = optional_yield{socket.get_io_context(), yield}; -+ auto y = optional_yield{context, yield}; - process_request(env.store, env.rest, &req, env.uri_prefix, - *env.auth_registry, &client, env.olog, y, scheduler); - } -@@ -560,7 +561,7 @@ void AsioFrontend::accept(Listener& l, boost::system::error_code ec) - return; - } - buffer.consume(bytes); -- handle_connection(env, stream, buffer, true, pause_mutex, -+ handle_connection(context, env, stream, buffer, true, pause_mutex, - scheduler.get(), ec, yield); - if (!ec) { - // ssl shutdown (ignoring errors) -@@ -578,7 +579,7 @@ void AsioFrontend::accept(Listener& l, boost::system::error_code ec) - auto c = connections.add(conn); - boost::beast::flat_buffer buffer; - boost::system::error_code ec; -- handle_connection(env, s, buffer, false, pause_mutex, -+ handle_connection(context, env, s, buffer, false, pause_mutex, - scheduler.get(), ec, yield); - s.shutdown(tcp::socket::shutdown_both, ec); - }); -From f1651b8c509d60787d10c4115e29fecfd2da237c Mon Sep 17 00:00:00 2001 -From: Casey Bodley <cbodley@redhat.com> -Date: Tue, 23 Apr 2019 15:41:45 -0400 -Subject: [PATCH] rgw: add executor type for basic_waitable_timers - -as of boost 1.70, the timer no longer depends on io_context directly, -so we have to specify its executor as a template parameter - -Signed-off-by: Casey Bodley <cbodley@redhat.com> ---- - src/rgw/rgw_dmclock_async_scheduler.h | 5 +++++ - src/rgw/rgw_reshard.h | 9 ++++++++- - 2 files changed, 13 insertions(+), 1 deletion(-) - -diff --git a/src/rgw/rgw_dmclock_async_scheduler.h b/src/rgw/rgw_dmclock_async_scheduler.h -index 70487a525373..1d454acd2ea6 100644 ---- a/src/rgw/rgw_dmclock_async_scheduler.h -+++ b/src/rgw/rgw_dmclock_async_scheduler.h -@@ -82,7 +82,12 @@ class AsyncScheduler : public md_config_obs_t, public Scheduler { - using Completion = async::Completion<Signature, async::AsBase<Request>>; - - using Clock = ceph::coarse_real_clock; -+#if BOOST_VERSION < 107000 - using Timer = boost::asio::basic_waitable_timer<Clock>; -+#else -+ using Timer = boost::asio::basic_waitable_timer<Clock, -+ boost::asio::wait_traits<Clock>, executor_type>; -+#endif - Timer timer; //< timer for the next scheduled request - - CephContext *const cct; -diff --git a/src/rgw/rgw_reshard.h b/src/rgw/rgw_reshard.h -index d99a6ff68d5f..213fc238d2ee 100644 ---- a/src/rgw/rgw_reshard.h -+++ b/src/rgw/rgw_reshard.h -@@ -183,7 +183,14 @@ class RGWReshardWait { - ceph::condition_variable cond; - - struct Waiter : boost::intrusive::list_base_hook<> { -- boost::asio::basic_waitable_timer<Clock> timer; -+#if BOOST_VERSION < 107000 -+ using Timer = boost::asio::basic_waitable_timer<Clock>; -+#else -+ using Executor = boost::asio::io_context::executor_type; -+ using Timer = boost::asio::basic_waitable_timer<Clock, -+ boost::asio::wait_traits<Clock>, Executor>; -+#endif -+ Timer timer; - explicit Waiter(boost::asio::io_context& ioc) : timer(ioc) {} - }; - boost::intrusive::list<Waiter> waiters; diff --git a/community/ceph/ceph-user.pre-install b/community/ceph/ceph-user.pre-install deleted file mode 100644 index bae4f09dc7..0000000000 --- a/community/ceph/ceph-user.pre-install +++ /dev/null @@ -1,5 +0,0 @@ -#!/bin/sh - -addgroup ceph -g 167 -S 2>/dev/null -adduser ceph -u 167 -S -G ceph -s /sbin/nologin -h /var/lib/ceph -g "Ceph Daemons" 2> /dev/null -exit 0 diff --git a/community/ceph/musl-fixes.patch b/community/ceph/musl-fixes.patch deleted file mode 100644 index 6e50e6ba5b..0000000000 --- a/community/ceph/musl-fixes.patch +++ /dev/null @@ -1,229 +0,0 @@ -diff --git a/src/common/secret.c b/src/common/secret.c -index b6f26ec3..1b4531f8 100644 ---- a/src/common/secret.c -+++ b/src/common/secret.c -@@ -63,9 +63,18 @@ int set_kernel_secret(const char *secret, const char *key_name) - - ret = ceph_unarmor(payload, payload+sizeof(payload), secret, secret+secret_len); - if (ret < 0) { -- char error_buf[80]; -- fprintf(stderr, "secret is not valid base64: %s.\n", -- strerror_r(-ret, error_buf, sizeof(error_buf))); -+ char error_buf[80] = "unkown error"; -+ char *p; -+#if defined(__GLIBC__) -+ p = strerror_r(-ret, error_buf, sizeof(error_buf)); -+#else -+ if (strerror_r(-ret, error_buf, sizeof(error_buf)) < 0) { -+ p = "unkown error"; -+ } else { -+ p = error_buf; -+ } -+#endif -+ fprintf(stderr, "secret is not valid base64: %s.\n", p); - return ret; - } - -diff --git a/src/dmclock/src/dmclock_util.cc b/src/dmclock/src/dmclock_util.cc -index e8046cdc..aa9000bc 100644 ---- a/src/dmclock/src/dmclock_util.cc -+++ b/src/dmclock/src/dmclock_util.cc -@@ -21,7 +21,7 @@ - #include "dmclock_util.h" - - --std::string crimson::dmclock::format_time(const Time& time, uint modulo) { -+std::string crimson::dmclock::format_time(const Time& time, unsigned int modulo) { - long subtract = long(time / modulo) * modulo; - std::stringstream ss; - ss << std::fixed << std::setprecision(4) << (time - subtract); -diff --git a/src/dmclock/src/dmclock_util.h b/src/dmclock/src/dmclock_util.h -index d3fd3f19..ee8b6c3a 100644 ---- a/src/dmclock/src/dmclock_util.h -+++ b/src/dmclock/src/dmclock_util.h -@@ -52,7 +52,7 @@ namespace crimson { - #endif - } - -- std::string format_time(const Time& time, uint modulo = 1000); -+ std::string format_time(const Time& time, unsigned int modulo = 1000); - - void debugger(); - -diff --git a/src/seastar/dpdk/config/common_base b/src/seastar/dpdk/config/common_base -index 8907bea3..6d3f7577 100644 ---- a/src/seastar/dpdk/config/common_base -+++ b/src/seastar/dpdk/config/common_base -@@ -96,7 +96,7 @@ CONFIG_RTE_MAX_TAILQ=32 - CONFIG_RTE_LOG_LEVEL=RTE_LOG_INFO - CONFIG_RTE_LOG_DP_LEVEL=RTE_LOG_INFO - CONFIG_RTE_LOG_HISTORY=256 --CONFIG_RTE_BACKTRACE=y -+CONFIG_RTE_BACKTRACE=n - CONFIG_RTE_LIBEAL_USE_HPET=n - CONFIG_RTE_EAL_ALLOW_INV_SOCKET_ID=n - CONFIG_RTE_EAL_ALWAYS_PANIC_ON_ERROR=n -diff --git a/src/spdk/dpdk/config/common_base b/src/spdk/dpdk/config/common_base -index d5fbb3a4..d9561545 100644 ---- a/src/spdk/dpdk/config/common_base -+++ b/src/spdk/dpdk/config/common_base -@@ -80,7 +80,7 @@ CONFIG_RTE_MAX_TAILQ=32 - CONFIG_RTE_ENABLE_ASSERT=n - CONFIG_RTE_LOG_DP_LEVEL=RTE_LOG_INFO - CONFIG_RTE_LOG_HISTORY=256 --CONFIG_RTE_BACKTRACE=y -+CONFIG_RTE_BACKTRACE=n - CONFIG_RTE_LIBEAL_USE_HPET=n - CONFIG_RTE_EAL_ALLOW_INV_SOCKET_ID=n - CONFIG_RTE_EAL_ALWAYS_PANIC_ON_ERROR=n -diff --git a/src/spdk/dpdk/config/rte_config.h b/src/spdk/dpdk/config/rte_config.h -index a8e47977..7599bd39 100644 ---- a/src/spdk/dpdk/config/rte_config.h -+++ b/src/spdk/dpdk/config/rte_config.h -@@ -30,7 +30,7 @@ - #define RTE_MAX_MEMZONE 2560 - #define RTE_MAX_TAILQ 32 - #define RTE_LOG_DP_LEVEL RTE_LOG_INFO --#define RTE_BACKTRACE 1 -+//#define RTE_BACKTRACE 1 - #define RTE_EAL_VFIO 1 - #define RTE_MAX_VFIO_CONTAINERS 64 - -diff --git a/src/spdk/dpdk/drivers/bus/pci/linux/pci_uio.c b/src/spdk/dpdk/drivers/bus/pci/linux/pci_uio.c -index a7c14421..aff241e8 100644 ---- a/src/spdk/dpdk/drivers/bus/pci/linux/pci_uio.c -+++ b/src/spdk/dpdk/drivers/bus/pci/linux/pci_uio.c -@@ -14,6 +14,32 @@ - - #if defined(RTE_ARCH_X86) - #include <sys/io.h> -+#if defined(__GLIBC__) -+#define pci_uio_outl_p outl_p -+#define pci_uio_outw_p outw_p -+#define pci_uio_outb_p outb_p -+#else -+static inline void -+pci_uio_outl_p(unsigned int value, unsigned short int port) -+{ -+ __asm__ __volatile__ ("outl %0,%w1\noutb %%al,$0x80" : : "a" (value), -+ "Nd" (port)); -+} -+ -+static inline void -+pci_uio_outw_p(unsigned short int value, unsigned short int port) -+{ -+ __asm__ __volatile__ ("outw %w0,%w1\noutb %%al,$0x80" : : "a" (value), -+ "Nd" (port)); -+} -+ -+static inline void -+pci_uio_outb_p(unsigned char value, unsigned short int port) -+{ -+ __asm__ __volatile__ ("outb %b0,%w1\noutb %%al,$0x80" : : "a" (value), -+ "Nd" (port)); -+} -+#endif - #endif - - #include <rte_log.h> -@@ -527,21 +553,21 @@ pci_uio_ioport_write(struct rte_pci_ioport *p, - if (len >= 4) { - size = 4; - #if defined(RTE_ARCH_X86) -- outl_p(*(const uint32_t *)s, reg); -+ pci_uio_outl_p(*(const uint32_t *)s, reg); - #else - *(volatile uint32_t *)reg = *(const uint32_t *)s; - #endif - } else if (len >= 2) { - size = 2; - #if defined(RTE_ARCH_X86) -- outw_p(*(const uint16_t *)s, reg); -+ pci_uio_outw_p(*(const uint16_t *)s, reg); - #else - *(volatile uint16_t *)reg = *(const uint16_t *)s; - #endif - } else { - size = 1; - #if defined(RTE_ARCH_X86) -- outb_p(*s, reg); -+ pci_uio_outb_p(*s, reg); - #else - *(volatile uint8_t *)reg = *s; - #endif -diff --git a/src/spdk/dpdk/lib/librte_eal/common/eal_common_fbarray.c b/src/spdk/dpdk/lib/librte_eal/common/eal_common_fbarray.c -index ba6c4ae3..b9b7d70d 100644 ---- a/src/spdk/dpdk/lib/librte_eal/common/eal_common_fbarray.c -+++ b/src/spdk/dpdk/lib/librte_eal/common/eal_common_fbarray.c -@@ -9,6 +9,7 @@ - #include <errno.h> - #include <sys/file.h> - #include <string.h> -+#include <fcntl.h> - - #include <rte_common.h> - #include <rte_log.h> -diff --git a/src/spdk/dpdk/lib/librte_eal/common/malloc_heap.c b/src/spdk/dpdk/lib/librte_eal/common/malloc_heap.c -index 02a5385d..cf063d5f 100644 ---- a/src/spdk/dpdk/lib/librte_eal/common/malloc_heap.c -+++ b/src/spdk/dpdk/lib/librte_eal/common/malloc_heap.c -@@ -1,6 +1,7 @@ - /* SPDX-License-Identifier: BSD-3-Clause - * Copyright(c) 2010-2014 Intel Corporation - */ -+ #include<string.h> - #include <stdint.h> - #include <stddef.h> - #include <stdlib.h> -diff --git a/src/spdk/dpdk/lib/librte_eal/linuxapp/eal/eal_hugepage_info.c b/src/spdk/dpdk/lib/librte_eal/linuxapp/eal/eal_hugepage_info.c -index 3a7d4b22..99b25d3c 100644 ---- a/src/spdk/dpdk/lib/librte_eal/linuxapp/eal/eal_hugepage_info.c -+++ b/src/spdk/dpdk/lib/librte_eal/linuxapp/eal/eal_hugepage_info.c -@@ -17,6 +17,7 @@ - #include <sys/mman.h> - #include <sys/queue.h> - #include <sys/stat.h> -+#include <fcntl.h> - - #include <linux/mman.h> /* for hugetlb-related flags */ - -diff --git a/src/spdk/dpdk/lib/librte_eal/linuxapp/eal/eal_memory.c b/src/spdk/dpdk/lib/librte_eal/linuxapp/eal/eal_memory.c -index 0bf2aef3..0c98c74c 100644 ---- a/src/spdk/dpdk/lib/librte_eal/linuxapp/eal/eal_memory.c -+++ b/src/spdk/dpdk/lib/librte_eal/linuxapp/eal/eal_memory.c -@@ -15,6 +15,7 @@ - #include <sys/mman.h> - #include <sys/types.h> - #include <sys/stat.h> -+#include <fcntl.h> - #include <sys/queue.h> - #include <sys/file.h> - #include <unistd.h> -diff --git a/src/spdk/dpdk/mk/target/generic/rte.vars.mk b/src/spdk/dpdk/mk/target/generic/rte.vars.mk -index 98085cd3..dd149acc 100644 ---- a/src/spdk/dpdk/mk/target/generic/rte.vars.mk -+++ b/src/spdk/dpdk/mk/target/generic/rte.vars.mk -@@ -108,6 +108,9 @@ CFLAGS += -include $(RTE_SDK_BIN)/include/rte_config.h - LDFLAGS += -L$(RTE_SDK_BIN)/lib - endif - -+# always define _GNU_SOURCE -+CFLAGS += -D_GNU_SOURCE -+ - export CFLAGS - export LDFLAGS - -diff --git a/src/tools/rbd_nbd/rbd-nbd.cc b/src/tools/rbd_nbd/rbd-nbd.cc -index cce44e4f..b0988e64 100644 ---- a/src/tools/rbd_nbd/rbd-nbd.cc -+++ b/src/tools/rbd_nbd/rbd-nbd.cc -@@ -552,7 +552,8 @@ private: - for (unsigned i = 0; i < cmdline.size(); i++) { - const char *arg = &cmdline[i]; - if (i == 0) { -- if (strcmp(basename(arg) , "rbd-nbd") != 0) { -+ const char *fname = strrchr(arg, '/'); -+ if (strcmp(fname ? fname+1 : arg, "rbd-nbd") != 0) { - return -EINVAL; - } - } else { |