Received: by 2002:a05:7412:8d10:b0:f3:1519:9f41 with SMTP id bj16csp5964774rdb; Thu, 14 Dec 2023 05:02:35 -0800 (PST) X-Google-Smtp-Source: AGHT+IH+8SQmoA/2uoQ9iTEqlPs+nxRilOGdquYcPNKxp+77MiKi6dZNZlV2qoYyJCJKX9OUs+31 X-Received: by 2002:a05:6a20:918b:b0:18f:97c:823b with SMTP id v11-20020a056a20918b00b0018f097c823bmr5976861pzd.69.1702558954683; Thu, 14 Dec 2023 05:02:34 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1702558954; cv=none; d=google.com; s=arc-20160816; b=y+sH6DCSu67N1iQaJVf7l9jsGoGbgXhyCbYR9yB9iFYCDxo8Fn71A0sjTCgtwtx03N lx+leKZRF+tV4T6wNcKnWF57D77fRbu50gf+qIKm8Y7rVm8+HX7AVgt2603ro7XHaVI+ AjIgMROY0bQFAXPvIMXfMlK89NMgXKMTkze9UaXDB3SpX9QL7r6NASyemqHwIMxLrayI uzMhiWWgZLyU5npAzA2hiQslJOrELuNW2Xb3qh295L1SP/FWpZEZQt4OdW3SFSCFmglh mr8EquMfXXFtF3nUoVfUr4m0JXT30+SWRBq5PLSt6tG0CTsAIvcHC5dBfUa2o+1VzaW6 Za2g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature:dkim-filter; bh=qQ0wXpLN/ynFGKJ85yV9ErVRRB1u/PzlcDbnZakJogE=; fh=YtSViko0S4mzjRL+vIBcPZ6MScNClfhalnj7Ll4mpO4=; b=Z2MQKBnB3LF4QfbLkUiFGeSZU6olqgaLVEIiMWFmGJhPe3WmsAdyG5aPsvY4uuRWIh 73F2BYYeQ48LtPIde8D/2jgRf4vllAhttjACqkL4BlhSv6ZNyE2mrdcWtpXJ3Nx6wgxf UaP9R/EEbxMMgegzbrZ6sdxc705OeOkNWAokFzUJyaFV7WCbRPaaCIkJDcNBcDYGeero UpIT5ko9vmZjBrRuDX5hsoEgu/7QeDY4UTPzTjj36IVSaD6Mr/92f4hhD1lujf8xQtaD xzhcDzA6Vz2DnYaaWQflIN3YmecT4+oaggnwT79MPpZACp2eyN+Dc8zrUJGty/opMsNW V5MQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@salutedevices.com header.s=mail header.b="j/OX8htx"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.31 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=salutedevices.com Return-Path: Received: from morse.vger.email (morse.vger.email. [23.128.96.31]) by mx.google.com with ESMTPS id 12-20020a63164c000000b005be1955657esi11219507pgw.127.2023.12.14.05.02.30 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 14 Dec 2023 05:02:34 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.31 as permitted sender) client-ip=23.128.96.31; Authentication-Results: mx.google.com; dkim=pass header.i=@salutedevices.com header.s=mail header.b="j/OX8htx"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.31 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=salutedevices.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by morse.vger.email (Postfix) with ESMTP id 2116080BDE15; Thu, 14 Dec 2023 05:02:01 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at morse.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1573258AbjLNNBg (ORCPT + 99 others); Thu, 14 Dec 2023 08:01:36 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42050 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1573218AbjLNNBU (ORCPT ); Thu, 14 Dec 2023 08:01:20 -0500 Received: from mx1.sberdevices.ru (mx2.sberdevices.ru [45.89.224.132]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E7E321B8; Thu, 14 Dec 2023 05:01:23 -0800 (PST) Received: from p-infra-ksmg-sc-msk02 (localhost [127.0.0.1]) by mx1.sberdevices.ru (Postfix) with ESMTP id 010FB12006E; Thu, 14 Dec 2023 16:01:22 +0300 (MSK) DKIM-Filter: OpenDKIM Filter v2.11.0 mx1.sberdevices.ru 010FB12006E DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=salutedevices.com; s=mail; t=1702558882; bh=qQ0wXpLN/ynFGKJ85yV9ErVRRB1u/PzlcDbnZakJogE=; h=Message-ID:Date:MIME-Version:Subject:To:From:Content-Type:From; b=j/OX8htx3B7dxoYJH9ZRKbsOojBStiMSYKkMl1AXbllCu+Xr/Xbd5crEviprYA5vB nYlHl+ciEZatBBm2UXTRHsdmoIQYDs4Cn5ja7vHqhnHMShuL/mxbDezXhmpCNsmrzf 5qaanmTOkoVrnm0AZUeGqQTDWnhmXKW2hruV6oB0vOs2kpqULbPDJ8s+0RzfoCE7cW vzSrvH5Y7EallXx9+XCYwS8Vu3xlo1uB6f4fpSytgsTF8qTTvluySlQuG7+YwpwTko n/IkyI5OkULiBxRfy/Q0jl93dp1rDsrdLSxBG/hdB/l81PGGeQ2RANz6jF9LyoXVjE OX3pu9V/Vj10g== Received: from smtp.sberdevices.ru (p-i-exch-sc-m01.sberdevices.ru [172.16.192.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mx1.sberdevices.ru (Postfix) with ESMTPS; Thu, 14 Dec 2023 16:01:21 +0300 (MSK) Received: from [192.168.0.106] (100.64.160.123) by p-i-exch-sc-m01.sberdevices.ru (172.16.192.107) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.1118.40; Thu, 14 Dec 2023 16:01:21 +0300 Message-ID: <1c768c53-74d8-3220-779a-d2771cb7bab6@salutedevices.com> Date: Thu, 14 Dec 2023 15:52:58 +0300 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.7.1 Subject: Re: [PATCH net-next v9 3/4] vsock: update SO_RCVLOWAT setting callback Content-Language: en-US To: "Michael S. Tsirkin" CC: Stefan Hajnoczi , Stefano Garzarella , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Jason Wang , Bobby Eshleman , , , , , , References: <20231214091947.395892-1-avkrasnov@salutedevices.com> <20231214091947.395892-4-avkrasnov@salutedevices.com> <20231214052502-mutt-send-email-mst@kernel.org> From: Arseniy Krasnov In-Reply-To: <20231214052502-mutt-send-email-mst@kernel.org> Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 7bit X-Originating-IP: [100.64.160.123] X-ClientProxiedBy: p-i-exch-sc-m02.sberdevices.ru (172.16.192.103) To p-i-exch-sc-m01.sberdevices.ru (172.16.192.107) X-KSMG-Rule-ID: 10 X-KSMG-Message-Action: clean X-KSMG-AntiSpam-Lua-Profiles: 182113 [Dec 14 2023] X-KSMG-AntiSpam-Version: 6.1.0.3 X-KSMG-AntiSpam-Envelope-From: avkrasnov@salutedevices.com X-KSMG-AntiSpam-Rate: 0 X-KSMG-AntiSpam-Status: not_detected X-KSMG-AntiSpam-Method: none X-KSMG-AntiSpam-Auth: dkim=none X-KSMG-AntiSpam-Info: LuaCore: 7 0.3.7 6d6bf5bd8eea7373134f756a2fd73e9456bb7d1a, {Tracking_from_domain_doesnt_match_to}, smtp.sberdevices.ru:5.0.1,7.1.1;100.64.160.123:7.1.2;salutedevices.com:7.1.1;127.0.0.199:7.1.2;d41d8cd98f00b204e9800998ecf8427e.com:7.1.1, FromAlignment: s, ApMailHostAddress: 100.64.160.123 X-MS-Exchange-Organization-SCL: -1 X-KSMG-AntiSpam-Interceptor-Info: scan successful X-KSMG-AntiPhishing: Clean X-KSMG-LinksScanning: Clean X-KSMG-AntiVirus: Kaspersky Secure Mail Gateway, version 2.0.1.6960, bases: 2023/12/14 10:50:00 #22693095 X-KSMG-AntiVirus-Status: Clean, skipped X-Spam-Status: No, score=-2.9 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, NICE_REPLY_A,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on morse.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (morse.vger.email [0.0.0.0]); Thu, 14 Dec 2023 05:02:01 -0800 (PST) On 14.12.2023 13:29, Michael S. Tsirkin wrote: > On Thu, Dec 14, 2023 at 12:19:46PM +0300, Arseniy Krasnov wrote: >> Do not return if transport callback for SO_RCVLOWAT is set (only in >> error case). In this case we don't need to set 'sk_rcvlowat' field in >> each transport - only in 'vsock_set_rcvlowat()'. Also, if 'sk_rcvlowat' >> is now set only in af_vsock.c, change callback name from 'set_rcvlowat' >> to 'notify_set_rcvlowat'. >> >> Signed-off-by: Arseniy Krasnov >> Reviewed-by: Stefano Garzarella >> Acked-by: Michael S. Tsirkin > > Maybe squash this with patch 2/4? Done in v10 Thanks, Arseniy > >> --- >> Changelog: >> v3 -> v4: >> * Rename 'set_rcvlowat' to 'notify_set_rcvlowat'. >> * Commit message updated. >> >> include/net/af_vsock.h | 2 +- >> net/vmw_vsock/af_vsock.c | 9 +++++++-- >> net/vmw_vsock/hyperv_transport.c | 4 ++-- >> 3 files changed, 10 insertions(+), 5 deletions(-) >> >> diff --git a/include/net/af_vsock.h b/include/net/af_vsock.h >> index e302c0e804d0..535701efc1e5 100644 >> --- a/include/net/af_vsock.h >> +++ b/include/net/af_vsock.h >> @@ -137,7 +137,6 @@ struct vsock_transport { >> u64 (*stream_rcvhiwat)(struct vsock_sock *); >> bool (*stream_is_active)(struct vsock_sock *); >> bool (*stream_allow)(u32 cid, u32 port); >> - int (*set_rcvlowat)(struct vsock_sock *vsk, int val); >> >> /* SEQ_PACKET. */ >> ssize_t (*seqpacket_dequeue)(struct vsock_sock *vsk, struct msghdr *msg, >> @@ -168,6 +167,7 @@ struct vsock_transport { >> struct vsock_transport_send_notify_data *); >> /* sk_lock held by the caller */ >> void (*notify_buffer_size)(struct vsock_sock *, u64 *); >> + int (*notify_set_rcvlowat)(struct vsock_sock *vsk, int val); >> >> /* Shutdown. */ >> int (*shutdown)(struct vsock_sock *, int); >> diff --git a/net/vmw_vsock/af_vsock.c b/net/vmw_vsock/af_vsock.c >> index 816725af281f..54ba7316f808 100644 >> --- a/net/vmw_vsock/af_vsock.c >> +++ b/net/vmw_vsock/af_vsock.c >> @@ -2264,8 +2264,13 @@ static int vsock_set_rcvlowat(struct sock *sk, int val) >> >> transport = vsk->transport; >> >> - if (transport && transport->set_rcvlowat) >> - return transport->set_rcvlowat(vsk, val); >> + if (transport && transport->notify_set_rcvlowat) { >> + int err; >> + >> + err = transport->notify_set_rcvlowat(vsk, val); >> + if (err) >> + return err; >> + } >> >> WRITE_ONCE(sk->sk_rcvlowat, val ? : 1); >> return 0; > > > > I would s > >> diff --git a/net/vmw_vsock/hyperv_transport.c b/net/vmw_vsock/hyperv_transport.c >> index 7cb1a9d2cdb4..e2157e387217 100644 >> --- a/net/vmw_vsock/hyperv_transport.c >> +++ b/net/vmw_vsock/hyperv_transport.c >> @@ -816,7 +816,7 @@ int hvs_notify_send_post_enqueue(struct vsock_sock *vsk, ssize_t written, >> } >> >> static >> -int hvs_set_rcvlowat(struct vsock_sock *vsk, int val) >> +int hvs_notify_set_rcvlowat(struct vsock_sock *vsk, int val) >> { >> return -EOPNOTSUPP; >> } >> @@ -856,7 +856,7 @@ static struct vsock_transport hvs_transport = { >> .notify_send_pre_enqueue = hvs_notify_send_pre_enqueue, >> .notify_send_post_enqueue = hvs_notify_send_post_enqueue, >> >> - .set_rcvlowat = hvs_set_rcvlowat >> + .notify_set_rcvlowat = hvs_notify_set_rcvlowat >> }; >> >> static bool hvs_check_transport(struct vsock_sock *vsk) >> -- >> 2.25.1 >