Received: by 2002:a05:6a10:c7c6:0:0:0:0 with SMTP id h6csp1936015pxy; Mon, 2 Aug 2021 14:23:00 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzy62QjtSsw6zVLkG8qrJ+G2WE70qhc4mZO8I4i0IneefMwoVBEl3kR3UZ01uXuuv/Ix2np X-Received: by 2002:a17:907:7790:: with SMTP id ky16mr15437155ejc.318.1627939380684; Mon, 02 Aug 2021 14:23:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1627939380; cv=none; d=google.com; s=arc-20160816; b=eKLcnhLDKSqF0EoDETndbQHcb9IfCPTv7Iq+h1oyutaNr2/UtxadFsIZV9yFlbLXTI yA4ujcu4JkuXrp2RtGkOcOAeMN18iqvHlwLu9k+VLysmW58bpqWJ2nGEFbtjpKSpmyls xA8LfE+Zs6I/jYozAX0UNdXWI8fRr+pZbGsccdLGGY2P0cLeOK9WlCq0SxFnLN0eGN7d 0yKJnoCRVMUD8mKJt1E1S3cwSlpnMcln9JKyncqRQckVl3U2VVkq/tZMGf0MWpliJpem T++ccw1w1A+q1oDg8KPzVyRL32iPv3EoNSRaTq/W4/dQ+XSL6qJQc1AL+HXg3trQSb7p ZznA== 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=gB7YFrieIpmwVCmE7FizVML0zcWrHXYydeLPQdihUz4=; b=cfUUAf9UadQkBkA4/CofCv9wGHsDUB7zYsCPm9ujPTnMHD0sZTu+pCErVC/1OKBofV SArKDTrsLAGzI28y67sp7mMFThJRcLKOmw5aMzm93RhR2ZAzSg+IE/leR/EHn0NlUZ2L HtzVnzYeunMP0pVz3KPR94QZAKyiJaZdsXM89qpCZhFFoGqJxpXg93VjsxZN9RkZHNl1 BX8m368w98bPbHxNK6wEM8Xjk13Fha9f8QxkIIWyrh1XchG7NfivT0NaaeOvckoRmp6C DH0GmnCIS1SHWY4Y/j8cu/k5XnXJ2DFpiTVpFFzgnOlKXBljUcB1e3jT1QZTaYxnu+8r E2PQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@bytedance-com.20150623.gappssmtp.com header.s=20150623 header.b="S/pRWwTV"; 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 e14si11820283ejj.279.2021.08.02.14.22.38; Mon, 02 Aug 2021 14:23:00 -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="S/pRWwTV"; 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 S232757AbhHBVTk (ORCPT + 99 others); Mon, 2 Aug 2021 17:19:40 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:38690 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232614AbhHBVTi (ORCPT ); Mon, 2 Aug 2021 17:19:38 -0400 Received: from mail-pj1-x102e.google.com (mail-pj1-x102e.google.com [IPv6:2607:f8b0:4864:20::102e]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 9E780C061760 for ; Mon, 2 Aug 2021 14:19:28 -0700 (PDT) Received: by mail-pj1-x102e.google.com with SMTP id s22-20020a17090a1c16b0290177caeba067so939306pjs.0 for ; Mon, 02 Aug 2021 14:19:28 -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=gB7YFrieIpmwVCmE7FizVML0zcWrHXYydeLPQdihUz4=; b=S/pRWwTVzlbZMfxX44uINtBvykBVML7GHvPj/N/zYNtvYZgXV9ZcQPs8nnQci/OYJG r+zMFXQi7GLtgEA72n4WC5TVz7Sh985DoEKIMnWvct7wmQqP2lBi9cFG74oFbLNn/vBW mTctdwglEUz3DLAGCTiT1Ta57dY/ch+qyO6ISrc6FKrr2AtGvH+DCGcLxesLkz351FmB 4CK8hgIcKGjfD57stZ7SfTnu0v0yl9lZ7UhIsblOAHETz2OW1Bfgbv9vRO/DoIS1uVMX leIXzZ2Zfmmv3TrujCvcGCYIKgNG2Ns+8CkJ80hIwDH2hng85ODddAqar6KY8ZFlDuNU S7MQ== 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=gB7YFrieIpmwVCmE7FizVML0zcWrHXYydeLPQdihUz4=; b=h7pVA8M/jB9nLo0koccJF6yJkh1N2LQKeBT1zu+NCcwVHistveFvpQCuruvSZlcMXL llvGWqACjXnpk49CnxTQsfbkNBDpPcCakUFzEfvMEEf2V0KIhVovzveJg4wNX2ond6mT SAVGw5xDBFMIOtQzMnCdFRxjkcRNhFTsR77AJup/UlQXm7BfMIdmJJxR9N147Of31AYY ge5UnUYPooG/vg5eLmd8d5hDOIZZ8CAYbVj6Tb93TW4bfCla++Ydt80Pbl0grUUC8t00 tZ1kn5osZsRM8Boe0cfxm0TuNkVDxjex1wgleFjU1cuFUFJZmOJZUFWFvQ9aSE9eL+/6 8xzA== X-Gm-Message-State: AOAM531HfkkHX75jMoC5PtC8MTOBpMYwTuSyKs/J36ruvi5u+jattBjK AWeynj0Rwj9z2d7qjZiNlpKbyg== X-Received: by 2002:a17:90a:bd92:: with SMTP id z18mr19229054pjr.195.1627939168194; Mon, 02 Aug 2021 14:19:28 -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 10sm12949212pjc.41.2021.08.02.14.19.26 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 02 Aug 2021 14:19:27 -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 , Johan Almbladh , linux-kernel@vger.kernel.org, bpf@vger.kernel.org, linux-kselftest@vger.kernel.org Subject: [PATCH bpf-next v3 1/5] af_unix: add read_sock for stream socket types Date: Mon, 2 Aug 2021 21:19:05 +0000 Message-Id: <20210802211912.116329-2-jiang.wang@bytedance.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20210802211912.116329-1-jiang.wang@bytedance.com> References: <20210802211912.116329-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 89927678c..0ae3fc4c8 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, @@ -2311,6 +2314,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