diff options
| author | Greg Kroah-Hartman <[email protected]> | 2022-01-30 15:00:39 +0100 | 
|---|---|---|
| committer | Greg Kroah-Hartman <[email protected]> | 2022-01-30 15:00:39 +0100 | 
| commit | 7ab004dbcbee38b8a70798835d3ffcd97a985a5e (patch) | |
| tree | 0caa6cb97801736046823ca785a5ba36bf684ac6 /fs/nfs/nfs42proc.c | |
| parent | 710f8af199ee9d72dd87083edd55c5ee250ee6f4 (diff) | |
| parent | 26291c54e111ff6ba87a164d85d4a4e134b7315c (diff) | |
Merge tag 'v5.17-rc2' into char-misc-next
We need the char/misc fixes in here as well.
Signed-off-by: Greg Kroah-Hartman <[email protected]>
Diffstat (limited to 'fs/nfs/nfs42proc.c')
| -rw-r--r-- | fs/nfs/nfs42proc.c | 13 | 
1 files changed, 8 insertions, 5 deletions
| diff --git a/fs/nfs/nfs42proc.c b/fs/nfs/nfs42proc.c index 8b21ff1be717..32129446beca 100644 --- a/fs/nfs/nfs42proc.c +++ b/fs/nfs/nfs42proc.c @@ -46,7 +46,7 @@ static int _nfs42_proc_fallocate(struct rpc_message *msg, struct file *filep,  {  	struct inode *inode = file_inode(filep);  	struct nfs_server *server = NFS_SERVER(inode); -	u32 bitmask[3]; +	u32 bitmask[NFS_BITMASK_SZ];  	struct nfs42_falloc_args args = {  		.falloc_fh	= NFS_FH(inode),  		.falloc_offset	= offset, @@ -69,9 +69,8 @@ static int _nfs42_proc_fallocate(struct rpc_message *msg, struct file *filep,  		return status;  	} -	memcpy(bitmask, server->cache_consistency_bitmask, sizeof(bitmask)); -	if (server->attr_bitmask[1] & FATTR4_WORD1_SPACE_USED) -		bitmask[1] |= FATTR4_WORD1_SPACE_USED; +	nfs4_bitmask_set(bitmask, server->cache_consistency_bitmask, inode, +			 NFS_INO_INVALID_BLOCKS);  	res.falloc_fattr = nfs_alloc_fattr();  	if (!res.falloc_fattr) @@ -1044,13 +1043,14 @@ static int _nfs42_proc_clone(struct rpc_message *msg, struct file *src_f,  	struct inode *src_inode = file_inode(src_f);  	struct inode *dst_inode = file_inode(dst_f);  	struct nfs_server *server = NFS_SERVER(dst_inode); +	__u32 dst_bitmask[NFS_BITMASK_SZ];  	struct nfs42_clone_args args = {  		.src_fh = NFS_FH(src_inode),  		.dst_fh = NFS_FH(dst_inode),  		.src_offset = src_offset,  		.dst_offset = dst_offset,  		.count = count, -		.dst_bitmask = server->cache_consistency_bitmask, +		.dst_bitmask = dst_bitmask,  	};  	struct nfs42_clone_res res = {  		.server	= server, @@ -1079,6 +1079,9 @@ static int _nfs42_proc_clone(struct rpc_message *msg, struct file *src_f,  	if (!res.dst_fattr)  		return -ENOMEM; +	nfs4_bitmask_set(dst_bitmask, server->cache_consistency_bitmask, +			 dst_inode, NFS_INO_INVALID_BLOCKS); +  	status = nfs4_call_sync(server->client, server, msg,  				&args.seq_args, &res.seq_res, 0);  	trace_nfs4_clone(src_inode, dst_inode, &args, status); |