Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp1059183ybi; Sat, 27 Jul 2019 01:54:13 -0700 (PDT) X-Google-Smtp-Source: APXvYqylyt0ezsk0c+gleI+lYlRHi+bTCoQkDp1z54YYow6Yi4imSi7YA+QKeMYfV5JfayAC6bWP X-Received: by 2002:a17:902:be0a:: with SMTP id r10mr94800109pls.51.1564217653044; Sat, 27 Jul 2019 01:54:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1564217653; cv=none; d=google.com; s=arc-20160816; b=s/CNhSnC9CvIeFdU00dua870IjOXiJGLlGhX2CRBJaD5nWTqguNtFK/82eafV3C/yD 8AHIy/6qaqEcXK3BHeIRCeVPjQrX2iG+t30nlj/FRpm3JgMNV0xNNTJQgTuDaHA8xmzg BSy8f5fVyuQPhrAYoQ/x9utaPjwFstuSBfjVLByqkNU4wvAgnVaZ7PfY50+UjRmcFhVq V1mlDdSz0OGLGzg+yR7FAA5UKdUwSBSrvmdgI/Nbt4GxNvV8ngqXdPAET/0U+HD8+y0w NXj1FGUnSDYBTX31T3O3ZZqT9WkWUnjXmqNnFk3W5q/0EoiHYm1j/FI5L8n6UDRS81NE fOKg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=C25fy3k879XYQNXdbYVGXowE6lZUzsphXo8g8Goy1xE=; b=r3sUaAmKx/Ejnf61rGvL7/q7aT+39zkaNpwqF0ljtKm2ADDVMn5oMN4mJjkmA778ND iL09037YRQUzY+AGa2/P4PjomYsdGh9l07xc5q71VdnWT+xWhSCp+0xreVsZI75Y5qrH LiARsZeRaA16TYRwd9cgf0pqrZJLjZngT9XWAyoZFQLazRzCiWlXVKvGoZDciOAgaiSS loQgs/EfHSr2Ch/XCSQ6GyFCZKhNnPB/OAwzsH9IsRTWvtFHNlQ7/iLPb/8UQf6BdoP5 bdcrRxyIcfcssYE4xuTWwyUW5bsLUmGPR7CSZxr4rMA4pw8nptLp1zqIfcYWn5T88TNJ 36rA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@brauner.io header.s=google header.b=Mis8aF0d; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id e8si20484256plb.420.2019.07.27.01.53.58; Sat, 27 Jul 2019 01:54:13 -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=@brauner.io header.s=google header.b=Mis8aF0d; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728571AbfG0IxU (ORCPT + 99 others); Sat, 27 Jul 2019 04:53:20 -0400 Received: from mail-wr1-f66.google.com ([209.85.221.66]:37608 "EHLO mail-wr1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727885AbfG0IxU (ORCPT ); Sat, 27 Jul 2019 04:53:20 -0400 Received: by mail-wr1-f66.google.com with SMTP id n9so31612997wrr.4 for ; Sat, 27 Jul 2019 01:53:18 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=brauner.io; s=google; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=C25fy3k879XYQNXdbYVGXowE6lZUzsphXo8g8Goy1xE=; b=Mis8aF0dJwg3GRD8U5KQvZWb5bZIwbgHboDXRhZjU26kcTA/ClrKnRksgliWlzNEn7 BTOuv2Um/ADMyc3kItzYKB3yJNJNQF8O/TqXLJPMAfpWzPQBQ8xYsr85DbUoM3Vm7CpH hHPur99wOENT0+z1iKi0+5z/b111Dpfy6ebxDVIIzm4iVVMlEkDrYzOSp/c2xxfSJZyi QdC83H5Mxr1cL9OdPMqFdKVIRl2MKn5YQPf0pUAoxrnlxdMqUyGNRM8S0TSQkM/kcg22 T0ZZmmUf/0+WyjsRNuWJDCEzI0tB74PBkvODv+LyV2DkynQxfbzs68ZoJ6wpXqxyxl+a ncmw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=C25fy3k879XYQNXdbYVGXowE6lZUzsphXo8g8Goy1xE=; b=mFMkHL8J6IdsaqJWR57iISsd4z3jHRakgr/2bBHyA9wthJdo2GFx5IBXxVkyx5aBrw 4hH56MIcS39dz/q92lxGPPKvpJfBmUC4/ariQJzUU0u0tIDUcvO7/lMCHOzZx624oYjJ kYCIB/bIZWeADNkkDH5N1QUD1CEzj1qiZBcv9p56zb0YJYu65HbfegXIQyAjph9b/NDg 0ujx5fL93oLFY3KLFAdiJ+mfFmLsJr0IU7XHkgvPW0sgHzv8+xmXWFFmQC1sP5/vqbP+ 5pU2dalJfpWWRIiskeeTgronLyuo59jJwsAlNS3RaCq2h4qaRFqfx8xSXTqwDMRXIfAd lYbA== X-Gm-Message-State: APjAAAXlqsZmjZBuZEyTyd+YMuh/TUUiIqwcLczMiQmpRcOqOgqdRjuZ dTOJ5Wzs8vNjW7HkTfB7Uhg6uq+YRLs= X-Received: by 2002:a5d:54c7:: with SMTP id x7mr77813434wrv.39.1564217597762; Sat, 27 Jul 2019 01:53:17 -0700 (PDT) Received: from localhost.localdomain ([213.220.153.21]) by smtp.gmail.com with ESMTPSA id y24sm40114584wmi.10.2019.07.27.01.53.16 (version=TLS1_3 cipher=AEAD-AES256-GCM-SHA384 bits=256/256); Sat, 27 Jul 2019 01:53:17 -0700 (PDT) From: Christian Brauner To: linux-kernel@vger.kernel.org, oleg@redhat.com Cc: arnd@arndb.de, ebiederm@xmission.com, keescook@chromium.org, 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, torvalds@linux-foundation.org, viro@zeniv.linux.org.uk, kernel-team@android.com, Christian Brauner Subject: [PATCH v2 0/2] pidfd: waiting on processes through pidfds Date: Sat, 27 Jul 2019 10:51:59 +0200 Message-Id: <20190727085201.11743-1-christian@brauner.io> X-Mailer: git-send-email 2.22.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hey everyone, /* v2 */ This adds the ability to wait on processes using pidfds. This is one of the few missing pieces to make it possible to manage processes using only pidfds. Now major changes have occured since v1. The only thing that was changed has been to move all find_get_pid() calls into the switch statement to avoid checking the type argument twice as suggested by Linus. The core patch for waitid is pleasantly small. The largest change is caused by adding proper tests for waitid(P_PIDFD). /* v1 */ Link: https://lore.kernel.org/lkml/20190726093934.13557-1-christian@brauner.io/ /* v0 */ Link: https://lore.kernel.org/lkml/20190724144651.28272-1-christian@brauner.io Christian Christian Brauner (2): pidfd: add P_PIDFD to waitid() pidfd: add pidfd_wait tests include/linux/pid.h | 4 + include/uapi/linux/wait.h | 1 + kernel/exit.c | 29 ++- kernel/fork.c | 8 + kernel/signal.c | 7 +- tools/testing/selftests/pidfd/pidfd.h | 25 +++ tools/testing/selftests/pidfd/pidfd_test.c | 14 -- tools/testing/selftests/pidfd/pidfd_wait.c | 245 +++++++++++++++++++++ 8 files changed, 313 insertions(+), 20 deletions(-) create mode 100644 tools/testing/selftests/pidfd/pidfd_wait.c -- 2.22.0