Skip to content

Commit

Permalink
filter: use reciprocal divide
Browse files Browse the repository at this point in the history
At compile time, we can replace the DIV_K instruction (divide by a
constant value) by a reciprocal divide.

At exec time, the expensive divide is replaced by a multiply, a less
expensive operation on most processors.

Signed-off-by: Eric Dumazet <[email protected]>
Acked-by: Changli Gao <[email protected]>
Signed-off-by: David S. Miller <[email protected]>
  • Loading branch information
Eric Dumazet authored and davem330 committed Nov 19, 2010
1 parent 8c1592d commit c26aed4
Showing 1 changed file with 3 additions and 1 deletion.
4 changes: 3 additions & 1 deletion net/core/filter.c
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@
#include <asm/uaccess.h>
#include <asm/unaligned.h>
#include <linux/filter.h>
#include <linux/reciprocal_div.h>

enum {
BPF_S_RET_K = 1,
Expand Down Expand Up @@ -205,7 +206,7 @@ unsigned int sk_run_filter(struct sk_buff *skb, const struct sock_filter *fentry
A /= X;
continue;
case BPF_S_ALU_DIV_K:
A /= K;
A = reciprocal_divide(A, K);
continue;
case BPF_S_ALU_AND_X:
A &= X;
Expand Down Expand Up @@ -506,6 +507,7 @@ int sk_chk_filter(struct sock_filter *filter, int flen)
/* check for division by zero */
if (ftest->k == 0)
return -EINVAL;
ftest->k = reciprocal_value(ftest->k);
break;
case BPF_S_LD_MEM:
case BPF_S_LDX_MEM:
Expand Down

0 comments on commit c26aed4

Please sign in to comment.