diff options
Diffstat (limited to 'fs/nfs/write.c')
| -rw-r--r-- | fs/nfs/write.c | 31 | 
1 files changed, 4 insertions, 27 deletions
| diff --git a/fs/nfs/write.c b/fs/nfs/write.c index 51a7e202d6e5..f41d24b54fd1 100644 --- a/fs/nfs/write.c +++ b/fs/nfs/write.c @@ -1420,10 +1420,12 @@ static void nfs_initiate_write(struct nfs_pgio_header *hdr,   */  static void nfs_redirty_request(struct nfs_page *req)  { +	struct nfs_inode *nfsi = NFS_I(page_file_mapping(req->wb_page)->host); +  	/* Bump the transmission count */  	req->wb_nio++;  	nfs_mark_request_dirty(req); -	set_bit(NFS_CONTEXT_RESEND_WRITES, &nfs_req_openctx(req)->flags); +	atomic_long_inc(&nfsi->redirtied_pages);  	nfs_end_page_writeback(req);  	nfs_release_request(req);  } @@ -1494,31 +1496,6 @@ void nfs_commit_prepare(struct rpc_task *task, void *calldata)  	NFS_PROTO(data->inode)->commit_rpc_prepare(task, data);  } -/* - * Special version of should_remove_suid() that ignores capabilities. - */ -static int nfs_should_remove_suid(const struct inode *inode) -{ -	umode_t mode = inode->i_mode; -	int kill = 0; - -	/* suid always must be killed */ -	if (unlikely(mode & S_ISUID)) -		kill = ATTR_KILL_SUID; - -	/* -	 * sgid without any exec bits is just a mandatory locking mark; leave -	 * it alone.  If some exec bits are set, it's a real sgid; kill it. -	 */ -	if (unlikely((mode & S_ISGID) && (mode & S_IXGRP))) -		kill |= ATTR_KILL_SGID; - -	if (unlikely(kill && S_ISREG(mode))) -		return kill; - -	return 0; -} -  static void nfs_writeback_check_extend(struct nfs_pgio_header *hdr,  		struct nfs_fattr *fattr)  { @@ -1904,7 +1881,7 @@ static void nfs_commit_release_pages(struct nfs_commit_data *data)  		/* We have a mismatch. Write the page again */  		dprintk_cont(" mismatch\n");  		nfs_mark_request_dirty(req); -		set_bit(NFS_CONTEXT_RESEND_WRITES, &nfs_req_openctx(req)->flags); +		atomic_long_inc(&NFS_I(data->inode)->redirtied_pages);  	next:  		nfs_unlock_and_release_request(req);  		/* Latency breaker */ | 
