Commit 92266d6e authored by Lai Jiangshan's avatar Lai Jiangshan Committed by Tejun Heo

async: simplify lowest_in_progress()

The code in lowest_in_progress() are duplicated in two branches,
simplify them.

tj: Minor indentation adjustment.
Signed-off-by: default avatarLai Jiangshan <laijs@cn.fujitsu.com>
Signed-off-by: default avatarTejun Heo <tj@kernel.org>
Cc: Arjan van de Ven <arjan@linux.intel.com>
parent 6dbe51c2
...@@ -84,24 +84,20 @@ static atomic_t entry_count; ...@@ -84,24 +84,20 @@ static atomic_t entry_count;
static async_cookie_t lowest_in_progress(struct async_domain *domain) static async_cookie_t lowest_in_progress(struct async_domain *domain)
{ {
struct async_entry *first = NULL; struct list_head *pending;
async_cookie_t ret = ASYNC_COOKIE_MAX; async_cookie_t ret = ASYNC_COOKIE_MAX;
unsigned long flags; unsigned long flags;
spin_lock_irqsave(&async_lock, flags); spin_lock_irqsave(&async_lock, flags);
if (domain) { if (domain)
if (!list_empty(&domain->pending)) pending = &domain->pending;
first = list_first_entry(&domain->pending, else
struct async_entry, domain_list); pending = &async_global_pending;
} else {
if (!list_empty(&async_global_pending))
first = list_first_entry(&async_global_pending,
struct async_entry, global_list);
}
if (first) if (!list_empty(pending))
ret = first->cookie; ret = list_first_entry(pending, struct async_entry,
domain_list)->cookie;
spin_unlock_irqrestore(&async_lock, flags); spin_unlock_irqrestore(&async_lock, flags);
return ret; return ret;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment