Re: [tcpm] WGLC comments addressed in draft-ietf-tcpm-converters-09?

<mohamed.boucadair@orange.com> Thu, 01 August 2019 08:57 UTC

Return-Path: <mohamed.boucadair@orange.com>
X-Original-To: tcpm@ietfa.amsl.com
Delivered-To: tcpm@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 3A8441200CE; Thu, 1 Aug 2019 01:57:38 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -2.598
X-Spam-Level:
X-Spam-Status: No, score=-2.598 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, RCVD_IN_DNSWL_LOW=-0.7, SPF_HELO_NONE=0.001, SPF_PASS=-0.001, UNPARSEABLE_RELAY=0.001, URIBL_BLOCKED=0.001] autolearn=ham autolearn_force=no
Received: from mail.ietf.org ([4.31.198.44]) by localhost (ietfa.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id Oc8Niq0pd2K3; Thu, 1 Aug 2019 01:57:34 -0700 (PDT)
Received: from relais-inet.orange.com (relais-inet.orange.com [80.12.70.35]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id 8F3E81200B1; Thu, 1 Aug 2019 01:57:34 -0700 (PDT)
Received: from opfednr07.francetelecom.fr (unknown [xx.xx.xx.71]) by opfednr22.francetelecom.fr (ESMTP service) with ESMTP id 45zkhD3vMXz106v; Thu, 1 Aug 2019 10:57:32 +0200 (CEST)
Received: from Exchangemail-eme6.itn.ftgroup (unknown [xx.xx.13.92]) by opfednr07.francetelecom.fr (ESMTP service) with ESMTP id 45zkhD31T1zFpXJ; Thu, 1 Aug 2019 10:57:32 +0200 (CEST)
Received: from OPEXCAUBMA2.corporate.adroot.infra.ftgroup ([fe80::e878:bd0:c89e:5b42]) by OPEXCAUBM34.corporate.adroot.infra.ftgroup ([::1]) with mapi id 14.03.0468.000; Thu, 1 Aug 2019 10:57:32 +0200
From: mohamed.boucadair@orange.com
To: "philip.eardley@bt.com" <philip.eardley@bt.com>, "Michael.Scharf@hs-esslingen.de" <Michael.Scharf@hs-esslingen.de>, "tcpm@ietf.org" <tcpm@ietf.org>
CC: "tcpm-chairs@ietf.org" <tcpm-chairs@ietf.org>
Thread-Topic: WGLC comments addressed in draft-ietf-tcpm-converters-09?
Thread-Index: AdVAY18GkuWfECVqQWaaLZInx1aQaQHJQcVQAAH6llAALWUTAA==
Date: Thu, 01 Aug 2019 08:57:32 +0000
Message-ID: <787AE7BB302AE849A7480A190F8B9330312F9DD4@OPEXCAUBMA2.corporate.adroot.infra.ftgroup>
References: <6EC6417807D9754DA64F3087E2E2E03E2D3C0FC8@rznt8114.rznt.rzdir.fht-esslingen.de> <CWXP123MB2583E113996E40BCC57F62FBEBDF0@CWXP123MB2583.GBRP123.PROD.OUTLOOK.COM> <787AE7BB302AE849A7480A190F8B9330312ECAD3@OPEXCAUBMA2.corporate.adroot.infra.ftgroup>
In-Reply-To: <787AE7BB302AE849A7480A190F8B9330312ECAD3@OPEXCAUBMA2.corporate.adroot.infra.ftgroup>
Accept-Language: fr-FR, en-US
Content-Language: fr-FR
X-MS-Has-Attach:
X-MS-TNEF-Correlator:
x-originating-ip: [10.114.13.247]
Content-Type: text/plain; charset="iso-8859-1"
Content-Transfer-Encoding: quoted-printable
MIME-Version: 1.0
Archived-At: <https://mailarchive.ietf.org/arch/msg/tcpm/NdlzpJRyvoMgIa1KdAmmFmwkGrs>
Subject: Re: [tcpm] WGLC comments addressed in draft-ietf-tcpm-converters-09?
X-BeenThere: tcpm@ietf.org
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: TCP Maintenance and Minor Extensions Working Group <tcpm.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/tcpm>, <mailto:tcpm-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/tcpm/>
List-Post: <mailto:tcpm@ietf.org>
List-Help: <mailto:tcpm-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/tcpm>, <mailto:tcpm-request@ietf.org?subject=subscribe>
X-List-Received-Date: Thu, 01 Aug 2019 08:57:38 -0000

Phil, 

I prepared an updated version with the following changes to address your remaining comments: 

* Position Figure 1 right after the text about upstream/downstream connections to avoid the confusion about the direction.
* Delete "(1)" from Figure 5 caption
* Add text to clarify why "eventually" is used in the text. Rearranged the text about address preservation/sharing modes, accordingly. 
* Section 3.2: remove the text about inserting Convert TLVs in "subsequent messages". 
* Section 3.3: add finally a side not to remind that RST does not close an MPTCP connection, and hence is not reflected by the converter on the TCP connection. 
* Section 4 (Introduction): Clarified that both control and data messages are sent over a relayed connection. I hesitated to add the NEW text you proposed about relaying connections, but finally discarded it because the behavior is already described in many places in the documents. No need to be redundant.  
* Update Figures 11/19
* Add an appendix to record the design considerations from the changes log.

I also made some other edits to fix some nits. 

You may check the full diff at: https://www.ietf.org/rfcdiff?url1=draft-ietf-tcpm-converters-09&url2=draft-ietf-tcpm-converters-10 

Thank you for the review. 

Cheers,
Med

> -----Message d'origine-----
> De : tcpm [mailto:tcpm-bounces@ietf.org] De la part de
> mohamed.boucadair@orange.com
> Envoyé : mercredi 31 juillet 2019 14:22
> À : philip.eardley@bt.com; Michael.Scharf@hs-esslingen.de; tcpm@ietf.org
> Cc : tcpm-chairs@ietf.org
> Objet : Re: [tcpm] WGLC comments addressed in draft-ietf-tcpm-converters-
> 09?
> 
> Hi Phil,
> 
> Thank you for double checking.
> 
> Please see inline.
> 
> Cheers,
> Med
> 
> > -----Message d'origine-----
> > De : tcpm [mailto:tcpm-bounces@ietf.org] De la part de
> > philip.eardley@bt.com
> > Envoyé : mercredi 31 juillet 2019 12:26
> > À : Michael.Scharf@hs-esslingen.de; tcpm@ietf.org
> > Cc : tcpm-chairs@ietf.org
> > Objet : Re: [tcpm] WGLC comments addressed in draft-ietf-tcpm-
> converters-
> > 09?
> >
> > I think most of my comments are addressed. Here are some things I think
> > could still be clarified, plus a couple of extra questions that occurred
> > to me when I was checking the latest version.
> >
> > Section 3.1
> > <<Nevertheless, and unless this is explicitly stated,  the description
> > assumes outgoing connections as default.>>
> >
> > This sentence seems to contradict itself (can something be both assumed
> > and have to be explicitly stated?).
> 
> [Med] Yes. Consider for example the following text:
> 
>    "By default, the Transport Converter listens on TCP port number TBA
>    for Convert protocol (Convert, for short) messages from Clients.
> 
>    Clients send packets that are eligible to the conversion service to
>    the provisioned Transport Converter using TBA as destination port
>    number.  Additional information is supplied by Clients to the
>    Transport Converter by means of Convert messages as detailed in the
>    following sub-sections."
> 
> It applies only for the outgoing connections.
> 
>  Maybe:-
> > In general this document assumes that the client initiates the
> connection
> > (in other words, it is an outgoing connection); the scenario with an
> > incoming connection is discussed in a couple of places [references].
> 
> [Med] I can use this wording if you think it is better.
> 
> >
> > In Figure 1 I find the 'upstream' and 'downstream' labels a bit
> confusing
> > (especially as the lines have arrowheads in both directions), and it is
> > shown as the link between client and converter etc. I think it would be
> > better to move lower down (ie separate from the actual link), something
> > like:
> > -------> upstream direction (outgoing connections)
> > <------ downstream direction (incoming connections)
> >
> 
> [Med] Actually, upsteram and downstream are defined as follows:
> 
>    o  the upstream connection is the one between the Client and the
>       Transport Converter.
> 
>    o  the downstream connection is between the Transport Converter and
>       the Server.
> 
> This is independent of the connection direction.
> 
> > Figure 5 caption has a stray "(1)" that can be deleted
> 
> [Med] Fixed.
> 
> >
> > Above Figure 6
> > <<addresses and, eventually, the destination IP address and port number"
> > I think ", eventually," should be deleted.
> >
> >
> 
> [Med] "eventually" is justified: cover the case of a converter configured
> in an address preservation mode (e.g., IPv6). The destination IP address
> won't be rewritten in such case.
> 
> 
> > Section 3.2 / 3.3
> > There are two paragraphs at the end of 3.2 and a bit more in 3.3
> > discussing what happens when a connection ends with FIN and TCP RST etc.
> I
> > think you should write a bit more about the MPTCP case - since there are
> > subflow TCP RST and MP_FASTCLOSE cases to consider. A TCP RST on one
> MPTCP
> > subflow presumably shouldn't trigger the Converter to close the TCP
> > connection on its other interface.
> 
> [Med] Section 3.2 covers the generic TCP case. Hence, there is no need to
> discuss MPTCP specifics in that section.
> 
> I guess you are referring to this text in Section 3.3:
> 
>    Note that, if the TCP connection fails for some reason, the Converter
>    tears down the Multipath TCP connection by transmitting a
>    MP_FASTCLOSE.  Likewise, if the Multipath TCP connection ends with
>    the transmission of DATA_FINs, the Converter terminates the TCP
>    connection by using FIN segments.
> 
> The text covers exclusively the cases that lead to the termination of the
> upstream/downstream connection.
> 
> Given that MPTCP spec says:
> 
>    "With MPTCP, the RST only has the scope of the
>    subflow and will only close the concerned subflow but not affect the
>    remaining subflows.  MPTCP's connection will stay alive at the data
>    level, in order to permit break-before-make handover between
>    subflows."
> 
> the subflow RST is not covered (as it does not terminate the MPTCP leg).
> 
> >
> > Section 4 intro
> >
> > << This section describes the messages that are exchanged between a
> >    Client and a Transport Converter.
> >
> >    By default, the Transport Converter listens on TCP port number TBA
> >    for Convert protocol (Convert, for short) messages from Clients.
> >
> >    Clients send packets that are eligible to the conversion service to
> >    the provisioned Transport Converter using TBA as destination port
> >    number.  Additional information is supplied by Clients to the
> >    Transport Converter by means of Convert messages as detailed in the
> >    following sub-sections.
> >
> >    Convert messages may appear only in a SYN, SYN+ACK, or ACK.
> >
> >    Convert messages MUST be included as the first bytes of the
> >    bytestream.  A Convert message starts with a 32 bits long fixed
> >    header (Section 4.1) followed by one or more Convert TLVs (Type,
> >    Length, Value) (Section 4.2).
> > >>
> >
> > Some comments:
> > The Client also listens on TCP port TBA (not just the converter)
> 
> [Med] The client will listen on the internal port number that it indicated
> when creating a mapping in the converter to allow for incoming
> connections. This is needed to demux services hosted on the same client.
> 
> This is covered in this text:
> 
>    The Converter accepts the request by creating a TCP
>    mapping (internal IP address, internal port number, external IP
>    address, external port number).  The external IP address and external
>    port number will be then advertised using an out-of-band mechanism so
>    that remote hosts can initiate TCP connections to the Client via the
>    Converter.  Note that the external and internal information may be
>    the same.
> 
> > Stress that ALL convert msgs start with the same header.
> > I think the "Clients send packets..." para is better re-arranged.
> >
> > Question: there seems to be a contradiction. The text here says "Convert
> > messages may appear only in syn, syn-ack, ack". But then in S3.2 it says
> > "This information is sent at the beginning of the bytestream, either
> > directly in the SYN+ACK or in a subsequent packet." (this information is
> > "about the TCP options that were negotiated with the Server.")
> > (Incidentally, in S3.2 essentially the same sentence is repeated two
> > sentences later.)  is the idea that SYN / syn-ack /ack is the 'normal'
> > case, but can be in later pkts?
> 
> [Med] Good catch.
> 
> OLD:
>    The Client sends a SYN destined to the Transport Converter.  The
>    payload of this SYN contains the address and port number of the
>    Server.  The Transport Converter does not reply immediately to this
>    SYN.  It first tries to create a TCP connection towards the target
>    Server.  If this upstream connection succeeds, the Transport
>    Converter confirms the establishment of the connection to the Client
>    by returning a SYN+ACK and the first bytes of the bytestream contain
>    information about the TCP options that were negotiated with the
>    Server.  This information is sent at the beginning of the bytestream,
>    either directly in the SYN+ACK or in a subsequent packet.  For
>    graphical reasons, the figures in this section show that the
>    Transport Converter returns this information in the SYN+ACK packet.
>    An implementation could also place this information in a packet that
>    it sent shortly after the SYN+ACK.
> 
> NEW:
>    The Client sends a SYN destined to the Transport Converter.  The
>    payload of this SYN contains the address and port number of the
>    Server.  The Transport Converter does not reply immediately to this
>    SYN.  It first tries to create a TCP connection towards the target
>    Server.  If this upstream connection succeeds, the Transport
>    Converter confirms the establishment of the connection to the Client
>    by returning a SYN+ACK and the first bytes of the bytestream contain
>    information about the TCP options that were negotiated with the
>    Server.
> 
> 
> >
> > Question: the text says "Clients send packets that are eligible to the
> > conversion service to the provisioned Transport Converter using TBA as
> > destination port number." Is this referring to the exchange of Convert
> > protocol messages? Or is this referring to subsequent data that is
> > actually sent to the TBA port number? I think the text implies the
> latter,
> > which I assume is not correct.
> 
> [Med] This applies to all messages that cross the converter.
> 
> >
> >
> > Suggested text:-
> >
> > <<
> >    This section defines the Convert protocol (Convert, for short)
> messages
> > that are exchanged between a Client and a Transport Converter.
> >
> >    Convert messages MUST be sent to TCP destination port TBA. Therefore,
> a
> > Transport Converter and a Client listen on this TCP port for Convert
> > messages.
> 
> [Med] The initial wording is correct.
> 
> >    Convert messages MAY appear in a SYN, SYN+ACK, or ACK or MAY appear
> in
> > a subsequent packet.
> 
> [Med] The initial wording is correct.
> 
> > Convert messages MUST be included as the first bytes of the bytestream.
> > All Convert messages start with a common 32 bits long header (Section
> > 4.1), followed by one or more Convert TLVs (Type, Length, Value)
> (Section
> > 4.2).
> > After a successful exchange of Convert messages, a TCP connection with
> TCP
> > extension(s) is established between the Client and Transport Converter
> > (for instance, Multipath TCP), and a (normal) TCP connection is
> > established between the Transport Converter and other end host, with the
> > Transport Converter acting as an explicit proxy between the two
> > connections (for instance, between MPTCP and TCP).
> 
> [Med] No problem (even if the last sentence is already stated in previous
> sections).
> 
> > >>
> >
> >
> > Section 4.0, 4.2.6 etc
> > Various places say things like "the Unassigned field MUST be set to zero
> > by the transmitter and
> >    ignored by the receiver.  These bits are available for future use
> >    [RFC8126]."
> > Comment: I heard in ietf-105 about problems for extensibility of various
> > protocols because implementations insist on all zeroes for fields,
> > otherwise discard packets. The suggestion is to grease (which I think
> > means that the senders set to random values and receivers MUST ignore)
> 
> [Med] I don't see the value for doing this.
> 
> > Also, 'sender' rather than 'transmitter'
> 
> [Med] Fixed. Thanks.
> 
> >
> > Figure 11
> > In the figure you have Value being optional in bits 16-31 and compulsory
> > in bits 32+. I think this should be the other way round.
> 
> [Med] OK.
> 
> >
> > Section 4.2.8
> > "This TLV has a variable length.  It appears after the Convert fixed-
> >    header in the bytestream returned by the Transport Converter."
> > Figure 19 doesn't show variable length. Must its length be a multiple of
> > 32 bytes (padded if needed)? (I assume so, to be consistent with
> > elsewhere.)
> 
> [Med] Agree. Fixed the figure.
> 
> Padding is mentioned in the error description (when appropriate), e.g.,:
> 
>      "The
>       list of unsupported TCP options MUST be padded with zeros to end
>       on a 32 bits boundary. "
> 
> > The second sentence could be deleted, since elsewhere text says the
> TLV(s)
> > must be at the start of the bytestream. But if you keep the sentence I
> > suggest you say "appears _immediately_ after"
> >
> 
> [Med] Deleted that sentence. No need to be redundant.
> 
> > S6
> > "The case of a middlebox that removes the payload of SYN+ACKs (but the
> >        payload of SYN) can be detected by a Client."
> > Do you mean: but _not_ the payload of SYN?
> 
> [Med] Yes.
> 
> >
> > <<Appendix A.  Change Log
> >    This section to be removed before publication.>>
> > It would be really nice if somehow the material here that explains the
> > design rationale, and development from earlier approaches, could be
> kept.
> > It's useful info, I think.
> 
> [Med] OK, added a new appendix to cover the key points.
> 
> >
> > Best wishes,
> > phil
> >
> > -----Original Message-----
> > From: Scharf, Michael [mailto:Michael.Scharf@hs-esslingen.de]
> > Sent: 22 July 2019 09:01
> > To: Eardley,PL,Philip,TUD1 R <philip.eardley@bt.com>
> > Cc: tcpm-chairs@ietf.org
> > Subject: WGLC comments addressed in draft-ietf-tcpm-converters-09?
> >
> > Hi Phil,
> >
> > Could you please have a look at -09 and let me know if your WGLC
> comments
> > are addressed?
> >
> > If not, please follow-up on the mailing list.
> >
> > Thanks
> >
> > Michael
> >
> > -----Original Message-----
> > From: tcpm <tcpm-bounces@ietf.org> On Behalf Of internet-drafts@ietf.org
> > Sent: Monday, July 22, 2019 8:04 AM
> > To: i-d-announce@ietf.org
> > Cc: tcpm@ietf.org
> > Subject: [tcpm] I-D Action: draft-ietf-tcpm-converters-09.txt
> >
> >
> > A New Internet-Draft is available from the on-line Internet-Drafts
> > directories.
> > This draft is a work item of the TCP Maintenance and Minor Extensions WG
> > of the IETF.
> >
> >         Title           : 0-RTT TCP Convert Protocol
> >         Authors         : Olivier Bonaventure
> >                           Mohamed Boucadair
> >                           Sri Gundavelli
> >                           SungHoon Seo
> >                           Benjamin Hesmans
> > 	Filename        : draft-ietf-tcpm-converters-09.txt
> > 	Pages           : 47
> > 	Date            : 2019-07-21
> >
> > Abstract:
> >    This document specifies an application proxy, called Transport
> >    Converter, to assist the deployment of TCP extensions such as
> >    Multipath TCP.  This proxy is designed to avoid inducing extra delay
> >    when involved in a network-assisted connection (that is, 0-RTT).
> >
> >    This specification assumes an explicit model, where the proxy is
> >    explicitly configured on hosts.
> >
> >
> > The IETF datatracker status page for this draft is:
> > https://datatracker.ietf.org/doc/draft-ietf-tcpm-converters/
> >
> > There are also htmlized versions available at:
> > https://tools.ietf.org/html/draft-ietf-tcpm-converters-09
> > https://datatracker.ietf.org/doc/html/draft-ietf-tcpm-converters-09
> >
> > A diff from the previous version is available at:
> > https://www.ietf.org/rfcdiff?url2=draft-ietf-tcpm-converters-09
> >
> >
> > Please note that it may take a couple of minutes from the time of
> > submission until the htmlized version and diff are available at
> > tools.ietf.org.
> >
> > Internet-Drafts are also available by anonymous FTP at:
> > ftp://ftp.ietf.org/internet-drafts/
> >
> > _______________________________________________
> > tcpm mailing list
> > tcpm@ietf.org
> > https://www.ietf.org/mailman/listinfo/tcpm
> >
> > _______________________________________________
> > tcpm mailing list
> > tcpm@ietf.org
> > https://www.ietf.org/mailman/listinfo/tcpm
> 
> _______________________________________________
> tcpm mailing list
> tcpm@ietf.org
> https://www.ietf.org/mailman/listinfo/tcpm