commit:     7e2d5bdd317d5250ef989a119cbaf5e5efdb1319
Author:     Holger Hoffstätte <holger <AT> applied-asynchrony <DOT> com>
AuthorDate: Sat Mar 14 13:52:13 2026 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Mar 14 14:48:17 2026 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7e2d5bdd

dev-debug/bpftrace: add 0.25.0

While upstream has started to vendor libbpf, they also still allow linking
against the system libbpf statically. Therefore we need to start depending on
libbpf[static-libs].

Signed-off-by: Holger Hoffstätte <holger <AT> applied-asynchrony.com>
Part-of: https://codeberg.org/gentoo/gentoo/pulls/320
Merges: https://codeberg.org/gentoo/gentoo/pulls/320
Signed-off-by: Sam James <sam <AT> gentoo.org>

 dev-debug/bpftrace/Manifest               |   1 +
 dev-debug/bpftrace/bpftrace-0.25.0.ebuild | 160 ++++++++++++++++++++++++++++++
 2 files changed, 161 insertions(+)

diff --git a/dev-debug/bpftrace/Manifest b/dev-debug/bpftrace/Manifest
index ff6c03567fd1..c316b2f8be15 100644
--- a/dev-debug/bpftrace/Manifest
+++ b/dev-debug/bpftrace/Manifest
@@ -1,3 +1,4 @@
 DIST bpftrace-0.24.2-man.tar.xz 43820 BLAKE2B 
b0964633f4c1a462874f20934c286c321307a4abf79ebebaf085396e545a119f39f46f35b597921a61a5707a6cad5b368788ca8db682dee0eb916fc8a65b5520
 SHA512 
5a64c875400ede0050ee13f00351e06f72aeb8d8ce0db6933ac9c9f93023388218dd5fd62db7fd24370ddadbe390c6efa71692afd2e55b7f5755e4816f4832eb
 DIST bpftrace-0.24.2.tar.gz 1375106 BLAKE2B 
c397eb7ded3a72ea0805487db66f422bda9a0a743b1757056dc1bc70119e2d4fa7e69577a7e295143ce2b9789c62c4469b995ac0dca228c464efb3db8da25eeb
 SHA512 
d9ff773ce39b578877d5e73a48434d3654b46985bb4b9ad458fbf622718049da5075b3a2d2e6d1ae0a9effbdb74658822b4c4535bca384fbd6e539fdec393f4b
 DIST bpftrace-0.25.0-man.tar.xz 44292 BLAKE2B 
e3ad8255b74836c9947595cd3c39caa201ccc420e573376ea7a144c499f4f74349911df87618f98a877d797b6d3b0c54f0117292537d03e184d2669b8a1331a5
 SHA512 
343fadffec5d2a6f702e2fe67087718c909f32cd6440dabc0fa93d2c0b8264ceda7d7a1eee7f79b4be2365318170c4eff7582453ec8ff4e15343ce2cb056b2ea
+DIST bpftrace-0.25.0.tar.gz 1484592 BLAKE2B 
75b6afd9e46d6df8c76c3e3bc515174b72dbc866b4375e3372d9bd07d86f3a1be1a4426f7fb9005458325ac0eea603689ceb619123db898a570a11affa78f026
 SHA512 
8a6515f21b4f19d4acaf338085ddb40e78d1ab4ce4c8e39733e85e301941cc6b125ec19892aa52632d9e9f94401fd5af126db23ebfecf6c9a33aa59ce7c316bd

diff --git a/dev-debug/bpftrace/bpftrace-0.25.0.ebuild 
b/dev-debug/bpftrace/bpftrace-0.25.0.ebuild
new file mode 100644
index 000000000000..ab4ee111d39f
--- /dev/null
+++ b/dev-debug/bpftrace/bpftrace-0.25.0.ebuild
@@ -0,0 +1,160 @@
+# Copyright 2019-2026 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+LLVM_COMPAT=( {18..22} )
+RUST_MIN_VER="1.85.0"
+RUST_OPTIONAL=1
+
+inherit cmake flag-o-matic linux-info llvm-r1 rust
+
+DESCRIPTION="High-level tracing language for eBPF"
+HOMEPAGE="https://github.com/bpftrace/bpftrace";
+MY_PV="${PV//_/}"
+
+if [[ ${PV} == *9999* ]] ; then
+       EGIT_REPO_URI="https://github.com/bpftrace/bpftrace";
+       EGIT_BRANCH="master"
+       inherit git-r3
+       # use a released man page for git
+       MAN_V="0.25.0"
+else
+       SRC_URI="https://github.com/bpftrace/bpftrace/archive/v${MY_PV}.tar.gz 
-> ${P}.tar.gz"
+       KEYWORDS="~amd64 ~arm64"
+       # the man page version may trail the release
+       #MAN_V="0.25.0"
+fi
+
+SRC_URI+=" 
https://github.com/bpftrace/bpftrace/releases/download/v${MAN_V:-${PV}}/man.tar.xz
 -> bpftrace-${MAN_V:-${PV}}-man.tar.xz"
+
+S="${WORKDIR}/${PN}-${MY_PV:-${PV}}"
+
+LICENSE="Apache-2.0"
+SLOT="0"
+
+IUSE="pcap systemd test"
+
+RESTRICT="!test? ( test )"
+
+RDEPEND="
+       >=dev-libs/blazesym_c-0.1.1
+       >=dev-libs/libbpf-1.6:=[static-libs]
+       >=dev-util/bcc-0.25.0
+       $(llvm_gen_dep '
+               llvm-core/clang:${LLVM_SLOT}=
+               llvm-core/llvm:${LLVM_SLOT}=[llvm_targets_BPF(+)]
+       ')
+       sys-libs/binutils-libs:=
+       virtual/libelf:=
+       systemd? ( sys-apps/systemd:= )
+       pcap? ( net-libs/libpcap:= )
+       virtual/zlib:=
+"
+DEPEND="
+       ${RDEPEND}
+       dev-libs/cereal:=
+       test? ( dev-cpp/gtest )
+"
+BDEPEND="
+       app-arch/xz-utils
+       app-alternatives/lex
+       app-alternatives/yacc
+       dev-libs/cereal
+       dev-util/bpftool
+       || ( dev-util/xxd app-editors/vim-core )
+       test? (
+               ${RUST_DEPEND}
+               dev-lang/go
+               dev-util/pahole
+       )
+       virtual/pkgconfig
+"
+
+PATCHES=(
+       "${FILESDIR}/0.11.4-old-kernels.patch"
+       "${FILESDIR}/0.21.0-dont-compress-man.patch"
+)
+
+pkg_pretend() {
+       local CONFIG_CHECK="
+               ~BPF
+               ~BPF_EVENTS
+               ~BPF_JIT
+               ~BPF_SYSCALL
+               ~DEBUG_INFO_BTF
+               ~DEBUG_INFO_BTF_MODULES
+               ~FTRACE_SYSCALLS
+               ~HAVE_EBPF_JIT
+       "
+
+       check_extra_config
+
+       if use test; then
+               if ! linux_config_exists ; then
+                       die "Unable to check your kernel for BTF support: tests 
cannot run."
+               elif ! linux_chkconfig_present DEBUG_INFO_BTF ; then
+                       die "CONFIG_DEBUG_INFO_BTF is not set: tests cannot 
run."
+               fi
+       fi
+}
+
+pkg_setup() {
+       llvm-r1_pkg_setup
+       use test && rust_pkg_setup
+}
+
+# git-r3 overrides automatic SRC_URI unpacking
+src_unpack() {
+       default
+
+       if [[ ${PV} == *9999* ]] ; then
+               git-r3_src_unpack
+       fi
+}
+
+src_prepare() {
+       # create a usable version from git
+       if [[ ${PV} == *9999* ]] ; then
+               local rev=$(git branch --show-current | sed -e 's/* //g' -e 
's/release\///g')-$(git rev-parse --short HEAD)
+               sed -i "/configure_file/i set (BPFTRACE_VERSION \"${rev}\")" 
cmake/Version.cmake || die
+       fi
+
+       cmake_src_prepare
+}
+
+src_configure() {
+       # suppress one remaining and benign ODR violation warning due to
+       # a generated libbpf header used by the tests, see:
+       # https://github.com/bpftrace/bpftrace/issues/4591
+       use test && append-flags -Wno-odr
+
+       local mycmakeargs=(
+               # DO dynamically link the bpftrace executable
+               -DSTATIC_LINKING=OFF
+               # DO NOT build the internal libs as shared
+               -DBUILD_SHARED_LIBS=OFF
+               -DBUILD_TESTING=$(usex test)
+               # we use the pregenerated man page
+               -DENABLE_MAN=OFF
+               -DENABLE_SKB_OUTPUT=$(usex pcap)
+               -DENABLE_SYSTEMD=$(usex systemd)
+               # always use system libbpf
+               -DUSE_SYSTEM_LIBBPF=ON
+       )
+
+       # enable UBSAN only when enabled in the toolchain
+       if is-flagq -fsanitize=undefined; then
+               filter-flags -fsanitize=undefined
+               mycmakeargs+=( -DBUILD_UBSAN=ON )
+       fi
+
+       cmake_src_configure
+}
+
+src_install() {
+       cmake_src_install
+       doman man/man8/*.?
+       gunzip "${WORKDIR}/man/man8/bpftrace.8.gz" || die
+       doman "${WORKDIR}/man/man8/bpftrace.8"
+}

Reply via email to