Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp7749980pxb; Thu, 18 Feb 2021 20:26:07 -0800 (PST) X-Google-Smtp-Source: ABdhPJzrc8StKYuznkg3fGsgU0qG0NLQbkespSdn2pTLXP/fRsnfGIJZqR85KcaS3ZniwgbcUPmQ X-Received: by 2002:a50:9556:: with SMTP id v22mr7398001eda.336.1613708767496; Thu, 18 Feb 2021 20:26:07 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1613708767; cv=none; d=google.com; s=arc-20160816; b=plDOwO2BF1/XgLhSRPyun1I0ADrxJ0xZVgX9QKl9AkN0Vflj3slAcnNROKBgReFZ67 mDxsleWXedV0bM1ObawHZk+/T/wxo70hv2I5xue96QCC16DsS3UtOv8CaIHs+7z73xbV wrdD0YvqUeKQsQxwKqAQ2fmS5vZzHT6boKXCNS44igsYgamYEMMNyl5nkU/fF392ec81 v9kTXYRcIs4Tf63Nq505lQJlA+i5lVqE+mAVTSslChsk3tovF6Bp1ZL8ufOaDPq9vjEs 62i7Y9R/lKk62FG72Kdww2ps1pjC/yxRdnt4rYxlIO5777/2tY5h5vCvNMHtAj2Hy45y AZng== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date; bh=k340BvgtPdZwTYfUkV/ICf72VvmSszk62kPd/B117FI=; b=FfPwZgmINzAP7UMc5FT4lHiVN7FUNvxUyGbYaHuO+F4yEZvyvaisRCIKORjyNQmCa7 Nz+K4NEjmE7JOy1LDmZFGpmjIePoitfT8wA6AoxBRLQVJyEWUH1gxVO1np3A9FJAbMBu wPSqi17mehaGq6vhEAfaRfzgIzSTBDFaiSmEUPHco8d9NR5yRa9VKdKOo64xqnzOgYc9 YUIvfD30MA2HsgJghf7OE13OdzhrmD2GAvzwDgckKb5TBNStqdgiT0GA2LxjZSQNeuqT JjcGMLccWX6Y1z/Cm6oNlhNAMz+jqt+N+/RRHnXNePYZA3L3c+kbrd0UtXKi+SLx9nz4 4cdw== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id sb17si5613741ejb.228.2021.02.18.20.25.44; Thu, 18 Feb 2021 20:26:07 -0800 (PST) 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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229826AbhBSEXD (ORCPT + 99 others); Thu, 18 Feb 2021 23:23:03 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54902 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229598AbhBSEXB (ORCPT ); Thu, 18 Feb 2021 23:23:01 -0500 Received: from zeniv-ca.linux.org.uk (zeniv-ca.linux.org.uk [IPv6:2607:5300:60:148a::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1B6E2C061756; Thu, 18 Feb 2021 20:22:21 -0800 (PST) Received: from viro by zeniv-ca.linux.org.uk with local (Exim 4.94 #2 (Red Hat Linux)) id 1lCxJ5-00FgXI-1r; Fri, 19 Feb 2021 04:22:19 +0000 Date: Fri, 19 Feb 2021 04:22:19 +0000 From: Al Viro To: Denis Kirjanov Cc: Christoph Hellwig , linux-kernel@vger.kernel.org, Jakub Kicinski , linux-fsdevel@vger.kernel.org Subject: [PATCH 5/8] fold unix_mknod() into unix_bind_bsd() Message-ID: References: <20210125154937.26479-1-kda@linux-powerpc.org> <20210127175742.GA1744861@infradead.org> <20210129082524.GA2282796@infradead.org> <20210129131855.GA2346744@infradead.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: Sender: Al Viro Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Signed-off-by: Al Viro --- net/unix/af_unix.c | 39 +++++++++++++++------------------------ 1 file changed, 15 insertions(+), 24 deletions(-) diff --git a/net/unix/af_unix.c b/net/unix/af_unix.c index d7aeb4827747..36b88c8c438b 100644 --- a/net/unix/af_unix.c +++ b/net/unix/af_unix.c @@ -984,45 +984,36 @@ static struct sock *unix_find_other(struct net *net, return NULL; } -static int unix_mknod(const char *sun_path, umode_t mode, struct path *res) +static int unix_bind_bsd(struct sock *sk, struct unix_address *addr) { + struct unix_sock *u = unix_sk(sk); + umode_t mode = S_IFSOCK | + (SOCK_INODE(sk->sk_socket)->i_mode & ~current_umask()); + struct path parent, path; struct dentry *dentry; - struct path path; - int err = 0; + unsigned int hash; + int err; + /* * Get the parent directory, calculate the hash for last * component. */ - dentry = kern_path_create(AT_FDCWD, sun_path, &path, 0); - err = PTR_ERR(dentry); + dentry = kern_path_create(AT_FDCWD, addr->name->sun_path, &parent, 0); if (IS_ERR(dentry)) - return err; + return PTR_ERR(dentry); /* * All right, let's create it. */ - err = security_path_mknod(&path, dentry, mode, 0); + err = security_path_mknod(&parent, dentry, mode, 0); if (!err) { - err = vfs_mknod(d_inode(path.dentry), dentry, mode, 0); + err = vfs_mknod(d_inode(parent.dentry), dentry, mode, 0); if (!err) { - res->mnt = mntget(path.mnt); - res->dentry = dget(dentry); + path.mnt = mntget(parent.mnt); + path.dentry = dget(dentry); } } - done_path_create(&path, dentry); - return err; -} - -static int unix_bind_bsd(struct sock *sk, struct unix_address *addr) -{ - struct unix_sock *u = unix_sk(sk); - struct path path = { }; - umode_t mode = S_IFSOCK | - (SOCK_INODE(sk->sk_socket)->i_mode & ~current_umask()); - unsigned int hash; - int err; - - err = unix_mknod(addr->name->sun_path, mode, &path); + done_path_create(&parent, dentry); if (err) { if (err == -EEXIST) err = -EADDRINUSE; -- 2.11.0