RDMA/rtrs-srv: Use sysfs_remove_file_self for disconnect
authorJack Wang <jinpu.wang@cloud.ionos.com>
Thu, 17 Dec 2020 14:19:00 +0000 (15:19 +0100)
committerJason Gunthorpe <jgg@nvidia.com>
Fri, 15 Jan 2021 19:25:08 +0000 (15:25 -0400)
Remove self first to avoid deadlock, we don't want to
use close_work to remove sess sysfs.

Fixes: 91b11610af8d ("RDMA/rtrs: server: sysfs interface functions")
Link: https://lore.kernel.org/r/20201217141915.56989-5-jinpu.wang@cloud.ionos.com
Signed-off-by: Jack Wang <jinpu.wang@cloud.ionos.com>
Tested-by: Lutz Pogrell <lutz.pogrell@cloud.ionos.com>
Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
drivers/infiniband/ulp/rtrs/rtrs-srv-sysfs.c

index d2edff3b8f0df04efb665b4321e181c6c9e7e0a5..cca3a0acbabc50e7412e725af14d0d1e2b6e007b 100644 (file)
@@ -51,6 +51,8 @@ static ssize_t rtrs_srv_disconnect_store(struct kobject *kobj,
        sockaddr_to_str((struct sockaddr *)&sess->s.dst_addr, str, sizeof(str));
 
        rtrs_info(s, "disconnect for path %s requested\n", str);
+       /* first remove sysfs itself to avoid deadlock */
+       sysfs_remove_file_self(&sess->kobj, &attr->attr);
        close_sess(sess);
 
        return count;