SORT BY:

LIST ORDER
THREAD
AUTHOR
SUBJECT


SEARCH

IPS HOME


    [Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

    iSCSI - positive data ack - change proposal


    • To: ips@ece.cmu.edu
    • Subject: iSCSI - positive data ack - change proposal
    • From: "Julian Satran" <Julian_Satran@il.ibm.com>
    • Date: Sat, 22 Sep 2001 14:04:34 +0300
    • Content-Disposition: inline
    • Content-type: multipart/mixed; Boundary="0__=C2256ACF003C6AE38f9e8a93df938690918cC2256ACF003C6AE3"
    • Sender: owner-ips@ece.cmu.edu

    Dear colleagues,
    
    As  I mentioned earlier all the elements needed for positive data-ack are
    already in place.
    
    I am suggesting the following changes to the document to reintroduce the
    data-ACK.
    
    Comments?
    
    Julo
    (See attached file: ack.txt)
    Within 2.2.2.3
    ---------------
    
    Initiators MAY also acknowledge received data and reduce by this the resources a target needs to dedicate to data recovery if target and initiator support this type of recovery.
    
    
    ------
    3.7.1 F (Final) Bit
    
    For outgoing data, this bit is 1 for the last PDU of unsolicited data or the last PDU of a sequence answering an R2T.
    
    For incoming data, this bit is 1 for the last input (read) data PDU of a sequence.  Input can be split in several sequences each one having it's own F bit. Splitting in sequences does not affect DataSN counting on Data-In PDUs but MAY be used as a "change direction" indication for Bidirectional operations that need such a change and/or end of recoverable sequences by targets with a limited retransmission buffer.  Upon receiving an Data-In PDU with the F set to 1 and the S bit 0 in a session with ErrorRecoveryLevel 1 or higher the initiator MUST issue a DataACK type of SNACK indicating the next expected DataSN for this task.
    
    For Bidirectional operations, the F bit is 1 both for the end of the input sequences as well as the end of the output sequences. 
    
     
    -----------
    
    3.16  SNACK Request
    
    
    Byte /    0       |       1       |       2       |       3       |
       /              |               |               |               |
      |7 6 5 4 3 2 1 0|7 6 5 4 3 2 1 0|7 6 5 4 3 2 1 0|7 6 5 4 3 2 1 0|
      +---------------+---------------+---------------+---------------+
     0|0|1| 0x10      |1|Rsrvd| Type  | Reserved                      |
      +---------------+---------------+---------------+---------------+
     4/ Reserved                                                      /
     +/                                                               /
      +---------------+---------------+---------------+---------------+
    16| Initiator Task Tag or 0xffffffff                              |
      +---------------+---------------+---------------+---------------+
    20| BegRun                                                        |
      +---------------+---------------+---------------+---------------+
    24| RunLength                                                     |
      +---------------+---------------+---------------+---------------+
    28| ExpStatSN                                                     |
      +---------------+---------------+---------------+---------------+
    32| Reserved                                                      |
      +---------------+---------------+---------------+---------------+
    36| ExpDataSN or Reserved                                         |
      +---------------+---------------+---------------+---------------+
    32/ Reserved                                                      /
     +/                                                               /
      +---------------+---------------+---------------+---------------+
    48
    
    Support for SNACK is optional.
    
    SNACK request is used to request retransmission of numbered-responses, data or R2T PDUs from the target.  The SNACK request indicates to the target the missed numbered-response or data run, where the run is composed of an initial missed StatSN, DataSN or R2TSN and the number of additional missed Status, Data or R2T PDUs (0 means only the initial).
    
    The numbered-response, Data or R2T PDUs requested by a SNACK have to be delivered as exact replicas of the ones the initiator missed including all its flags. 
    
    Any SNACK requesting a numbered-response, Data or R2T that was not sent by the target MUST be rejected with a reason code of "Invalid SNACK".
    
    SNACK is also used to positively acknowledge Data-In PDUs.
    
    3.16.1 Type
    
    This field encodes the SNACK function as follows:
    
    0-Data/R2T SNACK - requesting retransmission of a Data-In or R2T PDU
    1-Status SNACK - requesting retransmission of a numbered response
    2-DataACK - positively acknowledges Data-In PDUs 
    
    All other values are reserved.
    
    Data/R2T SNACK for a command MUST precede status acknowledgement for the given command.
    
    For a Data/R2T SNACK or a DataACK, the Initiator Task Tag MUST be set to the Initiator Task Tag of the referenced Command. Otherwise, it is reserved.
    
    For a Status SNACK the ExpDataSN field is reserved.
    
    An iSCSI target that does not support recovery within connection MAY discard status SNACK. If the target supports command recovery within session it MAY discard the SNACK after which it MUST issue an Asynchronous Message PDU with an iSCSI event indicating "Request Logout".
    
    If an initiator operates at ErrorRecoveryLevel 1 or higher it MUST issue a SNACK of type DataACK after receiving a Data-In PDU with the F bit set to 1 and the S bit 0.
    
    3.16.2 BegRun
    
    First missed DataSN, R2TSN or StatSN
    
    3.16.3 RunLength
    
    RunLength is the number of sequential missed DataSN, R2TSN or StatSN. RunLength 0 signals that all Data-In, R2T or Response PDUs carrying numbers equal or greater to BegRun have to be resent.
    
    
    


Home

Last updated: Sat Sep 22 22:17:33 2001
6679 messages in chronological order