Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp708937yba; Wed, 15 May 2019 08:36:49 -0700 (PDT) X-Google-Smtp-Source: APXvYqwMPOBdFNfOVHHe66AYd+uriZgakPGlRONqumEL6PuBAbyhIBlU4wfVUFAMVNRCI7mEjQAH X-Received: by 2002:a17:902:b581:: with SMTP id a1mr44108256pls.206.1557934609436; Wed, 15 May 2019 08:36:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1557934609; cv=none; d=google.com; s=arc-20160816; b=bCNNLUkXyaNcemJaPwn0vDf+a02MoI5lpUxMp9Cx+uKXwlBhpLD5RmIHPFYjV6YEB2 alrJo6eCwXKmRwIW2s5GywD1AWYXQZZmIe0AS3NBK0DgrBN7VPvsVFUh/LOQaSkBMCcx iJ284gPmwNB/Wu+jDGkwrcUrLW8Uvt3PTtaxvRoGSfWtFDyhCRQ8H0/3+LI2KNXuObJo VmfvhSYaN40SsA32CBT2Nm+S6QhH63noH6CDF1dJSoeUuZ1mknLXq0SHNeEcOckGW7A9 4iTz5R42W0pnEhGmN76m6G9276veGke4ea3om9GqNkycEQRYVIgMSJB0ssh2c+Hg34t8 MLog== 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=Mhf71kRkv/dEtnsCKn3gSZQtvmACX7EG+O+/STM2RK0=; b=gD2PI1N4A6AmbLV3ezvztTPEJdDRbPRmifGv3Z9wIdwhJQlnCidh7ukToceoHyXZfd +FUTOCQ1WEKeqjoqScVggiv7ti0g+sG0OhHTUFTz8ri/j0kdOzwFsSkqqSpiJIDDWwvE bfz04yU2qc0uHlKWidDUKptMrtPj8vyuOr1zXkfgEqUnDfuDbh+YIwzfMuMONA69Uafy bbVI1aIn6N0mr2lXqtqsWQvJWfbu0PsByQNIwhWlmsSqvHC/2I/mvUbLhBkqf1YPYsVh lz2a+5fiX7wPEEbM1V5GCH7Ym+gdIF3qf7L1e1aEr+J3dJvZupCBxKmOBXDuLMTYsQCj hjMA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id m9si2029018plt.182.2019.05.15.08.36.34; Wed, 15 May 2019 08:36:49 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728390AbfEOPfZ (ORCPT + 99 others); Wed, 15 May 2019 11:35:25 -0400 Received: from mx1.redhat.com ([209.132.183.28]:60786 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726335AbfEOPfY (ORCPT ); Wed, 15 May 2019 11:35:24 -0400 Received: from smtp.corp.redhat.com (int-mx02.intmail.prod.int.phx2.redhat.com [10.5.11.12]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 8E07930842A2; Wed, 15 May 2019 15:35:23 +0000 (UTC) Received: from dhcp-27-174.brq.redhat.com (unknown [10.43.17.159]) by smtp.corp.redhat.com (Postfix) with SMTP id 884EC60BE5; Wed, 15 May 2019 15:35:18 +0000 (UTC) Received: by dhcp-27-174.brq.redhat.com (nbSMTP-1.00) for uid 1000 oleg@redhat.com; Wed, 15 May 2019 17:35:20 +0200 (CEST) Date: Wed, 15 May 2019 17:35:15 +0200 From: Oleg Nesterov To: Christian Brauner Cc: jannh@google.com, viro@zeniv.linux.org.uk, torvalds@linux-foundation.org, linux-kernel@vger.kernel.org, arnd@arndb.de, dhowells@redhat.com, akpm@linux-foundation.org, cyphar@cyphar.com, ebiederm@xmission.com, elena.reshetova@intel.com, keescook@chromium.org, luto@amacapital.net, luto@kernel.org, tglx@linutronix.de, linux-alpha@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-ia64@vger.kernel.org, linux-m68k@lists.linux-m68k.org, linux-mips@vger.kernel.org, linux-parisc@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, linux-s390@vger.kernel.org, linux-sh@vger.kernel.org, sparclinux@vger.kernel.org, linux-xtensa@linux-xtensa.org, linux-api@vger.kernel.org, linux-arch@vger.kernel.org, linux-kselftest@vger.kernel.org Subject: Re: [PATCH 1/2] pid: add pidfd_open() Message-ID: <20190515153515.GA20783@redhat.com> References: <20190515100400.3450-1-christian@brauner.io> <20190515143857.GB18892@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190515143857.GB18892@redhat.com> User-Agent: Mutt/1.5.24 (2015-08-30) X-Scanned-By: MIMEDefang 2.79 on 10.5.11.12 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.40]); Wed, 15 May 2019 15:35:24 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 05/15, Oleg Nesterov wrote: > > On 05/15, Christian Brauner wrote: > > > > +SYSCALL_DEFINE2(pidfd_open, pid_t, pid, unsigned int, flags) > > +{ > > + int fd, ret; > > + struct pid *p; > > + struct task_struct *tsk; > > + > > + if (flags) > > + return -EINVAL; > > + > > + if (pid <= 0) > > + return -EINVAL; > > + > > + p = find_get_pid(pid); > > + if (!p) > > + return -ESRCH; > > + > > + rcu_read_lock(); > > + tsk = pid_task(p, PIDTYPE_PID); > > You do not need find_get_pid() before rcu_lock and put_pid() at the end. > You can just do find_vpid() under rcu_read_lock(). Ah, sorry. Somehow I forgot you need to call pidfd_create(pid), you can't do this under rcu_read_lock(). So I was wrong, you can't avoid get/put_pid. Oleg.