Re: [tcpm] [EXTERNAL] Re: hystart++

Yi Huang <huanyi@microsoft.com> Wed, 12 January 2022 00:25 UTC

Return-Path: <huanyi@microsoft.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 25BF43A1805 for <tcpm@ietfa.amsl.com>; Tue, 11 Jan 2022 16:25:35 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -2.676
X-Spam-Level:
X-Spam-Status: No, score=-2.676 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIMWL_WL_HIGH=-0.576, 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_PASS=-0.001, URIBL_BLOCKED=0.001] autolearn=ham autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (1024-bit key) header.d=microsoft.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 KzjPjdX-BRid for <tcpm@ietfa.amsl.com>; Tue, 11 Jan 2022 16:25:29 -0800 (PST)
Received: from na01-obe.outbound.protection.outlook.com (mail-eus2azon11021026.outbound.protection.outlook.com [52.101.57.26]) (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 778BE3A1806 for <tcpm@ietf.org>; Tue, 11 Jan 2022 16:25:27 -0800 (PST)
ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=I3I0csZA42vY7+wTFV0cYy5XLR+1PsCdNLwpePZQvOXM7ljZRMmhUu0JF/GeHESWNE9wZ2qJCfFbsLwQC2Onm8F66tybwBgkg1CKB+fLEa70FfDPUzxeNRDKuBNx5TQkyQyUDjci32VePbFQ8XqH/Oku5gPbAVpTvs/svqgW6vDfY4xkksfDgYw1NlaBZcuUG8UzKY9YILjWSezVPHj90f5BA1t7LLCRN1JKxMNd042JmhH7V/tY6oL2CBiYEkGziieJ8o1rNP3YthajkED5lxm/oTbKU1AOk/qvmX6feOTzltf/Uf2yz2LtEbpqDrWWLTS+j5Qcee4CO6ScYhyVmg==
ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=yQ6H8D73ZIB5Z7NNdpTV0CRVEqhiL3Nv0VH1pBty8Ig=; b=TECXVujbAHTwfA7msURz1x8DPQvSNrIyFjwh5nL7VEpBVAFMjgwfXfmoUwLJ6EfD93bMwfcbaumoytXTb0jWGyB0caSNtaE/Tm/Rv5kz0FbA79/wKEKWx+SwZ4hEyB+ru8Bew0+hIa9aD24rYIQUBWCZHod8JaOwRxe3owibN5OxXMdy7SB3LWoHe+ljqqVuV3gFy8nXu7dxS+F50q3RkYsDt58W4X69KV1dZRtV0qIjJoSXpilETPxWfsTE62ebJM7VG68HCv36PVlhTFv9TIaK/Ns9GaZxA/mAX9whjuhbsRFdHkD8XVdJYlGkmXFTNANm8iScCOfwy0pZFGh6jg==
ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=microsoft.com; dmarc=pass action=none header.from=microsoft.com; dkim=pass header.d=microsoft.com; arc=none
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=yQ6H8D73ZIB5Z7NNdpTV0CRVEqhiL3Nv0VH1pBty8Ig=; b=A0JVkcvGjdAbrQUR7QhMQUt3H5O3FmyxBwkEllO1V7DOcgdPtNtlEgvPy7avwW/cNWXis7anMvlAORFeGVcKaoG7+j4Nly9P0P08MBD26YI7O7pM/+Sw8HylDhlA7CSdO33c+s4Hat+qbUjl0jrEZ+yKvUvx5+tPRR19sXTN5gs=
Received: from PH0PR00MB1331.namprd00.prod.outlook.com (2603:10b6:510:10e::24) by PH0PR00MB1213.namprd00.prod.outlook.com (2603:10b6:510:9d::5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4914.0; Wed, 12 Jan 2022 00:25:20 +0000
Received: from PH0PR00MB1331.namprd00.prod.outlook.com ([fe80::291a:436c:58a:a95e]) by PH0PR00MB1331.namprd00.prod.outlook.com ([fe80::291a:436c:58a:a95e%9]) with mapi id 15.20.4925.000; Wed, 12 Jan 2022 00:25:20 +0000
From: Yi Huang <huanyi@microsoft.com>
To: Randall Stewart <rrs=40netflix.com@dmarc.ietf.org>, Neal Cardwell <ncardwell=40google.com@dmarc.ietf.org>
CC: "tcpm@ietf.org" <tcpm@ietf.org>
Thread-Topic: [EXTERNAL] Re: [tcpm] hystart++
Thread-Index: AQHX57Ugsm+coqMjyUun5bRHXnr1u6wfoXYAgD8jutQ=
Date: Wed, 12 Jan 2022 00:25:20 +0000
Message-ID: <PH0PR00MB1331786C9CC3A5721EEBC1E2C3529@PH0PR00MB1331.namprd00.prod.outlook.com>
References: <D8D48D50-6143-49D5-B3D8-C1888FFE33EB@netflix.com> <CADVnQyk1=JO-yt_MThxLCZ2kr951ia7HQT-GoSX0o34+EcOQ0w@mail.gmail.com> <E177EAF0-3DD7-4137-A293-8C033A890C65@netflix.com>
In-Reply-To: <E177EAF0-3DD7-4137-A293-8C033A890C65@netflix.com>
Accept-Language: en-US
Content-Language: en-US
X-MS-Has-Attach: yes
X-MS-TNEF-Correlator:
msip_labels: MSIP_Label_f42aa342-8706-4288-bd11-ebb85995028c_Enabled=True; MSIP_Label_f42aa342-8706-4288-bd11-ebb85995028c_SiteId=72f988bf-86f1-41af-91ab-2d7cd011db47; MSIP_Label_f42aa342-8706-4288-bd11-ebb85995028c_SetDate=2022-01-12T00:25:18.598Z; MSIP_Label_f42aa342-8706-4288-bd11-ebb85995028c_Name=General; MSIP_Label_f42aa342-8706-4288-bd11-ebb85995028c_ContentBits=0; MSIP_Label_f42aa342-8706-4288-bd11-ebb85995028c_Method=Standard;
authentication-results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=microsoft.com;
x-ms-publictraffictype: Email
x-ms-office365-filtering-correlation-id: 7dbcc4e9-eb90-4198-f6b2-08d9d562042c
x-ms-traffictypediagnostic: PH0PR00MB1213:EE_
x-ms-exchange-atpmessageproperties: SA|SL
x-microsoft-antispam-prvs: <PH0PR00MB121331125ED5A97F1BE54D65C3529@PH0PR00MB1213.namprd00.prod.outlook.com>
x-ms-oob-tlc-oobclassifiers: OLM:1728;
x-ms-exchange-senderadcheck: 1
x-ms-exchange-antispam-relay: 0
x-microsoft-antispam: BCL:0;
x-microsoft-antispam-message-info: va7IkoZP6C+iN5M4jCxgVQzkTEv5C89n7qm2lmmHOJ5CoeAbw1+Mg3hsrl2LF63ulyTdNzxpC0FjZkovti1x3zKrD9CTVTnb/ZZI0pXFoBybcun+QprWwLUDkZrOGGcVHK7zxdLKxsCqnZcn+Sn0V96dW3ozMy/ayZEwDKTtljgxg/tTEkFaWctPZ6jXX+kLREqfurN+32m1/x8+yaOtb9RSWDXgxkd7XmcL/Er45+WTxuhaQU7WD8zbJzDmVeBygc1kZOOlaAmOhOdeM+chwa2/mpOzIZbP2NDRpVgrf9mGf0RQLFYSVVh2Qi2iI2lOfNPyCWFayVZ5Lm7Nhvhs+BYBHmfAwKC4q3n8DM4fPU1j3lUI4/MF2GisWdGvn8ZoaPJCB9AT+PXj85CTt6240gH5/ggstUrZ0yDvzDOroD4wkDgeLdZe74g3wvpXMeu8LZ4G9znf3Lni+7wQsXLgr+uf/ExNjw28UvHKtVPKnsPMWZC+NN75wiH/owvUXVeyCRAS0XZWAB3w/A0vrToBUEI+Z67eZDMQM2suuFlZYpf4yteuWTd5F9Dq/D8TYEn0f0UyOa4rHpeY+sc2hzXIpIyxZhkoEO3jjppJFMygg7qAmjP+04FkhNkpUrZC/aHmJHIunCy2H1wBLpso3WWrUrlDlqhWX5z3mu/gsBHV6l/MFs08s9tx8aDjMtJRpB3suYhW/Nduqkm8QsEZlOipMcfcxiaKuKNgkd78aROQ6XYtItel6aaS3P+vDA7cyiVMzoItESWIFOOvHvURl2aMU+JDHJVyTXyMSypQACRkpTU5CVVMzzHqQyTe1Dls8gPZKqT+Hh/+aq9Kd3B/FXx/xkQaOE/XxRBey8KTEmH1BmqPNwQ6U6Jh2TI9VkPbkdE+
x-forefront-antispam-report: CIP:255.255.255.255; CTRY:; LANG:; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:PH0PR00MB1331.namprd00.prod.outlook.com; PTR:; CAT:NONE; SFS:(13230001)(4636009)(366004)(9686003)(316002)(83380400001)(5660300002)(186003)(38100700002)(6506007)(53546011)(66476007)(4326008)(66946007)(8936002)(66446008)(7696005)(99936003)(19627405001)(8676002)(64756008)(166002)(38070700005)(8990500004)(33656002)(82950400001)(82960400001)(966005)(52536014)(86362001)(71200400001)(76116006)(122000001)(508600001)(110136005)(55016003)(10290500003)(66556008)(2906002)(10090945008)(20210929001); DIR:OUT; SFP:1102;
x-ms-exchange-antispam-messagedata-chunkcount: 1
x-ms-exchange-antispam-messagedata-0: yR+/68Z8FKDnBsrbfSb6UOyHj3QVc0ADtFwhxHFdyA/5ckuHNUqbPtZWuuOkmMBbwMf3CqiUyyRy5Pw3fIvsmIVMpu6EZu3E4kIrkscmBT/qGmhIZTv1QwJlR2aXVxmlAaJRLIK/hwFhQH4S63tzicF8ebXNmj/KD3xGkxn83XPZy3RGRoZzPvvod7YC2Txq2ZnYC90C/+Il7ULIpbfD0sAMedFp/TXs7rD5/0zDK6BfBiAB8fwfW14QOCLIQf7aypoR4hKiJHDpLnIgGZmzkvIJxxzrk6jSIM0pqbedZs1NnMDbvex42dF1spr7FI5f7SuKlkJZBZoWDfSg9h1jgWfY43H8HQu+BF7DTIOZsJn0fN3BmvoDMW8+6MyY2z6p/IvjA727rUhOdg1Ra3xjje21bL9YXcl+/5l4OGbsjWqx7cKFE11xexzFaI2MWoHfF1jLvZGQX/93EayBv7eNcdCknNppXv7rscSy6lCUNyl5hkOuiQB/3T5m3ovnEsMzi8n2qvoUXGDQu7wPnwm3Wdqn5fW0uIvAcEey2Oc+Bge2HeR2ZbhOPadsYr4y961IuWrIKxwPN8v/EkfSUvqCD+D9S1/7SfliJ7BdLbYke+XZqW4oQ2anUUY2itmV4k6AYzhn6D9YiW8rIR1RSASrClUlPwoVN4ojCoYre5CfXrdpTvxwfNORDwG3nk5RK7o3jhmm8p9yCjKyZsWdL6mzwEJijdzX7BynTnsXF3KxzjW8z1uH40VI0+Z8dSEp1E9DeHVihs0l6n0wMUyvREJDgTLRF8k0kfu9W1KrPmK7+lELMs6QNzugR4HTKpFWkOK9ubP8EId7T6DCjgPh4wnQB2XsoV7qT6M+1Xl8N8nUqcG6wgjF4avSJ+WN3Gd7TIsUnC+Su0t/2hYAyvYtSEJf90ar64B5GqC0dZ09OFRWGvBoyjdadLgP52s6d0i4xDLtbi8rGXA5S89TxpW8RXPOcWwLOmqEsBmxYRCkSgurBGFgASgcK/a3sPIJ5S7KdFLpU/slalCeM4/vshHBL3WsrMGSFY7nVkQCvNFCu6/hDrPrYMPa0GMFgGrQdCox4zM6HotF+sIwbBrdfejst1XmlLPf8mYDQr237wfxMmLlaTCN26CinYq8zuHvX84Q95xkskrSzQ/oHq17u96pZ+OC9FbYebnNElgLahiDSH/iRk2jKxt6+kfn+/9ofH9xk84c6gQe+o+wC+jvA53wHjfZE0tL01OE0mKnflJyr4+7cyPz5RarMQHgEn7+nw6HKWOXO8lfZf59uDclSOHdXUtri8a2HsDLwPieUVDGNtuATwXdWAo1C7FacWO4YP3Q6L7Of3FCOMlHUqTSIwKaTiet6KmyND4aBB7MWfSLqEXkaT+EVTcjcwf7j1/uKqJy7tvG20CxdRjcpxk/+SMaY5jHT4YEmPmlcCh9hyGQQh0Vd719SZGKTyX9/5W1Obkf6teKt2ba6qqRq44Ei2tgN06+7C09WUc/RJyY4y4DhYbCnB9O29umCJixdfUzvVqnQrdDqETjqj/y0sjYLStQcNHCjgwAPKJDx5AtZdZo4kvhS1ki4g7fSr3k7mTe73+W+beCfl+IO0Nj+h1UcWKPONH2s5zx8VW4ijd9GOxtz1QnhPapHQgjfU2I9ECxsPDeE2E4m4Qb1sPjYFkwzhfJg/RWfg==
Content-Type: multipart/related; boundary="_004_PH0PR00MB1331786C9CC3A5721EEBC1E2C3529PH0PR00MB1331namp_"; type="multipart/alternative"
MIME-Version: 1.0
X-OriginatorOrg: microsoft.com
X-MS-Exchange-CrossTenant-AuthAs: Internal
X-MS-Exchange-CrossTenant-AuthSource: PH0PR00MB1331.namprd00.prod.outlook.com
X-MS-Exchange-CrossTenant-Network-Message-Id: 7dbcc4e9-eb90-4198-f6b2-08d9d562042c
X-MS-Exchange-CrossTenant-originalarrivaltime: 12 Jan 2022 00:25:20.1919 (UTC)
X-MS-Exchange-CrossTenant-fromentityheader: Hosted
X-MS-Exchange-CrossTenant-id: 72f988bf-86f1-41af-91ab-2d7cd011db47
X-MS-Exchange-CrossTenant-mailboxtype: HOSTED
X-MS-Exchange-CrossTenant-userprincipalname: +lX/Ld5d+z0XdY4RHdJ7KxJsRH1zRmeui1kZERh7FBlZv+6EdXrs1pSTvRiYCf0AbR6i7kanjdN8Sod7a+lA4Q==
X-MS-Exchange-Transport-CrossTenantHeadersStamped: PH0PR00MB1213
Archived-At: <https://mailarchive.ietf.org/arch/msg/tcpm/j6rb1YJ3wShddIs7vqMlc3poiiw>
X-Mailman-Approved-At: Wed, 12 Jan 2022 08:07:00 -0800
Subject: Re: [tcpm] [EXTERNAL] Re: hystart++
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: Wed, 12 Jan 2022 00:25:35 -0000

Hi Neal and Randall,



We implemented the suggested "set cssBaseLineMinRTT to (lastRoundMinRtt + RttThresh)" and we did an A/B test over our own emulated WAN test cases. We noticed that there's a regression in scenarios with latency jitters as you can see in the below graph. Mitigating spurious Hystart exit was why we invented CSS. Based on these results we concluded that the current draft algorithm is the better choice.



This is how we define test cases:

100ms,100Mbps,1250pkt,64000B,2000,50jitms,5jitdiv

=>

100ms RTT, 100Mbps bottleneck bandwidth, bottleneck queue length 1250 packets, IO size 64KB, IO count 2000, 50ms latency jitter, 1/5 jitter probability per packet





[cid:a108063c-37fa-402f-b920-c116fab108e9]



>> One option would be to track the maximum number of packets delivered in a round of slow-start (slowStartMaxDeliveredPackets), and only check for spurious Hystart++ exits if the most recent round of >> CSS has at least slowStartMaxDeliveredPackets delivered. Something like:

>>- if (currentRoundDeliveredPackets >= slowStartMaxDeliveredPackets &&

>>      currentRoundMinRTT < cssBaselineMinRtt)

>>

>>         o  cssBaselineMinRtt = infinity

>>

>>         o  resume slow start including HyStart++



We have not tried this but it requires rounds to be well aligned with RTTs. E.g. if one round takes about 2 RTTs and the other round takes 0.5 RTT, it won't consistently work.



Thanks,



Yi

________________________________
From: tcpm <tcpm-bounces@ietf.org> on behalf of Randall Stewart <rrs=40netflix.com@dmarc.ietf.org>
Sent: Thursday, December 2, 2021 12:08 PM
To: Neal Cardwell <ncardwell=40google.com@dmarc.ietf.org>
Cc: tcpm@ietf.org <tcpm@ietf.org>; Randall Stewart <rrs=40netflix.com@dmarc.ietf.org>
Subject: [EXTERNAL] Re: [tcpm] hystart++

[Some people who received this message don't often get email from rrs=40netflix.com@dmarc.ietf.org. Learn why this is important at http://aka.ms/LearnAboutSenderIdentification.]

Neal:

Great observation!!

> On Dec 2, 2021, at 2:43 PM, Neal Cardwell <ncardwell=40google.com@dmarc.ietf.org> wrote:
>
> Thanks, Randall. That's a nice analysis, and I agree that your proposal sounds like a nice improvement.
>
> This nice analysis brings to mind another potential (related) issue that might cause spurious oscillations: after Hystart++ exits slow-start, if there are application-limited periods where the amount of data in flight falls below the BDP (e.g. flow goes idle and then restarts), then we would expect the currentRoundMinRTT to be very low, triggering a resumption of slow-start in the current logic, even if the Hystart++ exit of slow-start was correct.
>

I have actually seen this occur.. in fact I was wondering how I was going to test
dropping back out in my lab (was thinking packet drill) and then my logging noted
that it had happened.. and it was because nginx had taken a 25ms break in applying
data .. RTT was 20ms so the whole network went idle by the time the buffer was refilled and
thus a bounce out and back in later :)

> It seems that the connection should not use a data ACK's RTT sample to estimate whether Hystart++ exit was spurious unless the amount of data in flight at the time that data was sent was "sufficiently large". How to define "sufficiently large" may be a little tricky (the cwnd is probably not a good gauge for "sufficiently large" since it is probably somewhere out beyond twice the BDP in CSS).
>

Yeah I was wondering if we might not want to adjust exit based on some other
metric in app limited cases...

> One option would be to track the maximum number of packets delivered in a round of slow-start (slowStartMaxDeliveredPackets), and only check for spurious Hystart++ exits if the most recent round of CSS has at least slowStartMaxDeliveredPackets delivered. Something like:
>
> - if (currentRoundDeliveredPackets >= slowStartMaxDeliveredPackets &&
>       currentRoundMinRTT < cssBaselineMinRtt)
>
>          o  cssBaselineMinRtt = infinity
>
>          o  resume slow start including HyStart++


That sounds like a very good adjustment.. I will maybe prototype it in my
lab and see if I can recreate the bounce I saw and see how well it works ;)

Best

R

>
> best regards,
> neal
>
>
>
>
>
>
> On Thu, Dec 2, 2021 at 1:46 PM Randall Stewart <rrs=40netflix.com@dmarc.ietf.org> wrote:
> Greetings all:
>
> I have implemented hystart++ off of the draft-03 for FreeBSD
> (both newreno and cubic) and I have noted one thing that I think
> is a bug in the spec:
>
> Draft-03 currently says:
>
>
>
>         o  if (currentRoundMinRTT >= (lastRoundMinRTT + RttThresh))
>
>            +  cssBaselineMinRtt = currentRoundMinRTT
>
>            +  exit slow start and enter CSS
>
>
> <And>
>
>
>
>      -  if (currentRoundMinRTT < cssBaselineMinRtt)
>
>         o  cssBaselineMinRtt = infinity
>
>         o  resume slow start including HyStart++
>
>
>
> But notice that the threshold for entering CSS is (lastRoundMinRtt + RttThresh) and
> the exiting of CSS back to Slow Start is (currentRoundMinRTT < cssBaseLineMinRTT), which can
> under the right circumstances set up an oscillation. In the case I observed I saw lastRoundMinRtt set
> to like 63ms and currentRoundMinRtt set at 115ms. And the next RTT in was 114ms.. so out of
> CSS into Slow Start, but the next measurement (114ms again) pushes you back into CSS since
> the lastRoundMinRTT + RttThresh is around 63ms or so.
>
> I would think what you really want here is to set cssBaseLineMinRTT to (lastRoundMinRtt + RttThresh).
>
> I.e. on entry:
>
>
>         o  if (currentRoundMinRTT >= (lastRoundMinRTT + RttThresh))
>
>            +  cssBaselineMinRtt = (lastRoundMinRtt + RttThresh)
>
>            +  exit slow start and enter CSS
>
> R
>
> ------
> Randall Stewart
> rrs@netflix.com
>
>
>
> _______________________________________________
> tcpm mailing list
> tcpm@ietf.org
> https://nam06.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww.ietf.org%2Fmailman%2Flistinfo%2Ftcpm&amp;data=04%7C01%7Chuanyi%40microsoft.com%7Cee82df6dc2ae4362922d08d9b5cf9fae%7C72f988bf86f141af91ab2d7cd011db47%7C1%7C0%7C637740726320069237%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000&amp;sdata=1oNiudKBKYJCz50wNxM30alScXlGJDZ2QsSSH1YBqgs%3D&amp;reserved=0
> _______________________________________________
> tcpm mailing list
> tcpm@ietf.org
> https://nam06.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww.google.com%2Furl%3Fq%3Dhttps%3A%2F%2Fwww.ietf.org%2Fmailman%2Flistinfo%2Ftcpm%26source%3Dgmail-imap%26ust%3D1639079070000000%26usg%3DAOvVaw1S8xcmYu7Uv0BTPfUSlc5Z&amp;data=04%7C01%7Chuanyi%40microsoft.com%7Cee82df6dc2ae4362922d08d9b5cf9fae%7C72f988bf86f141af91ab2d7cd011db47%7C1%7C0%7C637740726320069237%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000&amp;sdata=hMIondYgA%2B6EMrvwjS6RzmnLy%2B8OKFN6WftwPmoq8tk%3D&amp;reserved=0

------
Randall Stewart
rrs@netflix.com