linux-scsi.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [RESEND PATCH v3 0/2] change UIC command handling
       [not found] <CGME20230802013848epcas2p3a896970d5bdc8e3f3e422c84c282a151@epcas2p3.samsung.com>
@ 2023-08-02  1:28 ` Kiwoong Kim
  0 siblings, 0 replies; 12+ messages in thread
From: Kiwoong Kim @ 2023-08-02  1:28 UTC (permalink / raw)
  To: linux-scsi, linux-kernel, alim.akhtar, avri.altman, bvanassche,
	jejb, martin.petersen, beanhuo, adrian.hunter, sc.suh, hy50.seo,
	sh425.lee, kwangwon.min, junwoo80.lee, wkon.kim
  Cc: Kiwoong Kim

v2 -> v3: rule out the change of polling w/ pmc from this thread.
(I'll post the change later)
v1 -> v2: remove an unused variable in __ufshcd_send_uic_cmd

Kiwoong Kim (2):
  ufs: make __ufshcd_send_uic_cmd not wrapped by host_lock
  ufs: poll HCS.UCRDY before issuing a UIC command

 drivers/ufs/core/ufshcd.c | 13 +++++++------
 1 file changed, 7 insertions(+), 6 deletions(-)

-- 
2.7.4


^ permalink raw reply	[flat|nested] 12+ messages in thread

* [RESEND PATCH v3 0/2] change UIC command handling
       [not found] <CGME20230904014146epcas2p37d6690a5eb3a5652571bb00e358231a3@epcas2p3.samsung.com>
@ 2023-09-04  1:30 ` Kiwoong Kim
  2023-09-04  1:30   ` [RESEND PATCH v3 1/2] ufs: make __ufshcd_send_uic_cmd not wrapped by host_lock Kiwoong Kim
                     ` (2 more replies)
  0 siblings, 3 replies; 12+ messages in thread
From: Kiwoong Kim @ 2023-09-04  1:30 UTC (permalink / raw)
  To: linux-scsi, linux-kernel, alim.akhtar, avri.altman, bvanassche,
	jejb, martin.petersen, beanhuo, adrian.hunter, sc.suh, hy50.seo,
	sh425.lee, kwangwon.min, junwoo80.lee, wkon.kim
  Cc: Kiwoong Kim

v2 -> v3: rule out the change of polling w/ pmc from this thread.
(I'll post the change later)
v1 -> v2: remove an unused variable in __ufshcd_send_uic_cmd

Kiwoong Kim (2):
  ufs: make __ufshcd_send_uic_cmd not wrapped by host_lock
  ufs: poll HCS.UCRDY before issuing a UIC command

 drivers/ufs/core/ufshcd.c | 13 +++++++------
 1 file changed, 7 insertions(+), 6 deletions(-)

-- 
2.7.4


^ permalink raw reply	[flat|nested] 12+ messages in thread

* [RESEND PATCH v3 1/2] ufs: make __ufshcd_send_uic_cmd not wrapped by host_lock
  2023-09-04  1:30 ` [RESEND PATCH v3 0/2] change UIC command handling Kiwoong Kim
@ 2023-09-04  1:30   ` Kiwoong Kim
  2023-09-04  8:23     ` Chanwoo Lee
  2023-09-04  1:30   ` [RESEND PATCH v3 2/2] ufs: poll HCS.UCRDY before issuing a UIC command Kiwoong Kim
  2023-09-05 10:10   ` [RESEND PATCH v3 0/2] change UIC command handling Martin K. Petersen
  2 siblings, 1 reply; 12+ messages in thread
From: Kiwoong Kim @ 2023-09-04  1:30 UTC (permalink / raw)
  To: linux-scsi, linux-kernel, alim.akhtar, avri.altman, bvanassche,
	jejb, martin.petersen, beanhuo, adrian.hunter, sc.suh, hy50.seo,
	sh425.lee, kwangwon.min, junwoo80.lee, wkon.kim
  Cc: Kiwoong Kim

__ufshcd_send_uic_cmd is wrapped uic_cmd_mutex and
its related contexts are accessed within the period wrappted
by uic_cmd_mutex. Thus, wrapping with host_lock is
redundant.

Signed-off-by: Kiwoong Kim <kwmad.kim@samsung.com>
Reviewed-by: Bart Van Assche <bvanassche@acm.org>
---
 drivers/ufs/core/ufshcd.c | 6 +-----
 1 file changed, 1 insertion(+), 5 deletions(-)

diff --git a/drivers/ufs/core/ufshcd.c b/drivers/ufs/core/ufshcd.c
index 27e1a49..6300ed6 100644
--- a/drivers/ufs/core/ufshcd.c
+++ b/drivers/ufs/core/ufshcd.c
@@ -2414,7 +2414,6 @@ __ufshcd_send_uic_cmd(struct ufs_hba *hba, struct uic_command *uic_cmd,
 		      bool completion)
 {
 	lockdep_assert_held(&hba->uic_cmd_mutex);
-	lockdep_assert_held(hba->host->host_lock);
 
 	if (!ufshcd_ready_for_uic_cmd(hba)) {
 		dev_err(hba->dev,
@@ -2441,7 +2440,6 @@ __ufshcd_send_uic_cmd(struct ufs_hba *hba, struct uic_command *uic_cmd,
 int ufshcd_send_uic_cmd(struct ufs_hba *hba, struct uic_command *uic_cmd)
 {
 	int ret;
-	unsigned long flags;
 
 	if (hba->quirks & UFSHCD_QUIRK_BROKEN_UIC_CMD)
 		return 0;
@@ -2450,9 +2448,7 @@ int ufshcd_send_uic_cmd(struct ufs_hba *hba, struct uic_command *uic_cmd)
 	mutex_lock(&hba->uic_cmd_mutex);
 	ufshcd_add_delay_before_dme_cmd(hba);
 
-	spin_lock_irqsave(hba->host->host_lock, flags);
 	ret = __ufshcd_send_uic_cmd(hba, uic_cmd, true);
-	spin_unlock_irqrestore(hba->host->host_lock, flags);
 	if (!ret)
 		ret = ufshcd_wait_for_uic_cmd(hba, uic_cmd);
 
@@ -4161,8 +4157,8 @@ static int ufshcd_uic_pwr_ctrl(struct ufs_hba *hba, struct uic_command *cmd)
 		wmb();
 		reenable_intr = true;
 	}
-	ret = __ufshcd_send_uic_cmd(hba, cmd, false);
 	spin_unlock_irqrestore(hba->host->host_lock, flags);
+	ret = __ufshcd_send_uic_cmd(hba, cmd, false);
 	if (ret) {
 		dev_err(hba->dev,
 			"pwr ctrl cmd 0x%x with mode 0x%x uic error %d\n",
-- 
2.7.4


^ permalink raw reply related	[flat|nested] 12+ messages in thread

* [RESEND PATCH v3 2/2] ufs: poll HCS.UCRDY before issuing a UIC command
  2023-09-04  1:30 ` [RESEND PATCH v3 0/2] change UIC command handling Kiwoong Kim
  2023-09-04  1:30   ` [RESEND PATCH v3 1/2] ufs: make __ufshcd_send_uic_cmd not wrapped by host_lock Kiwoong Kim
@ 2023-09-04  1:30   ` Kiwoong Kim
  2023-09-04  8:27     ` [RESEND,v3,2/2] " Chanwoo Lee
  2023-09-05 10:10   ` [RESEND PATCH v3 0/2] change UIC command handling Martin K. Petersen
  2 siblings, 1 reply; 12+ messages in thread
From: Kiwoong Kim @ 2023-09-04  1:30 UTC (permalink / raw)
  To: linux-scsi, linux-kernel, alim.akhtar, avri.altman, bvanassche,
	jejb, martin.petersen, beanhuo, adrian.hunter, sc.suh, hy50.seo,
	sh425.lee, kwangwon.min, junwoo80.lee, wkon.kim
  Cc: Kiwoong Kim

With auto hibern8 enabled, UIC could be working
for a while to process a hibern8 operation and HCI
reports UIC not ready for a short term through HCS.UCRDY.
And UFS driver can't recognize the operation.
UFSHCI spec specifies UCRDY like this:
whether the host controller is ready to process UIC COMMAND

The 'ready' could be seen as many different meanings. If the meaning
includes not processing any request from HCI, processing a hibern8
operation can be 'not ready'. In this situation, the driver needs to
wait until the operations is completed.

Signed-off-by: Kiwoong Kim <kwmad.kim@samsung.com>
Reviewed-by: Adrian Hunter <adrian.hunter@intel.com>
---
 drivers/ufs/core/ufshcd.c | 7 ++++++-
 1 file changed, 6 insertions(+), 1 deletion(-)

diff --git a/drivers/ufs/core/ufshcd.c b/drivers/ufs/core/ufshcd.c
index 6300ed6..7bc3fc4 100644
--- a/drivers/ufs/core/ufshcd.c
+++ b/drivers/ufs/core/ufshcd.c
@@ -22,6 +22,7 @@
 #include <linux/module.h>
 #include <linux/regulator/consumer.h>
 #include <linux/sched/clock.h>
+#include <linux/iopoll.h>
 #include <scsi/scsi_cmnd.h>
 #include <scsi/scsi_dbg.h>
 #include <scsi/scsi_driver.h>
@@ -2322,7 +2323,11 @@ static inline int ufshcd_hba_capabilities(struct ufs_hba *hba)
  */
 static inline bool ufshcd_ready_for_uic_cmd(struct ufs_hba *hba)
 {
-	return ufshcd_readl(hba, REG_CONTROLLER_STATUS) & UIC_COMMAND_READY;
+	u32 val;
+	int ret = read_poll_timeout(ufshcd_readl, val, val & UIC_COMMAND_READY,
+				    500, UIC_CMD_TIMEOUT * 1000, false, hba,
+				    REG_CONTROLLER_STATUS);
+	return ret == 0 ? true : false;
 }
 
 /**
-- 
2.7.4


^ permalink raw reply related	[flat|nested] 12+ messages in thread

* Re: [RESEND PATCH v3 1/2] ufs: make __ufshcd_send_uic_cmd not wrapped by host_lock
  2023-09-04  1:30   ` [RESEND PATCH v3 1/2] ufs: make __ufshcd_send_uic_cmd not wrapped by host_lock Kiwoong Kim
@ 2023-09-04  8:23     ` Chanwoo Lee
  0 siblings, 0 replies; 12+ messages in thread
From: Chanwoo Lee @ 2023-09-04  8:23 UTC (permalink / raw)
  To: kwmad.kim
  Cc: adrian.hunter, alim.akhtar, avri.altman, beanhuo, bvanassche,
	hy50.seo, jejb, junwoo80.lee, kwangwon.min, linux-kernel,
	linux-scsi, martin.petersen, sc.suh, sh425.lee, wkon.kim,
	Chanwoo Lee

> __ufshcd_send_uic_cmd is wrapped uic_cmd_mutex and
> its related contexts are accessed within the period wrappted
> by uic_cmd_mutex. Thus, wrapping with host_lock is
> redundant.
> 
> Signed-off-by: Kiwoong Kim <kwmad.kim@samsung.com>
> Reviewed-by: Bart Van Assche <bvanassche@acm.org>
> ---

Reviewed-by: Junwoo Lee <junwoo80.lee@samsung.com>
Reviewed-by: Chanwoo Lee <cw9316.lee@samsung.com>


^ permalink raw reply	[flat|nested] 12+ messages in thread

* Re: [RESEND,v3,2/2] ufs: poll HCS.UCRDY before issuing a UIC command
  2023-09-04  1:30   ` [RESEND PATCH v3 2/2] ufs: poll HCS.UCRDY before issuing a UIC command Kiwoong Kim
@ 2023-09-04  8:27     ` Chanwoo Lee
  0 siblings, 0 replies; 12+ messages in thread
From: Chanwoo Lee @ 2023-09-04  8:27 UTC (permalink / raw)
  To: kwmad.kim
  Cc: adrian.hunter, alim.akhtar, avri.altman, beanhuo, bvanassche,
	hy50.seo, jejb, junwoo80.lee, kwangwon.min, linux-kernel,
	linux-scsi, martin.petersen, sc.suh, sh425.lee, wkon.kim,
	Chanwoo Lee

On 9/04/23 5:31 PM, cw9316.lee@samsung.com wrote:
> With auto hibern8 enabled, UIC could be working
> for a while to process a hibern8 operation and HCI
> reports UIC not ready for a short term through HCS.UCRDY.
> And UFS driver can't recognize the operation.
> UFSHCI spec specifies UCRDY like this:
> whether the host controller is ready to process UIC COMMAND
> 
> The 'ready' could be seen as many different meanings. If the meaning
> includes not processing any request from HCI, processing a hibern8
> operation can be 'not ready'. In this situation, the driver needs to
> wait until the operations is completed.
> 
> Signed-off-by: Kiwoong Kim <kwmad.kim@samsung.com>
> Reviewed-by: Adrian Hunter <adrian.hunter@intel.com>
> ---

Reviewed-by: Junwoo Lee <junwoo80.lee@samsung.com>
Reviewed-by: Chanwoo Lee <cw9316.lee@samsung.com>


^ permalink raw reply	[flat|nested] 12+ messages in thread

* Re: [RESEND PATCH v3 0/2] change UIC command handling
  2023-09-04  1:30 ` [RESEND PATCH v3 0/2] change UIC command handling Kiwoong Kim
  2023-09-04  1:30   ` [RESEND PATCH v3 1/2] ufs: make __ufshcd_send_uic_cmd not wrapped by host_lock Kiwoong Kim
  2023-09-04  1:30   ` [RESEND PATCH v3 2/2] ufs: poll HCS.UCRDY before issuing a UIC command Kiwoong Kim
@ 2023-09-05 10:10   ` Martin K. Petersen
  2023-09-11  1:35     ` Kiwoong Kim
  2 siblings, 1 reply; 12+ messages in thread
From: Martin K. Petersen @ 2023-09-05 10:10 UTC (permalink / raw)
  To: Kiwoong Kim
  Cc: linux-scsi, linux-kernel, alim.akhtar, avri.altman, bvanassche,
	jejb, martin.petersen, beanhuo, adrian.hunter, sc.suh, hy50.seo,
	sh425.lee, kwangwon.min, junwoo80.lee, wkon.kim


Kiwoong,

> v2 -> v3: rule out the change of polling w/ pmc from this thread.
> (I'll post the change later)
> v1 -> v2: remove an unused variable in __ufshcd_send_uic_cmd
>
> Kiwoong Kim (2):
>   ufs: make __ufshcd_send_uic_cmd not wrapped by host_lock
>   ufs: poll HCS.UCRDY before issuing a UIC command

Applied to 6.6/scsi-staging, thanks!

-- 
Martin K. Petersen	Oracle Linux Engineering

^ permalink raw reply	[flat|nested] 12+ messages in thread

* RE: [RESEND PATCH v3 0/2] change UIC command handling
  2023-09-05 10:10   ` [RESEND PATCH v3 0/2] change UIC command handling Martin K. Petersen
@ 2023-09-11  1:35     ` Kiwoong Kim
  2023-09-11  5:55       ` Adrian Hunter
  0 siblings, 1 reply; 12+ messages in thread
From: Kiwoong Kim @ 2023-09-11  1:35 UTC (permalink / raw)
  To: 'Martin K. Petersen'
  Cc: linux-scsi, linux-kernel, alim.akhtar, avri.altman, bvanassche,
	jejb, beanhuo, adrian.hunter, sc.suh, hy50.seo, sh425.lee,
	kwangwon.min, junwoo80.lee, wkon.kim

> > v2 -> v3: rule out the change of polling w/ pmc from this thread.
> > (I'll post the change later)
> > v1 -> v2: remove an unused variable in __ufshcd_send_uic_cmd
> >
> > Kiwoong Kim (2):
> >   ufs: make __ufshcd_send_uic_cmd not wrapped by host_lock
> >   ufs: poll HCS.UCRDY before issuing a UIC command
> 
> Applied to 6.6/scsi-staging, thanks!
> 
> --
> Martin K. Petersen	Oracle Linux Engineering

Hi, Martin

The following patch seems to make trouble because of using
read_poll_timeout.
Its initial version used udelay and after discussion it's been changed.
Could you revert this patch set?

> ufs: poll HCS.UCRDY before issuing a UIC command

[ 4671.226480] [3: kworker/u20:29:17140] BUG: scheduling while atomic:
kworker/u20:29/17140/0x00000002
..
[ 4671.228723] [3: kworker/u20:29:17140]  panic+0x16c/0x388
[ 4671.228745] [3: kworker/u20:29:17140]  check_panic_on_warn+0x60/0x94
[ 4671.228764] [3: kworker/u20:29:17140]  __schedule_bug+0x6c/0x94
[ 4671.228786] [3: kworker/u20:29:17140]  __schedule+0x6f4/0xa64
[ 4671.228806] [3: kworker/u20:29:17140]  schedule+0x7c/0xe8
[ 4671.228824] [3: kworker/u20:29:17140]
schedule_hrtimeout_range_clock+0x98/0x114
[ 4671.228841] [3: kworker/u20:29:17140]  schedule_hrtimeout_range+0x14/0x24
[ 4671.228856] [3: kworker/u20:29:17140]  usleep_range_state+0x60/0x94
[ 4671.228871] [3: kworker/u20:29:17140]  __ufshcd_send_uic_cmd+0xa0/0x1c4
[ 4671.228893] [3: kworker/u20:29:17140]  ufshcd_uic_pwr_ctrl+0x15c/0x390
[ 4671.228908] [3: kworker/u20:29:17140]
ufshcd_uic_hibern8_enter+0x9c/0x25c
[ 4671.228922] [3: kworker/u20:29:17140]
ufshcd_link_state_transition+0x34/0xb0
[ 4671.228939] [3: kworker/u20:29:17140]  __ufshcd_wl_suspend+0x3f0/0x4b4

Thanks you.


^ permalink raw reply	[flat|nested] 12+ messages in thread

* Re: [RESEND PATCH v3 0/2] change UIC command handling
  2023-09-11  1:35     ` Kiwoong Kim
@ 2023-09-11  5:55       ` Adrian Hunter
  2023-09-11  6:32         ` Kiwoong Kim
  0 siblings, 1 reply; 12+ messages in thread
From: Adrian Hunter @ 2023-09-11  5:55 UTC (permalink / raw)
  To: Kiwoong Kim
  Cc: linux-scsi, linux-kernel, alim.akhtar, avri.altman, bvanassche,
	jejb, beanhuo, sc.suh, hy50.seo, sh425.lee, kwangwon.min,
	junwoo80.lee, wkon.kim, 'Martin K. Petersen'

On 11/09/23 04:35, Kiwoong Kim wrote:
>>> v2 -> v3: rule out the change of polling w/ pmc from this thread.
>>> (I'll post the change later)
>>> v1 -> v2: remove an unused variable in __ufshcd_send_uic_cmd
>>>
>>> Kiwoong Kim (2):
>>>   ufs: make __ufshcd_send_uic_cmd not wrapped by host_lock
>>>   ufs: poll HCS.UCRDY before issuing a UIC command
>>
>> Applied to 6.6/scsi-staging, thanks!
>>
>> --
>> Martin K. Petersen	Oracle Linux Engineering
> 
> Hi, Martin
> 
> The following patch seems to make trouble because of using
> read_poll_timeout.
> Its initial version used udelay and after discussion it's been changed.
> Could you revert this patch set?
> 
>> ufs: poll HCS.UCRDY before issuing a UIC command
> 
> [ 4671.226480] [3: kworker/u20:29:17140] BUG: scheduling while atomic:
> kworker/u20:29/17140/0x00000002
> ..
> [ 4671.228723] [3: kworker/u20:29:17140]  panic+0x16c/0x388
> [ 4671.228745] [3: kworker/u20:29:17140]  check_panic_on_warn+0x60/0x94
> [ 4671.228764] [3: kworker/u20:29:17140]  __schedule_bug+0x6c/0x94
> [ 4671.228786] [3: kworker/u20:29:17140]  __schedule+0x6f4/0xa64
> [ 4671.228806] [3: kworker/u20:29:17140]  schedule+0x7c/0xe8
> [ 4671.228824] [3: kworker/u20:29:17140]
> schedule_hrtimeout_range_clock+0x98/0x114
> [ 4671.228841] [3: kworker/u20:29:17140]  schedule_hrtimeout_range+0x14/0x24
> [ 4671.228856] [3: kworker/u20:29:17140]  usleep_range_state+0x60/0x94
> [ 4671.228871] [3: kworker/u20:29:17140]  __ufshcd_send_uic_cmd+0xa0/0x1c4
> [ 4671.228893] [3: kworker/u20:29:17140]  ufshcd_uic_pwr_ctrl+0x15c/0x390
> [ 4671.228908] [3: kworker/u20:29:17140]
> ufshcd_uic_hibern8_enter+0x9c/0x25c
> [ 4671.228922] [3: kworker/u20:29:17140]
> ufshcd_link_state_transition+0x34/0xb0
> [ 4671.228939] [3: kworker/u20:29:17140]  __ufshcd_wl_suspend+0x3f0/0x4b4

Do you know what is in that path that makes it an atomic context?


^ permalink raw reply	[flat|nested] 12+ messages in thread

* RE: [RESEND PATCH v3 0/2] change UIC command handling
  2023-09-11  5:55       ` Adrian Hunter
@ 2023-09-11  6:32         ` Kiwoong Kim
  2023-09-11  7:10           ` Adrian Hunter
  0 siblings, 1 reply; 12+ messages in thread
From: Kiwoong Kim @ 2023-09-11  6:32 UTC (permalink / raw)
  To: 'Adrian Hunter'
  Cc: linux-scsi, linux-kernel, alim.akhtar, avri.altman, bvanassche,
	jejb, beanhuo, sc.suh, hy50.seo, sh425.lee, kwangwon.min,
	junwoo80.lee, wkon.kim, 'Martin K. Petersen'

> >> ufs: poll HCS.UCRDY before issuing a UIC command
> >
> > [ 4671.226480] [3: kworker/u20:29:17140] BUG: scheduling while atomic:
> > kworker/u20:29/17140/0x00000002
> > ..
> > [ 4671.228723] [3: kworker/u20:29:17140]  panic+0x16c/0x388 [
> > 4671.228745] [3: kworker/u20:29:17140]  check_panic_on_warn+0x60/0x94
> > [ 4671.228764] [3: kworker/u20:29:17140]  __schedule_bug+0x6c/0x94 [
> > 4671.228786] [3: kworker/u20:29:17140]  __schedule+0x6f4/0xa64 [
> > 4671.228806] [3: kworker/u20:29:17140]  schedule+0x7c/0xe8 [
> > 4671.228824] [3: kworker/u20:29:17140]
> > schedule_hrtimeout_range_clock+0x98/0x114
> > [ 4671.228841] [3: kworker/u20:29:17140]
> > schedule_hrtimeout_range+0x14/0x24
> > [ 4671.228856] [3: kworker/u20:29:17140]  usleep_range_state+0x60/0x94
> > [ 4671.228871] [3: kworker/u20:29:17140]
> > __ufshcd_send_uic_cmd+0xa0/0x1c4 [ 4671.228893] [3:
> > kworker/u20:29:17140]  ufshcd_uic_pwr_ctrl+0x15c/0x390 [ 4671.228908]
> > [3: kworker/u20:29:17140] ufshcd_uic_hibern8_enter+0x9c/0x25c
> > [ 4671.228922] [3: kworker/u20:29:17140]
> > ufshcd_link_state_transition+0x34/0xb0
> > [ 4671.228939] [3: kworker/u20:29:17140]
> > __ufshcd_wl_suspend+0x3f0/0x4b4
> 
> Do you know what is in that path that makes it an atomic context?

Hi,
This made that.

static int ufshcd_uic_pwr_ctrl(struct ufs_hba *hba, struct uic_command *cmd)
..
        bool reenable_intr = false;

        mutex_lock(&hba->uic_cmd_mutex); <<<<


At first, I was willing to post together w/ the following patch but I've got a suggestion to split the patch set because of different topic and I split the patch set.
- This patch removes the mutex, so it can fix the issue.
https://lore.kernel.org/linux-scsi/1694051306-172962-1-git-send-email-kwmad.kim@samsung.com/


But now I'm thinking again that simply removing the mutex could hurt atomicity of UIC command process
that the original code intended for the first time.
So I think this polling UCRDY should be modified rather than applying removal of the mutex.




^ permalink raw reply	[flat|nested] 12+ messages in thread

* Re: [RESEND PATCH v3 0/2] change UIC command handling
  2023-09-11  6:32         ` Kiwoong Kim
@ 2023-09-11  7:10           ` Adrian Hunter
  2023-09-11  7:23             ` Kiwoong Kim
  0 siblings, 1 reply; 12+ messages in thread
From: Adrian Hunter @ 2023-09-11  7:10 UTC (permalink / raw)
  To: Kiwoong Kim
  Cc: linux-scsi, linux-kernel, alim.akhtar, avri.altman, bvanassche,
	jejb, beanhuo, sc.suh, hy50.seo, sh425.lee, kwangwon.min,
	junwoo80.lee, wkon.kim, 'Martin K. Petersen'

On 11/09/23 09:32, Kiwoong Kim wrote:
>>>> ufs: poll HCS.UCRDY before issuing a UIC command
>>>
>>> [ 4671.226480] [3: kworker/u20:29:17140] BUG: scheduling while atomic:
>>> kworker/u20:29/17140/0x00000002
>>> ..
>>> [ 4671.228723] [3: kworker/u20:29:17140]  panic+0x16c/0x388 [
>>> 4671.228745] [3: kworker/u20:29:17140]  check_panic_on_warn+0x60/0x94
>>> [ 4671.228764] [3: kworker/u20:29:17140]  __schedule_bug+0x6c/0x94 [
>>> 4671.228786] [3: kworker/u20:29:17140]  __schedule+0x6f4/0xa64 [
>>> 4671.228806] [3: kworker/u20:29:17140]  schedule+0x7c/0xe8 [
>>> 4671.228824] [3: kworker/u20:29:17140]
>>> schedule_hrtimeout_range_clock+0x98/0x114
>>> [ 4671.228841] [3: kworker/u20:29:17140]
>>> schedule_hrtimeout_range+0x14/0x24
>>> [ 4671.228856] [3: kworker/u20:29:17140]  usleep_range_state+0x60/0x94
>>> [ 4671.228871] [3: kworker/u20:29:17140]
>>> __ufshcd_send_uic_cmd+0xa0/0x1c4 [ 4671.228893] [3:
>>> kworker/u20:29:17140]  ufshcd_uic_pwr_ctrl+0x15c/0x390 [ 4671.228908]
>>> [3: kworker/u20:29:17140] ufshcd_uic_hibern8_enter+0x9c/0x25c
>>> [ 4671.228922] [3: kworker/u20:29:17140]
>>> ufshcd_link_state_transition+0x34/0xb0
>>> [ 4671.228939] [3: kworker/u20:29:17140]
>>> __ufshcd_wl_suspend+0x3f0/0x4b4
>>
>> Do you know what is in that path that makes it an atomic context?
> 
> Hi,
> This made that.
> 
> static int ufshcd_uic_pwr_ctrl(struct ufs_hba *hba, struct uic_command *cmd)
> ..
>         bool reenable_intr = false;
> 
>         mutex_lock(&hba->uic_cmd_mutex); <<<<

It is OK to schedule while holding a mutex.  Are you sure
this is the problem?

> 
> 
> At first, I was willing to post together w/ the following patch but I've got a suggestion to split the patch set because of different topic and I split the patch set.
> - This patch removes the mutex, so it can fix the issue.
> https://lore.kernel.org/linux-scsi/1694051306-172962-1-git-send-email-kwmad.kim@samsung.com/
> 
> 
> But now I'm thinking again that simply removing the mutex could hurt atomicity of UIC command process
> that the original code intended for the first time.
> So I think this polling UCRDY should be modified rather than applying removal of the mutex.
> 
> 
> 


^ permalink raw reply	[flat|nested] 12+ messages in thread

* RE: [RESEND PATCH v3 0/2] change UIC command handling
  2023-09-11  7:10           ` Adrian Hunter
@ 2023-09-11  7:23             ` Kiwoong Kim
  0 siblings, 0 replies; 12+ messages in thread
From: Kiwoong Kim @ 2023-09-11  7:23 UTC (permalink / raw)
  To: 'Adrian Hunter'
  Cc: linux-scsi, linux-kernel, alim.akhtar, avri.altman, bvanassche,
	jejb, beanhuo, sc.suh, hy50.seo, sh425.lee, kwangwon.min,
	junwoo80.lee, wkon.kim, 'Martin K. Petersen'

> > static int ufshcd_uic_pwr_ctrl(struct ufs_hba *hba, struct uic_command
> > *cmd) ..
> >         bool reenable_intr = false;
> >
> >         mutex_lock(&hba->uic_cmd_mutex); <<<<
> 
> It is OK to schedule while holding a mutex.  Are you sure this is the
> problem?

Ah, I mis-understood it. It was for not applying this.
https://lore.kernel.org/linux-scsi/782ba5f26f0a96e58d85dff50751787d2d2a6b2b.1693790060.git.kwmad.kim@samsung.com/

So this patch set has no problem. Sorry for bothering all of you.

Thanks.



^ permalink raw reply	[flat|nested] 12+ messages in thread

end of thread, other threads:[~2023-09-11  7:23 UTC | newest]

Thread overview: 12+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
     [not found] <CGME20230904014146epcas2p37d6690a5eb3a5652571bb00e358231a3@epcas2p3.samsung.com>
2023-09-04  1:30 ` [RESEND PATCH v3 0/2] change UIC command handling Kiwoong Kim
2023-09-04  1:30   ` [RESEND PATCH v3 1/2] ufs: make __ufshcd_send_uic_cmd not wrapped by host_lock Kiwoong Kim
2023-09-04  8:23     ` Chanwoo Lee
2023-09-04  1:30   ` [RESEND PATCH v3 2/2] ufs: poll HCS.UCRDY before issuing a UIC command Kiwoong Kim
2023-09-04  8:27     ` [RESEND,v3,2/2] " Chanwoo Lee
2023-09-05 10:10   ` [RESEND PATCH v3 0/2] change UIC command handling Martin K. Petersen
2023-09-11  1:35     ` Kiwoong Kim
2023-09-11  5:55       ` Adrian Hunter
2023-09-11  6:32         ` Kiwoong Kim
2023-09-11  7:10           ` Adrian Hunter
2023-09-11  7:23             ` Kiwoong Kim
     [not found] <CGME20230802013848epcas2p3a896970d5bdc8e3f3e422c84c282a151@epcas2p3.samsung.com>
2023-08-02  1:28 ` Kiwoong Kim

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).