[Devel] Re: [PATCH 4/5] SUNRPC: ip map cache per network namespace cleanup
J. Bruce Fields
bfields at fieldses.org
Thu Jan 19 08:37:22 PST 2012
On Thu, Jan 19, 2012 at 06:49:31PM +0400, Stanislav Kinsbursky wrote:
> This patch converts ip_map_cache per network namespace implemenetation to the
> same view, as other caches done in the series.
> Besides generalization, code becomes shorter with this patch.
Again, isnt' it ip_map_cache, and not one of the dynamically created
cache details, that's being passed to the lookup routines?
I may just be confused....
--b.
>
> Signed-off-by: Stanislav Kinsbursky <skinsbursky at parallels.com>
>
> ---
> net/sunrpc/svcauth_unix.c | 71 +++++++++++++++++++--------------------------
> 1 files changed, 30 insertions(+), 41 deletions(-)
>
> diff --git a/net/sunrpc/svcauth_unix.c b/net/sunrpc/svcauth_unix.c
> index c753ae4..0a50788 100644
> --- a/net/sunrpc/svcauth_unix.c
> +++ b/net/sunrpc/svcauth_unix.c
> @@ -211,7 +211,7 @@ static int ip_map_parse(struct cache_detail *cd,
> len = qword_get(&mesg, buf, mlen);
> if (len <= 0) return -EINVAL;
>
> - if (rpc_pton(&init_net, buf, len, &address.sa, sizeof(address)) == 0)
> + if (rpc_pton(cd->net, buf, len, &address.sa, sizeof(address)) == 0)
> return -EINVAL;
> switch (address.sa.sa_family) {
> case AF_INET:
> @@ -875,56 +875,45 @@ struct auth_ops svcauth_unix = {
> .set_client = svcauth_unix_set_client,
> };
>
> +struct cache_detail ip_map_cache = {
> + .owner = THIS_MODULE,
> + .hash_size = IP_HASHMAX,
> + .name = "auth.unix.ip",
> + .cache_put = ip_map_put,
> + .cache_upcall = ip_map_upcall,
> + .cache_parse = ip_map_parse,
> + .cache_show = ip_map_show,
> + .match = ip_map_match,
> + .init = ip_map_init,
> + .update = update,
> + .alloc = ip_map_alloc,
> +};
> +
> int ip_map_cache_create(struct net *net)
> {
> - int err = -ENOMEM;
> - struct cache_detail *cd;
> - struct cache_head **tbl;
> struct sunrpc_net *sn = net_generic(net, sunrpc_net_id);
> + struct cache_detail *cd;
> + int err;
>
> - cd = kzalloc(sizeof(struct cache_detail), GFP_KERNEL);
> - if (cd == NULL)
> - goto err_cd;
> -
> - tbl = kzalloc(IP_HASHMAX * sizeof(struct cache_head *), GFP_KERNEL);
> - if (tbl == NULL)
> - goto err_tbl;
> -
> - cd->owner = THIS_MODULE,
> - cd->hash_size = IP_HASHMAX,
> - cd->hash_table = tbl,
> - cd->name = "auth.unix.ip",
> - cd->cache_put = ip_map_put,
> - cd->cache_upcall = ip_map_upcall,
> - cd->cache_parse = ip_map_parse,
> - cd->cache_show = ip_map_show,
> - cd->match = ip_map_match,
> - cd->init = ip_map_init,
> - cd->update = update,
> - cd->alloc = ip_map_alloc,
> -
> + cd = cache_create_net(&ip_map_cache, net);
> + if (IS_ERR(cd))
> + return PTR_ERR(cd);
> err = cache_register_net(cd, net);
> - if (err)
> - goto err_reg;
> -
> + if (err) {
> + cache_destroy_net(cd, net);
> + return err;
> + }
> sn->ip_map_cache = cd;
> return 0;
> -
> -err_reg:
> - kfree(tbl);
> -err_tbl:
> - kfree(cd);
> -err_cd:
> - return err;
> }
>
> void ip_map_cache_destroy(struct net *net)
> {
> - struct sunrpc_net *sn;
> + struct sunrpc_net *sn = net_generic(net, sunrpc_net_id);
> + struct cache_detail *cd = sn->ip_map_cache;
>
> - sn = net_generic(net, sunrpc_net_id);
> - cache_purge(sn->ip_map_cache);
> - cache_unregister_net(sn->ip_map_cache, net);
> - kfree(sn->ip_map_cache->hash_table);
> - kfree(sn->ip_map_cache);
> + sn->ip_map_cache = NULL;
> + cache_purge(cd);
> + cache_unregister_net(cd, net);
> + cache_destroy_net(cd, net);
> }
>
More information about the Devel
mailing list