Skip to content

Commit 2a338a5

Browse files
olgakorn1Trond Myklebust
authored andcommitted
sunrpc: add a symlink from rpc-client directory to the xprt_switch
An rpc client uses a transport switch and one ore more transports associated with that switch. Since transports are shared among rpc clients, create a symlink into the xprt_switch directory instead of duplicating entries under each rpc client. Signed-off-by: Olga Kornievskaia <kolga@netapp.com> Signed-off-by: Trond Myklebust <trond.myklebust@hammerspace.com>
1 parent baea994 commit 2a338a5

File tree

3 files changed

+26
-4
lines changed

3 files changed

+26
-4
lines changed

net/sunrpc/clnt.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -301,7 +301,6 @@ static int rpc_client_register(struct rpc_clnt *clnt,
301301
int err;
302302

303303
rpc_clnt_debugfs_register(clnt);
304-
rpc_sysfs_client_setup(clnt, net);
305304

306305
pipefs_sb = rpc_get_sb_net(net);
307306
if (pipefs_sb) {
@@ -426,6 +425,7 @@ static struct rpc_clnt * rpc_new_client(const struct rpc_create_args *args,
426425
/* save the nodename */
427426
rpc_clnt_set_nodename(clnt, nodename);
428427

428+
rpc_sysfs_client_setup(clnt, xps, rpc_net_ns(clnt));
429429
err = rpc_client_register(clnt, args->authflavor, args->client_name);
430430
if (err)
431431
goto out_no_path;

net/sunrpc/sysfs.c

Lines changed: 20 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -151,14 +151,29 @@ rpc_sysfs_xprt_switch_alloc(struct kobject *parent,
151151
return NULL;
152152
}
153153

154-
void rpc_sysfs_client_setup(struct rpc_clnt *clnt, struct net *net)
154+
void rpc_sysfs_client_setup(struct rpc_clnt *clnt,
155+
struct rpc_xprt_switch *xprt_switch,
156+
struct net *net)
155157
{
156158
struct rpc_sysfs_client *rpc_client;
157159

158-
rpc_client = rpc_sysfs_client_alloc(rpc_sunrpc_client_kobj, net, clnt->cl_clid);
160+
rpc_client = rpc_sysfs_client_alloc(rpc_sunrpc_client_kobj,
161+
net, clnt->cl_clid);
159162
if (rpc_client) {
163+
char name[] = "switch";
164+
struct rpc_sysfs_xprt_switch *xswitch =
165+
(struct rpc_sysfs_xprt_switch *)xprt_switch->xps_sysfs;
166+
int ret;
167+
160168
clnt->cl_sysfs = rpc_client;
169+
rpc_client->clnt = clnt;
170+
rpc_client->xprt_switch = xprt_switch;
161171
kobject_uevent(&rpc_client->kobject, KOBJ_ADD);
172+
ret = sysfs_create_link_nowarn(&rpc_client->kobject,
173+
&xswitch->kobject, name);
174+
if (ret)
175+
pr_warn("can't create link to %s in sysfs (%d)\n",
176+
name, ret);
162177
}
163178
}
164179

@@ -189,6 +204,9 @@ void rpc_sysfs_client_destroy(struct rpc_clnt *clnt)
189204
struct rpc_sysfs_client *rpc_client = clnt->cl_sysfs;
190205

191206
if (rpc_client) {
207+
char name[] = "switch";
208+
209+
sysfs_remove_link(&rpc_client->kobject, name);
192210
kobject_uevent(&rpc_client->kobject, KOBJ_REMOVE);
193211
kobject_del(&rpc_client->kobject);
194212
kobject_put(&rpc_client->kobject);

net/sunrpc/sysfs.h

Lines changed: 5 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -8,6 +8,8 @@
88
struct rpc_sysfs_client {
99
struct kobject kobject;
1010
struct net *net;
11+
struct rpc_clnt *clnt;
12+
struct rpc_xprt_switch *xprt_switch;
1113
};
1214

1315
struct rpc_sysfs_xprt_switch {
@@ -20,7 +22,9 @@ struct rpc_sysfs_xprt_switch {
2022
int rpc_sysfs_init(void);
2123
void rpc_sysfs_exit(void);
2224

23-
void rpc_sysfs_client_setup(struct rpc_clnt *clnt, struct net *net);
25+
void rpc_sysfs_client_setup(struct rpc_clnt *clnt,
26+
struct rpc_xprt_switch *xprt_switch,
27+
struct net *net);
2428
void rpc_sysfs_client_destroy(struct rpc_clnt *clnt);
2529
void rpc_sysfs_xprt_switch_setup(struct rpc_xprt_switch *xprt_switch,
2630
struct rpc_xprt *xprt, gfp_t gfp_flags);

0 commit comments

Comments
 (0)