2012-10-10 05:15:23 +00:00
|
|
|
From 54f7e1e25103cdc60f97bc1db95332e7cadae35e Mon Sep 17 00:00:00 2001
|
2011-11-20 00:01:55 +00:00
|
|
|
From: Thomas Gleixner <tglx@linutronix.de>
|
|
|
|
Date: Fri, 22 Jul 2011 08:07:08 +0200
|
2012-10-10 05:15:23 +00:00
|
|
|
Subject: [PATCH 091/279] signal-fix-up-rcu-wreckage.patch
|
2011-11-20 00:01:55 +00:00
|
|
|
|
|
|
|
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
|
|
|
|
---
|
|
|
|
kernel/signal.c | 6 +++---
|
|
|
|
1 file changed, 3 insertions(+), 3 deletions(-)
|
|
|
|
|
2012-05-12 14:20:55 +00:00
|
|
|
diff --git a/kernel/signal.c b/kernel/signal.c
|
2012-06-15 02:54:49 +00:00
|
|
|
index 385d137..6b744cb 100644
|
2012-05-12 14:20:55 +00:00
|
|
|
--- a/kernel/signal.c
|
|
|
|
+++ b/kernel/signal.c
|
|
|
|
@@ -1362,12 +1362,12 @@ struct sighand_struct *__lock_task_sighand(struct task_struct *tsk,
|
2011-11-20 00:01:55 +00:00
|
|
|
struct sighand_struct *sighand;
|
|
|
|
|
|
|
|
for (;;) {
|
|
|
|
- local_irq_save(*flags);
|
|
|
|
+ local_irq_save_nort(*flags);
|
|
|
|
rcu_read_lock();
|
|
|
|
sighand = rcu_dereference(tsk->sighand);
|
|
|
|
if (unlikely(sighand == NULL)) {
|
|
|
|
rcu_read_unlock();
|
|
|
|
- local_irq_restore(*flags);
|
|
|
|
+ local_irq_restore_nort(*flags);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2012-05-12 14:20:55 +00:00
|
|
|
@@ -1378,7 +1378,7 @@ struct sighand_struct *__lock_task_sighand(struct task_struct *tsk,
|
2011-11-20 00:01:55 +00:00
|
|
|
}
|
|
|
|
spin_unlock(&sighand->siglock);
|
|
|
|
rcu_read_unlock();
|
|
|
|
- local_irq_restore(*flags);
|
|
|
|
+ local_irq_restore_nort(*flags);
|
|
|
|
}
|
|
|
|
|
|
|
|
return sighand;
|