On Thu, 2005-09-15 at 15:19 -0700, Mike Anderson wrote:
> A side effect of not applying Alan's previous patch that added
> SHOST_RECOVERY to the SHOST_CANCEL: state is that we will not move to the
> SHOST_CANCEL and subsequently not to SHOST_DEL state if the eh is active
> during the start of scsi_remove_host. I sent mail on the 7th indicating to
> include that state change hunk of the diff, but I guess that overlapped
> with your newer state changes.
> http://marc.theaimsgroup.com/?l=linux-scsi&m=112238726326927&w=2

Yes, but that's not really legitimate since it introduces a bifurcation
in the state machine ... when the eh terminates it will come back to
running even if it went in from cancel.

> In looking at the state model introduced by your patch I believe there may
> still be a state model race issue if the recovery completes just after
> the "if (!scsi_host_set_state(shost, SHOST_CANCEL))" call in
> scsi_remove_host (maybe I am just looking to quickly at the state
> updates).

No, that's true; there's a tiny race that can be mediated by doing
locking around the state changes ... that was one of the feedback
comments from Alan.

> I still do not understand as I asked in a previous comment why we are not
> shutting down the eh_thread in scsi_remove_host and also why simpler state
> model updates could not solve the problem.

Well, it goes back to whether we wait for the thread or not.  To shut
the thread down, we also need to wait for it to complete.

As far as the state model goes, we either need to wait for the eh thread
before transitioning to cancel or introduce the extra states that
reflect the parallel eh transitions.

> I believe I also indicated that we could enhance scsi_error to shutdown
> faster during this state which should only be a performance improvement.

Yes, we could ... patches?

James




-------------------------------------------------------
SF.Net email is sponsored by:
Tame your development challenges with Apache's Geronimo App Server. Download
it for free - -and be entered to win a 42" plasma tv or your very own
Sony(tm)PSP.  Click here to play: http://sourceforge.net/geronimo.php
_______________________________________________
linux-usb-devel@lists.sourceforge.net
To unsubscribe, use the last form field at:
https://lists.sourceforge.net/lists/listinfo/linux-usb-devel

Reply via email to