Received: by 2002:a05:6a10:c604:0:0:0:0 with SMTP id y4csp81265pxt; Thu, 5 Aug 2021 18:40:12 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxc1fZMLId1/DVegs4zWx6KQQmAqVSRb2zKlJHuX0EFMk1mh2bmtINivcEiOXK+ji4ZcqZ0 X-Received: by 2002:a17:906:c2d7:: with SMTP id ch23mr7405430ejb.298.1628214012349; Thu, 05 Aug 2021 18:40:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1628214012; cv=none; d=google.com; s=arc-20160816; b=lrvh7Otmfd14MMbE+f8cSPEzCopfuhEpJA/i2pF/k0YLi+6jb+/aBN62u+Z+Rveqjm 7NAIL1mL/zzFQ222QG01Ny6UIz3NJ7nKwwzH62Hgd0SdEeHp239b+QKvPhjNZeOzQIHh uMv8D1SVdSGAm/hsmwTA0EXKZduHzvlutC550wnEhN5WHUBKLozApEy08u1vFIAx9b1R rSuO4aWQmBYMce5th6Zv9zUeiow47TgC1WbzyJVH/r6/i5Bg9N77PyINVUAdDJ0Vv2yU 0Blf7/sEUsBo/sL7HEVcBcleYbDCrClGJ0+T820+zNjBVmlvxpkECItw1UwTyY6kMktD xpDQ== 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=bk6BNtpX2bsqpgJ2JxfChzF+Dc9XGh58ZUTm6AVu4O8=; b=fuozddhuiPHRRhWGpEjKTTol2i2VMjcQuUCSD8nhhgM8qTvEUxah9Jh2zoM7bUtOJ3 lbE0m0CcvUSas78EgbxYs1FmdjlpLlz52WuxV2QBnsVA6TNLcwuVoSS24rAwXAWnlOD6 kEObkbdeTYYiMcs4qTPkbfVo5BWf5clZfb6g3OXrOsxRbCD6N8R6ec8SopviuQrLWSNy guZ0s15yv65kfPoyzpGLNq7/99ITAMf/VKDcrDADSSZqgwPC8E7/nPjK2lADTkdg5VeT RKIU4uZAbR/4MZLahX8gWB8Xq4D3WCuABhyFMPEAKXDtnU9EqQ3WZHn8fWtPQ853Ovse B4OA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@bytedance-com.20150623.gappssmtp.com header.s=20150623 header.b=jkPQQclQ; 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=fail (p=NONE sp=NONE dis=NONE) header.from=bytedance.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id jw27si7054626ejc.440.2021.08.05.18.39.48; Thu, 05 Aug 2021 18:40:12 -0700 (PDT) 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=@bytedance-com.20150623.gappssmtp.com header.s=20150623 header.b=jkPQQclQ; 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=fail (p=NONE sp=NONE dis=NONE) header.from=bytedance.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240533AbhHEWfZ (ORCPT + 99 others); Thu, 5 Aug 2021 18:35:25 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40734 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S240772AbhHEWfY (ORCPT ); Thu, 5 Aug 2021 18:35:24 -0400 Received: from mail-pj1-x102f.google.com (mail-pj1-x102f.google.com [IPv6:2607:f8b0:4864:20::102f]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 523F9C0613D5 for ; Thu, 5 Aug 2021 15:35:09 -0700 (PDT) Received: by mail-pj1-x102f.google.com with SMTP id o44-20020a17090a0a2fb0290176ca3e5a2fso13209099pjo.1 for ; Thu, 05 Aug 2021 15:35:09 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bytedance-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=bk6BNtpX2bsqpgJ2JxfChzF+Dc9XGh58ZUTm6AVu4O8=; b=jkPQQclQNlPFdS72CY978/hPr2qVc+s2HI7k3Zt5J5omsrvgJrSH1HD6Jlj3MJQuge Hu6oevksHhctJSP7LGkcFv4wyWcBgJT6QPpaQnaRUQ4FhqvebMSplo2jua+7qwJoQzwZ Mip06e6aahIM1xlclwJ0sxNnvwEExMtpIGz4CNCGnrVXP1C0MR9ZU4mj+xdv433qzDFZ aIpD6RgaD8pQnITX8PDXOBpxF91+rNzasXZzhJ83NVvAGP9peUHJfSrRAjFn/2XGtO7D 8he1Wp3CmtH9tGUXRkWy1gAYOJdmigbLVm5IVFtpKloVbksmaKwuWgDXF9380pGsbfVU PLHg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=bk6BNtpX2bsqpgJ2JxfChzF+Dc9XGh58ZUTm6AVu4O8=; b=FDK6LQ0fPjX/a5E5uhWCGfZD12T1sUgyehG85nFTy5kpiBdO7VegZ5cpvI3Evcq/MG 032UL9jLMMPtuqupk0tcTjQDVbJbEpqvxOfdzyggn86/vLAmCSJZQBrDXE8RvmNOSegO +Ns2tKtwsr81+iropYBk+FqZTGHwmZEjo/1ooHPqFL+jKMKQB7NCncKqcoR5n8J6EJo5 P/NAyTdwUODkPC5jgm2/1cnLMhs/uC8sAcfgLJm526u3BnwOAskGrqNv7cun/4sHujsF +mb9gdmLRSpAhpUYd2BaW7+9FWvMCCw/44QxUqUVw0UH45SmR9cJkX8YtWnzjU+h9bBP /6ew== X-Gm-Message-State: AOAM532AlvgggwJ3lFkX45oDISi30oA0fsbuXmpcEJ+YTqU80yPnafmd rH/dECYoPF6lrf+cOlRUBLJ6Jw== X-Received: by 2002:a17:90a:9747:: with SMTP id i7mr6976516pjw.141.1628202908950; Thu, 05 Aug 2021 15:35:08 -0700 (PDT) Received: from ip-10-124-121-13.byted.org (ec2-54-241-92-238.us-west-1.compute.amazonaws.com. [54.241.92.238]) by smtp.gmail.com with ESMTPSA id z8sm7931638pfa.113.2021.08.05.15.35.07 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 05 Aug 2021 15:35:08 -0700 (PDT) From: Jiang Wang To: netdev@vger.kernel.org Cc: cong.wang@bytedance.com, duanxiongchun@bytedance.com, xieyongji@bytedance.com, chaiwen.cc@bytedance.com, "David S. Miller" , Jakub Kicinski , John Fastabend , Daniel Borkmann , Jakub Sitnicki , Lorenz Bauer , Alexei Starovoitov , Andrii Nakryiko , Martin KaFai Lau , Song Liu , Yonghong Song , KP Singh , Shuah Khan , Al Viro , Christian Brauner , Johan Almbladh , linux-kernel@vger.kernel.org, bpf@vger.kernel.org, linux-kselftest@vger.kernel.org Subject: [PATCH bpf-next v5 1/5] af_unix: add read_sock for stream socket types Date: Thu, 5 Aug 2021 22:34:38 +0000 Message-Id: <20210805223445.624330-2-jiang.wang@bytedance.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20210805223445.624330-1-jiang.wang@bytedance.com> References: <20210805223445.624330-1-jiang.wang@bytedance.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org To support sockmap for af_unix stream type, implement read_sock, which is similar to the read_sock for unix dgram sockets. Signed-off-by: Jiang Wang Reviewed-by: Cong Wang --- net/unix/af_unix.c | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/net/unix/af_unix.c b/net/unix/af_unix.c index 256c4e31132e..c020ad0e8438 100644 --- a/net/unix/af_unix.c +++ b/net/unix/af_unix.c @@ -672,6 +672,8 @@ static int unix_dgram_sendmsg(struct socket *, struct msghdr *, size_t); static int unix_dgram_recvmsg(struct socket *, struct msghdr *, size_t, int); static int unix_read_sock(struct sock *sk, read_descriptor_t *desc, sk_read_actor_t recv_actor); +static int unix_stream_read_sock(struct sock *sk, read_descriptor_t *desc, + sk_read_actor_t recv_actor); static int unix_dgram_connect(struct socket *, struct sockaddr *, int, int); static int unix_seqpacket_sendmsg(struct socket *, struct msghdr *, size_t); @@ -725,6 +727,7 @@ static const struct proto_ops unix_stream_ops = { .shutdown = unix_shutdown, .sendmsg = unix_stream_sendmsg, .recvmsg = unix_stream_recvmsg, + .read_sock = unix_stream_read_sock, .mmap = sock_no_mmap, .sendpage = unix_stream_sendpage, .splice_read = unix_stream_splice_read, @@ -2358,6 +2361,15 @@ struct unix_stream_read_state { unsigned int splice_flags; }; +static int unix_stream_read_sock(struct sock *sk, read_descriptor_t *desc, + sk_read_actor_t recv_actor) +{ + if (unlikely(sk->sk_state != TCP_ESTABLISHED)) + return -ENOTCONN; + + return unix_read_sock(sk, desc, recv_actor); +} + static int unix_stream_read_generic(struct unix_stream_read_state *state, bool freezable) { -- 2.20.1