diff options
| author | Kaleb S. KEITHLEY <kkeithle@redhat.com> | 2013-12-02 10:47:26 -0500 | 
|---|---|---|
| committer | Vijay Bellur <vbellur@redhat.com> | 2013-12-04 03:34:13 -0800 | 
| commit | 1e40a57d1689b4943f67db5e249008d7f0969208 (patch) | |
| tree | 59ebd4120b5b7ee27822d7f616ab90d825e5547b /libglusterfs/src/syncop.h | |
| parent | 0f02c5125b96da8083a623ed9f455e68ded46b9c (diff) | |
gfapi: backport handles to 3.4 for nfs-ganeshav3.4.2qa2
nfs-ganesha-2.0 will ship shortly. It depends on the gfapi handle support,
which won't otherwise be released until 3.5 sometime in 2014.
Change-Id: I104d6fb275bb2c710790340fdc7d998446403026
Signed-off-by: Kaleb S. KEITHLEY <kkeithle@redhat.com>
Reviewed-on: http://review.gluster.org/6394
Tested-by: Gluster Build System <jenkins@build.gluster.com>
Reviewed-by: Shyamsundar Ranganathan <srangana@redhat.com>
Reviewed-by: Vijay Bellur <vbellur@redhat.com>
Diffstat (limited to 'libglusterfs/src/syncop.h')
| -rw-r--r-- | libglusterfs/src/syncop.h | 78 | 
1 files changed, 61 insertions, 17 deletions
| diff --git a/libglusterfs/src/syncop.h b/libglusterfs/src/syncop.h index d0417b260..4e14dc353 100644 --- a/libglusterfs/src/syncop.h +++ b/libglusterfs/src/syncop.h @@ -25,6 +25,13 @@  #define SYNCENV_PROC_MIN 2  #define SYNCPROC_IDLE_TIME 600 +/* + * Flags for syncopctx valid elements + */ +#define SYNCOPCTX_UID    0x00000001 +#define SYNCOPCTX_GID    0x00000002 +#define SYNCOPCTX_GROUPS 0x00000004 +  struct synctask;  struct syncproc;  struct syncenv; @@ -146,6 +153,14 @@ struct syncargs {  	int                 done;  }; +struct syncopctx { +        unsigned int valid;  /* valid flags for elements that are set */ +        uid_t        uid; +        gid_t        gid; +        int          grpsize; +        int          ngrps; +        gid_t       *groups; +};  #define __yawn(args) do {                                       \          args->task = synctask_get ();                           \ @@ -234,34 +249,63 @@ void synctask_waitfor (struct synctask *task, int count);  int synctask_setid (struct synctask *task, uid_t uid, gid_t gid);  #define SYNCTASK_SETID(uid, gid) synctask_setid (synctask_get(), uid, gid); +int syncopctx_setfsuid (void *uid); +int syncopctx_setfsgid (void *gid); +int syncopctx_setfsgroups (int count, const void *groups);  static inline call_frame_t *  syncop_create_frame (xlator_t *this)  { -	call_frame_t  *frame = NULL; -	int            ngrps = -1; +	call_frame_t     *frame = NULL; +	int               ngrps = -1; +	struct syncopctx *opctx = NULL;  	frame = create_frame (this, this->ctx->pool);  	if (!frame)  		return NULL; -	frame->root->pid = getpid(); -	frame->root->uid = geteuid (); -	frame->root->gid = getegid (); -        ngrps = getgroups (0, 0); -	if (ngrps < 0) { -		STACK_DESTROY (frame->root); -		return NULL; -	} +	frame->root->pid = getpid (); -	if (call_stack_alloc_groups (frame->root, ngrps) != 0) { -		STACK_DESTROY (frame->root); -		return NULL; -	} +	opctx = syncopctx_getctx (); +	if (opctx && (opctx->valid & SYNCOPCTX_UID)) +		frame->root->uid = opctx->uid; +	else +		frame->root->uid = geteuid (); -	if (getgroups (ngrps, frame->root->groups) < 0) { -		STACK_DESTROY (frame->root); -		return NULL; +	if (opctx && (opctx->valid & SYNCOPCTX_GID)) +		frame->root->gid = opctx->gid; +	else +		frame->root->gid = getegid (); + +	if (opctx && (opctx->valid & SYNCOPCTX_GROUPS)) { +		ngrps = opctx->ngrps; + +		if (ngrps != 0 && opctx->groups != NULL) { +			if (call_stack_alloc_groups (frame->root, ngrps) != 0) { +				STACK_DESTROY (frame->root); +				return NULL; +			} + +			memcpy (frame->root->groups, opctx->groups, +				(sizeof (gid_t) * ngrps)); +		} +	} +	else { +		ngrps = getgroups (0, 0); +		if (ngrps < 0) { +			STACK_DESTROY (frame->root); +			return NULL; +		} + +		if (call_stack_alloc_groups (frame->root, ngrps) != 0) { +			STACK_DESTROY (frame->root); +			return NULL; +		} + +		if (getgroups (ngrps, frame->root->groups) < 0) { +			STACK_DESTROY (frame->root); +			return NULL; +		}  	}  	return frame; | 
