From: Markus Kötter Date: Sat, 17 Dec 2011 11:39:08 +0000 (+0000) Subject: net: bpf_jit: fix an off-one bug in x86_64 cond jump target X-Git-Tag: firefly_0821_release~7541^2~2037 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=b3c5fb8252b04ec02654f80988e68852f1a14cb5;p=firefly-linux-kernel-4.4.55.git net: bpf_jit: fix an off-one bug in x86_64 cond jump target [ Upstream commit a03ffcf873fe0f2565386ca8ef832144c42e67fa ] x86 jump instruction size is 2 or 5 bytes (near/long jump), not 2 or 6 bytes. In case a conditional jump is followed by a long jump, conditional jump target is one byte past the start of target instruction. Signed-off-by: Markus Kötter Signed-off-by: Eric Dumazet Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- diff --git a/arch/x86/net/bpf_jit_comp.c b/arch/x86/net/bpf_jit_comp.c index bfab3fa10edc..7b65f752c5f8 100644 --- a/arch/x86/net/bpf_jit_comp.c +++ b/arch/x86/net/bpf_jit_comp.c @@ -568,8 +568,8 @@ cond_branch: f_offset = addrs[i + filter[i].jf] - addrs[i]; break; } if (filter[i].jt != 0) { - if (filter[i].jf) - t_offset += is_near(f_offset) ? 2 : 6; + if (filter[i].jf && f_offset) + t_offset += is_near(f_offset) ? 2 : 5; EMIT_COND_JMP(t_op, t_offset); if (filter[i].jf) EMIT_JMP(f_offset);