SUNRPC: replace casts in auth_unix.c with container_of()
authorTrond Myklebust <Trond.Myklebust@netapp.com>
Mon, 25 Jun 2007 13:48:25 +0000 (09:48 -0400)
committerTrond Myklebust <Trond.Myklebust@netapp.com>
Wed, 11 Jul 2007 03:40:35 +0000 (23:40 -0400)
Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
net/sunrpc/auth_unix.c

index 2f1bdb5c86b3e707bc1730fd1a0844b700389016..f17dabbab1c721bc23e6a7c3dd0bd818403e0b9b 100644 (file)
@@ -89,12 +89,14 @@ unx_create_cred(struct rpc_auth *auth, struct auth_cred *acred, int flags)
                  cred->uc_gids[i] = NOGROUP;
        }
 
-       return (struct rpc_cred *) cred;
+       return &cred->uc_base;
 }
 
 static void
-unx_destroy_cred(struct rpc_cred *cred)
+unx_destroy_cred(struct rpc_cred *rcred)
 {
+       struct unx_cred *cred = container_of(rcred, struct unx_cred, uc_base);
+
        kfree(cred);
 }
 
@@ -106,7 +108,7 @@ unx_destroy_cred(struct rpc_cred *cred)
 static int
 unx_match(struct auth_cred *acred, struct rpc_cred *rcred, int flags)
 {
-       struct unx_cred *cred = (struct unx_cred *) rcred;
+       struct unx_cred *cred = container_of(rcred, struct unx_cred, uc_base);
        int             i;
 
        if (!(flags & RPCAUTH_LOOKUP_ROOTCREDS)) {
@@ -137,7 +139,7 @@ static __be32 *
 unx_marshal(struct rpc_task *task, __be32 *p)
 {
        struct rpc_clnt *clnt = task->tk_client;
-       struct unx_cred *cred = (struct unx_cred *) task->tk_msg.rpc_cred;
+       struct unx_cred *cred = container_of(task->tk_msg.rpc_cred, struct unx_cred, uc_base);
        __be32          *base, *hold;
        int             i;