Re: [tcpm] [Technical Errata Reported] RFC8257 (6697)

Vidhi Goel <vidhi_goel@apple.com> Thu, 04 November 2021 22:37 UTC

Return-Path: <vidhi_goel@apple.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 230633A0D4A; Thu, 4 Nov 2021 15:37:40 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -2.1
X-Spam-Level:
X-Spam-Status: No, score=-2.1 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIMWL_WL_HIGH=-0.001, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, HTML_MESSAGE=0.001, RCVD_IN_MSPIKE_H2=-0.001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001, URIBL_BLOCKED=0.001] autolearn=ham autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (2048-bit key) header.d=apple.com
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 W2K49fv5hkqs; Thu, 4 Nov 2021 15:37:34 -0700 (PDT)
Received: from rn-mailsvcp-ppex-lapp14.apple.com (rn-mailsvcp-ppex-lapp14.rno.apple.com [17.179.253.33]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id 0A7263A0D4E; Thu, 4 Nov 2021 15:37:32 -0700 (PDT)
Received: from pps.filterd (rn-mailsvcp-ppex-lapp14.rno.apple.com [127.0.0.1]) by rn-mailsvcp-ppex-lapp14.rno.apple.com (8.16.1.2/8.16.1.2) with SMTP id 1A4MIiKF029408; Thu, 4 Nov 2021 15:37:23 -0700
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=apple.com; h=from : message-id : content-type : mime-version : subject : date : in-reply-to : cc : to : references; s=20180706; bh=Dkcffs+O7VB4oTRroapPvKKMqoCotiOuWOuKEs0IxTc=; b=POnsS04xBgcITbj2E6E1s3U3Um+qvFd5yeAXvfM+BJrDzPsTOejg4gialT0Ejv15dves RzBWpItWX46jymMwNE7bRKtkL1fNV8FRHJeQvg9GR//K4U3mFeUeDZrP7XGxSOYbe5M3 g9CPUOG6ADpgXuFGamVgtr6D0Wy9EfNTX25jBBvxyG9IODaCUi+KtyIlRnVF3vdtdq6C cbHfSlUZzLnKIPONDH65QI8LoOuzlArBw1KVFJ4sA18ia48T6zA6JIiV08VHnf74G4mJ qD5ZrLpwQmPx/RpCZXNlgCtVEGMNsvJyGdpy61KlvUk/YA/adBF1watq/31gseZ5bXpi xg==
Received: from rn-mailsvcp-mta-lapp03.rno.apple.com (rn-mailsvcp-mta-lapp03.rno.apple.com [10.225.203.151]) by rn-mailsvcp-ppex-lapp14.rno.apple.com with ESMTP id 3c12xcj6xq-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128 verify=NO); Thu, 04 Nov 2021 15:37:23 -0700
Received: from rn-mailsvcp-mmp-lapp03.rno.apple.com (rn-mailsvcp-mmp-lapp03.rno.apple.com [17.179.253.16]) by rn-mailsvcp-mta-lapp03.rno.apple.com (Oracle Communications Messaging Server 8.1.0.12.20210903 64bit (built Sep 3 2021)) with ESMTPS id <0R2200754K6BK660@rn-mailsvcp-mta-lapp03.rno.apple.com>; Thu, 04 Nov 2021 15:37:23 -0700 (PDT)
Received: from process_milters-daemon.rn-mailsvcp-mmp-lapp03.rno.apple.com by rn-mailsvcp-mmp-lapp03.rno.apple.com (Oracle Communications Messaging Server 8.1.0.12.20210903 64bit (built Sep 3 2021)) id <0R2200O00K11ST00@rn-mailsvcp-mmp-lapp03.rno.apple.com>; Thu, 04 Nov 2021 15:37:23 -0700 (PDT)
X-V-A:
X-V-T-CD: 8d45deca0a60b8e84b634a23cb93b003
X-V-E-CD: 1a0ff53b1cc9743547fae51364312ea2
X-V-R-CD: b7a4a7f65cbf65b241f39fe55b06b74f
X-V-CD: 0
X-V-ID: 214975ab-bc73-4074-a424-a0df7c9d94e3
X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.425, 18.0.790 definitions=2021-11-04_07:2021-11-03, 2021-11-04 signatures=0
Received: from smtpclient.apple (unknown [17.234.34.35]) by rn-mailsvcp-mmp-lapp03.rno.apple.com (Oracle Communications Messaging Server 8.1.0.12.20210903 64bit (built Sep 3 2021)) with ESMTPSA id <0R22005EQK6ANY00@rn-mailsvcp-mmp-lapp03.rno.apple.com>; Thu, 04 Nov 2021 15:37:22 -0700 (PDT)
From: Vidhi Goel <vidhi_goel@apple.com>
Message-id: <79834D30-A837-4538-A89A-6CA396B572C9@apple.com>
Content-type: multipart/signed; boundary="Apple-Mail=_AAD761D9-D6A7-468F-BF6C-4D49BFB5806C"; protocol="application/pkcs7-signature"; micalg="sha-256"
MIME-version: 1.0 (Mac OS X Mail 14.0 \(3654.100.0.2.11\))
Date: Thu, 04 Nov 2021 15:37:21 -0700
In-reply-to: <CAM4esxTg1CpxiLEQOp9_kKiY+7Do2fSiqMZRXn7n_KWB1n3dJg@mail.gmail.com>
Cc: t petch <ietfa@btconnect.com>, Michael Tuexen <tuexen@fh-muenster.de>, "tcpm@ietf.org Extensions" <tcpm@ietf.org>, Dave Thaler <dthaler@microsoft.com>, "Eggert, Lars" <lars@netapp.com>, "tsv-ads@ietf.org" <tsv-ads@ietf.org>, "tcpm-chairs@ietf.org" <tcpm-chairs@ietf.org>, RFC Errata System <rfc-editor@rfc-editor.org>
To: Martin Duke <martin.h.duke@gmail.com>
References: <20210928071818.BE0D7F40865@rfc-editor.org> <96ce4984-3678-9bdf-6b76-d7ba1bd42dcc@bobbriscoe.net> <CADVnQymMRzvs_4QRuSziYXfwu6ttKfak5cv5G=eBRvX8qOQKWw@mail.gmail.com> <d1514f76-fc40-fa73-c953-efcb70fe6901@bobbriscoe.net> <abd8609d-b643-2911-f082-9ce2ebe41bbd@bobbriscoe.net> <CB870F54-4E2B-43C4-9674-7D847081D96D@fh-muenster.de> <DFE6EB68-DC06-4958-88A4-FD8ADF769226@apple.com> <618410F1.1000809@btconnect.com> <CAM4esxReBRNfkf7GJ9z44e9wNs5z4=GkLATYj5x9QW-Eo0p-iw@mail.gmail.com> <CAM4esxTg1CpxiLEQOp9_kKiY+7Do2fSiqMZRXn7n_KWB1n3dJg@mail.gmail.com>
X-Mailer: Apple Mail (2.3654.100.0.2.11)
X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.425, 18.0.790 definitions=2021-11-04_07:2021-11-03, 2021-11-04 signatures=0
Archived-At: <https://mailarchive.ietf.org/arch/msg/tcpm/qwC1citrXqsAiNbjlivwiGxTjqk>
Subject: Re: [tcpm] [Technical Errata Reported] RFC8257 (6697)
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, 04 Nov 2021 22:37:40 -0000

> 1) WindowEnd should be initialized to SND.NXT, not SND.UNA.
> 
> These are the same at the time of initialization (IIUC, entering ESTABLISHED), no? The very first ACK (if not ECE) will set WindowEnd to SND.NXT = (end of the first flight). If the first ack is ECE, then we'll run through step 9 and have an immediate cwnd adjustment with Alpha=1. ISTM there is an issue with the initial conditions in the latter case, but not one fixed by initializing to SND.NXT.

I think it is consistent to simply initialize it WindowEnd = SND.NXT, that way it is semantically correct and consistent with the future assignment in step 7.

> 2) If SEG.ACK < DCTCP.WindowEnd, it skips steps 5 through 9. It should skip 5-8 and still execute step 9.
> 
> My understanding from the paragraph after step 9 is that cwnd reduction in step 9 should be done only once per RTT, so the original text seems correct? 

Yes, the cwnd reduction is done once per RTT but there is no synchronization between update of alpha and cwnd reduction (and subsequent CWR). Meaning, we update alpha regardless of whether CE mark was received or not but we only do cwnd reduction if CE is received. So, these two independent sub-modules could have a completely different RTT cycle.

We still need to do what Bob said,
So, steps 5-8 really needed to be sub-bullets of step 4. And step 9 would be renumbered step 5.

> 3) Step 9 should only apply when the ECE flag is set.
> 
> As this suggests the rule would only apply if the last ack in the window was ECE, I think the correct condition would be M > 0 (i.e. something was marked in the past window)
No. As I said above, the update of alpha is separate from cwnd reduction due to ECE. So, we still need to say in step 9, if ECE was received…


Combining all the suggestions from the email, below is how I put it together,

CURRENT:
========
   9.  Rather than always halving the congestion window as described in
       [RFC3168], the sender SHOULD update cwnd as follows:
 
          cwnd = cwnd * (1 - DCTCP.Alpha / 2)
 
   Just as specified in [RFC3168], DCTCP does not react to congestion
   indications more than once for every window of data.  The setting of
   the CWR bit is also as per [RFC3168].  This is required for
   interoperation with classic ECN receivers due to potential
   misconfigurations.
 
3.4.  Handling of Congestion Window Growth...
 
SUGGESTED:
==========
Steps 5-8 are sub-parts of step 4, i.e. steps 5, 6, 7 and 8 are 4.1, 4.2, 4.3 and 4.4 respectively and these should be followed if condition specified in step 4 is true. Step 9 is renumbered as step 5 which is followed independent of condition in step 4.
5. Rather than always halving the congestion window as described in
   [RFC3168], on the arrival of congestion feedback, the sender SHOULD 
   update cwnd as follows:
 
      cwnd = cwnd * (1 - DCTCP.Alpha / 2)
   Just as specified in [RFC3168], DCTCP does not react to congestion
   indications more than once for every window of data. Therefore, as 
   for RFC3168 ECN, it sets the variable for the end of congestion
   window reduced (CWR) state to SND.NXT and suppresses further
   reductions until this TCP sequence number is acknowledged. Periods
   of CWR state are triggered by congestion feedback, and therefore
   occur at times unrelated to the continuous cycle of observation
   windows used to update DCTCP.Alpha in step 4.
 
   The setting of the CWR bit is also as per [RFC3168].  This is 
   required for interoperation with classic ECN receivers due to 
   potential misconfigurations.

——————————

Looking forward to hear from others to refine the text.

Thanks,
Vidhi


> On Nov 4, 2021, at 2:54 PM, Martin Duke <martin.h.duke@gmail.com> wrote:
> 
> As someone who hasn't implemented DCTCP, I'd like to understand the proposed changes. While there's some editorial rearranging, which is usually not good grounds for a verified errata, there are three concrete concerns I see in the thread.
> 
> 1) WindowEnd should be initialized to SND.NXT, not SND.UNA.
> 
> These are the same at the time of initialization (IIUC, entering ESTABLISHED), no? The very first ACK (if not ECE) will set WindowEnd to SND.NXT = (end of the first flight). If the first ack is ECE, then we'll run through step 9 and have an immediate cwnd adjustment with Alpha=1. ISTM there is an issue with the initial conditions in the latter case, but not one fixed by initializing to SND.NXT.
> 
> 2) If SEG.ACK < DCTCP.WindowEnd, it skips steps 5 through 9. It should skip 5-8 and still execute step 9.
> 
> My understanding from the paragraph after step 9 is that cwnd reduction in step 9 should be done only once per RTT, so the original text seems correct? 
> 
> 3) Step 9 should only apply when the ECE flag is set.
> 
> As this suggests the rule would only apply if the last ack in the window was ECE, I think the correct condition would be M > 0 (i.e. something was marked in the past window)
> 
> If I've missed a concern or mangled one of the three listed, don't hesitate to speak up!
> 
> Martin
> 
> On Thu, Nov 4, 2021 at 1:38 PM Martin Duke <martin.h.duke@gmail.com <mailto:martin.h.duke@gmail.com>> wrote:
> Yes, I'm the one to apply the erratum to the RFC.
> 
> The rfc-editor page presents both the original and corrected version of the RFC. A future RFC that obsoletes this one would be expected to incorporate all verified errata.
> 
> On Thu, Nov 4, 2021 at 9:57 AM t petch <ietfa@btconnect.com <mailto:ietfa@btconnect.com>> wrote:
> n 04/11/2021 00:37, Vidhi Goel wrote:
> >>> The status of this erratum is 'Reported'. I think some consensus was reached on the list. What happens now? Who is meant to propose updated text for the erratum based on the discussion?
> >> Hi Bob,
> >>
> >> as far as I know, the WG chairs can't change erratas. That might be possible for AD, I think,
> >> but I'm not sure.
> >
> > I am a bit new to the errata process and would like to understand a bit more about next steps. Based on Bob’s suggestion about updated text and feedback from others, how do we proceed to make the necessary change to the RFC 8257?
> > Is the only thing we can do now is somehow update the Suggestion in errata itself? When would the update me applied to the RFC?
> 
> 
> The usual form of an Erratum is along the lines of
> OLD
> <current text>
> NEW
> <proposed text>
> Note
> Section 31.102 is ambiguous and could be interpreted as ... or .... 
> This erratum .....
> 
> 
> Discussion may result in a better version of <proposed text> in which 
> case the usual practice is to reject the Erratum and craft a new one.
> 
> ADs sometimes add notes explaining why the action that is being taken is 
> being taken but I think it unusual for an AD to do more than that.
> 
> This Erratum I do not understand and so would reject.  What is the
> problem?  What is the fix?
> 
> As others have said, an Erratum cannot change the consensus expressed in 
> the RFC.  The RFC is immutable.  A change of meaning is a new RFC.
> 
> Perhaps discuss on the list what you perceive the problem to be and if 
> there is consensus that there is a problem and that it falls within the 
> limited scope of an Erratum, then craft an Erratum.
> 
> Tom Petch
> 
> > Thanks,
> > Vidhi
> >
> >> On Nov 3, 2021, at 12:02 PM, tuexen@fh-muenster.de <mailto:tuexen@fh-muenster.de> wrote:
> >>
> >>> On 3. Nov 2021, at 19:09, Bob Briscoe <ietf@bobbriscoe.net <mailto:ietf@bobbriscoe.net>> wrote:
> >>>
> >>> TCPM chairs,
> >>>
> >>> The status of this erratum is 'Reported'. I think some consensus was reached on the list. What happens now? Who is meant to propose updated text for the erratum based on the discussion?
> >> Hi Bob,
> >>
> >> as far as I know, the WG chairs can't change erratas. That might be possible for AD, I think,
> >> but I'm not sure.
> >>
> >> Best regards
> >> Michael
> >>>
> >>>
> >>> Bob
> >>>
> >>> On 01/10/2021 14:12, Bob Briscoe wrote:
> >>>> Neal,
> >>>>
> >>>> On 30/09/2021 16:43, Neal Cardwell wrote:
> >>>>> I agree with the points made by Vidhi and Bob, and really like Bob's text.
> >>>>>
> >>>>> In the suggested text there may be a typo; I believe we want s/SND.UNA/SND.NXT/.
> >>>>
> >>>> [BB] Agree (and your next point about solely ECN indications).
> >>>>
> >>>> I only said SND.UNA 'cos I was looking back at this earlier sentence in the RFC, and I copied the idea without engaging brain:
> >>>>    o  DCTCP.WindowEnd: the TCP sequence number threshold when one
> >>>>       observation window ends and another is to begin; initialized to
> >>>>       SND.UNA.
> >>>>
> >>>> Why does this say SND.UNA? Is this another erratum? I believe the Linux code initializes to SND.NXT in dctcp_reset(), which is called from dctcp_init():
> >>>> https://elixir.bootlin.com/linux/v4.7/source/net/ipv4/tcp_dctcp.c#L78 <https://elixir.bootlin.com/linux/v4.7/source/net/ipv4/tcp_dctcp.c#L78>
> >>>>
> >>>> BTW, step 7 correctly says SND.NXT:
> >>>>    7.  Determine the end of the next observation window:
> >>>>
> >>>>           DCTCP.WindowEnd = SND.NXT
> >>>>
> >>>>
> >>>>
> >>>>
> >>>> Bob
> >>>>
> >>>>> And probably we want to be more specific about only suppressing further ECN-based reductions (further loss-triggered reductions would be good to allow). I'm posting my suggested tweaks in blue, starting from Bob's nice green text:
> >>>>>
> >>>>> SUGGESTED:
> >>>>> ==========
> >>>>>
> >>>>> 3.4. Congestion Window Reduction
> >>>>>    Rather than always halving the congestion window as described in
> >>>>>    [RFC3168]
> >>>>> , on the arrival of ECN congestion feedback,
> >>>>> the sender SHOULD
> >>>>>    update cwnd as follows:
> >>>>>
> >>>>>       cwnd = cwnd * (1 - DCTCP.Alpha / 2)
> >>>>>
> >>>>>    Just as specified in [RFC3168], DCTCP does not react to congestion
> >>>>>    indications more than once for every window of data.
> >>>>> Therefore, as
> >>>>>    for RFC3168 ECN, it sets the variable for the end of congestion
> >>>>>    window reduced (CWR) state to
> >>>>> SND.NXT
> >>>>> and suppresses further
> >>>>>
> >>>>> ECN-triggered
> >>>>> reductions until this TCP sequence number is acknowledged. Periods
> >>>>>    of CWR state are triggered by congestion feedback, and therefore
> >>>>>    occur at times unrelated to the continuous cycle of observation
> >>>>>    windows used to update DCTCP.Alpha in Section 3.3.
> >>>>>
> >>>>>
> >>>>>    The setting of the CWR bit is also as per [RFC3168].  This is
> >>>>>    required for interoperation with classic ECN receivers due to
> >>>>>    potential misconfigurations.
> >>>>>
> >>>>> 3.
> >>>>> 5.  Handling of Congestion Window Growth...
> >>>>>
> >>>>> neal
> >>>>>
> >>>>>
> >>>>> On Thu, Sep 30, 2021 at 11:22 AM Bob Briscoe <in@bobbriscoe.net <mailto:in@bobbriscoe.net>> wrote:
> >>>>> Vidhi,
> >>>>>
> >>>>> You're right. It's incorrect to have the window reduction hanging off the end of the list of steps for updating the EWMA.
> >>>>>
> >>>>> To make this concrete, here's some specific additional text (in green for those with HTML mail readers). Also, rather than splitting into sub-subsections, I have suggested that Item 9. of the list in subsection 3.3 is moved out of the list, and instead forms the basis of a new subsection 3.4. entitled "Congestion Window Reduction".
> >>>>>
> >>>>> CURRENT:
> >>>>> ========
> >>>>>    9.  Rather than always halving the congestion window as described in
> >>>>>        [RFC3168], the sender SHOULD update cwnd as follows:
> >>>>>
> >>>>>           cwnd = cwnd * (1 - DCTCP.Alpha / 2)
> >>>>>
> >>>>>    Just as specified in [RFC3168], DCTCP does not react to congestion
> >>>>>    indications more than once for every window of data.  The setting of
> >>>>>    the CWR bit is also as per [RFC3168].  This is required for
> >>>>>    interoperation with classic ECN receivers due to potential
> >>>>>    misconfigurations.
> >>>>>
> >>>>>
> >>>>> 3.4
> >>>>> .  Handling of Congestion Window Growth...
> >>>>>
> >>>>>
> >>>>> SUGGESTED:
> >>>>> ==========
> >>>>>
> >>>>> 3.4. Congestion Window Reduction
> >>>>>    Rather than always halving the congestion window as described in
> >>>>>    [RFC3168]
> >>>>> , on the arrival of congestion feedback,
> >>>>> the sender SHOULD
> >>>>>    update cwnd as follows:
> >>>>>
> >>>>>       cwnd = cwnd * (1 - DCTCP.Alpha / 2)
> >>>>>
> >>>>>    Just as specified in [RFC3168], DCTCP does not react to congestion
> >>>>>    indications more than once for every window of data.
> >>>>> Therefore, as
> >>>>>    for RFC3168 ECN, it sets the variable for the end of congestion
> >>>>>    window reduced (CWR) state to SND.UNA and suppresses further
> >>>>>    reductions until this TCP sequence number is acknowledged. Periods
> >>>>>    of CWR state are triggered by congestion feedback, and therefore
> >>>>>    occur at times unrelated to the continuous cycle of observation
> >>>>>    windows used to update DCTCP.Alpha in Section 3.3.
> >>>>>
> >>>>>
> >>>>>    The setting of the CWR bit is also as per [RFC3168].  This is
> >>>>>    required for interoperation with classic ECN receivers due to
> >>>>>    potential misconfigurations.
> >>>>>
> >>>>>
> >>>>> 3.5.  Handling of Congestion Window Growth...
> >>>>>
> >>>>> Then the of numbering all subsequent subsections of section 3. will increment by 0.1.
> >>>>>
> >>>>>
> >>>>>
> >>>>> Bob
> >>>>>
> >>>>> On 28/09/2021 08:18, RFC Errata System wrote:
> >>>>>> The following errata report has been submitted for RFC8257,
> >>>>>> "Data Center TCP (DCTCP): TCP Congestion Control for Data Centers".
> >>>>>>
> >>>>>> --------------------------------------
> >>>>>> You may review the report below and at:
> >>>>>>
> >>>>>> https://www.rfc-editor.org/errata/eid6697 <https://www.rfc-editor.org/errata/eid6697>
> >>>>>>
> >>>>>>
> >>>>>> --------------------------------------
> >>>>>> Type: Technical
> >>>>>> Reported by: Vidhi Goel
> >>>>>> <vidhi_goel@apple.com <mailto:vidhi_goel@apple.com>>
> >>>>>>
> >>>>>>
> >>>>>> Section: 3.3
> >>>>>>
> >>>>>> Original Text
> >>>>>> -------------
> >>>>>> The below pseudocode follows after DCTCP.Alpha is updated on ACK processing. This is wrong as cwnd should only be reduced using DCTCP.Alpha when ECE is received.
> >>>>>>
> >>>>>> 9. Rather than always halving the congestion window as described in
> >>>>>>        [RFC3168], the sender SHOULD update cwnd as follows:
> >>>>>>
> >>>>>>           cwnd = cwnd * (1 - DCTCP.Alpha / 2)
> >>>>>>
> >>>>>> Corrected Text
> >>>>>> --------------
> >>>>>> Instead, a new paragraph for Congestion Response to ECN feedback would be much clearer. First start with RFC 3168's response to ECE and then provide DCTCP's response to ECE.
> >>>>>>
> >>>>>> I am thinking splitting section 3.3 into two sub-sections -
> >>>>>> 3.3.1 Computation of DCTCP.Alpha
> >>>>>> 3.3.2 Congestion Response to ECE at sender
> >>>>>>
> >>>>>>
> >>>>>>
> >>>>>> Notes
> >>>>>> -----
> >>>>>> Although RFC 8257 refers to RFC 3168 congestion window halving at step 9, but it is confusing to put it right after step 8.
> >>>>>>
> >>>>>> Instructions:
> >>>>>> -------------
> >>>>>> This erratum is currently posted as "Reported". If necessary, please
> >>>>>> use "Reply All" to discuss whether it should be verified or
> >>>>>> rejected. When a decision is reached, the verifying party
> >>>>>> can log in to change the status and edit the report, if necessary.
> >>>>>>
> >>>>>> --------------------------------------
> >>>>>> RFC8257 (draft-ietf-tcpm-dctcp-10)
> >>>>>> --------------------------------------
> >>>>>> Title               : Data Center TCP (DCTCP): TCP Congestion Control for Data Centers
> >>>>>> Publication Date    : October 2017
> >>>>>> Author(s)           : S. Bensley, D. Thaler, P. Balasubramanian, L. Eggert, G. Judd
> >>>>>> Category            : INFORMATIONAL
> >>>>>> Source              : TCP Maintenance and Minor Extensions
> >>>>>> Area                : Transport
> >>>>>> Stream              : IETF
> >>>>>> Verifying Party     : IESG
> >>>>>>
> >>>>>> _______________________________________________
> >>>>>> tcpm mailing list
> >>>>>>
> >>>>>> tcpm@ietf.org <mailto:tcpm@ietf.org>
> >>>>>> https://www.ietf.org/mailman/listinfo/tcpm <https://www.ietf.org/mailman/listinfo/tcpm>
> >>>>>
> >>>>> --
> >>>>> ________________________________________________________________
> >>>>> Bob Briscoe
> >>>>> http://bobbriscoe.net/ <http://bobbriscoe.net/>
> >>>>> _______________________________________________
> >>>>> tcpm mailing list
> >>>>> tcpm@ietf.org <mailto:tcpm@ietf.org>
> >>>>> https://www.ietf.org/mailman/listinfo/tcpm <https://www.ietf.org/mailman/listinfo/tcpm>
> >>>>
> >>>> --
> >>>> ________________________________________________________________
> >>>> Bob Briscoe
> >>>> http://bobbriscoe.net/ <http://bobbriscoe.net/>
> >>>
> >>> --
> >>> ________________________________________________________________
> >>> Bob Briscoe
> >>> http://bobbriscoe.net/ <http://bobbriscoe.net/>
> >>
> >
> >
> >
> > _______________________________________________
> > tcpm mailing list
> > tcpm@ietf.org <mailto:tcpm@ietf.org>
> > https://www.ietf.org/mailman/listinfo/tcpm <https://www.ietf.org/mailman/listinfo/tcpm>
> >