Received: by 2002:a05:6a10:c604:0:0:0:0 with SMTP id y4csp2986489pxt; Mon, 9 Aug 2021 13:54:48 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyM9FZAHjV7CNflH4fAGey9cz57Ue2EBBTNlo9LITUgmaM9JPAO+OV9etbLIwmpJD7l6pvB X-Received: by 2002:a05:6402:26d1:: with SMTP id x17mr285747edd.126.1628542488625; Mon, 09 Aug 2021 13:54:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1628542488; cv=none; d=google.com; s=arc-20160816; b=J7pBOoEPf5wYSA7+xbT85QVYKHD9QdSsWK9l5syLzW+z+ySjQw8unwVGQkjtBgbFAz O3D24im/+6+YZRKBIHUyIslbDy1kJC/A973/r+Sp1zacIlATPGEtKTlAA6yhxkDfmdhE uOKInYZyCJxBEZpSIUH64dggiETFhEaB7GKs2ikmW0kf8pRnFaPH5tx47thiqHqF7wkE ppze4t/LvNfckk5i3OnOzlapY3oCI1P0Wt5Xs59Dw+c7qM1TziFD2iJ4kUJSd6g+hPTV 0R9pNqFk9+Tcv4LXdaXaRyfWL5ig93SmbW0MKVeq65nVZhpUOaufDv+waSnJiuL91PQx kXbg== 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=kUllV3DBmiSMYJylDDx6u2hxJpc3XLFcCu2/N9midzXCpFwrvoyogst76/X+2U+gPo /t6fQcAJcG5Ykmn0YqgNtxvR134c9pgWPeZpdgk1h5yetcvzyUlq9xZDKLE4bh/mowuG QJqyf2Ygraha6DIt2cd8hO4c4HXlnItJLzSSGX54GilXr88B5nN1YHufJUDWO3qd3WJp y/8JFMCPWs8Jn++84Z3FmXLpEA1OtgFEyaqpiVvzQJlYydDazGTOAi7cfdLCsinYZrt6 h08ToN3f5x/sXzSk96oDs5CPNm+pAxs6P1OlPpMlyqappIUuWpplYawqSntxZ4HqXxZX XVLw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@bytedance-com.20150623.gappssmtp.com header.s=20150623 header.b=KC3n99VE; 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 sb17si18211833ejb.349.2021.08.09.13.53.55; Mon, 09 Aug 2021 13:54:48 -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=KC3n99VE; 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 S236090AbhHITsX (ORCPT + 99 others); Mon, 9 Aug 2021 15:48:23 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33950 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236059AbhHITsV (ORCPT ); Mon, 9 Aug 2021 15:48:21 -0400 Received: from mail-pj1-x102d.google.com (mail-pj1-x102d.google.com [IPv6:2607:f8b0:4864:20::102d]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2351DC061796 for ; Mon, 9 Aug 2021 12:48:01 -0700 (PDT) Received: by mail-pj1-x102d.google.com with SMTP id gz13-20020a17090b0ecdb0290178c0e0ce8bso795757pjb.1 for ; Mon, 09 Aug 2021 12:48:01 -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=KC3n99VEaWNMUZdMdyY9zKGuyHsfZ99gdj1BB7pOe2GUIDHiKeQq6fujCf6k2XGlNh +f4qPDcQfvMWe4mORcVFByr4dKslSWEb8icxESZ6C1/ByE3DLvsf1vh3hJ/xmXhvKAN+ uWRapfdmnOfNsSQBsIjQ1ceIYU7grQPapTkVgGyF22CTqGxvZ2y5mCkb8qd0pzWKnNcF chaQWAExevXr5Uc5ZvD89GrU0ovBIGw/OGRU6+ZedZXfiDG1knEX1/qMjGWUNw3lSSWe v131W5ApL9Mv4JrqBegMNNchTq7RZvPkqlk2xffd9SBabboRCCxjKetqifpRprVgYn+L FDgg== 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=mi/yrUpabi814FYgQNeeW4xqBoktoqBw+0Pf8G95k95infCeQuOv0498bkzc1ZN166 YS9ibwQc9md/CZLMZL+KJoQKGTwTlF14sK7RSif4zNowmBP12LNQYsoJL1uG2iukD8e3 NKgvqrijwUEeRSISRyqf5+7Kjay6AKYhq7FWFk2JoY3J3ejUMMETyspy3C94Tua1Jesw n46KWVJl7j3JJMAM1UhTp/MMffZtixHGO3cen2iazXN9u8RODg3kFSXri4uiI1pg0I0s FcoqocPNHNzFPXG8tGidUp4j+vg/+hFjSpi3MCupae7YMkdBgnYHEDVTumbg66M0n+sq 7+gA== X-Gm-Message-State: AOAM5303+i31abpMZ+xHc6AK8OtK5fLzF9mofBwc8wiheRZcPKQEMtLj dKdtYl89uhDflbxKqW6/7kqsaQ== X-Received: by 2002:a62:1d45:0:b029:3ab:415e:8d5f with SMTP id d66-20020a621d450000b02903ab415e8d5fmr25383591pfd.8.1628538480679; Mon, 09 Aug 2021 12:48:00 -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 x19sm21372291pfa.104.2021.08.09.12.47.59 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 09 Aug 2021 12:48:00 -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 v6 1/5] af_unix: add read_sock for stream socket types Date: Mon, 9 Aug 2021 19:47:34 +0000 Message-Id: <20210809194742.1489985-2-jiang.wang@bytedance.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20210809194742.1489985-1-jiang.wang@bytedance.com> References: <20210809194742.1489985-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