Signed-off-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
                                __netpoll_cleanup(&nt->np);
 
                                spin_lock_irqsave(&target_list_lock, flags);
-                               dev_put(nt->np.dev);
+                               dev_put_track(nt->np.dev, &nt->np.dev_tracker);
                                nt->np.dev = NULL;
                                nt->enabled = false;
                                stopped = true;
 
 
 struct netpoll {
        struct net_device *dev;
+       netdevice_tracker dev_tracker;
        char dev_name[IFNAMSIZ];
        const char *name;
 
 
        err = __netpoll_setup(np, ndev);
        if (err)
                goto put;
-
+       netdev_tracker_alloc(ndev, &np->dev_tracker, GFP_KERNEL);
        rtnl_unlock();
        return 0;
 
        if (!np->dev)
                goto out;
        __netpoll_cleanup(np);
-       dev_put(np->dev);
+       dev_put_track(np->dev, &np->dev_tracker);
        np->dev = NULL;
 out:
        rtnl_unlock();