Commit c0afb0ff authored by Peter Zijlstra's avatar Peter Zijlstra Committed by Ingo Molnar
parent cf702edd
...@@ -30,6 +30,7 @@ void debug_mutex_lock_common(struct mutex *lock, struct mutex_waiter *waiter) ...@@ -30,6 +30,7 @@ void debug_mutex_lock_common(struct mutex *lock, struct mutex_waiter *waiter)
memset(waiter, MUTEX_DEBUG_INIT, sizeof(*waiter)); memset(waiter, MUTEX_DEBUG_INIT, sizeof(*waiter));
waiter->magic = waiter; waiter->magic = waiter;
INIT_LIST_HEAD(&waiter->list); INIT_LIST_HEAD(&waiter->list);
waiter->ww_ctx = MUTEX_POISON_WW_CTX;
} }
void debug_mutex_wake_waiter(struct mutex *lock, struct mutex_waiter *waiter) void debug_mutex_wake_waiter(struct mutex *lock, struct mutex_waiter *waiter)
......
...@@ -982,17 +982,15 @@ __mutex_lock_common(struct mutex *lock, unsigned int state, unsigned int subclas ...@@ -982,17 +982,15 @@ __mutex_lock_common(struct mutex *lock, unsigned int state, unsigned int subclas
} }
debug_mutex_lock_common(lock, &waiter); debug_mutex_lock_common(lock, &waiter);
waiter.task = current;
if (ww_ctx)
waiter.ww_ctx = ww_ctx;
lock_contended(&lock->dep_map, ip); lock_contended(&lock->dep_map, ip);
if (!use_ww_ctx) { if (!use_ww_ctx) {
/* add waiting tasks to the end of the waitqueue (FIFO): */ /* add waiting tasks to the end of the waitqueue (FIFO): */
__mutex_add_waiter(lock, &waiter, &lock->wait_list); __mutex_add_waiter(lock, &waiter, &lock->wait_list);
#ifdef CONFIG_DEBUG_MUTEXES
waiter.ww_ctx = MUTEX_POISON_WW_CTX;
#endif
} else { } else {
/* /*
* Add in stamp order, waking up waiters that must kill * Add in stamp order, waking up waiters that must kill
...@@ -1001,12 +999,8 @@ __mutex_lock_common(struct mutex *lock, unsigned int state, unsigned int subclas ...@@ -1001,12 +999,8 @@ __mutex_lock_common(struct mutex *lock, unsigned int state, unsigned int subclas
ret = __ww_mutex_add_waiter(&waiter, lock, ww_ctx); ret = __ww_mutex_add_waiter(&waiter, lock, ww_ctx);
if (ret) if (ret)
goto err_early_kill; goto err_early_kill;
waiter.ww_ctx = ww_ctx;
} }
waiter.task = current;
set_current_state(state); set_current_state(state);
for (;;) { for (;;) {
bool first; bool first;
......
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