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 <eric.dumazet@gmail.com>
Acked-by: Changli Gao <xiaosuo@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
 #include <asm/uaccess.h>
 #include <asm/unaligned.h>
 #include <linux/filter.h>
+#include <linux/reciprocal_div.h>
 
 enum {
        BPF_S_RET_K = 1,
                        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;
                        /* 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: