lists.openwall.net | lists / announce owl-users owl-dev john-users john-dev passwdqc-users yescrypt popa3d-users / oss-security kernel-hardening musl sabotage tlsify passwords / crypt-dev xvendor / Bugtraq Full-Disclosure linux-kernel linux-netdev linux-ext4 linux-hardening linux-cve-announce PHC | |
Open Source and information security mailing list archives
| ||
|
Date: Mon, 30 Jan 2012 14:45:23 +0000 From: Wei Liu <wei.liu2@...rix.com> To: netdev@...r.kernel.org, xen-devel@...ts.xensource.com CC: ian.campbell@...rix.com, konrad.wilk@...cle.com, Wei Liu <wei.liu2@...rix.com> Subject: [RFC PATCH V3 05/16] netback: add module get/put operations along with vif connect/disconnect. If there is vif running and user unloads netback, it will certainly cause problems -- guest's network interface just mysteriously stops working. v2: fix module_put path disconnect function may get called by the generic framework even before vif connects. Tested-by: Konrad Rzeszutek Wilk <konrad.wilk@...cle.com> Signed-off-by: Wei Liu <wei.liu2@...rix.com> --- drivers/net/xen-netback/interface.c | 11 ++++++++++- 1 files changed, 10 insertions(+), 1 deletions(-) diff --git a/drivers/net/xen-netback/interface.c b/drivers/net/xen-netback/interface.c index dfc04f8..7914f60 100644 --- a/drivers/net/xen-netback/interface.c +++ b/drivers/net/xen-netback/interface.c @@ -323,6 +323,8 @@ int xenvif_connect(struct xenvif *vif, unsigned long tx_ring_ref, if (vif->irq) return 0; + __module_get(THIS_MODULE); + err = xen_netbk_map_frontend_rings(vif, tx_ring_ref, rx_ring_ref); if (err < 0) goto err; @@ -372,12 +374,14 @@ err_unbind: err_unmap: xen_netbk_unmap_frontend_rings(vif); err: + module_put(THIS_MODULE); return err; } void xenvif_disconnect(struct xenvif *vif) { struct net_device *dev = vif->dev; + int need_module_put = 0; if (netif_carrier_ok(dev)) { rtnl_lock(); @@ -397,12 +401,17 @@ void xenvif_disconnect(struct xenvif *vif) del_timer_sync(&vif->credit_timeout); - if (vif->irq) + if (vif->irq) { unbind_from_irqhandler(vif->irq, vif); + need_module_put = 1; + } unregister_netdev(vif->dev); xen_netbk_unmap_frontend_rings(vif); free_netdev(vif->dev); + + if (need_module_put) + module_put(THIS_MODULE); } -- 1.7.2.5 -- To unsubscribe from this list: send the line "unsubscribe netdev" in the body of a message to majordomo@...r.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists