Commit ee26bdd6 authored by Jeff Layton's avatar Jeff Layton Committed by Anna Schumaker

pnfs: don't merge new ff lsegs with ones that have LAYOUTRETURN bit set

Otherwise, we'll end up returning layouts that we've just received if
the client issues a new LAYOUTGET prior to the LAYOUTRETURN.
Signed-off-by: default avatarJeff Layton <jeff.layton@primarydata.com>
Signed-off-by: default avatarAnna Schumaker <Anna.Schumaker@Netapp.com>
parent 446ca219
...@@ -299,6 +299,8 @@ ff_lseg_merge(struct pnfs_layout_segment *new, ...@@ -299,6 +299,8 @@ ff_lseg_merge(struct pnfs_layout_segment *new,
{ {
u64 new_end, old_end; u64 new_end, old_end;
if (test_bit(NFS_LSEG_LAYOUTRETURN, &old->pls_flags))
return false;
if (new->pls_range.iomode != old->pls_range.iomode) if (new->pls_range.iomode != old->pls_range.iomode)
return false; return false;
old_end = pnfs_calc_offset_end(old->pls_range.offset, old_end = pnfs_calc_offset_end(old->pls_range.offset,
...@@ -319,8 +321,6 @@ ff_lseg_merge(struct pnfs_layout_segment *new, ...@@ -319,8 +321,6 @@ ff_lseg_merge(struct pnfs_layout_segment *new,
new_end); new_end);
if (test_bit(NFS_LSEG_ROC, &old->pls_flags)) if (test_bit(NFS_LSEG_ROC, &old->pls_flags))
set_bit(NFS_LSEG_ROC, &new->pls_flags); set_bit(NFS_LSEG_ROC, &new->pls_flags);
if (test_bit(NFS_LSEG_LAYOUTRETURN, &old->pls_flags))
set_bit(NFS_LSEG_LAYOUTRETURN, &new->pls_flags);
return true; return true;
} }
......
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