]> git.proxmox.com Git - mirror_ubuntu-eoan-kernel.git/commitdiff
cls_basic: Convert to use idr_alloc_u32
authorMatthew Wilcox <mawilcox@microsoft.com>
Tue, 28 Nov 2017 15:36:09 +0000 (10:36 -0500)
committerMatthew Wilcox <mawilcox@microsoft.com>
Tue, 6 Feb 2018 21:41:26 +0000 (16:41 -0500)
Use the new helper which saves a temporary variable and a few lines of
code.

Signed-off-by: Matthew Wilcox <mawilcox@microsoft.com>
net/sched/cls_basic.c

index 588c635f195e9c785d771714d18967c324278f8d..6b7ab3512f5bb8136162b2275c5d789a5dceb084 100644 (file)
@@ -185,7 +185,6 @@ static int basic_change(struct net *net, struct sk_buff *in_skb,
        struct nlattr *tb[TCA_BASIC_MAX + 1];
        struct basic_filter *fold = (struct basic_filter *) *arg;
        struct basic_filter *fnew;
-       unsigned long idr_index;
 
        if (tca[TCA_OPTIONS] == NULL)
                return -EINVAL;
@@ -208,21 +207,17 @@ static int basic_change(struct net *net, struct sk_buff *in_skb,
        if (err < 0)
                goto errout;
 
-       if (handle) {
-               fnew->handle = handle;
-               if (!fold) {
-                       err = idr_alloc_ext(&head->handle_idr, fnew, &idr_index,
-                                           handle, handle + 1, GFP_KERNEL);
-                       if (err)
-                               goto errout;
-               }
-       } else {
-               err = idr_alloc_ext(&head->handle_idr, fnew, &idr_index,
-                                   1, 0x7FFFFFFF, GFP_KERNEL);
-               if (err)
-                       goto errout;
-               fnew->handle = idr_index;
+       if (!handle) {
+               handle = 1;
+               err = idr_alloc_u32(&head->handle_idr, fnew, &handle,
+                                   INT_MAX, GFP_KERNEL);
+       } else if (!fold) {
+               err = idr_alloc_u32(&head->handle_idr, fnew, &handle,
+                                   handle, GFP_KERNEL);
        }
+       if (err)
+               goto errout;
+       fnew->handle = handle;
 
        err = basic_set_parms(net, tp, fnew, base, tb, tca[TCA_RATE], ovr,
                              extack);