]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
selftests/bpf: Add testcases for BPF_MUL
authorMatan Shachnai <m.shachnai@gmail.com>
Wed, 18 Dec 2024 03:23:35 +0000 (22:23 -0500)
committerAlexei Starovoitov <ast@kernel.org>
Mon, 30 Dec 2024 22:49:42 +0000 (14:49 -0800)
The previous commit improves precision of BPF_MUL.
Add tests to exercise updated BPF_MUL.

Signed-off-by: Matan Shachnai <m.shachnai@gmail.com>
Link: https://lore.kernel.org/r/20241218032337.12214-3-m.shachnai@gmail.com
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
tools/testing/selftests/bpf/progs/verifier_bounds.c

index a0bb7fb40ea5fab810cfea2813abe4b915c7b6e2..0eb33bb801b5aa62bb08c16e90e75db694b252f7 100644 (file)
@@ -1200,4 +1200,138 @@ l0_%=:  r0 = 0;                                         \
        : __clobber_all);
 }
 
+SEC("tc")
+__description("multiply mixed sign bounds. test 1")
+__success __log_level(2)
+__msg("r6 *= r7 {{.*}}; R6_w=scalar(smin=umin=0x1bc16d5cd4927ee1,smax=umax=0x1bc16d674ec80000,smax32=0x7ffffeff,umax32=0xfffffeff,var_off=(0x1bc16d4000000000; 0x3ffffffeff))")
+__naked void mult_mixed0_sign(void)
+{
+       asm volatile (
+       "call %[bpf_get_prandom_u32];"
+       "r6 = r0;"
+       "call %[bpf_get_prandom_u32];"
+       "r7 = r0;"
+       "r6 &= 0xf;"
+       "r6 -= 1000000000;"
+       "r7 &= 0xf;"
+       "r7 -= 2000000000;"
+       "r6 *= r7;"
+       "exit"
+       :
+       : __imm(bpf_get_prandom_u32),
+         __imm(bpf_skb_store_bytes)
+       : __clobber_all);
+}
+
+SEC("tc")
+__description("multiply mixed sign bounds. test 2")
+__success __log_level(2)
+__msg("r6 *= r7 {{.*}}; R6_w=scalar(smin=smin32=-100,smax=smax32=200)")
+__naked void mult_mixed1_sign(void)
+{
+       asm volatile (
+       "call %[bpf_get_prandom_u32];"
+       "r6 = r0;"
+       "call %[bpf_get_prandom_u32];"
+       "r7 = r0;"
+       "r6 &= 0xf;"
+       "r6 -= 0xa;"
+       "r7 &= 0xf;"
+       "r7 -= 0x14;"
+       "r6 *= r7;"
+       "exit"
+       :
+       : __imm(bpf_get_prandom_u32),
+         __imm(bpf_skb_store_bytes)
+       : __clobber_all);
+}
+
+SEC("tc")
+__description("multiply negative bounds")
+__success __log_level(2)
+__msg("r6 *= r7 {{.*}}; R6_w=scalar(smin=umin=smin32=umin32=0x3ff280b0,smax=umax=smax32=umax32=0x3fff0001,var_off=(0x3ff00000; 0xf81ff))")
+__naked void mult_sign_bounds(void)
+{
+       asm volatile (
+       "r8 = 0x7fff;"
+       "call %[bpf_get_prandom_u32];"
+       "r6 = r0;"
+       "call %[bpf_get_prandom_u32];"
+       "r7 = r0;"
+       "r6 &= 0xa;"
+       "r6 -= r8;"
+       "r7 &= 0xf;"
+       "r7 -= r8;"
+       "r6 *= r7;"
+       "exit"
+       :
+       : __imm(bpf_get_prandom_u32),
+         __imm(bpf_skb_store_bytes)
+       : __clobber_all);
+}
+
+SEC("tc")
+__description("multiply bounds that don't cross signed boundary")
+__success __log_level(2)
+__msg("r8 *= r6 {{.*}}; R6_w=scalar(smin=smin32=0,smax=umax=smax32=umax32=11,var_off=(0x0; 0xb)) R8_w=scalar(smin=0,smax=umax=0x7b96bb0a94a3a7cd,var_off=(0x0; 0x7fffffffffffffff))")
+__naked void mult_no_sign_crossing(void)
+{
+       asm volatile (
+       "r6 = 0xb;"
+       "r8 = 0xb3c3f8c99262687 ll;"
+       "call %[bpf_get_prandom_u32];"
+       "r7 = r0;"
+       "r6 &= r7;"
+       "r8 *= r6;"
+       "exit"
+       :
+       : __imm(bpf_get_prandom_u32),
+         __imm(bpf_skb_store_bytes)
+       : __clobber_all);
+}
+
+SEC("tc")
+__description("multiplication overflow, result in unbounded reg. test 1")
+__success __log_level(2)
+__msg("r6 *= r7 {{.*}}; R6_w=scalar()")
+__naked void mult_unsign_ovf(void)
+{
+       asm volatile (
+       "r8 = 0x7ffffffffff ll;"
+       "call %[bpf_get_prandom_u32];"
+       "r6 = r0;"
+       "call %[bpf_get_prandom_u32];"
+       "r7 = r0;"
+       "r6 &= 0x7fffffff;"
+       "r7 &= r8;"
+       "r6 *= r7;"
+       "exit"
+       :
+       : __imm(bpf_get_prandom_u32),
+         __imm(bpf_skb_store_bytes)
+       : __clobber_all);
+}
+
+SEC("tc")
+__description("multiplication overflow, result in unbounded reg. test 2")
+__success __log_level(2)
+__msg("r6 *= r7 {{.*}}; R6_w=scalar()")
+__naked void mult_sign_ovf(void)
+{
+       asm volatile (
+       "r8 = 0x7ffffffff ll;"
+       "call %[bpf_get_prandom_u32];"
+       "r6 = r0;"
+       "call %[bpf_get_prandom_u32];"
+       "r7 = r0;"
+       "r6 &= 0xa;"
+       "r6 -= r8;"
+       "r7 &= 0x7fffffff;"
+       "r6 *= r7;"
+       "exit"
+       :
+       : __imm(bpf_get_prandom_u32),
+         __imm(bpf_skb_store_bytes)
+       : __clobber_all);
+}
 char _license[] SEC("license") = "GPL";