From: Dan Carpenter <dan.carpenter@oracle.com>
To: kernel-janitors@vger.kernel.org
Subject: [bug report] rcu: Diagnostics for grace-period hangs
Date: Mon, 14 May 2018 12:45:03 +0000 [thread overview]
Message-ID: <20180514124503.GA8398@mwanda> (raw)
Hello Paul E. McKenney,
The patch e2ba0f065aec: "rcu: Diagnostics for grace-period hangs"
from Apr 21, 2018, leads to the following static checker warning:
kernel/rcu/tree.c:2739 rcu_check_gp_start_stall()
error: double lock 'irqsave:flags'
kernel/rcu/tree.c
2726
2727 raw_spin_lock_irqsave_rcu_node(rnp, flags);
2728 j = jiffies;
2729 if (rcu_gp_in_progress(rsp) ||
2730 ULONG_CMP_GE(rnp_root->gp_seq, rnp_root->gp_seq_needed) ||
2731 time_before(j, READ_ONCE(rsp->gp_req_activity) + HZ) ||
2732 time_before(j, READ_ONCE(rsp->gp_activity) + HZ) ||
2733 atomic_read(&warned)) {
2734 raw_spin_unlock_irqrestore_rcu_node(rnp, flags);
2735 return;
2736 }
2737 /* Hold onto the leaf lock to make others see warned=1. */
2738
2739 raw_spin_lock_irqsave_rcu_node(rnp_root, flags);
Saving irqsave is not nestable. The second save overwrites the first so
that IRQs can't be re-enabled.
2740 j = jiffies;
2741 if (rcu_gp_in_progress(rsp) ||
2742 ULONG_CMP_GE(rnp_root->gp_seq, rnp_root->gp_seq_needed) ||
2743 time_before(j, rsp->gp_req_activity + HZ) ||
2744 time_before(j, rsp->gp_activity + HZ) ||
2745 atomic_xchg(&warned, 1)) {
2746 raw_spin_unlock_irqrestore_rcu_node(rnp_root, flags);
2747 raw_spin_unlock_irqrestore_rcu_node(rnp, flags);
2748 return;
2749 }
2750 pr_alert("%s: g%ld->%ld gar:%lu ga:%lu f%#x %s->state:%#lx\n",
2751 __func__, (long)READ_ONCE(rsp->gp_seq),
2752 (long)READ_ONCE(rnp_root->gp_seq_needed),
2753 j - rsp->gp_req_activity, j - rsp->gp_activity,
2754 rsp->gp_flags, rsp->name,
2755 rsp->gp_kthread ? rsp->gp_kthread->state : 0x1ffffL);
2756 WARN_ON(1);
2757 raw_spin_unlock_irqrestore_rcu_node(rnp_root, flags);
2758 raw_spin_unlock_irqrestore_rcu_node(rnp, flags);
2759 }
regards,
dan carpenter
next reply other threads:[~2018-05-14 12:45 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-05-14 12:45 Dan Carpenter [this message]
2018-05-14 16:46 ` [bug report] rcu: Diagnostics for grace-period hangs Paul E. McKenney
2018-05-15 11:46 ` Dan Carpenter
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20180514124503.GA8398@mwanda \
--to=dan.carpenter@oracle.com \
--cc=kernel-janitors@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox