提交 b6663ad7 编写于 作者: D David S. Miller

Merge branch 'cls_bpf'

Daniel Borkmann says:

====================
Two cls_bpf fixes

Found them while doing a review on act_bpf and going over the
cls_bpf code again. Will also address the first issue in act_bpf
as it needs to be fixed there, too.
====================
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
...@@ -180,6 +180,11 @@ static int cls_bpf_modify_existing(struct net *net, struct tcf_proto *tp, ...@@ -180,6 +180,11 @@ static int cls_bpf_modify_existing(struct net *net, struct tcf_proto *tp,
} }
bpf_size = bpf_len * sizeof(*bpf_ops); bpf_size = bpf_len * sizeof(*bpf_ops);
if (bpf_size != nla_len(tb[TCA_BPF_OPS])) {
ret = -EINVAL;
goto errout;
}
bpf_ops = kzalloc(bpf_size, GFP_KERNEL); bpf_ops = kzalloc(bpf_size, GFP_KERNEL);
if (bpf_ops == NULL) { if (bpf_ops == NULL) {
ret = -ENOMEM; ret = -ENOMEM;
...@@ -215,15 +220,21 @@ static u32 cls_bpf_grab_new_handle(struct tcf_proto *tp, ...@@ -215,15 +220,21 @@ static u32 cls_bpf_grab_new_handle(struct tcf_proto *tp,
struct cls_bpf_head *head) struct cls_bpf_head *head)
{ {
unsigned int i = 0x80000000; unsigned int i = 0x80000000;
u32 handle;
do { do {
if (++head->hgen == 0x7FFFFFFF) if (++head->hgen == 0x7FFFFFFF)
head->hgen = 1; head->hgen = 1;
} while (--i > 0 && cls_bpf_get(tp, head->hgen)); } while (--i > 0 && cls_bpf_get(tp, head->hgen));
if (i == 0)
if (unlikely(i == 0)) {
pr_err("Insufficient number of handles\n"); pr_err("Insufficient number of handles\n");
handle = 0;
} else {
handle = head->hgen;
}
return i; return handle;
} }
static int cls_bpf_change(struct net *net, struct sk_buff *in_skb, static int cls_bpf_change(struct net *net, struct sk_buff *in_skb,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册