Lines Matching refs:npinfo
100 struct netpoll_info *npinfo = in queue_process() local
105 while ((skb = skb_dequeue(&npinfo->txq))) { in queue_process()
120 skb_queue_head(&npinfo->txq, skb); in queue_process()
124 schedule_delayed_work(&npinfo->tx_work, HZ/10); in queue_process()
187 struct netpoll_info *ni = rcu_dereference_bh(dev->npinfo); in netpoll_poll_dev()
223 ni = srcu_dereference(dev->npinfo, &netpoll_srcu); in netpoll_poll_disable()
234 ni = rcu_dereference(dev->npinfo); in netpoll_poll_enable()
329 struct netpoll_info *npinfo; in netpoll_send_skb_on_dev() local
333 npinfo = rcu_dereference_bh(np->dev->npinfo); in netpoll_send_skb_on_dev()
334 if (!npinfo || !netif_running(dev) || !netif_device_present(dev)) { in netpoll_send_skb_on_dev()
340 if (skb_queue_len(&npinfo->txq) == 0 && !netpoll_owner_active(dev)) { in netpoll_send_skb_on_dev()
372 skb_queue_tail(&npinfo->txq, skb); in netpoll_send_skb_on_dev()
373 schedule_delayed_work(&npinfo->tx_work,0); in netpoll_send_skb_on_dev()
602 struct netpoll_info *npinfo; in __netpoll_setup() local
618 if (!ndev->npinfo) { in __netpoll_setup()
619 npinfo = kmalloc(sizeof(*npinfo), GFP_KERNEL); in __netpoll_setup()
620 if (!npinfo) { in __netpoll_setup()
625 sema_init(&npinfo->dev_lock, 1); in __netpoll_setup()
626 skb_queue_head_init(&npinfo->txq); in __netpoll_setup()
627 INIT_DELAYED_WORK(&npinfo->tx_work, queue_process); in __netpoll_setup()
629 atomic_set(&npinfo->refcnt, 1); in __netpoll_setup()
633 err = ops->ndo_netpoll_setup(ndev, npinfo); in __netpoll_setup()
638 npinfo = rtnl_dereference(ndev->npinfo); in __netpoll_setup()
639 atomic_inc(&npinfo->refcnt); in __netpoll_setup()
642 npinfo->netpoll = np; in __netpoll_setup()
645 rcu_assign_pointer(ndev->npinfo, npinfo); in __netpoll_setup()
650 kfree(npinfo); in __netpoll_setup()
789 struct netpoll_info *npinfo = in rcu_cleanup_netpoll_info() local
792 skb_queue_purge(&npinfo->txq); in rcu_cleanup_netpoll_info()
795 cancel_delayed_work(&npinfo->tx_work); in rcu_cleanup_netpoll_info()
798 __skb_queue_purge(&npinfo->txq); in rcu_cleanup_netpoll_info()
800 cancel_delayed_work(&npinfo->tx_work); in rcu_cleanup_netpoll_info()
801 kfree(npinfo); in rcu_cleanup_netpoll_info()
806 struct netpoll_info *npinfo; in __netpoll_cleanup() local
812 npinfo = rtnl_dereference(np->dev->npinfo); in __netpoll_cleanup()
813 if (!npinfo) in __netpoll_cleanup()
818 if (atomic_dec_and_test(&npinfo->refcnt)) { in __netpoll_cleanup()
825 RCU_INIT_POINTER(np->dev->npinfo, NULL); in __netpoll_cleanup()
826 call_rcu_bh(&npinfo->rcu, rcu_cleanup_netpoll_info); in __netpoll_cleanup()
828 RCU_INIT_POINTER(np->dev->npinfo, NULL); in __netpoll_cleanup()