pNFS: Fix a memory leak when attempted pnfs fails
authorTrond Myklebust <trond.myklebust@primarydata.com>
Wed, 17 Jun 2015 23:41:51 +0000 (19:41 -0400)
committerTrond Myklebust <trond.myklebust@primarydata.com>
Thu, 18 Jun 2015 00:00:26 +0000 (20:00 -0400)
pnfs_do_write() expects the call to pnfs_write_through_mds() to free the
pgio header and to release the layout segment before exiting. The problem
is that nfs_pgio_data_destroy() doesn't actually do this; it only frees
the memory allocated by nfs_generic_pgio().

Ditto for pnfs_do_read()...

Fix in both cases is to add a call to hdr->release(hdr).

Cc: stable@vger.kernel.org
Signed-off-by: Trond Myklebust <trond.myklebust@primarydata.com>
fs/nfs/pnfs.c

index 230606243be6ad079733e583d173b14d3baeda55..219ee6a3f1b3d5d4b5058e9df58fd887c7013c42 100644 (file)
@@ -1865,6 +1865,7 @@ pnfs_write_through_mds(struct nfs_pageio_descriptor *desc,
                mirror->pg_recoalesce = 1;
        }
        nfs_pgio_data_destroy(hdr);
+       hdr->release(hdr);
 }
 
 static enum pnfs_try_status
@@ -1979,6 +1980,7 @@ pnfs_read_through_mds(struct nfs_pageio_descriptor *desc,
                mirror->pg_recoalesce = 1;
        }
        nfs_pgio_data_destroy(hdr);
+       hdr->release(hdr);
 }
 
 /*