From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-5.3 required=3.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,NICE_REPLY_A,SPF_HELO_NONE, SPF_PASS,UNPARSEABLE_RELAY,USER_AGENT_SANE_1 autolearn=no autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 3A360C2D0A3 for ; Mon, 9 Nov 2020 16:26:47 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 03E1E206CB for ; Mon, 9 Nov 2020 16:26:46 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730185AbgKIQ0q (ORCPT ); Mon, 9 Nov 2020 11:26:46 -0500 Received: from out30-57.freemail.mail.aliyun.com ([115.124.30.57]:45871 "EHLO out30-57.freemail.mail.aliyun.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729791AbgKIQ0p (ORCPT ); Mon, 9 Nov 2020 11:26:45 -0500 X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R101e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=e01e04400;MF=wenan.mao@linux.alibaba.com;NM=1;PH=DS;RN=8;SR=0;TI=SMTPD_---0UEmInaP_1604939200; Received: from B-44NBMD6M-0121.local(mailfrom:wenan.mao@linux.alibaba.com fp:SMTPD_---0UEmInaP_1604939200) by smtp.aliyun-inc.com(127.0.0.1); Tue, 10 Nov 2020 00:26:40 +0800 Subject: Re: [PATCH net v2] net: Update window_clamp if SOCK_RCVBUF is set To: Eric Dumazet Cc: David Miller , Alexey Kuznetsov , Hideaki YOSHIFUJI , Jakub Kicinski , netdev , LKML , kernel-janitors@vger.kernel.org References: <1604913614-19432-1-git-send-email-wenan.mao@linux.alibaba.com> <1604914417-24578-1-git-send-email-wenan.mao@linux.alibaba.com> <3b92167c-201c-e85d-822d-06f0c9ac508c@linux.alibaba.com> From: Mao Wenan Message-ID: <302ad089-9e82-1856-0652-b92251c14e37@linux.alibaba.com> Date: Tue, 10 Nov 2020 00:26:40 +0800 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:78.0) Gecko/20100101 Thunderbird/78.3.2 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 在 2020/11/9 下午10:01, Eric Dumazet 写道: > On Mon, Nov 9, 2020 at 12:41 PM Eric Dumazet wrote: >> >> Packetdrill test would be : >> >> // Force syncookies >> `sysctl -q net.ipv4.tcp_syncookies=2` >> >> 0 socket(..., SOCK_STREAM, IPPROTO_TCP) = 3 >> +0 setsockopt(3, SOL_SOCKET, SO_REUSEADDR, [1], 4) = 0 >> +0 setsockopt(3, SOL_SOCKET, SO_RCVBUF, [2048], 4) = 0 >> +0 bind(3, ..., ...) = 0 >> +0 listen(3, 1) = 0 >> >> +0 < S 0:0(0) win 32792 >> +0 > S. 0:0(0) ack 1 >> +.1 < . 1:1(0) ack 1 win 1024 >> +0 accept(3, ..., ...) = 4 >> +0 %{ assert tcpi_snd_wscale == 0, tcpi_snd_wscale }% >> > > Also, please add to your next submission an appropriate Fixes: tag : > > Fixes: e88c64f0a425 ("tcp: allow effective reduction of TCP's > rcv-buffer via setsockopt") OK, thanks, I can reproduce wscale=0 with your packetdrill, and I will send v3 with the fixes tag. > >> On Mon, Nov 9, 2020 at 12:02 PM Eric Dumazet wrote: >>> >>> On Mon, Nov 9, 2020 at 11:12 AM Mao Wenan wrote: >>>> >>>> >>>> >>>> 在 2020/11/9 下午5:56, Eric Dumazet 写道: >>>>> On Mon, Nov 9, 2020 at 10:33 AM Mao Wenan wrote: >>>>>> >>>>>> When net.ipv4.tcp_syncookies=1 and syn flood is happened, >>>>>> cookie_v4_check or cookie_v6_check tries to redo what >>>>>> tcp_v4_send_synack or tcp_v6_send_synack did, >>>>>> rsk_window_clamp will be changed if SOCK_RCVBUF is set, >>>>>> which will make rcv_wscale is different, the client >>>>>> still operates with initial window scale and can overshot >>>>>> granted window, the client use the initial scale but local >>>>>> server use new scale to advertise window value, and session >>>>>> work abnormally. >>>>> >>>>> What is not working exactly ? >>>>> >>>>> Sending a 'big wscale' should not really matter, unless perhaps there >>>>> is a buggy stack at the remote end ? >>>> 1)in tcp_v4_send_synack, if SO_RCVBUF is set and >>>> tcp_full_space(sk)=65535, pass req->rsk_window_clamp=65535 to >>>> tcp_select_initial_window, rcv_wscale will be zero, and send to client, >>>> the client consider wscale is 0; >>>> 2)when ack is back from client, if there is no this patch, >>>> req->rsk_window_clamp is 0, and pass to tcp_select_initial_window, >>>> wscale will be 7, this new rcv_wscale is no way to advertise to client. >>>> 3)if server send rcv_wind to client with window=63, it consider the real >>>> window is 63*2^7=8064, but client consider the server window is only >>>> 63*2^0=63, it can't send big packet to server, and the send-q of client >>>> is full. >>>> >>> >>> I see, please change your patches so that tcp_full_space() is used _once_ >>> >>> listener sk_rcvbuf can change under us. >>> >>> I really have no idea how window can be set to 63, so please send us >>> the packetdrill test once you have it. From mboxrd@z Thu Jan 1 00:00:00 1970 From: Mao Wenan Date: Mon, 09 Nov 2020 16:26:40 +0000 Subject: Re: [PATCH net v2] net: Update window_clamp if SOCK_RCVBUF is set Message-Id: <302ad089-9e82-1856-0652-b92251c14e37@linux.alibaba.com> List-Id: References: <1604913614-19432-1-git-send-email-wenan.mao@linux.alibaba.com> <1604914417-24578-1-git-send-email-wenan.mao@linux.alibaba.com> <3b92167c-201c-e85d-822d-06f0c9ac508c@linux.alibaba.com> In-Reply-To: MIME-Version: 1.0 Content-Type: text/plain; charset="windows-1254" Content-Transfer-Encoding: base64 To: Eric Dumazet Cc: David Miller , Alexey Kuznetsov , Hideaki YOSHIFUJI , Jakub Kicinski , netdev , LKML , kernel-janitors@vger.kernel.org CgrlnKggMjAyMC8xMS85IOS4i+WNiDEwOjAxLCBFcmljIER1bWF6ZXQg5YaZ6YGTOgo+IE9uIE1v biwgTm92IDksIDIwMjAgYXQgMTI6NDEgUE0gRXJpYyBEdW1hemV0IDxlZHVtYXpldEBnb29nbGUu Y29tPiB3cm90ZToKPj4KPj4gUGFja2V0ZHJpbGwgdGVzdCB3b3VsZCBiZSA6Cj4+Cj4+IC8vIEZv cmNlIHN5bmNvb2tpZXMKPj4gYHN5c2N0bCAtcSBuZXQuaXB2NC50Y3Bfc3luY29va2llcz0yYAo+ Pgo+PiAgICAgIDAgc29ja2V0KC4uLiwgU09DS19TVFJFQU0sIElQUFJPVE9fVENQKSA9IDMKPj4g ICAgICswIHNldHNvY2tvcHQoMywgU09MX1NPQ0tFVCwgU09fUkVVU0VBRERSLCBbMV0sIDQpID0g MAo+PiAgICAgKzAgc2V0c29ja29wdCgzLCBTT0xfU09DS0VULCBTT19SQ1ZCVUYsIFsyMDQ4XSwg NCkgPSAwCj4+ICAgICArMCBiaW5kKDMsIC4uLiwgLi4uKSA9IDAKPj4gICAgICswIGxpc3Rlbigz LCAxKSA9IDAKPj4KPj4gKzAgPCBTIDA6MCgwKSB3aW4gMzI3OTIgPG1zcyAxMDAwLHNhY2tPSyxU UyB2YWwgMTAwIGVjciAwLG5vcCx3c2NhbGUgNz4KPj4gICAgICswID4gUy4gMDowKDApIGFjayAx IDxtc3MgMTQ2MCxzYWNrT0ssVFMgdmFsIDQwMDAgZWNyIDEwMCxub3Asd3NjYWxlIDA+Cj4+ICAg ICsuMSA8IC4gMToxKDApIGFjayAxIHdpbiAxMDI0IDxub3Asbm9wLFRTIHZhbCAyMDAgZWNyIDQw MDA+Cj4+ICAgICArMCBhY2NlcHQoMywgLi4uLCAuLi4pID0gNAo+PiArMCAleyBhc3NlcnQgdGNw aV9zbmRfd3NjYWxlID0gMCwgdGNwaV9zbmRfd3NjYWxlIH0lCj4+Cj4gCj4gQWxzbywgcGxlYXNl IGFkZCB0byB5b3VyIG5leHQgc3VibWlzc2lvbiBhbiBhcHByb3ByaWF0ZSBGaXhlczogdGFnIDoK PiAKPiBGaXhlczogZTg4YzY0ZjBhNDI1ICgidGNwOiBhbGxvdyBlZmZlY3RpdmUgcmVkdWN0aW9u IG9mIFRDUCdzCj4gcmN2LWJ1ZmZlciB2aWEgc2V0c29ja29wdCIpCgpPSywgdGhhbmtzLCBJIGNh biByZXByb2R1Y2Ugd3NjYWxlPTAgd2l0aCB5b3VyIHBhY2tldGRyaWxsLCBhbmQgSSB3aWxsIApz ZW5kIHYzIHdpdGggdGhlIGZpeGVzIHRhZy4KCj4gCj4+IE9uIE1vbiwgTm92IDksIDIwMjAgYXQg MTI6MDIgUE0gRXJpYyBEdW1hemV0IDxlZHVtYXpldEBnb29nbGUuY29tPiB3cm90ZToKPj4+Cj4+ PiBPbiBNb24sIE5vdiA5LCAyMDIwIGF0IDExOjEyIEFNIE1hbyBXZW5hbiA8d2VuYW4ubWFvQGxp bnV4LmFsaWJhYmEuY29tPiB3cm90ZToKPj4+Pgo+Pj4+Cj4+Pj4KPj4+PiDlnKggMjAyMC8xMS85 IOS4i+WNiDU6NTYsIEVyaWMgRHVtYXpldCDlhpnpgZM6Cj4+Pj4+IE9uIE1vbiwgTm92IDksIDIw MjAgYXQgMTA6MzMgQU0gTWFvIFdlbmFuIDx3ZW5hbi5tYW9AbGludXguYWxpYmFiYS5jb20+IHdy b3RlOgo+Pj4+Pj4KPj4+Pj4+IFdoZW4gbmV0LmlwdjQudGNwX3N5bmNvb2tpZXM9MSBhbmQgc3lu IGZsb29kIGlzIGhhcHBlbmVkLAo+Pj4+Pj4gY29va2llX3Y0X2NoZWNrIG9yIGNvb2tpZV92Nl9j aGVjayB0cmllcyB0byByZWRvIHdoYXQKPj4+Pj4+IHRjcF92NF9zZW5kX3N5bmFjayBvciB0Y3Bf djZfc2VuZF9zeW5hY2sgZGlkLAo+Pj4+Pj4gcnNrX3dpbmRvd19jbGFtcCB3aWxsIGJlIGNoYW5n ZWQgaWYgU09DS19SQ1ZCVUYgaXMgc2V0LAo+Pj4+Pj4gd2hpY2ggd2lsbCBtYWtlIHJjdl93c2Nh bGUgaXMgZGlmZmVyZW50LCB0aGUgY2xpZW50Cj4+Pj4+PiBzdGlsbCBvcGVyYXRlcyB3aXRoIGlu aXRpYWwgd2luZG93IHNjYWxlIGFuZCBjYW4gb3ZlcnNob3QKPj4+Pj4+IGdyYW50ZWQgd2luZG93 LCB0aGUgY2xpZW50IHVzZSB0aGUgaW5pdGlhbCBzY2FsZSBidXQgbG9jYWwKPj4+Pj4+IHNlcnZl ciB1c2UgbmV3IHNjYWxlIHRvIGFkdmVydGlzZSB3aW5kb3cgdmFsdWUsIGFuZCBzZXNzaW9uCj4+ Pj4+PiB3b3JrIGFibm9ybWFsbHkuCj4+Pj4+Cj4+Pj4+IFdoYXQgaXMgbm90IHdvcmtpbmcgZXhh Y3RseSA/Cj4+Pj4+Cj4+Pj4+IFNlbmRpbmcgYSAnYmlnIHdzY2FsZScgc2hvdWxkIG5vdCByZWFs bHkgbWF0dGVyLCB1bmxlc3MgcGVyaGFwcyB0aGVyZQo+Pj4+PiBpcyBhIGJ1Z2d5IHN0YWNrIGF0 IHRoZSByZW1vdGUgZW5kID8KPj4+PiAxKWluIHRjcF92NF9zZW5kX3N5bmFjaywgaWYgU09fUkNW QlVGIGlzIHNldCBhbmQKPj4+PiB0Y3BfZnVsbF9zcGFjZShzayllNTM1LCBwYXNzIHJlcS0+cnNr X3dpbmRvd19jbGFtcGU1MzUgdG8KPj4+PiB0Y3Bfc2VsZWN0X2luaXRpYWxfd2luZG93LCByY3Zf d3NjYWxlIHdpbGwgYmUgemVybywgYW5kIHNlbmQgdG8gY2xpZW50LAo+Pj4+IHRoZSBjbGllbnQg Y29uc2lkZXIgd3NjYWxlIGlzIDA7Cj4+Pj4gMil3aGVuIGFjayBpcyBiYWNrIGZyb20gY2xpZW50 LCBpZiB0aGVyZSBpcyBubyB0aGlzIHBhdGNoLAo+Pj4+IHJlcS0+cnNrX3dpbmRvd19jbGFtcCBp cyAwLCBhbmQgcGFzcyB0byB0Y3Bfc2VsZWN0X2luaXRpYWxfd2luZG93LAo+Pj4+IHdzY2FsZSB3 aWxsIGJlIDcsIHRoaXMgbmV3IHJjdl93c2NhbGUgaXMgbm8gd2F5IHRvIGFkdmVydGlzZSB0byBj bGllbnQuCj4+Pj4gMylpZiBzZXJ2ZXIgc2VuZCByY3Zfd2luZCB0byBjbGllbnQgd2l0aCB3aW5k b3djLCBpdCBjb25zaWRlciB0aGUgcmVhbAo+Pj4+IHdpbmRvdyBpcyA2MyoyXjeANjQsIGJ1dCBj bGllbnQgY29uc2lkZXIgdGhlIHNlcnZlciB3aW5kb3cgaXMgb25seQo+Pj4+IDYzKjJeMGMsIGl0 IGNhbid0IHNlbmQgYmlnIHBhY2tldCB0byBzZXJ2ZXIsIGFuZCB0aGUgc2VuZC1xIG9mIGNsaWVu dAo+Pj4+IGlzIGZ1bGwuCj4+Pj4KPj4+Cj4+PiBJIHNlZSwgcGxlYXNlIGNoYW5nZSB5b3VyIHBh dGNoZXMgc28gdGhhdCB0Y3BfZnVsbF9zcGFjZSgpIGlzIHVzZWQgX29uY2VfCj4+Pgo+Pj4gbGlz dGVuZXIgc2tfcmN2YnVmIGNhbiBjaGFuZ2UgdW5kZXIgdXMuCj4+Pgo+Pj4gSSByZWFsbHkgaGF2 ZSBubyBpZGVhIGhvdyB3aW5kb3cgY2FuIGJlIHNldCB0byA2Mywgc28gcGxlYXNlIHNlbmQgdXMK Pj4+IHRoZSBwYWNrZXRkcmlsbCB0ZXN0IG9uY2UgeW91IGhhdmUgaXQu