diff options
Diffstat (limited to 'arch/um/drivers/ssl.c')
-rw-r--r-- | arch/um/drivers/ssl.c | 16 |
1 files changed, 7 insertions, 9 deletions
diff --git a/arch/um/drivers/ssl.c b/arch/um/drivers/ssl.c index 475de52783e4..fc22b9bd9153 100644 --- a/arch/um/drivers/ssl.c +++ b/arch/um/drivers/ssl.c | |||
@@ -51,6 +51,8 @@ static int ssl_config(char *str, char **error_out); | |||
51 | static int ssl_get_config(char *dev, char *str, int size, char **error_out); | 51 | static int ssl_get_config(char *dev, char *str, int size, char **error_out); |
52 | static int ssl_remove(int n, char **error_out); | 52 | static int ssl_remove(int n, char **error_out); |
53 | 53 | ||
54 | |||
55 | /* Const, except for .mc.list */ | ||
54 | static struct line_driver driver = { | 56 | static struct line_driver driver = { |
55 | .name = "UML serial line", | 57 | .name = "UML serial line", |
56 | .device_name = "ttyS", | 58 | .device_name = "ttyS", |
@@ -62,8 +64,6 @@ static struct line_driver driver = { | |||
62 | .read_irq_name = "ssl", | 64 | .read_irq_name = "ssl", |
63 | .write_irq = SSL_WRITE_IRQ, | 65 | .write_irq = SSL_WRITE_IRQ, |
64 | .write_irq_name = "ssl-write", | 66 | .write_irq_name = "ssl-write", |
65 | .symlink_from = "serial", | ||
66 | .symlink_to = "tts", | ||
67 | .mc = { | 67 | .mc = { |
68 | .list = LIST_HEAD_INIT(driver.mc.list), | 68 | .list = LIST_HEAD_INIT(driver.mc.list), |
69 | .name = "ssl", | 69 | .name = "ssl", |
@@ -74,14 +74,12 @@ static struct line_driver driver = { | |||
74 | }, | 74 | }, |
75 | }; | 75 | }; |
76 | 76 | ||
77 | /* The array is initialized by line_init, which is an initcall. The | 77 | /* The array is initialized by line_init, at initcall time. The |
78 | * individual elements are protected by individual semaphores. | 78 | * elements are locked individually as needed. |
79 | */ | 79 | */ |
80 | static struct line serial_lines[NR_PORTS] = | 80 | static struct line serial_lines[NR_PORTS] = |
81 | { [0 ... NR_PORTS - 1] = LINE_INIT(CONFIG_SSL_CHAN, &driver) }; | 81 | { [0 ... NR_PORTS - 1] = LINE_INIT(CONFIG_SSL_CHAN, &driver) }; |
82 | 82 | ||
83 | static struct lines lines = LINES_INIT(NR_PORTS); | ||
84 | |||
85 | static int ssl_config(char *str, char **error_out) | 83 | static int ssl_config(char *str, char **error_out) |
86 | { | 84 | { |
87 | return line_config(serial_lines, ARRAY_SIZE(serial_lines), str, &opts, | 85 | return line_config(serial_lines, ARRAY_SIZE(serial_lines), str, &opts, |
@@ -175,6 +173,7 @@ static int ssl_console_setup(struct console *co, char *options) | |||
175 | return console_open_chan(line, co); | 173 | return console_open_chan(line, co); |
176 | } | 174 | } |
177 | 175 | ||
176 | /* No locking for register_console call - relies on single-threaded initcalls */ | ||
178 | static struct console ssl_cons = { | 177 | static struct console ssl_cons = { |
179 | .name = "ttyS", | 178 | .name = "ttyS", |
180 | .write = ssl_console_write, | 179 | .write = ssl_console_write, |
@@ -190,9 +189,8 @@ static int ssl_init(void) | |||
190 | 189 | ||
191 | printk(KERN_INFO "Initializing software serial port version %d\n", | 190 | printk(KERN_INFO "Initializing software serial port version %d\n", |
192 | ssl_version); | 191 | ssl_version); |
193 | ssl_driver = line_register_devfs(&lines, &driver, &ssl_ops, | 192 | ssl_driver = register_lines(&driver, &ssl_ops, serial_lines, |
194 | serial_lines, | 193 | ARRAY_SIZE(serial_lines)); |
195 | ARRAY_SIZE(serial_lines)); | ||
196 | 194 | ||
197 | lines_init(serial_lines, ARRAY_SIZE(serial_lines), &opts); | 195 | lines_init(serial_lines, ARRAY_SIZE(serial_lines), &opts); |
198 | 196 | ||