Re: [storm] FW: iSER - one last issue: update

Alexander Nezhinsky <nezhinsky@gmail.com> Sun, 04 March 2012 20:05 UTC

Return-Path: <nezhinsky@gmail.com>
X-Original-To: storm@ietfa.amsl.com
Delivered-To: storm@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 03FC621F851C for <storm@ietfa.amsl.com>; Sun, 4 Mar 2012 12:05:15 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -0.998
X-Spam-Level:
X-Spam-Status: No, score=-0.998 tagged_above=-999 required=5 tests=[BAYES_50=0.001, HTML_MESSAGE=0.001, RCVD_IN_DNSWL_LOW=-1]
Received: from mail.ietf.org ([12.22.58.30]) by localhost (ietfa.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id zCGZz6js9TPY for <storm@ietfa.amsl.com>; Sun, 4 Mar 2012 12:05:11 -0800 (PST)
Received: from mail-iy0-f172.google.com (mail-iy0-f172.google.com [209.85.210.172]) by ietfa.amsl.com (Postfix) with ESMTP id 23BAA21F851A for <storm@ietf.org>; Sun, 4 Mar 2012 12:05:11 -0800 (PST)
Received: by iazz13 with SMTP id z13so5445216iaz.31 for <storm@ietf.org>; Sun, 04 Mar 2012 12:05:10 -0800 (PST)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=mime-version:in-reply-to:references:date:message-id:subject:from:to :content-type; bh=DeO3U1O1X+wOWSXbiZxQ9MmZRb5AqJMiZev2DIwqFe0=; b=CPbvAfyZIZLytGMvMM7VGiosWyCnnqSoSdspSJvERmP2yXw1MsvtVxAOGmEGB46dpQ qDdLB+GIZ1BBUIP1Nwlm8w4vADcbbDG6QGKmjztLBN3Hxg21teaINvU0Xrib+gOCTXNC MQbdu4zzHHRzeIcuAE2p90aYpmDEc8HGDWj6XzoRVpzD+5+gDjH7+aC4zeuf2Zhj8Ld9 Uuwj6PgWWir2ZV5zhAqipDCsfpDxueWvjd1KTfpC08FylOT3IqAzgr1DASo3FzDUZs0P u8TgWIn1QGmy+stHkzEvMnrNpboY57r9YPQ/czyhDEz5pXJy4y65bHutQJn7KfBQGTkP m8DQ==
MIME-Version: 1.0
Received: by 10.50.158.133 with SMTP id wu5mr3852637igb.50.1330891510695; Sun, 04 Mar 2012 12:05:10 -0800 (PST)
Received: by 10.231.203.2 with HTTP; Sun, 4 Mar 2012 12:05:10 -0800 (PST)
In-Reply-To: <F83812DF4B59B9499C1BC978336D917461D05460@TK5EX14MBXC111.redmond.corp.microsoft.com>
References: <C5469CD4B2AA4C72B6A47B28FD2E0690@china.huawei.com> <F83812DF4B59B9499C1BC978336D917461CDEBCF@TK5EX14MBXC118.redmond.corp.microsoft.com> <7C4DFCE962635144B8FAE8CA11D0BF1E05A7D9137A@MX14A.corp.emc.com> <F83812DF4B59B9499C1BC978336D917461CF96F4@TK5EX14MBXC111.redmond.corp.microsoft.com> <SNT106-DS16487B5F5F81DCE5FE5F4FA0880@phx.gbl> <7C4DFCE962635144B8FAE8CA11D0BF1E05A7D91649@MX14A.corp.emc.com> <F83812DF4B59B9499C1BC978336D917461CFBEF1@TK5EX14MBXC111.redmond.corp.microsoft.com> <2D98DD3F898B6B4DA287BF3BA07DAE93029056@IRVEXCHMB11.corp.ad.broadcom.com> <F83812DF4B59B9499C1BC978336D917461D05460@TK5EX14MBXC111.redmond.corp.microsoft.com>
Date: Sun, 04 Mar 2012 22:05:10 +0200
Message-ID: <CAEkHY=c=Cu5t0=z5qk1AUAybaVSvvigFx016c0ch2MTV1YUxag@mail.gmail.com>
From: Alexander Nezhinsky <nezhinsky@gmail.com>
To: storm@ietf.org, david.black@emc.com, cbm@chadalapaka.com, hemal@broadcom.com, Mike Ko <Michael@huaweisymantec.com>, Tom Talpey <ttalpey@microsoft.com>
Content-Type: multipart/alternative; boundary="14dae9341103bac84804ba705338"
Subject: Re: [storm] FW: iSER - one last issue: update
X-BeenThere: storm@ietf.org
X-Mailman-Version: 2.1.12
Precedence: list
List-Id: Storage Maintenance WG <storm.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/storm>, <mailto:storm-request@ietf.org?subject=unsubscribe>
List-Archive: <http://www.ietf.org/mail-archive/web/storm>
List-Post: <mailto:storm@ietf.org>
List-Help: <mailto:storm-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/storm>, <mailto:storm-request@ietf.org?subject=subscribe>
X-List-Received-Date: Sun, 04 Mar 2012 20:05:15 -0000

Hi

Back after being virtually absent from the list for quite a time
(unfortunately)...

I've read the last discussion on iSER and tried to summarize my experience
and the current viewpoint here. But anyway, i'm hardly representing "the"
IB community :)

First of all the current implementation of iSER (which is in Linux,
comprising a low-level scsi kernel module on the initiator side and
user-space plug-in to STGT target) does not use SendSE / SendInvalidate /
SendInvalidateSE, on either side.

Neither initiator nor target require this functionality for the correct
operation and, to my opinion, they would hardly ever require it. I'll try
to explain my reasoning.

If I understand correctly, the main rationale behind using SendSE is to try
to decrease the number of times interrupts are armed on the hardware level.
Let's see how interrupt arming is done in practice.

Infiniband based applications may be implemented either in kernel or in
user space. In kernel a completion notification results in an interrupt
which is served in ISR. In user space the interrupt events (at least in
linux) are delivered to the application using a file descriptor which
becomes readable. This mechanism, especially in user space (where
kernel-user interaction is added to interrupt latency), is quite
inefficient, relative to the high speeds of transfer being used.

Thus the common practice is to re-arm the notifications only after a period
of absence of completions and to drain the CQ repetitively after receiving
such notification using poll_cq mechanism, for as long as possible. In
protocols like iSER under heavy load conditions it is possible to receive
most of the completions without ever arming an interrupt at least during
the bursts of traffic. In the extreme cases some applications may decide to
work exclusively in polling mode to ensure minimal latency and increase
throughput when the packets are expected to be small.

Thus the target implementations would almost uniformly rely on a mix of
interrupt-driven notifications and CQ polling. So the initiator software
has no way to know if the target will ever request notifications for
solicited events only. Moreover it can safely bet on a target not using it
or not relying on it. Initiators, usually being more "general-purpose"
would use polling less aggressively, but i believe they will also tend to
employ some "arm/poll/re-arm" scheme which does not depend on SendSE to
ensure correctness.

Another concern here is the utility of SendSE in iWarp and, if any, its
relevance to Infiniband settings. The only case where SendSE is used with
iWarp is Unsolicied Data-OUTs, in cases when more than a single Data-OUT
PDU is sent. By the way, this means that the initiators don't rely on
SendSE at all, doesn't it?

The current iSER target implementation opts for Solicited-only mode of
operation, refusing to accept Unsolicited Data-OUTs through negotiation.
This was done initially because of certain technical limitations of STGT
design, but a few experiments have shown that relying upon Unsolicited
Data-OUTs for small data sizes does not improve performance and that mixing
Unsolicited and Solicited Data-OUTs sometimes even decreases it (I can put
forward some theories about why this happens, if anybody is interested, i
can share with you in a separate mail). This is only an unreliable
observation coming from a single implementation but I guess that even when
Unsolicited data is enabled, it is unwise to use many small Data-OUTs. This
will lead to unnecessary overhead in processing interrupts, completions and
protocol packet headers. Thus using only immediate data or a single
relatively large Data-OUT (by setting FirstBurstLength =
MaxRecvDataSegmentLength) is always preferred, performance-wise.

To summarize, those very scenarios that justified using SendSE in iWarp
design are grossly irrelevant to the reality of the implementations based
on Infiniband. And, to tell the truth, I can't see why iWarp setup should
be significantly different from Infiniband one in this aspect.

I don't know much about TCA types and unaware of other applications to
inform, but if my previous arguments are acceptable, these questions are
less relevant.

Now, regarding SendInvalidate. I think that being unable to use it with
bidirectional commands alone makes this quite impractical even in iWarp.
Coupled with Mike's observation that iSER layer is required to check
invalidation anyway, makes the requirement to use SendInvalidate quite
strange, unless there are some implicit reasons, which i am unaware of. In
this case those reasons are better made explicit.


Alexander.


On Mon, Jan 30, 2012 at 3:53 PM, Tom Talpey <ttalpey@microsoft.com> wrote:

>  Alexander, have you been watching the IETF/STORM discussion on iSER?
> There is a critical issue on the table which requires input from Infiniband
> iSER implementors.****
>
> ** **
>
> iSER is considering maintaining the RFC5046 requirement that the use of
> SendSE and SendInvSE be mandatory for certain target sends, however the IB
> spec does not require all TCAs to implement these operations. We seek to
> know if:****
>
> **1)      **The IB community agrees or disagrees with this****
>
> **2)      **Whether any IB/iSER initiator implementations require
> receiving solicited events for correct operation (i.e. do they arm for
> solicited or all?)****
>
> **3)      **Whether there are in fact any relevant TCAs which fail to
> support solicited events****
>
> **4)      **What other implementations we may need to inform of this
> issue.****
>
> ** **
>
> You should make your opinion known to the list, so we may advance the
> specification.****
>
> ** **
>
> *From:* Hemal Shah [mailto:hemal@broadcom.com]
> *Sent:* Wednesday, January 25, 2012 6:48 PM
> *To:* Tom Talpey; david.black@emc.com; cbm@chadalapaka.com; storm@ietf.org
>
> *Subject:* RE: [storm] iSER - one last issue: update****
>
>  ** **
>
> *I think we should investigate [3c]. From the consistency standpoint,
> [3c] makes iSER consistent across different RCaPs.*
>
> * *
>
> *Can someone from InfiniBand side comment?*
>
> * *
>
> *Hemal*
>
> * *
>
> *From:* storm-bounces@ietf.org [mailto:storm-bounces@ietf.org] *On Behalf
> Of *Tom Talpey
> *Sent:* Tuesday, January 24, 2012 7:50 PM
> *To:* david.black@emc.com; cbm@chadalapaka.com; storm@ietf.org
> *Subject:* Re: [storm] iSER - one last issue: update****
>
> ** **
>
> To take [3a], making SendSE mandatory for iWARP and mandatory-to-not for
> all others, would be very inconsistent and somewhat contradictory. For
> example, Infiniband currently runs at speeds approximately triple that of
> Ethernet, and up. Surely a performance-oriented tweak such as SendSE
> matters more for IB than iWARP, if it matters at all. And, such a decision
> makes it more difficult to design a common upper layer implementation.****
>
> ** **
>
> So, just to throw another log on this fire, [3c], I suggest we ask the
> Infiniband community whether they’re ok with SendSE/SendInvSE being a MUST
> for solicited replies exactly as specified in RFC5046. It means that for
> Infiniband, all HCAs, but only those TCAs which support solicited events,
> can be used with the protocol. And it means the sending side of the
> existing draft implementations may have to change to send them where
> required.****
>
> ** **
>
> ** **
>
> *From:* storm-bounces@ietf.org [mailto:storm-bounces@ietf.org] *On Behalf
> Of *david.black@emc.com
> *Sent:* Tuesday, January 24, 2012 7:42 PM
> *To:* cbm@chadalapaka.com; storm@ietf.org
> *Subject:* Re: [storm] iSER - one last issue: update****
>
> ** **
>
> [WG chair hat off]****
>
> ** **
>
> Proposed slight refinement: If the SendSE and SendInvSE requirements are
> applied to RCaPs that “require all implementations to support Solicited
> Events”, that set of RCaPs includes iWARP, but not InfiniBand.****
>
> ** **
>
> That refinement creates a need to figure out the complementary requirement
> that applies to InfiniBand, which Tom more or less asked about earlier in
> this thread:****
>
> ** **
>
> > If using SendSE is so important here, when MUST a plain-old Send be
> used?****
>
> ** **
>
> There are at least a couple of approaches to this one:****
>
> ** **
>
> [3a] SendSE/SendInvSE MUST NOT be used with other RCaPs.****
>
> ** **
>
> [3b] Explain how a sender figures out whether to use SendSE/SendInvSE or
> not (aka “negotiation”).****
>
> ** **
>
> [3a] would be the simplest.  The “running code” matters here - does the IB
> implementation of iSER use SendSE/SendInvSE?  If not, [3a] should be fine.
> ****
>
> ** **
>
> Thanks,
> --David****
>
> ** **
>
> *From:* Mallikarjun Chadalapaka [mailto:cbm@chadalapaka.com]
> *Sent:* Tuesday, January 24, 2012 7:25 PM
> *To:* Tom Talpey; Black, David; storm@ietf.org
> *Subject:* RE: [storm] iSER - one last issue: update****
>
> ** **
>
> I think we should go with [1] and [2a] that David outlined.  As Hemal
> said, there were good reasons why RFC 5046 stipulated SendInvSE and SendSE,
> where it did.  I would rather not weaken it, at least for the iWARP RCaP
> ecosystem.****
>
> ** **
>
> Mallikarjun****
>
> ** **
>
> ** **
>
> *From:* storm-bounces@ietf.org [mailto:storm-bounces@ietf.org] *On Behalf
> Of *Tom Talpey
> *Sent:* Tuesday, January 24, 2012 5:49 AM
> *To:* david.black@emc.com; storm@ietf.org
> *Subject:* Re: [storm] iSER - one last issue: update****
>
> ** **
>
> [WG co-chair hat off]****
>
> ** **
>
> > [2a] Leave things alone - if the RCaP supports Solicited Events, then
> the “MUST”****
>
> > requirements for SendSE and SendInvSE apply as they did in RFC 5046.****
>
> ** **
>
> The core issue here is the statement “if the RCaP supports Solicited
> Events”. Both the iWARP and Infiniband protocols support them. But
> Infiniband does not require all adapters support them – the architecture
> requires it for HCAs but leaves it optional for TCAs (Infiniband
> architecture v1.2.1 table 319 on page 1045). Because this latter property
> cannot be detected by the remote upper layer, it does not appear to be
> possible to make an interoperable decision for all protocols and all
> implementations.****
>
> ** **
>
> That said, in the absence of any existing iSER-over-iWARP SendSE
> implementations, I agree the entire discussion is effectively moot.****
>
> ** **
>
> Tom.****
>
> ** **
>
> *From:* storm-bounces@ietf.org [mailto:storm-bounces@ietf.org] *On Behalf
> Of *david.black@emc.com
> *Sent:* Monday, January 23, 2012 8:05 PM
> *To:* storm@ietf.org
> *Subject:* [storm] iSER - one last issue: update****
>
> ** **
>
> [WG chair hat off]****
>
> ** **
>
> This is a message intended for discussion and comments.****
>
> ** **
>
> Looking for a way forward, this observation from Mike seems like a useful
> place to start:****
>
> ** **
>
> > This iSER update is meant to reflect running code and to generalize the
> support of iSER over any RCaP, not just iWARP. ****
>
> ** **
>
> RFC 5046 (iSER) was written on the assumption that the RCaP layer supports
> Solicited****
>
> Event functionality.  I also read RFC 5040 as requiring RDMAP
> implementations (part of****
>
> iWARP) to support Solicited Event functionality.****
>
> ** **
>
> This first step seems easy:****
>
> ** **
>
> [1] There are RCaPs that don’t support Solicited Event functionality;
> those RCaPs have****
>
> no choice - they MUST use Send (not SendSE) and SendInv (not SendInvSE).
> ****
>
>
> ****
>
> I would prefer to write iSER requirements in terms of whether the RCaP
> supports****
>
> Solicited Event functionality as opposed to calling out iWARP explicitly
> as having****
>
> different requirements.  OTOH, I’m prepared to listen to arguments to the
> contrary.****
>
> ** **
>
> Beyond that, I think there are two primary choices:****
>
> ** **
>
> [2a] Leave things alone - if the RCaP supports Solicited Events, then the
> “MUST”****
>
> requirements for SendSE and SendInvSE apply as they did in RFC 5046.****
>
> ** **
>
> [2b] In the alternative, if there are iSER implementations for iWARP that
> aren’t using****
>
> SendSE and SendInvSE in accordance with RFC 5046’s requirements, then we
> need to change****
>
> those requirements to match the implementations.****
>
> ** **
>
> I would hope we can agree on [1], and I believe that’ll cover the
> InfiniBand case, right?****
>
> ** **
>
> For choosing between [2a] and [2b] it would help a lot to konw what iSER
> over iWARP****
>
> implementations are actually doing (SendSE/SendInvSE vs. Send/SendInv).***
> *
>
> ** **
>
> *** Who is familiar with the iSER over iWARP implementation(s) ??? *******
>
> ** **
>
> In general, what do folks think ought to be done here - [2a], [2b] or
> something else?****
>
> ** **
>
> [WG chair hat on]****
>
> ** **
>
> We do need to resolve this issue and reflect that resolution in a -09 iSER
> draft before****
>
> RFC publication can be requested.****
>
> ** **
>
> Thanks,
> --David****
>
> ** **
>
> *From:* Tom Talpey [mailto:ttalpey@microsoft.com]
> *Sent:* Thursday, January 19, 2012 3:33 PM
> *To:* Michael Ko; Hemal Shah; Black, David; storm@ietf.org
> *Subject:* RE: iSER - one last issue****
>
> ** **
>
> More precisely, are there any iSER **initiators** that **depend** on
> receiving solicited events over the iWARP RDMA transport? I believe this to
> be a very short list, if any. But I’d be ok with being proven wrong.****
>
> ** **
>
> ** **
>
> ** **
>
> *From:* Michael Ko [mailto:Michael@huaweisymantec.com]
> *Sent:* Thursday, January 19, 2012 12:39 PM
> *To:* Hemal Shah; Tom Talpey; david.black@emc.com; storm@ietf.org
> *Subject:* Re: iSER - one last issue****
>
> ** **
>
> For all RCaP layers, the Send message (or any variant) MUST be used, as
> opposed to using RDMA Read or Write to accomplish the task.  So a SHOULD
> for RCaP other than iWARP is incorrect.  RFC 5040 can mandate that all
> RDMAP messages be supported, but it is still up to implementation to decide
> what messages to use in any situation.  This iSER update is meant to
> reflect running code and to generalize the support of iSER over any RCaP,
> not just iWARP.  So the question is are there any running code that uses
> SendSE and SendInvSE for iSER.  Conversely, if the running code can get by
> using Send messages to accomplish the task, what is the point of mandating
> a MUST at this point for SendSE and SendInvSE?  Note that the receiver
> cannot completely rely on the sender for the Invalidate feature
> anyway.  The iSER layer at the initiator is required to explicitly
> invalidate the STag for bidirectional commands and abnormal completion of a
> command.  Even when automatic invalidation is used, the iSER layer is
> required to sanity checking the automatic invalidation.  In other words,
> the iSER spec puts the burden on the receiver for doing the right thing in
> handling the Send messages, and not relying on the sender for the mere
> convenience. ****
>
>  ****
>
> Mike****
>
> ----- Original Message ----- ****
>
> *From:* Hemal Shah <hemal@broadcom.com> ** **
>
> *To:* Tom Talpey <ttalpey@microsoft.com> ; david.black@emc.com ;
> Michael@huaweisymantec.com ; storm@ietf.org ****
>
> *Sent:* Thursday, January 19, 2012 8:44 AM****
>
> *Subject:* RE: iSER - one last issue****
>
> ** **
>
> *Tom,*
>
> * *
>
> *You are welcome! You are right about 7.3.4 as the only section mandating
> Send message.*
>
> * *
>
> *I think your concern about specifying the requirement for the other RCaP
> implementation is valid. I suggest we should word the requirements as below:
> *
>
> * *
>
> “If the RCaP layer is as specified in [RFC5040] and [RFC5041], the SendSE
> message MUST be used. For any other RCaP layer, the Send message SHOULD be
> used. ”****
>
> ** **
>
> *Hemal*
>
> * *
>
> *From:* Tom Talpey [mailto:ttalpey@microsoft.com]
> *Sent:* Thursday, January 19, 2012 8:09 AM
> *To:* Hemal Shah; david.black@emc.com; Michael@huaweisymantec.com;
> storm@ietf.org
> *Subject:* RE: iSER - one last issue****
>
> ** **
>
> Thanks for pointing out that sentence in RFC5046 7.3.4. I believe it is
> the only such stipulation.****
>
> ** **
>
> I’m ok with stating the requirement as RFC5046-over-RFC5040 compliance.
> But this new draft opens the door to alternative behaviors, therefore it
> needs to be stated more clearly. What’s the requirement when SendSE is not
> supported? And, how does the receiver know what to expect?****
>
> ** **
>
> In other words, if it’s proposed that the statement be:****
>
>                 “When the RCaP layer is as specified in [RFC5040] and
> [RFC5041], the SendSE message MUST be used.”****
>
> ** **
>
> … then what MUST be used when the RCaP is not? That statement needs to be
> made, too.****
>
> ** **
>
> ** **
>
> *From:* Hemal Shah [mailto:hemal@broadcom.com]
> *Sent:* Thursday, January 19, 2012 10:38 AM
> *To:* Tom Talpey; david.black@emc.com; Michael@huaweisymantec.com;
> storm@ietf.org
> *Subject:* RE: iSER - one last issue****
>
> ** **
>
> *Tom,*
>
> * *
>
> *RFC5046 is very clear about the use of Send Message Type for iSCSI
> control-type PDU. For specific iSCSI PDUs, Section 7 mandates the use of
> Send, SendSE, or SendSEInv. Section 7 of RFC5046 clearly specifies the use
> of specific Send Message Type for each iSCSI control-type PDUs (Login,
> Logout, Text request, Text response…). Section 7.3.4 mandates the use of
> plain-old Send also as needed. For example, see text below from 7.3.4.*
>
> * *
>
> For unsolicited data, if the F bit is set to 0 in a SCSI Data-out****
>
> PDU, the iSER layer at the initiator MUST use a Send Message to send****
>
> the SCSI Data-out PDU.****
>
> ** **
>
> *Regarding your comment in the second paragraph below, RFC5040
> expectation is all the RDMAP messages specified in RFC5040 are supported
> (if that is not the case then we cannot count on any of the other RDMAP
> messages to be supported). So, an implementation that does not support
> SendSE at the sender is not compliant with RFC5040. So, your second point
> does not apply.*
>
> * *
>
> *I hope that addresses your comments.*
>
> * *
>
> *Hemal*
>
> * *
>
> *From:* Tom Talpey [mailto:ttalpey@microsoft.com]
> *Sent:* Thursday, January 19, 2012 5:51 AM
> *To:* Hemal Shah; david.black@emc.com; Michael@huaweisymantec.com;
> storm@ietf.org
> *Subject:* RE: iSER - one last issue****
>
> ** **
>
> If using SendSE is so important here, when MUST a plain-old Send be used?
> There is no mention of any distinction in RFC5046 section 1.4.2 nor in this
> draft’s section 2.4.2.****
>
> ** **
>
> Even with a MUST on the SendSE, the behavior is indeterminate, since it
> would still be contingent on support for SendSE at the **sender**. This
> critical exception voids any normative requirement, even over iWARP. The
> strongest statement that can be made is SHOULD.****
>
> ** **
>
> Tom.****
>
> ** **
>
> *From:* storm-bounces@ietf.org [mailto:storm-bounces@ietf.org] *On Behalf
> Of *Hemal Shah
> *Sent:* Wednesday, January 18, 2012 6:56 PM
> *To:* david.black@emc.com; Michael@huaweisymantec.com; storm@ietf.org
> *Subject:* Re: [storm] iSER - one last issue****
>
> ** **
>
> *David and Mike,*
>
> * *
>
> *I believe that the requirements should not be weakened and we should
> stick to the requirement in RFC5046.*
>
> * *
>
> *RFC5046 required the use of specific Send Message Type for valid reasons.
> *
>
> * *
>
> *In the case of requiring SendSE message use, the intent was to give a
> hint to the remote side to generate an event upon processing of SendSE
> message. For example, the SendSE is specifically carrying SCSI information
> that needs attention on the remote side e.g. SCSI command, Logout…*
>
> * *
>
> *In the case of requiring SendInvSE Message, the intent was to invalidate
> the STag used in the data transfer as well as inform the remote side to
> generate an event. For example, mandating the use of SendInvSE for the SCSI
> response PDU for a SCSI Read limits the exposure of STag used in SCSI Read
> data transfer and avoids the explicit invalidation of the STag at the
> initiator. Plus, it allows the target to generate an event on the initiator
> upon the completion of SCSI Read command.*
>
> * *
>
> *By relaxing RFC5046 requirements in the latest iSER draft, we will not
> only impact all iWARP based iSER implementations that rely on the use of
> specific Send Message Type for SCSI data transfers but also change the
> intended behavior of initiators and targets.*
>
> * *
>
> *For iWARP, I strongly suggest that the iSER draft does not relax the
> requirements specified in RFC5046.*
>
> * *
>
> *I hope that helps.*
>
> * *
>
> *Hemal    *
>
> * *
>
> *From:* storm-bounces@ietf.org [mailto:storm-bounces@ietf.org] *On Behalf
> Of *david.black@emc.com
> *Sent:* Wednesday, January 18, 2012 3:10 PM
> *To:* Michael@huaweisymantec.com; storm@ietf.org
> *Subject:* Re: [storm] iSER - one last issue****
>
> ** **
>
> Mike,****
>
> ** **
>
> Thank you for the explanation, but I don’t believe you’ve correctly stated
> ****
>
> the intent of RFC 5046.  Here are some examples from RFC 5046’s text:****
>
> ** **
>
> 1.5.  SCSI Read Overview****
>
> ** **
>
>    The iSER Message is transferred to the target using a SendSE Message.**
> **
>
> ** **
>
>    The iSER layer at the target uses a SendInvSE Message to transfer the**
> **
>
>    SCSI Response PDU back to the iSER layer at the initiator.****
>
> ** **
>
> Similar language occurs in 1.6 SCSI Write Overview.****
>
> ** **
>
> 5.2.1.  Normal Connection Termination at the Initiator****
>
> ** **
>
>    The iSER layer at the initiator MUST****
>
>    use a SendSE Message to send the Logout Request PDU to the target.****
>
> ** **
>
> Similar language occurs in 5.2.2 for target side normal connection
> termination,****
>
> and more importantly in 7.3.1 SCSI Command:****
>
> ** **
>
>    The iSER layer at the initiator MUST send the SCSI command in a****
>
>    SendSE Message to the target.****
>
> ** **
>
> None of the quoted text permits use of Send instead of SendSE or SendInv**
> **
>
> instead of SendInvSE.****
>
> ** **
>
> What you propose to do effectively changes “MUST” to “should” (lower case,
> ****
>
> weaker than “SHOULD”), and that sure looks like a change to RFC 5046.****
>
> ** **
>
> Are there good implementation-based reasons to weaken these requirements
> now?****
>
> ** **
>
> Does anyone else have a viewpoint on this topic?****
>
> ** **
>
> Thanks,
> --David****
>
> ** **
>
> *From:* Michael Ko [mailto:Michael@huaweisymantec.com]
> *Sent:* Wednesday, January 18, 2012 2:22 PM
> *To:* Black, David; storm@ietf.org
> *Subject:* Re: iSER - one last issue****
>
> ** **
>
> David,****
>
>  ****
>
> Here is my rationale for using the lower case "should".****
>
>  ****
>
> The intent of RFC5046 is that the Send Message type must be used instead
> of RDMA Reads or Writes.  The Solicited Event feature of the Send Message
> is provided as a convenience.  The receiver must still do the right thing
> in handling the Send Message regardless of whether the SE feature is used.
> In other words, the sender is responsible for using the right format for
> the message (Send vs RDMA) but the receiver must not rely on the sender to
> determine how to handle the received message.  The same rationale goes for
> the Invalidate feature.  ****
>
>  ****
>
> Mike****
>
> ----- Original Message ----- ****
>
> *From:* david.black@emc.com ****
>
> *To:* Michael@huaweisymantec.com ; storm@ietf.org ****
>
> *Sent:* Monday, January 16, 2012 2:06 PM****
>
> *Subject:* iSER - one last issue****
>
> ** **
>
> Mike,****
>
> ** **
>
> Thanks for getting the -08 version of the iSER draft posted.  I think that
> ****
>
> draft addresses all of the open issues, but I have a question for the WG**
> **
>
> about how to express the SendSE and SendInvSE requirements from RFC 5046.*
> ***
>
> ** **
>
> The -08 version of the iSER draft expresses requirements for the SendSE***
> *
>
> and SendInvSE messages (this is primarily for iSER over RDDP/iWARP) as:***
> *
>
> ** **
>
> The SendSE Message should be used if****
>
> supported by the RCaP layer (e.g., iWARP).****
>
> ** **
>
> My reading of RFC 5046 is that its requirements are tighter - to accurately
> ****
>
> reflect RFC 5046, I would replace “should” with “MUST” in the above text,*
> ***
>
> at least for iWARP.****
>
> ** **
>
> In the alternative, if the “should”s remain, an explanatory item****
>
> needs to be added to the Appendix A list of changes from RFC 5046.****
>
> ** **
>
> What do others think the right course of action is here, use “MUST” or****
>
> explain weakening of requirement to “should” ?****
>
> ** **
>
> Thanks,
> --David****
>