RE: [Ips] iSCSI: Correct value for ExpDataSN for bidirectional commands

Julian Satran <Julian_Satran@il.ibm.com> Tue, 03 February 2004 07:06 UTC

Received: from optimus.ietf.org (optimus.ietf.org [132.151.1.19]) by ietf.org (8.9.1a/8.9.1a) with ESMTP id CAA19279 for <ips-archive@odin.ietf.org>; Tue, 3 Feb 2004 02:06:44 -0500 (EST)
Received: from localhost.localdomain ([127.0.0.1] helo=www1.ietf.org) by optimus.ietf.org with esmtp (Exim 4.20) id 1AnudT-0001C9-HZ for ips-archive@odin.ietf.org; Tue, 03 Feb 2004 02:06:15 -0500
Received: (from exim@localhost) by www1.ietf.org (8.12.8/8.12.8/Submit) id i1376Fim004587 for ips-archive@odin.ietf.org; Tue, 3 Feb 2004 02:06:15 -0500
Received: from odin.ietf.org ([132.151.1.176] helo=ietf.org) by optimus.ietf.org with esmtp (Exim 4.20) id 1AnudT-0001Bq-4F for ips-web-archive@optimus.ietf.org; Tue, 03 Feb 2004 02:06:15 -0500
Received: from ietf-mx (ietf-mx.ietf.org [132.151.6.1]) by ietf.org (8.9.1a/8.9.1a) with ESMTP id CAA18667 for <ips-web-archive@ietf.org>; Tue, 3 Feb 2004 02:06:12 -0500 (EST)
Received: from ietf-mx ([132.151.6.1]) by ietf-mx with esmtp (Exim 4.12) id 1AnudP-0000XQ-00 for ips-web-archive@ietf.org; Tue, 03 Feb 2004 02:06:11 -0500
Received: from exim by ietf-mx with spam-scanned (Exim 4.12) id 1AnucU-0000SS-00 for ips-web-archive@ietf.org; Tue, 03 Feb 2004 02:05:15 -0500
Received: from optimus.ietf.org ([132.151.1.19]) by ietf-mx with esmtp (Exim 4.12) id 1AnucJ-0000NO-00 for ips-web-archive@ietf.org; Tue, 03 Feb 2004 02:05:03 -0500
Received: from localhost.localdomain ([127.0.0.1] helo=www1.ietf.org) by optimus.ietf.org with esmtp (Exim 4.20) id 1AnucI-0000T7-QJ; Tue, 03 Feb 2004 02:05:02 -0500
Received: from odin.ietf.org ([132.151.1.176] helo=ietf.org) by optimus.ietf.org with esmtp (Exim 4.20) id 1AnubW-00009n-Kr for ips@optimus.ietf.org; Tue, 03 Feb 2004 02:04:14 -0500
Received: from ietf-mx (ietf-mx.ietf.org [132.151.6.1]) by ietf.org (8.9.1a/8.9.1a) with ESMTP id CAA16484 for <ips@ietf.org>; Tue, 3 Feb 2004 02:04:12 -0500 (EST)
Received: from ietf-mx ([132.151.6.1]) by ietf-mx with esmtp (Exim 4.12) id 1AnubT-0000Mf-00 for ips@ietf.org; Tue, 03 Feb 2004 02:04:11 -0500
Received: from exim by ietf-mx with spam-scanned (Exim 4.12) id 1AnuaX-0000Gy-00 for ips@ietf.org; Tue, 03 Feb 2004 02:03:14 -0500
Received: from mtagate6.uk.ibm.com ([195.212.29.139]) by ietf-mx with esmtp (Exim 4.12) id 1Anua2-0000AP-00 for ips@ietf.org; Tue, 03 Feb 2004 02:02:42 -0500
Received: from d06nrmr1307.portsmouth.uk.ibm.com (d06nrmr1307.portsmouth.uk.ibm.com [9.149.38.129]) by mtagate6.uk.ibm.com (8.12.10/8.12.10) with ESMTP id i13728ZP107132; Tue, 3 Feb 2004 07:02:08 GMT
Received: from d10ml001.telaviv.ibm.com (d06av02.portsmouth.uk.ibm.com [9.149.37.228]) by d06nrmr1307.portsmouth.uk.ibm.com (8.12.10/NCO/VER6.6) with ESMTP id i13726xE093070; Tue, 3 Feb 2004 07:02:07 GMT
In-Reply-To: <CA56AF7C40BC6540BA471AD2CC8F305709C5FF@wcosmb02.cos.agilent.com>
To: pat_thaler@agilent.com
Cc: cbm@rose.hp.com, ips@ietf.org, ips-admin@ietf.org, wrstuden@wasabisystems.com
MIME-Version: 1.0
Subject: RE: [Ips] iSCSI: Correct value for ExpDataSN for bidirectional commands
X-Mailer: Lotus Notes Release 6.5 September 26, 2003
From: Julian Satran <Julian_Satran@il.ibm.com>
Message-ID: <OF45F1488F.042D3645-ONC2256E2F.00259C60-C2256E2F.0026A518@il.ibm.com>
Date: Tue, 03 Feb 2004 09:02:00 +0200
X-MIMETrack: Serialize by Router on D10ML001/10/M/IBM(Release 6.0.2CF2|July 23, 2003) at 03/02/2004 09:02:01, Serialize complete at 03/02/2004 09:02:01
Content-Type: text/plain; charset="US-ASCII"
Sender: ips-admin@ietf.org
Errors-To: ips-admin@ietf.org
X-BeenThere: ips@ietf.org
X-Mailman-Version: 2.0.12
Precedence: bulk
List-Unsubscribe: <https://www1.ietf.org/mailman/listinfo/ips>, <mailto:ips-request@ietf.org?subject=unsubscribe>
List-Id: IP Storage <ips.ietf.org>
List-Post: <mailto:ips@ietf.org>
List-Help: <mailto:ips-request@ietf.org?subject=help>
List-Subscribe: <https://www1.ietf.org/mailman/listinfo/ips>, <mailto:ips-request@ietf.org?subject=subscribe>
X-Spam-Checker-Version: SpamAssassin 2.60 (1.212-2003-09-23-exp) on ietf-mx.ietf.org
X-Spam-Status: No, hits=0.1 required=5.0 tests=AWL autolearn=no version=2.60

Pat,

Regardless of the name - the two types of PDUs share the same space and if 
one is missing it has to be recovered.
The target knows exactly what each one was and the initiator asks for both 
the same way.
I don't see a point in changing something that is not broken. 

Regards,
Julo



<pat_thaler@agilent.com> 
02/02/2004 19:51

To
Julian Satran/Haifa/IBM@IBMIL
cc
<cbm@rose.hp.com>, <ips@ietf.org>, <ips-admin@ietf.org>, 
<wrstuden@wasabisystems.com>
Subject
RE: [Ips] iSCSI: Correct value for ExpDataSN for bidirectional commands






If we really believe that the change would be overly painful for current 
and in development implementations, I would prefer a change to make R2TSN 
and DataSN independent for bidirectional commands. The logic:

Bidirectional commands already need extra context so carrying an extra SN 
variable is a very small burden to them.

It is poor form to have one variable that is sitting under two names. It 
creates confusion and is likely to cause interoperability problems in the 
future. 

Therefore, it is worth the burden of carrying an extra value in 
bidirectional command context to forstall interoperability problems.

Regards,
Pat

-----Original Message-----
From: Julian Satran [mailto:Julian_Satran@il.ibm.com]
Sent: Friday, January 30, 2004 3:57 AM
To: THALER,PAT (A-Roseville,ex1)
Cc: cbm@rose.hp.com; ips@ietf.org; ips-admin@ietf.org;
wrstuden@wasabisystems.com
Subject: RE: [Ips] iSCSI: Correct value for ExpDataSN for bidirectional
commands


Will fix the example (thanks Pat and perhaps add the text you suggested). 
For pratical purposes it should be noted that the only SCSI device that 
plans to use bidirectional data transfers to-date has different phases for 

input and output so that block are no mixed.

However I assumed always that the space is shared and that data placement 
is unaffected by the order of PDU's . The SNACK identifies unambiguously 
to the target what is missing and the initiator has to know only that 
something is missing in order to start a recovery action.

Other than the example the spec is fine.

ips-admin@ietf.org wrote on 30/01/2004 03:25:58:

> I also don't think the current spec is clear and I think the 
> combination of the behavior described in 10.4.8 and that described in 
> 3.2.2 is broken for bidirectional commands. The reason for reporting 
> ExpDataSN in the SCSI Response is to allow the initiator to check that
> it received all the Data-In PDUs associated with the command and to 
> send a SNACK if it didn't.
> 
> For example, one could have the following in response to a 
> bidirectional command:
> 
> DataSN     PDU
> 0   1st Data-In
> 1   1st R2T
> 2   2nd R2T
> 3   2nd Data-In
> 4   3rd Data-In
> 5   4th Data-In
> 6   3rd R2T
> 
> If the ExpDataSN to be reported in the SCSI Response was truly the 
> number of Data-In PDUs as 10.4.8 says, its value would be 4. Note that
> the above is consistent with the text of 3.2.2.3 which says that 
> DataSN and R2TSN for bidirectional commands form one continuous 
> undifferentiated series but it is not consistent with the example in 
> B.3. The example shows a PDU with R2TSN = 0 followed by a PDU with 
DataSN = 0.
> 
> This is broken because the initiator could not compare the value 
> received in ExpDataSN to its copy of ExpDataSN to determine whether it
> had gotten all the Data-In PDUs. If the behavior in 10.4.8 is 
> maintained, an initiator will have to keep a count of the Data-In PDUs
> it has received for bidirectional commands in addition to keeping the 
> ExpDataSN value. The target would also have to keep two separate 
> counters during processing of bidirectional commands (both named 
> ExpDataSN by the draft) - one of how many Data-In PDUs it has sent so 
> it can put it in the Response and one of the value of ExpDataSN 
> indicating the DataSN to put in the next Data-In or R2T PDU it sends 
> for the command.
> 
> There is no reason to define the protocol such that keeping two values
> is necessary here. It appears that the reason to say that DataSN and 
> R2TSN form one sequence for bidirectional commands is to allow the 
> command to maintain one count for DataIn and R2T PDUs rather than 
> having two counters. If we were willing to forgo that optimization, 
> then DataSN and R2TSN should have been kept separate. 
> 
> In any case, it is incorrect to have two variables for the same 
> context with the same name.
> 
> One can correct the problem by changing 10.4.8 to say that for 
> bidirectional commands ExpDataSN is the number of DataIn and R2T PDUs 
> that were sent, then one can maintain one value. One should also 
> correct the example in B.3.
> 
> One could also correct the problem by changing 3.2.2 so that DataSN 
> was kept separate from R2TSN in bidirectional commands. In some 
> senses, this would have been cleaner because it avoids having one 
> variable with two names but it would require more context per command 
> and it is probably a bigger change for existing implementations.
> 
> The code in E.2.2 seems ambiguous - it just says if (expDataSN does 
> not match) but it doesn't define what is considered a match. Neither 
> the target code nor the initiator code in E.2 seems to address how the
> value of ExpDataSN for response PDUs and the compare to response PDUs 
> is derived. Therefore it would be consistent with either choice.
> 
> Regards,
> Pat
> 
> -----Original Message-----
> From: ips-admin@ietf.org [mailto:ips-admin@ietf.org]On Behalf Of
> wrstuden@wasabisystems.com
> Sent: Thursday, January 29, 2004 2:46 PM
> To: Mallikarjun C.
> Cc: ips@ietf.org
> Subject: Re: [Ips] iSCSI: Correct value for ExpDataSN for bidirectional
> commands
> 
> 
> On Thu, 29 Jan 2004, Mallikarjun C. wrote:
> 
> > Not sure why the initiator needs to be reported on the
> > total # of R2Ts in the final response....I presume
> > any mismatch in R2Ts is already factored into the status.
> >
> > _If_ we indeed want to include R2Ts, I think it would be
> > necessary to make changes (10.4.8, E.2.2, and perhaps 6)
> > because I believe the current spec semantics are clear
> > that R2Ts are not included.
> 
> While I'll be honest that I don't understand _why_ R2Ts are factored 
into
> the DataSN space along with Data-In PDUs, I've understood they were
> comingled for over a year. I think it was about 16 months ago I asked
> about this (before draft 20), and Julian explained that they shared the
> same space.
> 
> So I don't think it's supposed to be something new.
> 
> Take care,
> 
> Bill
> 
> _______________________________________________
> Ips mailing list
> Ips@ietf.org
> https://www1.ietf.org/mailman/listinfo/ips
> 
> 
> _______________________________________________
> Ips mailing list
> Ips@ietf.org
> https://www1.ietf.org/mailman/listinfo/ips




_______________________________________________
Ips mailing list
Ips@ietf.org
https://www1.ietf.org/mailman/listinfo/ips