Re: [RFC][PATCH 00/13] firewire-sbp-target: FireWire SBP-2 SCSItarget

From: Stefan Richter
Date: Sun Feb 12 2012 - 11:16:48 EST


On Feb 12 Chris Boot wrote:
> On 12/02/2012 14:12, Stefan Richter wrote:
> > The APIs which you include from "../../firewire/core.h" should eventually
> > be moved to<linux/firewire.h>. I think it does not matter whether this
> > is done before or after mainline merge. When we do so we should check
> > whether the affected APIs can be improved for usage in drivers.
>
> I'm not even sure I use that much from there at all. Possibly only
> fw_card_{get,put,release}(), so that could quite easily be moved into
> <linux/firewire.h>.

Yes, I suppose this is just the card reference counting which we found
is needed for some types of userspace drivers too. But for them it is
wrapped up in the core-cdev.c glue, thus still core-internal presently.

> > Many of the printks should surely be demoted to debug messages with
> > runtime on-and-off switch.
>
> I've moved a lot of them to pr_debug() which doesn't emit anything
> unless you ask it to. Are there others you think should be pr_debug()
> that aren't?

OK, could have been a wrong impression after superficial reading.

[...]
> > sbp_login.c:
> > + pr_notice("initiator already logged-in\n");
> > +
> > + /*
> > + * SBP-2 R4 says we should return access denied, but
> > + * that can confuse initiators. Instead we need to
> > + * treat this like a reconnect, but send the login
> > + * response block like a fresh login.
> > + */
> > Are there initiators which don't bother with reconnect but send relogin
> > straight away?
>
> I found my PowerBook did. It looks like when OpenFirmware hands over to
> Darwin, the latter just does a login. I changed this before I had the
> code to expire sessions once the reconnect timeout expires though so
> it's probably unnecessary now but it would slow down the boot by several
> seconds.

Right, this is a special case. I remember this as an issue with Linux on
Apple PCs as well, together with a particular harddisk firmware with
somewhat unusual timing characteristics, which rejects firewire-sbp2's
login because it still considers the firmware's login valid. The former
ieee1394 + sbp2 stack had more luck, but probably just because of slightly
different timing on their part.

You could make this a special case for initiators with Apple's OUI in
the EUI-64. But I suppose there is no real downside to do this
unconditionally.

Anyway, the case of Apple firmware login -> OS login handover could
certainly be mentioned in the quoted comment, as the one quite common case
where this deviation from the spec is required or at least beneficial.

> > Kconfig:
> > "default n" is redundant.
> > "*older* Apple computers": They are still manufactured with this feature.
>
> I thought all the newer ones only did this over Thunderbolt and not
> FireWire? I'm more than happy to change this though.

Oh, I don't actually know about these ones.
--
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@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/