[PATCH] 2.5.5 Fix for get_pid hang

Paul Larson (plars@austin.ibm.com)
22 Feb 2002 16:32:32 -0600


--=-NdBfNCEm4tq+wTB/cjXE
Content-Type: text/plain
Content-Transfer-Encoding: 7bit

This is a fix for a problem where if we run out of available pids,
get_pid will hang the system while it searches through the tasks for an
available pid forever.

Thanks,
Paul Larson

--=-NdBfNCEm4tq+wTB/cjXE
Content-Disposition: attachment; filename=getpid25.patch
Content-Transfer-Encoding: quoted-printable
Content-Type: text/x-patch; charset=ISO-8859-1

diff -Naur linux-2.5.5/kernel/fork.c linux-2.5.5-getpid/kernel/fork.c
--- linux-2.5.5/kernel/fork.c Tue Feb 19 20:10:55 2002
+++ linux-2.5.5-getpid/kernel/fork.c Fri Feb 22 17:29:38 2002
@@ -24,6 +24,7 @@
#include <linux/file.h>
#include <linux/binfmts.h>
#include <linux/fs.h>
+#include <linux/compiler.h>
=20
#include <asm/pgtable.h>
#include <asm/pgalloc.h>
@@ -129,12 +130,13 @@
{
static int next_safe =3D PID_MAX;
struct task_struct *p;
- int pid;
+ int pid, beginpid;
=20
if (flags & CLONE_PID)
return current->pid;
=20
spin_lock(&lastpid_lock);
+ beginpid =3D last_pid;
if((++last_pid) & 0xffff8000) {
last_pid =3D 300; /* Skip daemons etc. */
goto inside;
@@ -154,12 +156,16 @@
last_pid =3D 300;
next_safe =3D PID_MAX;
}
+ if(unlikely(last_pid =3D=3D beginpid))
+ goto nomorepids;
goto repeat;
}
if(p->pid > last_pid && next_safe > p->pid)
next_safe =3D p->pid;
if(p->pgrp > last_pid && next_safe > p->pgrp)
next_safe =3D p->pgrp;
+ if(p->tgid > last_pid && next_safe > p->tgid)
+ next_safe =3D p->tgid;
if(p->session > last_pid && next_safe > p->session)
next_safe =3D p->session;
}
@@ -169,6 +175,11 @@
spin_unlock(&lastpid_lock);
=20
return pid;
+
+nomorepids:
+ read_unlock(&tasklist_lock);
+ spin_unlock(&lastpid_lock);
+ return 0;
}
=20
static inline int dup_mmap(struct mm_struct * mm)
@@ -667,6 +678,8 @@
=20
copy_flags(clone_flags, p);
p->pid =3D get_pid(clone_flags);
+ if (p->pid =3D=3D 0 && current->pid !=3D 0)
+ goto bad_fork_cleanup;
=20
INIT_LIST_HEAD(&p->run_list);
=20

--=-NdBfNCEm4tq+wTB/cjXE--

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/