bpf: Allow to change skb mark in test_run
authorNikita V. Shirokov <tehnerd@tehnerd.com>
Wed, 18 Dec 2019 20:57:47 +0000 (12:57 -0800)
committerAlexei Starovoitov <ast@kernel.org>
Thu, 19 Dec 2019 01:05:58 +0000 (17:05 -0800)
allow to pass skb's mark field into bpf_prog_test_run ctx
for BPF_PROG_TYPE_SCHED_CLS prog type. that would allow
to test bpf programs which are doing decision based on this
field

Signed-off-by: Nikita V. Shirokov <tehnerd@tehnerd.com>
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
net/bpf/test_run.c
tools/testing/selftests/bpf/prog_tests/skb_ctx.c
tools/testing/selftests/bpf/progs/test_skb_ctx.c

index 93a9c87787e0702617e2e36ebac417445bd20488..d555c0d8657dad8414adf7a88ea0020c046f12c6 100644 (file)
@@ -251,7 +251,13 @@ static int convert___skb_to_skb(struct sk_buff *skb, struct __sk_buff *__skb)
                return 0;
 
        /* make sure the fields we don't use are zeroed */
-       if (!range_is_zero(__skb, 0, offsetof(struct __sk_buff, priority)))
+       if (!range_is_zero(__skb, 0, offsetof(struct __sk_buff, mark)))
+               return -EINVAL;
+
+       /* mark is allowed */
+
+       if (!range_is_zero(__skb, offsetofend(struct __sk_buff, mark),
+                          offsetof(struct __sk_buff, priority)))
                return -EINVAL;
 
        /* priority is allowed */
@@ -274,6 +280,7 @@ static int convert___skb_to_skb(struct sk_buff *skb, struct __sk_buff *__skb)
                           sizeof(struct __sk_buff)))
                return -EINVAL;
 
+       skb->mark = __skb->mark;
        skb->priority = __skb->priority;
        skb->tstamp = __skb->tstamp;
        memcpy(&cb->data, __skb->cb, QDISC_CB_PRIV_LEN);
@@ -301,6 +308,7 @@ static void convert_skb_to___skb(struct sk_buff *skb, struct __sk_buff *__skb)
        if (!__skb)
                return;
 
+       __skb->mark = skb->mark;
        __skb->priority = skb->priority;
        __skb->tstamp = skb->tstamp;
        memcpy(__skb->cb, &cb->data, QDISC_CB_PRIV_LEN);
index edf5e8c7d400d375fd8b696080a0fdf7b77bdc13..c6d6b685a9468f7cbd1d147be0aaafaa6c5829a2 100644 (file)
@@ -13,6 +13,7 @@ void test_skb_ctx(void)
                .tstamp = 7,
                .wire_len = 100,
                .gso_segs = 8,
+               .mark = 9,
        };
        struct bpf_prog_test_run_attr tattr = {
                .data_in = &pkt_v4,
@@ -93,4 +94,8 @@ void test_skb_ctx(void)
                   "ctx_out_tstamp",
                   "skb->tstamp == %lld, expected %d\n",
                   skb.tstamp, 8);
+       CHECK_ATTR(skb.mark != 10,
+                  "ctx_out_mark",
+                  "skb->mark == %u, expected %d\n",
+                  skb.mark, 10);
 }
index 534fbf9a734458abfb28a77a098d77862e126e69..e18da87fe84fa2c9bbe1e0f663ef263ef40ab841 100644 (file)
@@ -17,6 +17,7 @@ int process(struct __sk_buff *skb)
        }
        skb->priority++;
        skb->tstamp++;
+       skb->mark++;
 
        if (skb->wire_len != 100)
                return 1;