<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML><HEAD>
<META http-equiv=Content-Type content="text/html; charset=us-ascii">
<META content="MSHTML 6.00.2900.3199" name=GENERATOR></HEAD>
<BODY>
<DIV><FONT face=Arial size=2><PRE><SPAN class=h2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>Group,</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT size=3><FONT face="Times New Roman">below is proposal on how to resolve peer-to-peer iWARP CM issue discovered at interop event.</FONT></FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>The main issue is that MPA spec (relevant portion of IETF RFC 5044 is below) require that</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>connection initiator send first message over the established connection.</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>Multiple MPI implementations and several other apps use peer-to-peer model.</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>So rather then forcing all of them to do it on their own, which will not help with</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>interop between different implementations, the goal is to extend lower layers to provide it.</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3></FONT></SPAN> </H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>Our first idea was to leave MPA protocol untouched and try to solve this problem</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>in iw_cm. But there are too many complications to it. First, in order to adhere to RFC5044</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>initiator must send first FPDU and responder process it. But since the connection is already</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>established processing FPDU involves ULP on whose behalf the connection is created.</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>So either initiator sends a message which generates completion on responder CQ, thus visible</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>to ULP, or not. In the later case, the only op which can do it is RDMA one, which means</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>that responder somehow provided initiator S-tag which it can use. So, this is an extension</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>to MPA, probably using private data. And that responder upon receiving it destroy this S-tag.</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>In any case this is an extension of MPA. </FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>In the former, Send is used but this requires a buffer to be posted to CQ. But since</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>the same CQ (or SharedCQ) can be used by other connections at the same time it can cause</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>the responder CM posted buffer to be consumed by other connection. This is not acceptable.</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3></FONT></SPAN> </H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>So new we consider extension to MPA protocol.</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>The goal is to be completely backwards compatible to existing version 1.</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>In a nutshell, use a "flag" in the MPA request message which indicates that</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>"ready to receive" message will be send by requestor upon receiving</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>MPA response message with connection acceptance.</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3></FONT></SPAN> </H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>here are the changes to IETF RFC5044</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3></FONT></SPAN> </H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>1. <FONT face="Courier New">     0                   1                   2                   3
       0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   0  |                                                               |
      +         Key (16 bytes containing "MPA ID Req Frame")          +
   4  |      (4D 50 41 20 49 44 20 52 65 71 20 46 72 61 6D 65)        |
      +         Or  (16 bytes containing "MPA ID Rep Frame")          +
   8  |      (4D 50 41 20 49 44 20 52 65 70 20 46 72 61 6D 65)        |
      +         Or  (16 bytes containing "MPA ID Rtr Frame")          +
   12 |      (4D 50 41 20 49 44 20 52 74 52 20 46 72 61 6D 65)        |                                              +
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   16 |M|C|R|S| Res   |     Rev       |          PD_Length            |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                                                               |
      ~                                                               ~
      ~                   Private Data                                ~
      |                                                               |
      |                               +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                               |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+</FONT></FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3><FONT face="Courier New"></FONT></FONT></SPAN> </H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3><FONT face="Courier New">2. S: indicator in the Req frame whether or not Requestor will send Rtr frame.</FONT></FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3><FONT face="Courier New">      In Req frame, if set to 1 then Rtr frame will be sent if responder</FONT></FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3><FONT face="Courier New">    sends Rep frame with accept bit set. 0 indicate that Rtr frame</FONT></FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3><FONT face="Courier New">    will not be sent.</FONT></FONT></SPAN></H2><H2><SPAN class=221203914-21112007>    <FONT size=3>In Rep frame, 0 means that Responder cannot support Rtr frame,</FONT></SPAN></H2><H2><SPAN class=221203914-21112007>    <FONT size=3>while 1 that it is and is waiting for it.</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3><FONT face="Courier New">     (While my preference is to handle this as MPA protocol version matching rules,</FONT></FONT></SPAN></H2><H2><SPAN class=221203914-21112007>    <FONT size=3>proposed method will provide complete backwards compatibility) </FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3><FONT face="Courier New">    Unused by Rtr frame. That is set to 0 in Rtr frame and ignored</FONT></FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3><FONT face="Courier New">    by responder.</FONT></FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3><FONT face="Courier New"></FONT></FONT></SPAN> </H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3><FONT face="Courier New">    All other bits M,C,R and remainder of Res treated as in MPA ver 1.</FONT></FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3><FONT face="Courier New">    </FONT></FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3><FONT face="Courier New">    Rtr frame adhere to C bit as specified in Rep frame</FONT></FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3><FONT face="Courier New"></FONT></FONT></SPAN> </H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3><FONT face="Courier New">3.  No private data format is defined for Rtr in this version.</FONT></FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3><FONT face="Courier New"></FONT></FONT></SPAN> </H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3><FONT face="Courier New">4. Example will be added to present Rtr model.</FONT></FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT size=3> That is if S bit is not set the current MPA ver 1 model is followed.</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT size=3>And if S bit is set then "proposed" model with Rtr message is followed.</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT size=3></FONT></SPAN> </H2><H2><SPAN class=221203914-21112007><FONT size=3>5. Requestor use of Rtr frame must adhere to S bit setting of Rep frame.</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3><FONT face="Courier New"></FONT></FONT></SPAN> </H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3><FONT face="Courier New">**************************************************</FONT></FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3><FONT face="Courier New"></FONT></FONT></SPAN> </H2><H2><SPAN class=221203914-21112007><FONT size=3>While the process of driving this proposal thru IETF is very very length,</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT size=3>in order to solve this problem now, we can still use this proposal with the</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT size=3>current version 1 of MPA. All existing implementation will still work.</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT size=3>And if both sides support this change than peer-to-peer model is also provided.</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT size=3></FONT></SPAN> </H2><H2><SPAN class=221203914-21112007><FONT size=3>Comments, suggestion, critics requested.</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT size=3>I am especially want to know if we are missing some gotch you</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT size=3>which was discussed by RDDP WG when they rejected peer-to-peer model for MPA.</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT size=3></FONT></SPAN> </H2><H2><SPAN class=221203914-21112007><FONT size=3>iWARP vendors, please comment on the feasibility of implementing this MPA</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT size=3>extension.</FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3><FONT face="Courier New">
</FONT></FONT></SPAN></H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3></FONT></SPAN> </H2><H2><SPAN class=221203914-21112007><FONT face="Times New Roman" size=3>*********************************************************************</FONT></SPAN></H2><H2> </H2><H2><A name=section-7>7</A>.  Connection Semantics</H2></SPAN>

<SPAN class=h3><H3><A name=section-7.1>7.1</A>.  Connection Setup</H3></SPAN>

   MPA requires that the Consumer MUST activate MPA, and any TCP
   enhancements for MPA, on a TCP half connection at the same location
   in the octet stream at both the sender and the receiver.  This is
   required in order for the Marker scheme to correctly locate the
   Markers (if enabled) and to correctly locate the first FPDU.

   MPA, and any TCP enhancements for MPA are enabled by the ULP in both
   directions at once at an endpoint.



<SPAN class=grey>Culley, et al.              Standards Track                    [Page 24]</SPAN>
<A class=invisible id=page-25 href="http://tools.ietf.org/html/rfc5044#page-25" name=page-25><SPAN class=break> </SPAN></A>
<SPAN class=grey><A href="http://tools.ietf.org/html/rfc5044">RFC 5044</A>                  MPA Framing for TCP               October 2007</SPAN>


   This can be accomplished several ways, and is left up to DDP's ULP:

   *   DDP's ULP MAY require DDP on MPA startup immediately after TCP
       connection setup.  This has the advantage that no streaming mode
       negotiation is needed.  An example of such a protocol is shown in
       Figure 10: Example Immediate Startup negotiation.

       This may be accomplished by using a well-known port, or a service
       locator protocol to locate an appropriate port on which DDP on
       MPA is expected to operate.

   *   DDP's ULP MAY negotiate the start of DDP on MPA sometime after a
       normal TCP startup, using TCP streaming data exchanges on the
       same connection.  The exchange establishes that DDP on MPA (as
       well as other ULPs) will be used, and exactly locates the point
       in the octet stream where MPA is to begin operation.  Note that
       such a negotiation protocol is outside the scope of this
       specification.  A simplified example of such a protocol is shown
       in Figure 9: Example Delayed Startup negotiation on page 33.

   An MPA endpoint operates in two distinct phases.

   The Startup Phase is used to verify correct MPA setup, exchange CRC
   and Marker configuration, and optionally pass Private Data between
   endpoints prior to completing a DDP connection.  During this phase,
   specifically formatted frames are exchanged as TCP byte streams
   without using CRCs or Markers.  During this phase a DDP endpoint need
   not be "bound" to the MPA connection.  In fact, the choice of DDP
   endpoint and its operating parameters may not be known until the
   Consumer supplied Private Data (if any) has been examined by the
   Consumer.

   The second distinct phase is Full Operation during which FPDUs are
   sent using all the rules that pertain (CRCs, Markers, MULPDU
   restrictions, etc.).  A DDP endpoint MUST be "bound" to the MPA
   connection at entry to this phase.

   When Private Data is passed between ULPs in the Startup Phase, the
   ULP is responsible for interpreting that data, and then placing MPA
   into Full Operation.

   Note: The following text differentiates the two endpoints by calling
       them Initiator and Responder.  This is quite arbitrary and is NOT
       related to the TCP startup (SYN, SYN/ACK sequence).  The
       Initiator is the side that sends first in the MPA startup
       sequence (the MPA Request Frame).





<SPAN class=grey>Culley, et al.              Standards Track                    [Page 25]</SPAN>
<A class=invisible id=page-26 href="http://tools.ietf.org/html/rfc5044#page-26" name=page-26><SPAN class=break> </SPAN></A>
<SPAN class=grey><A href="http://tools.ietf.org/html/rfc5044">RFC 5044</A>                  MPA Framing for TCP               October 2007</SPAN>


   Note: The possibility that both endpoints would be allowed to make a
       connection at the same time, sometimes called an active/active
       connection, was considered by the work group and rejected.  There
       were several motivations for this decision.  One was that
       applications needing this facility were few (none other than
       theoretical at the time of this document).  Another was that the
       facility created some implementation difficulties, particularly
       with the "dual stack" designs described later on.  A last issue
       was that dealing with rejected connections at startup would have
       required at least an additional frame type, and more recovery
       actions, complicating the protocol.  While none of these issues
       was overwhelming, the group and implementers were not motivated
       to do the work to resolve these issues.  The protocol includes a
       method of detecting these active/active startup attempts so that
       they can be rejected and an error reported.

   The ULP is responsible for determining which side is Initiator or
   Responder.  For client/server type ULPs, this is easy.  For peer-peer
   ULPs (which might utilize a TCP style active/active startup), some
   mechanism (not defined by this specification) must be established, or
   some streaming mode data exchanged prior to MPA startup to determine
   which side starts in Initiator and which starts in Responder MPA
   mode.

<SPAN class=h4><H4><A name=section-7.1.1>7.1.1</A>  MPA Request and Reply Frame Format</H4></SPAN>

       0                   1                   2                   3
       0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   0  |                                                               |
      +         Key (16 bytes containing "MPA ID Req Frame")          +
   4  |      (4D 50 41 20 49 44 20 52 65 71 20 46 72 61 6D 65)        |
      +         Or  (16 bytes containing "MPA ID Rep Frame")          +
   8  |      (4D 50 41 20 49 44 20 52 65 70 20 46 72 61 6D 65)        |
      +                                                               +
   12 |                                                               |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   16 |M|C|R| Res     |     Rev       |          PD_Length            |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                                                               |
      ~                                                               ~
      ~                   Private Data                                ~
      |                                                               |
      |                               +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
      |                               |
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+

                     Figure 8: MPA Request/Reply Frame



<SPAN class=grey>Culley, et al.              Standards Track                    [Page 26]</SPAN>
<A class=invisible id=page-27 href="http://tools.ietf.org/html/rfc5044#page-27" name=page-27><SPAN class=break> </SPAN></A>
<SPAN class=grey><A href="http://tools.ietf.org/html/rfc5044">RFC 5044</A>                  MPA Framing for TCP               October 2007</SPAN>


   Key: This field contains the "key" used to validate that the sender
       is an MPA sender.  Initiator mode senders MUST set this field to
       the fixed value "MPA ID Req Frame" or (in byte order) 4D 50 41 20
       49 44 20 52 65 71 20 46 72 61 6D 65 (in hexadecimal).  Responder
       mode receivers MUST check this field for the same value, and
       close the connection and report an error locally if any other
       value is detected.  Responder mode senders MUST set this field to
       the fixed value "MPA ID Rep Frame" or (in byte order) 4D 50 41 20
       49 44 20 52 65 70 20 46 72 61 6D 65 (in hexadecimal).  Initiator
       mode receivers MUST check this field for the same value, and
       close the connection and report an error locally if any other
       value is detected.

   M: This bit declares an endpoint's REQUIRED Marker usage.  When this
       bit is '1' in an MPA Request Frame, the Initiator declares that
       Markers are REQUIRED in FPDUs sent from the Responder.  When set
       to '1' in an MPA Reply Frame, this bit declares that Markers are
       REQUIRED in FPDUs sent from the Initiator.  When in a received
       MPA Request Frame or MPA Reply Frame and the value is '0',
       Markers MUST NOT be added to the data stream by that endpoint.
       When '1' Markers MUST be added as described in <A href="http://tools.ietf.org/html/rfc5044#section-4.3">Section 4.3</A>, MPA
       Markers.

   C: This bit declares an endpoint's preferred CRC usage.  When this
       field is '0' in the MPA Request Frame and the MPA Reply Frame,
       CRCs MUST not be checked and need not be generated by either
       endpoint.  When this bit is '1' in either the MPA Request Frame
       or MPA Reply Frame, CRCs MUST be generated and checked by both
       endpoints.  Note that even when not in use, the CRC field remains
       present in the FPDU.  When CRCs are not in use, the CRC field
       MUST be considered valid for FPDU checking regardless of its
       contents.

   R: This bit is set to zero, and not checked on reception in the MPA
       Request Frame.  In the MPA Reply Frame, this bit is the Rejected
       Connection bit, set by the Responders ULP to indicate acceptance
       '0', or rejection '1', of the connection parameters provided in
       the Private Data.

   Res: This field is reserved for future use.  It MUST be set to zero
       when sending, and not checked on reception.










<SPAN class=grey>Culley, et al.              Standards Track                    [Page 27]</SPAN>
<A class=invisible id=page-28 href="http://tools.ietf.org/html/rfc5044#page-28" name=page-28><SPAN class=break> </SPAN></A>
<SPAN class=grey><A href="http://tools.ietf.org/html/rfc5044">RFC 5044</A>                  MPA Framing for TCP               October 2007</SPAN>


   Rev: This field contains the revision of MPA.  For this version of
       the specification, senders MUST set this field to one.  MPA
       receivers compliant with this version of the specification MUST
       check this field.  If the MPA receiver cannot interoperate with
       the received version, then it MUST close the connection and
       report an error locally.  Otherwise, the MPA receiver should
       report the received version to the ULP.

   PD_Length: This field MUST contain the length in octets of the
       Private Data field.  A value of zero indicates that there is no
       Private Data field present at all.  If the receiver detects that
       the PD_Length field does not match the length of the Private Data
       field, or if the length of the Private Data field exceeds 512
       octets, the receiver MUST close the connection and report an
       error locally.  Otherwise, the MPA receiver should pass the
       PD_Length value and Private Data to the ULP.

   Private Data: This field may contain any value defined by ULPs or may
       not be present.  The Private Data field MUST be between 0 and 512
       octets in length.  ULPs define how to size, set, and validate
       this field within these limits.  Private Data usage is further
       discussed in <A href="http://tools.ietf.org/html/rfc5044#section-7.1.4">Section 7.1.4</A>.

<SPAN class=h4><H4><A name=section-7.1.2>7.1.2</A>.  Connection Startup Rules</H4></SPAN>

   The following rules apply to MPA connection Startup Phase:

   1.  When MPA is started in the Initiator mode, the MPA implementation
       MUST send a valid MPA Request Frame.  The MPA Request Frame MAY
       include ULP-supplied Private Data.

   2.  When MPA is started in the Responder mode, the MPA implementation
       MUST wait until an MPA Request Frame is received and validated
       before entering Full MPA/DDP Operation.

       If the MPA Request Frame is improperly formatted, the
       implementation MUST close the TCP connection and exit MPA.

       If the MPA Request Frame is properly formatted but the Private
       Data is not acceptable, the implementation SHOULD return an MPA
       Reply Frame with the Rejected Connection bit set to '1'; the MPA
       Reply Frame MAY include ULP-supplied Private Data; the
       implementation MUST exit MPA, leaving the TCP connection open.
       The ULP may close TCP or use the connection for other purposes.

       If the MPA Request Frame is properly formatted and the Private
       Data is acceptable, the implementation SHOULD return an MPA Reply
       Frame with the Rejected Connection bit set to '0'; the MPA Reply



<SPAN class=grey>Culley, et al.              Standards Track                    [Page 28]</SPAN>
<A class=invisible id=page-29 href="http://tools.ietf.org/html/rfc5044#page-29" name=page-29><SPAN class=break> </SPAN></A>
<SPAN class=grey><A href="http://tools.ietf.org/html/rfc5044">RFC 5044</A>                  MPA Framing for TCP               October 2007</SPAN>


       Frame MAY include ULP-supplied Private Data; and the Responder
       SHOULD prepare to interpret any data received as FPDUs and pass
       any received ULPDUs to DDP.

       Note: Since the receiver's ability to deal with Markers is
           unknown until the Request and Reply Frames have been
           received, sending FPDUs before this occurs is not possible.


       Note: The requirement to wait on a Request Frame before sending a
           Reply Frame is a design choice.  It makes for a well-ordered
           sequence of events at each end, and avoids having to specify
           how to deal with situations where both ends start at the same
           time.

   3.  MPA Initiator mode implementations MUST receive and validate an
       MPA Reply Frame.

       If the MPA Reply Frame is improperly formatted, the
       implementation MUST close the TCP connection and exit MPA.

       If the MPA Reply Frame is properly formatted but is the Private
       Data is not acceptable, or if the Rejected Connection bit is set
       to '1', the implementation MUST exit MPA, leaving the TCP
       connection open.  The ULP may close TCP or use the connection for
       other purposes.

       If the MPA Reply Frame is properly formatted and the Private Data
       is acceptable, and the Reject Connection bit is set to '0', the
       implementation SHOULD enter Full MPA/DDP Operation Phase;
       interpreting any received data as FPDUs and sending DDP ULPDUs as
       FPDUs.

   4.  MPA Responder mode implementations MUST receive and validate at
       least one FPDU before sending any FPDUs or Markers.

       Note: This requirement is present to allow the Initiator time to
           get its receiver into Full Operation before an FPDU arrives,
           avoiding potential race conditions at the Initiator.  This
           was also subject to some debate in the work group before
           rough consensus was reached.  Eliminating this requirement
           would allow faster startup in some types of applications.
           However, that would also make certain implementations
           (particularly "dual stack") much harder.

   5.  If a received "Key" does not match the expected value (see
       <A href="http://tools.ietf.org/html/rfc5044#section-7.1.1">Section 7.1.1</A>, MPA Request and Reply Frame Format) the TCP/DDP
       connection MUST be closed, and an error returned to the ULP.



<SPAN class=grey>Culley, et al.              Standards Track                    [Page 29]</SPAN>
<A class=invisible id=page-30 href="http://tools.ietf.org/html/rfc5044#page-30" name=page-30><SPAN class=break> </SPAN></A>
<SPAN class=grey><A href="http://tools.ietf.org/html/rfc5044">RFC 5044</A>                  MPA Framing for TCP               October 2007</SPAN>


   6.  The received Private Data fields may be used by Consumers at
       either end to further validate the connection and set up DDP or
       other ULP parameters.  The Initiator ULP MAY close the
       TCP/MPA/DDP connection as a result of validating the Private Data
       fields.  The Responder SHOULD return an MPA Reply Frame with the
       "Reject Connection" bit set to '1' if the validation of the
       Private Data is not acceptable to the ULP.

   7.  When the first FPDU is to be sent, then if Markers are enabled,
       the first octets sent are the special Marker 0x00000000, followed
       by the start of the FPDU (the FPDU's ULPDU Length field).  If
       Markers are not enabled, the first octets sent are the start of
       the FPDU (the FPDU's ULPDU Length field).

   8.  MPA implementations MUST use the difference between the MPA
       Request Frame and the MPA Reply Frame to check for incorrect
       "Initiator/Initiator" startups.  Implementations SHOULD put a
       timeout on waiting for the MPA Request Frame when started in
       Responder mode, to detect incorrect "Responder/Responder"
       startups.

   9.  MPA implementations MUST validate the PD_Length field.  The
       buffer that receives the Private Data field MUST be large enough
       to receive that data; the amount of Private Data MUST not exceed
       the PD_Length or the application buffer.  If any of the above
       fails, the startup frame MUST be considered improperly formatted.

   10. MPA implementations SHOULD implement a reasonable timeout while
       waiting for the entire set of startup frames; this prevents
       certain denial-of-service attacks.  ULPs SHOULD implement a
       reasonable timeout while waiting for FPDUs, ULPDUs, and
       application level messages to guard against application failures
       and certain denial-of-service attacks.

<SPAN class=h4><H4><A name=section-7.1.3>7.1.3</A>.  Example Delayed Startup Sequence</H4></SPAN>

   A variety of startup sequences are possible when using MPA on TCP.
   Following is an example of an MPA/DDP startup that occurs after TCP
   has been running for a while and has exchanged some amount of
   streaming data.  This example does not use any Private Data (an
   example that does is shown later in <A href="http://tools.ietf.org/html/rfc5044#section-7.1.4.2">Section 7.1.4.2</A>, Example
   Immediate Startup Using Private Data), although it is perfectly legal
   to include the Private Data.  Note that since the example does not
   use any Private Data, there are no ULP interactions shown between
   receiving "startup frames" and putting MPA into Full Operation.






<SPAN class=grey>Culley, et al.              Standards Track                    [Page 30]</SPAN>
<A class=invisible id=page-31 href="http://tools.ietf.org/html/rfc5044#page-31" name=page-31><SPAN class=break> </SPAN></A>
<SPAN class=grey><A href="http://tools.ietf.org/html/rfc5044">RFC 5044</A>                  MPA Framing for TCP               October 2007</SPAN>


         Initiator                                 Responder

  +---------------------------+
  |ULP streaming mode         |
  |  <Hello> request to       |
  |  transition to DDP/MPA    |           +---------------------------+
  |  mode (optional).         | --------> |ULP gets request;          |
  +---------------------------+           |  enables MPA Responder    |
                                          |  mode with last (optional)|
                                          |  streaming mode           |
                                          |  <Hello Ack> for MPA to   |
                                          |  send.                    |
  +---------------------------+           |MPA waits for incoming     |
  |ULP receives streaming     | <-------- |  <MPA Request Frame>.     |
  |  <Hello Ack>;             |           +---------------------------+
  |Enters MPA Initiator mode; |
  |MPA sends                  |
  |  <MPA Request Frame>;     |
  |MPA waits for incoming     |           +---------------------------+
  |  <MPA Reply Frame>.       | - - - - > |MPA receives               |
  +---------------------------+           |  <MPA Request Frame>.     |
                                          |Consumer binds DDP to MPA; |
                                          |MPA sends the              |
                                          |  <MPA Reply Frame>.       |
                                          |DDP/MPA enables FPDU       |
  +---------------------------+           |  decoding, but does not   |
  |MPA receives the           | < - - - - |  send any FPDUs.          |
  |  <MPA Reply Frame>        |           +---------------------------+
  |Consumer binds DDP to MPA; |
  |DDP/MPA begins Full        |
  |  Operation.               |
  |MPA sends first FPDU (as   |           +---------------------------+
  |  DDP ULPDUs become        | ========> |MPA receives first FPDU.   |
  |  available).              |           |MPA sends first FPDU (as   |
  +---------------------------+           |  DDP ULPDUs become        |
                                  <====== |  available).              |
                                          +---------------------------+

              Figure 9: Example Delayed Startup Negotiation












<SPAN class=grey>Culley, et al.              Standards Track                    [Page 31]</SPAN>
<A class=invisible id=page-32 href="http://tools.ietf.org/html/rfc5044#page-32" name=page-32><SPAN class=break> </SPAN></A>
<SPAN class=grey><A href="http://tools.ietf.org/html/rfc5044">RFC 5044</A>                  MPA Framing for TCP               October 2007</SPAN>


   An example Delayed Startup sequence is described below:

       *   Active and passive sides start up a TCP connection in the
           usual fashion, probably using sockets APIs.  They exchange
           some amount of streaming mode data.  At some point, one side
           (the MPA Initiator) sends streaming mode data that
           effectively says "Hello, let's go into MPA/DDP mode".

   *   When the remote side (the MPA Responder) gets this streaming mode
       message, the Consumer would send a last streaming mode message
       that effectively says "I acknowledge your Hello, and am now in
       MPA Responder mode".  The exchange of these messages establishes
       the exact point in the TCP stream where MPA is enabled.  The
       Responding Consumer enables MPA in the Responder mode and waits
       for the initial MPA startup message.

       *   The Initiating Consumer would enable MPA startup in the
           Initiator mode which then sends the MPA Request Frame.  It is
           assumed that no Private Data messages are needed for this
           example, although it is possible to do so.  The Initiating
           MPA (and Consumer) would also wait for the MPA connection to
           be accepted.

   *   The Responding MPA would receive the initial MPA Request Frame
       and would inform the Consumer that this message arrived.  The
       Consumer can then accept the MPA/DDP connection or close the TCP
       connection.

   *   To accept the connection request, the Responding Consumer would
       use an appropriate API to bind the TCP/MPA connections to a DDP
       endpoint, thus enabling MPA/DDP into Full Operation.  In the
       process of going to Full Operation, MPA sends the MPA Reply
       Frame.  MPA/DDP waits for the first incoming FPDU before sending
       any FPDUs.

   *   If the initial TCP data was not a properly formatted MPA Request
       Frame, MPA will close or reset the TCP connection immediately.

       *   The Initiating MPA would receive the MPA Reply Frame and
           would report this message to the Consumer.  The Consumer can
           then accept the MPA/DDP connection, or close or reset the TCP
           connection to abort the process.

       *   On determining that the connection is acceptable, the
           Initiating Consumer would use an appropriate API to bind the
           TCP/MPA connections to a DDP endpoint thus enabling MPA/DDP
           into Full Operation.  MPA/DDP would begin sending DDP
           messages as MPA FPDUs.



<SPAN class=grey>Culley, et al.              Standards Track                    [Page 32]</SPAN>
<A class=invisible id=page-33 href="http://tools.ietf.org/html/rfc5044#page-33" name=page-33><SPAN class=break> </SPAN></A>
<SPAN class=grey><A href="http://tools.ietf.org/html/rfc5044">RFC 5044</A>                  MPA Framing for TCP               October 2007</SPAN>


<SPAN class=h4><H4><A name=section-7.1.4>7.1.4</A>.  Use of Private Data</H4></SPAN>

   This section is advisory in nature, in that it suggests a method by
   which a ULP can deal with pre-DDP connection information exchange.

<SPAN class=h5><H5><A name=section-7.1.4.1>7.1.4.1</A>.  Motivation</H5></SPAN>

   Prior RDMA protocols have been developed that provide Private Data
   via out-of-band mechanisms.  As a result, many applications now
   expect some form of Private Data to be available for application use
   prior to setting up the DDP/RDMA connection.  Following are some
   examples of the use of Private Data.

   An RDMA endpoint (referred to as a Queue Pair, or QP, in InfiniBand
   and the [<A href="http://tools.ietf.org/html/rfc5044#ref-VERBS-RDMA">VERBS-RDMA</A>]) must be associated with a Protection Domain.
   No receive operations may be posted to the endpoint before it is
   associated with a Protection Domain.  Indeed under both the
   InfiniBand and proposed RDMA/DDP verbs [<A href="http://tools.ietf.org/html/rfc5044#ref-VERBS-RDMA">VERBS-RDMA</A>] an endpoint/QP is
   created within a Protection Domain.

   There are some applications where the choice of Protection Domain is
   dependent upon the identity of the remote ULP client.  For example,
   if a user session requires multiple connections, it is highly
   desirable for all of those connections to use a single Protection
   Domain.  Note: Use of Protection Domains is further discussed in
   [<A title='"Direct Data Placement Protocol (DDP) / Remote Direct Memory Access Protocol (RDMAP) Security"' href="http://tools.ietf.org/html/rfc5044#ref-RDMASEC">RDMASEC</A>].

   InfiniBand, the DAT APIs [<A title='"kDAPL (Kernel Direct Access Programming Library) and uDAPL (User Direct Access Programming Library)"' href="http://tools.ietf.org/html/rfc5044#ref-DAT-API">DAT-API</A>], and the IT-API [<A title='"Interconnect Transport API (IT-API)"' href="http://tools.ietf.org/html/rfc5044#ref-IT-API">IT-API</A>] all
   provide for the active-side ULP to provide Private Data when
   requesting a connection.  This data is passed to the ULP to allow it
   to determine whether to accept the connection, and if so with which
   endpoint (and implicitly which Protection Domain).

   The Private Data can also be used to ensure that both ends of the
   connection have configured their RDMA endpoints compatibly on such
   matters as the RDMA Read capacity (see [<A title='"A Remote Direct Memory Access Protocol Specification"' href="http://tools.ietf.org/html/rfc5044#ref-RDMAP">RDMAP</A>]).  Further ULP-
   specific uses are also presumed, such as establishing the identity of
   the client.

   Private Data is also allowed for when accepting the connection, to
   allow completion of any negotiation on RDMA resources and for other
   ULP reasons.

   There are several potential ways to exchange this Private Data.  For
   example, the InfiniBand specification includes a connection
   management protocol that allows a small amount of Private Data to be
   exchanged using datagrams before actually starting the RDMA
   connection.



<SPAN class=grey>Culley, et al.              Standards Track                    [Page 33]</SPAN>
<A class=invisible id=page-34 href="http://tools.ietf.org/html/rfc5044#page-34" name=page-34><SPAN class=break> </SPAN></A>
<SPAN class=grey><A href="http://tools.ietf.org/html/rfc5044">RFC 5044</A>                  MPA Framing for TCP               October 2007</SPAN>


   This document allows for small amounts of Private Data to be
   exchanged as part of the MPA startup sequence.  The actual Private
   Data fields are carried in the MPA Request Frame and the MPA Reply
   Frame.

   If larger amounts of Private Data or more negotiation is necessary,
   TCP streaming mode messages may be exchanged prior to enabling MPA.












































<SPAN class=grey>Culley, et al.              Standards Track                    [Page 34]</SPAN>
<A class=invisible id=page-35 href="http://tools.ietf.org/html/rfc5044#page-35" name=page-35><SPAN class=break> </SPAN></A>
<SPAN class=grey><A href="http://tools.ietf.org/html/rfc5044">RFC 5044</A>                  MPA Framing for TCP               October 2007</SPAN>


<SPAN class=h5><H5><A name=section-7.1.4.2>7.1.4.2</A>.  Example Immediate Startup Using Private Data</H5></SPAN>

          Initiator                                 Responder

   +---------------------------+
   |TCP SYN sent.              |           +--------------------------+
   +---------------------------+ --------> |TCP gets SYN packet;      |
   +---------------------------+           |  sends SYN-Ack.          |
   |TCP gets SYN-Ack           | <-------- +--------------------------+
   |  sends Ack.               |
   +---------------------------+ --------> +--------------------------+
   +---------------------------+           |Consumer enables MPA      |
   |Consumer enables MPA       |           |Responder mode, waits for |
   |Initiator mode with        |           |  <MPA Request frame>.    |
   |Private Data; MPA sends    |           +--------------------------+
   |  <MPA Request Frame>;     |
   |MPA waits for incoming     |           +--------------------------+
   |  <MPA Reply Frame>.       | - - - - > |MPA receives              |
   +---------------------------+           |  <MPA Request Frame>.    |
                                           |Consumer examines Private |
                                           |Data, provides MPA with   |
                                           |return Private Data,      |
                                           |binds DDP to MPA, and     |
                                           |enables MPA to send an    |
                                           |  <MPA Reply Frame>.      |
                                           |DDP/MPA enables FPDU      |
   +---------------------------+           |decoding, but does not    |
   |MPA receives the           | < - - - - |send any FPDUs.           |
   |  <MPA Reply Frame>.       |           +--------------------------+
   |Consumer examines Private  |
   |Data, binds DDP to MPA,    |
   |and enables DDP/MPA to     |
   |begin Full Operation.      |
   |MPA sends first FPDU (as   |           +--------------------------+
   |DDP ULPDUs become          | ========> |MPA receives first FPDU.  |
   |available).                |           |MPA sends first FPDU (as  |
   +---------------------------+           |DDP ULPDUs become         |
                                   <====== |available).               |
                                           +--------------------------+

             Figure 10: Example Immediate Startup Negotiation

   Note: The exact order of when MPA is started in the TCP connection
       sequence is implementation dependent; the above diagram shows one
       possible sequence.  Also, the Initiator "Ack" to the Responder's
       "SYN-Ack" may be combined into the same TCP segment containing
       the MPA Request Frame (as is allowed by TCP RFCs).




<SPAN class=grey>Culley, et al.              Standards Track                    [Page 35]</SPAN>
<A class=invisible id=page-36 href="http://tools.ietf.org/html/rfc5044#page-36" name=page-36><SPAN class=break> </SPAN></A>
<SPAN class=grey><A href="http://tools.ietf.org/html/rfc5044">RFC 5044</A>                  MPA Framing for TCP               October 2007</SPAN>


   The example immediate startup sequence is described below:

   *   The passive side (Responding Consumer) would listen on the TCP
       destination port, to indicate its readiness to accept a
       connection.

       *   The active side (Initiating Consumer) would request a
           connection from a TCP endpoint (that expected to upgrade to
           MPA/DDP/RDMA and expected the Private Data) to a destination
           address and port.

       *   The Initiating Consumer would initiate a TCP connection to
           the destination port.  Acceptance/rejection of the connection
           would proceed as per normal TCP connection establishment.

   *   The passive side (Responding Consumer) would receive the TCP
       connection request as usual allowing normal TCP gatekeepers, such
       as INETD and TCPserver, to exercise their normal
       safeguard/logging functions.  On acceptance of the TCP
       connection, the Responding Consumer would enable MPA in the
       Responder mode and wait for the initial MPA startup message.

       *   The Initiating Consumer would enable MPA startup in the
           Initiator mode to send an initial MPA Request Frame with its
           included Private Data message to send.  The Initiating MPA
           (and Consumer) would also wait for the MPA connection to be
           accepted, and any returned Private Data.

   *   The Responding MPA would receive the initial MPA Request Frame
       with the Private Data message and would pass the Private Data
       through to the Consumer.  The Consumer can then accept the
       MPA/DDP connection, close the TCP connection, or reject the MPA
       connection with a return message.

   *   To accept the connection request, the Responding Consumer would
       use an appropriate API to bind the TCP/MPA connections to a DDP
       endpoint, thus enabling MPA/DDP into Full Operation.  In the
       process of going to Full Operation, MPA sends the MPA Reply
       Frame, which includes the Consumer-supplied Private Data
       containing any appropriate Consumer response.  MPA/DDP waits for
       the first incoming FPDU before sending any FPDUs.

   *   If the initial TCP data was not a properly formatted MPA Request
       Frame, MPA will close or reset the TCP connection immediately.







<SPAN class=grey>Culley, et al.              Standards Track                    [Page 36]</SPAN>
<A class=invisible id=page-37 href="http://tools.ietf.org/html/rfc5044#page-37" name=page-37><SPAN class=break> </SPAN></A>
<SPAN class=grey><A href="http://tools.ietf.org/html/rfc5044">RFC 5044</A>                  MPA Framing for TCP               October 2007</SPAN>


   *   To reject the MPA connection request, the Responding Consumer
       would send an MPA Reply Frame with any ULP-supplied Private Data
       (with reason for rejection), with the "Rejected Connection" bit
       set to '1', and may close the TCP connection.

       *   The Initiating MPA would receive the MPA Reply Frame with the
           Private Data message and would report this message to the
           Consumer, including the supplied Private Data.

           If the "Rejected Connection" bit is set to a '1', MPA will
           close the TCP connection and exit.

           If the "Rejected Connection" bit is set to a '0', and on
           determining from the MPA Reply Frame Private Data that the
           connection is acceptable, the Initiating Consumer would use
           an appropriate API to bind the TCP/MPA connections to a DDP
           endpoint thus enabling MPA/DDP into Full Operation.  MPA/DDP
           would begin sending DDP messages as MPA FPDUs.

<SPAN class=h4><H4><A name=section-7.1.5>7.1.5</A>.  "Dual Stack" Implementations</H4></SPAN>

   MPA/DDP implementations are commonly expected to be implemented as
   part of a "dual stack" architecture.  One stack is the traditional
   TCP stack, usually with a sockets interface API (Application
   Programming Interface).  The second stack is the MPA/DDP stack with
   its own API, and potentially separate code or hardware to deal with
   the MPA/DDP data.  Of course, implementations may vary, so the
   following comments are of an advisory nature only.

   The use of the two stacks offers advantages:

       TCP connection setup is usually done with the TCP stack.  This
       allows use of the usual naming and addressing mechanisms.  It
       also means that any mechanisms used to "harden" the connection
       setup against security threats are also used when starting
       MPA/DDP.

       Some applications may have been originally designed for TCP, but
       are "enhanced" to utilize MPA/DDP after a negotiation reveals the
       capability to do so.  The negotiation process takes place in
       TCP's streaming mode, using the usual TCP APIs.

       Some new applications, designed for RDMA or DDP, still need to
       exchange some data prior to starting MPA/DDP.  This exchange can
       be of arbitrary length or complexity, but often consists of only
       a small amount of Private Data, perhaps only a single message.
       Using the TCP streaming mode for this exchange allows this to be
       done using well-understood methods.



<SPAN class=grey>Culley, et al.              Standards Track                    [Page 37]</SPAN>
<A class=invisible id=page-38 href="http://tools.ietf.org/html/rfc5044#page-38" name=page-38><SPAN class=break> </SPAN></A>
<SPAN class=grey><A href="http://tools.ietf.org/html/rfc5044">RFC 5044</A>                  MPA Framing for TCP               October 2007</SPAN>


   The main disadvantage of using two stacks is the conversion of an
   active TCP connection between them.  This process must be done with
   care to prevent loss of data.

   To avoid some of the problems when using a "dual stack" architecture,
   the following additional restrictions may be required by the
   implementation:

   1.  Enabling the DDP/MPA stack SHOULD be done only when no incoming
       stream data is expected.  This is typically managed by the ULP
       protocol.  When following the recommended startup sequence, the
       Responder side enters DDP/MPA mode, sends the last streaming mode
       data, and then waits for the MPA Request Frame.  No additional
       streaming mode data is expected.  The Initiator side ULP receives
       the last streaming mode data, and then enters DDP/MPA mode.
       Again, no additional streaming mode data is expected.

   2.  The DDP/MPA MAY provide the ability to send a "last streaming
       message" as part of its Responder DDP/MPA enable function.  This
       allows the DDP/MPA stack to more easily manage the conversion to
       DDP/MPA mode (and avoid problems with a very fast return of the
       MPA Request Frame from the Initiator side).

   Note: Regardless of the "stack" architecture used, TCP's rules MUST
       be followed.  For example, if network data is lost, re-segmented,
       or re-ordered, TCP MUST recover appropriately even when this
       occurs while switching stacks.
</PRE></FONT></DIV>
<DIV> </DIV><?xml:namespace prefix = o ns = 
"urn:schemas-microsoft-com:office:office" /><o:SmartTagType name="Street" 
namespaceuri="urn:schemas-microsoft-com:office:smarttags"></o:SmartTagType><o:SmartTagType 
name="address" 
namespaceuri="urn:schemas-microsoft-com:office:smarttags"></o:SmartTagType>
<STYLE>st1\:* {
        BEHAVIOR: url(#ieooui)
}
</STYLE>

<STYLE>@page Section1 {size: 8.5in 11.0in; margin: 1.0in 1.25in 1.0in 1.25in; mso-header-margin: .5in; mso-footer-margin: .5in; mso-paper-source: 0; }
P.MsoNormal {
        FONT-SIZE: 12pt; MARGIN: 0in 0in 0pt; FONT-FAMILY: "Times New Roman"; mso-style-parent: ""; mso-pagination: widow-orphan; mso-fareast-font-family: "Times New Roman"
}
LI.MsoNormal {
        FONT-SIZE: 12pt; MARGIN: 0in 0in 0pt; FONT-FAMILY: "Times New Roman"; mso-style-parent: ""; mso-pagination: widow-orphan; mso-fareast-font-family: "Times New Roman"
}
DIV.MsoNormal {
        FONT-SIZE: 12pt; MARGIN: 0in 0in 0pt; FONT-FAMILY: "Times New Roman"; mso-style-parent: ""; mso-pagination: widow-orphan; mso-fareast-font-family: "Times New Roman"
}
A:link {
        COLOR: blue; TEXT-DECORATION: underline; text-underline: single
}
SPAN.MsoHyperlink {
        COLOR: blue; TEXT-DECORATION: underline; text-underline: single
}
A:visited {
        COLOR: purple; TEXT-DECORATION: underline; text-underline: single
}
SPAN.MsoHyperlinkFollowed {
        COLOR: purple; TEXT-DECORATION: underline; text-underline: single
}
SPAN.SpellE {
        mso-style-name: ""; mso-spl-e: yes
}
SPAN.GramE {
        mso-style-name: ""; mso-gram-e: yes
}
DIV.Section1 {
        page: Section1
}
</STYLE>

<DIV class=Section1>
<P class=MsoNormal align=left><SPAN class=SpellE><SPAN 
style="FONT-SIZE: 10pt; FONT-FAMILY: Arial">Arkady</SPAN></SPAN><SPAN 
style="FONT-SIZE: 10pt; FONT-FAMILY: Arial"> <SPAN 
class=SpellE>Kanevsky</SPAN><SPAN 
style="mso-tab-count: 2">                       
</SPAN>email: <A 
href="mailto:arkady@netapp.com">arkady@netapp.com</A><o:p></o:p></SPAN></P>
<P class=MsoNormal><SPAN style="FONT-SIZE: 10pt; FONT-FAMILY: Arial">Network 
Appliance Inc.<SPAN 
style="mso-tab-count: 2">               
</SPAN><SPAN class=GramE>phone</SPAN>: 781-768-5395<o:p></o:p></SPAN></P>
<P class=MsoNormal><?xml:namespace prefix = st1 ns = 
"urn:schemas-microsoft-com:office:smarttags" /><st1:Street 
w:st="on"><st1:address 
style="BACKGROUND-POSITION: left bottom; BACKGROUND-IMAGE: url(res://ietag.dll/#34/#1001); BACKGROUND-REPEAT: repeat-x" 
tabIndex=0 w:st="on"><SPAN style="FONT-SIZE: 10pt; FONT-FAMILY: Arial">1601 
Trapelo Rd. - Suite 16.</SPAN></st1:address></st1:Street><SPAN 
style="mso-tab-count: 2">        </SPAN><SPAN 
style="FONT-SIZE: 10pt; FONT-FAMILY: Arial">Fax: 
781-895-1195<o:p></o:p></SPAN></P>
<P class=MsoNormal><SPAN style="FONT-SIZE: 10pt; FONT-FAMILY: Arial">Waltham, MA 
02451                   
central phone: 781-768-5300</SPAN></P></DIV>
<DIV> </DIV></BODY></HTML>