Received: by 2002:a25:868d:0:0:0:0:0 with SMTP id z13csp444266ybk; Wed, 13 May 2020 04:22:19 -0700 (PDT) X-Google-Smtp-Source: APiQypJPIHTfGEWuriSt70Ya6AHjsfl08+N1ZFsG9RJ4Shjq1vNce60Bfr0eSU/DyNXuAjCuyOFj X-Received: by 2002:a50:d0d7:: with SMTP id g23mr15904635edf.163.1589368939404; Wed, 13 May 2020 04:22:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1589368939; cv=none; d=google.com; s=arc-20160816; b=gSMHwW2JM9Zx4yr3YUWeO+B7VX1fz+S4RdhKzs3Y6NTjZ36ioViDeDTSJ5cd5UNydZ Qbc3X0GzTp+0Js+vQQnYyy6UCpus9F4YzadUVe8bhfdPmIOH/q0tgn/MyRwzw/U0ef9j LKDpnvlzQ9wTFUIk3q8aybwO/NRuxhX/c8Bvu1+pkywi646doFUS7TX2sG9jKyaUvXBp QTVr210rAiiZ0xlfF+9xZzAj+9w1FW0xSZwP8Kh1yPt9dBzSxuXHciNbx5DmVrvqUSR7 2+dbN/1aQuLsdRToygc0JEiC0cLIByuOzmb9tha79d2GknDLDyPIf4dMXmpTH0h/jeh+ G7JA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=RLvo7hjDcvVtOrezk4Nkw939gaaMTzcPPQGV3XxANWQ=; b=X/Djuf4g2mS8ICJxne7D/Slabh2XKw7NDFKPhml+1Anyyycy81C9fcq0ymw2XktwFI Jez+yMGD493b/iaR+YP0dDV+VxNEWrbcNhmGYR6ytOXgRg9354YD8jy7lBVY1cmZAfgp Y+qKeY3Q923CAA6scMGTbKd3p9tNYhvBB90pvqEg7G4H/rJBhtn0j6fjL9ZH4+GiHa2t GkYxUofJhrTza70zmYrNCRBgyWD31YuetXTjvOgFutuYTYOc93dZwWkaYfWo1+8HSrr9 iQF6Orci7Fqet01H6HmytAy1gDedhWf3SL3zduOI/U/zPAOzLl+kquJ/0nOKNqs6B8mn DjVw== 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 bi13si10019072edb.449.2020.05.13.04.21.56; Wed, 13 May 2020 04:22:19 -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; 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 S2388365AbgEMKDP (ORCPT + 99 others); Wed, 13 May 2020 06:03:15 -0400 Received: from verein.lst.de ([213.95.11.211]:45385 "EHLO verein.lst.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1733187AbgEMJtM (ORCPT ); Wed, 13 May 2020 05:49:12 -0400 Received: by verein.lst.de (Postfix, from userid 2407) id C02CF68C65; Wed, 13 May 2020 11:49:08 +0200 (CEST) Date: Wed, 13 May 2020 11:49:08 +0200 From: Christoph Hellwig To: Ido Schimmel Cc: Christoph Hellwig , "David S. Miller" , Jakub Kicinski , netdev@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH 2/3] net/scm: cleanup scm_detach_fds Message-ID: <20200513094908.GA31756@lst.de> References: <20200511115913.1420836-1-hch@lst.de> <20200511115913.1420836-3-hch@lst.de> <20200513092918.GA596863@splinter> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200513092918.GA596863@splinter> User-Agent: Mutt/1.5.17 (2007-11-01) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, May 13, 2020 at 12:29:18PM +0300, Ido Schimmel wrote: > On Mon, May 11, 2020 at 01:59:12PM +0200, Christoph Hellwig wrote: > > Factor out two helpes to keep the code tidy. > > > > Signed-off-by: Christoph Hellwig > > Christoph, > > After installing net-next (fb9f2e92864f) on a Fedora 32 machine I cannot > ssh to it. Bisected it to this commit [1]. > > When trying to connect I see these error messages in journal: > > sshd[1029]: error: mm_receive_fd: no message header > sshd[1029]: fatal: mm_pty_allocate: receive fds failed > sshd[1029]: fatal: mm_request_receive_expect: buffer error: incomplete message > sshd[1018]: fatal: mm_request_receive: read: Connection reset by peer > > Please let me know if more info is required. I can easily test a patch > if you need me to try something. To start we can try reverting just this commit, which requires a little manual work. Patch below: --- From fe4f53219b42aeded3c1464dbe2bbc9365f6a853 Mon Sep 17 00:00:00 2001 From: Christoph Hellwig Date: Wed, 13 May 2020 11:48:33 +0200 Subject: Revert "net/scm: cleanup scm_detach_fds" This reverts commit 2618d530dd8b7ac0fdcb83f4c95b88f7b0d37ce6. --- net/core/scm.c | 94 +++++++++++++++++++++++--------------------------- 1 file changed, 43 insertions(+), 51 deletions(-) diff --git a/net/core/scm.c b/net/core/scm.c index a75cd637a71ff..2d9aa5682bed2 100644 --- a/net/core/scm.c +++ b/net/core/scm.c @@ -280,53 +280,18 @@ void put_cmsg_scm_timestamping(struct msghdr *msg, struct scm_timestamping_inter } EXPORT_SYMBOL(put_cmsg_scm_timestamping); -static int __scm_install_fd(struct file *file, int __user *ufd, int o_flags) -{ - struct socket *sock; - int new_fd; - int error; - - error = security_file_receive(file); - if (error) - return error; - - new_fd = get_unused_fd_flags(o_flags); - if (new_fd < 0) - return new_fd; - - error = put_user(new_fd, ufd); - if (error) { - put_unused_fd(new_fd); - return error; - } - - /* Bump the usage count and install the file. */ - sock = sock_from_file(file, &error); - if (sock) { - sock_update_netprioidx(&sock->sk->sk_cgrp_data); - sock_update_classid(&sock->sk->sk_cgrp_data); - } - fd_install(new_fd, get_file(file)); - return error; -} - -static int scm_max_fds(struct msghdr *msg) -{ - if (msg->msg_controllen <= sizeof(struct cmsghdr)) - return 0; - return (msg->msg_controllen - sizeof(struct cmsghdr)) / sizeof(int); -} - void scm_detach_fds(struct msghdr *msg, struct scm_cookie *scm) { struct cmsghdr __user *cm = (__force struct cmsghdr __user*)msg->msg_control; - int o_flags = (msg->msg_flags & MSG_CMSG_CLOEXEC) ? O_CLOEXEC : 0; - int fdmax = min_t(int, scm_max_fds(msg), scm->fp->count); - int __user *cmsg_data = CMSG_USER_DATA(cm); + + int fdmax = 0; + int fdnum = scm->fp->count; + struct file **fp = scm->fp->fp; + int __user *cmfptr; int err = 0, i; - if (msg->msg_flags & MSG_CMSG_COMPAT) { + if (MSG_CMSG_COMPAT & msg->msg_flags) { scm_detach_fds_compat(msg, scm); return; } @@ -335,35 +300,62 @@ void scm_detach_fds(struct msghdr *msg, struct scm_cookie *scm) if (WARN_ON_ONCE(!msg->msg_control_is_user)) return; - for (i = 0; i < fdmax; i++) { - err = __scm_install_fd(scm->fp->fp[i], cmsg_data + i, o_flags); + if (msg->msg_controllen > sizeof(struct cmsghdr)) + fdmax = ((msg->msg_controllen - sizeof(struct cmsghdr)) + / sizeof(int)); + + if (fdnum < fdmax) + fdmax = fdnum; + + for (i=0, cmfptr =(int __user *)CMSG_USER_DATA(cm); imsg_flags + ? O_CLOEXEC : 0); + if (err < 0) + break; + new_fd = err; + err = put_user(new_fd, cmfptr); + if (err) { + put_unused_fd(new_fd); + break; + } + /* Bump the usage count and install the file. */ + sock = sock_from_file(fp[i], &err); + if (sock) { + sock_update_netprioidx(&sock->sk->sk_cgrp_data); + sock_update_classid(&sock->sk->sk_cgrp_data); + } + fd_install(new_fd, get_file(fp[i])); } - if (i > 0) { - int cmlen = CMSG_LEN(i * sizeof(int)); - + if (i > 0) + { + int cmlen = CMSG_LEN(i*sizeof(int)); err = put_user(SOL_SOCKET, &cm->cmsg_level); if (!err) err = put_user(SCM_RIGHTS, &cm->cmsg_type); if (!err) err = put_user(cmlen, &cm->cmsg_len); if (!err) { - cmlen = CMSG_SPACE(i * sizeof(int)); + cmlen = CMSG_SPACE(i*sizeof(int)); if (msg->msg_controllen < cmlen) cmlen = msg->msg_controllen; msg->msg_control += cmlen; msg->msg_controllen -= cmlen; } } - - if (i < scm->fp->count || (scm->fp->count && fdmax <= 0)) + if (i < fdnum || (fdnum && fdmax <= 0)) msg->msg_flags |= MSG_CTRUNC; /* - * All of the files that fit in the message have had their usage counts - * incremented, so we just free the list. + * All of the files that fit in the message have had their + * usage counts incremented, so we just free the list. */ __scm_destroy(scm); } -- 2.26.2