bpf: Initialise retval in bpf_prog_test_run_xdp()
authorToke Høiland-Jørgensen <toke@redhat.com>
Thu, 10 Mar 2022 11:02:28 +0000 (12:02 +0100)
committerDaniel Borkmann <daniel@iogearbox.net>
Thu, 10 Mar 2022 15:12:10 +0000 (16:12 +0100)
The kernel test robot pointed out that the newly added
bpf_test_run_xdp_live() runner doesn't set the retval in the caller (by
design), which means that the variable can be passed unitialised to
bpf_test_finish(). Fix this by initialising the variable properly.

Fixes: b530e9e1063e ("bpf: Add "live packet" mode for XDP in BPF_PROG_RUN")
Reported-by: kernel test robot <lkp@intel.com>
Reported-by: Dan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: Toke Høiland-Jørgensen <toke@redhat.com>
Signed-off-by: Daniel Borkmann <daniel@iogearbox.net>
Link: https://lore.kernel.org/bpf/20220310110228.161869-1-toke@redhat.com
net/bpf/test_run.c

index 25169908be4a4fb5c511ed912422b689e6c36fc5..0acdc37c841513bd14adabef51d12c6a39bac100 100644 (file)
@@ -1207,9 +1207,9 @@ int bpf_prog_test_run_xdp(struct bpf_prog *prog, const union bpf_attr *kattr,
        bool do_live = (kattr->test.flags & BPF_F_TEST_XDP_LIVE_FRAMES);
        u32 tailroom = SKB_DATA_ALIGN(sizeof(struct skb_shared_info));
        u32 batch_size = kattr->test.batch_size;
+       u32 retval = 0, duration, max_data_sz;
        u32 size = kattr->test.data_size_in;
        u32 headroom = XDP_PACKET_HEADROOM;
-       u32 retval, duration, max_data_sz;
        u32 repeat = kattr->test.repeat;
        struct netdev_rx_queue *rxqueue;
        struct skb_shared_info *sinfo;