All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH v2] scsi: docs: update notes about scsi_times_out
@ 2022-02-19  0:16 Khazhismel Kumykov
  2022-02-22 18:32 ` Bart Van Assche
                   ` (2 more replies)
  0 siblings, 3 replies; 4+ messages in thread
From: Khazhismel Kumykov @ 2022-02-19  0:16 UTC (permalink / raw)
  To: Jonathan Corbet, James E.J. Bottomley, Martin K. Petersen
  Cc: linux-doc, linux-scsi, linux-kernel, bvanassche, Hannes Reinecke,
	Khazhismel Kumykov

Most importantly: eh_timed_out() is not limited by scmd->allowed,
and can reset timer forever.

Fixes: c829c394165f ("[SCSI] FC transport : Avoid device offline cases by stalling aborts until device unblocked")

Signed-off-by: Khazhismel Kumykov <khazhy@google.com>
---
 Documentation/scsi/scsi_eh.rst | 15 +++++++--------
 1 file changed, 7 insertions(+), 8 deletions(-)

diff --git a/Documentation/scsi/scsi_eh.rst b/Documentation/scsi/scsi_eh.rst
index 7d78c2475615..885395dc1f15 100644
--- a/Documentation/scsi/scsi_eh.rst
+++ b/Documentation/scsi/scsi_eh.rst
@@ -95,19 +95,18 @@ function
 
     - BLK_EH_RESET_TIMER
 	This indicates that more time is required to finish the
-	command.  Timer is restarted.  This action is counted as a
-	retry and only allowed scmd->allowed + 1(!) times.  Once the
-	limit is reached, action for BLK_EH_DONE is taken instead.
+	command.  Timer is restarted.
 
     - BLK_EH_DONE
         eh_timed_out() callback did not handle the command.
 	Step #2 is taken.
 
- 2. scsi_abort_command() is invoked to schedule an asynchrous abort.
-    Asynchronous abort are not invoked for commands which the
-    SCSI_EH_ABORT_SCHEDULED flag is set (this indicates that the command
-    already had been aborted once, and this is a retry which failed),
-    or when the EH deadline is expired. In these case Step #3 is taken.
+ 2. scsi_abort_command() is invoked to schedule an asynchronous abort which may
+    issue a retry scmd->allowed + 1 times.  Asynchronous aborts are not invoked
+    for commands for which the SCSI_EH_ABORT_SCHEDULED flag is set (this
+    indicates that the command already had been aborted once, and this is a
+    retry which failed), when retries are exceeded, or when the EH deadline is
+    expired. In these cases Step #3 is taken.
 
  3. scsi_eh_scmd_add(scmd, SCSI_EH_CANCEL_CMD) is invoked for the
     command.  See [1-4] for more information.
-- 
2.35.1.473.g83b2b277ed-goog


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

* Re: [PATCH v2] scsi: docs: update notes about scsi_times_out
  2022-02-19  0:16 [PATCH v2] scsi: docs: update notes about scsi_times_out Khazhismel Kumykov
@ 2022-02-22 18:32 ` Bart Van Assche
  2022-02-28  2:33 ` Martin K. Petersen
  2022-03-02  5:13 ` Martin K. Petersen
  2 siblings, 0 replies; 4+ messages in thread
From: Bart Van Assche @ 2022-02-22 18:32 UTC (permalink / raw)
  To: Khazhismel Kumykov, Jonathan Corbet, James E.J. Bottomley,
	Martin K. Petersen
  Cc: linux-doc, linux-scsi, linux-kernel, Hannes Reinecke

On 2/18/22 16:16, Khazhismel Kumykov wrote:
> Most importantly: eh_timed_out() is not limited by scmd->allowed,
> and can reset timer forever.
> 
> Fixes: c829c394165f ("[SCSI] FC transport : Avoid device offline cases by stalling aborts until device unblocked")
> 
> Signed-off-by: Khazhismel Kumykov <khazhy@google.com>

No blank line between a "Fixes:" tag and a "Signed-off-by:" tag please. 
Anyway:

Reviewed-by: Bart Van Assche <bvanassche@acm.org>

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

* Re: [PATCH v2] scsi: docs: update notes about scsi_times_out
  2022-02-19  0:16 [PATCH v2] scsi: docs: update notes about scsi_times_out Khazhismel Kumykov
  2022-02-22 18:32 ` Bart Van Assche
@ 2022-02-28  2:33 ` Martin K. Petersen
  2022-03-02  5:13 ` Martin K. Petersen
  2 siblings, 0 replies; 4+ messages in thread
From: Martin K. Petersen @ 2022-02-28  2:33 UTC (permalink / raw)
  To: Khazhismel Kumykov
  Cc: Jonathan Corbet, James E.J. Bottomley, Martin K. Petersen,
	linux-doc, linux-scsi, linux-kernel, bvanassche, Hannes Reinecke


Khazhismel,

> Most importantly: eh_timed_out() is not limited by scmd->allowed,
> and can reset timer forever.

Applied to 5.18/scsi-staging, thanks!

-- 
Martin K. Petersen	Oracle Linux Engineering

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

* Re: [PATCH v2] scsi: docs: update notes about scsi_times_out
  2022-02-19  0:16 [PATCH v2] scsi: docs: update notes about scsi_times_out Khazhismel Kumykov
  2022-02-22 18:32 ` Bart Van Assche
  2022-02-28  2:33 ` Martin K. Petersen
@ 2022-03-02  5:13 ` Martin K. Petersen
  2 siblings, 0 replies; 4+ messages in thread
From: Martin K. Petersen @ 2022-03-02  5:13 UTC (permalink / raw)
  To: Jonathan Corbet, James E.J. Bottomley, Khazhismel Kumykov
  Cc: Martin K . Petersen, linux-kernel, bvanassche, linux-scsi,
	Hannes Reinecke, linux-doc

On Fri, 18 Feb 2022 16:16:01 -0800, Khazhismel Kumykov wrote:

> Most importantly: eh_timed_out() is not limited by scmd->allowed,
> and can reset timer forever.
> 
> Fixes: c829c394165f ("[SCSI] FC transport : Avoid device offline cases by stalling aborts until device unblocked")
> 
> 

Applied to 5.18/scsi-queue, thanks!

[1/1] scsi: docs: update notes about scsi_times_out
      https://git.kernel.org/mkp/scsi/c/5c139ce9e1c2

-- 
Martin K. Petersen	Oracle Linux Engineering

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

end of thread, other threads:[~2022-03-02  5:14 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2022-02-19  0:16 [PATCH v2] scsi: docs: update notes about scsi_times_out Khazhismel Kumykov
2022-02-22 18:32 ` Bart Van Assche
2022-02-28  2:33 ` Martin K. Petersen
2022-03-02  5:13 ` Martin K. Petersen

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.