From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 64247C433EF for ; Tue, 8 Feb 2022 19:07:53 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1385830AbiBHTHw (ORCPT ); Tue, 8 Feb 2022 14:07:52 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56134 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1352581AbiBHTHu (ORCPT ); Tue, 8 Feb 2022 14:07:50 -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 D5C38C0613CB for ; Tue, 8 Feb 2022 11:07:49 -0800 (PST) Received: from viro by zeniv-ca.linux.org.uk with local (Exim 4.94.2 #2 (Red Hat Linux)) id 1nHVq1-000S8r-Iw; Tue, 08 Feb 2022 19:07:41 +0000 Date: Tue, 8 Feb 2022 19:07:41 +0000 From: Al Viro To: Waiman Long Cc: Christian Brauner , "Eric W. Biederman" , Andrew Morton , Jens Axboe , Alexey Gladkov , David Hildenbrand , Jann Horn , linux-kernel@vger.kernel.org Subject: Re: [PATCH] copy_process(): Move fd_install() out of sighand->siglock critical section Message-ID: References: <20220208163912.1084752-1-longman@redhat.com> 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 On Tue, Feb 08, 2022 at 01:51:35PM -0500, Waiman Long wrote: > On 2/8/22 13:16, Al Viro wrote: > > On Tue, Feb 08, 2022 at 11:39:12AM -0500, Waiman Long wrote: > > > > > One way to solve this problem is to move the fd_install() call out of > > > the sighand->siglock critical section. > > > > > > Before commit 6fd2fe494b17 ("copy_process(): don't use ksys_close() > > > on cleanups"), the pidfd installation was done without holding both > > > the task_list lock and the sighand->siglock. Obviously, holding these > > > two locks are not really needed to protect the fd_install() call. > > > So move the fd_install() call down to after the releases of both locks. > > Umm... That assumes we can delay it that far. IOW, that nothing > > relies upon having pidfd observable in /proc/*/fd as soon as the child > > becomes visible there in the first place. > > > > What warranties are expected from CLONE_PIDFD wrt observation of > > child's descriptor table? > > > I think the fd_install() call can be moved after the release of > sighand->siglock but before the release the tasklist_lock. Will that be good > enough? Looks like it should, but I'd rather hear from the CLONE_PIDFD authors first... Christian, could you comment on that?