bpf: fix cb access in socket filter programs on tail calls
Commitff936a04e5
("bpf: fix cb access in socket filter programs") added a fix for socket filter programs such that in i) AF_PACKET the 20 bytes of skb->cb[] area gets zeroed before use in order to not leak data, and ii) socket filter programs attached to TCP/UDP sockets need to save/restore these 20 bytes since they are also used by protocol layers at that time. The problem is that bpf_prog_run_save_cb() and bpf_prog_run_clear_cb() only look at the actual attached program to determine whether to zero or save/restore the skb->cb[] parts. There can be cases where the actual attached program does not access the skb->cb[], but the program tail calls into another program which does access this area. In such a case, the zero or save/restore is currently not performed. Since the programs we tail call into are unknown at verification time and can dynamically change, we need to assume that whenever the attached program performs a tail call, that later programs could access the skb->cb[], and therefore we need to always set cb_access to 1. Fixes:ff936a04e5
("bpf: fix cb access in socket filter programs") Signed-off-by: Daniel Borkmann <daniel@iogearbox.net> Acked-by: Alexei Starovoitov <ast@kernel.org> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
0aa8c13eb5
commit
6b1bb01bcc
1 changed files with 7 additions and 0 deletions
|
@ -617,6 +617,13 @@ static void fixup_bpf_calls(struct bpf_prog *prog)
|
||||||
if (insn->imm == BPF_FUNC_xdp_adjust_head)
|
if (insn->imm == BPF_FUNC_xdp_adjust_head)
|
||||||
prog->xdp_adjust_head = 1;
|
prog->xdp_adjust_head = 1;
|
||||||
if (insn->imm == BPF_FUNC_tail_call) {
|
if (insn->imm == BPF_FUNC_tail_call) {
|
||||||
|
/* If we tail call into other programs, we
|
||||||
|
* cannot make any assumptions since they
|
||||||
|
* can be replaced dynamically during runtime
|
||||||
|
* in the program array.
|
||||||
|
*/
|
||||||
|
prog->cb_access = 1;
|
||||||
|
|
||||||
/* mark bpf_tail_call as different opcode
|
/* mark bpf_tail_call as different opcode
|
||||||
* to avoid conditional branch in
|
* to avoid conditional branch in
|
||||||
* interpeter for every normal call
|
* interpeter for every normal call
|
||||||
|
|
Loading…
Reference in a new issue