|
@@ -1130,6 +1130,7 @@ __rt_mutex_slowlock(struct rt_mutex *lock, int state,
|
|
|
set_current_state(state);
|
|
|
}
|
|
|
|
|
|
+ __set_current_state(TASK_RUNNING);
|
|
|
return ret;
|
|
|
}
|
|
|
|
|
@@ -1188,10 +1189,9 @@ rt_mutex_slowlock(struct rt_mutex *lock, int state,
|
|
|
ret = task_blocks_on_rt_mutex(lock, &waiter, current, chwalk);
|
|
|
|
|
|
if (likely(!ret))
|
|
|
+ /* sleep on the mutex */
|
|
|
ret = __rt_mutex_slowlock(lock, state, timeout, &waiter);
|
|
|
|
|
|
- set_current_state(TASK_RUNNING);
|
|
|
-
|
|
|
if (unlikely(ret)) {
|
|
|
remove_waiter(lock, &waiter);
|
|
|
rt_mutex_handle_deadlock(ret, chwalk, &waiter);
|
|
@@ -1626,10 +1626,9 @@ int rt_mutex_finish_proxy_lock(struct rt_mutex *lock,
|
|
|
|
|
|
set_current_state(TASK_INTERRUPTIBLE);
|
|
|
|
|
|
+ /* sleep on the mutex */
|
|
|
ret = __rt_mutex_slowlock(lock, TASK_INTERRUPTIBLE, to, waiter);
|
|
|
|
|
|
- set_current_state(TASK_RUNNING);
|
|
|
-
|
|
|
if (unlikely(ret))
|
|
|
remove_waiter(lock, waiter);
|
|
|
|