SUNRPC: Fix a pipe_version reference leak
authorTrond Myklebust <trond.myklebust@primarydata.com>
Sun, 16 Feb 2014 18:28:01 +0000 (13:28 -0500)
committerTrond Myklebust <trond.myklebust@primarydata.com>
Sun, 16 Feb 2014 18:28:01 +0000 (13:28 -0500)
In gss_alloc_msg(), if the call to gss_encode_v1_msg() fails, we
want to release the reference to the pipe_version that was obtained
earlier in the function.

Fixes: 9d3a2260f0f4b (SUNRPC: Fix buffer overflow checking in...)
Signed-off-by: Trond Myklebust <trond.myklebust@primarydata.com>
net/sunrpc/auth_gss/auth_gss.c

index 1ba1fd1149126984637317342615197c2ac5bc9a..36e431ee1c902ef1c6ed777331cf97ceda0bdee4 100644 (file)
@@ -500,10 +500,12 @@ gss_alloc_msg(struct gss_auth *gss_auth,
        default:
                err = gss_encode_v1_msg(gss_msg, service_name, gss_auth->target_name);
                if (err)
-                       goto err_free_msg;
+                       goto err_put_pipe_version;
        };
        kref_get(&gss_auth->kref);
        return gss_msg;
+err_put_pipe_version:
+       put_pipe_version(gss_auth->net);
 err_free_msg:
        kfree(gss_msg);
 err: