Re: sig->cputimer.lock/rq->lock lockdep report
From: Ari Savolainen
Date: Thu Oct 13 2011 - 10:44:38 EST
The patch works. No more warnings in the log after boot. I have the
issue in two machines. Both of them freeze after a few hours of use,
but log files don't tell anything after a forced reboot. Tomorrow will
tell if this was it.
Ari
2011/10/12 Peter Zijlstra <a.p.zijlstra@xxxxxxxxx>:
> On Wed, 2011-10-12 at 23:13 +0300, Ari Savolainen wrote:
>> I've got the same problem that Dave reported earlier. I bisected it to
>> commit d670ec13178d "posix-cpu-timers: Cure SMP wobbles".
>
> https://lkml.org/lkml/2011/10/7/282
>
> Does the below work for you? (still not proud of it)
>
> ---
> include/linux/sched.h | 3 +++
> kernel/posix-cpu-timers.c | 6 +++++-
> kernel/sched_stats.h | 4 ++--
> 3 files changed, 10 insertions(+), 3 deletions(-)
>
> diff --git a/include/linux/sched.h b/include/linux/sched.h
> index 41d0237..ad9eafc 100644
> --- a/include/linux/sched.h
> +++ b/include/linux/sched.h
> @@ -503,6 +503,7 @@ struct task_cputime {
> * @running: non-zero when there are timers running and
> * @cputime receives updates.
> * @lock: lock for fields in this struct.
> + * @runtime_lock: lock for cputime.sum_exec_runtime
> *
> * This structure contains the version of task_cputime, above, that is
> * used for thread group CPU timer calculations.
> @@ -511,6 +512,7 @@ struct thread_group_cputimer {
> struct task_cputime cputime;
> int running;
> spinlock_t lock;
> + spinlock_t runtime_lock;
> };
>
> #include <linux/rwsem.h>
> @@ -2566,6 +2568,7 @@ void thread_group_cputimer(struct task_struct *tsk, struct task_cputime *times);
> static inline void thread_group_cputime_init(struct signal_struct *sig)
> {
> spin_lock_init(&sig->cputimer.lock);
> + spin_lock_init(&sig->cputimer.runtime_lock);
> }
>
> /*
> diff --git a/kernel/posix-cpu-timers.c b/kernel/posix-cpu-timers.c
> index c8008dd..fa189a6 100644
> --- a/kernel/posix-cpu-timers.c
> +++ b/kernel/posix-cpu-timers.c
> @@ -284,9 +284,13 @@ void thread_group_cputimer(struct task_struct *tsk, struct task_cputime *times)
> * it.
> */
> thread_group_cputime(tsk, &sum);
> + spin_lock(&cputimer->runtime_lock);
> update_gt_cputime(&cputimer->cputime, &sum);
> - }
> + } else
> + spin_lock(&cputimer->runtime_lock);
> +
> *times = cputimer->cputime;
> + spin_unlock(&cputimer->runtime_lock);
> spin_unlock_irqrestore(&cputimer->lock, flags);
> }
>
> diff --git a/kernel/sched_stats.h b/kernel/sched_stats.h
> index 331e01b..a7e2c1a 100644
> --- a/kernel/sched_stats.h
> +++ b/kernel/sched_stats.h
> @@ -330,7 +330,7 @@ static inline void account_group_exec_runtime(struct task_struct *tsk,
> if (!cputimer->running)
> return;
>
> - spin_lock(&cputimer->lock);
> + spin_lock(&cputimer->runtime_lock);
> cputimer->cputime.sum_exec_runtime += ns;
> - spin_unlock(&cputimer->lock);
> + spin_unlock(&cputimer->runtime_lock);
> }
>
>
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/