{
        struct inode *inode = lgp->args.inode;
        struct nfs_server *server = NFS_SERVER(inode);
-       struct pnfs_layout_hdr *lo;
+       struct pnfs_layout_hdr *lo = lgp->lo;
        int nfs4err = task->tk_status;
        int err, status = 0;
        LIST_HEAD(head);
        case -NFS4ERR_BAD_STATEID:
                exception->timeout = 0;
                spin_lock(&inode->i_lock);
-               lo = NFS_I(inode)->layout;
                /* If the open stateid was bad, then recover it. */
                if (!lo || test_bit(NFS_LAYOUT_INVALID_STID, &lo->plh_flags) ||
                    !nfs4_stateid_match_other(&lgp->args.stateid, &lo->plh_stateid)) {
 
        dprintk("--> %s\n", __func__);
 
-       /* nfs4_layoutget_release calls pnfs_put_layout_hdr */
-       pnfs_get_layout_hdr(NFS_I(inode)->layout);
-
        nfs4_init_sequence(&lgp->args.seq_args, &lgp->res.seq_res, 0, 0);
 
        task = rpc_run_task(&task_setup_data);
 
        size_t max_pages = lgp->args.layout.pglen / PAGE_SIZE;
 
        nfs4_free_pages(lgp->args.layout.pages, max_pages);
-       if (lgp->args.inode)
-               pnfs_put_layout_hdr(NFS_I(lgp->args.inode)->layout);
+       pnfs_put_layout_hdr(lgp->lo);
        put_nfs_open_context(lgp->args.ctx);
        kfree(lgp);
 }
                goto out_put_layout_hdr;
        }
 
+       lgp->lo = lo;
+       pnfs_get_layout_hdr(lo);
+
        lseg = nfs4_proc_layoutget(lgp, &timeout);
        trace_pnfs_update_layout(ino, pos, count, iomode, lo, lseg,
                                 PNFS_UPDATE_LAYOUT_SEND_LAYOUTGET);
                pnfs_put_layout_hdr(lo);
                return;
        }
+       lgp->lo = lo;
        data->lgp = lgp;
        data->o_arg.lg_args = &lgp->args;
        data->o_res.lg_res = &lgp->res;
 static void _lgopen_prepare_floating(struct nfs4_opendata *data,
                                     struct nfs_open_context *ctx)
 {
+       struct inode *ino = data->dentry->d_inode;
        struct pnfs_layout_range rng = {
                .iomode = (data->o_arg.fmode & FMODE_WRITE) ?
                          IOMODE_RW: IOMODE_READ,
        };
        struct nfs4_layoutget *lgp;
 
-       lgp = pnfs_alloc_init_layoutget_args(NULL, ctx, ¤t_stateid,
+       lgp = pnfs_alloc_init_layoutget_args(ino, ctx, ¤t_stateid,
                                             &rng, GFP_KERNEL);
        if (!lgp)
                return;
        /* Could check on max_ops, but currently hardcoded high enough */
        if (!nfs_server_capable(data->dir->d_inode, NFS_CAP_LGOPEN))
                return;
+       if (data->lgp)
+               return;
        if (data->state)
                _lgopen_prepare_attached(data, ctx);
        else
                }
                return;
        }
-       if (!lgp->args.inode) {
+       if (!lgp->lo) {
                lo = _pnfs_grab_empty_layout(ino, ctx);
                if (!lo)
                        return;
-               lgp->args.inode = ino;
+               lgp->lo = lo;
        } else
-               lo = NFS_I(lgp->args.inode)->layout;
+               lo = lgp->lo;
 
        lseg = pnfs_layout_process(lgp);
        if (!IS_ERR(lseg)) {
 void nfs4_lgopen_release(struct nfs4_layoutget *lgp)
 {
        if (lgp != NULL) {
-               struct inode *inode = lgp->args.inode;
-               if (inode) {
-                       struct pnfs_layout_hdr *lo = NFS_I(inode)->layout;
-                       pnfs_clear_first_layoutget(lo);
-                       nfs_layoutget_end(lo);
+               if (lgp->lo) {
+                       pnfs_clear_first_layoutget(lgp->lo);
+                       nfs_layoutget_end(lgp->lo);
                }
                pnfs_layoutget_free(lgp);
        }
 struct pnfs_layout_segment *
 pnfs_layout_process(struct nfs4_layoutget *lgp)
 {
-       struct pnfs_layout_hdr *lo = NFS_I(lgp->args.inode)->layout;
+       struct pnfs_layout_hdr *lo = lgp->lo;
        struct nfs4_layoutget_res *res = &lgp->res;
        struct pnfs_layout_segment *lseg;
        struct inode *ino = lo->plh_inode;