summaryrefslogtreecommitdiffstats
path: root/kernel/bpf
diff options
context:
space:
mode:
authorDaniel Borkmann <daniel@iogearbox.net>2018-01-16 03:46:08 +0100
committerAlexei Starovoitov <ast@kernel.org>2018-01-16 11:29:15 -0800
commita2284d912bfc865cdca4c00488e08a3550f9a405 (patch)
tree03aea207e0887441cad8e42550fc6fbf3475ae8c /kernel/bpf
parent68fda450a7df51cff9e5a4d4a4d9d0d5f2589153 (diff)
downloadlinux-a2284d912bfc865cdca4c00488e08a3550f9a405.tar.bz2
bpf, arm64: fix stack_depth tracking in combination with tail calls
Using dynamic stack_depth tracking in arm64 JIT is currently broken in combination with tail calls. In prologue, we cache ctx->stack_size and adjust SP reg for setting up function call stack, and tearing it down again in epilogue. Problem is that when doing a tail call, the cached ctx->stack_size might not be the same. One way to fix the problem with minimal overhead is to re-adjust SP in emit_bpf_tail_call() and properly adjust it to the current program's ctx->stack_size. Tested on Cavium ThunderX ARMv8. Fixes: f1c9eed7f437 ("bpf, arm64: take advantage of stack_depth tracking") Signed-off-by: Daniel Borkmann <daniel@iogearbox.net> Signed-off-by: Alexei Starovoitov <ast@kernel.org>
Diffstat (limited to 'kernel/bpf')
0 files changed, 0 insertions, 0 deletions