[PATCH] proc_pid_make_inode() fix
authorAlexander Viro <viro@math.psu.edu>
Fri, 15 Mar 2002 07:06:10 +0000 (23:06 -0800)
committerLinus Torvalds <torvalds@home.transmeta.com>
Fri, 15 Mar 2002 07:06:10 +0000 (23:06 -0800)
commit11aec25f03ef4c312bae099007dad94db7d0ae98
treeb8de70167cd1f65456d859c93f5dd89e68f18e5c
parent063b009f71b9ab15e25b1e63d95a7e65b0122ff8
[PATCH] proc_pid_make_inode() fix

In case if proc_pid_make_inode() steps on exiting task we do
iput() and return NULL.  Unfortunately, in that case inode->i_ino
doesn't look like inumber of a per-process inode and we take the
wrong path in proc_delete_inode().  I.e. do dput(PDE(inode)).  Which
is left uninitialized...

We used to get out with that almost by accident - that code
worked only because we had zeroed out one field of union and that
guaranteed that another field would be NULL.  It worked, but broke
at the first occasion.
fs/proc/base.c