Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp249497pxb; Wed, 24 Feb 2021 00:39:04 -0800 (PST) X-Google-Smtp-Source: ABdhPJwV5BZ7tg4Mt7jiZBWobN00hsBDBNp8n2gDCXD9C8L7QNeTW9qV/zVzgR6RPLk/YXhFC6EY X-Received: by 2002:a17:907:2d10:: with SMTP id gs16mr30475835ejc.0.1614155944029; Wed, 24 Feb 2021 00:39:04 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1614155944; cv=none; d=google.com; s=arc-20160816; b=yWgQlbD0mlHGoOjr4RWVvQs3YqPNRUImnZTjRPfVegPCTwBROjaaHBofkHlx86eQx2 Ao3CSas7pAmhqj5/ucoBm3WPT8n+bF87KDqzwW03BIYnYkoyDLkZAyt3Hc5yQDpd/VBm y61jXDAvJBJS2Oj2BPykoCyhpSG7Rj+oge0mnyPzpHy1F4wGr2o7ssJ4ytnDTqn7dM4g xquJLKC8A1sSRduO1FySCGl50z8ibti+Tz6XCC5Vo5W72dp75KnrerOHkOjICLeONn5y ENzovUn3w1jeGtE0cDfmsfiUn8cQi4dDd5lvCWdEYIlvfbiMJ95mHiJ1rLUm+gxn4Pul 94kQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=1JbGPMGc3zR5mJ9ryS3aC3fSGYocZkjlOuNb6WBZZ3I=; b=GWGdq9DYgZl0oj4CF4KDWARw8JHuGS1KDvOL5fLKiwg4FDkGqH4bLIBUa5FKtYWMo4 ltRP36cvMel2K9RfqxFhbrIimxAEUakJATh4kQEemRtLyUgo02PAFUBvmU8Ti6qMdF8L QyBZPGe7siSTwDqZoulhYPw2Cn+yzN+xvR7fb8BoYigWC/E7j3TCpk0yZ9XYXOb88/iX temoCTC8x3xUcE4+n0s80P5/nxLefoCteAxV1tk6cFp9/9Bw1dUKDkvmwnbL486A084w +Y62ssdhBoBe4RkuVKBHmPiO8y0IjqzjT/i/dXDIEoidOPxd9OkAte+N6fpnOL4eB1im AzOw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=KSGq+666; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f7si760730edd.574.2021.02.24.00.38.38; Wed, 24 Feb 2021 00:39:04 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=KSGq+666; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232948AbhBXIY6 (ORCPT + 99 others); Wed, 24 Feb 2021 03:24:58 -0500 Received: from us-smtp-delivery-124.mimecast.com ([63.128.21.124]:35362 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229556AbhBXIYx (ORCPT ); Wed, 24 Feb 2021 03:24:53 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1614155006; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=1JbGPMGc3zR5mJ9ryS3aC3fSGYocZkjlOuNb6WBZZ3I=; b=KSGq+666prtCURPW2NWMu9TT5irzC6T/ytkR3X0+dQZAp65bfqyRkCkL0+ZZklzaFoRmdC a4kx0Wy28vYagEajpFldjPPd9MCwmrRxbbpRVk6Jt/rA1CFq+8aiW9jaD31ozJgEG8Xtf2 hUvTV3bR9mLtlMEP+vzC1iqSwXl1u9A= Received: from mail-wr1-f70.google.com (mail-wr1-f70.google.com [209.85.221.70]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-412-Rg6-67G-OQGRN2-sVN3Vlw-1; Wed, 24 Feb 2021 03:23:24 -0500 X-MC-Unique: Rg6-67G-OQGRN2-sVN3Vlw-1 Received: by mail-wr1-f70.google.com with SMTP id k5so697270wrw.14 for ; Wed, 24 Feb 2021 00:23:24 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to; bh=1JbGPMGc3zR5mJ9ryS3aC3fSGYocZkjlOuNb6WBZZ3I=; b=edhE078mWITh9Ug6hlNWNWRjG1W/P5ansQ7/vxeYa3IbTARx+ZE3hGnd8f0rhqr8DW Y1DqhH/PJu64FWMX7JRiQV2IZIneHVfzYsDSh3miNldFE2Hy2mjkYkHEjK8KMcZQ1yqb jZr9UjNj7pfOnoSFddiD6otMVcuPUZnB8xcSMnRyS6Z77qYtUKevMu6C9WjT0dJWwSHU W4RihdErmLHMZio6prIcX0DknHaI8CF8IWV1Cndts/CotnWbcCgtnffEksVEMHEX/rq1 KLzKX2PaqqlHBPzQeqwjkZTA/nI7DGUpKOEDeUQVFZgEbGvJSyg4QZ0PbITRDx8/8C2W jCwA== X-Gm-Message-State: AOAM531HNEEnQoaU4BoIs1qemxHc62k+EGAzWPx1b2PvcLz+PC9ndETd TVxIFUHbugx38nUwV/wwuPMBzpkhJCK8uFpq4rzeRFbMPjh6eXAbMH0zRtFRrZCRCt1ZZwY9kUT TnVywhN0639t3MvfvJpqU+pi1 X-Received: by 2002:a7b:cb81:: with SMTP id m1mr2574142wmi.117.1614155003181; Wed, 24 Feb 2021 00:23:23 -0800 (PST) X-Received: by 2002:a7b:cb81:: with SMTP id m1mr2574122wmi.117.1614155002974; Wed, 24 Feb 2021 00:23:22 -0800 (PST) Received: from steredhat (host-79-34-249-199.business.telecomitalia.it. [79.34.249.199]) by smtp.gmail.com with ESMTPSA id a1sm2056803wrx.95.2021.02.24.00.23.21 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 24 Feb 2021 00:23:22 -0800 (PST) Date: Wed, 24 Feb 2021 09:23:19 +0100 From: Stefano Garzarella To: Arseny Krasnov Cc: Stefan Hajnoczi , "Michael S. Tsirkin" , Jason Wang , "David S. Miller" , Jakub Kicinski , Jorgen Hansen , Andra Paraschiv , Norbert Slusarek , Colin Ian King , "kvm@vger.kernel.org" , "virtualization@lists.linux-foundation.org" , "netdev@vger.kernel.org" , "linux-kernel@vger.kernel.org" , "stsp2@yandex.ru" , "oxffffaa@gmail.com" Subject: Re: [RFC PATCH v5 00/19] virtio/vsock: introduce SOCK_SEQPACKET support Message-ID: <20210224082319.yrmqr6zs7emvghw3@steredhat> References: <20210218053347.1066159-1-arseny.krasnov@kaspersky.com> <20210222142311.gekdd7gsm33wglos@steredhat> <20210223145016.ddavx6fihq4akdim@steredhat> <7a280168-cb54-ae26-4697-c797f6b04708@kaspersky.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii; format=flowed Content-Disposition: inline In-Reply-To: <7a280168-cb54-ae26-4697-c797f6b04708@kaspersky.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Feb 24, 2021 at 07:29:25AM +0300, Arseny Krasnov wrote: > >On 23.02.2021 17:50, Stefano Garzarella wrote: >> On Mon, Feb 22, 2021 at 03:23:11PM +0100, Stefano Garzarella wrote: >>> Hi Arseny, >>> >>> On Thu, Feb 18, 2021 at 08:33:44AM +0300, Arseny Krasnov wrote: >>>> This patchset impelements support of SOCK_SEQPACKET for virtio >>>> transport. >>>> As SOCK_SEQPACKET guarantees to save record boundaries, so to >>>> do it, two new packet operations were added: first for start of record >>>> and second to mark end of record(SEQ_BEGIN and SEQ_END later). Also, >>>> both operations carries metadata - to maintain boundaries and payload >>>> integrity. Metadata is introduced by adding special header with two >>>> fields - message count and message length: >>>> >>>> struct virtio_vsock_seq_hdr { >>>> __le32 msg_cnt; >>>> __le32 msg_len; >>>> } __attribute__((packed)); >>>> >>>> This header is transmitted as payload of SEQ_BEGIN and SEQ_END >>>> packets(buffer of second virtio descriptor in chain) in the same way as >>>> data transmitted in RW packets. Payload was chosen as buffer for this >>>> header to avoid touching first virtio buffer which carries header of >>>> packet, because someone could check that size of this buffer is equal >>>> to size of packet header. To send record, packet with start marker is >>>> sent first(it's header contains length of record and counter), then >>>> counter is incremented and all data is sent as usual 'RW' packets and >>>> finally SEQ_END is sent(it also carries counter of message, which is >>>> counter of SEQ_BEGIN + 1), also after sedning SEQ_END counter is >>>> incremented again. On receiver's side, length of record is known from >>>> packet with start record marker. To check that no packets were dropped >>>> by transport, counters of two sequential SEQ_BEGIN and SEQ_END are >>>> checked(counter of SEQ_END must be bigger that counter of SEQ_BEGIN by >>>> 1) and length of data between two markers is compared to length in >>>> SEQ_BEGIN header. >>>> Now as packets of one socket are not reordered neither on >>>> vsock nor on vhost transport layers, such markers allows to restore >>>> original record on receiver's side. If user's buffer is smaller that >>>> record length, when all out of size data is dropped. >>>> Maximum length of datagram is not limited as in stream socket, >>>> because same credit logic is used. Difference with stream socket is >>>> that user is not woken up until whole record is received or error >>>> occurred. Implementation also supports 'MSG_EOR' and 'MSG_TRUNC' flags. >>>> Tests also implemented. >>> I reviewed the first part (af_vsock.c changes), tomorrow I'll review >>> the rest. That part looks great to me, only found a few minor issues. >> I revieiwed the rest of it as well, left a few minor comments, but I >> think we're well on track. >> >> I'll take a better look at the specification patch tomorrow. >Great, Thank You >> >> Thanks, >> Stefano >> >>> In the meantime, however, I'm getting a doubt, especially with regard >>> to other transports besides virtio. >>> >>> Should we hide the begin/end marker sending in the transport? >>> >>> I mean, should the transport just provide a seqpacket_enqueue() >>> callbacl? >>> Inside it then the transport will send the markers. This is because >>> some transports might not need to send markers. >>> >>> But thinking about it more, they could actually implement stubs for >>> that calls, if they don't need to send markers. >>> >>> So I think for now it's fine since it allows us to reuse a lot of >>> code, unless someone has some objection. > >I thought about that, I'll try to implement it in next version. Let's see... If you want to discuss it first, write down the idea you want to implement, I wouldn't want to make you do unnecessary work. :-) Cheers, Stefano