diff options
| author | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2009-12-09 09:14:38 +0300 | 
|---|---|---|
| committer | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2009-12-09 09:14:38 +0300 | 
| commit | bcd6acd51f3d4d1ada201e9bc5c40a31d6d80c71 (patch) | |
| tree | 2f6dffd2d3e4dd67355a224de7e7a960335a92fd /drivers/serial/suncore.c | |
| parent | 11c34c7deaeeebcee342cbc35e1bb2a6711b2431 (diff) | |
| parent | 3ff6a468b45b5dfeb0e903e56f4eb27d34b2437c (diff) | |
| download | linux-bcd6acd51f3d4d1ada201e9bc5c40a31d6d80c71.tar.xz | |
Merge commit 'origin/master' into next
Conflicts:
	include/linux/kvm.h
Diffstat (limited to 'drivers/serial/suncore.c')
| -rw-r--r-- | drivers/serial/suncore.c | 37 | 
1 files changed, 20 insertions, 17 deletions
| diff --git a/drivers/serial/suncore.c b/drivers/serial/suncore.c index a2d4a19550ab..ed7d958b0a01 100644 --- a/drivers/serial/suncore.c +++ b/drivers/serial/suncore.c @@ -53,20 +53,21 @@ void sunserial_unregister_minors(struct uart_driver *drv, int count)  EXPORT_SYMBOL(sunserial_unregister_minors);  int sunserial_console_match(struct console *con, struct device_node *dp, -			    struct uart_driver *drv, int line) +			    struct uart_driver *drv, int line, bool ignore_line)  { -	int off; -  	if (!con || of_console_device != dp)  		return 0; -	off = 0; -	if (of_console_options && -	    *of_console_options == 'b') -		off = 1; +	if (!ignore_line) { +		int off = 0; -	if ((line & 1) != off) -		return 0; +		if (of_console_options && +		    *of_console_options == 'b') +			off = 1; + +		if ((line & 1) != off) +			return 0; +	}  	con->index = line;  	drv->cons = con; @@ -76,23 +77,24 @@ int sunserial_console_match(struct console *con, struct device_node *dp,  }  EXPORT_SYMBOL(sunserial_console_match); -void -sunserial_console_termios(struct console *con) +void sunserial_console_termios(struct console *con, struct device_node *uart_dp)  { -	struct device_node *dp; -	const char *od, *mode, *s; +	const char *mode, *s;  	char mode_prop[] = "ttyX-mode";  	int baud, bits, stop, cflag;  	char parity; -	dp = of_find_node_by_path("/options"); -	od = of_get_property(dp, "output-device", NULL); -	if (!strcmp(od, "rsc")) { -		mode = of_get_property(of_console_device, +	if (!strcmp(uart_dp->name, "rsc") || +	    !strcmp(uart_dp->name, "rsc-console") || +	    !strcmp(uart_dp->name, "rsc-control")) { +		mode = of_get_property(uart_dp,  				       "ssp-console-modes", NULL);  		if (!mode)  			mode = "115200,8,n,1,-"; +	} else if (!strcmp(uart_dp->name, "lom-console")) { +		mode = "9600,8,n,1,-";  	} else { +		struct device_node *dp;  		char c;  		c = 'a'; @@ -101,6 +103,7 @@ sunserial_console_termios(struct console *con)  		mode_prop[3] = c; +		dp = of_find_node_by_path("/options");  		mode = of_get_property(dp, mode_prop, NULL);  		if (!mode)  			mode = "9600,8,n,1,-"; | 
