diff options
author | Daniel Borkmann <daniel@iogearbox.net> | 2018-11-26 14:05:38 +0100 |
---|---|---|
committer | Alexei Starovoitov <ast@kernel.org> | 2018-11-27 02:34:24 +0100 |
commit | e2c95a61656d29ceaac97b6a975c8a1f26e26f15 (patch) | |
tree | 8fb9a3cc00ef0b47edb7428d297bc921b39e1f2f /scripts | |
parent | Merge git://git.kernel.org/pub/scm/linux/kernel/git/bpf/bpf (diff) | |
download | linux-e2c95a61656d29ceaac97b6a975c8a1f26e26f15.tar.xz linux-e2c95a61656d29ceaac97b6a975c8a1f26e26f15.zip |
bpf, ppc64: generalize fetching subprog into bpf_jit_get_func_addr
Make fetching of the BPF call address from ppc64 JIT generic. ppc64
was using a slightly different variant rather than through the insns'
imm field encoding as the target address would not fit into that space.
Therefore, the target subprog number was encoded into the insns' offset
and fetched through fp->aux->func[off]->bpf_func instead. Given there
are other JITs with this issue and the mechanism of fetching the address
is JIT-generic, move it into the core as a helper instead. On the JIT
side, we get information on whether the retrieved address is a fixed
one, that is, not changing through JIT passes, or a dynamic one. For
the former, JITs can optimize their imm emission because this doesn't
change jump offsets throughout JIT process.
Signed-off-by: Daniel Borkmann <daniel@iogearbox.net>
Reviewed-by: Sandipan Das <sandipan@linux.ibm.com>
Tested-by: Sandipan Das <sandipan@linux.ibm.com>
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
Diffstat (limited to 'scripts')
0 files changed, 0 insertions, 0 deletions