Commit 7175fe90 authored by Yanchuan Nian's avatar Yanchuan Nian Committed by Trond Myklebust

nfs: Check whether a layout pointer is NULL before free it

The new layout pointer in pnfs_find_alloc_layout() may be NULL because of
out of memory. we must do some check work, otherwise pnfs_free_layout_hdr()
will go wrong because it can not deal with a NULL pointer.
Signed-off-by: default avatarYanchuan Nian <ycnian@gmail.com>
Signed-off-by: default avatarTrond Myklebust <Trond.Myklebust@netapp.com>
parent 8d96b106
...@@ -925,8 +925,8 @@ pnfs_find_alloc_layout(struct inode *ino, ...@@ -925,8 +925,8 @@ pnfs_find_alloc_layout(struct inode *ino,
if (likely(nfsi->layout == NULL)) { /* Won the race? */ if (likely(nfsi->layout == NULL)) { /* Won the race? */
nfsi->layout = new; nfsi->layout = new;
return new; return new;
} } else if (new != NULL)
pnfs_free_layout_hdr(new); pnfs_free_layout_hdr(new);
out_existing: out_existing:
pnfs_get_layout_hdr(nfsi->layout); pnfs_get_layout_hdr(nfsi->layout);
return nfsi->layout; return nfsi->layout;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment