[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20190430143933.19368-1-yuehaibing@huawei.com>
Date: Tue, 30 Apr 2019 22:39:33 +0800
From: YueHaibing <yuehaibing@...wei.com>
To: <davem@...emloft.net>, <ericvh@...il.com>, <lucho@...kov.net>,
<asmadeus@...ewreck.org>
CC: <linux-kernel@...r.kernel.org>, <netdev@...r.kernel.org>,
<v9fs-developer@...ts.sourceforge.net>,
YueHaibing <yuehaibing@...wei.com>
Subject: [PATCH -next] 9p/xen: Add cleanup path in p9_trans_xen_init
If xenbus_register_frontend() fails in p9_trans_xen_init,
we should call v9fs_unregister_trans() to do cleanup.
Fixes: 868eb122739a ("xen/9pfs: introduce Xen 9pfs transport driver")
Signed-off-by: YueHaibing <yuehaibing@...wei.com>
---
net/9p/trans_xen.c | 8 +++++++-
1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/net/9p/trans_xen.c b/net/9p/trans_xen.c
index 29420eb..3963eb1 100644
--- a/net/9p/trans_xen.c
+++ b/net/9p/trans_xen.c
@@ -530,13 +530,19 @@ static struct xenbus_driver xen_9pfs_front_driver = {
static int p9_trans_xen_init(void)
{
+ int rc;
+
if (!xen_domain())
return -ENODEV;
pr_info("Initialising Xen transport for 9pfs\n");
v9fs_register_trans(&p9_xen_trans);
- return xenbus_register_frontend(&xen_9pfs_front_driver);
+ rc = xenbus_register_frontend(&xen_9pfs_front_driver);
+ if (rc)
+ v9fs_unregister_trans(&p9_xen_trans);
+
+ return rc;
}
module_init(p9_trans_xen_init);
--
2.7.0
Powered by blists - more mailing lists