Re: [PATCH Version 1 1/1] NFS free the layoutget slot before calling pnfs_layout_process

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

 



On Wed, 2017-03-15 at 11:18 -0400, andros@xxxxxxxxxx wrote:
> From: Andy Adamson <andros@xxxxxxxxxx>
> 
> Otherwise no slots could be available for the potential
> pnfs_layout_process getdeviceinfo call and the client hangs on pNFS
> I/O.
> 
> This occurs in testing against the pynfs pNFS server where the
> the on-wire reply highest_slotid and slot id are zero, and the
> target high slot id is 8 (negotiated in CREATE_SESSION).
> 
> The internal fore channel slot table max_slotid, the maximum allowed
> table slotid value, has been reduced via nfs41_set_max_slotid_locked
>  from 8 to 1.  Thus there is one slot (slotid 0) available for use
> but
> it has not been freed by layoutget proir to the getdeviceinfo
> request.
> 
> So the layout get call is waiting for the getdeviceinfo call to
> complete,
> and the getdeviceinfo call is waiting for layoutget to free the slot.
> 
> Signed-off-by: Andy Adamson <andros@xxxxxxxxxx>
> ---
>  fs/nfs/nfs4proc.c | 2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
> 
> diff --git a/fs/nfs/nfs4proc.c b/fs/nfs/nfs4proc.c
> index 1b18368..8ca92d0 100644
> --- a/fs/nfs/nfs4proc.c
> +++ b/fs/nfs/nfs4proc.c
> @@ -8504,10 +8504,10 @@ nfs4_proc_layoutget(struct nfs4_layoutget
> *lgp, long *timeout, gfp_t gfp_flags)
>  			&lgp->res.stateid,
>  			status);
>  
> +	nfs4_sequence_free_slot(&lgp->res.seq_res);
>  	/* if layoutp->len is 0, nfs4_layoutget_prepare called
> rpc_exit */
>  	if (status == 0 && lgp->res.layoutp->len)
>  		lseg = pnfs_layout_process(lgp);
> -	nfs4_sequence_free_slot(&lgp->res.seq_res);
>  	rpc_put_task(task);
>  	dprintk("<-- %s status=%d\n", __func__, status);
>  	if (status)

The placement of the call to nfs4_sequence_free_slot() after the call
to pnfs_layout_process() is deliberate, and is needed in order to
ensure that layoutrecall callbacks are processed correctly in order
after the layoutget has been processed (see referring_call_exists()).

The call to nfs4_find_get_deviceid() needs to be moved out of
pnfs_update_layout().
In the flexfiles driver, it was moved to nfs4_ff_layout_prepare_ds(),
but it looks to me as if the files driver needs to call it earlier due
to the need to calculate stripes. Perhaps the right thing is to add a
wrapper around pnfs_update_layout() in fs/nfs/filelayout/filelayout.c
that can be called by both filelayout_pg_init_read() and
filelayout_pg_init_write()?

-- 
Trond Myklebust
Linux NFS client maintainer, PrimaryData
trond.myklebust@xxxxxxxxxxxxxxx
��.n��������+%������w��{.n�����{��w���jg��������ݢj����G�������j:+v���w�m������w�������h�����٥




[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