Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp3754624ybi; Mon, 29 Jul 2019 12:01:48 -0700 (PDT) X-Google-Smtp-Source: APXvYqxQ4h4IEyW2Dil7aHfDuqdXBwyLC9XUxW/YwcYVMPIkXCtmT7bN1q/REArnJfcYo4a2oLxr X-Received: by 2002:a63:4823:: with SMTP id v35mr78231320pga.138.1564426908288; Mon, 29 Jul 2019 12:01:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1564426908; cv=none; d=google.com; s=arc-20160816; b=UYTp6V20vdNmNgzon8zb/0eASBQOhtNr/AHuCbYfMuV63ETaKeKVWTs4omQuly1Y+D mscoiEG/41PAO20rfgyp3JMVdKqjM7Z6Ioy2qVawDdixItBcrwtfxgZjWMwTnLAyAvIM fHkxNbpUsOj+t8h8icDaJBa2uni4kb8LgJ2y/J7cJ0sTbWseHyCypadFlm//MI5+VKTc cxkZ7uwQPBERB+b40ngnlSUhyuoEoDyV5H6lMUEkznO603J5n8asAiR+WyGilov+tibu l/1TfuiApGUmGzWHndd4dbL9OvO5K4kaVsFvPVk83+0JtcWqgMFDqgZ9CtRUBOdP9H9u v/1w== 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 :dkim-signature; bh=Hfu708o/mVgXoKaiBjfu2KmWx5O5JJDKePJXiIrhEfE=; b=GV30VbkRJIr13bK/+pQg3JcmiUXKPisEk9ufRJk9qcNyTGFh4FVaiTMJIC4cnCX5K3 4TEyoZWoBh9Gs8gEgLwhWY2N7CA7GrV150n+8SZKHCzAUcsF4QUEEFksDeQ/nL5IaI8z gnUjtXEqBXtXjLmnCkI0MB3bOc4nFgXO0714g1OgtQr3rAiKRbNsGEySyNPpaZhz+IqR MdPmtz75t68l5Urdo2sAHF3aN1Xvfky1AUE4B/PTOMKTlclp1LeFRh6PByi+EF3sDAGo E8kr6m6wR3inlCNUuaaYRVt7P7qNmeCmKv8eoQ3JsG1N3WJbtuKyyxUv9bHoTtfADdP0 +JTw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=IwVnGfXV; 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=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a186si26225172pge.365.2019.07.29.12.01.32; Mon, 29 Jul 2019 12:01:48 -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; dkim=pass header.i=@chromium.org header.s=google header.b=IwVnGfXV; 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=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728929AbfG2QYl (ORCPT + 99 others); Mon, 29 Jul 2019 12:24:41 -0400 Received: from mail-pf1-f193.google.com ([209.85.210.193]:46574 "EHLO mail-pf1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728487AbfG2QYl (ORCPT ); Mon, 29 Jul 2019 12:24:41 -0400 Received: by mail-pf1-f193.google.com with SMTP id c3so5154515pfa.13 for ; Mon, 29 Jul 2019 09:24:40 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to; bh=Hfu708o/mVgXoKaiBjfu2KmWx5O5JJDKePJXiIrhEfE=; b=IwVnGfXVwYw5/ml78DM05Lc3bvqXArkV7u+TuWjeF7i5Cf8f1BT64SqqDwOW4Uq+f6 TOAf8hjXnVS/Bb1DCAadVxB8Dvcqhv7RcW0L9QaFT5apGyzltdF6UKsmtV2c86TMtatx 71SBpHd25E+BFsaaryC6RivxCDMsG2h9H/tZE= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to; bh=Hfu708o/mVgXoKaiBjfu2KmWx5O5JJDKePJXiIrhEfE=; b=l4RRxXGVKqyLbuo9CDwO68CN02azrp+CSqAKLl+0/Rt645Mu4gkQ4w8QSOhtfE2FYg vzAfd8IBqVGqx8jAoNIUhG/5VsQVwg6kKAYMnIZHDRXeK0KyHD5etEFzsT75rPTVekfT Y4xbki7e/6keEMm79IGWWJazxqBS1z8Ser18FEyzEDTldc5v6IK/7QZ/Ol8w9/J765Ct FNrUeIgZnEEsoVk5Q2+fbvDoPbyHmnhgN1vr3RrRKiIF1dI2LeBPDVnTtzJTqukM8i6U V+ME/e+dX0nJ154Lm4jJoqXt6ag/Jdc9Mc4cCGczUpylgZAowJc+nOjAbr3Hn/mjRmi1 C29A== X-Gm-Message-State: APjAAAVdGakPKFgMprZGqrXvfT1a6yhTzFwnGwDegWccmduTrZ6F7/oZ 3Phkoquv+jj1+z1R+28LfTXyzQ== X-Received: by 2002:a62:7a8a:: with SMTP id v132mr37390223pfc.103.1564417480398; Mon, 29 Jul 2019 09:24:40 -0700 (PDT) Received: from www.outflux.net (smtp.outflux.net. [198.145.64.163]) by smtp.gmail.com with ESMTPSA id 65sm64996154pgf.30.2019.07.29.09.24.39 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Mon, 29 Jul 2019 09:24:39 -0700 (PDT) Date: Mon, 29 Jul 2019 09:24:38 -0700 From: Kees Cook To: Christian Brauner Cc: linux-kernel@vger.kernel.org, oleg@redhat.com, torvalds@linux-foundation.org, arnd@arndb.de, ebiederm@xmission.com, joel@joelfernandes.org, tglx@linutronix.de, tj@kernel.org, dhowells@redhat.com, jannh@google.com, luto@kernel.org, akpm@linux-foundation.org, cyphar@cyphar.com, viro@zeniv.linux.org.uk, kernel-team@android.com Subject: Re: [PATCH v3 1/2] pidfd: add P_PIDFD to waitid() Message-ID: <201907290915.8B421306D@keescook> References: <20190727222229.6516-1-christian@brauner.io> <20190727222229.6516-2-christian@brauner.io> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190727222229.6516-2-christian@brauner.io> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun, Jul 28, 2019 at 12:22:29AM +0200, Christian Brauner wrote: > diff --git a/kernel/exit.c b/kernel/exit.c > index a75b6a7f458a..64bb6893a37d 100644 > --- a/kernel/exit.c > +++ b/kernel/exit.c > @@ -1552,6 +1552,23 @@ static long do_wait(struct wait_opts *wo) > return retval; > } > > +static struct pid *pidfd_get_pid(unsigned int fd) > +{ > + struct fd f; > + struct pid *pid; > + > + f = fdget(fd); > + if (!f.file) > + return ERR_PTR(-EBADF); > + > + pid = pidfd_pid(f.file); > + if (!IS_ERR(pid)) > + get_pid(pid); > + > + fdput(f); > + return pid; > +} > + > static long kernel_waitid(int which, pid_t upid, struct waitid_info *infop, > int options, struct rusage *ru) > { > @@ -1574,19 +1591,29 @@ static long kernel_waitid(int which, pid_t upid, struct waitid_info *infop, > type = PIDTYPE_PID; > if (upid <= 0) > return -EINVAL; > + > + pid = find_get_pid(upid); > break; > case P_PGID: > type = PIDTYPE_PGID; > if (upid <= 0) > return -EINVAL; > + > + pid = find_get_pid(upid); > + break; > + case P_PIDFD: > + type = PIDTYPE_PID; > + if (upid < 0) > + return -EINVAL; > + > + pid = pidfd_get_pid(upid); > + if (IS_ERR(pid)) > + return PTR_ERR(pid); I spent some time convincing myself that this early bail out was correct. It seems this path is only reachable in the EBADF case, so that makes sense. The other failure modes in this switch all give a NULL pid so that the final do_wait() returns ECHILD. So, as long as that's intentional (which I think it is), this all looks fine. :) Reviewed-by: Kees Cook -- Kees Cook