[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <tkrat.3829f18186b21759@s5r6.in-berlin.de>
Date: Tue, 19 Aug 2008 21:28:18 +0200 (CEST)
From: Stefan Richter <stefanr@...6.in-berlin.de>
To: linux1394-devel@...ts.sourceforge.net
cc: linux-kernel@...r.kernel.org, damien_benoist@...oo.com
Subject: Re: [patch 2/3] ieee1394: don't drop nodes during bus reset series
I wrote:
> nodemgr_node_probe checked for generation increments too late and
> therefore prematurely reported nodes as "suspended".
>
> Fixes http://bugzilla.kernel.org/show_bug.cgi?id=11349 for me.
This and the accompanying sbp2 patch 3/3 allows the drivers to keep
going if they have temporary trouble with the protocol traffic due to
bus resets in a series.
I now implemented an additional patch which lets the drivers even
tolerate it if nodes vanish a few seconds from the bus --- e.g. a wonky
repeater blacks out briefly, or user plugs cables from left to right,
and so on. As a preparation for this enhancement, I have a cleanup in
nodemgr in the pipeline. Next up:
patch 1/2) ieee1394: nodemgr clean up class iterators
patch 2/2) ieee1394: survive a few seconds connection loss
With this you can indeed unplug a disk, even a bus powered one, and plug
it back in in the next few seconds, while programs are actively
accessing the disk. The IO of these programs will merely be blocked
during the disturbance, but sbp2 will log back in and IO will continue
without error.
Of course situations like these should rather be avoided; but they _do_
happen for example on a bus with PC--disk_A--disk_B when disk_A is
switched from self power to bus power and continues to work as repeater
when bus-powered. The repeater function is only established after a
short disruption of the bus though. Not nice at all if you forgot to
unmount disk_B for the time being. From now on, unmounting it will not
be necessary because it is very very likely that sbp2 will be able to
re-login to disk_B.
The patches which I'll post will apply to 2.6.27-rc only. Variants for
2.6.25 and .26 will be uploaded to
http://user.in-berlin.de/~s5r6/linux1394/updates/ in a few minutes.
The ieee1394 core driver actually contained stubs for this capability
for years, but the implementation wasn't fleshed out for this purpose
until now. Therefore my patches even remove more code than they add.
The new firewire stack desperately needs a similar feature. It monitors
the bus for PHYs vanishing even more precisely than the ieee1394 stack,
thus there is an even higher probability that firewire-sbp2
unnecessarily withdraws a disk from the SCSI stack.
--
Stefan Richter
-=====-==--- =--- =--==
http://arcgraph.de/sr/
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists