Re: [PATCH] Add /proc/pid_generation

From: Kevin Easton
Date: Thu Nov 22 2018 - 06:27:05 EST


On Wed, Nov 21, 2018 at 12:14:44PM -0800, Daniel Colascione wrote:
> This change adds a per-pid-namespace 64-bit generation number,
> incremented on PID rollover, and exposes it via a new proc file
> /proc/pid_generation. By examining this file before and after /proc
> enumeration, user code can detect the potential reuse of a PID and
> restart the task enumeration process, repeating until it gets a
> coherent snapshot.

I see downthread this patch has been withdrawn, but nonetheless I'm
still curious - does this actually solve the problem?

It seems to me that a PID could be reused within a scan even if the
generation number remains the same at the beginning and end of a scan:

Say you have a very long-lived task with PID 500 allocated in generation
0. The PID creation has since wrapped and we are now allocating from the
start of the range again, with generation 1. We begin a scan of /proc,
read the generation (1) and at this point, our task dies and PID 500 is
then reallocated to a new task. We finish our scan, generation is still
1 but PID 500 is now ambiguous.

Am I wrong?

- Kevin