]> git.baikalelectronics.ru Git - kernel.git/commit
firewire: fw-sbp2: delay first login to avoid retries
authorStefan Richter <stefanr@s5r6.in-berlin.de>
Tue, 21 Oct 2008 22:28:36 +0000 (00:28 +0200)
committerStefan Richter <stefanr@s5r6.in-berlin.de>
Sun, 26 Oct 2008 09:27:01 +0000 (10:27 +0100)
commitc712536abbbfd25f8d518fef11eb8a4a48e30196
tree1b810e6cec5bc303c16806d4e33b2923a122a1ee
parenta9eee777533b00f580ccd4b7a3208e4136a14c38
firewire: fw-sbp2: delay first login to avoid retries

This optimizes firewire-sbp2's device probe for the case that the local
node and the SBP-2 node were discovered at the same time.  In this case,
fw-core's bus management work and fw-sbp2's login and SCSI probe work
are scheduled in parallel (in the globally shared workqueue and in
fw-sbp2's workqueue, respectively).  The bus reset from fw-core may then
disturb and extremely delay the login and SCSI probe because the latter
fails with several command timeouts and retries and has to be retried
from scratch.

We avoid this particular situation of sbp2_login() and fw_card_bm_work()
running in parallel by delaying the first sbp2_login() a little bit.

This is meant to be a short-term fix for
https://bugzilla.redhat.com/show_bug.cgi?id=466679.  In the long run,
the SCSI probe, i.e. fw-sbp2's call of __scsi_add_device(), should be
parallelized with sbp2_reconnect().

Problem reported and fix tested and confirmed by Alex Kanavin.

Signed-off-by: Stefan Richter <stefanr@s5r6.in-berlin.de>
drivers/firewire/fw-sbp2.c