diff options
| author | Linus Torvalds <[email protected]> | 2008-01-30 19:54:24 +1100 | 
|---|---|---|
| committer | Linus Torvalds <[email protected]> | 2008-01-30 19:54:24 +1100 | 
| commit | 85004cc367abc000aa36c0d0e270ab609a68b0cb (patch) | |
| tree | 5739aae778d67b6d119fe5c668313fc2823e9836 /include/linux/sunrpc/sched.h | |
| parent | 149a051f82d2b3860fe32fa182dbc83a66274894 (diff) | |
| parent | 3fbd67ad61f6d5a09ea717b56c50bc5c3d8042a8 (diff) | |
Merge git://git.linux-nfs.org/pub/linux/nfs-2.6
* git://git.linux-nfs.org/pub/linux/nfs-2.6: (118 commits)
  NFSv4: Iterate through all nfs_clients when the server recalls a delegation
  NFSv4: Deal more correctly with duplicate delegations
  NFS: Fix a potential race between umount and nfs_access_cache_shrinker()
  NFS: Add an asynchronous delegreturn operation for use in nfs_clear_inode
  nfs: convert NFS_*(inode) helpers to static inline
  nfs: obliterate NFS_FLAGS macro
  NFS: Address memory leaks in the NFS client mount option parser
  nfs4: allow nfsv4 acls on non-regular-files
  NFS: Optimise away the sigmask code in aio/dio reads and writes
  SUNRPC: Don't bother changing the sigmask for asynchronous RPC calls
  SUNRPC: rpcb_getport_sync() passes incorrect address size to rpc_create()
  SUNRPC: Clean up block comment preceding rpcb_getport_sync()
  SUNRPC: Use appropriate argument types in rpcb client
  SUNRPC: rpcb_getport_sync() should use built-in hostname generator
  SUNRPC: Clean up functions that free address_strings array
  NFS: NFS version number is unsigned
  NLM: Fix a bogus 'return' in nlmclnt_rpc_release
  NLM: Introduce an arguments structure for nlmclnt_init()
  NLM/NFS: Use cached nlm_host when calling nlmclnt_proc()
  NFS: Invoke nlmclnt_init during NFS mount processing
  ...
Diffstat (limited to 'include/linux/sunrpc/sched.h')
| -rw-r--r-- | include/linux/sunrpc/sched.h | 57 | 
1 files changed, 19 insertions, 38 deletions
| diff --git a/include/linux/sunrpc/sched.h b/include/linux/sunrpc/sched.h index 8ea077db0099..ce3d1b132729 100644 --- a/include/linux/sunrpc/sched.h +++ b/include/linux/sunrpc/sched.h @@ -56,8 +56,6 @@ struct rpc_task {  	__u8			tk_garb_retry;  	__u8			tk_cred_retry; -	unsigned long		tk_cookie;	/* Cookie for batching tasks */ -  	/*  	 * timeout_fn   to be executed by timer bottom half  	 * callback	to be executed after waking up @@ -78,7 +76,6 @@ struct rpc_task {  	struct timer_list	tk_timer;	/* kernel timer */  	unsigned long		tk_timeout;	/* timeout for rpc_sleep() */  	unsigned short		tk_flags;	/* misc flags */ -	unsigned char		tk_priority : 2;/* Task priority */  	unsigned long		tk_runstate;	/* Task run status */  	struct workqueue_struct	*tk_workqueue;	/* Normally rpciod, but could  						 * be any workqueue @@ -94,6 +91,9 @@ struct rpc_task {  	unsigned long		tk_start;	/* RPC task init timestamp */  	long			tk_rtt;		/* round-trip time (jiffies) */ +	pid_t			tk_owner;	/* Process id for batching tasks */ +	unsigned char		tk_priority : 2;/* Task priority */ +  #ifdef RPC_DEBUG  	unsigned short		tk_pid;		/* debugging aid */  #endif @@ -117,6 +117,15 @@ struct rpc_call_ops {  	void (*rpc_release)(void *);  }; +struct rpc_task_setup { +	struct rpc_task *task; +	struct rpc_clnt *rpc_client; +	const struct rpc_message *rpc_message; +	const struct rpc_call_ops *callback_ops; +	void *callback_data; +	unsigned short flags; +	signed char priority; +};  /*   * RPC task flags @@ -180,10 +189,10 @@ struct rpc_call_ops {   * Note: if you change these, you must also change   * the task initialization definitions below.   */ -#define RPC_PRIORITY_LOW	0 -#define RPC_PRIORITY_NORMAL	1 -#define RPC_PRIORITY_HIGH	2 -#define RPC_NR_PRIORITY		(RPC_PRIORITY_HIGH+1) +#define RPC_PRIORITY_LOW	(-1) +#define RPC_PRIORITY_NORMAL	(0) +#define RPC_PRIORITY_HIGH	(1) +#define RPC_NR_PRIORITY		(1 + RPC_PRIORITY_HIGH - RPC_PRIORITY_LOW)  /*   * RPC synchronization objects @@ -191,7 +200,7 @@ struct rpc_call_ops {  struct rpc_wait_queue {  	spinlock_t		lock;  	struct list_head	tasks[RPC_NR_PRIORITY];	/* task queue for each priority level */ -	unsigned long		cookie;			/* cookie of last task serviced */ +	pid_t			owner;			/* process id of last task serviced */  	unsigned char		maxpriority;		/* maximum priority (0 if queue is not a priority queue) */  	unsigned char		priority;		/* current priority */  	unsigned char		count;			/* # task groups remaining serviced so far */ @@ -208,41 +217,13 @@ struct rpc_wait_queue {   * performance of NFS operations such as read/write.   */  #define RPC_BATCH_COUNT			16 - -#ifndef RPC_DEBUG -# define RPC_WAITQ_INIT(var,qname) { \ -		.lock = __SPIN_LOCK_UNLOCKED(var.lock), \ -		.tasks = { \ -			[0] = LIST_HEAD_INIT(var.tasks[0]), \ -			[1] = LIST_HEAD_INIT(var.tasks[1]), \ -			[2] = LIST_HEAD_INIT(var.tasks[2]), \ -		}, \ -	} -#else -# define RPC_WAITQ_INIT(var,qname) { \ -		.lock = __SPIN_LOCK_UNLOCKED(var.lock), \ -		.tasks = { \ -			[0] = LIST_HEAD_INIT(var.tasks[0]), \ -			[1] = LIST_HEAD_INIT(var.tasks[1]), \ -			[2] = LIST_HEAD_INIT(var.tasks[2]), \ -		}, \ -		.name = qname, \ -	} -#endif -# define RPC_WAITQ(var,qname)      struct rpc_wait_queue var = RPC_WAITQ_INIT(var,qname) -  #define RPC_IS_PRIORITY(q)		((q)->maxpriority > 0)  /*   * Function prototypes   */ -struct rpc_task *rpc_new_task(struct rpc_clnt *, int flags, -				const struct rpc_call_ops *ops, void *data); -struct rpc_task *rpc_run_task(struct rpc_clnt *clnt, int flags, -				const struct rpc_call_ops *ops, void *data); -void		rpc_init_task(struct rpc_task *task, struct rpc_clnt *clnt, -				int flags, const struct rpc_call_ops *ops, -				void *data); +struct rpc_task *rpc_new_task(const struct rpc_task_setup *); +struct rpc_task *rpc_run_task(const struct rpc_task_setup *);  void		rpc_put_task(struct rpc_task *);  void		rpc_exit_task(struct rpc_task *);  void		rpc_release_calldata(const struct rpc_call_ops *, void *); |