Page MenuHomeFreeBSD

iscsi: Handle large Text responses.
ClosedPublic

Authored by jhb on Dec 17 2021, 8:59 PM.
Tags
None
Referenced Files
F107315656: D33548.id100239.diff
Sun, Jan 12, 10:26 AM
Unknown Object (File)
Mon, Dec 30, 12:17 PM
Unknown Object (File)
Mon, Dec 23, 7:55 AM
Unknown Object (File)
Thu, Dec 19, 6:39 AM
Unknown Object (File)
Dec 11 2024, 9:38 PM
Unknown Object (File)
Dec 10 2024, 9:31 PM
Unknown Object (File)
Dec 2 2024, 4:01 PM
Unknown Object (File)
Nov 28 2024, 9:39 PM
Subscribers

Details

Summary

Text requests and responses can span multiple PDUs. In that case,
the sender sets the Continue bit in non-final PDUs and the Final
bit in the last PDU. The receiver responds to non-final PDUs with
an empty text PDU.

To support this, add a more abstract API in libiscsi which accepts
and receives key sets rather than PDUs. These routines internally
send or receive one or more PDUs. Use these new functions to replace
the handling of TextRequest and TextResponse PDUs in discovery sessions
in both ctld and iscsid.

Note that there is not currently a use case for large Text requests
and those are still always sent as a single PDU. However, discovery
sessions can return a text response listing targets that spans
multiple PDUs, so the new API supports sending and receiving multi-PDU
responses.

Reported by: Jithesh Arakkan @ Chelsio
Sponsored by: Chelsio Communications

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

jhb requested review of this revision.Dec 17 2021, 8:59 PM

I may be wrong, but I have some suspicions about the protocol.

lib/libiscsi/text.c
213 ↗(On Diff #100239)

RFC tells in 11.11.1:

A Text Response with the
F bit set to 1 in response to a Text Request with the F bit set to 0
is a protocol error.
302 ↗(On Diff #100239)

As I read RFC, 0xffffffff should be there only on the first request, but if there is more than one, later should reflect back value sent by the target. In 11.10.4:

The target sets the Target Transfer Tag in a Text Response to a value
other than the reserved value 0xffffffff whenever it indicates that
it has more data to send or more operations to perform that are
associated with the specified Initiator Task Tag.  It MUST do so
whenever it sets the F bit to 0 in the response.  By copying the
Target Transfer Tag from the response to the next Text Request, the
initiator tells the target to continue the operation for the specific
Initiator Task Tag.
327 ↗(On Diff #100239)

And respectively it should not be 0xffffffff here and it should not be final, since we'll still respond.

354 ↗(On Diff #100239)

I think here should be the same ttt as we possibly selected in text_read_request().

lib/libiscsi/text.c
213 ↗(On Diff #100239)

Hmm, I may just remove support for large requests then. Linux only supports large responses (and it is all I need in my use case of using cxgbei with small PDU sizes and a lot of targets). The explicit example of a large response in 11.10.4 is this:

Long Text Responses are handled as shown in the following example:

      I->T Text SendTargets=All (F = 1, TTT = 0xffffffff)

      T->I Text <part 1> (F = 0, TTT = 0x12345678)

      I->T Text <empty> (F = 1, TTT = 0x12345678)

      T->I Text <part 2> (F = 0, TTT = 0x12345678)

      I->T Text <empty> (F = 1, TTT = 0x12345678)

      ...

      T->I Text <part n> (F = 1, TTT = 0xffffffff)
302 ↗(On Diff #100239)

This is due to my trying to infer how to handle large requests (vs large responses). I may just remove the large request support since I don't have an easy way to test it anyway as noted above. Same applies below.

  • Drop support for Text Requests that span PDUs.
This revision is now accepted and ready to land.Dec 29 2021, 4:15 PM
jhb retitled this revision from iscsi: Handle large Text requests. to iscsi: Handle large Text responses..Dec 29 2021, 10:31 PM
jhb edited the summary of this revision. (Show Details)
This revision was automatically updated to reflect the committed changes.