Re: [PATCH 1/2] pnfs_submit: fix layoutreturn layout stateid processing

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, Oct 12, 2010 at 6:13 AM,  <andros@xxxxxxxxxx> wrote:
> From: Andy Adamson <andros@xxxxxxxxxx>
>
> Add missing layoutreturn stateid update.
> This patch also enforces the following rfc 5661 requirement:
>
> section 12.5.4

Should this be 12.5.3?

>   "For LAYOUTRETURN results, the client MUST delete the range from its
>   record of what ranges of the file's layout it had before using the
>   seqid."
>
> Reported-by: P.B.Shelley <shelleypt@xxxxxxxxx>
> Signed-off-by: Andy Adamson <andros@xxxxxxxxxx>
> ---
>  fs/nfs/nfs4proc.c |   10 +++++-----
>  fs/nfs/pnfs.c     |    7 +++----
>  fs/nfs/pnfs.h     |    3 ++-
>  3 files changed, 10 insertions(+), 10 deletions(-)
>
> diff --git a/fs/nfs/nfs4proc.c b/fs/nfs/nfs4proc.c
> index 7727f59..4c56d9b 100644
> --- a/fs/nfs/nfs4proc.c
> +++ b/fs/nfs/nfs4proc.c
> @@ -5678,11 +5678,11 @@ static void nfs4_layoutreturn_release(void *calldata)
>        dprintk("--> %s return_type %d lo %p\n", __func__,
>                lrp->args.return_type, lo);
>
> -       if (lrp->args.return_type == RETURN_FILE) {
> -               if (!lrp->res.lrs_present)
> -                       pnfs_invalidate_layout_stateid(lo);
> -               pnfs_layoutreturn_release(lo, &lrp->args.range);
> -       }
> +       pnfs_layoutreturn_release(lo, &lrp->args.range);

args.range (and lo itself) only make sense in RETURN_FILE case.

> +       if (!lrp->res.lrs_present)
> +               pnfs_invalidate_layout_stateid(lo);
> +       else
> +               pnfs_set_layout_stateid(lo, &lrp->res.stateid);
>        kfree(calldata);
>        dprintk("<-- %s\n", __func__);
>  }
> diff --git a/fs/nfs/pnfs.c b/fs/nfs/pnfs.c
> index eb4dfdf..124d3ca 100644
> --- a/fs/nfs/pnfs.c
> +++ b/fs/nfs/pnfs.c
> @@ -400,8 +400,7 @@ pnfs_layoutreturn_release(struct pnfs_layout_hdr *lo,
>        LIST_HEAD(tmp_list);
>
>        spin_lock(&nfsi->vfs_inode.i_lock);
> -       if (range)
> -               pnfs_clear_lseg_list(lo, &tmp_list, range);
> +       pnfs_clear_lseg_list(lo, &tmp_list, range);
>        put_layout_hdr_locked(lo); /* Matched in _pnfs_return_layout */
>        spin_unlock(&nfsi->vfs_inode.i_lock);
>        pnfs_free_lseg_list(&tmp_list);
> @@ -460,7 +459,7 @@ pnfs_destroy_all_layouts(struct nfs_client *clp)
>  *
>  * lo->stateid could be the open stateid, in which case we just use what given.
>  */
> -static void
> +void
>  pnfs_set_layout_stateid(struct pnfs_layout_hdr *lo,
>                        const nfs4_stateid *new)
>  {
> @@ -625,7 +624,7 @@ return_layout(struct inode *ino, struct pnfs_layout_range *range,
>        lrp = kzalloc(sizeof(*lrp), GFP_KERNEL);
>        if (lrp == NULL) {
>                if (lo && (type == RETURN_FILE))
> -                       pnfs_layoutreturn_release(lo, NULL);
> +                       put_layout_hdr(lo->inode);
>                goto out;
>        }
>        lrp->args.reclaim = 0;
> diff --git a/fs/nfs/pnfs.h b/fs/nfs/pnfs.h
> index 235709e..3fd2bc3 100644
> --- a/fs/nfs/pnfs.h
> +++ b/fs/nfs/pnfs.h
> @@ -210,7 +210,8 @@ void pnfs_destroy_all_layouts(struct nfs_client *);
>  void put_layout_hdr(struct inode *inode);
>  void pnfs_get_layout_stateid(nfs4_stateid *dst, struct pnfs_layout_hdr *lo,
>                             struct nfs4_state *open_state);
> -
> +void pnfs_set_layout_stateid(struct pnfs_layout_hdr *lo,
> +                                   const nfs4_stateid *new);
>
>  static inline bool
>  has_layout(struct nfs_inode *nfsi)
> --
> 1.6.6
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-nfs" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
>
--
To unsubscribe from this list: send the line "unsubscribe linux-nfs" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux Filesystem Development]     [Linux USB Development]     [Linux Media Development]     [Video for Linux]     [Linux NILFS]     [Linux Audio Users]     [Yosemite Info]     [Linux SCSI]

  Powered by Linux