All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] de_thread: eliminate unneccessary sighand locking
@ 2005-06-19 16:13 Oleg Nesterov
  2005-06-28  1:50 ` Roland McGrath
  0 siblings, 1 reply; 9+ messages in thread
From: Oleg Nesterov @ 2005-06-19 16:13 UTC (permalink / raw)
  To: Ingo Molnar; +Cc: Roland McGrath, Andrew Morton, linux-kernel

while switching current->sighand de_thread does:

	write_lock_irq(&tasklist_lock);
	spin_lock(&oldsighand->siglock);
	spin_lock(&newsighand->siglock);

	current->sighand = newsighand;
	recalc_sigpending();

Is these 2 sighand locks are really needed?

At this moment we already zapped other threads, so nobody
can access newsighand via current->. And we are holding
tasklist_lock, so other processes can't send signals to us
or use our ->sighand in any way.

oldsighand can be seen from CLONE_SIGHAND processes, but
we are not using oldsighand in any way, so this lock seems
to be unneeded too.

The only possibility that I can imagine is that some process
does:
	read_lock(tasklist_lock);
	task = find_task();
	spin_lock(task->sighand->siglock);
	read_unlock(tasklist_lock);
	play with task->signal

Is this possible/allowed?

And why do we need recalc_sigpending() ? We are not changing
->pending or ->blocked, just ->sighand.

Signed-off-by: Oleg Nesterov <oleg@tv-sign.ru>

--- 2.6.12/fs/exec.c~	2005-05-09 16:37:16.000000000 +0400
+++ 2.6.12/fs/exec.c	2005-06-20 00:03:24.000000000 +0400
@@ -758,14 +758,7 @@ no_thread_group:
 		       sizeof(newsighand->action));
 
 		write_lock_irq(&tasklist_lock);
-		spin_lock(&oldsighand->siglock);
-		spin_lock(&newsighand->siglock);
-
 		current->sighand = newsighand;
-		recalc_sigpending();
-
-		spin_unlock(&newsighand->siglock);
-		spin_unlock(&oldsighand->siglock);
 		write_unlock_irq(&tasklist_lock);
 
 		if (atomic_dec_and_test(&oldsighand->count))

^ permalink raw reply	[flat|nested] 9+ messages in thread

end of thread, other threads:[~2005-06-28  8:56 UTC | newest]

Thread overview: 9+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2005-06-19 16:13 [PATCH] de_thread: eliminate unneccessary sighand locking Oleg Nesterov
2005-06-28  1:50 ` Roland McGrath
2005-06-28  6:17   ` Oleg Nesterov
2005-06-28  6:27     ` Roland McGrath
2005-06-28  6:42       ` Ingo Molnar
2005-06-28  7:08         ` Roland McGrath
2005-06-28  7:16           ` Ingo Molnar
2005-06-28  7:26             ` Roland McGrath
2005-06-28  8:26               ` Ingo Molnar

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.