On Fri, Oct 02, 2015 at 05:06:47PM +0200, Nicolas Schichan wrote: > For ARMv7 with UDIV instruction support, generate an UDIV instruction > followed by an MLS instruction. > > For other ARM variants, generate code calling a C wrapper similar to > the jit_udiv() function used for BPF_ALU | BPF_DIV instructions. > > Some performance numbers reported by the test_bpf module (the duration > per filter run is reported in nanoseconds, between "jitted:<x>" and > "PASS": > > ARMv7 QEMU nojit: test_bpf: #3 DIV_MOD_KX jited:0 2196 PASS > ARMv7 QEMU jit: test_bpf: #3 DIV_MOD_KX jited:1 104 PASS > ARMv5 QEMU nojit: test_bpf: #3 DIV_MOD_KX jited:0 2176 PASS > ARMv5 QEMU jit: test_bpf: #3 DIV_MOD_KX jited:1 1104 PASS > ARMv5 kirkwood nojit: test_bpf: #3 DIV_MOD_KX jited:0 1103 PASS > ARMv5 kirkwood jit: test_bpf: #3 DIV_MOD_KX jited:1 311 PASS > > Signed-off-by: Nicolas Schichan <nschic...@freebox.fr>
run-time check for zero is there, so looks good to me Acked-by: Alexei Starovoitov <a...@kernel.org> -- To unsubscribe from this list: send the line "unsubscribe netdev" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html