Gentoo Archives: gentoo-commits

From: Theo Anderson <telans@××××××.de>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] repo/proj/guru:master commit in: dev-util/xdp-tools/files/, dev-util/xdp-tools/
Date: Sat, 24 Apr 2021 23:19:56
Message-Id: 1619260830.10fdc366340d7e164747ecc6896ded7fb37c195b.telans@gentoo
1 commit: 10fdc366340d7e164747ecc6896ded7fb37c195b
2 Author: Kurt Kanzenbach <kurt <AT> kmk-computers <DOT> de>
3 AuthorDate: Sat Apr 24 10:38:29 2021 +0000
4 Commit: Theo Anderson <telans <AT> posteo <DOT> de>
5 CommitDate: Sat Apr 24 10:40:30 2021 +0000
6 URL: https://gitweb.gentoo.org/repo/proj/guru.git/commit/?id=10fdc366
7
8 dev-util/xdp-tools: Bump to v1.1.1
9
10 Package-Manager: Portage-3.0.17, Repoman-3.0.2
11 Signed-off-by: Kurt Kanzenbach <kurt <AT> kmk-computers.de>
12
13 dev-util/xdp-tools/Manifest | 1 +
14 .../xdp-tools/files/xdp-tools-1.1.1-install.patch | 23 +++++++
15 .../xdp-tools/files/xdp-tools-1.1.1-readelf.patch | 51 +++++++++++++++
16 dev-util/xdp-tools/xdp-tools-1.1.1.ebuild | 75 ++++++++++++++++++++++
17 4 files changed, 150 insertions(+)
18
19 diff --git a/dev-util/xdp-tools/Manifest b/dev-util/xdp-tools/Manifest
20 index 2919fe527..0362a71ee 100644
21 --- a/dev-util/xdp-tools/Manifest
22 +++ b/dev-util/xdp-tools/Manifest
23 @@ -1 +1,2 @@
24 DIST xdp-tools-1.1.0.tar.gz 157577 BLAKE2B 219219898cf83c72dd07ef64b3eda889ca2825ae9f21ab7714020fbc467ef37a4df978ee0c7eef45c1ebd43370ff71f43d1dab0d11507d80de3cbf39d45cab16 SHA512 31165f932dcdf8181c012500e2dc27118860d8733932ab253d02dd07a436c0ef1f5bc3253e6def716b10ff50b37854bb5e9679cc38adec27c3366823c8656232
25 +DIST xdp-tools-1.1.1.tar.gz 171627 BLAKE2B 5a2009f8b171d23a0f9b91b119e4376aecdddeb6d84c4323f05c03b382d4161c0d0364ef7a34b55771fe76c920b5bb18fe46c12d15c5356db6dc34174c5e5438 SHA512 580e87d7bfa7ee5b48caebceac4928386c3e3157ebb8d5cf1dd11a98187b9d17d027ef99f6598ce9b74eed7eb9b307195c4baa199675233d06c76bc8dc4861e5
26
27 diff --git a/dev-util/xdp-tools/files/xdp-tools-1.1.1-install.patch b/dev-util/xdp-tools/files/xdp-tools-1.1.1-install.patch
28 new file mode 100644
29 index 000000000..a02fb50f1
30 --- /dev/null
31 +++ b/dev-util/xdp-tools/files/xdp-tools-1.1.1-install.patch
32 @@ -0,0 +1,23 @@
33 +From 1de19829622cf394a6154834955379e7e45e0cb8 Mon Sep 17 00:00:00 2001
34 +From: Kurt Kanzenbach <kurt@×××××××××××××.de>
35 +Date: Fri, 10 Apr 2020 15:39:13 +0200
36 +Subject: [PATCH] lib: xdp: make: Don't install static libs
37 +
38 +Don't install static libs.
39 +
40 +Signed-off-by: Kurt Kanzenbach <kurt@×××××××××××××.de>
41 +---
42 + lib/libxdp/Makefile | 2 +-
43 + 1 file changed, 1 insertion(+), 1 deletion(-)
44 +
45 +--- a/lib/libxdp/Makefile
46 ++++ b/lib/libxdp/Makefile
47 +@@ -49,7 +49,7 @@ install: all
48 + $(Q)install -d -m 0755 $(DESTDIR)$(BPF_OBJECT_DIR)
49 + $(Q)install -m 0644 $(LIB_HEADERS) $(DESTDIR)$(HDRDIR)/
50 + $(Q)install -m 0644 $(PC_FILE) $(DESTDIR)$(LIBDIR)/pkgconfig/
51 +- $(Q)cp -fpR $(SHARED_LIBS) $(STATIC_LIBS) $(DESTDIR)$(LIBDIR)
52 ++ $(Q)cp -fpR $(SHARED_LIBS) $(DESTDIR)$(LIBDIR)
53 + $(Q)install -m 0755 $(XDP_OBJS) $(DESTDIR)$(BPF_OBJECT_DIR)
54 + $(if $(MAN_FILES),$(Q)install -m 0755 -d $(DESTDIR)$(MANDIR)/man3)
55 + $(if $(MAN_FILES),$(Q)install -m 0644 $(MAN_FILES) $(DESTDIR)$(MANDIR)/man3)
56
57 diff --git a/dev-util/xdp-tools/files/xdp-tools-1.1.1-readelf.patch b/dev-util/xdp-tools/files/xdp-tools-1.1.1-readelf.patch
58 new file mode 100644
59 index 000000000..2330e549d
60 --- /dev/null
61 +++ b/dev-util/xdp-tools/files/xdp-tools-1.1.1-readelf.patch
62 @@ -0,0 +1,51 @@
63 +From: Kurt Kanzenbach <kurt@×××××××××××××.de>
64 +Subject: lib: xdp: make: Fix hardcoded readelf
65 +
66 +Don't hardcode readelf. Allow to reuse something else.
67 +
68 +Signed-off-by: Kurt Kanzenbach <kurt@×××××××××××××.de>
69 +---
70 + lib/libxdp/Makefile | 10 +++++-----
71 + 1 file changed, 5 insertions(+), 5 deletions(-)
72 +
73 +--- a/lib/libxdp/Makefile
74 ++++ b/lib/libxdp/Makefile
75 +@@ -26,7 +26,7 @@ TEMPLATED_SOURCES := xdp-dispatcher.c
76 +
77 + CFLAGS += -I$(HEADER_DIR) -I$(LIB_DIR)/util
78 + BPF_CFLAGS += -I$(HEADER_DIR)
79 +-
80 ++READELF ?= readelf
81 +
82 + ifndef BUILD_STATIC_ONLY
83 + SHARED_LIBS := $(OBJDIR)/libxdp.so \
84 +@@ -89,12 +89,12 @@ $(SHARED_OBJDIR)/%.o: %.c $(EXTRA_LIB_DE
85 +
86 + XDP_IN_SHARED := $(SHARED_OBJDIR)/libxdp.o
87 +
88 +-GLOBAL_SYM_COUNT = $(shell readelf -s --wide $(XDP_IN_SHARED) | \
89 ++GLOBAL_SYM_COUNT = $(shell $(READELF) -s --wide $(XDP_IN_SHARED) | \
90 + cut -d "@" -f1 | sed 's/_v[0-9]_[0-9]_[0-9].*//' | \
91 + sed 's/\[.*\]//' | \
92 + awk '/GLOBAL/ && /DEFAULT/ && !/UND/ {print $$NF}' | \
93 + sort -u | wc -l)
94 +-VERSIONED_SYM_COUNT = $(shell readelf --dyn-syms --wide $(OBJDIR)/libxdp.so | \
95 ++VERSIONED_SYM_COUNT = $(shell $(READELF) --dyn-syms --wide $(OBJDIR)/libxdp.so | \
96 + grep -Eo '[^ ]+@LIBXDP_' | cut -d@ -f1 | sort -u | wc -l)
97 +
98 + check: check_abi
99 +@@ -106,12 +106,12 @@ check_abi: $(OBJDIR)/libxdp.so
100 + "versioned symbols in $^ ($(VERSIONED_SYM_COUNT))." \
101 + "Please make sure all symbols are" \
102 + "versioned in $(VERSION_SCRIPT)." >&2; \
103 +- readelf -s --wide $(XDP_IN_SHARED) | \
104 ++ $(READELF) -s --wide $(XDP_IN_SHARED) | \
105 + cut -d "@" -f1 | sed 's/_v[0-9]_[0-9]_[0-9].*//' | \
106 + sed 's/\[.*\]//' | \
107 + awk '/GLOBAL/ && /DEFAULT/ && !/UND/ {print $$NF}'| \
108 + sort -u > $(OUTPUT)libxdp_global_syms.tmp; \
109 +- readelf --dyn-syms --wide $(OUTPUT)libxdp.so | \
110 ++ $(READELF) --dyn-syms --wide $(OUTPUT)libxdp.so | \
111 + grep -Eo '[^ ]+@LIBXDP_' | cut -d@ -f1 | \
112 + sort -u > $(OUTPUT)libxdp_versioned_syms.tmp; \
113 + diff -u $(OUTPUT)libxdp_global_syms.tmp \
114
115 diff --git a/dev-util/xdp-tools/xdp-tools-1.1.1.ebuild b/dev-util/xdp-tools/xdp-tools-1.1.1.ebuild
116 new file mode 100644
117 index 000000000..694cfccfb
118 --- /dev/null
119 +++ b/dev-util/xdp-tools/xdp-tools-1.1.1.ebuild
120 @@ -0,0 +1,75 @@
121 +# Copyright 1999-2021 Gentoo Authors
122 +# Distributed under the terms of the GNU General Public License v2
123 +
124 +EAPI=7
125 +
126 +inherit linux-info llvm multilib toolchain-funcs
127 +
128 +# version v1.1.1 is not tagged, use commit
129 +MY_COMMIT="69827a07b395b78a2b577c3e1af6075f8c47fdd8"
130 +
131 +DESCRIPTION="Utilities and example programs for use with XDP"
132 +HOMEPAGE="https://github.com/xdp-project/xdp-tools"
133 +SRC_URI="https://github.com/xdp-project/${PN}/archive/${MY_COMMIT}.tar.gz -> ${P}.tar.gz"
134 +
135 +SLOT="0"
136 +LICENSE="GPL-2"
137 +KEYWORDS="~amd64 ~x86"
138 +
139 +# skip strip for eBPF object files
140 +# tests have to be run as root
141 +RESTRICT="strip test"
142 +
143 +# skip QA check(s) for eBPF samples
144 +QA_EXECSTACK="usr/lib*/bpf/*.o usr/share/xdp-tools/*.o"
145 +QA_PREBUILT="usr/lib*/bpf/*.o usr/share/xdp-tools/*.o"
146 +
147 +# XDP should be enabled
148 +CONFIG_CHECK="~XDP_SOCKETS"
149 +
150 +LLVM_MAX_SLOT=10
151 +
152 +BDEPEND="
153 + virtual/pkgconfig
154 +"
155 +RDEPEND="
156 + >=dev-libs/libbpf-0.0.7
157 + net-libs/libpcap
158 + sys-libs/zlib
159 + virtual/libelf
160 +"
161 +DEPEND="${RDEPEND}
162 + sys-devel/clang:10
163 + sys-devel/llvm:10
164 +"
165 +
166 +PATCHES=(
167 + "${FILESDIR}/${P}-install.patch"
168 + "${FILESDIR}/${P}-readelf.patch"
169 +)
170 +
171 +S="${WORKDIR}/xdp-tools-${MY_COMMIT}"
172 +
173 +pkg_setup() {
174 + llvm_pkg_setup
175 +}
176 +
177 +src_configure() {
178 + ./configure || die
179 +}
180 +
181 +src_compile() {
182 + emake \
183 + CC="$(tc-getCC)" \
184 + AR="$(tc-getAR)" \
185 + READELF=$(tc-getREADELF) \
186 + PRODUCTION=1 \
187 + DYNAMIC_LIBXDP=1 \
188 + FORCE_SYSTEM_LIBBPF=1 \
189 + PREFIX=/usr \
190 + LIBDIR="/usr/$(get_libdir)" all
191 +}
192 +
193 +src_install() {
194 + emake PREFIX=/usr LIBDIR="/usr/$(get_libdir)" DESTDIR="${D}" install
195 +}