diff options
Diffstat (limited to 'kernel/padata.c')
| -rw-r--r-- | kernel/padata.c | 15 | 
1 files changed, 10 insertions, 5 deletions
| diff --git a/kernel/padata.c b/kernel/padata.c index e5819bb8bd1d..de90af5fcbe6 100644 --- a/kernel/padata.c +++ b/kernel/padata.c @@ -207,14 +207,16 @@ int padata_do_parallel(struct padata_shell *ps,  	pw = padata_work_alloc();  	spin_unlock(&padata_works_lock); +	if (!pw) { +		/* Maximum works limit exceeded, run in the current task. */ +		padata->parallel(padata); +	} +  	rcu_read_unlock_bh();  	if (pw) {  		padata_work_init(pw, padata_parallel_worker, padata, 0);  		queue_work(pinst->parallel_wq, &pw->pw_work); -	} else { -		/* Maximum works limit exceeded, run in the current task. */ -		padata->parallel(padata);  	}  	return 0; @@ -388,13 +390,16 @@ void padata_do_serial(struct padata_priv *padata)  	int hashed_cpu = padata_cpu_hash(pd, padata->seq_nr);  	struct padata_list *reorder = per_cpu_ptr(pd->reorder_list, hashed_cpu);  	struct padata_priv *cur; +	struct list_head *pos;  	spin_lock(&reorder->lock);  	/* Sort in ascending order of sequence number. */ -	list_for_each_entry_reverse(cur, &reorder->list, list) +	list_for_each_prev(pos, &reorder->list) { +		cur = list_entry(pos, struct padata_priv, list);  		if (cur->seq_nr < padata->seq_nr)  			break; -	list_add(&padata->list, &cur->list); +	} +	list_add(&padata->list, pos);  	spin_unlock(&reorder->lock);  	/* |