mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 10:40:15 +02:00 
			
		
		
		
	nfsd41: use current stateid by value
Signed-off-by: Tigran Mkrtchyan <kofemann@gmail.com> Signed-off-by: J. Bruce Fields <bfields@redhat.com>
This commit is contained in:
		
							parent
							
								
									9428fe1abb
								
							
						
					
					
						commit
						37c593c573
					
				
					 4 changed files with 33 additions and 9 deletions
				
			
		| 
						 | 
					@ -4,6 +4,7 @@
 | 
				
			||||||
#include "state.h"
 | 
					#include "state.h"
 | 
				
			||||||
#include "xdr4.h"
 | 
					#include "xdr4.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					extern void clear_current_stateid(struct nfsd4_compound_state *cstate);
 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
 * functions to set current state id
 | 
					 * functions to set current state id
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -453,7 +453,10 @@ nfsd4_restorefh(struct svc_rqst *rqstp, struct nfsd4_compound_state *cstate,
 | 
				
			||||||
		return nfserr_restorefh;
 | 
							return nfserr_restorefh;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	fh_dup2(&cstate->current_fh, &cstate->save_fh);
 | 
						fh_dup2(&cstate->current_fh, &cstate->save_fh);
 | 
				
			||||||
	cstate->current_stateid = cstate->save_stateid;
 | 
						if (HAS_STATE_ID(cstate, SAVED_STATE_ID_FLAG)) {
 | 
				
			||||||
 | 
							memcpy(&cstate->current_stateid, &cstate->save_stateid, sizeof(stateid_t));
 | 
				
			||||||
 | 
							SET_STATE_ID(cstate, CURRENT_STATE_ID_FLAG);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
	return nfs_ok;
 | 
						return nfs_ok;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -465,7 +468,10 @@ nfsd4_savefh(struct svc_rqst *rqstp, struct nfsd4_compound_state *cstate,
 | 
				
			||||||
		return nfserr_nofilehandle;
 | 
							return nfserr_nofilehandle;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	fh_dup2(&cstate->save_fh, &cstate->current_fh);
 | 
						fh_dup2(&cstate->save_fh, &cstate->current_fh);
 | 
				
			||||||
	cstate->save_stateid = cstate->current_stateid;
 | 
						if (HAS_STATE_ID(cstate, CURRENT_STATE_ID_FLAG)) {
 | 
				
			||||||
 | 
							memcpy(&cstate->save_stateid, &cstate->current_stateid, sizeof(stateid_t));
 | 
				
			||||||
 | 
							SET_STATE_ID(cstate, SAVED_STATE_ID_FLAG);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
	return nfs_ok;
 | 
						return nfs_ok;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1238,7 +1244,7 @@ nfsd4_proc_compound(struct svc_rqst *rqstp,
 | 
				
			||||||
				opdesc->op_set_currentstateid(cstate, &op->u);
 | 
									opdesc->op_set_currentstateid(cstate, &op->u);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			if (opdesc->op_flags & OP_CLEAR_STATEID)
 | 
								if (opdesc->op_flags & OP_CLEAR_STATEID)
 | 
				
			||||||
				cstate->current_stateid = NULL;
 | 
									clear_current_stateid(cstate);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			if (need_wrongsec_check(rqstp))
 | 
								if (need_wrongsec_check(rqstp))
 | 
				
			||||||
				op->status = check_nfsd_access(cstate->current_fh.fh_export, rqstp);
 | 
									op->status = check_nfsd_access(cstate->current_fh.fh_export, rqstp);
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -4699,15 +4699,23 @@ nfs4_state_shutdown(void)
 | 
				
			||||||
static void
 | 
					static void
 | 
				
			||||||
get_stateid(struct nfsd4_compound_state *cstate, stateid_t *stateid)
 | 
					get_stateid(struct nfsd4_compound_state *cstate, stateid_t *stateid)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	if (cstate->current_stateid && CURRENT_STATEID(stateid))
 | 
						if (HAS_STATE_ID(cstate, CURRENT_STATE_ID_FLAG) && CURRENT_STATEID(stateid))
 | 
				
			||||||
		memcpy(stateid, cstate->current_stateid, sizeof(stateid_t));
 | 
							memcpy(stateid, &cstate->current_stateid, sizeof(stateid_t));
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static void
 | 
					static void
 | 
				
			||||||
put_stateid(struct nfsd4_compound_state *cstate, stateid_t *stateid)
 | 
					put_stateid(struct nfsd4_compound_state *cstate, stateid_t *stateid)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	if (cstate->minorversion)
 | 
						if (cstate->minorversion) {
 | 
				
			||||||
		cstate->current_stateid = stateid;
 | 
							memcpy(&cstate->current_stateid, stateid, sizeof(stateid_t));
 | 
				
			||||||
 | 
							SET_STATE_ID(cstate, CURRENT_STATE_ID_FLAG);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void
 | 
				
			||||||
 | 
					clear_current_stateid(struct nfsd4_compound_state *cstate)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						CLEAR_STATE_ID(cstate, CURRENT_STATE_ID_FLAG);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -43,6 +43,13 @@
 | 
				
			||||||
#define NFSD4_MAX_TAGLEN	128
 | 
					#define NFSD4_MAX_TAGLEN	128
 | 
				
			||||||
#define XDR_LEN(n)                     (((n) + 3) & ~3)
 | 
					#define XDR_LEN(n)                     (((n) + 3) & ~3)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define CURRENT_STATE_ID_FLAG (1<<0)
 | 
				
			||||||
 | 
					#define SAVED_STATE_ID_FLAG (1<<1)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define SET_STATE_ID(c, f) ((c)->sid_flags |= (f))
 | 
				
			||||||
 | 
					#define HAS_STATE_ID(c, f) ((c)->sid_flags & (f))
 | 
				
			||||||
 | 
					#define CLEAR_STATE_ID(c, f) ((c)->sid_flags &= ~(f))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
struct nfsd4_compound_state {
 | 
					struct nfsd4_compound_state {
 | 
				
			||||||
	struct svc_fh		current_fh;
 | 
						struct svc_fh		current_fh;
 | 
				
			||||||
	struct svc_fh		save_fh;
 | 
						struct svc_fh		save_fh;
 | 
				
			||||||
| 
						 | 
					@ -54,8 +61,10 @@ struct nfsd4_compound_state {
 | 
				
			||||||
	size_t			iovlen;
 | 
						size_t			iovlen;
 | 
				
			||||||
	u32			minorversion;
 | 
						u32			minorversion;
 | 
				
			||||||
	u32			status;
 | 
						u32			status;
 | 
				
			||||||
	const stateid_t	*current_stateid;
 | 
						stateid_t	current_stateid;
 | 
				
			||||||
	const stateid_t	*save_stateid;
 | 
						stateid_t	save_stateid;
 | 
				
			||||||
 | 
						/* to indicate current and saved state id presents */
 | 
				
			||||||
 | 
						u32		sid_flags;
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static inline bool nfsd4_has_session(struct nfsd4_compound_state *cs)
 | 
					static inline bool nfsd4_has_session(struct nfsd4_compound_state *cs)
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in a new issue