Received: by 2002:a05:6a10:c604:0:0:0:0 with SMTP id y4csp315592pxt; Wed, 4 Aug 2021 23:56:21 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw5Xo6brYjhROPspaD34x3YuCoF8iBVKFqAqROVRHVomZT+YymbyHfVf7Y3ukDiS/q0vbWi X-Received: by 2002:a05:6402:2283:: with SMTP id cw3mr4623747edb.87.1628146581197; Wed, 04 Aug 2021 23:56:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1628146581; cv=none; d=google.com; s=arc-20160816; b=b/lEsAZD+rxNuJUAvE6RthX8bDBAmIylX6IqWNKUmEcgtf71IUt9WTmhW99iDqjo9r rTA+tcOS+kelTiWoTw7r+IPg7AE7ty6HBLIqWiApgFyNPwFEVaZbODqOEWDj1C4w8Z0z K45saRFz8qeLaFvExZesNO3Gldi0FizYktuEHTnbjju0CLeHMpLmZb5zIZTdm0IfGJhn Z4LNxkkuicuvJN9SXLru8vZq8hCgbFUqOldqOZzHTKtcYP8hXqwVQaYDmyFmB+BYYi7V AFu/GQQU4ty7rpBLqllm40Ian+r899bAyG9dpZHb7Fupgq2DL53vOeNQmBtxnBIhNnQb /D9A== 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=EZ9uHDi7uoO0eRFoa78Ada57+Eg23guA5nhYDnly2Aia/bZXLoytHppDMteBDcE+70 qz0eeRAJPtvO8vUuwK4xlkRVWyFDDQCKgVw1O1mqGMRyCmq47NWiRWQeMzUScwLOZJOd OPTOOF0YV/i/BOli9E/9iMcqblpxryZsN5z5Ng4E+xVcbRyPYpp6Sf7PAm9WnNd3CMdw zG6y9aqTfRvLnkGiAB+q9FaDwgZwHdzKKn9KIregrQZsAp4Zqa7u79LADFVvrE0O2fT7 vMTei3jegH0KcfhZgexZx1bP3w3APKd3vYUqUsczjD7UA3Zn89K2ZJsCl70blw8uoZvk 2UAg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@bytedance-com.20150623.gappssmtp.com header.s=20150623 header.b=kbbIfWLn; 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 lk14si4670707ejb.559.2021.08.04.23.55.56; Wed, 04 Aug 2021 23:56:21 -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=kbbIfWLn; 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 S237010AbhHEFOO (ORCPT + 99 others); Thu, 5 Aug 2021 01:14:14 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56208 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237061AbhHEFOO (ORCPT ); Thu, 5 Aug 2021 01:14:14 -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 A5FA3C0613C1 for ; Wed, 4 Aug 2021 22:14:00 -0700 (PDT) Received: by mail-pl1-x635.google.com with SMTP id k2so5649278plk.13 for ; Wed, 04 Aug 2021 22:14:00 -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=kbbIfWLnf1f9HRgVSHpYM44TCZobQoXD04sDX3qdumrizkrXTm4JzaSoxVEIH82beG Z+EPdXRCZne5sgygWSflaYL+N4EZmWuJv2yevWIYayEQe/RctKj6jJu7SA1v5bZN1155 E8Ydl8mHRceDPOkCopzefU27eFn7e7lenDmEZkd4oSVghqrEtcRwdjZbtXR0lOmay2BH pB+6UHNKgcHMnqPKqNDpbaq5OrJW/g646ISrefB1q9OmNhekn5uzhm8254m7plqJPuxg vDsPknCOKdMlqsXmgZpQApcMu0JaMJfF7KXi8WExg745ssFH5ChWWXT7sHayLTVnFBwk L1ZQ== 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=bBtpZaBfBWtGVm/FCxn85323j8i0S61xP9xhxN1olkmfmweyyxOm1xMRrU7a1rxnye ixq5FHDsZyGm5QPZWB5X0Snu8OZ51y73JzG1h6R7wA5cw/qbxuT9WGDVs2VC969qEKQq x2D5MDEJ/ckfINRBJLVSzTpdCajjfu3DH0Q6qXe4zoxMzMn/gI4RbZbb7JgjVetr41G+ 5trQUDmtLvgia10QO/uGeMquPi/bAtaOVMEA3lNQEZqy4MYG1+PMCtMr88CvXNZIngYr WeQG8WXk6ivOH5+4xMS9dwoa2W+2KJSv7lAEUSSkaX56k1OPWH3yGfFzYDE1YACjFTNu YCdQ== X-Gm-Message-State: AOAM532ick9mD8N5Hy8lMVK9xvdrh1jp3sYIbkxOKnDTel3yMTovPZ0G 1ikuOy3gRVw7onAnM2Tl2N+y9Q== X-Received: by 2002:a17:90b:514:: with SMTP id r20mr2815663pjz.80.1628140440230; Wed, 04 Aug 2021 22:14: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 k4sm4201098pjs.55.2021.08.04.22.13.58 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 04 Aug 2021 22:13:59 -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 v4 1/5] af_unix: add read_sock for stream socket types Date: Thu, 5 Aug 2021 05:13:33 +0000 Message-Id: <20210805051340.3798543-2-jiang.wang@bytedance.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20210805051340.3798543-1-jiang.wang@bytedance.com> References: <20210805051340.3798543-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