[SPARC64]: Prevent registering wrong serial console.
If the console is not for a particular Sun serial controller, set the drv->cons to NULL. Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
@@ -955,14 +955,13 @@ static struct console sunsab_console = {
|
|||||||
.index = -1,
|
.index = -1,
|
||||||
.data = &sunsab_reg,
|
.data = &sunsab_reg,
|
||||||
};
|
};
|
||||||
#define SUNSAB_CONSOLE (&sunsab_console)
|
|
||||||
|
|
||||||
static void __init sunsab_console_init(void)
|
static inline struct console *SUNSAB_CONSOLE(void)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
if (con_is_present())
|
if (con_is_present())
|
||||||
return;
|
return NULL;
|
||||||
|
|
||||||
for (i = 0; i < num_channels; i++) {
|
for (i = 0; i < num_channels; i++) {
|
||||||
int this_minor = sunsab_reg.minor + i;
|
int this_minor = sunsab_reg.minor + i;
|
||||||
@@ -971,13 +970,14 @@ static void __init sunsab_console_init(void)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (i == num_channels)
|
if (i == num_channels)
|
||||||
return;
|
return NULL;
|
||||||
|
|
||||||
sunsab_console.index = i;
|
sunsab_console.index = i;
|
||||||
register_console(&sunsab_console);
|
|
||||||
|
return &sunsab_console;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
#define SUNSAB_CONSOLE (NULL)
|
#define SUNSAB_CONSOLE() (NULL)
|
||||||
#define sunsab_console_init() do { } while (0)
|
#define sunsab_console_init() do { } while (0)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@@ -1124,7 +1124,6 @@ static int __init sunsab_init(void)
|
|||||||
|
|
||||||
sunsab_reg.minor = sunserial_current_minor;
|
sunsab_reg.minor = sunserial_current_minor;
|
||||||
sunsab_reg.nr = num_channels;
|
sunsab_reg.nr = num_channels;
|
||||||
sunsab_reg.cons = SUNSAB_CONSOLE;
|
|
||||||
|
|
||||||
ret = uart_register_driver(&sunsab_reg);
|
ret = uart_register_driver(&sunsab_reg);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
@@ -1143,9 +1142,9 @@ static int __init sunsab_init(void)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
sunserial_current_minor += num_channels;
|
sunsab_reg.cons = SUNSAB_CONSOLE();
|
||||||
|
|
||||||
sunsab_console_init();
|
sunserial_current_minor += num_channels;
|
||||||
|
|
||||||
for (i = 0; i < num_channels; i++) {
|
for (i = 0; i < num_channels; i++) {
|
||||||
struct uart_sunsab_port *up = &sunsab_ports[i];
|
struct uart_sunsab_port *up = &sunsab_ports[i];
|
||||||
|
@@ -1464,18 +1464,17 @@ static struct console sunsu_cons = {
|
|||||||
.index = -1,
|
.index = -1,
|
||||||
.data = &sunsu_reg,
|
.data = &sunsu_reg,
|
||||||
};
|
};
|
||||||
#define SUNSU_CONSOLE (&sunsu_cons)
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Register console.
|
* Register console.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static int __init sunsu_serial_console_init(void)
|
static inline struct console *SUNSU_CONSOLE(void)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
if (con_is_present())
|
if (con_is_present())
|
||||||
return 0;
|
return NULL;
|
||||||
|
|
||||||
for (i = 0; i < UART_NR; i++) {
|
for (i = 0; i < UART_NR; i++) {
|
||||||
int this_minor = sunsu_reg.minor + i;
|
int this_minor = sunsu_reg.minor + i;
|
||||||
@@ -1484,16 +1483,16 @@ static int __init sunsu_serial_console_init(void)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (i == UART_NR)
|
if (i == UART_NR)
|
||||||
return 0;
|
return NULL;
|
||||||
if (sunsu_ports[i].port_node == 0)
|
if (sunsu_ports[i].port_node == 0)
|
||||||
return 0;
|
return NULL;
|
||||||
|
|
||||||
sunsu_cons.index = i;
|
sunsu_cons.index = i;
|
||||||
register_console(&sunsu_cons);
|
|
||||||
return 0;
|
return &sunsu_cons;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
#define SUNSU_CONSOLE (NULL)
|
#define SUNSU_CONSOLE() (NULL)
|
||||||
#define sunsu_serial_console_init() do { } while (0)
|
#define sunsu_serial_console_init() do { } while (0)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@@ -1523,16 +1522,17 @@ static int __init sunsu_serial_init(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
sunsu_reg.minor = sunserial_current_minor;
|
sunsu_reg.minor = sunserial_current_minor;
|
||||||
sunserial_current_minor += instance;
|
|
||||||
|
|
||||||
sunsu_reg.nr = instance;
|
sunsu_reg.nr = instance;
|
||||||
sunsu_reg.cons = SUNSU_CONSOLE;
|
|
||||||
|
|
||||||
ret = uart_register_driver(&sunsu_reg);
|
ret = uart_register_driver(&sunsu_reg);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
sunsu_serial_console_init();
|
sunserial_current_minor += instance;
|
||||||
|
|
||||||
|
sunsu_reg.cons = SUNSU_CONSOLE();
|
||||||
|
|
||||||
for (i = 0; i < UART_NR; i++) {
|
for (i = 0; i < UART_NR; i++) {
|
||||||
struct uart_sunsu_port *up = &sunsu_ports[i];
|
struct uart_sunsu_port *up = &sunsu_ports[i];
|
||||||
|
|
||||||
|
@@ -1390,7 +1390,6 @@ static struct console sunzilog_console = {
|
|||||||
.index = -1,
|
.index = -1,
|
||||||
.data = &sunzilog_reg,
|
.data = &sunzilog_reg,
|
||||||
};
|
};
|
||||||
#define SUNZILOG_CONSOLE (&sunzilog_console)
|
|
||||||
|
|
||||||
static int __init sunzilog_console_init(void)
|
static int __init sunzilog_console_init(void)
|
||||||
{
|
{
|
||||||
@@ -1413,8 +1412,31 @@ static int __init sunzilog_console_init(void)
|
|||||||
register_console(&sunzilog_console);
|
register_console(&sunzilog_console);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline struct console *SUNZILOG_CONSOLE(void)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
if (con_is_present())
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
for (i = 0; i < NUM_CHANNELS; i++) {
|
||||||
|
int this_minor = sunzilog_reg.minor + i;
|
||||||
|
|
||||||
|
if ((this_minor - 64) == (serial_console - 1))
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (i == NUM_CHANNELS)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
sunzilog_console.index = i;
|
||||||
|
sunzilog_port_table[i].flags |= SUNZILOG_FLAG_IS_CONS;
|
||||||
|
|
||||||
|
return &sunzilog_console;
|
||||||
|
}
|
||||||
|
|
||||||
#else
|
#else
|
||||||
#define SUNZILOG_CONSOLE (NULL)
|
#define SUNZILOG_CONSOLE() (NULL)
|
||||||
#define sunzilog_console_init() do { } while (0)
|
#define sunzilog_console_init() do { } while (0)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@@ -1666,14 +1688,14 @@ static int __init sunzilog_ports_init(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
sunzilog_reg.nr = uart_count;
|
sunzilog_reg.nr = uart_count;
|
||||||
sunzilog_reg.cons = SUNZILOG_CONSOLE;
|
|
||||||
|
|
||||||
sunzilog_reg.minor = sunserial_current_minor;
|
sunzilog_reg.minor = sunserial_current_minor;
|
||||||
sunserial_current_minor += uart_count;
|
|
||||||
|
|
||||||
ret = uart_register_driver(&sunzilog_reg);
|
ret = uart_register_driver(&sunzilog_reg);
|
||||||
if (ret == 0) {
|
if (ret == 0) {
|
||||||
sunzilog_console_init();
|
sunzilog_reg.cons = SUNZILOG_CONSOLE();
|
||||||
|
|
||||||
|
sunserial_current_minor += uart_count;
|
||||||
|
|
||||||
for (i = 0; i < NUM_CHANNELS; i++) {
|
for (i = 0; i < NUM_CHANNELS; i++) {
|
||||||
struct uart_sunzilog_port *up = &sunzilog_port_table[i];
|
struct uart_sunzilog_port *up = &sunzilog_port_table[i];
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user