net_sched: move tp->root allocation into fw_init()
authorWANG Cong <xiyou.wangcong@gmail.com>
Thu, 5 Mar 2015 04:11:44 +0000 (20:11 -0800)
committerDavid S. Miller <davem@davemloft.net>
Fri, 6 Mar 2015 02:30:44 +0000 (21:30 -0500)
Cc: Jamal Hadi Salim <jhs@mojatatu.com>
Signed-off-by: Cong Wang <xiyou.wangcong@gmail.com>
Acked-by: Jamal Hadi Salim <jhs@mojatatu.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/sched/cls_fw.c

index a5269f76004c2974a2e1e650433a7ba394710965..9d9aa3e82b108d17fbb168310e60ba913e5f50fc 100644 (file)
@@ -33,6 +33,7 @@
 
 struct fw_head {
        u32                     mask;
+       bool                    mask_set;
        struct fw_filter __rcu  *ht[HTSIZE];
        struct rcu_head         rcu;
 };
@@ -113,6 +114,14 @@ static unsigned long fw_get(struct tcf_proto *tp, u32 handle)
 
 static int fw_init(struct tcf_proto *tp)
 {
+       struct fw_head *head;
+
+       head = kzalloc(sizeof(struct fw_head), GFP_KERNEL);
+       if (head == NULL)
+               return -ENOBUFS;
+
+       head->mask_set = false;
+       rcu_assign_pointer(tp->root, head);
        return 0;
 }
 
@@ -286,17 +295,11 @@ static int fw_change(struct net *net, struct sk_buff *in_skb,
        if (!handle)
                return -EINVAL;
 
-       if (head == NULL) {
-               u32 mask = 0xFFFFFFFF;
+       if (!head->mask_set) {
+               head->mask = 0xFFFFFFFF;
                if (tb[TCA_FW_MASK])
-                       mask = nla_get_u32(tb[TCA_FW_MASK]);
-
-               head = kzalloc(sizeof(struct fw_head), GFP_KERNEL);
-               if (head == NULL)
-                       return -ENOBUFS;
-               head->mask = mask;
-
-               rcu_assign_pointer(tp->root, head);
+                       head->mask = nla_get_u32(tb[TCA_FW_MASK]);
+               head->mask_set = true;
        }
 
        f = kzalloc(sizeof(struct fw_filter), GFP_KERNEL);