Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp6425356pxv; Thu, 29 Jul 2021 14:25:38 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwpdhLZlGjenZ0lmXl7EH0WrrJRxg0hncscoWibyDTWw3laPkUyneIgq6f/kc0JulyibFXS X-Received: by 2002:a6b:b287:: with SMTP id b129mr5661911iof.209.1627593937900; Thu, 29 Jul 2021 14:25:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1627593937; cv=none; d=google.com; s=arc-20160816; b=KFRunxGry3OaUtYRAllXabQ9Owrp5SF5hnvern2tOXkj074GLcqr3mjtWxJSZlS3gw 9ciiUTg0uqroXxsZfe+/QRN2Gj8mEF6jTEtcsdv1DI5+MX+/E6pGuKoTT3BymR4err6U HqMoMwKm3pZjSPexb5EfYpsiIrGBeckK3nBI82r4WI+ovDTPkTawiAmrH5vhQ1PVryEP qelFA4ySothvayrs1N9edtyPKY2dPHbiwB5VZOqGB6cj+HrcpbXYRQZjkzhPpewkiWoo YprA8e4L1OA+iV7dJAn9VDShIx4KGE8CWzhd48rrlArMnxGeYQONtirDqxKdOI755L7r pTjA== 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=PjFacwapYIqPAPzzRuig5SPK2xWcjv7VM6KT+b+tn2tDB6bHpXSXyqC8nxTklMcGp+ HSP87VJi7Vnpv/ERsAC2+7iGfXUBck8eTxYxgVX7mRYEDyCm2w9Awjr+uSdAm40dnT5b uhdagis4LWUbZ75jga9oM/rTuPzI/Nv2Cco5EEL22alNvTndtwFvnG2xIXyyyrDZE+oY DH5Q1fdAsRg9+hUh1jyMmwCrRDkN3Mnq2BwWCkdHvpUujhDY/KQKE/fN+/kwZY9dnoIn U5Gn/rTSHykKvmCmWsAOff6t3Wgljyg3F8p+EKTsyrAMKlUjXQPfClVJOOpmjcVAAumA l/SA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@bytedance-com.20150623.gappssmtp.com header.s=20150623 header.b=aEN3o4qh; 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 l6si2985820ios.26.2021.07.29.14.25.26; Thu, 29 Jul 2021 14:25:37 -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=aEN3o4qh; 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 S234268AbhG2VYi (ORCPT + 99 others); Thu, 29 Jul 2021 17:24:38 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:49736 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234074AbhG2VYa (ORCPT ); Thu, 29 Jul 2021 17:24:30 -0400 Received: from mail-pl1-x635.google.com (mail-pl1-x635.google.com [IPv6:2607:f8b0:4864:20::635]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id AB729C0613CF for ; Thu, 29 Jul 2021 14:24:22 -0700 (PDT) Received: by mail-pl1-x635.google.com with SMTP id d1so8556069pll.1 for ; Thu, 29 Jul 2021 14:24:22 -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=aEN3o4qhlxi3dIZxBQ43eTWGCPh7EmlV5ZH+6tV3nIocmZClxRaV6lLAdf5A7RUU5I 8syfVFwSO5AZimhl6S6dlv74/PX0cTnbGHBT41NZs0MlEHaK08mpul5OMByI2Gtz22g4 l/wz/Qi/spTgzaa2dLlCUQrqPtLMvo8RsXfjUnv8I2prJpyIIeA4mss2IHhaHKkqqn5u kegTxFxaffSbI8d1BQrxUhF1Z0f2QaMlguHWszVW8GwH7jOkeE2ED2W80uu/zWAtyVU9 1gVmBAFglvrYFo73cSmMRMVjAS9CzNuzOK0aMzxwXBdOnAB0uygNR3e1meOvxy5+zd/q 65ug== 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=Nn08060v+xLwTR+b5w8U5xKPDgxN2ZeRjOaWlgYXtbeBwU790X+TM8zdi65tHjLI3V Fi8aVt6ltW3ok1lraTYv24DS8FCopvDEsJmEZ4XJKmMB8amr1Rcw+3+sgUqFblTFWYRc YS+MOtgq/LsuirsR5uo88d6IyHwdNcniQ/MX8NBhB4Llq6NqjBapSD0e8gs6GgS5Lp6y Jo6LQVDQ0DFFUVG3dSmlBr/3oXOTdbdIHah1ftR8U7ul0lOxrcSpJkRPhkFuDammOumm K9Wv7qaQEdIfTLQizG2vVxuONO7T/BbjrdNnWRJowtq1/Whj2Nr26SXO0HjMPIUG3B0d u0AA== X-Gm-Message-State: AOAM532Ox2jcMFYKOE6t29Gfln4+wZE9Z5OnGqEx53S2LJv6gNGWMnW9 z2G8/Ol8zzPup2coDMCI3a8vaw== X-Received: by 2002:a17:90a:138f:: with SMTP id i15mr7373597pja.173.1627593862272; Thu, 29 Jul 2021 14:24:22 -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 c15sm4686258pfl.181.2021.07.29.14.24.20 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 29 Jul 2021 14:24:21 -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 v2 1/5] af_unix: add read_sock for stream socket types Date: Thu, 29 Jul 2021 21:23:57 +0000 Message-Id: <20210729212402.1043211-2-jiang.wang@bytedance.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20210729212402.1043211-1-jiang.wang@bytedance.com> References: <20210729212402.1043211-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