Received: by 2002:a05:6a10:2785:0:0:0:0 with SMTP id ia5csp132576pxb; Thu, 14 Jan 2021 21:58:57 -0800 (PST) X-Google-Smtp-Source: ABdhPJyyZh/b+5RIervpFpmqPlWRXhTgQlmklmf3ab11yRl0dz/yrxCZIfeSiGBUrSrKyUpfWl6G X-Received: by 2002:a17:906:4d47:: with SMTP id b7mr7492062ejv.420.1610690337779; Thu, 14 Jan 2021 21:58:57 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1610690337; cv=none; d=google.com; s=arc-20160816; b=OuV1xiH+EOuNQWy1XBWGIWeE8zjVMTSu17kPDRyU32zArRT4hHYTvRVHB5SstA/phd rLVKB/XCZFjS6gfYsrgI3IhCSLaWyCzThLbG+GS1m6hB8aTTlP4qxz3hLct3gJls/HL/ 8yP4GpeYDh8SKep7FMBF6I7XVpTl7jU0r3IpwzNh5NoJZfRe0T5vyG2q4Wgjs9cIrwt6 Fs/NnUD9dTN812hHrZh5NQQ1oClfjzItTvKHyg4XPvTdxG9DeVOsYWNcswjN9gBAAB5L nPD0k/lXXnYp4SOkUavYps+fVIxNqvFqn54nHeiDBmXuSj9+rf6b8m03KckmxJlxGKXq wyDw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=xtSUASiAL0qT1orA0XbogLEeBLgIWwpcy5x9v2H97L0=; b=RH5nmiHLXqJ8oR5OJtx4hJXcyh45TrVK/wu9BCMlfBsO5lzQFqecuFjyc8XBHGbw5j TXn6yIE9lFyL/WDF0pBX/0CKUPvJuU78FWqgGNAJyPQhTSSjPsz2HkoVdbCUwaRZkxni YX2v8EAsmlif0eaAS32DiI8LXHodwj1VIoU2CwT+BnWzsoumP4GOAY41Cgy5MfBpvQKq LImjk88gOkf3aC0C6/Y4wB5RFIxRsNgERKHNbymRwUtlgg31udquTMGqqKvrRgDh2u2W 4PjZV/88x2/zoMxEXWXHBdHc6YND45SgikNC6uy+Zh58TVVEYmUbOkZGQvgOg8y/MIzE uIPw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kaspersky.com header.s=mail header.b=K7iuHYkX; 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=REJECT sp=REJECT dis=NONE) header.from=kaspersky.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id v5si3327698eji.385.2021.01.14.21.58.34; Thu, 14 Jan 2021 21:58:57 -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=@kaspersky.com header.s=mail header.b=K7iuHYkX; 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=REJECT sp=REJECT dis=NONE) header.from=kaspersky.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1733244AbhAOFmM (ORCPT + 99 others); Fri, 15 Jan 2021 00:42:12 -0500 Received: from mx12.kaspersky-labs.com ([91.103.66.155]:60979 "EHLO mx12.kaspersky-labs.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732055AbhAOFmK (ORCPT ); Fri, 15 Jan 2021 00:42:10 -0500 Received: from relay12.kaspersky-labs.com (unknown [127.0.0.10]) by relay12.kaspersky-labs.com (Postfix) with ESMTP id 7FB3875F1B; Fri, 15 Jan 2021 08:41:27 +0300 (MSK) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=kaspersky.com; s=mail; t=1610689287; bh=xtSUASiAL0qT1orA0XbogLEeBLgIWwpcy5x9v2H97L0=; h=From:To:Subject:Date:Message-ID:MIME-Version:Content-Type; b=K7iuHYkXP0wBdfrOVA4xdGlpWAYOQS9aQhVqKKxou1XEznqkefRb/2OedDhQcK6s6 8p7JhARuSOAausboWpgHDdfTPthAVsDEwZcTlrq4I/6GvEzvznGCzzcufS7Ssk4cdg KFKrKy2CfarOc1+No3ss3XU4BokDQS6kDBHOwoYU= Received: from mail-hq2.kaspersky.com (unknown [91.103.66.206]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-SHA256 (128/128 bits)) (Client CN "mail-hq2.kaspersky.com", Issuer "Kaspersky MailRelays CA G3" (verified OK)) by mailhub12.kaspersky-labs.com (Postfix) with ESMTPS id CFDEF75F36; Fri, 15 Jan 2021 08:41:26 +0300 (MSK) Received: from arseniy-pc.avp.ru (10.64.68.128) by hqmailmbx3.avp.ru (10.64.67.243) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.2044.4; Fri, 15 Jan 2021 08:41:26 +0300 From: Arseny Krasnov To: Stefan Hajnoczi , Stefano Garzarella , "Michael S. Tsirkin" , Jason Wang , "David S. Miller" , Jakub Kicinski , Arseny Krasnov , Colin Ian King , Andra Paraschiv , Jeff Vander Stoep CC: , , , , , Subject: [RFC PATCH v2 03/13] af_vsock: implement rx loops entry point Date: Fri, 15 Jan 2021 08:41:16 +0300 Message-ID: <20210115054119.1455879-1-arseny.krasnov@kaspersky.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20210115053553.1454517-1-arseny.krasnov@kaspersky.com> References: <20210115053553.1454517-1-arseny.krasnov@kaspersky.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-Originating-IP: [10.64.68.128] X-ClientProxiedBy: hqmailmbx2.avp.ru (10.64.67.242) To hqmailmbx3.avp.ru (10.64.67.243) X-KSE-ServerInfo: hqmailmbx3.avp.ru, 9 X-KSE-AntiSpam-Interceptor-Info: scan successful X-KSE-AntiSpam-Version: 5.9.16, Database issued on: 01/15/2021 05:18:27 X-KSE-AntiSpam-Status: KAS_STATUS_NOT_DETECTED X-KSE-AntiSpam-Method: none X-KSE-AntiSpam-Rate: 10 X-KSE-AntiSpam-Info: Lua profiles 161159 [Jan 15 2021] X-KSE-AntiSpam-Info: LuaCore: 420 420 0b339e70b2b1bb108f53ec9b40aa316bba18ceea X-KSE-AntiSpam-Info: Version: 5.9.16.0 X-KSE-AntiSpam-Info: Envelope from: arseny.krasnov@kaspersky.com X-KSE-AntiSpam-Info: {Prob_from_in_msgid} X-KSE-AntiSpam-Info: {Tracking_date, moscow} X-KSE-AntiSpam-Info: {Tracking_from_domain_doesnt_match_to} X-KSE-AntiSpam-Info: arseniy-pc.avp.ru:7.1.1;kaspersky.com:7.1.1;127.0.0.199:7.1.2;d41d8cd98f00b204e9800998ecf8427e.com:7.1.1 X-KSE-AntiSpam-Info: Rate: 10 X-KSE-AntiSpam-Info: Status: not_detected X-KSE-AntiSpam-Info: Method: none X-KSE-Antiphishing-Info: Clean X-KSE-Antiphishing-ScanningType: Deterministic X-KSE-Antiphishing-Method: None X-KSE-Antiphishing-Bases: 01/15/2021 05:21:00 X-KSE-AttachmentFiltering-Interceptor-Info: no applicable attachment filtering rules found X-KSE-Antivirus-Interceptor-Info: scan successful X-KSE-Antivirus-Info: Clean, bases: 15.01.2021 2:12:00 X-KSE-BulkMessagesFiltering-Scan-Result: InTheLimit X-KSE-AttachmentFiltering-Interceptor-Info: no applicable attachment filtering rules found X-KSE-BulkMessagesFiltering-Scan-Result: InTheLimit X-KLMS-Rule-ID: 52 X-KLMS-Message-Action: clean X-KLMS-AntiSpam-Status: not scanned, disabled by settings X-KLMS-AntiSpam-Interceptor-Info: not scanned X-KLMS-AntiPhishing: Clean, bases: 2021/01/15 05:03:00 X-KLMS-AntiVirus: Kaspersky Security for Linux Mail Server, version 8.0.3.30, bases: 2021/01/15 02:12:00 #16041563 X-KLMS-AntiVirus-Status: Clean, skipped Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This adds entry point for STREAM/SEQPACKET rx loops. As both types are connect oriented, so there are same checks before reading data from socket. All this checks are performed in this entry point, then specific rx loop is called. Signed-off-by: Arseny Krasnov --- net/vmw_vsock/af_vsock.c | 55 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 55 insertions(+) diff --git a/net/vmw_vsock/af_vsock.c b/net/vmw_vsock/af_vsock.c index afacbe9f4231..38afaa90d141 100644 --- a/net/vmw_vsock/af_vsock.c +++ b/net/vmw_vsock/af_vsock.c @@ -2244,6 +2244,61 @@ vsock_stream_recvmsg(struct socket *sock, struct msghdr *msg, size_t len, return err; } +static int vsock_connectible_recvmsg(struct socket *sock, struct msghdr *msg, + size_t len, int flags) +{ + struct sock *sk; + int err = 0; + struct vsock_sock *vsk; + const struct vsock_transport *transport; + + sk = sock->sk; + + lock_sock(sk); + + vsk = vsock_sk(sk); + transport = vsk->transport; + + if (!transport || sk->sk_state != TCP_ESTABLISHED) { + /* Recvmsg is supposed to return 0 if a peer performs an + * orderly shutdown. Differentiate between that case and when a + * peer has not connected or a local shutdown occurred with the + * SOCK_DONE flag. + */ + if (!sock_flag(sk, SOCK_DONE)) + err = -ENOTCONN; + + goto out; + } + + if (flags & MSG_OOB) { + err = -EOPNOTSUPP; + goto out; + } + + /* We don't check peer_shutdown flag here since peer may actually shut + * down, but there can be data in the queue that a local socket can + * receive. + */ + if (sk->sk_shutdown & RCV_SHUTDOWN) + goto out; + + /* It is valid on Linux to pass in a zero-length receive buffer. This + * is not an error. We may as well bail out now. + */ + if (!len) + goto out; + + if (sk->sk_type == SOCK_STREAM) + err = __vsock_stream_recvmsg(sk, msg, len, flags); + else + err = __vsock_seqpacket_recvmsg(sk, msg, len, flags); + +out: + release_sock(sk); + return err; +} + static const struct proto_ops vsock_stream_ops = { .family = PF_VSOCK, .owner = THIS_MODULE, -- 2.25.1