Re: FireWire/SBP2 Target mode

From: Chris Boot
Date: Mon Feb 06 2012 - 09:51:19 EST


On 06/02/2012 14:43, Clemens Ladisch wrote:
Chris Boot wrote:
You can pull the code from:
git://github.com/bootc/Linux-SBP-2-Target.git

The TODO file says:
* Update Juju so we can get the speed in the fw_address_handler callback

What is the speed needed for?

"The speed at which the block write request to the MANAGEMENT_AGENT register is received shall determine the speed used by the target for all subsequent requests to read the initiatorâs configuration ROM, fetch ORBâs from initiator memory or store status at the initiatorâs status_FIFO. Command block ORBâs separately specify the speed for requests addressed to the data buffer or page table."

(T10/1155D Revision 4 page 53/54)

SBP-2 says:
| The target shall issue data transfer requests with a speed equal to
| that specified by the spd field in the ORB.

SBP-3 says:
| The target shall issue data transfer requests with a speed equal to
| that specified by the controlling spd field, whether in the ORB or in
| a node selector in an associated page table.

Please note that you can't then disable a unit until all the targets
are logged-out. For Linux this usually means 'rmmod firewire_sbp2'.

That driver should not, by default, log into targets on its own node.

It still tries to and never appears to give up, so this needs blacklisting on the target system until firewire_sbp2 is changed. It's harmless other than filling up the kernel log with error messages.

What I meant, however, is if you connect to the target from a separate Linux system you will be unable to disable the unit on the target system until the _initiator_ logs out. You can do this on the initiator by unloading the module, which sends a logout request to the target.

HTH,
Chris

--
Chris Boot
bootc@xxxxxxxxx
--
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/