* [PATCH][RFC] ptmx fix duplicate idr_remove
@ 2006-04-04 18:35 Paul Fulghum
2006-04-05 7:57 ` Andrew Morton
0 siblings, 1 reply; 3+ messages in thread
From: Paul Fulghum @ 2006-04-04 18:35 UTC (permalink / raw)
To: Linux Kernel Mailing List
Remove duplicate call to idr_remove() in ptmx_open.
Error during open can result in call to release_dev()
followed by call to idr_remove(). release_dev already
calls idr_remove so the second call can cause a stack
dump in idr_remove()->sub_remove() flagging an attempt
to release an already released entry.
I reproduces this on a machine with a misconfigured
X server (attempting to restart multiple times rapidly)
getting the same error as the 1st link below.
This also seems to be related to:
http://marc.theaimsgroup.com/?l=selinux&m=110536513426735&w=2
http://marc.theaimsgroup.com/?l=selinux&m=110596994916785&w=2
The stack dump can occur on close (as well as open) as shown
in the 1st instance above, possible from something like:
process A - open (index=0), open fail to out1,
release_dev calls idr_remove (index 0), down(sem) sleeps
process B - open (index=0), open OK (idr allocated)
process A - wake and call idr_remove on index 0
...
process B - close, release_dev, stack dump on idr_remove (index=0)
because entry already removed
Comments?
--- linux-2.6.16/drivers/char/tty_io.c 2006-03-19 23:53:29.000000000 -0600
+++ b/drivers/char/tty_io.c 2006-04-04 12:52:47.000000000 -0500
@@ -2188,6 +2188,7 @@ static int ptmx_open(struct inode * inod
return 0;
out1:
release_dev(filp);
+ return retval;
out:
down(&allocated_ptys_lock);
idr_remove(&allocated_ptys, index);
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH][RFC] ptmx fix duplicate idr_remove
2006-04-04 18:35 [PATCH][RFC] ptmx fix duplicate idr_remove Paul Fulghum
@ 2006-04-05 7:57 ` Andrew Morton
2006-04-05 13:36 ` Paul Fulghum
0 siblings, 1 reply; 3+ messages in thread
From: Andrew Morton @ 2006-04-05 7:57 UTC (permalink / raw)
To: Paul Fulghum; +Cc: linux-kernel
Paul Fulghum <paulkf@microgate.com> wrote:
>
> Remove duplicate call to idr_remove() in ptmx_open.
>
> Error during open can result in call to release_dev()
> followed by call to idr_remove(). release_dev already
> calls idr_remove so the second call can cause a stack
> dump in idr_remove()->sub_remove() flagging an attempt
> to release an already released entry.
>
> I reproduces this on a machine with a misconfigured
> X server (attempting to restart multiple times rapidly)
> getting the same error as the 1st link below.
>
> This also seems to be related to:
> http://marc.theaimsgroup.com/?l=selinux&m=110536513426735&w=2
> http://marc.theaimsgroup.com/?l=selinux&m=110596994916785&w=2
>
> The stack dump can occur on close (as well as open) as shown
> in the 1st instance above, possible from something like:
> process A - open (index=0), open fail to out1,
> release_dev calls idr_remove (index 0), down(sem) sleeps
> process B - open (index=0), open OK (idr allocated)
> process A - wake and call idr_remove on index 0
> ...
> process B - close, release_dev, stack dump on idr_remove (index=0)
> because entry already removed
>
> Comments?
>
> --- linux-2.6.16/drivers/char/tty_io.c 2006-03-19 23:53:29.000000000 -0600
> +++ b/drivers/char/tty_io.c 2006-04-04 12:52:47.000000000 -0500
> @@ -2188,6 +2188,7 @@ static int ptmx_open(struct inode * inod
> return 0;
> out1:
> release_dev(filp);
> + return retval;
> out:
> down(&allocated_ptys_lock);
> idr_remove(&allocated_ptys, index);
Look solid.
Except for this, in release_dev():
/* check whether both sides are closing ... */
if (!tty_closing || (o_tty && !o_tty_closing))
return;
if that's taken, we won't have run idr_remove() at all?
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH][RFC] ptmx fix duplicate idr_remove
2006-04-05 7:57 ` Andrew Morton
@ 2006-04-05 13:36 ` Paul Fulghum
0 siblings, 0 replies; 3+ messages in thread
From: Paul Fulghum @ 2006-04-05 13:36 UTC (permalink / raw)
To: Andrew Morton; +Cc: linux-kernel
Andrew Morton wrote:
> Except for this, in release_dev():
>
> /* check whether both sides are closing ... */
> if (!tty_closing || (o_tty && !o_tty_closing))
> return;
>
> if that's taken, we won't have run idr_remove() at all?
ptmx_open creates the ptm/pts pair.
If ptmx_open fails, the conditions
for releasing the ptm (and associated pts)
have been met: no active references.
--
Paul Fulghum
Microgate Systems, Ltd.
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2006-04-05 13:36 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2006-04-04 18:35 [PATCH][RFC] ptmx fix duplicate idr_remove Paul Fulghum
2006-04-05 7:57 ` Andrew Morton
2006-04-05 13:36 ` Paul Fulghum
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).