hvc_console: Fix free_irq in spinlocked section
commit 611e097d77
Author: Christian Borntraeger <borntraeger@de.ibm.com>
hvc_console: rework setup to replace irq functions with callbacks
introduced a spinlock recursion problem. The notifier_del is
called with a lock held, and in turns calls free_irq which then
complains when manipulating procfs. This fixes it by moving the
call to the notifier to outside of the locked section.
Signed-off-by: Christian Borntraeger<borntraeger@de.ibm.com>
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
This commit is contained in:
parent
f5ea64dcba
commit
eef2622a9f
1 changed files with 5 additions and 5 deletions
|
@ -367,13 +367,13 @@ static void hvc_close(struct tty_struct *tty, struct file * filp)
|
||||||
spin_lock_irqsave(&hp->lock, flags);
|
spin_lock_irqsave(&hp->lock, flags);
|
||||||
|
|
||||||
if (--hp->count == 0) {
|
if (--hp->count == 0) {
|
||||||
if (hp->ops->notifier_del)
|
|
||||||
hp->ops->notifier_del(hp, hp->data);
|
|
||||||
|
|
||||||
/* We are done with the tty pointer now. */
|
/* We are done with the tty pointer now. */
|
||||||
hp->tty = NULL;
|
hp->tty = NULL;
|
||||||
spin_unlock_irqrestore(&hp->lock, flags);
|
spin_unlock_irqrestore(&hp->lock, flags);
|
||||||
|
|
||||||
|
if (hp->ops->notifier_del)
|
||||||
|
hp->ops->notifier_del(hp, hp->data);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Chain calls chars_in_buffer() and returns immediately if
|
* Chain calls chars_in_buffer() and returns immediately if
|
||||||
* there is no buffered data otherwise sleeps on a wait queue
|
* there is no buffered data otherwise sleeps on a wait queue
|
||||||
|
@ -416,11 +416,11 @@ static void hvc_hangup(struct tty_struct *tty)
|
||||||
hp->n_outbuf = 0;
|
hp->n_outbuf = 0;
|
||||||
hp->tty = NULL;
|
hp->tty = NULL;
|
||||||
|
|
||||||
|
spin_unlock_irqrestore(&hp->lock, flags);
|
||||||
|
|
||||||
if (hp->ops->notifier_del)
|
if (hp->ops->notifier_del)
|
||||||
hp->ops->notifier_del(hp, hp->data);
|
hp->ops->notifier_del(hp, hp->data);
|
||||||
|
|
||||||
spin_unlock_irqrestore(&hp->lock, flags);
|
|
||||||
|
|
||||||
while(temp_open_count) {
|
while(temp_open_count) {
|
||||||
--temp_open_count;
|
--temp_open_count;
|
||||||
kref_put(&hp->kref, destroy_hvc_struct);
|
kref_put(&hp->kref, destroy_hvc_struct);
|
||||||
|
|
Loading…
Reference in a new issue