backport patches from upstream
This commit is contained in:
parent
bac749a341
commit
05dce15b2d
@ -0,0 +1,49 @@
|
|||||||
|
From 2de3b87122c18b58b3e2b32ab2e81ac43774a7aa Mon Sep 17 00:00:00 2001
|
||||||
|
From: Tom Hromatka <tom.hromatka@oracle.com>
|
||||||
|
Date: Wed, 16 Mar 2022 11:19:14 -0600
|
||||||
|
Subject: [PATCH] bpf: pfc: Add handling for 0 syscalls in the binary tree
|
||||||
|
|
||||||
|
Handle the unlikely case where a user has chosen the
|
||||||
|
binary tree optimization but has zero syscalls in their
|
||||||
|
filter.
|
||||||
|
|
||||||
|
Fixes: https://github.com/seccomp/libseccomp/issues/370
|
||||||
|
Fixes: a3732b32b8e67 ("bpf:pfc: Add optimization option to use a binary tree")
|
||||||
|
Signed-off-by: Tom Hromatka <tom.hromatka@oracle.com>
|
||||||
|
Acked-by: Paul Moore <paul@paul-moore.com>
|
||||||
|
---
|
||||||
|
src/gen_bpf.c | 3 +++
|
||||||
|
src/gen_pfc.c | 3 +++
|
||||||
|
2 files changed, 6 insertions(+)
|
||||||
|
|
||||||
|
diff --git a/src/gen_bpf.c b/src/gen_bpf.c
|
||||||
|
index c878f44..7131761 100644
|
||||||
|
--- a/src/gen_bpf.c
|
||||||
|
+++ b/src/gen_bpf.c
|
||||||
|
@@ -1348,6 +1348,9 @@ static int _get_bintree_levels(unsigned int syscall_cnt)
|
||||||
|
{
|
||||||
|
unsigned int i = 2, max_level = SYSCALLS_PER_NODE * 2;
|
||||||
|
|
||||||
|
+ if (syscall_cnt == 0)
|
||||||
|
+ return 0;
|
||||||
|
+
|
||||||
|
while (max_level < syscall_cnt) {
|
||||||
|
max_level <<= 1;
|
||||||
|
i++;
|
||||||
|
diff --git a/src/gen_pfc.c b/src/gen_pfc.c
|
||||||
|
index c7fb536..4916055 100644
|
||||||
|
--- a/src/gen_pfc.c
|
||||||
|
+++ b/src/gen_pfc.c
|
||||||
|
@@ -275,6 +275,9 @@ static int _get_bintree_levels(unsigned int syscall_cnt,
|
||||||
|
/* Only use a binary tree if requested */
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
+ if (syscall_cnt == 0)
|
||||||
|
+ return 0;
|
||||||
|
+
|
||||||
|
do {
|
||||||
|
max_level = SYSCALLS_PER_NODE << i;
|
||||||
|
i++;
|
||||||
|
--
|
||||||
|
2.27.0
|
||||||
|
|
||||||
187
backport-tests-Add-a-binary-tree-test-with-zero-syscalls.patch
Normal file
187
backport-tests-Add-a-binary-tree-test-with-zero-syscalls.patch
Normal file
@ -0,0 +1,187 @@
|
|||||||
|
From 5731dd9f73df9025b2c8924e2f4ce78a7d94af00 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Tom Hromatka <tom.hromatka@oracle.com>
|
||||||
|
Date: Wed, 16 Mar 2022 11:24:40 -0600
|
||||||
|
Subject: [PATCH] tests: Add a binary tree test with zero syscalls
|
||||||
|
|
||||||
|
Add a test that exercises the binary tree optimization but
|
||||||
|
the seccomp filter has zero syscalls in it.
|
||||||
|
|
||||||
|
Related-bug: https://github.com/seccomp/libseccomp/issues/370
|
||||||
|
Signed-off-by: Tom Hromatka <tom.hromatka@oracle.com>
|
||||||
|
Acked-by: Paul Moore <paul@paul-moore.com>
|
||||||
|
---
|
||||||
|
tests/59-basic-empty_binary_tree.c | 54 ++++++++++++++++++++++++++
|
||||||
|
tests/59-basic-empty_binary_tree.py | 41 +++++++++++++++++++
|
||||||
|
tests/59-basic-empty_binary_tree.tests | 16 ++++++++
|
||||||
|
tests/Makefile.am | 9 +++--
|
||||||
|
4 files changed, 117 insertions(+), 3 deletions(-)
|
||||||
|
create mode 100644 tests/59-basic-empty_binary_tree.c
|
||||||
|
create mode 100755 tests/59-basic-empty_binary_tree.py
|
||||||
|
create mode 100644 tests/59-basic-empty_binary_tree.tests
|
||||||
|
|
||||||
|
diff --git a/tests/59-basic-empty_binary_tree.c b/tests/59-basic-empty_binary_tree.c
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000..6b6485e
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/tests/59-basic-empty_binary_tree.c
|
||||||
|
@@ -0,0 +1,54 @@
|
||||||
|
+/**
|
||||||
|
+ * Seccomp Library test program
|
||||||
|
+ *
|
||||||
|
+ * Copyright (c) 2018-2020 Oracle and/or its affiliates.
|
||||||
|
+ * Author: Tom Hromatka <tom.hromatka@oracle.com>
|
||||||
|
+ */
|
||||||
|
+
|
||||||
|
+/*
|
||||||
|
+ * This library is free software; you can redistribute it and/or modify it
|
||||||
|
+ * under the terms of version 2.1 of the GNU Lesser General Public License as
|
||||||
|
+ * published by the Free Software Foundation.
|
||||||
|
+ *
|
||||||
|
+ * This library is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
+ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
|
||||||
|
+ * for more details.
|
||||||
|
+ *
|
||||||
|
+ * You should have received a copy of the GNU Lesser General Public License
|
||||||
|
+ * along with this library; if not, see <http://www.gnu.org/licenses>.
|
||||||
|
+ */
|
||||||
|
+
|
||||||
|
+#include <errno.h>
|
||||||
|
+#include <unistd.h>
|
||||||
|
+
|
||||||
|
+#include <seccomp.h>
|
||||||
|
+
|
||||||
|
+#include "util.h"
|
||||||
|
+
|
||||||
|
+int main(int argc, char *argv[])
|
||||||
|
+{
|
||||||
|
+ int rc;
|
||||||
|
+ struct util_options opts;
|
||||||
|
+ scmp_filter_ctx ctx = NULL;
|
||||||
|
+
|
||||||
|
+ rc = util_getopt(argc, argv, &opts);
|
||||||
|
+ if (rc < 0)
|
||||||
|
+ goto out;
|
||||||
|
+
|
||||||
|
+ ctx = seccomp_init(SCMP_ACT_ALLOW);
|
||||||
|
+ if (ctx == NULL)
|
||||||
|
+ return ENOMEM;
|
||||||
|
+
|
||||||
|
+ rc = seccomp_attr_set(ctx, SCMP_FLTATR_CTL_OPTIMIZE, 2);
|
||||||
|
+ if (rc < 0)
|
||||||
|
+ goto out;
|
||||||
|
+
|
||||||
|
+ rc = util_filter_output(&opts, ctx);
|
||||||
|
+ if (rc)
|
||||||
|
+ goto out;
|
||||||
|
+
|
||||||
|
+out:
|
||||||
|
+ seccomp_release(ctx);
|
||||||
|
+ return (rc < 0 ? -rc : rc);
|
||||||
|
+}
|
||||||
|
diff --git a/tests/59-basic-empty_binary_tree.py b/tests/59-basic-empty_binary_tree.py
|
||||||
|
new file mode 100755
|
||||||
|
index 0000000..5acbbd4
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/tests/59-basic-empty_binary_tree.py
|
||||||
|
@@ -0,0 +1,41 @@
|
||||||
|
+#!/usr/bin/env python
|
||||||
|
+
|
||||||
|
+#
|
||||||
|
+# Seccomp Library test program
|
||||||
|
+#
|
||||||
|
+# Copyright (c) 2022 Oracle and/or its affiliates.
|
||||||
|
+# Author: Tom Hromatka <tom.hromatka@oracle.com>
|
||||||
|
+#
|
||||||
|
+
|
||||||
|
+#
|
||||||
|
+# This library is free software; you can redistribute it and/or modify it
|
||||||
|
+# under the terms of version 2.1 of the GNU Lesser General Public License as
|
||||||
|
+# published by the Free Software Foundation.
|
||||||
|
+#
|
||||||
|
+# This library is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
+# FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
|
||||||
|
+# for more details.
|
||||||
|
+#
|
||||||
|
+# You should have received a copy of the GNU Lesser General Public License
|
||||||
|
+# along with this library; if not, see <http://www.gnu.org/licenses>.
|
||||||
|
+#
|
||||||
|
+
|
||||||
|
+import argparse
|
||||||
|
+import sys
|
||||||
|
+
|
||||||
|
+import util
|
||||||
|
+
|
||||||
|
+from seccomp import *
|
||||||
|
+
|
||||||
|
+def test(args):
|
||||||
|
+ f = SyscallFilter(ALLOW)
|
||||||
|
+ f.set_attr(Attr.CTL_OPTIMIZE, 2)
|
||||||
|
+ return f
|
||||||
|
+
|
||||||
|
+args = util.get_opt()
|
||||||
|
+ctx = test(args)
|
||||||
|
+util.filter_output(args, ctx)
|
||||||
|
+
|
||||||
|
+# kate: syntax python;
|
||||||
|
+# kate: indent-mode python; space-indent on; indent-width 4; mixedindent off;
|
||||||
|
diff --git a/tests/59-basic-empty_binary_tree.tests b/tests/59-basic-empty_binary_tree.tests
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000..ff6dbc3
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/tests/59-basic-empty_binary_tree.tests
|
||||||
|
@@ -0,0 +1,16 @@
|
||||||
|
+#
|
||||||
|
+# libseccomp regression test automation data
|
||||||
|
+#
|
||||||
|
+# Copyright (c) 2022 Oracle and/or its affiliates.
|
||||||
|
+# Author: Tom Hromatka <tom.hromatka@oracle.com>
|
||||||
|
+#
|
||||||
|
+
|
||||||
|
+test type: bpf-sim
|
||||||
|
+
|
||||||
|
+# Testname Arch Syscall Arg0 Arg1 Arg2 Arg3 Arg4 Arg5 Result
|
||||||
|
+59-basic-empty_binary_tree all,-x32 0-350 N N N N N N ALLOW
|
||||||
|
+
|
||||||
|
+test type: bpf-valgrind
|
||||||
|
+
|
||||||
|
+# Testname
|
||||||
|
+59-basic-empty_binary_tree
|
||||||
|
diff --git a/tests/Makefile.am b/tests/Makefile.am
|
||||||
|
index b39ee06..f0a1f8e 100644
|
||||||
|
--- a/tests/Makefile.am
|
||||||
|
+++ b/tests/Makefile.am
|
||||||
|
@@ -93,7 +93,8 @@ check_PROGRAMS = \
|
||||||
|
55-basic-pfc_binary_tree \
|
||||||
|
56-basic-iterate_syscalls \
|
||||||
|
57-basic-rawsysrc \
|
||||||
|
- 58-live-tsync_notify
|
||||||
|
+ 58-live-tsync_notify \
|
||||||
|
+ 59-basic-empty_binary_tree
|
||||||
|
|
||||||
|
EXTRA_DIST_TESTPYTHON = \
|
||||||
|
util.py \
|
||||||
|
@@ -152,7 +153,8 @@ EXTRA_DIST_TESTPYTHON = \
|
||||||
|
54-live-binary_tree.py \
|
||||||
|
56-basic-iterate_syscalls.py \
|
||||||
|
57-basic-rawsysrc.py \
|
||||||
|
- 58-live-tsync_notify.py
|
||||||
|
+ 58-live-tsync_notify.py \
|
||||||
|
+ 59-basic-empty_binary_tree.py
|
||||||
|
|
||||||
|
EXTRA_DIST_TESTCFGS = \
|
||||||
|
01-sim-allow.tests \
|
||||||
|
@@ -212,7 +214,8 @@ EXTRA_DIST_TESTCFGS = \
|
||||||
|
55-basic-pfc_binary_tree.tests \
|
||||||
|
56-basic-iterate_syscalls.tests \
|
||||||
|
57-basic-rawsysrc.tests \
|
||||||
|
- 58-live-tsync_notify.tests
|
||||||
|
+ 58-live-tsync_notify.tests \
|
||||||
|
+ 59-basic-empty_binary_tree.tests
|
||||||
|
|
||||||
|
EXTRA_DIST_TESTSCRIPTS = \
|
||||||
|
38-basic-pfc_coverage.sh 38-basic-pfc_coverage.pfc \
|
||||||
|
--
|
||||||
|
2.27.0
|
||||||
|
|
||||||
@ -1,12 +1,15 @@
|
|||||||
Name: libseccomp
|
Name: libseccomp
|
||||||
Version: 2.5.3
|
Version: 2.5.3
|
||||||
Release: 1
|
Release: 2
|
||||||
Summary: Interface to the syscall filtering mechanism
|
Summary: Interface to the syscall filtering mechanism
|
||||||
License: LGPLv2
|
License: LGPLv2
|
||||||
URL: https://github.com/seccomp/libseccomp
|
URL: https://github.com/seccomp/libseccomp
|
||||||
Source0: https://github.com/seccomp/libseccomp/releases/download/v%{version}/%{name}-%{version}.tar.gz
|
Source0: https://github.com/seccomp/libseccomp/releases/download/v%{version}/%{name}-%{version}.tar.gz
|
||||||
|
|
||||||
BuildRequires: gcc gperf
|
Patch0: backport-bpf-pfc-Add-handling-for-0-syscalls-in-the-binary-tr.patch
|
||||||
|
Patch1: backport-tests-Add-a-binary-tree-test-with-zero-syscalls.patch
|
||||||
|
|
||||||
|
BuildRequires: gcc gperf autoconf automake
|
||||||
|
|
||||||
%description
|
%description
|
||||||
The libseccomp library provides an easy to use, platform independent, interface to
|
The libseccomp library provides an easy to use, platform independent, interface to
|
||||||
@ -31,6 +34,7 @@ developing applications that use %{name}.
|
|||||||
%autosetup -n %{name}-%{version} -p1
|
%autosetup -n %{name}-%{version} -p1
|
||||||
|
|
||||||
%build
|
%build
|
||||||
|
autoreconf
|
||||||
%configure
|
%configure
|
||||||
%make_build
|
%make_build
|
||||||
|
|
||||||
@ -67,6 +71,9 @@ make check
|
|||||||
%{_mandir}/man*/*
|
%{_mandir}/man*/*
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Sat Aug 27 2022 zoulin <zoulin13@h-partners.com> - 2.5.3-2
|
||||||
|
- backport patches from upstream
|
||||||
|
|
||||||
* Tue Dec 28 2021 fuanan <fuanan3@huawei.com> - 2.5.3-1
|
* Tue Dec 28 2021 fuanan <fuanan3@huawei.com> - 2.5.3-1
|
||||||
- update version to 2.5.3
|
- update version to 2.5.3
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user