aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/serial/8250.c
diff options
context:
space:
mode:
authorDavid Miller <davem@davemloft.net>2008-10-13 05:36:31 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2008-10-13 12:51:40 -0400
commitb70ac7718579b5cbf3bdd74fd01132d1c91596f4 (patch)
treea418dec814cbdea806c7767c0d77928bfe9091bc /drivers/serial/8250.c
parentb5d674abcffeacaf83038bbf7c0caf24edd497dd (diff)
serial: allow 8250 to be used on sparc
This requires three changes: 1) Remove !SPARC restriction in Kconfig. 2) Move Sparc specific serial drivers before 8250, so that serial console devices don't change names on us, even if 8250 finds devices. 3) Since the Sparc specific serial drivers try to use the same major/minor device namespace as 8250, some coordination is necessary. Use the sunserial_*() layer routines to allocate minor number space within TTY_MAJOR when CONFIG_SPARC. This has no effect on other platforms. Thanks to Josip Rodin for bringing up this issue and testing plus debugging various revisions of this patch. Signed-off-by: David S. Miller <davem@davemloft.net> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Alan Cox <alan@redhat.com> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'drivers/serial/8250.c')
-rw-r--r--drivers/serial/8250.c21
1 files changed, 17 insertions, 4 deletions
diff --git a/drivers/serial/8250.c b/drivers/serial/8250.c
index ed593c4b6e7d..db2cdc103c88 100644
--- a/drivers/serial/8250.c
+++ b/drivers/serial/8250.c
@@ -44,6 +44,10 @@
44 44
45#include "8250.h" 45#include "8250.h"
46 46
47#ifdef CONFIG_SPARC
48#include "suncore.h"
49#endif
50
47/* 51/*
48 * Configuration: 52 * Configuration:
49 * share_irqs - whether we pass IRQF_SHARED to request_irq(). This option 53 * share_irqs - whether we pass IRQF_SHARED to request_irq(). This option
@@ -2676,7 +2680,6 @@ static struct uart_driver serial8250_reg = {
2676 .dev_name = "ttyS", 2680 .dev_name = "ttyS",
2677 .major = TTY_MAJOR, 2681 .major = TTY_MAJOR,
2678 .minor = 64, 2682 .minor = 64,
2679 .nr = UART_NR,
2680 .cons = SERIAL8250_CONSOLE, 2683 .cons = SERIAL8250_CONSOLE,
2681}; 2684};
2682 2685
@@ -2958,10 +2961,12 @@ static int __init serial8250_init(void)
2958 "%d ports, IRQ sharing %sabled\n", nr_uarts, 2961 "%d ports, IRQ sharing %sabled\n", nr_uarts,
2959 share_irqs ? "en" : "dis"); 2962 share_irqs ? "en" : "dis");
2960 2963
2961 for (i = 0; i < NR_IRQS; i++) 2964#ifdef CONFIG_SPARC
2962 spin_lock_init(&irq_lists[i].lock); 2965 ret = sunserial_register_minors(&serial8250_reg, UART_NR);
2963 2966#else
2967 serial8250_reg.nr = UART_NR;
2964 ret = uart_register_driver(&serial8250_reg); 2968 ret = uart_register_driver(&serial8250_reg);
2969#endif
2965 if (ret) 2970 if (ret)
2966 goto out; 2971 goto out;
2967 2972
@@ -2986,7 +2991,11 @@ static int __init serial8250_init(void)
2986 put_dev: 2991 put_dev:
2987 platform_device_put(serial8250_isa_devs); 2992 platform_device_put(serial8250_isa_devs);
2988 unreg_uart_drv: 2993 unreg_uart_drv:
2994#ifdef CONFIG_SPARC
2995 sunserial_unregister_minors(&serial8250_reg, UART_NR);
2996#else
2989 uart_unregister_driver(&serial8250_reg); 2997 uart_unregister_driver(&serial8250_reg);
2998#endif
2990 out: 2999 out:
2991 return ret; 3000 return ret;
2992} 3001}
@@ -3005,7 +3014,11 @@ static void __exit serial8250_exit(void)
3005 platform_driver_unregister(&serial8250_isa_driver); 3014 platform_driver_unregister(&serial8250_isa_driver);
3006 platform_device_unregister(isa_dev); 3015 platform_device_unregister(isa_dev);
3007 3016
3017#ifdef CONFIG_SPARC
3018 sunserial_unregister_minors(&serial8250_reg, UART_NR);
3019#else
3008 uart_unregister_driver(&serial8250_reg); 3020 uart_unregister_driver(&serial8250_reg);
3021#endif
3009} 3022}
3010 3023
3011module_init(serial8250_init); 3024module_init(serial8250_init);