Loading include/net/phonet/pn_dev.h +1 −0 Original line number Diff line number Diff line Loading @@ -34,6 +34,7 @@ struct phonet_device { struct list_head list; struct net_device *netdev; DECLARE_BITMAP(addrs, 64); struct rcu_head rcu; }; int phonet_device_init(void); Loading net/phonet/pn_dev.c +11 −4 Original line number Diff line number Diff line Loading @@ -162,6 +162,14 @@ int phonet_address_add(struct net_device *dev, u8 addr) return err; } static void phonet_device_rcu_free(struct rcu_head *head) { struct phonet_device *pnd; pnd = container_of(head, struct phonet_device, rcu); kfree(pnd); } int phonet_address_del(struct net_device *dev, u8 addr) { struct phonet_device_list *pndevs = phonet_device_list(dev_net(dev)); Loading @@ -179,10 +187,9 @@ int phonet_address_del(struct net_device *dev, u8 addr) pnd = NULL; mutex_unlock(&pndevs->lock); if (pnd) { synchronize_rcu(); kfree(pnd); } if (pnd) call_rcu(&pnd->rcu, phonet_device_rcu_free); return err; } Loading Loading
include/net/phonet/pn_dev.h +1 −0 Original line number Diff line number Diff line Loading @@ -34,6 +34,7 @@ struct phonet_device { struct list_head list; struct net_device *netdev; DECLARE_BITMAP(addrs, 64); struct rcu_head rcu; }; int phonet_device_init(void); Loading
net/phonet/pn_dev.c +11 −4 Original line number Diff line number Diff line Loading @@ -162,6 +162,14 @@ int phonet_address_add(struct net_device *dev, u8 addr) return err; } static void phonet_device_rcu_free(struct rcu_head *head) { struct phonet_device *pnd; pnd = container_of(head, struct phonet_device, rcu); kfree(pnd); } int phonet_address_del(struct net_device *dev, u8 addr) { struct phonet_device_list *pndevs = phonet_device_list(dev_net(dev)); Loading @@ -179,10 +187,9 @@ int phonet_address_del(struct net_device *dev, u8 addr) pnd = NULL; mutex_unlock(&pndevs->lock); if (pnd) { synchronize_rcu(); kfree(pnd); } if (pnd) call_rcu(&pnd->rcu, phonet_device_rcu_free); return err; } Loading