diff options
Diffstat (limited to 'net/sunrpc/sched.c')
| -rw-r--r-- | net/sunrpc/sched.c | 14 | 
1 files changed, 10 insertions, 4 deletions
diff --git a/net/sunrpc/sched.c b/net/sunrpc/sched.c index 994cfea2bad..128494ec9a6 100644 --- a/net/sunrpc/sched.c +++ b/net/sunrpc/sched.c @@ -300,8 +300,9 @@ EXPORT_SYMBOL_GPL(__rpc_wait_for_completion_task);  /*   * Make an RPC task runnable.   * - * Note: If the task is ASYNC, this must be called with - * the spinlock held to protect the wait queue operation. + * Note: If the task is ASYNC, and is being made runnable after sitting on an + * rpc_wait_queue, this must be called with the queue spinlock held to protect + * the wait queue operation.   */  static void rpc_make_runnable(struct rpc_task *task)  { @@ -790,7 +791,9 @@ void rpc_execute(struct rpc_task *task)  static void rpc_async_schedule(struct work_struct *work)  { +	current->flags |= PF_FSTRANS;  	__rpc_execute(container_of(work, struct rpc_task, u.tk_work)); +	current->flags &= ~PF_FSTRANS;  }  /** @@ -812,7 +815,10 @@ static void rpc_async_schedule(struct work_struct *work)  void *rpc_malloc(struct rpc_task *task, size_t size)  {  	struct rpc_buffer *buf; -	gfp_t gfp = RPC_IS_SWAPPER(task) ? GFP_ATOMIC : GFP_NOWAIT; +	gfp_t gfp = GFP_NOWAIT; + +	if (RPC_IS_SWAPPER(task)) +		gfp |= __GFP_MEMALLOC;  	size += sizeof(struct rpc_buffer);  	if (size <= RPC_BUFFER_MAXSIZE) @@ -886,7 +892,7 @@ static void rpc_init_task(struct rpc_task *task, const struct rpc_task_setup *ta  static struct rpc_task *  rpc_alloc_task(void)  { -	return (struct rpc_task *)mempool_alloc(rpc_task_mempool, GFP_NOFS); +	return (struct rpc_task *)mempool_alloc(rpc_task_mempool, GFP_NOIO);  }  /*  |