From: Ray Jui <ray.jui@broadcom.com>
To: YE Chengfeng <cyeaa@connect.ust.hk>,
"andi.shyti@kernel.org" <andi.shyti@kernel.org>,
"rjui@broadcom.com" <rjui@broadcom.com>,
"sbranden@broadcom.com" <sbranden@broadcom.com>
Cc: "linux-i2c@vger.kernel.org" <linux-i2c@vger.kernel.org>,
Linux ARM <linux-arm-kernel@lists.infradead.org>,
"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>,
"bcm-kernel-feedback-list@broadcom.com"
<bcm-kernel-feedback-list@broadcom.com>
Subject: Re: [PATCH] i2c: bcm-iproc: Fix bcm_iproc_i2c_isr deadlock issue
Date: Mon, 26 Jun 2023 09:42:39 -0700 [thread overview]
Message-ID: <b68ad6c4-f5e6-9bb7-0ac8-2cd08ce04c7a@broadcom.com> (raw)
In-Reply-To: <TYCP286MB1188708B1CE64D95FBACF9E78A20A@TYCP286MB1188.JPNP286.PROD.OUTLOOK.COM>
[-- Attachment #1.1: Type: text/plain, Size: 2728 bytes --]
Hi Chengfeng,
On 6/24/2023 12:36 PM, YE Chengfeng wrote:
> iproc_i2c_rd_reg and iproc_i2c_wr_reg are called from both
> interrupt context (e.g. bcm_iproc_i2c_isr) and process context
> (e.g. bcm_iproc_i2c_suspend). Therefore, interrupts should be
> disabled to avoid potential deadlock. To prevent this deadlock,
> use spin_lock_irqsave.
>
> Signed-off-by: Chengfeng Ye <cyeaa@connect.ust.hk>
> ---
> drivers/i2c/busses/i2c-bcm-iproc.c | 10 ++++++----
> 1 file changed, 6 insertions(+), 4 deletions(-)
>
> diff --git a/drivers/i2c/busses/i2c-bcm-iproc.c b/drivers/i2c/busses/i2c-bcm-iproc.c
> index 85d8a6b04885..d02245e4db8c 100644
> --- a/drivers/i2c/busses/i2c-bcm-iproc.c
> +++ b/drivers/i2c/busses/i2c-bcm-iproc.c
> @@ -233,13 +233,14 @@ static inline u32 iproc_i2c_rd_reg(struct bcm_iproc_i2c_dev *iproc_i2c,
> u32 offset)
> {
> u32 val;
> + unsigned long flags;
>
> if (iproc_i2c->idm_base) {
> - spin_lock(&iproc_i2c->idm_lock);
> + spin_lock_irqsave(&iproc_i2c->idm_lock, flags);
> writel(iproc_i2c->ape_addr_mask,
> iproc_i2c->idm_base + IDM_CTRL_DIRECT_OFFSET);
> val = readl(iproc_i2c->base + offset);
> - spin_unlock(&iproc_i2c->idm_lock);
> + spin_unlock_irqrestore(&iproc_i2c->idm_lock, flags);
> } else {
> val = readl(iproc_i2c->base + offset);
> }
> @@ -250,12 +251,13 @@ static inline u32 iproc_i2c_rd_reg(struct bcm_iproc_i2c_dev *iproc_i2c,
> static inline void iproc_i2c_wr_reg(struct bcm_iproc_i2c_dev *iproc_i2c,
> u32 offset, u32 val)
> {
> + unsigned long flags;
> if (iproc_i2c->idm_base) {
> - spin_lock(&iproc_i2c->idm_lock);
> + spin_lock_irqsave(&iproc_i2c->idm_lock, flags);
> writel(iproc_i2c->ape_addr_mask,
> iproc_i2c->idm_base + IDM_CTRL_DIRECT_OFFSET);
> writel(val, iproc_i2c->base + offset);
> - spin_unlock(&iproc_i2c->idm_lock);
> + spin_unlock_irqrestore(&iproc_i2c->idm_lock, flags);
> } else {
> writel(val, iproc_i2c->base + offset);
> }
> --
> 2.17.1
This fix looks good to me. Thanks. Just curious, did you actually see a
race condition issue as a result of this, or the fix is done completely
based on the analysis of the code?
Acked-by: Ray Jui <ray.jui@broadcom.com>
[-- Attachment #1.2: S/MIME Cryptographic Signature --]
[-- Type: application/pkcs7-signature, Size: 4194 bytes --]
[-- Attachment #2: Type: text/plain, Size: 176 bytes --]
_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
next prev parent reply other threads:[~2023-06-26 16:43 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-06-24 19:36 [PATCH] i2c: bcm-iproc: Fix bcm_iproc_i2c_isr deadlock issue YE Chengfeng
2023-06-26 16:42 ` Ray Jui [this message]
2023-06-26 17:05 ` YE Chengfeng
2023-06-26 17:18 ` Ray Jui
2023-07-06 19:36 ` Wolfram Sang
2023-07-06 20:08 ` Ray Jui
2023-07-06 21:28 ` YE Chengfeng
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=b68ad6c4-f5e6-9bb7-0ac8-2cd08ce04c7a@broadcom.com \
--to=ray.jui@broadcom.com \
--cc=andi.shyti@kernel.org \
--cc=bcm-kernel-feedback-list@broadcom.com \
--cc=cyeaa@connect.ust.hk \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-i2c@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=rjui@broadcom.com \
--cc=sbranden@broadcom.com \
/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