From 193c6b302fbfb0e8c7400556f592efe9410ca9b4 Mon Sep 17 00:00:00 2001 From: Jeff Dike Date: Mon, 4 Feb 2008 22:31:19 -0800 Subject: [PATCH] --- yaml --- r: 83219 b: refs/heads/master c: 438ee6798cd8bfc44da725fca846367e19d86652 h: refs/heads/master i: 83217: f0897fb7ddd010e821aeb9c06ace9edfef5364ef 83215: 096b1bf950e52872d9724e2f987b7d0a7cefe9ed v: v3 --- [refs] | 2 +- trunk/arch/um/drivers/line.c | 8 +++++--- trunk/arch/um/drivers/mconsole_kern.c | 8 +++++++- 3 files changed, 13 insertions(+), 5 deletions(-) diff --git a/[refs] b/[refs] index a495e4fe853f..b2bc1ec25143 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 83380cc1c9694a05bcdb7c95d293e99d3475d906 +refs/heads/master: 438ee6798cd8bfc44da725fca846367e19d86652 diff --git a/trunk/arch/um/drivers/line.c b/trunk/arch/um/drivers/line.c index fac058b49282..2c898c4d6b6a 100644 --- a/trunk/arch/um/drivers/line.c +++ b/trunk/arch/um/drivers/line.c @@ -774,9 +774,11 @@ static irqreturn_t winch_interrupt(int irq, void *data) tty = winch->tty; if (tty != NULL) { line = tty->driver_data; - chan_window_size(&line->chan_list, &tty->winsize.ws_row, - &tty->winsize.ws_col); - kill_pgrp(tty->pgrp, SIGWINCH, 1); + if (line != NULL) { + chan_window_size(&line->chan_list, &tty->winsize.ws_row, + &tty->winsize.ws_col); + kill_pgrp(tty->pgrp, SIGWINCH, 1); + } } out: if (winch->fd != -1) diff --git a/trunk/arch/um/drivers/mconsole_kern.c b/trunk/arch/um/drivers/mconsole_kern.c index fabd75f5bb5c..c953e1477be4 100644 --- a/trunk/arch/um/drivers/mconsole_kern.c +++ b/trunk/arch/um/drivers/mconsole_kern.c @@ -792,6 +792,8 @@ static int __init mconsole_init(void) printk(KERN_ERR "Failed to initialize management console\n"); return 1; } + if (os_set_fd_block(sock, 0)) + goto out; register_reboot_notifier(&reboot_notifier); @@ -800,7 +802,7 @@ static int __init mconsole_init(void) "mconsole", (void *)sock); if (err) { printk(KERN_ERR "Failed to get IRQ for management console\n"); - return 1; + goto out; } if (notify_socket != NULL) { @@ -816,6 +818,10 @@ static int __init mconsole_init(void) printk(KERN_INFO "mconsole (version %d) initialized on %s\n", MCONSOLE_VERSION, mconsole_socket_name); return 0; + + out: + os_close_file(sock); + return 1; } __initcall(mconsole_init);