Commit c1a3daf7 authored by Alexei Starovoitov's avatar Alexei Starovoitov

Merge branch 'Support bpf trampoline for s390x'

Ilya Leoshkevich says:

====================

v2: https://lore.kernel.org/bpf/20230128000650.1516334-1-iii@linux.ibm.com/#t
v2 -> v3:
- Make __arch_prepare_bpf_trampoline static.
  (Reported-by: kernel test robot <lkp@intel.com>)
- Support both old- and new- style map definitions in sk_assign. (Alexei)
- Trim DENYLIST.s390x. (Alexei)
- Adjust s390x vmlinux path in vmtest.sh.
- Drop merged fixes.

v1: https://lore.kernel.org/bpf/20230125213817.1424447-1-iii@linux.ibm.com/#t
v1 -> v2:
- Fix core_read_macros, sk_assign, test_profiler, test_bpffs (24/31;
  I'm not quite happy with the fix, but don't have better ideas),
  and xdp_synproxy. (Andrii)
- Prettify liburandom_read and verify_pkcs7_sig fixes. (Andrii)
- Fix bpf_usdt_arg using barrier_var(); prettify barrier_var(). (Andrii)
- Change BPF_MAX_TRAMP_LINKS to enum and query it using BTF. (Andrii)
- Improve bpf_jit_supports_kfunc_call() description. (Alexei)
- Always check sign_extend() return value.
- Cc: Alexander Gordeev.

Hi,

This series implements poke, trampoline, kfunc, and mixing subprogs
and tailcalls on s390x.

The following failures still remain:

#82      get_stack_raw_tp:FAIL
get_stack_print_output:FAIL:user_stack corrupted user stack
Known issue:
We cannot reliably unwind userspace on s390x without DWARF.

#101     ksyms_module:FAIL
address of kernel function bpf_testmod_test_mod_kfunc is out of range
Known issue:
Kernel and modules are too far away from each other on s390x.

#190     stacktrace_build_id:FAIL
Known issue:
We cannot reliably unwind userspace on s390x without DWARF.

#281     xdp_metadata:FAIL
See patch 6.

None of these seem to be due to the new changes.

Best regards,
Ilya
====================
Signed-off-by: default avatarAlexei Starovoitov <ast@kernel.org>
parents 07dcbd73 ee105d5a
This diff is collapsed.
...@@ -944,7 +944,11 @@ struct btf_func_model { ...@@ -944,7 +944,11 @@ struct btf_func_model {
* bytes on x86. * bytes on x86.
*/ */
enum { enum {
#if defined(__s390x__)
BPF_MAX_TRAMP_LINKS = 27,
#else
BPF_MAX_TRAMP_LINKS = 38, BPF_MAX_TRAMP_LINKS = 38,
#endif
}; };
struct bpf_tramp_links { struct bpf_tramp_links {
......
This diff is collapsed.
...@@ -29,7 +29,23 @@ static int stop, duration; ...@@ -29,7 +29,23 @@ static int stop, duration;
static bool static bool
configure_stack(void) configure_stack(void)
{ {
char tc_version[128];
char tc_cmd[BUFSIZ]; char tc_cmd[BUFSIZ];
char *prog;
FILE *tc;
/* Check whether tc is built with libbpf. */
tc = popen("tc -V", "r");
if (CHECK_FAIL(!tc))
return false;
if (CHECK_FAIL(!fgets(tc_version, sizeof(tc_version), tc)))
return false;
if (strstr(tc_version, ", libbpf "))
prog = "test_sk_assign_libbpf.bpf.o";
else
prog = "test_sk_assign.bpf.o";
if (CHECK_FAIL(pclose(tc)))
return false;
/* Move to a new networking namespace */ /* Move to a new networking namespace */
if (CHECK_FAIL(unshare(CLONE_NEWNET))) if (CHECK_FAIL(unshare(CLONE_NEWNET)))
...@@ -46,8 +62,8 @@ configure_stack(void) ...@@ -46,8 +62,8 @@ configure_stack(void)
/* Load qdisc, BPF program */ /* Load qdisc, BPF program */
if (CHECK_FAIL(system("tc qdisc add dev lo clsact"))) if (CHECK_FAIL(system("tc qdisc add dev lo clsact")))
return false; return false;
sprintf(tc_cmd, "%s %s %s %s", "tc filter add dev lo ingress bpf", sprintf(tc_cmd, "%s %s %s %s %s", "tc filter add dev lo ingress bpf",
"direct-action object-file ./test_sk_assign.bpf.o", "direct-action object-file", prog,
"section tc", "section tc",
(env.verbosity < VERBOSE_VERY) ? " 2>/dev/null" : "verbose"); (env.verbosity < VERBOSE_VERY) ? " 2>/dev/null" : "verbose");
if (CHECK(system(tc_cmd), "BPF load failed;", if (CHECK(system(tc_cmd), "BPF load failed;",
...@@ -129,15 +145,12 @@ get_port(int fd) ...@@ -129,15 +145,12 @@ get_port(int fd)
static ssize_t static ssize_t
rcv_msg(int srv_client, int type) rcv_msg(int srv_client, int type)
{ {
struct sockaddr_storage ss;
char buf[BUFSIZ]; char buf[BUFSIZ];
socklen_t slen;
if (type == SOCK_STREAM) if (type == SOCK_STREAM)
return read(srv_client, &buf, sizeof(buf)); return read(srv_client, &buf, sizeof(buf));
else else
return recvfrom(srv_client, &buf, sizeof(buf), 0, return recvfrom(srv_client, &buf, sizeof(buf), 0, NULL, NULL);
(struct sockaddr *)&ss, &slen);
} }
static int static int
......
...@@ -16,6 +16,16 @@ ...@@ -16,6 +16,16 @@
#include <bpf/bpf_helpers.h> #include <bpf/bpf_helpers.h>
#include <bpf/bpf_endian.h> #include <bpf/bpf_endian.h>
#if defined(IPROUTE2_HAVE_LIBBPF)
/* Use a new-style map definition. */
struct {
__uint(type, BPF_MAP_TYPE_SOCKMAP);
__type(key, int);
__type(value, __u64);
__uint(pinning, LIBBPF_PIN_BY_NAME);
__uint(max_entries, 1);
} server_map SEC(".maps");
#else
/* Pin map under /sys/fs/bpf/tc/globals/<map name> */ /* Pin map under /sys/fs/bpf/tc/globals/<map name> */
#define PIN_GLOBAL_NS 2 #define PIN_GLOBAL_NS 2
...@@ -35,6 +45,7 @@ struct { ...@@ -35,6 +45,7 @@ struct {
.max_elem = 1, .max_elem = 1,
.pinning = PIN_GLOBAL_NS, .pinning = PIN_GLOBAL_NS,
}; };
#endif
char _license[] SEC("license") = "GPL"; char _license[] SEC("license") = "GPL";
......
// SPDX-License-Identifier: GPL-2.0
#define IPROUTE2_HAVE_LIBBPF
#include "test_sk_assign.c"
...@@ -13,7 +13,7 @@ s390x) ...@@ -13,7 +13,7 @@ s390x)
QEMU_BINARY=qemu-system-s390x QEMU_BINARY=qemu-system-s390x
QEMU_CONSOLE="ttyS1" QEMU_CONSOLE="ttyS1"
QEMU_FLAGS=(-smp 2) QEMU_FLAGS=(-smp 2)
BZIMAGE="arch/s390/boot/compressed/vmlinux" BZIMAGE="arch/s390/boot/vmlinux"
;; ;;
x86_64) x86_64)
QEMU_BINARY=qemu-system-x86_64 QEMU_BINARY=qemu-system-x86_64
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment