aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJeff Dike <jdike@addtoit.com>2008-02-05 01:31:19 -0500
committerLinus Torvalds <torvalds@woody.linux-foundation.org>2008-02-05 12:44:31 -0500
commit438ee6798cd8bfc44da725fca846367e19d86652 (patch)
tree5bf5ccfeb363f4a4c7f8dfb10d24c1c9a2062b8a
parent83380cc1c9694a05bcdb7c95d293e99d3475d906 (diff)
uml: DEBUG_SHIRQ fixes
A couple more DEBUG_SHIRQ fixes. The previous mconsole blocking fix exposed the lack of O_NONBLOCK on the mconsole socket. Also, winch_interrupt started crashing because it is called at irq free time and it tries to dereference tty->driver_data, which has already been set to NULL. I added some error cleanup in mconsole_init while I was there. Cc: "Karol Swietlicki" <magotari@gmail.com> Signed-off-by: Jeff Dike <jdike@linux.intel.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r--arch/um/drivers/line.c8
-rw-r--r--arch/um/drivers/mconsole_kern.c8
2 files changed, 12 insertions, 4 deletions
diff --git a/arch/um/drivers/line.c b/arch/um/drivers/line.c
index fac058b49282..2c898c4d6b6a 100644
--- a/arch/um/drivers/line.c
+++ b/arch/um/drivers/line.c
@@ -774,9 +774,11 @@ static irqreturn_t winch_interrupt(int irq, void *data)
774 tty = winch->tty; 774 tty = winch->tty;
775 if (tty != NULL) { 775 if (tty != NULL) {
776 line = tty->driver_data; 776 line = tty->driver_data;
777 chan_window_size(&line->chan_list, &tty->winsize.ws_row, 777 if (line != NULL) {
778 &tty->winsize.ws_col); 778 chan_window_size(&line->chan_list, &tty->winsize.ws_row,
779 kill_pgrp(tty->pgrp, SIGWINCH, 1); 779 &tty->winsize.ws_col);
780 kill_pgrp(tty->pgrp, SIGWINCH, 1);
781 }
780 } 782 }
781 out: 783 out:
782 if (winch->fd != -1) 784 if (winch->fd != -1)
diff --git a/arch/um/drivers/mconsole_kern.c b/arch/um/drivers/mconsole_kern.c
index fabd75f5bb5c..c953e1477be4 100644
--- a/arch/um/drivers/mconsole_kern.c
+++ b/arch/um/drivers/mconsole_kern.c
@@ -792,6 +792,8 @@ static int __init mconsole_init(void)
792 printk(KERN_ERR "Failed to initialize management console\n"); 792 printk(KERN_ERR "Failed to initialize management console\n");
793 return 1; 793 return 1;
794 } 794 }
795 if (os_set_fd_block(sock, 0))
796 goto out;
795 797
796 register_reboot_notifier(&reboot_notifier); 798 register_reboot_notifier(&reboot_notifier);
797 799
@@ -800,7 +802,7 @@ static int __init mconsole_init(void)
800 "mconsole", (void *)sock); 802 "mconsole", (void *)sock);
801 if (err) { 803 if (err) {
802 printk(KERN_ERR "Failed to get IRQ for management console\n"); 804 printk(KERN_ERR "Failed to get IRQ for management console\n");
803 return 1; 805 goto out;
804 } 806 }
805 807
806 if (notify_socket != NULL) { 808 if (notify_socket != NULL) {
@@ -816,6 +818,10 @@ static int __init mconsole_init(void)
816 printk(KERN_INFO "mconsole (version %d) initialized on %s\n", 818 printk(KERN_INFO "mconsole (version %d) initialized on %s\n",
817 MCONSOLE_VERSION, mconsole_socket_name); 819 MCONSOLE_VERSION, mconsole_socket_name);
818 return 0; 820 return 0;
821
822 out:
823 os_close_file(sock);
824 return 1;
819} 825}
820 826
821__initcall(mconsole_init); 827__initcall(mconsole_init);