From 1865cfc8e9c9e355cbb50ba34b1a47839b87f1f7 Mon Sep 17 00:00:00 2001 From: CentOS Sources Date: Tue, 9 Nov 2021 04:55:43 -0500 Subject: [PATCH] import oci-seccomp-bpf-hook-1.2.0-3.module+el8.5.0+11073+ba5c6d09 --- .gitignore | 1 + .oci-seccomp-bpf-hook.metadata | 1 + SOURCES/build-fix.patch | 12 +++ SPECS/oci-seccomp-bpf-hook.spec | 168 ++++++++++++++++++++++++++++++++ 4 files changed, 182 insertions(+) create mode 100644 .gitignore create mode 100644 .oci-seccomp-bpf-hook.metadata create mode 100644 SOURCES/build-fix.patch create mode 100644 SPECS/oci-seccomp-bpf-hook.spec diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..67e59d9 --- /dev/null +++ b/.gitignore @@ -0,0 +1 @@ +SOURCES/v1.2.0.tar.gz diff --git a/.oci-seccomp-bpf-hook.metadata b/.oci-seccomp-bpf-hook.metadata new file mode 100644 index 0000000..0de06b3 --- /dev/null +++ b/.oci-seccomp-bpf-hook.metadata @@ -0,0 +1 @@ +87e5a6bd76c56b81e779438c531f31f14a6c9b7e SOURCES/v1.2.0.tar.gz diff --git a/SOURCES/build-fix.patch b/SOURCES/build-fix.patch new file mode 100644 index 0000000..676352a --- /dev/null +++ b/SOURCES/build-fix.patch @@ -0,0 +1,12 @@ +diff -up oci-seccomp-bpf-hook-1.2.0/vendor/github.com/iovisor/gobpf/bcc/module.go.orig oci-seccomp-bpf-hook-1.2.0/vendor/github.com/iovisor/gobpf/bcc/module.go +--- oci-seccomp-bpf-hook-1.2.0/vendor/github.com/iovisor/gobpf/bcc/module.go.orig 2021-05-21 14:15:44.936127448 +0200 ++++ oci-seccomp-bpf-hook-1.2.0/vendor/github.com/iovisor/gobpf/bcc/module.go 2021-05-21 14:16:03.459454988 +0200 +@@ -258,7 +258,7 @@ func (bpf *Module) attachProbe(evName st + func (bpf *Module) attachUProbe(evName string, attachType uint32, path string, addr uint64, fd, pid int) error { + evNameCS := C.CString(evName) + binaryPathCS := C.CString(path) +- res, err := C.bpf_attach_uprobe(C.int(fd), attachType, evNameCS, binaryPathCS, (C.uint64_t)(addr), (C.pid_t)(pid)) ++ res, err := C.bpf_attach_uprobe(C.int(fd), attachType, evNameCS, binaryPathCS, (C.uint64_t)(addr), (C.pid_t)(pid), 0) + C.free(unsafe.Pointer(evNameCS)) + C.free(unsafe.Pointer(binaryPathCS)) + diff --git a/SPECS/oci-seccomp-bpf-hook.spec b/SPECS/oci-seccomp-bpf-hook.spec new file mode 100644 index 0000000..9cff865 --- /dev/null +++ b/SPECS/oci-seccomp-bpf-hook.spec @@ -0,0 +1,168 @@ +%global with_check 0 + +%global _find_debuginfo_dwz_opts %{nil} +%global _dwz_low_mem_die_limit 0 + +%if 0%{?rhel} > 7 && ! 0%{?fedora} +%define gobuild(o:) \ +go build -buildmode pie -compiler gc -tags="rpm_crashtraceback libtrust_openssl ${BUILDTAGS:-}" -ldflags "${LDFLAGS:-} -linkmode=external -compressdwarf=false -B 0x$(head -c20 /dev/urandom|od -An -tx1|tr -d ' \\n') -extldflags '%__global_ldflags'" -a -v %{?**}; +%else +%if ! 0%{?gobuild:1} +%define gobuild(o:) GO111MODULE=off go build -buildmode pie -compiler gc -tags="rpm_crashtraceback ${BUILDTAGS:-}" -ldflags "${LDFLAGS:-} -linkmode=external -B 0x$(head -c20 /dev/urandom|od -An -tx1|tr -d ' \\n') -extldflags '-Wl,-z,relro -Wl,-z,now -specs=/usr/lib/rpm/redhat/redhat-hardened-ld '" -a -v %{?**}; +%endif +%endif + +%global provider github +%global provider_tld com +%global project containers +%global repo oci-seccomp-bpf-hook +# https://github.com/containers/oci-seccomp-bpf-hook +%global provider_prefix %{provider}.%{provider_tld}/%{project}/%{repo} +%global import_path %{provider_prefix} +%global git0 https://%{provider}.%{provider_tld}/%{project}/%{repo} + +# https://fedoraproject.org/wiki/PackagingDrafts/Go#Go_Language_Architectures +ExclusiveArch: %{go_arches} + +Name: oci-seccomp-bpf-hook +Version: 1.2.0 +Release: 3%{?dist} +Summary: OCI Hook to generate seccomp json files based on EBF syscalls used by container +License: ASL 2.0 +URL: %{git0} +Source0: %{git0}/archive/v%{version}.tar.gz +Patch0: build-fix.patch +BuildRequires: golang +BuildRequires: go-md2man +BuildRequires: glib2-devel +BuildRequires: glibc-devel +BuildRequires: bcc-devel +BuildRequires: git +BuildRequires: gpgme-devel +BuildRequires: libseccomp-devel +BuildRequires: make +Requires: crun >= 0.17 +Enhances: podman +Enhances: cri-o + +%description +%{summary} +%{repo} provides a library for applications looking to use +the Container Pod concept popularized by Kubernetes. + +%prep +%autosetup -Sgit +sed -i '/$(MAKE) -C docs install/d' Makefile +sed -i 's/HOOK_BIN_DIR/\%{_usr}\/libexec\/oci\/hooks.d/' %{name}.json +sed -i '/$(HOOK_DIR)\/%{name}.json/d' Makefile + +%build +export GO111MODULE=off +export GOPATH=$(pwd):$(pwd)/_build +export CGO_CFLAGS="%{optflags} -D_GNU_SOURCE -D_LARGEFILE_SOURCE -D_LARGEFILE64_SOURCE -D_FILE_OFFSET_BITS=64" + +mkdir _build +pushd _build +mkdir -p src/%{provider}.%{provider_tld}/%{project} +ln -s ../../../../ src/%{import_path} +popd +ln -s vendor src + +export GOPATH=$(pwd)/_build:$(pwd) +export LDFLAGS="-X main.version=%{version}" +%gobuild -o bin/%{name} %{import_path} + +pushd docs +go-md2man -in %{name}.md -out %{name}.1 +popd + +%install +%{__make} DESTDIR=%{buildroot} PREFIX=%{_prefix} install-nobuild +%{__make} DESTDIR=%{buildroot} PREFIX=%{_prefix} GOMD2MAN=go-md2man -C docs install-nobuild + +%check +%if 0%{?with_check} +# Since we aren't packaging up the vendor directory we need to link +# back to it somehow. Hack it up so that we can add the vendor +# directory from BUILD dir as a gopath to be searched when executing +# tests from the BUILDROOT dir. +ln -s ./ ./vendor/src # ./vendor/src -> ./vendor + +export GOPATH=%{buildroot}/%{gopath}:$(pwd)/vendor:%{gopath} + +%if ! 0%{?gotest:1} +%global gotest go test +%endif + +%gotest %{import_path}/src/%{name} +%endif + +#define license tag if not already defined +%{!?_licensedir:%global license %doc} + +%files +%license LICENSE +%doc README.md +%dir %{_libexecdir}/oci/hooks.d +%{_libexecdir}/oci/hooks.d/%{name} +%{_datadir}/containers/oci/hooks.d/%{name}.json +%{_mandir}/man1/%{name}.1* + +%changelog +* Fri May 21 2021 Jindrich Novy - 1.2.0-3 +- actually apply the build fix patch +- Related: #1934415 + +* Fri May 21 2021 Jindrich Novy - 1.2.0-2 +- resolve build issue +- Related: #1934415 + +* Mon Feb 22 2021 Jindrich Novy - 1.2.0-1 +- revert back to 1.2.0 - build issues +- Related: #1883490 + +* Fri Feb 19 2021 Jindrich Novy - 1.2.1-1 +- update to + https://github.com/containers/oci-seccomp-bpf-hook/releases/tag/v1.2.1 +- require crun >= 0.17 +- Related: #1883490 + +* Thu Jan 28 2021 Jindrich Novy - 1.2.0-1 +- revert back to 1.2.0 due to build issues +- Related: #1883490 + +* Thu Jan 28 2021 Jindrich Novy - 1.2.1-1 +- update to https://github.com/containers/oci-seccomp-bpf-hook/releases/tag/v1.2.1 +- Related: #1883490 + +* Tue Dec 08 2020 Jindrich Novy - 1.2.0-2 +- sync with RHEL8 devel branch +- Related: #1883490 + +* Wed Oct 21 2020 Jindrich Novy - 1.2.0-1 +- synchronize with stream-container-tools-rhel8 +- Related: #1883490 + +* Tue Aug 11 2020 Jindrich Novy - 1.1.2-3 +- propagate proper CFLAGS to CGO_CFLAGS to assure code hardening and optimization +- Related: #1821193 + +* Thu Jul 23 2020 Lokesh Mandvekar - 1.1.2-2 +- Resolves: #1857606 + +* Fri Jul 17 2020 Jindrich Novy - 1.1.2-1 +- update to https://github.com/containers/oci-seccomp-bpf-hook/releases/tag/v1.1.2 +- Related: #1821193 + +* Thu Jun 18 2020 Jindrich Novy - 1.1.1-1 +- update to https://github.com/containers/oci-seccomp-bpf-hook/releases/tag/v1.1.1 +- Related: #1821193 + +* Tue May 12 2020 Jindrich Novy - 1.1.0-2 +- exclude i686 arch as bcc, the build dependency is not built + for it +- Related: #1821193 + +* Tue May 12 2020 Jindrich Novy - 1.1.0-1 +- initial build for container-tools-rhel8 +- Related: #1821193