diff options
author | Eric Paris <eparis@redhat.com> | 2014-03-07 11:41:32 -0500 |
---|---|---|
committer | Eric Paris <eparis@redhat.com> | 2014-03-07 11:41:32 -0500 |
commit | b7d3622a39fde7658170b7f3cf6c6889bb8db30d (patch) | |
tree | 64f4e781ecb2a85d675e234072b988560bcd25f1 /drivers/tty | |
parent | f3411cb2b2e396a41ed3a439863f028db7140a34 (diff) | |
parent | d8ec26d7f8287f5788a494f56e8814210f0e64be (diff) |
Merge tag 'v3.13' into for-3.15
Linux 3.13
Conflicts:
include/net/xfrm.h
Simple merge where v3.13 removed 'extern' from definitions and the audit
tree did s/u32/unsigned int/ to the same definitions.
Diffstat (limited to 'drivers/tty')
58 files changed, 1263 insertions, 375 deletions
diff --git a/drivers/tty/amiserial.c b/drivers/tty/amiserial.c index 2b86f8e0fb58..71630a2af42c 100644 --- a/drivers/tty/amiserial.c +++ b/drivers/tty/amiserial.c | |||
@@ -1855,6 +1855,9 @@ static struct console sercons = { | |||
1855 | */ | 1855 | */ |
1856 | static int __init amiserial_console_init(void) | 1856 | static int __init amiserial_console_init(void) |
1857 | { | 1857 | { |
1858 | if (!MACH_IS_AMIGA) | ||
1859 | return -ENODEV; | ||
1860 | |||
1858 | register_console(&sercons); | 1861 | register_console(&sercons); |
1859 | return 0; | 1862 | return 0; |
1860 | } | 1863 | } |
diff --git a/drivers/tty/bfin_jtag_comm.c b/drivers/tty/bfin_jtag_comm.c index a93a424873fa..8096fcbe2dc1 100644 --- a/drivers/tty/bfin_jtag_comm.c +++ b/drivers/tty/bfin_jtag_comm.c | |||
@@ -349,7 +349,7 @@ bfin_jc_early_write(struct console *co, const char *buf, unsigned int count) | |||
349 | bfin_jc_straight_buffer_write(buf, count); | 349 | bfin_jc_straight_buffer_write(buf, count); |
350 | } | 350 | } |
351 | 351 | ||
352 | static struct __initdata console bfin_jc_early_console = { | 352 | static struct console bfin_jc_early_console __initdata = { |
353 | .name = "early_BFJC", | 353 | .name = "early_BFJC", |
354 | .write = bfin_jc_early_write, | 354 | .write = bfin_jc_early_write, |
355 | .flags = CON_ANYTIME | CON_PRINTBUFFER, | 355 | .flags = CON_ANYTIME | CON_PRINTBUFFER, |
diff --git a/drivers/tty/ehv_bytechan.c b/drivers/tty/ehv_bytechan.c index 9bffcec5ad82..0419b69e270f 100644 --- a/drivers/tty/ehv_bytechan.c +++ b/drivers/tty/ehv_bytechan.c | |||
@@ -32,6 +32,7 @@ | |||
32 | #include <linux/poll.h> | 32 | #include <linux/poll.h> |
33 | #include <asm/epapr_hcalls.h> | 33 | #include <asm/epapr_hcalls.h> |
34 | #include <linux/of.h> | 34 | #include <linux/of.h> |
35 | #include <linux/of_irq.h> | ||
35 | #include <linux/platform_device.h> | 36 | #include <linux/platform_device.h> |
36 | #include <linux/cdev.h> | 37 | #include <linux/cdev.h> |
37 | #include <linux/console.h> | 38 | #include <linux/console.h> |
diff --git a/drivers/tty/hvc/hvc_dcc.c b/drivers/tty/hvc/hvc_dcc.c index 44fbebab5075..3502a7bbb69e 100644 --- a/drivers/tty/hvc/hvc_dcc.c +++ b/drivers/tty/hvc/hvc_dcc.c | |||
@@ -86,6 +86,21 @@ static int hvc_dcc_get_chars(uint32_t vt, char *buf, int count) | |||
86 | return i; | 86 | return i; |
87 | } | 87 | } |
88 | 88 | ||
89 | static bool hvc_dcc_check(void) | ||
90 | { | ||
91 | unsigned long time = jiffies + (HZ / 10); | ||
92 | |||
93 | /* Write a test character to check if it is handled */ | ||
94 | __dcc_putchar('\n'); | ||
95 | |||
96 | while (time_is_after_jiffies(time)) { | ||
97 | if (!(__dcc_getstatus() & DCC_STATUS_TX)) | ||
98 | return true; | ||
99 | } | ||
100 | |||
101 | return false; | ||
102 | } | ||
103 | |||
89 | static const struct hv_ops hvc_dcc_get_put_ops = { | 104 | static const struct hv_ops hvc_dcc_get_put_ops = { |
90 | .get_chars = hvc_dcc_get_chars, | 105 | .get_chars = hvc_dcc_get_chars, |
91 | .put_chars = hvc_dcc_put_chars, | 106 | .put_chars = hvc_dcc_put_chars, |
@@ -93,6 +108,9 @@ static const struct hv_ops hvc_dcc_get_put_ops = { | |||
93 | 108 | ||
94 | static int __init hvc_dcc_console_init(void) | 109 | static int __init hvc_dcc_console_init(void) |
95 | { | 110 | { |
111 | if (!hvc_dcc_check()) | ||
112 | return -ENODEV; | ||
113 | |||
96 | hvc_instantiate(0, 0, &hvc_dcc_get_put_ops); | 114 | hvc_instantiate(0, 0, &hvc_dcc_get_put_ops); |
97 | return 0; | 115 | return 0; |
98 | } | 116 | } |
@@ -100,6 +118,9 @@ console_initcall(hvc_dcc_console_init); | |||
100 | 118 | ||
101 | static int __init hvc_dcc_init(void) | 119 | static int __init hvc_dcc_init(void) |
102 | { | 120 | { |
121 | if (!hvc_dcc_check()) | ||
122 | return -ENODEV; | ||
123 | |||
103 | hvc_alloc(0, 0, &hvc_dcc_get_put_ops, 128); | 124 | hvc_alloc(0, 0, &hvc_dcc_get_put_ops, 128); |
104 | return 0; | 125 | return 0; |
105 | } | 126 | } |
diff --git a/drivers/tty/hvc/hvc_iucv.c b/drivers/tty/hvc/hvc_iucv.c index fd17a9b804b8..db19a38c8c69 100644 --- a/drivers/tty/hvc/hvc_iucv.c +++ b/drivers/tty/hvc/hvc_iucv.c | |||
@@ -1354,8 +1354,7 @@ out_error_memory: | |||
1354 | mempool_destroy(hvc_iucv_mempool); | 1354 | mempool_destroy(hvc_iucv_mempool); |
1355 | kmem_cache_destroy(hvc_iucv_buffer_cache); | 1355 | kmem_cache_destroy(hvc_iucv_buffer_cache); |
1356 | out_error: | 1356 | out_error: |
1357 | if (hvc_iucv_filter) | 1357 | kfree(hvc_iucv_filter); |
1358 | kfree(hvc_iucv_filter); | ||
1359 | hvc_iucv_devices = 0; /* ensure that we do not provide any device */ | 1358 | hvc_iucv_devices = 0; /* ensure that we do not provide any device */ |
1360 | return rc; | 1359 | return rc; |
1361 | } | 1360 | } |
diff --git a/drivers/tty/hvc/hvc_opal.c b/drivers/tty/hvc/hvc_opal.c index cd69b48f6dfd..6496872e2e47 100644 --- a/drivers/tty/hvc/hvc_opal.c +++ b/drivers/tty/hvc/hvc_opal.c | |||
@@ -329,7 +329,7 @@ static void udbg_init_opal_common(void) | |||
329 | void __init hvc_opal_init_early(void) | 329 | void __init hvc_opal_init_early(void) |
330 | { | 330 | { |
331 | struct device_node *stdout_node = NULL; | 331 | struct device_node *stdout_node = NULL; |
332 | const u32 *termno; | 332 | const __be32 *termno; |
333 | const char *name = NULL; | 333 | const char *name = NULL; |
334 | const struct hv_ops *ops; | 334 | const struct hv_ops *ops; |
335 | u32 index; | 335 | u32 index; |
@@ -371,7 +371,7 @@ void __init hvc_opal_init_early(void) | |||
371 | if (!stdout_node) | 371 | if (!stdout_node) |
372 | return; | 372 | return; |
373 | termno = of_get_property(stdout_node, "reg", NULL); | 373 | termno = of_get_property(stdout_node, "reg", NULL); |
374 | index = termno ? *termno : 0; | 374 | index = termno ? be32_to_cpup(termno) : 0; |
375 | if (index >= MAX_NR_HVC_CONSOLES) | 375 | if (index >= MAX_NR_HVC_CONSOLES) |
376 | return; | 376 | return; |
377 | hvc_opal_privs[index] = &hvc_opal_boot_priv; | 377 | hvc_opal_privs[index] = &hvc_opal_boot_priv; |
diff --git a/drivers/tty/hvc/hvc_vio.c b/drivers/tty/hvc/hvc_vio.c index c791b18cdd08..b594abfbf21e 100644 --- a/drivers/tty/hvc/hvc_vio.c +++ b/drivers/tty/hvc/hvc_vio.c | |||
@@ -48,6 +48,7 @@ | |||
48 | #include <asm/prom.h> | 48 | #include <asm/prom.h> |
49 | #include <asm/hvsi.h> | 49 | #include <asm/hvsi.h> |
50 | #include <asm/udbg.h> | 50 | #include <asm/udbg.h> |
51 | #include <asm/machdep.h> | ||
51 | 52 | ||
52 | #include "hvc_console.h" | 53 | #include "hvc_console.h" |
53 | 54 | ||
@@ -457,7 +458,9 @@ void __init hvc_vio_init_early(void) | |||
457 | if (hvterm_priv0.proto == HV_PROTOCOL_HVSI) | 458 | if (hvterm_priv0.proto == HV_PROTOCOL_HVSI) |
458 | goto out; | 459 | goto out; |
459 | #endif | 460 | #endif |
460 | add_preferred_console("hvc", 0, NULL); | 461 | /* Check whether the user has requested a different console. */ |
462 | if (!strstr(cmd_line, "console=")) | ||
463 | add_preferred_console("hvc", 0, NULL); | ||
461 | hvc_instantiate(0, 0, ops); | 464 | hvc_instantiate(0, 0, ops); |
462 | out: | 465 | out: |
463 | of_node_put(stdout_node); | 466 | of_node_put(stdout_node); |
diff --git a/drivers/tty/hvc/hvc_xen.c b/drivers/tty/hvc/hvc_xen.c index c193af6a628f..636c9baad7a5 100644 --- a/drivers/tty/hvc/hvc_xen.c +++ b/drivers/tty/hvc/hvc_xen.c | |||
@@ -183,7 +183,7 @@ static int dom0_write_console(uint32_t vtermno, const char *str, int len) | |||
183 | { | 183 | { |
184 | int rc = HYPERVISOR_console_io(CONSOLEIO_write, len, (char *)str); | 184 | int rc = HYPERVISOR_console_io(CONSOLEIO_write, len, (char *)str); |
185 | if (rc < 0) | 185 | if (rc < 0) |
186 | return 0; | 186 | return rc; |
187 | 187 | ||
188 | return len; | 188 | return len; |
189 | } | 189 | } |
@@ -642,7 +642,22 @@ struct console xenboot_console = { | |||
642 | 642 | ||
643 | void xen_raw_console_write(const char *str) | 643 | void xen_raw_console_write(const char *str) |
644 | { | 644 | { |
645 | dom0_write_console(0, str, strlen(str)); | 645 | ssize_t len = strlen(str); |
646 | int rc = 0; | ||
647 | |||
648 | if (xen_domain()) { | ||
649 | rc = dom0_write_console(0, str, len); | ||
650 | #ifdef CONFIG_X86 | ||
651 | if (rc == -ENOSYS && xen_hvm_domain()) | ||
652 | goto outb_print; | ||
653 | |||
654 | } else if (xen_cpuid_base()) { | ||
655 | int i; | ||
656 | outb_print: | ||
657 | for (i = 0; i < len; i++) | ||
658 | outb(str[i], 0xe9); | ||
659 | #endif | ||
660 | } | ||
646 | } | 661 | } |
647 | 662 | ||
648 | void xen_raw_printk(const char *fmt, ...) | 663 | void xen_raw_printk(const char *fmt, ...) |
diff --git a/drivers/tty/hvc/hvsi_lib.c b/drivers/tty/hvc/hvsi_lib.c index ac2767100df5..347050ea414a 100644 --- a/drivers/tty/hvc/hvsi_lib.c +++ b/drivers/tty/hvc/hvsi_lib.c | |||
@@ -9,7 +9,7 @@ | |||
9 | 9 | ||
10 | static int hvsi_send_packet(struct hvsi_priv *pv, struct hvsi_header *packet) | 10 | static int hvsi_send_packet(struct hvsi_priv *pv, struct hvsi_header *packet) |
11 | { | 11 | { |
12 | packet->seqno = atomic_inc_return(&pv->seqno); | 12 | packet->seqno = cpu_to_be16(atomic_inc_return(&pv->seqno)); |
13 | 13 | ||
14 | /* Assumes that always succeeds, works in practice */ | 14 | /* Assumes that always succeeds, works in practice */ |
15 | return pv->put_chars(pv->termno, (char *)packet, packet->len); | 15 | return pv->put_chars(pv->termno, (char *)packet, packet->len); |
@@ -28,7 +28,7 @@ static void hvsi_start_handshake(struct hvsi_priv *pv) | |||
28 | /* Send version query */ | 28 | /* Send version query */ |
29 | q.hdr.type = VS_QUERY_PACKET_HEADER; | 29 | q.hdr.type = VS_QUERY_PACKET_HEADER; |
30 | q.hdr.len = sizeof(struct hvsi_query); | 30 | q.hdr.len = sizeof(struct hvsi_query); |
31 | q.verb = VSV_SEND_VERSION_NUMBER; | 31 | q.verb = cpu_to_be16(VSV_SEND_VERSION_NUMBER); |
32 | hvsi_send_packet(pv, &q.hdr); | 32 | hvsi_send_packet(pv, &q.hdr); |
33 | } | 33 | } |
34 | 34 | ||
@@ -40,7 +40,7 @@ static int hvsi_send_close(struct hvsi_priv *pv) | |||
40 | 40 | ||
41 | ctrl.hdr.type = VS_CONTROL_PACKET_HEADER; | 41 | ctrl.hdr.type = VS_CONTROL_PACKET_HEADER; |
42 | ctrl.hdr.len = sizeof(struct hvsi_control); | 42 | ctrl.hdr.len = sizeof(struct hvsi_control); |
43 | ctrl.verb = VSV_CLOSE_PROTOCOL; | 43 | ctrl.verb = cpu_to_be16(VSV_CLOSE_PROTOCOL); |
44 | return hvsi_send_packet(pv, &ctrl.hdr); | 44 | return hvsi_send_packet(pv, &ctrl.hdr); |
45 | } | 45 | } |
46 | 46 | ||
@@ -69,14 +69,14 @@ static void hvsi_got_control(struct hvsi_priv *pv) | |||
69 | { | 69 | { |
70 | struct hvsi_control *pkt = (struct hvsi_control *)pv->inbuf; | 70 | struct hvsi_control *pkt = (struct hvsi_control *)pv->inbuf; |
71 | 71 | ||
72 | switch (pkt->verb) { | 72 | switch (be16_to_cpu(pkt->verb)) { |
73 | case VSV_CLOSE_PROTOCOL: | 73 | case VSV_CLOSE_PROTOCOL: |
74 | /* We restart the handshaking */ | 74 | /* We restart the handshaking */ |
75 | hvsi_start_handshake(pv); | 75 | hvsi_start_handshake(pv); |
76 | break; | 76 | break; |
77 | case VSV_MODEM_CTL_UPDATE: | 77 | case VSV_MODEM_CTL_UPDATE: |
78 | /* Transition of carrier detect */ | 78 | /* Transition of carrier detect */ |
79 | hvsi_cd_change(pv, pkt->word & HVSI_TSCD); | 79 | hvsi_cd_change(pv, be32_to_cpu(pkt->word) & HVSI_TSCD); |
80 | break; | 80 | break; |
81 | } | 81 | } |
82 | } | 82 | } |
@@ -87,7 +87,7 @@ static void hvsi_got_query(struct hvsi_priv *pv) | |||
87 | struct hvsi_query_response r; | 87 | struct hvsi_query_response r; |
88 | 88 | ||
89 | /* We only handle version queries */ | 89 | /* We only handle version queries */ |
90 | if (pkt->verb != VSV_SEND_VERSION_NUMBER) | 90 | if (be16_to_cpu(pkt->verb) != VSV_SEND_VERSION_NUMBER) |
91 | return; | 91 | return; |
92 | 92 | ||
93 | pr_devel("HVSI@%x: Got version query, sending response...\n", | 93 | pr_devel("HVSI@%x: Got version query, sending response...\n", |
@@ -96,7 +96,7 @@ static void hvsi_got_query(struct hvsi_priv *pv) | |||
96 | /* Send version response */ | 96 | /* Send version response */ |
97 | r.hdr.type = VS_QUERY_RESPONSE_PACKET_HEADER; | 97 | r.hdr.type = VS_QUERY_RESPONSE_PACKET_HEADER; |
98 | r.hdr.len = sizeof(struct hvsi_query_response); | 98 | r.hdr.len = sizeof(struct hvsi_query_response); |
99 | r.verb = VSV_SEND_VERSION_NUMBER; | 99 | r.verb = cpu_to_be16(VSV_SEND_VERSION_NUMBER); |
100 | r.u.version = HVSI_VERSION; | 100 | r.u.version = HVSI_VERSION; |
101 | r.query_seqno = pkt->hdr.seqno; | 101 | r.query_seqno = pkt->hdr.seqno; |
102 | hvsi_send_packet(pv, &r.hdr); | 102 | hvsi_send_packet(pv, &r.hdr); |
@@ -112,7 +112,7 @@ static void hvsi_got_response(struct hvsi_priv *pv) | |||
112 | 112 | ||
113 | switch(r->verb) { | 113 | switch(r->verb) { |
114 | case VSV_SEND_MODEM_CTL_STATUS: | 114 | case VSV_SEND_MODEM_CTL_STATUS: |
115 | hvsi_cd_change(pv, r->u.mctrl_word & HVSI_TSCD); | 115 | hvsi_cd_change(pv, be32_to_cpu(r->u.mctrl_word) & HVSI_TSCD); |
116 | pv->mctrl_update = 1; | 116 | pv->mctrl_update = 1; |
117 | break; | 117 | break; |
118 | } | 118 | } |
@@ -265,8 +265,7 @@ int hvsilib_read_mctrl(struct hvsi_priv *pv) | |||
265 | pv->mctrl_update = 0; | 265 | pv->mctrl_update = 0; |
266 | q.hdr.type = VS_QUERY_PACKET_HEADER; | 266 | q.hdr.type = VS_QUERY_PACKET_HEADER; |
267 | q.hdr.len = sizeof(struct hvsi_query); | 267 | q.hdr.len = sizeof(struct hvsi_query); |
268 | q.hdr.seqno = atomic_inc_return(&pv->seqno); | 268 | q.verb = cpu_to_be16(VSV_SEND_MODEM_CTL_STATUS); |
269 | q.verb = VSV_SEND_MODEM_CTL_STATUS; | ||
270 | rc = hvsi_send_packet(pv, &q.hdr); | 269 | rc = hvsi_send_packet(pv, &q.hdr); |
271 | if (rc <= 0) { | 270 | if (rc <= 0) { |
272 | pr_devel("HVSI@%x: Error %d...\n", pv->termno, rc); | 271 | pr_devel("HVSI@%x: Error %d...\n", pv->termno, rc); |
@@ -304,9 +303,9 @@ int hvsilib_write_mctrl(struct hvsi_priv *pv, int dtr) | |||
304 | 303 | ||
305 | ctrl.hdr.type = VS_CONTROL_PACKET_HEADER, | 304 | ctrl.hdr.type = VS_CONTROL_PACKET_HEADER, |
306 | ctrl.hdr.len = sizeof(struct hvsi_control); | 305 | ctrl.hdr.len = sizeof(struct hvsi_control); |
307 | ctrl.verb = VSV_SET_MODEM_CTL; | 306 | ctrl.verb = cpu_to_be16(VSV_SET_MODEM_CTL); |
308 | ctrl.mask = HVSI_TSDTR; | 307 | ctrl.mask = cpu_to_be32(HVSI_TSDTR); |
309 | ctrl.word = dtr ? HVSI_TSDTR : 0; | 308 | ctrl.word = cpu_to_be32(dtr ? HVSI_TSDTR : 0); |
310 | return hvsi_send_packet(pv, &ctrl.hdr); | 309 | return hvsi_send_packet(pv, &ctrl.hdr); |
311 | } | 310 | } |
312 | 311 | ||
diff --git a/drivers/tty/metag_da.c b/drivers/tty/metag_da.c index 0e888621f484..7332e2ca4615 100644 --- a/drivers/tty/metag_da.c +++ b/drivers/tty/metag_da.c | |||
@@ -495,7 +495,7 @@ static int dashtty_write(struct tty_struct *tty, const unsigned char *buf, | |||
495 | count = dport->xmit_cnt; | 495 | count = dport->xmit_cnt; |
496 | /* xmit buffer no longer empty? */ | 496 | /* xmit buffer no longer empty? */ |
497 | if (count) | 497 | if (count) |
498 | INIT_COMPLETION(dport->xmit_empty); | 498 | reinit_completion(&dport->xmit_empty); |
499 | mutex_unlock(&dport->xmit_lock); | 499 | mutex_unlock(&dport->xmit_lock); |
500 | 500 | ||
501 | if (total) { | 501 | if (total) { |
diff --git a/drivers/tty/n_tty.c b/drivers/tty/n_tty.c index 7a744b69c3d1..34aacaaae14a 100644 --- a/drivers/tty/n_tty.c +++ b/drivers/tty/n_tty.c | |||
@@ -93,6 +93,7 @@ struct n_tty_data { | |||
93 | size_t canon_head; | 93 | size_t canon_head; |
94 | size_t echo_head; | 94 | size_t echo_head; |
95 | size_t echo_commit; | 95 | size_t echo_commit; |
96 | size_t echo_mark; | ||
96 | DECLARE_BITMAP(char_map, 256); | 97 | DECLARE_BITMAP(char_map, 256); |
97 | 98 | ||
98 | /* private to n_tty_receive_overrun (single-threaded) */ | 99 | /* private to n_tty_receive_overrun (single-threaded) */ |
@@ -336,6 +337,7 @@ static void reset_buffer_flags(struct n_tty_data *ldata) | |||
336 | { | 337 | { |
337 | ldata->read_head = ldata->canon_head = ldata->read_tail = 0; | 338 | ldata->read_head = ldata->canon_head = ldata->read_tail = 0; |
338 | ldata->echo_head = ldata->echo_tail = ldata->echo_commit = 0; | 339 | ldata->echo_head = ldata->echo_tail = ldata->echo_commit = 0; |
340 | ldata->echo_mark = 0; | ||
339 | ldata->line_start = 0; | 341 | ldata->line_start = 0; |
340 | 342 | ||
341 | ldata->erasing = 0; | 343 | ldata->erasing = 0; |
@@ -767,8 +769,8 @@ static size_t __process_echoes(struct tty_struct *tty) | |||
767 | * of echo overrun before the next commit), then discard enough | 769 | * of echo overrun before the next commit), then discard enough |
768 | * data at the tail to prevent a subsequent overrun */ | 770 | * data at the tail to prevent a subsequent overrun */ |
769 | while (ldata->echo_commit - tail >= ECHO_DISCARD_WATERMARK) { | 771 | while (ldata->echo_commit - tail >= ECHO_DISCARD_WATERMARK) { |
770 | if (echo_buf(ldata, tail == ECHO_OP_START)) { | 772 | if (echo_buf(ldata, tail) == ECHO_OP_START) { |
771 | if (echo_buf(ldata, tail) == ECHO_OP_ERASE_TAB) | 773 | if (echo_buf(ldata, tail + 1) == ECHO_OP_ERASE_TAB) |
772 | tail += 3; | 774 | tail += 3; |
773 | else | 775 | else |
774 | tail += 2; | 776 | tail += 2; |
@@ -787,6 +789,7 @@ static void commit_echoes(struct tty_struct *tty) | |||
787 | size_t head; | 789 | size_t head; |
788 | 790 | ||
789 | head = ldata->echo_head; | 791 | head = ldata->echo_head; |
792 | ldata->echo_mark = head; | ||
790 | old = ldata->echo_commit - ldata->echo_tail; | 793 | old = ldata->echo_commit - ldata->echo_tail; |
791 | 794 | ||
792 | /* Process committed echoes if the accumulated # of bytes | 795 | /* Process committed echoes if the accumulated # of bytes |
@@ -810,10 +813,12 @@ static void process_echoes(struct tty_struct *tty) | |||
810 | struct n_tty_data *ldata = tty->disc_data; | 813 | struct n_tty_data *ldata = tty->disc_data; |
811 | size_t echoed; | 814 | size_t echoed; |
812 | 815 | ||
813 | if (!L_ECHO(tty) || ldata->echo_commit == ldata->echo_tail) | 816 | if ((!L_ECHO(tty) && !L_ECHONL(tty)) || |
817 | ldata->echo_mark == ldata->echo_tail) | ||
814 | return; | 818 | return; |
815 | 819 | ||
816 | mutex_lock(&ldata->output_lock); | 820 | mutex_lock(&ldata->output_lock); |
821 | ldata->echo_commit = ldata->echo_mark; | ||
817 | echoed = __process_echoes(tty); | 822 | echoed = __process_echoes(tty); |
818 | mutex_unlock(&ldata->output_lock); | 823 | mutex_unlock(&ldata->output_lock); |
819 | 824 | ||
@@ -821,11 +826,13 @@ static void process_echoes(struct tty_struct *tty) | |||
821 | tty->ops->flush_chars(tty); | 826 | tty->ops->flush_chars(tty); |
822 | } | 827 | } |
823 | 828 | ||
829 | /* NB: echo_mark and echo_head should be equivalent here */ | ||
824 | static void flush_echoes(struct tty_struct *tty) | 830 | static void flush_echoes(struct tty_struct *tty) |
825 | { | 831 | { |
826 | struct n_tty_data *ldata = tty->disc_data; | 832 | struct n_tty_data *ldata = tty->disc_data; |
827 | 833 | ||
828 | if (!L_ECHO(tty) || ldata->echo_commit == ldata->echo_head) | 834 | if ((!L_ECHO(tty) && !L_ECHONL(tty)) || |
835 | ldata->echo_commit == ldata->echo_head) | ||
829 | return; | 836 | return; |
830 | 837 | ||
831 | mutex_lock(&ldata->output_lock); | 838 | mutex_lock(&ldata->output_lock); |
@@ -1752,20 +1759,14 @@ int is_ignored(int sig) | |||
1752 | static void n_tty_set_termios(struct tty_struct *tty, struct ktermios *old) | 1759 | static void n_tty_set_termios(struct tty_struct *tty, struct ktermios *old) |
1753 | { | 1760 | { |
1754 | struct n_tty_data *ldata = tty->disc_data; | 1761 | struct n_tty_data *ldata = tty->disc_data; |
1755 | int canon_change = 1; | ||
1756 | 1762 | ||
1757 | if (old) | 1763 | if (!old || (old->c_lflag ^ tty->termios.c_lflag) & ICANON) { |
1758 | canon_change = (old->c_lflag ^ tty->termios.c_lflag) & ICANON; | ||
1759 | if (canon_change) { | ||
1760 | bitmap_zero(ldata->read_flags, N_TTY_BUF_SIZE); | 1764 | bitmap_zero(ldata->read_flags, N_TTY_BUF_SIZE); |
1761 | ldata->line_start = ldata->canon_head = ldata->read_tail; | 1765 | ldata->line_start = ldata->canon_head = ldata->read_tail; |
1762 | ldata->erasing = 0; | 1766 | ldata->erasing = 0; |
1763 | ldata->lnext = 0; | 1767 | ldata->lnext = 0; |
1764 | } | 1768 | } |
1765 | 1769 | ||
1766 | if (canon_change && !L_ICANON(tty) && read_cnt(ldata)) | ||
1767 | wake_up_interruptible(&tty->read_wait); | ||
1768 | |||
1769 | ldata->icanon = (L_ICANON(tty) != 0); | 1770 | ldata->icanon = (L_ICANON(tty) != 0); |
1770 | 1771 | ||
1771 | if (I_ISTRIP(tty) || I_IUCLC(tty) || I_IGNCR(tty) || | 1772 | if (I_ISTRIP(tty) || I_IUCLC(tty) || I_IGNCR(tty) || |
@@ -1820,9 +1821,8 @@ static void n_tty_set_termios(struct tty_struct *tty, struct ktermios *old) | |||
1820 | * Fix tty hang when I_IXON(tty) is cleared, but the tty | 1821 | * Fix tty hang when I_IXON(tty) is cleared, but the tty |
1821 | * been stopped by STOP_CHAR(tty) before it. | 1822 | * been stopped by STOP_CHAR(tty) before it. |
1822 | */ | 1823 | */ |
1823 | if (!I_IXON(tty) && old && (old->c_iflag & IXON) && !tty->flow_stopped) { | 1824 | if (!I_IXON(tty) && old && (old->c_iflag & IXON) && !tty->flow_stopped) |
1824 | start_tty(tty); | 1825 | start_tty(tty); |
1825 | } | ||
1826 | 1826 | ||
1827 | /* The termios change make the tty ready for I/O */ | 1827 | /* The termios change make the tty ready for I/O */ |
1828 | wake_up_interruptible(&tty->write_wait); | 1828 | wake_up_interruptible(&tty->write_wait); |
@@ -2005,7 +2005,10 @@ static int canon_copy_from_read_buf(struct tty_struct *tty, | |||
2005 | found = 1; | 2005 | found = 1; |
2006 | 2006 | ||
2007 | size = N_TTY_BUF_SIZE - tail; | 2007 | size = N_TTY_BUF_SIZE - tail; |
2008 | n = (found + eol + size) & (N_TTY_BUF_SIZE - 1); | 2008 | n = eol - tail; |
2009 | if (n > 4096) | ||
2010 | n += 4096; | ||
2011 | n += found; | ||
2009 | c = n; | 2012 | c = n; |
2010 | 2013 | ||
2011 | if (found && read_buf(ldata, eol) == __DISABLED_CHAR) { | 2014 | if (found && read_buf(ldata, eol) == __DISABLED_CHAR) { |
@@ -2250,18 +2253,19 @@ static ssize_t n_tty_read(struct tty_struct *tty, struct file *file, | |||
2250 | if (time) | 2253 | if (time) |
2251 | timeout = time; | 2254 | timeout = time; |
2252 | } | 2255 | } |
2253 | mutex_unlock(&ldata->atomic_read_lock); | 2256 | n_tty_set_room(tty); |
2254 | remove_wait_queue(&tty->read_wait, &wait); | 2257 | up_read(&tty->termios_rwsem); |
2255 | 2258 | ||
2259 | remove_wait_queue(&tty->read_wait, &wait); | ||
2256 | if (!waitqueue_active(&tty->read_wait)) | 2260 | if (!waitqueue_active(&tty->read_wait)) |
2257 | ldata->minimum_to_wake = minimum; | 2261 | ldata->minimum_to_wake = minimum; |
2258 | 2262 | ||
2263 | mutex_unlock(&ldata->atomic_read_lock); | ||
2264 | |||
2259 | __set_current_state(TASK_RUNNING); | 2265 | __set_current_state(TASK_RUNNING); |
2260 | if (b - buf) | 2266 | if (b - buf) |
2261 | retval = b - buf; | 2267 | retval = b - buf; |
2262 | 2268 | ||
2263 | n_tty_set_room(tty); | ||
2264 | up_read(&tty->termios_rwsem); | ||
2265 | return retval; | 2269 | return retval; |
2266 | } | 2270 | } |
2267 | 2271 | ||
diff --git a/drivers/tty/nozomi.c b/drivers/tty/nozomi.c index d6080c3831ef..cd0429369557 100644 --- a/drivers/tty/nozomi.c +++ b/drivers/tty/nozomi.c | |||
@@ -959,7 +959,7 @@ static int receive_flow_control(struct nozomi *dc) | |||
959 | dev_err(&dc->pdev->dev, | 959 | dev_err(&dc->pdev->dev, |
960 | "ERROR: flow control received for non-existing port\n"); | 960 | "ERROR: flow control received for non-existing port\n"); |
961 | return 0; | 961 | return 0; |
962 | }; | 962 | } |
963 | 963 | ||
964 | DBG1("0x%04X->0x%04X", *((u16 *)&dc->port[port].ctrl_dl), | 964 | DBG1("0x%04X->0x%04X", *((u16 *)&dc->port[port].ctrl_dl), |
965 | *((u16 *)&ctrl_dl)); | 965 | *((u16 *)&ctrl_dl)); |
@@ -1025,7 +1025,7 @@ static enum ctrl_port_type port2ctrl(enum port_type port, | |||
1025 | dev_err(&dc->pdev->dev, | 1025 | dev_err(&dc->pdev->dev, |
1026 | "ERROR: send flow control " \ | 1026 | "ERROR: send flow control " \ |
1027 | "received for non-existing port\n"); | 1027 | "received for non-existing port\n"); |
1028 | }; | 1028 | } |
1029 | return CTRL_ERROR; | 1029 | return CTRL_ERROR; |
1030 | } | 1030 | } |
1031 | 1031 | ||
@@ -1805,7 +1805,7 @@ static int ntty_ioctl(struct tty_struct *tty, | |||
1805 | default: | 1805 | default: |
1806 | DBG1("ERR: 0x%08X, %d", cmd, cmd); | 1806 | DBG1("ERR: 0x%08X, %d", cmd, cmd); |
1807 | break; | 1807 | break; |
1808 | }; | 1808 | } |
1809 | 1809 | ||
1810 | return rval; | 1810 | return rval; |
1811 | } | 1811 | } |
diff --git a/drivers/tty/serial/8250/8250_core.c b/drivers/tty/serial/8250/8250_core.c index 570df9d2a5d2..e33d38cb170f 100644 --- a/drivers/tty/serial/8250/8250_core.c +++ b/drivers/tty/serial/8250/8250_core.c | |||
@@ -2322,7 +2322,7 @@ serial8250_do_set_termios(struct uart_port *port, struct ktermios *termios, | |||
2322 | 2322 | ||
2323 | if (up->capabilities & UART_CAP_FIFO && port->fifosize > 1) { | 2323 | if (up->capabilities & UART_CAP_FIFO && port->fifosize > 1) { |
2324 | fcr = uart_config[port->type].fcr; | 2324 | fcr = uart_config[port->type].fcr; |
2325 | if (baud < 2400 || fifo_bug) { | 2325 | if ((baud < 2400 && !up->dma) || fifo_bug) { |
2326 | fcr &= ~UART_FCR_TRIGGER_MASK; | 2326 | fcr &= ~UART_FCR_TRIGGER_MASK; |
2327 | fcr |= UART_FCR_TRIGGER_1; | 2327 | fcr |= UART_FCR_TRIGGER_1; |
2328 | } | 2328 | } |
diff --git a/drivers/tty/serial/8250/8250_dw.c b/drivers/tty/serial/8250/8250_dw.c index daf710f5c3fc..06525f10e364 100644 --- a/drivers/tty/serial/8250/8250_dw.c +++ b/drivers/tty/serial/8250/8250_dw.c | |||
@@ -56,11 +56,11 @@ | |||
56 | 56 | ||
57 | 57 | ||
58 | struct dw8250_data { | 58 | struct dw8250_data { |
59 | int last_lcr; | 59 | u8 usr_reg; |
60 | int last_mcr; | 60 | int last_mcr; |
61 | int line; | 61 | int line; |
62 | struct clk *clk; | 62 | struct clk *clk; |
63 | u8 usr_reg; | 63 | struct uart_8250_dma dma; |
64 | }; | 64 | }; |
65 | 65 | ||
66 | static inline int dw8250_modify_msr(struct uart_port *p, int offset, int value) | 66 | static inline int dw8250_modify_msr(struct uart_port *p, int offset, int value) |
@@ -76,17 +76,34 @@ static inline int dw8250_modify_msr(struct uart_port *p, int offset, int value) | |||
76 | return value; | 76 | return value; |
77 | } | 77 | } |
78 | 78 | ||
79 | static void dw8250_force_idle(struct uart_port *p) | ||
80 | { | ||
81 | serial8250_clear_and_reinit_fifos(container_of | ||
82 | (p, struct uart_8250_port, port)); | ||
83 | (void)p->serial_in(p, UART_RX); | ||
84 | } | ||
85 | |||
79 | static void dw8250_serial_out(struct uart_port *p, int offset, int value) | 86 | static void dw8250_serial_out(struct uart_port *p, int offset, int value) |
80 | { | 87 | { |
81 | struct dw8250_data *d = p->private_data; | 88 | struct dw8250_data *d = p->private_data; |
82 | 89 | ||
83 | if (offset == UART_LCR) | ||
84 | d->last_lcr = value; | ||
85 | |||
86 | if (offset == UART_MCR) | 90 | if (offset == UART_MCR) |
87 | d->last_mcr = value; | 91 | d->last_mcr = value; |
88 | 92 | ||
89 | writeb(value, p->membase + (offset << p->regshift)); | 93 | writeb(value, p->membase + (offset << p->regshift)); |
94 | |||
95 | /* Make sure LCR write wasn't ignored */ | ||
96 | if (offset == UART_LCR) { | ||
97 | int tries = 1000; | ||
98 | while (tries--) { | ||
99 | unsigned int lcr = p->serial_in(p, UART_LCR); | ||
100 | if ((value & ~UART_LCR_SPAR) == (lcr & ~UART_LCR_SPAR)) | ||
101 | return; | ||
102 | dw8250_force_idle(p); | ||
103 | writeb(value, p->membase + (UART_LCR << p->regshift)); | ||
104 | } | ||
105 | dev_err(p->dev, "Couldn't set LCR to %d\n", value); | ||
106 | } | ||
90 | } | 107 | } |
91 | 108 | ||
92 | static unsigned int dw8250_serial_in(struct uart_port *p, int offset) | 109 | static unsigned int dw8250_serial_in(struct uart_port *p, int offset) |
@@ -107,13 +124,23 @@ static void dw8250_serial_out32(struct uart_port *p, int offset, int value) | |||
107 | { | 124 | { |
108 | struct dw8250_data *d = p->private_data; | 125 | struct dw8250_data *d = p->private_data; |
109 | 126 | ||
110 | if (offset == UART_LCR) | ||
111 | d->last_lcr = value; | ||
112 | |||
113 | if (offset == UART_MCR) | 127 | if (offset == UART_MCR) |
114 | d->last_mcr = value; | 128 | d->last_mcr = value; |
115 | 129 | ||
116 | writel(value, p->membase + (offset << p->regshift)); | 130 | writel(value, p->membase + (offset << p->regshift)); |
131 | |||
132 | /* Make sure LCR write wasn't ignored */ | ||
133 | if (offset == UART_LCR) { | ||
134 | int tries = 1000; | ||
135 | while (tries--) { | ||
136 | unsigned int lcr = p->serial_in(p, UART_LCR); | ||
137 | if ((value & ~UART_LCR_SPAR) == (lcr & ~UART_LCR_SPAR)) | ||
138 | return; | ||
139 | dw8250_force_idle(p); | ||
140 | writel(value, p->membase + (UART_LCR << p->regshift)); | ||
141 | } | ||
142 | dev_err(p->dev, "Couldn't set LCR to %d\n", value); | ||
143 | } | ||
117 | } | 144 | } |
118 | 145 | ||
119 | static unsigned int dw8250_serial_in32(struct uart_port *p, int offset) | 146 | static unsigned int dw8250_serial_in32(struct uart_port *p, int offset) |
@@ -131,9 +158,8 @@ static int dw8250_handle_irq(struct uart_port *p) | |||
131 | if (serial8250_handle_irq(p, iir)) { | 158 | if (serial8250_handle_irq(p, iir)) { |
132 | return 1; | 159 | return 1; |
133 | } else if ((iir & UART_IIR_BUSY) == UART_IIR_BUSY) { | 160 | } else if ((iir & UART_IIR_BUSY) == UART_IIR_BUSY) { |
134 | /* Clear the USR and write the LCR again. */ | 161 | /* Clear the USR */ |
135 | (void)p->serial_in(p, d->usr_reg); | 162 | (void)p->serial_in(p, d->usr_reg); |
136 | p->serial_out(p, UART_LCR, d->last_lcr); | ||
137 | 163 | ||
138 | return 1; | 164 | return 1; |
139 | } | 165 | } |
@@ -153,6 +179,14 @@ dw8250_do_pm(struct uart_port *port, unsigned int state, unsigned int old) | |||
153 | pm_runtime_put_sync_suspend(port->dev); | 179 | pm_runtime_put_sync_suspend(port->dev); |
154 | } | 180 | } |
155 | 181 | ||
182 | static bool dw8250_dma_filter(struct dma_chan *chan, void *param) | ||
183 | { | ||
184 | struct dw8250_data *data = param; | ||
185 | |||
186 | return chan->chan_id == data->dma.tx_chan_id || | ||
187 | chan->chan_id == data->dma.rx_chan_id; | ||
188 | } | ||
189 | |||
156 | static void dw8250_setup_port(struct uart_8250_port *up) | 190 | static void dw8250_setup_port(struct uart_8250_port *up) |
157 | { | 191 | { |
158 | struct uart_port *p = &up->port; | 192 | struct uart_port *p = &up->port; |
@@ -241,7 +275,8 @@ static int dw8250_probe_of(struct uart_port *p, | |||
241 | } | 275 | } |
242 | 276 | ||
243 | #ifdef CONFIG_ACPI | 277 | #ifdef CONFIG_ACPI |
244 | static int dw8250_probe_acpi(struct uart_8250_port *up) | 278 | static int dw8250_probe_acpi(struct uart_8250_port *up, |
279 | struct dw8250_data *data) | ||
245 | { | 280 | { |
246 | const struct acpi_device_id *id; | 281 | const struct acpi_device_id *id; |
247 | struct uart_port *p = &up->port; | 282 | struct uart_port *p = &up->port; |
@@ -260,9 +295,7 @@ static int dw8250_probe_acpi(struct uart_8250_port *up) | |||
260 | if (!p->uartclk) | 295 | if (!p->uartclk) |
261 | p->uartclk = (unsigned int)id->driver_data; | 296 | p->uartclk = (unsigned int)id->driver_data; |
262 | 297 | ||
263 | up->dma = devm_kzalloc(p->dev, sizeof(*up->dma), GFP_KERNEL); | 298 | up->dma = &data->dma; |
264 | if (!up->dma) | ||
265 | return -ENOMEM; | ||
266 | 299 | ||
267 | up->dma->rxconf.src_maxburst = p->fifosize / 4; | 300 | up->dma->rxconf.src_maxburst = p->fifosize / 4; |
268 | up->dma->txconf.dst_maxburst = p->fifosize / 4; | 301 | up->dma->txconf.dst_maxburst = p->fifosize / 4; |
@@ -270,7 +303,8 @@ static int dw8250_probe_acpi(struct uart_8250_port *up) | |||
270 | return 0; | 303 | return 0; |
271 | } | 304 | } |
272 | #else | 305 | #else |
273 | static inline int dw8250_probe_acpi(struct uart_8250_port *up) | 306 | static inline int dw8250_probe_acpi(struct uart_8250_port *up, |
307 | struct dw8250_data *data) | ||
274 | { | 308 | { |
275 | return -ENODEV; | 309 | return -ENODEV; |
276 | } | 310 | } |
@@ -314,6 +348,12 @@ static int dw8250_probe(struct platform_device *pdev) | |||
314 | uart.port.uartclk = clk_get_rate(data->clk); | 348 | uart.port.uartclk = clk_get_rate(data->clk); |
315 | } | 349 | } |
316 | 350 | ||
351 | data->dma.rx_chan_id = -1; | ||
352 | data->dma.tx_chan_id = -1; | ||
353 | data->dma.rx_param = data; | ||
354 | data->dma.tx_param = data; | ||
355 | data->dma.fn = dw8250_dma_filter; | ||
356 | |||
317 | uart.port.iotype = UPIO_MEM; | 357 | uart.port.iotype = UPIO_MEM; |
318 | uart.port.serial_in = dw8250_serial_in; | 358 | uart.port.serial_in = dw8250_serial_in; |
319 | uart.port.serial_out = dw8250_serial_out; | 359 | uart.port.serial_out = dw8250_serial_out; |
@@ -324,7 +364,7 @@ static int dw8250_probe(struct platform_device *pdev) | |||
324 | if (err) | 364 | if (err) |
325 | return err; | 365 | return err; |
326 | } else if (ACPI_HANDLE(&pdev->dev)) { | 366 | } else if (ACPI_HANDLE(&pdev->dev)) { |
327 | err = dw8250_probe_acpi(&uart); | 367 | err = dw8250_probe_acpi(&uart, data); |
328 | if (err) | 368 | if (err) |
329 | return err; | 369 | return err; |
330 | } else { | 370 | } else { |
@@ -417,6 +457,8 @@ MODULE_DEVICE_TABLE(of, dw8250_of_match); | |||
417 | static const struct acpi_device_id dw8250_acpi_match[] = { | 457 | static const struct acpi_device_id dw8250_acpi_match[] = { |
418 | { "INT33C4", 0 }, | 458 | { "INT33C4", 0 }, |
419 | { "INT33C5", 0 }, | 459 | { "INT33C5", 0 }, |
460 | { "INT3434", 0 }, | ||
461 | { "INT3435", 0 }, | ||
420 | { "80860F0A", 0 }, | 462 | { "80860F0A", 0 }, |
421 | { }, | 463 | { }, |
422 | }; | 464 | }; |
diff --git a/drivers/tty/serial/8250/8250_em.c b/drivers/tty/serial/8250/8250_em.c index 5f3bba12c159..d1a9078003bd 100644 --- a/drivers/tty/serial/8250/8250_em.c +++ b/drivers/tty/serial/8250/8250_em.c | |||
@@ -122,7 +122,7 @@ static int serial8250_em_probe(struct platform_device *pdev) | |||
122 | up.port.dev = &pdev->dev; | 122 | up.port.dev = &pdev->dev; |
123 | up.port.private_data = priv; | 123 | up.port.private_data = priv; |
124 | 124 | ||
125 | clk_enable(priv->sclk); | 125 | clk_prepare_enable(priv->sclk); |
126 | up.port.uartclk = clk_get_rate(priv->sclk); | 126 | up.port.uartclk = clk_get_rate(priv->sclk); |
127 | 127 | ||
128 | up.port.iotype = UPIO_MEM32; | 128 | up.port.iotype = UPIO_MEM32; |
@@ -134,7 +134,7 @@ static int serial8250_em_probe(struct platform_device *pdev) | |||
134 | ret = serial8250_register_8250_port(&up); | 134 | ret = serial8250_register_8250_port(&up); |
135 | if (ret < 0) { | 135 | if (ret < 0) { |
136 | dev_err(&pdev->dev, "unable to register 8250 port\n"); | 136 | dev_err(&pdev->dev, "unable to register 8250 port\n"); |
137 | clk_disable(priv->sclk); | 137 | clk_disable_unprepare(priv->sclk); |
138 | return ret; | 138 | return ret; |
139 | } | 139 | } |
140 | 140 | ||
@@ -148,7 +148,7 @@ static int serial8250_em_remove(struct platform_device *pdev) | |||
148 | struct serial8250_em_priv *priv = platform_get_drvdata(pdev); | 148 | struct serial8250_em_priv *priv = platform_get_drvdata(pdev); |
149 | 149 | ||
150 | serial8250_unregister_port(priv->line); | 150 | serial8250_unregister_port(priv->line); |
151 | clk_disable(priv->sclk); | 151 | clk_disable_unprepare(priv->sclk); |
152 | return 0; | 152 | return 0; |
153 | } | 153 | } |
154 | 154 | ||
diff --git a/drivers/tty/serial/8250/8250_pci.c b/drivers/tty/serial/8250/8250_pci.c index c810da7c7a88..4697a514b80a 100644 --- a/drivers/tty/serial/8250/8250_pci.c +++ b/drivers/tty/serial/8250/8250_pci.c | |||
@@ -9,6 +9,7 @@ | |||
9 | * it under the terms of the GNU General Public License as published by | 9 | * it under the terms of the GNU General Public License as published by |
10 | * the Free Software Foundation; either version 2 of the License. | 10 | * the Free Software Foundation; either version 2 of the License. |
11 | */ | 11 | */ |
12 | #undef DEBUG | ||
12 | #include <linux/module.h> | 13 | #include <linux/module.h> |
13 | #include <linux/init.h> | 14 | #include <linux/init.h> |
14 | #include <linux/pci.h> | 15 | #include <linux/pci.h> |
@@ -27,8 +28,6 @@ | |||
27 | 28 | ||
28 | #include "8250.h" | 29 | #include "8250.h" |
29 | 30 | ||
30 | #undef SERIAL_DEBUG_PCI | ||
31 | |||
32 | /* | 31 | /* |
33 | * init function returns: | 32 | * init function returns: |
34 | * > 0 - number of ports | 33 | * > 0 - number of ports |
@@ -63,7 +62,7 @@ static int pci_default_setup(struct serial_private*, | |||
63 | 62 | ||
64 | static void moan_device(const char *str, struct pci_dev *dev) | 63 | static void moan_device(const char *str, struct pci_dev *dev) |
65 | { | 64 | { |
66 | printk(KERN_WARNING | 65 | dev_err(&dev->dev, |
67 | "%s: %s\n" | 66 | "%s: %s\n" |
68 | "Please send the output of lspci -vv, this\n" | 67 | "Please send the output of lspci -vv, this\n" |
69 | "message (0x%04x,0x%04x,0x%04x,0x%04x), the\n" | 68 | "message (0x%04x,0x%04x,0x%04x,0x%04x), the\n" |
@@ -233,7 +232,7 @@ static int pci_inteli960ni_init(struct pci_dev *dev) | |||
233 | /* is firmware started? */ | 232 | /* is firmware started? */ |
234 | pci_read_config_dword(dev, 0x44, (void *)&oldval); | 233 | pci_read_config_dword(dev, 0x44, (void *)&oldval); |
235 | if (oldval == 0x00001000L) { /* RESET value */ | 234 | if (oldval == 0x00001000L) { /* RESET value */ |
236 | printk(KERN_DEBUG "Local i960 firmware missing"); | 235 | dev_dbg(&dev->dev, "Local i960 firmware missing\n"); |
237 | return -ENODEV; | 236 | return -ENODEV; |
238 | } | 237 | } |
239 | return 0; | 238 | return 0; |
@@ -827,7 +826,7 @@ static int pci_netmos_9900_numports(struct pci_dev *dev) | |||
827 | if (sub_serports > 0) { | 826 | if (sub_serports > 0) { |
828 | return sub_serports; | 827 | return sub_serports; |
829 | } else { | 828 | } else { |
830 | printk(KERN_NOTICE "NetMos/Mostech serial driver ignoring port on ambiguous config.\n"); | 829 | dev_err(&dev->dev, "NetMos/Mostech serial driver ignoring port on ambiguous config.\n"); |
831 | return 0; | 830 | return 0; |
832 | } | 831 | } |
833 | } | 832 | } |
@@ -931,7 +930,7 @@ static int pci_ite887x_init(struct pci_dev *dev) | |||
931 | } | 930 | } |
932 | 931 | ||
933 | if (!inta_addr[i]) { | 932 | if (!inta_addr[i]) { |
934 | printk(KERN_ERR "ite887x: could not find iobase\n"); | 933 | dev_err(&dev->dev, "ite887x: could not find iobase\n"); |
935 | return -ENODEV; | 934 | return -ENODEV; |
936 | } | 935 | } |
937 | 936 | ||
@@ -1024,9 +1023,9 @@ static int pci_oxsemi_tornado_init(struct pci_dev *dev) | |||
1024 | /* Tornado device */ | 1023 | /* Tornado device */ |
1025 | if (deviceID == 0x07000200) { | 1024 | if (deviceID == 0x07000200) { |
1026 | number_uarts = ioread8(p + 4); | 1025 | number_uarts = ioread8(p + 4); |
1027 | printk(KERN_DEBUG | 1026 | dev_dbg(&dev->dev, |
1028 | "%d ports detected on Oxford PCI Express device\n", | 1027 | "%d ports detected on Oxford PCI Express device\n", |
1029 | number_uarts); | 1028 | number_uarts); |
1030 | } | 1029 | } |
1031 | pci_iounmap(dev, p); | 1030 | pci_iounmap(dev, p); |
1032 | return number_uarts; | 1031 | return number_uarts; |
@@ -1308,6 +1307,29 @@ static int pci_default_setup(struct serial_private *priv, | |||
1308 | return setup_port(priv, port, bar, offset, board->reg_shift); | 1307 | return setup_port(priv, port, bar, offset, board->reg_shift); |
1309 | } | 1308 | } |
1310 | 1309 | ||
1310 | static int pci_pericom_setup(struct serial_private *priv, | ||
1311 | const struct pciserial_board *board, | ||
1312 | struct uart_8250_port *port, int idx) | ||
1313 | { | ||
1314 | unsigned int bar, offset = board->first_offset, maxnr; | ||
1315 | |||
1316 | bar = FL_GET_BASE(board->flags); | ||
1317 | if (board->flags & FL_BASE_BARS) | ||
1318 | bar += idx; | ||
1319 | else | ||
1320 | offset += idx * board->uart_offset; | ||
1321 | |||
1322 | maxnr = (pci_resource_len(priv->dev, bar) - board->first_offset) >> | ||
1323 | (board->reg_shift + 3); | ||
1324 | |||
1325 | if (board->flags & FL_REGION_SZ_CAP && idx >= maxnr) | ||
1326 | return 1; | ||
1327 | |||
1328 | port->port.uartclk = 14745600; | ||
1329 | |||
1330 | return setup_port(priv, port, bar, offset, board->reg_shift); | ||
1331 | } | ||
1332 | |||
1311 | static int | 1333 | static int |
1312 | ce4100_serial_setup(struct serial_private *priv, | 1334 | ce4100_serial_setup(struct serial_private *priv, |
1313 | const struct pciserial_board *board, | 1335 | const struct pciserial_board *board, |
@@ -1324,6 +1346,120 @@ ce4100_serial_setup(struct serial_private *priv, | |||
1324 | return ret; | 1346 | return ret; |
1325 | } | 1347 | } |
1326 | 1348 | ||
1349 | #define PCI_DEVICE_ID_INTEL_BYT_UART1 0x0f0a | ||
1350 | #define PCI_DEVICE_ID_INTEL_BYT_UART2 0x0f0c | ||
1351 | |||
1352 | #define BYT_PRV_CLK 0x800 | ||
1353 | #define BYT_PRV_CLK_EN (1 << 0) | ||
1354 | #define BYT_PRV_CLK_M_VAL_SHIFT 1 | ||
1355 | #define BYT_PRV_CLK_N_VAL_SHIFT 16 | ||
1356 | #define BYT_PRV_CLK_UPDATE (1 << 31) | ||
1357 | |||
1358 | #define BYT_GENERAL_REG 0x808 | ||
1359 | #define BYT_GENERAL_DIS_RTS_N_OVERRIDE (1 << 3) | ||
1360 | |||
1361 | #define BYT_TX_OVF_INT 0x820 | ||
1362 | #define BYT_TX_OVF_INT_MASK (1 << 1) | ||
1363 | |||
1364 | static void | ||
1365 | byt_set_termios(struct uart_port *p, struct ktermios *termios, | ||
1366 | struct ktermios *old) | ||
1367 | { | ||
1368 | unsigned int baud = tty_termios_baud_rate(termios); | ||
1369 | unsigned int m = 6912; | ||
1370 | unsigned int n = 15625; | ||
1371 | u32 reg; | ||
1372 | |||
1373 | /* For baud rates 1M, 2M, 3M and 4M the dividers must be adjusted. */ | ||
1374 | if (baud == 1000000 || baud == 2000000 || baud == 4000000) { | ||
1375 | m = 64; | ||
1376 | n = 100; | ||
1377 | |||
1378 | p->uartclk = 64000000; | ||
1379 | } else if (baud == 3000000) { | ||
1380 | m = 48; | ||
1381 | n = 100; | ||
1382 | |||
1383 | p->uartclk = 48000000; | ||
1384 | } else { | ||
1385 | p->uartclk = 44236800; | ||
1386 | } | ||
1387 | |||
1388 | /* Reset the clock */ | ||
1389 | reg = (m << BYT_PRV_CLK_M_VAL_SHIFT) | (n << BYT_PRV_CLK_N_VAL_SHIFT); | ||
1390 | writel(reg, p->membase + BYT_PRV_CLK); | ||
1391 | reg |= BYT_PRV_CLK_EN | BYT_PRV_CLK_UPDATE; | ||
1392 | writel(reg, p->membase + BYT_PRV_CLK); | ||
1393 | |||
1394 | /* | ||
1395 | * If auto-handshake mechanism is not enabled, | ||
1396 | * disable rts_n override | ||
1397 | */ | ||
1398 | reg = readl(p->membase + BYT_GENERAL_REG); | ||
1399 | reg &= ~BYT_GENERAL_DIS_RTS_N_OVERRIDE; | ||
1400 | if (termios->c_cflag & CRTSCTS) | ||
1401 | reg |= BYT_GENERAL_DIS_RTS_N_OVERRIDE; | ||
1402 | writel(reg, p->membase + BYT_GENERAL_REG); | ||
1403 | |||
1404 | serial8250_do_set_termios(p, termios, old); | ||
1405 | } | ||
1406 | |||
1407 | static bool byt_dma_filter(struct dma_chan *chan, void *param) | ||
1408 | { | ||
1409 | return chan->chan_id == *(int *)param; | ||
1410 | } | ||
1411 | |||
1412 | static int | ||
1413 | byt_serial_setup(struct serial_private *priv, | ||
1414 | const struct pciserial_board *board, | ||
1415 | struct uart_8250_port *port, int idx) | ||
1416 | { | ||
1417 | struct uart_8250_dma *dma; | ||
1418 | int ret; | ||
1419 | |||
1420 | dma = devm_kzalloc(port->port.dev, sizeof(*dma), GFP_KERNEL); | ||
1421 | if (!dma) | ||
1422 | return -ENOMEM; | ||
1423 | |||
1424 | switch (priv->dev->device) { | ||
1425 | case PCI_DEVICE_ID_INTEL_BYT_UART1: | ||
1426 | dma->rx_chan_id = 3; | ||
1427 | dma->tx_chan_id = 2; | ||
1428 | break; | ||
1429 | case PCI_DEVICE_ID_INTEL_BYT_UART2: | ||
1430 | dma->rx_chan_id = 5; | ||
1431 | dma->tx_chan_id = 4; | ||
1432 | break; | ||
1433 | default: | ||
1434 | return -EINVAL; | ||
1435 | } | ||
1436 | |||
1437 | dma->rxconf.slave_id = dma->rx_chan_id; | ||
1438 | dma->rxconf.src_maxburst = 16; | ||
1439 | |||
1440 | dma->txconf.slave_id = dma->tx_chan_id; | ||
1441 | dma->txconf.dst_maxburst = 16; | ||
1442 | |||
1443 | dma->fn = byt_dma_filter; | ||
1444 | dma->rx_param = &dma->rx_chan_id; | ||
1445 | dma->tx_param = &dma->tx_chan_id; | ||
1446 | |||
1447 | ret = pci_default_setup(priv, board, port, idx); | ||
1448 | port->port.iotype = UPIO_MEM; | ||
1449 | port->port.type = PORT_16550A; | ||
1450 | port->port.flags = (port->port.flags | UPF_FIXED_PORT | UPF_FIXED_TYPE); | ||
1451 | port->port.set_termios = byt_set_termios; | ||
1452 | port->port.fifosize = 64; | ||
1453 | port->tx_loadsz = 64; | ||
1454 | port->dma = dma; | ||
1455 | port->capabilities = UART_CAP_FIFO | UART_CAP_AFE; | ||
1456 | |||
1457 | /* Disable Tx counter interrupts */ | ||
1458 | writel(BYT_TX_OVF_INT_MASK, port->port.membase + BYT_TX_OVF_INT); | ||
1459 | |||
1460 | return ret; | ||
1461 | } | ||
1462 | |||
1327 | static int | 1463 | static int |
1328 | pci_omegapci_setup(struct serial_private *priv, | 1464 | pci_omegapci_setup(struct serial_private *priv, |
1329 | const struct pciserial_board *board, | 1465 | const struct pciserial_board *board, |
@@ -1344,17 +1480,80 @@ pci_brcm_trumanage_setup(struct serial_private *priv, | |||
1344 | return ret; | 1480 | return ret; |
1345 | } | 1481 | } |
1346 | 1482 | ||
1483 | static int pci_fintek_setup(struct serial_private *priv, | ||
1484 | const struct pciserial_board *board, | ||
1485 | struct uart_8250_port *port, int idx) | ||
1486 | { | ||
1487 | struct pci_dev *pdev = priv->dev; | ||
1488 | unsigned long base; | ||
1489 | unsigned long iobase; | ||
1490 | unsigned long ciobase = 0; | ||
1491 | u8 config_base; | ||
1492 | |||
1493 | /* | ||
1494 | * We are supposed to be able to read these from the PCI config space, | ||
1495 | * but the values there don't seem to match what we need to use, so | ||
1496 | * just use these hard-coded values for now, as they are correct. | ||
1497 | */ | ||
1498 | switch (idx) { | ||
1499 | case 0: iobase = 0xe000; config_base = 0x40; break; | ||
1500 | case 1: iobase = 0xe008; config_base = 0x48; break; | ||
1501 | case 2: iobase = 0xe010; config_base = 0x50; break; | ||
1502 | case 3: iobase = 0xe018; config_base = 0x58; break; | ||
1503 | case 4: iobase = 0xe020; config_base = 0x60; break; | ||
1504 | case 5: iobase = 0xe028; config_base = 0x68; break; | ||
1505 | case 6: iobase = 0xe030; config_base = 0x70; break; | ||
1506 | case 7: iobase = 0xe038; config_base = 0x78; break; | ||
1507 | case 8: iobase = 0xe040; config_base = 0x80; break; | ||
1508 | case 9: iobase = 0xe048; config_base = 0x88; break; | ||
1509 | case 10: iobase = 0xe050; config_base = 0x90; break; | ||
1510 | case 11: iobase = 0xe058; config_base = 0x98; break; | ||
1511 | default: | ||
1512 | /* Unknown number of ports, get out of here */ | ||
1513 | return -EINVAL; | ||
1514 | } | ||
1515 | |||
1516 | if (idx < 4) { | ||
1517 | base = pci_resource_start(priv->dev, 3); | ||
1518 | ciobase = (int)(base + (0x8 * idx)); | ||
1519 | } | ||
1520 | |||
1521 | dev_dbg(&pdev->dev, "%s: idx=%d iobase=0x%lx ciobase=0x%lx config_base=0x%2x\n", | ||
1522 | __func__, idx, iobase, ciobase, config_base); | ||
1523 | |||
1524 | /* Enable UART I/O port */ | ||
1525 | pci_write_config_byte(pdev, config_base + 0x00, 0x01); | ||
1526 | |||
1527 | /* Select 128-byte FIFO and 8x FIFO threshold */ | ||
1528 | pci_write_config_byte(pdev, config_base + 0x01, 0x33); | ||
1529 | |||
1530 | /* LSB UART */ | ||
1531 | pci_write_config_byte(pdev, config_base + 0x04, (u8)(iobase & 0xff)); | ||
1532 | |||
1533 | /* MSB UART */ | ||
1534 | pci_write_config_byte(pdev, config_base + 0x05, (u8)((iobase & 0xff00) >> 8)); | ||
1535 | |||
1536 | /* irq number, this usually fails, but the spec says to do it anyway. */ | ||
1537 | pci_write_config_byte(pdev, config_base + 0x06, pdev->irq); | ||
1538 | |||
1539 | port->port.iotype = UPIO_PORT; | ||
1540 | port->port.iobase = iobase; | ||
1541 | port->port.mapbase = 0; | ||
1542 | port->port.membase = NULL; | ||
1543 | port->port.regshift = 0; | ||
1544 | |||
1545 | return 0; | ||
1546 | } | ||
1547 | |||
1347 | static int skip_tx_en_setup(struct serial_private *priv, | 1548 | static int skip_tx_en_setup(struct serial_private *priv, |
1348 | const struct pciserial_board *board, | 1549 | const struct pciserial_board *board, |
1349 | struct uart_8250_port *port, int idx) | 1550 | struct uart_8250_port *port, int idx) |
1350 | { | 1551 | { |
1351 | port->port.flags |= UPF_NO_TXEN_TEST; | 1552 | port->port.flags |= UPF_NO_TXEN_TEST; |
1352 | printk(KERN_DEBUG "serial8250: skipping TxEn test for device " | 1553 | dev_dbg(&priv->dev->dev, |
1353 | "[%04x:%04x] subsystem [%04x:%04x]\n", | 1554 | "serial8250: skipping TxEn test for device [%04x:%04x] subsystem [%04x:%04x]\n", |
1354 | priv->dev->vendor, | 1555 | priv->dev->vendor, priv->dev->device, |
1355 | priv->dev->device, | 1556 | priv->dev->subsystem_vendor, priv->dev->subsystem_device); |
1356 | priv->dev->subsystem_vendor, | ||
1357 | priv->dev->subsystem_device); | ||
1358 | 1557 | ||
1359 | return pci_default_setup(priv, board, port, idx); | 1558 | return pci_default_setup(priv, board, port, idx); |
1360 | } | 1559 | } |
@@ -1662,6 +1861,20 @@ static struct pci_serial_quirk pci_serial_quirks[] __refdata = { | |||
1662 | .subdevice = PCI_ANY_ID, | 1861 | .subdevice = PCI_ANY_ID, |
1663 | .setup = kt_serial_setup, | 1862 | .setup = kt_serial_setup, |
1664 | }, | 1863 | }, |
1864 | { | ||
1865 | .vendor = PCI_VENDOR_ID_INTEL, | ||
1866 | .device = PCI_DEVICE_ID_INTEL_BYT_UART1, | ||
1867 | .subvendor = PCI_ANY_ID, | ||
1868 | .subdevice = PCI_ANY_ID, | ||
1869 | .setup = byt_serial_setup, | ||
1870 | }, | ||
1871 | { | ||
1872 | .vendor = PCI_VENDOR_ID_INTEL, | ||
1873 | .device = PCI_DEVICE_ID_INTEL_BYT_UART2, | ||
1874 | .subvendor = PCI_ANY_ID, | ||
1875 | .subdevice = PCI_ANY_ID, | ||
1876 | .setup = byt_serial_setup, | ||
1877 | }, | ||
1665 | /* | 1878 | /* |
1666 | * ITE | 1879 | * ITE |
1667 | */ | 1880 | */ |
@@ -1826,6 +2039,31 @@ static struct pci_serial_quirk pci_serial_quirks[] __refdata = { | |||
1826 | .exit = pci_plx9050_exit, | 2039 | .exit = pci_plx9050_exit, |
1827 | }, | 2040 | }, |
1828 | /* | 2041 | /* |
2042 | * Pericom | ||
2043 | */ | ||
2044 | { | ||
2045 | .vendor = 0x12d8, | ||
2046 | .device = 0x7952, | ||
2047 | .subvendor = PCI_ANY_ID, | ||
2048 | .subdevice = PCI_ANY_ID, | ||
2049 | .setup = pci_pericom_setup, | ||
2050 | }, | ||
2051 | { | ||
2052 | .vendor = 0x12d8, | ||
2053 | .device = 0x7954, | ||
2054 | .subvendor = PCI_ANY_ID, | ||
2055 | .subdevice = PCI_ANY_ID, | ||
2056 | .setup = pci_pericom_setup, | ||
2057 | }, | ||
2058 | { | ||
2059 | .vendor = 0x12d8, | ||
2060 | .device = 0x7958, | ||
2061 | .subvendor = PCI_ANY_ID, | ||
2062 | .subdevice = PCI_ANY_ID, | ||
2063 | .setup = pci_pericom_setup, | ||
2064 | }, | ||
2065 | |||
2066 | /* | ||
1829 | * PLX | 2067 | * PLX |
1830 | */ | 2068 | */ |
1831 | { | 2069 | { |
@@ -2255,6 +2493,27 @@ static struct pci_serial_quirk pci_serial_quirks[] __refdata = { | |||
2255 | .subdevice = PCI_ANY_ID, | 2493 | .subdevice = PCI_ANY_ID, |
2256 | .setup = pci_brcm_trumanage_setup, | 2494 | .setup = pci_brcm_trumanage_setup, |
2257 | }, | 2495 | }, |
2496 | { | ||
2497 | .vendor = 0x1c29, | ||
2498 | .device = 0x1104, | ||
2499 | .subvendor = PCI_ANY_ID, | ||
2500 | .subdevice = PCI_ANY_ID, | ||
2501 | .setup = pci_fintek_setup, | ||
2502 | }, | ||
2503 | { | ||
2504 | .vendor = 0x1c29, | ||
2505 | .device = 0x1108, | ||
2506 | .subvendor = PCI_ANY_ID, | ||
2507 | .subdevice = PCI_ANY_ID, | ||
2508 | .setup = pci_fintek_setup, | ||
2509 | }, | ||
2510 | { | ||
2511 | .vendor = 0x1c29, | ||
2512 | .device = 0x1112, | ||
2513 | .subvendor = PCI_ANY_ID, | ||
2514 | .subdevice = PCI_ANY_ID, | ||
2515 | .setup = pci_fintek_setup, | ||
2516 | }, | ||
2258 | 2517 | ||
2259 | /* | 2518 | /* |
2260 | * Default "match everything" terminator entry | 2519 | * Default "match everything" terminator entry |
@@ -2449,9 +2708,13 @@ enum pci_board_num_t { | |||
2449 | pbn_ADDIDATA_PCIe_4_3906250, | 2708 | pbn_ADDIDATA_PCIe_4_3906250, |
2450 | pbn_ADDIDATA_PCIe_8_3906250, | 2709 | pbn_ADDIDATA_PCIe_8_3906250, |
2451 | pbn_ce4100_1_115200, | 2710 | pbn_ce4100_1_115200, |
2711 | pbn_byt, | ||
2452 | pbn_omegapci, | 2712 | pbn_omegapci, |
2453 | pbn_NETMOS9900_2s_115200, | 2713 | pbn_NETMOS9900_2s_115200, |
2454 | pbn_brcm_trumanage, | 2714 | pbn_brcm_trumanage, |
2715 | pbn_fintek_4, | ||
2716 | pbn_fintek_8, | ||
2717 | pbn_fintek_12, | ||
2455 | }; | 2718 | }; |
2456 | 2719 | ||
2457 | /* | 2720 | /* |
@@ -3185,6 +3448,13 @@ static struct pciserial_board pci_boards[] = { | |||
3185 | .base_baud = 921600, | 3448 | .base_baud = 921600, |
3186 | .reg_shift = 2, | 3449 | .reg_shift = 2, |
3187 | }, | 3450 | }, |
3451 | [pbn_byt] = { | ||
3452 | .flags = FL_BASE0, | ||
3453 | .num_ports = 1, | ||
3454 | .base_baud = 2764800, | ||
3455 | .uart_offset = 0x80, | ||
3456 | .reg_shift = 2, | ||
3457 | }, | ||
3188 | [pbn_omegapci] = { | 3458 | [pbn_omegapci] = { |
3189 | .flags = FL_BASE0, | 3459 | .flags = FL_BASE0, |
3190 | .num_ports = 8, | 3460 | .num_ports = 8, |
@@ -3202,6 +3472,24 @@ static struct pciserial_board pci_boards[] = { | |||
3202 | .reg_shift = 2, | 3472 | .reg_shift = 2, |
3203 | .base_baud = 115200, | 3473 | .base_baud = 115200, |
3204 | }, | 3474 | }, |
3475 | [pbn_fintek_4] = { | ||
3476 | .num_ports = 4, | ||
3477 | .uart_offset = 8, | ||
3478 | .base_baud = 115200, | ||
3479 | .first_offset = 0x40, | ||
3480 | }, | ||
3481 | [pbn_fintek_8] = { | ||
3482 | .num_ports = 8, | ||
3483 | .uart_offset = 8, | ||
3484 | .base_baud = 115200, | ||
3485 | .first_offset = 0x40, | ||
3486 | }, | ||
3487 | [pbn_fintek_12] = { | ||
3488 | .num_ports = 12, | ||
3489 | .uart_offset = 8, | ||
3490 | .base_baud = 115200, | ||
3491 | .first_offset = 0x40, | ||
3492 | }, | ||
3205 | }; | 3493 | }; |
3206 | 3494 | ||
3207 | static const struct pci_device_id blacklist[] = { | 3495 | static const struct pci_device_id blacklist[] = { |
@@ -3362,14 +3650,15 @@ pciserial_init_ports(struct pci_dev *dev, const struct pciserial_board *board) | |||
3362 | if (quirk->setup(priv, board, &uart, i)) | 3650 | if (quirk->setup(priv, board, &uart, i)) |
3363 | break; | 3651 | break; |
3364 | 3652 | ||
3365 | #ifdef SERIAL_DEBUG_PCI | 3653 | dev_dbg(&dev->dev, "Setup PCI port: port %lx, irq %d, type %d\n", |
3366 | printk(KERN_DEBUG "Setup PCI port: port %lx, irq %d, type %d\n", | 3654 | uart.port.iobase, uart.port.irq, uart.port.iotype); |
3367 | uart.port.iobase, uart.port.irq, uart.port.iotype); | ||
3368 | #endif | ||
3369 | 3655 | ||
3370 | priv->line[i] = serial8250_register_8250_port(&uart); | 3656 | priv->line[i] = serial8250_register_8250_port(&uart); |
3371 | if (priv->line[i] < 0) { | 3657 | if (priv->line[i] < 0) { |
3372 | printk(KERN_WARNING "Couldn't register serial port %s: %d\n", pci_name(dev), priv->line[i]); | 3658 | dev_err(&dev->dev, |
3659 | "Couldn't register serial port %lx, irq %d, type %d, error %d\n", | ||
3660 | uart.port.iobase, uart.port.irq, | ||
3661 | uart.port.iotype, priv->line[i]); | ||
3373 | break; | 3662 | break; |
3374 | } | 3663 | } |
3375 | } | 3664 | } |
@@ -3462,7 +3751,7 @@ pciserial_init_one(struct pci_dev *dev, const struct pci_device_id *ent) | |||
3462 | } | 3751 | } |
3463 | 3752 | ||
3464 | if (ent->driver_data >= ARRAY_SIZE(pci_boards)) { | 3753 | if (ent->driver_data >= ARRAY_SIZE(pci_boards)) { |
3465 | printk(KERN_ERR "pci_init_one: invalid driver_data: %ld\n", | 3754 | dev_err(&dev->dev, "invalid driver_data: %ld\n", |
3466 | ent->driver_data); | 3755 | ent->driver_data); |
3467 | return -EINVAL; | 3756 | return -EINVAL; |
3468 | } | 3757 | } |
@@ -3520,8 +3809,6 @@ static void pciserial_remove_one(struct pci_dev *dev) | |||
3520 | { | 3809 | { |
3521 | struct serial_private *priv = pci_get_drvdata(dev); | 3810 | struct serial_private *priv = pci_get_drvdata(dev); |
3522 | 3811 | ||
3523 | pci_set_drvdata(dev, NULL); | ||
3524 | |||
3525 | pciserial_remove_ports(priv); | 3812 | pciserial_remove_ports(priv); |
3526 | 3813 | ||
3527 | pci_disable_device(dev); | 3814 | pci_disable_device(dev); |
@@ -3555,7 +3842,7 @@ static int pciserial_resume_one(struct pci_dev *dev) | |||
3555 | err = pci_enable_device(dev); | 3842 | err = pci_enable_device(dev); |
3556 | /* FIXME: We cannot simply error out here */ | 3843 | /* FIXME: We cannot simply error out here */ |
3557 | if (err) | 3844 | if (err) |
3558 | printk(KERN_ERR "pciserial: Unable to re-enable ports, trying to continue.\n"); | 3845 | dev_err(&dev->dev, "Unable to re-enable ports, trying to continue.\n"); |
3559 | pciserial_resume_ports(priv); | 3846 | pciserial_resume_ports(priv); |
3560 | } | 3847 | } |
3561 | return 0; | 3848 | return 0; |
@@ -4848,6 +5135,15 @@ static struct pci_device_id serial_pci_tbl[] = { | |||
4848 | { PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_CE4100_UART, | 5135 | { PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_CE4100_UART, |
4849 | PCI_ANY_ID, PCI_ANY_ID, 0, 0, | 5136 | PCI_ANY_ID, PCI_ANY_ID, 0, 0, |
4850 | pbn_ce4100_1_115200 }, | 5137 | pbn_ce4100_1_115200 }, |
5138 | /* Intel BayTrail */ | ||
5139 | { PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_BYT_UART1, | ||
5140 | PCI_ANY_ID, PCI_ANY_ID, | ||
5141 | PCI_CLASS_COMMUNICATION_SERIAL << 8, 0xff0000, | ||
5142 | pbn_byt }, | ||
5143 | { PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_BYT_UART2, | ||
5144 | PCI_ANY_ID, PCI_ANY_ID, | ||
5145 | PCI_CLASS_COMMUNICATION_SERIAL << 8, 0xff0000, | ||
5146 | pbn_byt }, | ||
4851 | 5147 | ||
4852 | /* | 5148 | /* |
4853 | * Cronyx Omega PCI | 5149 | * Cronyx Omega PCI |
@@ -4918,6 +5214,11 @@ static struct pci_device_id serial_pci_tbl[] = { | |||
4918 | 0, | 5214 | 0, |
4919 | 0, pbn_exar_XR17V358 }, | 5215 | 0, pbn_exar_XR17V358 }, |
4920 | 5216 | ||
5217 | /* Fintek PCI serial cards */ | ||
5218 | { PCI_DEVICE(0x1c29, 0x1104), .driver_data = pbn_fintek_4 }, | ||
5219 | { PCI_DEVICE(0x1c29, 0x1108), .driver_data = pbn_fintek_8 }, | ||
5220 | { PCI_DEVICE(0x1c29, 0x1112), .driver_data = pbn_fintek_12 }, | ||
5221 | |||
4921 | /* | 5222 | /* |
4922 | * These entries match devices with class COMMUNICATION_SERIAL, | 5223 | * These entries match devices with class COMMUNICATION_SERIAL, |
4923 | * COMMUNICATION_MODEM or COMMUNICATION_MULTISERIAL | 5224 | * COMMUNICATION_MODEM or COMMUNICATION_MULTISERIAL |
diff --git a/drivers/tty/serial/8250/Kconfig b/drivers/tty/serial/8250/Kconfig index f3b306efaa59..23329918f229 100644 --- a/drivers/tty/serial/8250/Kconfig +++ b/drivers/tty/serial/8250/Kconfig | |||
@@ -41,7 +41,7 @@ config SERIAL_8250_DEPRECATED_OPTIONS | |||
41 | accept kernel parameters in both forms like 8250_core.nr_uarts=4 and | 41 | accept kernel parameters in both forms like 8250_core.nr_uarts=4 and |
42 | 8250.nr_uarts=4. We now renamed the module back to 8250, but if | 42 | 8250.nr_uarts=4. We now renamed the module back to 8250, but if |
43 | anybody noticed in 3.7 and changed their userspace we still have to | 43 | anybody noticed in 3.7 and changed their userspace we still have to |
44 | keep the 8350_core.* options around until they revert the changes | 44 | keep the 8250_core.* options around until they revert the changes |
45 | they already did. | 45 | they already did. |
46 | 46 | ||
47 | If 8250 is built as a module, this adds 8250_core alias instead. | 47 | If 8250 is built as a module, this adds 8250_core alias instead. |
diff --git a/drivers/tty/serial/Kconfig b/drivers/tty/serial/Kconfig index febd45cd5027..a3817ab8602f 100644 --- a/drivers/tty/serial/Kconfig +++ b/drivers/tty/serial/Kconfig | |||
@@ -709,7 +709,7 @@ config SERIAL_IP22_ZILOG_CONSOLE | |||
709 | 709 | ||
710 | config SERIAL_SH_SCI | 710 | config SERIAL_SH_SCI |
711 | tristate "SuperH SCI(F) serial port support" | 711 | tristate "SuperH SCI(F) serial port support" |
712 | depends on HAVE_CLK && (SUPERH || ARCH_SHMOBILE) | 712 | depends on HAVE_CLK && (SUPERH || ARM || COMPILE_TEST) |
713 | select SERIAL_CORE | 713 | select SERIAL_CORE |
714 | 714 | ||
715 | config SERIAL_SH_SCI_NR_UARTS | 715 | config SERIAL_SH_SCI_NR_UARTS |
@@ -1512,6 +1512,7 @@ config SERIAL_FSL_LPUART_CONSOLE | |||
1512 | config SERIAL_ST_ASC | 1512 | config SERIAL_ST_ASC |
1513 | tristate "ST ASC serial port support" | 1513 | tristate "ST ASC serial port support" |
1514 | select SERIAL_CORE | 1514 | select SERIAL_CORE |
1515 | depends on ARM || COMPILE_TEST | ||
1515 | help | 1516 | help |
1516 | This driver is for the on-chip Asychronous Serial Controller on | 1517 | This driver is for the on-chip Asychronous Serial Controller on |
1517 | STMicroelectronics STi SoCs. | 1518 | STMicroelectronics STi SoCs. |
diff --git a/drivers/tty/serial/amba-pl010.c b/drivers/tty/serial/amba-pl010.c index 8b90f0b6dfdf..33bd8606be62 100644 --- a/drivers/tty/serial/amba-pl010.c +++ b/drivers/tty/serial/amba-pl010.c | |||
@@ -728,7 +728,6 @@ static int pl010_probe(struct amba_device *dev, const struct amba_id *id) | |||
728 | amba_set_drvdata(dev, uap); | 728 | amba_set_drvdata(dev, uap); |
729 | ret = uart_add_one_port(&amba_reg, &uap->port); | 729 | ret = uart_add_one_port(&amba_reg, &uap->port); |
730 | if (ret) { | 730 | if (ret) { |
731 | amba_set_drvdata(dev, NULL); | ||
732 | amba_ports[i] = NULL; | 731 | amba_ports[i] = NULL; |
733 | clk_put(uap->clk); | 732 | clk_put(uap->clk); |
734 | unmap: | 733 | unmap: |
@@ -745,8 +744,6 @@ static int pl010_remove(struct amba_device *dev) | |||
745 | struct uart_amba_port *uap = amba_get_drvdata(dev); | 744 | struct uart_amba_port *uap = amba_get_drvdata(dev); |
746 | int i; | 745 | int i; |
747 | 746 | ||
748 | amba_set_drvdata(dev, NULL); | ||
749 | |||
750 | uart_remove_one_port(&amba_reg, &uap->port); | 747 | uart_remove_one_port(&amba_reg, &uap->port); |
751 | 748 | ||
752 | for (i = 0; i < ARRAY_SIZE(amba_ports); i++) | 749 | for (i = 0; i < ARRAY_SIZE(amba_ports); i++) |
diff --git a/drivers/tty/serial/amba-pl011.c b/drivers/tty/serial/amba-pl011.c index aaa22867e656..7203864992a5 100644 --- a/drivers/tty/serial/amba-pl011.c +++ b/drivers/tty/serial/amba-pl011.c | |||
@@ -2147,7 +2147,6 @@ static int pl011_probe(struct amba_device *dev, const struct amba_id *id) | |||
2147 | amba_set_drvdata(dev, uap); | 2147 | amba_set_drvdata(dev, uap); |
2148 | ret = uart_add_one_port(&amba_reg, &uap->port); | 2148 | ret = uart_add_one_port(&amba_reg, &uap->port); |
2149 | if (ret) { | 2149 | if (ret) { |
2150 | amba_set_drvdata(dev, NULL); | ||
2151 | amba_ports[i] = NULL; | 2150 | amba_ports[i] = NULL; |
2152 | pl011_dma_remove(uap); | 2151 | pl011_dma_remove(uap); |
2153 | } | 2152 | } |
@@ -2160,8 +2159,6 @@ static int pl011_remove(struct amba_device *dev) | |||
2160 | struct uart_amba_port *uap = amba_get_drvdata(dev); | 2159 | struct uart_amba_port *uap = amba_get_drvdata(dev); |
2161 | int i; | 2160 | int i; |
2162 | 2161 | ||
2163 | amba_set_drvdata(dev, NULL); | ||
2164 | |||
2165 | uart_remove_one_port(&amba_reg, &uap->port); | 2162 | uart_remove_one_port(&amba_reg, &uap->port); |
2166 | 2163 | ||
2167 | for (i = 0; i < ARRAY_SIZE(amba_ports); i++) | 2164 | for (i = 0; i < ARRAY_SIZE(amba_ports); i++) |
diff --git a/drivers/tty/serial/arc_uart.c b/drivers/tty/serial/arc_uart.c index 569872f4c9b8..c9f5c9dcc15c 100644 --- a/drivers/tty/serial/arc_uart.c +++ b/drivers/tty/serial/arc_uart.c | |||
@@ -533,7 +533,7 @@ arc_uart_init_one(struct platform_device *pdev, int dev_id) | |||
533 | unsigned long *plat_data; | 533 | unsigned long *plat_data; |
534 | struct arc_uart_port *uart = &arc_uart_ports[dev_id]; | 534 | struct arc_uart_port *uart = &arc_uart_ports[dev_id]; |
535 | 535 | ||
536 | plat_data = (unsigned long *)dev_get_platdata(&pdev->dev); | 536 | plat_data = dev_get_platdata(&pdev->dev); |
537 | if (!plat_data) | 537 | if (!plat_data) |
538 | return -ENODEV; | 538 | return -ENODEV; |
539 | 539 | ||
diff --git a/drivers/tty/serial/atmel_serial.c b/drivers/tty/serial/atmel_serial.c index 6b0f75eac8a2..c7d99af46a96 100644 --- a/drivers/tty/serial/atmel_serial.c +++ b/drivers/tty/serial/atmel_serial.c | |||
@@ -99,6 +99,7 @@ static void atmel_stop_rx(struct uart_port *port); | |||
99 | #define UART_PUT_RTOR(port,v) __raw_writel(v, (port)->membase + ATMEL_US_RTOR) | 99 | #define UART_PUT_RTOR(port,v) __raw_writel(v, (port)->membase + ATMEL_US_RTOR) |
100 | #define UART_PUT_TTGR(port, v) __raw_writel(v, (port)->membase + ATMEL_US_TTGR) | 100 | #define UART_PUT_TTGR(port, v) __raw_writel(v, (port)->membase + ATMEL_US_TTGR) |
101 | #define UART_GET_IP_NAME(port) __raw_readl((port)->membase + ATMEL_US_NAME) | 101 | #define UART_GET_IP_NAME(port) __raw_readl((port)->membase + ATMEL_US_NAME) |
102 | #define UART_GET_IP_VERSION(port) __raw_readl((port)->membase + ATMEL_US_VERSION) | ||
102 | 103 | ||
103 | /* PDC registers */ | 104 | /* PDC registers */ |
104 | #define UART_PUT_PTCR(port,v) __raw_writel(v, (port)->membase + ATMEL_PDC_PTCR) | 105 | #define UART_PUT_PTCR(port,v) __raw_writel(v, (port)->membase + ATMEL_PDC_PTCR) |
@@ -1503,6 +1504,7 @@ static void atmel_get_ip_name(struct uart_port *port) | |||
1503 | { | 1504 | { |
1504 | struct atmel_uart_port *atmel_port = to_atmel_uart_port(port); | 1505 | struct atmel_uart_port *atmel_port = to_atmel_uart_port(port); |
1505 | int name = UART_GET_IP_NAME(port); | 1506 | int name = UART_GET_IP_NAME(port); |
1507 | u32 version; | ||
1506 | int usart, uart; | 1508 | int usart, uart; |
1507 | /* usart and uart ascii */ | 1509 | /* usart and uart ascii */ |
1508 | usart = 0x55534152; | 1510 | usart = 0x55534152; |
@@ -1517,7 +1519,22 @@ static void atmel_get_ip_name(struct uart_port *port) | |||
1517 | dev_dbg(port->dev, "This is uart\n"); | 1519 | dev_dbg(port->dev, "This is uart\n"); |
1518 | atmel_port->is_usart = false; | 1520 | atmel_port->is_usart = false; |
1519 | } else { | 1521 | } else { |
1520 | dev_err(port->dev, "Not supported ip name, set to uart\n"); | 1522 | /* fallback for older SoCs: use version field */ |
1523 | version = UART_GET_IP_VERSION(port); | ||
1524 | switch (version) { | ||
1525 | case 0x302: | ||
1526 | case 0x10213: | ||
1527 | dev_dbg(port->dev, "This version is usart\n"); | ||
1528 | atmel_port->is_usart = true; | ||
1529 | break; | ||
1530 | case 0x203: | ||
1531 | case 0x10202: | ||
1532 | dev_dbg(port->dev, "This version is uart\n"); | ||
1533 | atmel_port->is_usart = false; | ||
1534 | break; | ||
1535 | default: | ||
1536 | dev_err(port->dev, "Not supported ip name nor version, set to uart\n"); | ||
1537 | } | ||
1521 | } | 1538 | } |
1522 | } | 1539 | } |
1523 | 1540 | ||
diff --git a/drivers/tty/serial/bfin_sport_uart.c b/drivers/tty/serial/bfin_sport_uart.c index 87636cc61a21..4f229703328b 100644 --- a/drivers/tty/serial/bfin_sport_uart.c +++ b/drivers/tty/serial/bfin_sport_uart.c | |||
@@ -766,9 +766,8 @@ static int sport_uart_probe(struct platform_device *pdev) | |||
766 | return -ENOMEM; | 766 | return -ENOMEM; |
767 | } | 767 | } |
768 | 768 | ||
769 | ret = peripheral_request_list( | 769 | ret = peripheral_request_list(dev_get_platdata(&pdev->dev), |
770 | (unsigned short *)dev_get_platdata(&pdev->dev), | 770 | DRV_NAME); |
771 | DRV_NAME); | ||
772 | if (ret) { | 771 | if (ret) { |
773 | dev_err(&pdev->dev, | 772 | dev_err(&pdev->dev, |
774 | "Fail to request SPORT peripherals\n"); | 773 | "Fail to request SPORT peripherals\n"); |
@@ -844,8 +843,7 @@ static int sport_uart_probe(struct platform_device *pdev) | |||
844 | out_error_unmap: | 843 | out_error_unmap: |
845 | iounmap(sport->port.membase); | 844 | iounmap(sport->port.membase); |
846 | out_error_free_peripherals: | 845 | out_error_free_peripherals: |
847 | peripheral_free_list( | 846 | peripheral_free_list(dev_get_platdata(&pdev->dev)); |
848 | (unsigned short *)dev_get_platdata(&pdev->dev)); | ||
849 | out_error_free_mem: | 847 | out_error_free_mem: |
850 | kfree(sport); | 848 | kfree(sport); |
851 | bfin_sport_uart_ports[pdev->id] = NULL; | 849 | bfin_sport_uart_ports[pdev->id] = NULL; |
@@ -864,8 +862,7 @@ static int sport_uart_remove(struct platform_device *pdev) | |||
864 | if (sport) { | 862 | if (sport) { |
865 | uart_remove_one_port(&sport_uart_reg, &sport->port); | 863 | uart_remove_one_port(&sport_uart_reg, &sport->port); |
866 | iounmap(sport->port.membase); | 864 | iounmap(sport->port.membase); |
867 | peripheral_free_list( | 865 | peripheral_free_list(dev_get_platdata(&pdev->dev)); |
868 | (unsigned short *)dev_get_platdata(&pdev->dev)); | ||
869 | kfree(sport); | 866 | kfree(sport); |
870 | bfin_sport_uart_ports[pdev->id] = NULL; | 867 | bfin_sport_uart_ports[pdev->id] = NULL; |
871 | } | 868 | } |
diff --git a/drivers/tty/serial/bfin_uart.c b/drivers/tty/serial/bfin_uart.c index 3c75e8e04028..869ceba2ec57 100644 --- a/drivers/tty/serial/bfin_uart.c +++ b/drivers/tty/serial/bfin_uart.c | |||
@@ -680,7 +680,7 @@ static int bfin_serial_startup(struct uart_port *port) | |||
680 | default: | 680 | default: |
681 | uart_dma_ch_rx = uart_dma_ch_tx = 0; | 681 | uart_dma_ch_rx = uart_dma_ch_tx = 0; |
682 | break; | 682 | break; |
683 | }; | 683 | } |
684 | 684 | ||
685 | if (uart_dma_ch_rx && | 685 | if (uart_dma_ch_rx && |
686 | request_dma(uart_dma_ch_rx, "BFIN_UART_RX") < 0) { | 686 | request_dma(uart_dma_ch_rx, "BFIN_UART_RX") < 0) { |
@@ -726,7 +726,7 @@ static int bfin_serial_startup(struct uart_port *port) | |||
726 | #ifdef CONFIG_SERIAL_BFIN_HARD_CTSRTS | 726 | #ifdef CONFIG_SERIAL_BFIN_HARD_CTSRTS |
727 | if (uart->cts_pin >= 0) { | 727 | if (uart->cts_pin >= 0) { |
728 | if (request_irq(uart->status_irq, bfin_serial_mctrl_cts_int, | 728 | if (request_irq(uart->status_irq, bfin_serial_mctrl_cts_int, |
729 | IRQF_DISABLED, "BFIN_UART_MODEM_STATUS", uart)) { | 729 | 0, "BFIN_UART_MODEM_STATUS", uart)) { |
730 | uart->cts_pin = -1; | 730 | uart->cts_pin = -1; |
731 | dev_info(port->dev, "Unable to attach BlackFin UART Modem Status interrupt.\n"); | 731 | dev_info(port->dev, "Unable to attach BlackFin UART Modem Status interrupt.\n"); |
732 | } | 732 | } |
@@ -765,7 +765,7 @@ static void bfin_serial_shutdown(struct uart_port *port) | |||
765 | break; | 765 | break; |
766 | default: | 766 | default: |
767 | break; | 767 | break; |
768 | }; | 768 | } |
769 | #endif | 769 | #endif |
770 | free_irq(uart->rx_irq, uart); | 770 | free_irq(uart->rx_irq, uart); |
771 | free_irq(uart->tx_irq, uart); | 771 | free_irq(uart->tx_irq, uart); |
@@ -1240,7 +1240,7 @@ static int bfin_serial_probe(struct platform_device *pdev) | |||
1240 | */ | 1240 | */ |
1241 | #endif | 1241 | #endif |
1242 | ret = peripheral_request_list( | 1242 | ret = peripheral_request_list( |
1243 | (unsigned short *)dev_get_platdata(&pdev->dev), | 1243 | dev_get_platdata(&pdev->dev), |
1244 | DRIVER_NAME); | 1244 | DRIVER_NAME); |
1245 | if (ret) { | 1245 | if (ret) { |
1246 | dev_err(&pdev->dev, | 1246 | dev_err(&pdev->dev, |
@@ -1358,8 +1358,7 @@ static int bfin_serial_probe(struct platform_device *pdev) | |||
1358 | out_error_unmap: | 1358 | out_error_unmap: |
1359 | iounmap(uart->port.membase); | 1359 | iounmap(uart->port.membase); |
1360 | out_error_free_peripherals: | 1360 | out_error_free_peripherals: |
1361 | peripheral_free_list( | 1361 | peripheral_free_list(dev_get_platdata(&pdev->dev)); |
1362 | (unsigned short *)dev_get_platdata(&pdev->dev)); | ||
1363 | out_error_free_mem: | 1362 | out_error_free_mem: |
1364 | kfree(uart); | 1363 | kfree(uart); |
1365 | bfin_serial_ports[pdev->id] = NULL; | 1364 | bfin_serial_ports[pdev->id] = NULL; |
@@ -1377,8 +1376,7 @@ static int bfin_serial_remove(struct platform_device *pdev) | |||
1377 | if (uart) { | 1376 | if (uart) { |
1378 | uart_remove_one_port(&bfin_serial_reg, &uart->port); | 1377 | uart_remove_one_port(&bfin_serial_reg, &uart->port); |
1379 | iounmap(uart->port.membase); | 1378 | iounmap(uart->port.membase); |
1380 | peripheral_free_list( | 1379 | peripheral_free_list(dev_get_platdata(&pdev->dev)); |
1381 | (unsigned short *)dev_get_platdata(&pdev->dev)); | ||
1382 | kfree(uart); | 1380 | kfree(uart); |
1383 | bfin_serial_ports[pdev->id] = NULL; | 1381 | bfin_serial_ports[pdev->id] = NULL; |
1384 | } | 1382 | } |
@@ -1432,8 +1430,8 @@ static int bfin_earlyprintk_probe(struct platform_device *pdev) | |||
1432 | return -ENOENT; | 1430 | return -ENOENT; |
1433 | } | 1431 | } |
1434 | 1432 | ||
1435 | ret = peripheral_request_list( | 1433 | ret = peripheral_request_list(dev_get_platdata(&pdev->dev), |
1436 | (unsigned short *)dev_get_platdata(&pdev->dev), DRIVER_NAME); | 1434 | DRIVER_NAME); |
1437 | if (ret) { | 1435 | if (ret) { |
1438 | dev_err(&pdev->dev, | 1436 | dev_err(&pdev->dev, |
1439 | "fail to request bfin serial peripherals\n"); | 1437 | "fail to request bfin serial peripherals\n"); |
@@ -1463,8 +1461,7 @@ static int bfin_earlyprintk_probe(struct platform_device *pdev) | |||
1463 | return 0; | 1461 | return 0; |
1464 | 1462 | ||
1465 | out_error_free_peripherals: | 1463 | out_error_free_peripherals: |
1466 | peripheral_free_list( | 1464 | peripheral_free_list(dev_get_platdata(&pdev->dev)); |
1467 | (unsigned short *)dev_get_platdata(&pdev->dev)); | ||
1468 | 1465 | ||
1469 | return ret; | 1466 | return ret; |
1470 | } | 1467 | } |
diff --git a/drivers/tty/serial/clps711x.c b/drivers/tty/serial/clps711x.c index 7e4e4088471c..8d0b994357c8 100644 --- a/drivers/tty/serial/clps711x.c +++ b/drivers/tty/serial/clps711x.c | |||
@@ -459,7 +459,6 @@ static int uart_clps711x_probe(struct platform_device *pdev) | |||
459 | ret = uart_register_driver(&s->uart); | 459 | ret = uart_register_driver(&s->uart); |
460 | if (ret) { | 460 | if (ret) { |
461 | dev_err(&pdev->dev, "Registering UART driver failed\n"); | 461 | dev_err(&pdev->dev, "Registering UART driver failed\n"); |
462 | devm_clk_put(&pdev->dev, s->uart_clk); | ||
463 | return ret; | 462 | return ret; |
464 | } | 463 | } |
465 | 464 | ||
@@ -487,7 +486,6 @@ static int uart_clps711x_remove(struct platform_device *pdev) | |||
487 | for (i = 0; i < UART_CLPS711X_NR; i++) | 486 | for (i = 0; i < UART_CLPS711X_NR; i++) |
488 | uart_remove_one_port(&s->uart, &s->port[i]); | 487 | uart_remove_one_port(&s->uart, &s->port[i]); |
489 | 488 | ||
490 | devm_clk_put(&pdev->dev, s->uart_clk); | ||
491 | uart_unregister_driver(&s->uart); | 489 | uart_unregister_driver(&s->uart); |
492 | 490 | ||
493 | return 0; | 491 | return 0; |
diff --git a/drivers/tty/serial/cpm_uart/cpm_uart_core.c b/drivers/tty/serial/cpm_uart/cpm_uart_core.c index 1a535f70dc41..7d76214612c7 100644 --- a/drivers/tty/serial/cpm_uart/cpm_uart_core.c +++ b/drivers/tty/serial/cpm_uart/cpm_uart_core.c | |||
@@ -41,6 +41,8 @@ | |||
41 | #include <linux/bootmem.h> | 41 | #include <linux/bootmem.h> |
42 | #include <linux/dma-mapping.h> | 42 | #include <linux/dma-mapping.h> |
43 | #include <linux/fs_uart_pd.h> | 43 | #include <linux/fs_uart_pd.h> |
44 | #include <linux/of_address.h> | ||
45 | #include <linux/of_irq.h> | ||
44 | #include <linux/of_platform.h> | 46 | #include <linux/of_platform.h> |
45 | #include <linux/gpio.h> | 47 | #include <linux/gpio.h> |
46 | #include <linux/of_gpio.h> | 48 | #include <linux/of_gpio.h> |
@@ -1207,7 +1209,7 @@ static int cpm_uart_init_port(struct device_node *np, | |||
1207 | pinfo->port.fifosize = pinfo->tx_nrfifos * pinfo->tx_fifosize; | 1209 | pinfo->port.fifosize = pinfo->tx_nrfifos * pinfo->tx_fifosize; |
1208 | spin_lock_init(&pinfo->port.lock); | 1210 | spin_lock_init(&pinfo->port.lock); |
1209 | 1211 | ||
1210 | pinfo->port.irq = of_irq_to_resource(np, 0, NULL); | 1212 | pinfo->port.irq = irq_of_parse_and_map(np, 0); |
1211 | if (pinfo->port.irq == NO_IRQ) { | 1213 | if (pinfo->port.irq == NO_IRQ) { |
1212 | ret = -EINVAL; | 1214 | ret = -EINVAL; |
1213 | goto out_pram; | 1215 | goto out_pram; |
diff --git a/drivers/tty/serial/cpm_uart/cpm_uart_cpm1.c b/drivers/tty/serial/cpm_uart/cpm_uart_cpm1.c index 18f79575894a..527a969b0952 100644 --- a/drivers/tty/serial/cpm_uart/cpm_uart_cpm1.c +++ b/drivers/tty/serial/cpm_uart/cpm_uart_cpm1.c | |||
@@ -45,6 +45,7 @@ | |||
45 | #include <linux/kernel.h> | 45 | #include <linux/kernel.h> |
46 | 46 | ||
47 | #include <linux/of.h> | 47 | #include <linux/of.h> |
48 | #include <linux/of_address.h> | ||
48 | 49 | ||
49 | #include "cpm_uart.h" | 50 | #include "cpm_uart.h" |
50 | 51 | ||
diff --git a/drivers/tty/serial/ifx6x60.c b/drivers/tty/serial/ifx6x60.c index af286e6713eb..590390970996 100644 --- a/drivers/tty/serial/ifx6x60.c +++ b/drivers/tty/serial/ifx6x60.c | |||
@@ -1008,7 +1008,7 @@ static int ifx_spi_spi_probe(struct spi_device *spi) | |||
1008 | return -ENODEV; | 1008 | return -ENODEV; |
1009 | } | 1009 | } |
1010 | 1010 | ||
1011 | pl_data = (struct ifx_modem_platform_data *)dev_get_platdata(&spi->dev); | 1011 | pl_data = dev_get_platdata(&spi->dev); |
1012 | if (!pl_data) { | 1012 | if (!pl_data) { |
1013 | dev_err(&spi->dev, "missing platform data!"); | 1013 | dev_err(&spi->dev, "missing platform data!"); |
1014 | return -ENODEV; | 1014 | return -ENODEV; |
diff --git a/drivers/tty/serial/imx.c b/drivers/tty/serial/imx.c index 042aa077b5b3..b2cfdb661947 100644 --- a/drivers/tty/serial/imx.c +++ b/drivers/tty/serial/imx.c | |||
@@ -223,8 +223,7 @@ struct imx_port { | |||
223 | struct dma_chan *dma_chan_rx, *dma_chan_tx; | 223 | struct dma_chan *dma_chan_rx, *dma_chan_tx; |
224 | struct scatterlist rx_sgl, tx_sgl[2]; | 224 | struct scatterlist rx_sgl, tx_sgl[2]; |
225 | void *rx_buf; | 225 | void *rx_buf; |
226 | unsigned int rx_bytes, tx_bytes; | 226 | unsigned int tx_bytes; |
227 | struct work_struct tsk_dma_rx, tsk_dma_tx; | ||
228 | unsigned int dma_tx_nents; | 227 | unsigned int dma_tx_nents; |
229 | wait_queue_head_t dma_wait; | 228 | wait_queue_head_t dma_wait; |
230 | }; | 229 | }; |
@@ -505,34 +504,25 @@ static void dma_tx_callback(void *data) | |||
505 | dev_dbg(sport->port.dev, "exit in %s.\n", __func__); | 504 | dev_dbg(sport->port.dev, "exit in %s.\n", __func__); |
506 | return; | 505 | return; |
507 | } | 506 | } |
508 | |||
509 | schedule_work(&sport->tsk_dma_tx); | ||
510 | } | 507 | } |
511 | 508 | ||
512 | static void dma_tx_work(struct work_struct *w) | 509 | static void imx_dma_tx(struct imx_port *sport) |
513 | { | 510 | { |
514 | struct imx_port *sport = container_of(w, struct imx_port, tsk_dma_tx); | ||
515 | struct circ_buf *xmit = &sport->port.state->xmit; | 511 | struct circ_buf *xmit = &sport->port.state->xmit; |
516 | struct scatterlist *sgl = sport->tx_sgl; | 512 | struct scatterlist *sgl = sport->tx_sgl; |
517 | struct dma_async_tx_descriptor *desc; | 513 | struct dma_async_tx_descriptor *desc; |
518 | struct dma_chan *chan = sport->dma_chan_tx; | 514 | struct dma_chan *chan = sport->dma_chan_tx; |
519 | struct device *dev = sport->port.dev; | 515 | struct device *dev = sport->port.dev; |
520 | enum dma_status status; | 516 | enum dma_status status; |
521 | unsigned long flags; | ||
522 | int ret; | 517 | int ret; |
523 | 518 | ||
524 | status = chan->device->device_tx_status(chan, (dma_cookie_t)0, NULL); | 519 | status = dmaengine_tx_status(chan, (dma_cookie_t)0, NULL); |
525 | if (DMA_IN_PROGRESS == status) | 520 | if (DMA_IN_PROGRESS == status) |
526 | return; | 521 | return; |
527 | 522 | ||
528 | spin_lock_irqsave(&sport->port.lock, flags); | ||
529 | sport->tx_bytes = uart_circ_chars_pending(xmit); | 523 | sport->tx_bytes = uart_circ_chars_pending(xmit); |
530 | if (sport->tx_bytes == 0) { | ||
531 | spin_unlock_irqrestore(&sport->port.lock, flags); | ||
532 | return; | ||
533 | } | ||
534 | 524 | ||
535 | if (xmit->tail > xmit->head) { | 525 | if (xmit->tail > xmit->head && xmit->head > 0) { |
536 | sport->dma_tx_nents = 2; | 526 | sport->dma_tx_nents = 2; |
537 | sg_init_table(sgl, 2); | 527 | sg_init_table(sgl, 2); |
538 | sg_set_buf(sgl, xmit->buf + xmit->tail, | 528 | sg_set_buf(sgl, xmit->buf + xmit->tail, |
@@ -542,7 +532,6 @@ static void dma_tx_work(struct work_struct *w) | |||
542 | sport->dma_tx_nents = 1; | 532 | sport->dma_tx_nents = 1; |
543 | sg_init_one(sgl, xmit->buf + xmit->tail, sport->tx_bytes); | 533 | sg_init_one(sgl, xmit->buf + xmit->tail, sport->tx_bytes); |
544 | } | 534 | } |
545 | spin_unlock_irqrestore(&sport->port.lock, flags); | ||
546 | 535 | ||
547 | ret = dma_map_sg(dev, sgl, sport->dma_tx_nents, DMA_TO_DEVICE); | 536 | ret = dma_map_sg(dev, sgl, sport->dma_tx_nents, DMA_TO_DEVICE); |
548 | if (ret == 0) { | 537 | if (ret == 0) { |
@@ -609,11 +598,7 @@ static void imx_start_tx(struct uart_port *port) | |||
609 | } | 598 | } |
610 | 599 | ||
611 | if (sport->dma_is_enabled) { | 600 | if (sport->dma_is_enabled) { |
612 | /* | 601 | imx_dma_tx(sport); |
613 | * We may in the interrupt context, so arise a work_struct to | ||
614 | * do the real job. | ||
615 | */ | ||
616 | schedule_work(&sport->tsk_dma_tx); | ||
617 | return; | 602 | return; |
618 | } | 603 | } |
619 | 604 | ||
@@ -732,6 +717,7 @@ out: | |||
732 | return IRQ_HANDLED; | 717 | return IRQ_HANDLED; |
733 | } | 718 | } |
734 | 719 | ||
720 | static int start_rx_dma(struct imx_port *sport); | ||
735 | /* | 721 | /* |
736 | * If the RXFIFO is filled with some data, and then we | 722 | * If the RXFIFO is filled with some data, and then we |
737 | * arise a DMA operation to receive them. | 723 | * arise a DMA operation to receive them. |
@@ -750,7 +736,7 @@ static void imx_dma_rxint(struct imx_port *sport) | |||
750 | writel(temp, sport->port.membase + UCR1); | 736 | writel(temp, sport->port.membase + UCR1); |
751 | 737 | ||
752 | /* tell the DMA to receive the data. */ | 738 | /* tell the DMA to receive the data. */ |
753 | schedule_work(&sport->tsk_dma_rx); | 739 | start_rx_dma(sport); |
754 | } | 740 | } |
755 | } | 741 | } |
756 | 742 | ||
@@ -795,8 +781,15 @@ static irqreturn_t imx_int(int irq, void *dev_id) | |||
795 | static unsigned int imx_tx_empty(struct uart_port *port) | 781 | static unsigned int imx_tx_empty(struct uart_port *port) |
796 | { | 782 | { |
797 | struct imx_port *sport = (struct imx_port *)port; | 783 | struct imx_port *sport = (struct imx_port *)port; |
784 | unsigned int ret; | ||
785 | |||
786 | ret = (readl(sport->port.membase + USR2) & USR2_TXDC) ? TIOCSER_TEMT : 0; | ||
798 | 787 | ||
799 | return (readl(sport->port.membase + USR2) & USR2_TXDC) ? TIOCSER_TEMT : 0; | 788 | /* If the TX DMA is working, return 0. */ |
789 | if (sport->dma_is_enabled && sport->dma_is_txing) | ||
790 | ret = 0; | ||
791 | |||
792 | return ret; | ||
800 | } | 793 | } |
801 | 794 | ||
802 | /* | 795 | /* |
@@ -865,22 +858,6 @@ static int imx_setup_ufcr(struct imx_port *sport, unsigned int mode) | |||
865 | } | 858 | } |
866 | 859 | ||
867 | #define RX_BUF_SIZE (PAGE_SIZE) | 860 | #define RX_BUF_SIZE (PAGE_SIZE) |
868 | static int start_rx_dma(struct imx_port *sport); | ||
869 | static void dma_rx_work(struct work_struct *w) | ||
870 | { | ||
871 | struct imx_port *sport = container_of(w, struct imx_port, tsk_dma_rx); | ||
872 | struct tty_port *port = &sport->port.state->port; | ||
873 | |||
874 | if (sport->rx_bytes) { | ||
875 | tty_insert_flip_string(port, sport->rx_buf, sport->rx_bytes); | ||
876 | tty_flip_buffer_push(port); | ||
877 | sport->rx_bytes = 0; | ||
878 | } | ||
879 | |||
880 | if (sport->dma_is_rxing) | ||
881 | start_rx_dma(sport); | ||
882 | } | ||
883 | |||
884 | static void imx_rx_dma_done(struct imx_port *sport) | 861 | static void imx_rx_dma_done(struct imx_port *sport) |
885 | { | 862 | { |
886 | unsigned long temp; | 863 | unsigned long temp; |
@@ -912,6 +889,7 @@ static void dma_rx_callback(void *data) | |||
912 | struct imx_port *sport = data; | 889 | struct imx_port *sport = data; |
913 | struct dma_chan *chan = sport->dma_chan_rx; | 890 | struct dma_chan *chan = sport->dma_chan_rx; |
914 | struct scatterlist *sgl = &sport->rx_sgl; | 891 | struct scatterlist *sgl = &sport->rx_sgl; |
892 | struct tty_port *port = &sport->port.state->port; | ||
915 | struct dma_tx_state state; | 893 | struct dma_tx_state state; |
916 | enum dma_status status; | 894 | enum dma_status status; |
917 | unsigned int count; | 895 | unsigned int count; |
@@ -919,13 +897,15 @@ static void dma_rx_callback(void *data) | |||
919 | /* unmap it first */ | 897 | /* unmap it first */ |
920 | dma_unmap_sg(sport->port.dev, sgl, 1, DMA_FROM_DEVICE); | 898 | dma_unmap_sg(sport->port.dev, sgl, 1, DMA_FROM_DEVICE); |
921 | 899 | ||
922 | status = chan->device->device_tx_status(chan, (dma_cookie_t)0, &state); | 900 | status = dmaengine_tx_status(chan, (dma_cookie_t)0, &state); |
923 | count = RX_BUF_SIZE - state.residue; | 901 | count = RX_BUF_SIZE - state.residue; |
924 | dev_dbg(sport->port.dev, "We get %d bytes.\n", count); | 902 | dev_dbg(sport->port.dev, "We get %d bytes.\n", count); |
925 | 903 | ||
926 | if (count) { | 904 | if (count) { |
927 | sport->rx_bytes = count; | 905 | tty_insert_flip_string(port, sport->rx_buf, count); |
928 | schedule_work(&sport->tsk_dma_rx); | 906 | tty_flip_buffer_push(port); |
907 | |||
908 | start_rx_dma(sport); | ||
929 | } else | 909 | } else |
930 | imx_rx_dma_done(sport); | 910 | imx_rx_dma_done(sport); |
931 | } | 911 | } |
@@ -1007,7 +987,6 @@ static int imx_uart_dma_init(struct imx_port *sport) | |||
1007 | ret = -ENOMEM; | 987 | ret = -ENOMEM; |
1008 | goto err; | 988 | goto err; |
1009 | } | 989 | } |
1010 | sport->rx_bytes = 0; | ||
1011 | 990 | ||
1012 | /* Prepare for TX : */ | 991 | /* Prepare for TX : */ |
1013 | sport->dma_chan_tx = dma_request_slave_channel(dev, "tx"); | 992 | sport->dma_chan_tx = dma_request_slave_channel(dev, "tx"); |
@@ -1038,11 +1017,7 @@ err: | |||
1038 | static void imx_enable_dma(struct imx_port *sport) | 1017 | static void imx_enable_dma(struct imx_port *sport) |
1039 | { | 1018 | { |
1040 | unsigned long temp; | 1019 | unsigned long temp; |
1041 | struct tty_port *port = &sport->port.state->port; | ||
1042 | 1020 | ||
1043 | port->low_latency = 1; | ||
1044 | INIT_WORK(&sport->tsk_dma_tx, dma_tx_work); | ||
1045 | INIT_WORK(&sport->tsk_dma_rx, dma_rx_work); | ||
1046 | init_waitqueue_head(&sport->dma_wait); | 1021 | init_waitqueue_head(&sport->dma_wait); |
1047 | 1022 | ||
1048 | /* set UCR1 */ | 1023 | /* set UCR1 */ |
@@ -1063,7 +1038,6 @@ static void imx_enable_dma(struct imx_port *sport) | |||
1063 | static void imx_disable_dma(struct imx_port *sport) | 1038 | static void imx_disable_dma(struct imx_port *sport) |
1064 | { | 1039 | { |
1065 | unsigned long temp; | 1040 | unsigned long temp; |
1066 | struct tty_port *port = &sport->port.state->port; | ||
1067 | 1041 | ||
1068 | /* clear UCR1 */ | 1042 | /* clear UCR1 */ |
1069 | temp = readl(sport->port.membase + UCR1); | 1043 | temp = readl(sport->port.membase + UCR1); |
@@ -1081,7 +1055,6 @@ static void imx_disable_dma(struct imx_port *sport) | |||
1081 | writel(temp, sport->port.membase + UCR4); | 1055 | writel(temp, sport->port.membase + UCR4); |
1082 | 1056 | ||
1083 | sport->dma_is_enabled = 0; | 1057 | sport->dma_is_enabled = 0; |
1084 | port->low_latency = 0; | ||
1085 | } | 1058 | } |
1086 | 1059 | ||
1087 | /* half the RX buffer size */ | 1060 | /* half the RX buffer size */ |
@@ -1303,6 +1276,16 @@ static void imx_shutdown(struct uart_port *port) | |||
1303 | clk_disable_unprepare(sport->clk_ipg); | 1276 | clk_disable_unprepare(sport->clk_ipg); |
1304 | } | 1277 | } |
1305 | 1278 | ||
1279 | static void imx_flush_buffer(struct uart_port *port) | ||
1280 | { | ||
1281 | struct imx_port *sport = (struct imx_port *)port; | ||
1282 | |||
1283 | if (sport->dma_is_enabled) { | ||
1284 | sport->tx_bytes = 0; | ||
1285 | dmaengine_terminate_all(sport->dma_chan_tx); | ||
1286 | } | ||
1287 | } | ||
1288 | |||
1306 | static void | 1289 | static void |
1307 | imx_set_termios(struct uart_port *port, struct ktermios *termios, | 1290 | imx_set_termios(struct uart_port *port, struct ktermios *termios, |
1308 | struct ktermios *old) | 1291 | struct ktermios *old) |
@@ -1539,7 +1522,7 @@ imx_verify_port(struct uart_port *port, struct serial_struct *ser) | |||
1539 | ret = -EINVAL; | 1522 | ret = -EINVAL; |
1540 | if (sport->port.uartclk / 16 != ser->baud_base) | 1523 | if (sport->port.uartclk / 16 != ser->baud_base) |
1541 | ret = -EINVAL; | 1524 | ret = -EINVAL; |
1542 | if ((void *)sport->port.mapbase != ser->iomem_base) | 1525 | if (sport->port.mapbase != (unsigned long)ser->iomem_base) |
1543 | ret = -EINVAL; | 1526 | ret = -EINVAL; |
1544 | if (sport->port.iobase != ser->port) | 1527 | if (sport->port.iobase != ser->port) |
1545 | ret = -EINVAL; | 1528 | ret = -EINVAL; |
@@ -1623,6 +1606,7 @@ static struct uart_ops imx_pops = { | |||
1623 | .break_ctl = imx_break_ctl, | 1606 | .break_ctl = imx_break_ctl, |
1624 | .startup = imx_startup, | 1607 | .startup = imx_startup, |
1625 | .shutdown = imx_shutdown, | 1608 | .shutdown = imx_shutdown, |
1609 | .flush_buffer = imx_flush_buffer, | ||
1626 | .set_termios = imx_set_termios, | 1610 | .set_termios = imx_set_termios, |
1627 | .type = imx_type, | 1611 | .type = imx_type, |
1628 | .release_port = imx_release_port, | 1612 | .release_port = imx_release_port, |
diff --git a/drivers/tty/serial/ip22zilog.c b/drivers/tty/serial/ip22zilog.c index cb3c81eb0996..1d9420548e16 100644 --- a/drivers/tty/serial/ip22zilog.c +++ b/drivers/tty/serial/ip22zilog.c | |||
@@ -832,7 +832,7 @@ ip22zilog_convert_to_zs(struct uart_ip22zilog_port *up, unsigned int cflag, | |||
832 | up->curregs[5] |= Tx8; | 832 | up->curregs[5] |= Tx8; |
833 | up->parity_mask = 0xff; | 833 | up->parity_mask = 0xff; |
834 | break; | 834 | break; |
835 | }; | 835 | } |
836 | up->curregs[4] &= ~0x0c; | 836 | up->curregs[4] &= ~0x0c; |
837 | if (cflag & CSTOPB) | 837 | if (cflag & CSTOPB) |
838 | up->curregs[4] |= SB2; | 838 | up->curregs[4] |= SB2; |
diff --git a/drivers/tty/serial/max310x.c b/drivers/tty/serial/max310x.c index b2e707aa603a..8d71e4047bb3 100644 --- a/drivers/tty/serial/max310x.c +++ b/drivers/tty/serial/max310x.c | |||
@@ -690,7 +690,7 @@ static void max310x_handle_tx(struct uart_port *port) | |||
690 | max310x_port_write(port, MAX310X_THR_REG, | 690 | max310x_port_write(port, MAX310X_THR_REG, |
691 | xmit->buf[xmit->tail]); | 691 | xmit->buf[xmit->tail]); |
692 | xmit->tail = (xmit->tail + 1) & (UART_XMIT_SIZE - 1); | 692 | xmit->tail = (xmit->tail + 1) & (UART_XMIT_SIZE - 1); |
693 | }; | 693 | } |
694 | } | 694 | } |
695 | 695 | ||
696 | if (uart_circ_chars_pending(xmit) < WAKEUP_CHARS) | 696 | if (uart_circ_chars_pending(xmit) < WAKEUP_CHARS) |
diff --git a/drivers/tty/serial/mfd.c b/drivers/tty/serial/mfd.c index d3db042f649e..52c930fac210 100644 --- a/drivers/tty/serial/mfd.c +++ b/drivers/tty/serial/mfd.c | |||
@@ -293,7 +293,7 @@ static void serial_hsu_enable_ms(struct uart_port *port) | |||
293 | serial_out(up, UART_IER, up->ier); | 293 | serial_out(up, UART_IER, up->ier); |
294 | } | 294 | } |
295 | 295 | ||
296 | void hsu_dma_tx(struct uart_hsu_port *up) | 296 | static void hsu_dma_tx(struct uart_hsu_port *up) |
297 | { | 297 | { |
298 | struct circ_buf *xmit = &up->port.state->xmit; | 298 | struct circ_buf *xmit = &up->port.state->xmit; |
299 | struct hsu_dma_buffer *dbuf = &up->txbuf; | 299 | struct hsu_dma_buffer *dbuf = &up->txbuf; |
@@ -340,7 +340,8 @@ void hsu_dma_tx(struct uart_hsu_port *up) | |||
340 | } | 340 | } |
341 | 341 | ||
342 | /* The buffer is already cache coherent */ | 342 | /* The buffer is already cache coherent */ |
343 | void hsu_dma_start_rx_chan(struct hsu_dma_chan *rxc, struct hsu_dma_buffer *dbuf) | 343 | static void hsu_dma_start_rx_chan(struct hsu_dma_chan *rxc, |
344 | struct hsu_dma_buffer *dbuf) | ||
344 | { | 345 | { |
345 | dbuf->ofs = 0; | 346 | dbuf->ofs = 0; |
346 | 347 | ||
@@ -386,7 +387,8 @@ static void serial_hsu_stop_tx(struct uart_port *port) | |||
386 | 387 | ||
387 | /* This is always called in spinlock protected mode, so | 388 | /* This is always called in spinlock protected mode, so |
388 | * modify timeout timer is safe here */ | 389 | * modify timeout timer is safe here */ |
389 | void hsu_dma_rx(struct uart_hsu_port *up, u32 int_sts, unsigned long *flags) | 390 | static void hsu_dma_rx(struct uart_hsu_port *up, u32 int_sts, |
391 | unsigned long *flags) | ||
390 | { | 392 | { |
391 | struct hsu_dma_buffer *dbuf = &up->rxbuf; | 393 | struct hsu_dma_buffer *dbuf = &up->rxbuf; |
392 | struct hsu_dma_chan *chan = up->rxc; | 394 | struct hsu_dma_chan *chan = up->rxc; |
@@ -1183,7 +1185,7 @@ static struct console serial_hsu_console = { | |||
1183 | #define SERIAL_HSU_CONSOLE NULL | 1185 | #define SERIAL_HSU_CONSOLE NULL |
1184 | #endif | 1186 | #endif |
1185 | 1187 | ||
1186 | struct uart_ops serial_hsu_pops = { | 1188 | static struct uart_ops serial_hsu_pops = { |
1187 | .tx_empty = serial_hsu_tx_empty, | 1189 | .tx_empty = serial_hsu_tx_empty, |
1188 | .set_mctrl = serial_hsu_set_mctrl, | 1190 | .set_mctrl = serial_hsu_set_mctrl, |
1189 | .get_mctrl = serial_hsu_get_mctrl, | 1191 | .get_mctrl = serial_hsu_get_mctrl, |
@@ -1451,7 +1453,6 @@ static void serial_hsu_remove(struct pci_dev *pdev) | |||
1451 | uart_remove_one_port(&serial_hsu_reg, &up->port); | 1453 | uart_remove_one_port(&serial_hsu_reg, &up->port); |
1452 | } | 1454 | } |
1453 | 1455 | ||
1454 | pci_set_drvdata(pdev, NULL); | ||
1455 | free_irq(pdev->irq, priv); | 1456 | free_irq(pdev->irq, priv); |
1456 | pci_disable_device(pdev); | 1457 | pci_disable_device(pdev); |
1457 | } | 1458 | } |
@@ -1504,4 +1505,4 @@ module_init(hsu_pci_init); | |||
1504 | module_exit(hsu_pci_exit); | 1505 | module_exit(hsu_pci_exit); |
1505 | 1506 | ||
1506 | MODULE_LICENSE("GPL v2"); | 1507 | MODULE_LICENSE("GPL v2"); |
1507 | MODULE_ALIAS("platform:medfield-hsu"); | 1508 | MODULE_DEVICE_TABLE(pci, pci_ids); |
diff --git a/drivers/tty/serial/mpc52xx_uart.c b/drivers/tty/serial/mpc52xx_uart.c index 5be1df39f9f5..ec06505e3ae6 100644 --- a/drivers/tty/serial/mpc52xx_uart.c +++ b/drivers/tty/serial/mpc52xx_uart.c | |||
@@ -1301,7 +1301,6 @@ static struct uart_ops mpc52xx_uart_ops = { | |||
1301 | .shutdown = mpc52xx_uart_shutdown, | 1301 | .shutdown = mpc52xx_uart_shutdown, |
1302 | .set_termios = mpc52xx_uart_set_termios, | 1302 | .set_termios = mpc52xx_uart_set_termios, |
1303 | /* .pm = mpc52xx_uart_pm, Not supported yet */ | 1303 | /* .pm = mpc52xx_uart_pm, Not supported yet */ |
1304 | /* .set_wake = mpc52xx_uart_set_wake, Not supported yet */ | ||
1305 | .type = mpc52xx_uart_type, | 1304 | .type = mpc52xx_uart_type, |
1306 | .release_port = mpc52xx_uart_release_port, | 1305 | .release_port = mpc52xx_uart_release_port, |
1307 | .request_port = mpc52xx_uart_request_port, | 1306 | .request_port = mpc52xx_uart_request_port, |
@@ -1766,7 +1765,7 @@ mpc52xx_uart_of_remove(struct platform_device *op) | |||
1766 | static int | 1765 | static int |
1767 | mpc52xx_uart_of_suspend(struct platform_device *op, pm_message_t state) | 1766 | mpc52xx_uart_of_suspend(struct platform_device *op, pm_message_t state) |
1768 | { | 1767 | { |
1769 | struct uart_port *port = (struct uart_port *) platform_get_drvdata(op); | 1768 | struct uart_port *port = platform_get_drvdata(op); |
1770 | 1769 | ||
1771 | if (port) | 1770 | if (port) |
1772 | uart_suspend_port(&mpc52xx_uart_driver, port); | 1771 | uart_suspend_port(&mpc52xx_uart_driver, port); |
@@ -1777,7 +1776,7 @@ mpc52xx_uart_of_suspend(struct platform_device *op, pm_message_t state) | |||
1777 | static int | 1776 | static int |
1778 | mpc52xx_uart_of_resume(struct platform_device *op) | 1777 | mpc52xx_uart_of_resume(struct platform_device *op) |
1779 | { | 1778 | { |
1780 | struct uart_port *port = (struct uart_port *) platform_get_drvdata(op); | 1779 | struct uart_port *port = platform_get_drvdata(op); |
1781 | 1780 | ||
1782 | if (port) | 1781 | if (port) |
1783 | uart_resume_port(&mpc52xx_uart_driver, port); | 1782 | uart_resume_port(&mpc52xx_uart_driver, port); |
diff --git a/drivers/tty/serial/mpsc.c b/drivers/tty/serial/mpsc.c index 8d702677acc5..e30a3ca3cea3 100644 --- a/drivers/tty/serial/mpsc.c +++ b/drivers/tty/serial/mpsc.c | |||
@@ -2030,7 +2030,7 @@ static void mpsc_drv_get_platform_data(struct mpsc_port_info *pi, | |||
2030 | { | 2030 | { |
2031 | struct mpsc_pdata *pdata; | 2031 | struct mpsc_pdata *pdata; |
2032 | 2032 | ||
2033 | pdata = (struct mpsc_pdata *)dev_get_platdata(&pd->dev); | 2033 | pdata = dev_get_platdata(&pd->dev); |
2034 | 2034 | ||
2035 | pi->port.uartclk = pdata->brg_clk_freq; | 2035 | pi->port.uartclk = pdata->brg_clk_freq; |
2036 | pi->port.iotype = UPIO_MEM; | 2036 | pi->port.iotype = UPIO_MEM; |
diff --git a/drivers/tty/serial/mrst_max3110.c b/drivers/tty/serial/mrst_max3110.c index a67e7081f001..db0448ae59dc 100644 --- a/drivers/tty/serial/mrst_max3110.c +++ b/drivers/tty/serial/mrst_max3110.c | |||
@@ -43,6 +43,7 @@ | |||
43 | 43 | ||
44 | #include <linux/kthread.h> | 44 | #include <linux/kthread.h> |
45 | #include <linux/spi/spi.h> | 45 | #include <linux/spi/spi.h> |
46 | #include <linux/pm.h> | ||
46 | 47 | ||
47 | #include "mrst_max3110.h" | 48 | #include "mrst_max3110.h" |
48 | 49 | ||
@@ -61,6 +62,7 @@ struct uart_max3110 { | |||
61 | struct task_struct *main_thread; | 62 | struct task_struct *main_thread; |
62 | struct task_struct *read_thread; | 63 | struct task_struct *read_thread; |
63 | struct mutex thread_mutex; | 64 | struct mutex thread_mutex; |
65 | struct mutex io_mutex; | ||
64 | 66 | ||
65 | u32 baud; | 67 | u32 baud; |
66 | u16 cur_conf; | 68 | u16 cur_conf; |
@@ -90,6 +92,7 @@ static int max3110_write_then_read(struct uart_max3110 *max, | |||
90 | struct spi_transfer x; | 92 | struct spi_transfer x; |
91 | int ret; | 93 | int ret; |
92 | 94 | ||
95 | mutex_lock(&max->io_mutex); | ||
93 | spi_message_init(&message); | 96 | spi_message_init(&message); |
94 | memset(&x, 0, sizeof x); | 97 | memset(&x, 0, sizeof x); |
95 | x.len = len; | 98 | x.len = len; |
@@ -104,6 +107,7 @@ static int max3110_write_then_read(struct uart_max3110 *max, | |||
104 | 107 | ||
105 | /* Do the i/o */ | 108 | /* Do the i/o */ |
106 | ret = spi_sync(spi, &message); | 109 | ret = spi_sync(spi, &message); |
110 | mutex_unlock(&max->io_mutex); | ||
107 | return ret; | 111 | return ret; |
108 | } | 112 | } |
109 | 113 | ||
@@ -491,19 +495,9 @@ static int serial_m3110_startup(struct uart_port *port) | |||
491 | port->state->port.low_latency = 1; | 495 | port->state->port.low_latency = 1; |
492 | 496 | ||
493 | if (max->irq) { | 497 | if (max->irq) { |
494 | max->read_thread = NULL; | 498 | /* Enable RX IRQ only */ |
495 | ret = request_irq(max->irq, serial_m3110_irq, | 499 | config |= WC_RXA_IRQ_ENABLE; |
496 | IRQ_TYPE_EDGE_FALLING, "max3110", max); | 500 | } else { |
497 | if (ret) { | ||
498 | max->irq = 0; | ||
499 | pr_err(PR_FMT "unable to allocate IRQ, polling\n"); | ||
500 | } else { | ||
501 | /* Enable RX IRQ only */ | ||
502 | config |= WC_RXA_IRQ_ENABLE; | ||
503 | } | ||
504 | } | ||
505 | |||
506 | if (max->irq == 0) { | ||
507 | /* If IRQ is disabled, start a read thread for input data */ | 501 | /* If IRQ is disabled, start a read thread for input data */ |
508 | max->read_thread = | 502 | max->read_thread = |
509 | kthread_run(max3110_read_thread, max, "max3110_read"); | 503 | kthread_run(max3110_read_thread, max, "max3110_read"); |
@@ -517,8 +511,6 @@ static int serial_m3110_startup(struct uart_port *port) | |||
517 | 511 | ||
518 | ret = max3110_out(max, config); | 512 | ret = max3110_out(max, config); |
519 | if (ret) { | 513 | if (ret) { |
520 | if (max->irq) | ||
521 | free_irq(max->irq, max); | ||
522 | if (max->read_thread) | 514 | if (max->read_thread) |
523 | kthread_stop(max->read_thread); | 515 | kthread_stop(max->read_thread); |
524 | max->read_thread = NULL; | 516 | max->read_thread = NULL; |
@@ -540,9 +532,6 @@ static void serial_m3110_shutdown(struct uart_port *port) | |||
540 | max->read_thread = NULL; | 532 | max->read_thread = NULL; |
541 | } | 533 | } |
542 | 534 | ||
543 | if (max->irq) | ||
544 | free_irq(max->irq, max); | ||
545 | |||
546 | /* Disable interrupts from this port */ | 535 | /* Disable interrupts from this port */ |
547 | config = WC_TAG | WC_SW_SHDI; | 536 | config = WC_TAG | WC_SW_SHDI; |
548 | max3110_out(max, config); | 537 | max3110_out(max, config); |
@@ -749,7 +738,8 @@ static int serial_m3110_suspend(struct device *dev) | |||
749 | struct spi_device *spi = to_spi_device(dev); | 738 | struct spi_device *spi = to_spi_device(dev); |
750 | struct uart_max3110 *max = spi_get_drvdata(spi); | 739 | struct uart_max3110 *max = spi_get_drvdata(spi); |
751 | 740 | ||
752 | disable_irq(max->irq); | 741 | if (max->irq > 0) |
742 | disable_irq(max->irq); | ||
753 | uart_suspend_port(&serial_m3110_reg, &max->port); | 743 | uart_suspend_port(&serial_m3110_reg, &max->port); |
754 | max3110_out(max, max->cur_conf | WC_SW_SHDI); | 744 | max3110_out(max, max->cur_conf | WC_SW_SHDI); |
755 | return 0; | 745 | return 0; |
@@ -762,7 +752,8 @@ static int serial_m3110_resume(struct device *dev) | |||
762 | 752 | ||
763 | max3110_out(max, max->cur_conf); | 753 | max3110_out(max, max->cur_conf); |
764 | uart_resume_port(&serial_m3110_reg, &max->port); | 754 | uart_resume_port(&serial_m3110_reg, &max->port); |
765 | enable_irq(max->irq); | 755 | if (max->irq > 0) |
756 | enable_irq(max->irq); | ||
766 | return 0; | 757 | return 0; |
767 | } | 758 | } |
768 | 759 | ||
@@ -803,6 +794,7 @@ static int serial_m3110_probe(struct spi_device *spi) | |||
803 | max->irq = (u16)spi->irq; | 794 | max->irq = (u16)spi->irq; |
804 | 795 | ||
805 | mutex_init(&max->thread_mutex); | 796 | mutex_init(&max->thread_mutex); |
797 | mutex_init(&max->io_mutex); | ||
806 | 798 | ||
807 | max->word_7bits = 0; | 799 | max->word_7bits = 0; |
808 | max->parity = 0; | 800 | max->parity = 0; |
@@ -840,6 +832,16 @@ static int serial_m3110_probe(struct spi_device *spi) | |||
840 | goto err_kthread; | 832 | goto err_kthread; |
841 | } | 833 | } |
842 | 834 | ||
835 | if (max->irq) { | ||
836 | ret = request_irq(max->irq, serial_m3110_irq, | ||
837 | IRQ_TYPE_EDGE_FALLING, "max3110", max); | ||
838 | if (ret) { | ||
839 | max->irq = 0; | ||
840 | dev_warn(&spi->dev, | ||
841 | "unable to allocate IRQ, will use polling method\n"); | ||
842 | } | ||
843 | } | ||
844 | |||
843 | spi_set_drvdata(spi, max); | 845 | spi_set_drvdata(spi, max); |
844 | pmax = max; | 846 | pmax = max; |
845 | 847 | ||
@@ -867,6 +869,9 @@ static int serial_m3110_remove(struct spi_device *dev) | |||
867 | 869 | ||
868 | free_page((unsigned long)max->con_xmit.buf); | 870 | free_page((unsigned long)max->con_xmit.buf); |
869 | 871 | ||
872 | if (max->irq) | ||
873 | free_irq(max->irq, max); | ||
874 | |||
870 | if (max->main_thread) | 875 | if (max->main_thread) |
871 | kthread_stop(max->main_thread); | 876 | kthread_stop(max->main_thread); |
872 | 877 | ||
diff --git a/drivers/tty/serial/mxs-auart.c b/drivers/tty/serial/mxs-auart.c index 10e9d70b5c40..d8b6fee77a03 100644 --- a/drivers/tty/serial/mxs-auart.c +++ b/drivers/tty/serial/mxs-auart.c | |||
@@ -39,6 +39,7 @@ | |||
39 | #include <asm/cacheflush.h> | 39 | #include <asm/cacheflush.h> |
40 | 40 | ||
41 | #define MXS_AUART_PORTS 5 | 41 | #define MXS_AUART_PORTS 5 |
42 | #define MXS_AUART_FIFO_SIZE 16 | ||
42 | 43 | ||
43 | #define AUART_CTRL0 0x00000000 | 44 | #define AUART_CTRL0 0x00000000 |
44 | #define AUART_CTRL0_SET 0x00000004 | 45 | #define AUART_CTRL0_SET 0x00000004 |
@@ -548,6 +549,9 @@ static int mxs_auart_dma_init(struct mxs_auart_port *s) | |||
548 | s->flags |= MXS_AUART_DMA_ENABLED; | 549 | s->flags |= MXS_AUART_DMA_ENABLED; |
549 | dev_dbg(s->dev, "enabled the DMA support."); | 550 | dev_dbg(s->dev, "enabled the DMA support."); |
550 | 551 | ||
552 | /* The DMA buffer is now the FIFO the TTY subsystem can use */ | ||
553 | s->port.fifosize = UART_XMIT_SIZE; | ||
554 | |||
551 | return 0; | 555 | return 0; |
552 | 556 | ||
553 | err_out: | 557 | err_out: |
@@ -741,6 +745,9 @@ static int mxs_auart_startup(struct uart_port *u) | |||
741 | writel(AUART_INTR_RXIEN | AUART_INTR_RTIEN | AUART_INTR_CTSMIEN, | 745 | writel(AUART_INTR_RXIEN | AUART_INTR_RTIEN | AUART_INTR_CTSMIEN, |
742 | u->membase + AUART_INTR); | 746 | u->membase + AUART_INTR); |
743 | 747 | ||
748 | /* Reset FIFO size (it could have changed if DMA was enabled) */ | ||
749 | u->fifosize = MXS_AUART_FIFO_SIZE; | ||
750 | |||
744 | /* | 751 | /* |
745 | * Enable fifo so all four bytes of a DMA word are written to | 752 | * Enable fifo so all four bytes of a DMA word are written to |
746 | * output (otherwise, only the LSB is written, ie. 1 in 4 bytes) | 753 | * output (otherwise, only the LSB is written, ie. 1 in 4 bytes) |
@@ -1056,7 +1063,7 @@ static int mxs_auart_probe(struct platform_device *pdev) | |||
1056 | s->port.membase = ioremap(r->start, resource_size(r)); | 1063 | s->port.membase = ioremap(r->start, resource_size(r)); |
1057 | s->port.ops = &mxs_auart_ops; | 1064 | s->port.ops = &mxs_auart_ops; |
1058 | s->port.iotype = UPIO_MEM; | 1065 | s->port.iotype = UPIO_MEM; |
1059 | s->port.fifosize = 16; | 1066 | s->port.fifosize = MXS_AUART_FIFO_SIZE; |
1060 | s->port.uartclk = clk_get_rate(s->clk); | 1067 | s->port.uartclk = clk_get_rate(s->clk); |
1061 | s->port.type = PORT_IMX; | 1068 | s->port.type = PORT_IMX; |
1062 | s->port.dev = s->dev = &pdev->dev; | 1069 | s->port.dev = s->dev = &pdev->dev; |
diff --git a/drivers/tty/serial/omap-serial.c b/drivers/tty/serial/omap-serial.c index 816d1a23f9d0..fa511ebab67c 100644 --- a/drivers/tty/serial/omap-serial.c +++ b/drivers/tty/serial/omap-serial.c | |||
@@ -39,6 +39,7 @@ | |||
39 | #include <linux/irq.h> | 39 | #include <linux/irq.h> |
40 | #include <linux/pm_runtime.h> | 40 | #include <linux/pm_runtime.h> |
41 | #include <linux/of.h> | 41 | #include <linux/of.h> |
42 | #include <linux/of_irq.h> | ||
42 | #include <linux/gpio.h> | 43 | #include <linux/gpio.h> |
43 | #include <linux/of_gpio.h> | 44 | #include <linux/of_gpio.h> |
44 | #include <linux/platform_data/serial-omap.h> | 45 | #include <linux/platform_data/serial-omap.h> |
@@ -134,6 +135,7 @@ struct uart_omap_port { | |||
134 | struct uart_port port; | 135 | struct uart_port port; |
135 | struct uart_omap_dma uart_dma; | 136 | struct uart_omap_dma uart_dma; |
136 | struct device *dev; | 137 | struct device *dev; |
138 | int wakeirq; | ||
137 | 139 | ||
138 | unsigned char ier; | 140 | unsigned char ier; |
139 | unsigned char lcr; | 141 | unsigned char lcr; |
@@ -175,7 +177,7 @@ struct uart_omap_port { | |||
175 | bool is_suspending; | 177 | bool is_suspending; |
176 | }; | 178 | }; |
177 | 179 | ||
178 | #define to_uart_omap_port(p) ((container_of((p), struct uart_omap_port, port))) | 180 | #define to_uart_omap_port(p) ((container_of((p), struct uart_omap_port, port))) |
179 | 181 | ||
180 | static struct uart_omap_port *ui[OMAP_MAX_HSUART_PORTS]; | 182 | static struct uart_omap_port *ui[OMAP_MAX_HSUART_PORTS]; |
181 | 183 | ||
@@ -214,10 +216,23 @@ static int serial_omap_get_context_loss_count(struct uart_omap_port *up) | |||
214 | return pdata->get_context_loss_count(up->dev); | 216 | return pdata->get_context_loss_count(up->dev); |
215 | } | 217 | } |
216 | 218 | ||
219 | static inline void serial_omap_enable_wakeirq(struct uart_omap_port *up, | ||
220 | bool enable) | ||
221 | { | ||
222 | if (!up->wakeirq) | ||
223 | return; | ||
224 | |||
225 | if (enable) | ||
226 | enable_irq(up->wakeirq); | ||
227 | else | ||
228 | disable_irq(up->wakeirq); | ||
229 | } | ||
230 | |||
217 | static void serial_omap_enable_wakeup(struct uart_omap_port *up, bool enable) | 231 | static void serial_omap_enable_wakeup(struct uart_omap_port *up, bool enable) |
218 | { | 232 | { |
219 | struct omap_uart_port_info *pdata = dev_get_platdata(up->dev); | 233 | struct omap_uart_port_info *pdata = dev_get_platdata(up->dev); |
220 | 234 | ||
235 | serial_omap_enable_wakeirq(up, enable); | ||
221 | if (!pdata || !pdata->enable_wakeup) | 236 | if (!pdata || !pdata->enable_wakeup) |
222 | return; | 237 | return; |
223 | 238 | ||
@@ -242,12 +257,12 @@ serial_omap_baud_is_mode16(struct uart_port *port, unsigned int baud) | |||
242 | unsigned int n16 = port->uartclk / (16 * baud); | 257 | unsigned int n16 = port->uartclk / (16 * baud); |
243 | int baudAbsDiff13 = baud - (port->uartclk / (13 * n13)); | 258 | int baudAbsDiff13 = baud - (port->uartclk / (13 * n13)); |
244 | int baudAbsDiff16 = baud - (port->uartclk / (16 * n16)); | 259 | int baudAbsDiff16 = baud - (port->uartclk / (16 * n16)); |
245 | if(baudAbsDiff13 < 0) | 260 | if (baudAbsDiff13 < 0) |
246 | baudAbsDiff13 = -baudAbsDiff13; | 261 | baudAbsDiff13 = -baudAbsDiff13; |
247 | if(baudAbsDiff16 < 0) | 262 | if (baudAbsDiff16 < 0) |
248 | baudAbsDiff16 = -baudAbsDiff16; | 263 | baudAbsDiff16 = -baudAbsDiff16; |
249 | 264 | ||
250 | return (baudAbsDiff13 > baudAbsDiff16); | 265 | return (baudAbsDiff13 >= baudAbsDiff16); |
251 | } | 266 | } |
252 | 267 | ||
253 | /* | 268 | /* |
@@ -258,13 +273,13 @@ serial_omap_baud_is_mode16(struct uart_port *port, unsigned int baud) | |||
258 | static unsigned int | 273 | static unsigned int |
259 | serial_omap_get_divisor(struct uart_port *port, unsigned int baud) | 274 | serial_omap_get_divisor(struct uart_port *port, unsigned int baud) |
260 | { | 275 | { |
261 | unsigned int divisor; | 276 | unsigned int mode; |
262 | 277 | ||
263 | if (!serial_omap_baud_is_mode16(port, baud)) | 278 | if (!serial_omap_baud_is_mode16(port, baud)) |
264 | divisor = 13; | 279 | mode = 13; |
265 | else | 280 | else |
266 | divisor = 16; | 281 | mode = 16; |
267 | return port->uartclk/(baud * divisor); | 282 | return port->uartclk/(mode * baud); |
268 | } | 283 | } |
269 | 284 | ||
270 | static void serial_omap_enable_ms(struct uart_port *port) | 285 | static void serial_omap_enable_ms(struct uart_port *port) |
@@ -283,28 +298,40 @@ static void serial_omap_enable_ms(struct uart_port *port) | |||
283 | static void serial_omap_stop_tx(struct uart_port *port) | 298 | static void serial_omap_stop_tx(struct uart_port *port) |
284 | { | 299 | { |
285 | struct uart_omap_port *up = to_uart_omap_port(port); | 300 | struct uart_omap_port *up = to_uart_omap_port(port); |
286 | struct circ_buf *xmit = &up->port.state->xmit; | ||
287 | int res; | 301 | int res; |
288 | 302 | ||
289 | pm_runtime_get_sync(up->dev); | 303 | pm_runtime_get_sync(up->dev); |
290 | 304 | ||
291 | /* handle rs485 */ | 305 | /* Handle RS-485 */ |
292 | if (up->rs485.flags & SER_RS485_ENABLED) { | 306 | if (up->rs485.flags & SER_RS485_ENABLED) { |
293 | /* do nothing if current tx not yet completed */ | 307 | if (up->scr & OMAP_UART_SCR_TX_EMPTY) { |
294 | res = serial_in(up, UART_LSR) & UART_LSR_TEMT; | 308 | /* THR interrupt is fired when both TX FIFO and TX |
295 | if (!res) | 309 | * shift register are empty. This means there's nothing |
296 | return; | 310 | * left to transmit now, so make sure the THR interrupt |
297 | 311 | * is fired when TX FIFO is below the trigger level, | |
298 | /* if there's no more data to send, turn off rts */ | 312 | * disable THR interrupts and toggle the RS-485 GPIO |
299 | if (uart_circ_empty(xmit)) { | 313 | * data direction pin if needed. |
300 | /* if rts not already disabled */ | 314 | */ |
315 | up->scr &= ~OMAP_UART_SCR_TX_EMPTY; | ||
316 | serial_out(up, UART_OMAP_SCR, up->scr); | ||
301 | res = (up->rs485.flags & SER_RS485_RTS_AFTER_SEND) ? 1 : 0; | 317 | res = (up->rs485.flags & SER_RS485_RTS_AFTER_SEND) ? 1 : 0; |
302 | if (gpio_get_value(up->rts_gpio) != res) { | 318 | if (gpio_get_value(up->rts_gpio) != res) { |
303 | if (up->rs485.delay_rts_after_send > 0) { | 319 | if (up->rs485.delay_rts_after_send > 0) |
304 | mdelay(up->rs485.delay_rts_after_send); | 320 | mdelay(up->rs485.delay_rts_after_send); |
305 | } | ||
306 | gpio_set_value(up->rts_gpio, res); | 321 | gpio_set_value(up->rts_gpio, res); |
307 | } | 322 | } |
323 | } else { | ||
324 | /* We're asked to stop, but there's still stuff in the | ||
325 | * UART FIFO, so make sure the THR interrupt is fired | ||
326 | * when both TX FIFO and TX shift register are empty. | ||
327 | * The next THR interrupt (if no transmission is started | ||
328 | * in the meantime) will indicate the end of a | ||
329 | * transmission. Therefore we _don't_ disable THR | ||
330 | * interrupts in this situation. | ||
331 | */ | ||
332 | up->scr |= OMAP_UART_SCR_TX_EMPTY; | ||
333 | serial_out(up, UART_OMAP_SCR, up->scr); | ||
334 | return; | ||
308 | } | 335 | } |
309 | } | 336 | } |
310 | 337 | ||
@@ -384,15 +411,18 @@ static void serial_omap_start_tx(struct uart_port *port) | |||
384 | 411 | ||
385 | pm_runtime_get_sync(up->dev); | 412 | pm_runtime_get_sync(up->dev); |
386 | 413 | ||
387 | /* handle rs485 */ | 414 | /* Handle RS-485 */ |
388 | if (up->rs485.flags & SER_RS485_ENABLED) { | 415 | if (up->rs485.flags & SER_RS485_ENABLED) { |
416 | /* Fire THR interrupts when FIFO is below trigger level */ | ||
417 | up->scr &= ~OMAP_UART_SCR_TX_EMPTY; | ||
418 | serial_out(up, UART_OMAP_SCR, up->scr); | ||
419 | |||
389 | /* if rts not already enabled */ | 420 | /* if rts not already enabled */ |
390 | res = (up->rs485.flags & SER_RS485_RTS_ON_SEND) ? 1 : 0; | 421 | res = (up->rs485.flags & SER_RS485_RTS_ON_SEND) ? 1 : 0; |
391 | if (gpio_get_value(up->rts_gpio) != res) { | 422 | if (gpio_get_value(up->rts_gpio) != res) { |
392 | gpio_set_value(up->rts_gpio, res); | 423 | gpio_set_value(up->rts_gpio, res); |
393 | if (up->rs485.delay_rts_before_send > 0) { | 424 | if (up->rs485.delay_rts_before_send > 0) |
394 | mdelay(up->rs485.delay_rts_before_send); | 425 | mdelay(up->rs485.delay_rts_before_send); |
395 | } | ||
396 | } | 426 | } |
397 | } | 427 | } |
398 | 428 | ||
@@ -699,6 +729,20 @@ static int serial_omap_startup(struct uart_port *port) | |||
699 | if (retval) | 729 | if (retval) |
700 | return retval; | 730 | return retval; |
701 | 731 | ||
732 | /* Optional wake-up IRQ */ | ||
733 | if (up->wakeirq) { | ||
734 | retval = request_irq(up->wakeirq, serial_omap_irq, | ||
735 | up->port.irqflags, up->name, up); | ||
736 | if (retval) { | ||
737 | free_irq(up->port.irq, up); | ||
738 | return retval; | ||
739 | } | ||
740 | disable_irq(up->wakeirq); | ||
741 | } else { | ||
742 | dev_info(up->port.dev, "no wakeirq for uart%d\n", | ||
743 | up->port.line); | ||
744 | } | ||
745 | |||
702 | dev_dbg(up->port.dev, "serial_omap_startup+%d\n", up->port.line); | 746 | dev_dbg(up->port.dev, "serial_omap_startup+%d\n", up->port.line); |
703 | 747 | ||
704 | pm_runtime_get_sync(up->dev); | 748 | pm_runtime_get_sync(up->dev); |
@@ -787,6 +831,8 @@ static void serial_omap_shutdown(struct uart_port *port) | |||
787 | pm_runtime_mark_last_busy(up->dev); | 831 | pm_runtime_mark_last_busy(up->dev); |
788 | pm_runtime_put_autosuspend(up->dev); | 832 | pm_runtime_put_autosuspend(up->dev); |
789 | free_irq(up->port.irq, up); | 833 | free_irq(up->port.irq, up); |
834 | if (up->wakeirq) | ||
835 | free_irq(up->wakeirq, up); | ||
790 | } | 836 | } |
791 | 837 | ||
792 | static void serial_omap_uart_qos_work(struct work_struct *work) | 838 | static void serial_omap_uart_qos_work(struct work_struct *work) |
@@ -938,7 +984,7 @@ serial_omap_set_termios(struct uart_port *port, struct ktermios *termios, | |||
938 | */ | 984 | */ |
939 | 985 | ||
940 | /* Set receive FIFO threshold to 16 characters and | 986 | /* Set receive FIFO threshold to 16 characters and |
941 | * transmit FIFO threshold to 16 spaces | 987 | * transmit FIFO threshold to 32 spaces |
942 | */ | 988 | */ |
943 | up->fcr &= ~OMAP_UART_FCR_RX_FIFO_TRIG_MASK; | 989 | up->fcr &= ~OMAP_UART_FCR_RX_FIFO_TRIG_MASK; |
944 | up->fcr &= ~OMAP_UART_FCR_TX_FIFO_TRIG_MASK; | 990 | up->fcr &= ~OMAP_UART_FCR_TX_FIFO_TRIG_MASK; |
@@ -1060,15 +1106,6 @@ serial_omap_set_termios(struct uart_port *port, struct ktermios *termios, | |||
1060 | dev_dbg(up->port.dev, "serial_omap_set_termios+%d\n", up->port.line); | 1106 | dev_dbg(up->port.dev, "serial_omap_set_termios+%d\n", up->port.line); |
1061 | } | 1107 | } |
1062 | 1108 | ||
1063 | static int serial_omap_set_wake(struct uart_port *port, unsigned int state) | ||
1064 | { | ||
1065 | struct uart_omap_port *up = to_uart_omap_port(port); | ||
1066 | |||
1067 | serial_omap_enable_wakeup(up, state); | ||
1068 | |||
1069 | return 0; | ||
1070 | } | ||
1071 | |||
1072 | static void | 1109 | static void |
1073 | serial_omap_pm(struct uart_port *port, unsigned int state, | 1110 | serial_omap_pm(struct uart_port *port, unsigned int state, |
1074 | unsigned int oldstate) | 1111 | unsigned int oldstate) |
@@ -1353,6 +1390,15 @@ serial_omap_config_rs485(struct uart_port *port, struct serial_rs485 *rs485conf) | |||
1353 | up->ier = mode; | 1390 | up->ier = mode; |
1354 | serial_out(up, UART_IER, up->ier); | 1391 | serial_out(up, UART_IER, up->ier); |
1355 | 1392 | ||
1393 | /* If RS-485 is disabled, make sure the THR interrupt is fired when | ||
1394 | * TX FIFO is below the trigger level. | ||
1395 | */ | ||
1396 | if (!(up->rs485.flags & SER_RS485_ENABLED) && | ||
1397 | (up->scr & OMAP_UART_SCR_TX_EMPTY)) { | ||
1398 | up->scr &= ~OMAP_UART_SCR_TX_EMPTY; | ||
1399 | serial_out(up, UART_OMAP_SCR, up->scr); | ||
1400 | } | ||
1401 | |||
1356 | spin_unlock_irqrestore(&up->port.lock, flags); | 1402 | spin_unlock_irqrestore(&up->port.lock, flags); |
1357 | pm_runtime_mark_last_busy(up->dev); | 1403 | pm_runtime_mark_last_busy(up->dev); |
1358 | pm_runtime_put_autosuspend(up->dev); | 1404 | pm_runtime_put_autosuspend(up->dev); |
@@ -1401,7 +1447,6 @@ static struct uart_ops serial_omap_pops = { | |||
1401 | .shutdown = serial_omap_shutdown, | 1447 | .shutdown = serial_omap_shutdown, |
1402 | .set_termios = serial_omap_set_termios, | 1448 | .set_termios = serial_omap_set_termios, |
1403 | .pm = serial_omap_pm, | 1449 | .pm = serial_omap_pm, |
1404 | .set_wake = serial_omap_set_wake, | ||
1405 | .type = serial_omap_type, | 1450 | .type = serial_omap_type, |
1406 | .release_port = serial_omap_release_port, | 1451 | .release_port = serial_omap_release_port, |
1407 | .request_port = serial_omap_request_port, | 1452 | .request_port = serial_omap_request_port, |
@@ -1582,11 +1627,23 @@ static int serial_omap_probe(struct platform_device *pdev) | |||
1582 | struct uart_omap_port *up; | 1627 | struct uart_omap_port *up; |
1583 | struct resource *mem, *irq; | 1628 | struct resource *mem, *irq; |
1584 | struct omap_uart_port_info *omap_up_info = dev_get_platdata(&pdev->dev); | 1629 | struct omap_uart_port_info *omap_up_info = dev_get_platdata(&pdev->dev); |
1585 | int ret; | 1630 | int ret, uartirq = 0, wakeirq = 0; |
1586 | 1631 | ||
1632 | /* The optional wakeirq may be specified in the board dts file */ | ||
1587 | if (pdev->dev.of_node) { | 1633 | if (pdev->dev.of_node) { |
1634 | uartirq = irq_of_parse_and_map(pdev->dev.of_node, 0); | ||
1635 | if (!uartirq) | ||
1636 | return -EPROBE_DEFER; | ||
1637 | wakeirq = irq_of_parse_and_map(pdev->dev.of_node, 1); | ||
1588 | omap_up_info = of_get_uart_port_info(&pdev->dev); | 1638 | omap_up_info = of_get_uart_port_info(&pdev->dev); |
1589 | pdev->dev.platform_data = omap_up_info; | 1639 | pdev->dev.platform_data = omap_up_info; |
1640 | } else { | ||
1641 | irq = platform_get_resource(pdev, IORESOURCE_IRQ, 0); | ||
1642 | if (!irq) { | ||
1643 | dev_err(&pdev->dev, "no irq resource?\n"); | ||
1644 | return -ENODEV; | ||
1645 | } | ||
1646 | uartirq = irq->start; | ||
1590 | } | 1647 | } |
1591 | 1648 | ||
1592 | mem = platform_get_resource(pdev, IORESOURCE_MEM, 0); | 1649 | mem = platform_get_resource(pdev, IORESOURCE_MEM, 0); |
@@ -1595,12 +1652,6 @@ static int serial_omap_probe(struct platform_device *pdev) | |||
1595 | return -ENODEV; | 1652 | return -ENODEV; |
1596 | } | 1653 | } |
1597 | 1654 | ||
1598 | irq = platform_get_resource(pdev, IORESOURCE_IRQ, 0); | ||
1599 | if (!irq) { | ||
1600 | dev_err(&pdev->dev, "no irq resource?\n"); | ||
1601 | return -ENODEV; | ||
1602 | } | ||
1603 | |||
1604 | if (!devm_request_mem_region(&pdev->dev, mem->start, resource_size(mem), | 1655 | if (!devm_request_mem_region(&pdev->dev, mem->start, resource_size(mem), |
1605 | pdev->dev.driver->name)) { | 1656 | pdev->dev.driver->name)) { |
1606 | dev_err(&pdev->dev, "memory region already claimed\n"); | 1657 | dev_err(&pdev->dev, "memory region already claimed\n"); |
@@ -1634,7 +1685,8 @@ static int serial_omap_probe(struct platform_device *pdev) | |||
1634 | up->port.dev = &pdev->dev; | 1685 | up->port.dev = &pdev->dev; |
1635 | up->port.type = PORT_OMAP; | 1686 | up->port.type = PORT_OMAP; |
1636 | up->port.iotype = UPIO_MEM; | 1687 | up->port.iotype = UPIO_MEM; |
1637 | up->port.irq = irq->start; | 1688 | up->port.irq = uartirq; |
1689 | up->wakeirq = wakeirq; | ||
1638 | 1690 | ||
1639 | up->port.regshift = 2; | 1691 | up->port.regshift = 2; |
1640 | up->port.fifosize = 64; | 1692 | up->port.fifosize = 64; |
@@ -1670,8 +1722,9 @@ static int serial_omap_probe(struct platform_device *pdev) | |||
1670 | up->port.uartclk = omap_up_info->uartclk; | 1722 | up->port.uartclk = omap_up_info->uartclk; |
1671 | if (!up->port.uartclk) { | 1723 | if (!up->port.uartclk) { |
1672 | up->port.uartclk = DEFAULT_CLK_SPEED; | 1724 | up->port.uartclk = DEFAULT_CLK_SPEED; |
1673 | dev_warn(&pdev->dev, "No clock speed specified: using default:" | 1725 | dev_warn(&pdev->dev, |
1674 | "%d\n", DEFAULT_CLK_SPEED); | 1726 | "No clock speed specified: using default: %d\n", |
1727 | DEFAULT_CLK_SPEED); | ||
1675 | } | 1728 | } |
1676 | 1729 | ||
1677 | up->latency = PM_QOS_CPU_DMA_LAT_DEFAULT_VALUE; | 1730 | up->latency = PM_QOS_CPU_DMA_LAT_DEFAULT_VALUE; |
diff --git a/drivers/tty/serial/pch_uart.c b/drivers/tty/serial/pch_uart.c index 44077c0b7670..0aa2b528ef3d 100644 --- a/drivers/tty/serial/pch_uart.c +++ b/drivers/tty/serial/pch_uart.c | |||
@@ -1614,7 +1614,6 @@ static struct uart_ops pch_uart_ops = { | |||
1614 | .shutdown = pch_uart_shutdown, | 1614 | .shutdown = pch_uart_shutdown, |
1615 | .set_termios = pch_uart_set_termios, | 1615 | .set_termios = pch_uart_set_termios, |
1616 | /* .pm = pch_uart_pm, Not supported yet */ | 1616 | /* .pm = pch_uart_pm, Not supported yet */ |
1617 | /* .set_wake = pch_uart_set_wake, Not supported yet */ | ||
1618 | .type = pch_uart_type, | 1617 | .type = pch_uart_type, |
1619 | .release_port = pch_uart_release_port, | 1618 | .release_port = pch_uart_release_port, |
1620 | .request_port = pch_uart_request_port, | 1619 | .request_port = pch_uart_request_port, |
@@ -1996,6 +1995,8 @@ module_exit(pch_uart_module_exit); | |||
1996 | 1995 | ||
1997 | MODULE_LICENSE("GPL v2"); | 1996 | MODULE_LICENSE("GPL v2"); |
1998 | MODULE_DESCRIPTION("Intel EG20T PCH UART PCI Driver"); | 1997 | MODULE_DESCRIPTION("Intel EG20T PCH UART PCI Driver"); |
1998 | MODULE_DEVICE_TABLE(pci, pch_uart_pci_id); | ||
1999 | |||
1999 | module_param(default_baud, uint, S_IRUGO); | 2000 | module_param(default_baud, uint, S_IRUGO); |
2000 | MODULE_PARM_DESC(default_baud, | 2001 | MODULE_PARM_DESC(default_baud, |
2001 | "Default BAUD for initial driver state and console (default 9600)"); | 2002 | "Default BAUD for initial driver state and console (default 9600)"); |
diff --git a/drivers/tty/serial/pmac_zilog.c b/drivers/tty/serial/pmac_zilog.c index f87f1a0c8c6e..e9d420ff3931 100644 --- a/drivers/tty/serial/pmac_zilog.c +++ b/drivers/tty/serial/pmac_zilog.c | |||
@@ -57,6 +57,8 @@ | |||
57 | #include <linux/bitops.h> | 57 | #include <linux/bitops.h> |
58 | #include <linux/sysrq.h> | 58 | #include <linux/sysrq.h> |
59 | #include <linux/mutex.h> | 59 | #include <linux/mutex.h> |
60 | #include <linux/of_address.h> | ||
61 | #include <linux/of_irq.h> | ||
60 | #include <asm/sections.h> | 62 | #include <asm/sections.h> |
61 | #include <asm/io.h> | 63 | #include <asm/io.h> |
62 | #include <asm/irq.h> | 64 | #include <asm/irq.h> |
@@ -1072,7 +1074,7 @@ static void pmz_convert_to_zs(struct uart_pmac_port *uap, unsigned int cflag, | |||
1072 | uap->curregs[5] |= Tx8; | 1074 | uap->curregs[5] |= Tx8; |
1073 | uap->parity_mask = 0xff; | 1075 | uap->parity_mask = 0xff; |
1074 | break; | 1076 | break; |
1075 | }; | 1077 | } |
1076 | uap->curregs[4] &= ~(SB_MASK); | 1078 | uap->curregs[4] &= ~(SB_MASK); |
1077 | if (cflag & CSTOPB) | 1079 | if (cflag & CSTOPB) |
1078 | uap->curregs[4] |= SB2; | 1080 | uap->curregs[4] |= SB2; |
@@ -2050,6 +2052,9 @@ static int __init pmz_console_init(void) | |||
2050 | /* Probe ports */ | 2052 | /* Probe ports */ |
2051 | pmz_probe(); | 2053 | pmz_probe(); |
2052 | 2054 | ||
2055 | if (pmz_ports_count == 0) | ||
2056 | return -ENODEV; | ||
2057 | |||
2053 | /* TODO: Autoprobe console based on OF */ | 2058 | /* TODO: Autoprobe console based on OF */ |
2054 | /* pmz_console.index = i; */ | 2059 | /* pmz_console.index = i; */ |
2055 | register_console(&pmz_console); | 2060 | register_console(&pmz_console); |
diff --git a/drivers/tty/serial/sa1100.c b/drivers/tty/serial/sa1100.c index ba25722a7131..753d4525b367 100644 --- a/drivers/tty/serial/sa1100.c +++ b/drivers/tty/serial/sa1100.c | |||
@@ -647,7 +647,10 @@ void sa1100_register_uart_fns(struct sa1100_port_fns *fns) | |||
647 | sa1100_pops.set_mctrl = fns->set_mctrl; | 647 | sa1100_pops.set_mctrl = fns->set_mctrl; |
648 | 648 | ||
649 | sa1100_pops.pm = fns->pm; | 649 | sa1100_pops.pm = fns->pm; |
650 | sa1100_pops.set_wake = fns->set_wake; | 650 | /* |
651 | * FIXME: fns->set_wake is unused - this should be called from | ||
652 | * the suspend() callback if device_may_wakeup(dev)) is set. | ||
653 | */ | ||
651 | } | 654 | } |
652 | 655 | ||
653 | void __init sa1100_register_uart(int idx, int port) | 656 | void __init sa1100_register_uart(int idx, int port) |
diff --git a/drivers/tty/serial/samsung.c b/drivers/tty/serial/samsung.c index f3dfa19a1cb8..c1af04d46682 100644 --- a/drivers/tty/serial/samsung.c +++ b/drivers/tty/serial/samsung.c | |||
@@ -407,7 +407,14 @@ static unsigned int s3c24xx_serial_get_mctrl(struct uart_port *port) | |||
407 | 407 | ||
408 | static void s3c24xx_serial_set_mctrl(struct uart_port *port, unsigned int mctrl) | 408 | static void s3c24xx_serial_set_mctrl(struct uart_port *port, unsigned int mctrl) |
409 | { | 409 | { |
410 | /* todo - possibly remove AFC and do manual CTS */ | 410 | unsigned int umcon = rd_regl(port, S3C2410_UMCON); |
411 | |||
412 | if (mctrl & TIOCM_RTS) | ||
413 | umcon |= S3C2410_UMCOM_RTS_LOW; | ||
414 | else | ||
415 | umcon &= ~S3C2410_UMCOM_RTS_LOW; | ||
416 | |||
417 | wr_regl(port, S3C2410_UMCON, umcon); | ||
411 | } | 418 | } |
412 | 419 | ||
413 | static void s3c24xx_serial_break_ctl(struct uart_port *port, int break_state) | 420 | static void s3c24xx_serial_break_ctl(struct uart_port *port, int break_state) |
@@ -774,8 +781,6 @@ static void s3c24xx_serial_set_termios(struct uart_port *port, | |||
774 | if (termios->c_cflag & CSTOPB) | 781 | if (termios->c_cflag & CSTOPB) |
775 | ulcon |= S3C2410_LCON_STOPB; | 782 | ulcon |= S3C2410_LCON_STOPB; |
776 | 783 | ||
777 | umcon = (termios->c_cflag & CRTSCTS) ? S3C2410_UMCOM_AFC : 0; | ||
778 | |||
779 | if (termios->c_cflag & PARENB) { | 784 | if (termios->c_cflag & PARENB) { |
780 | if (termios->c_cflag & PARODD) | 785 | if (termios->c_cflag & PARODD) |
781 | ulcon |= S3C2410_LCON_PODD; | 786 | ulcon |= S3C2410_LCON_PODD; |
@@ -792,6 +797,15 @@ static void s3c24xx_serial_set_termios(struct uart_port *port, | |||
792 | 797 | ||
793 | wr_regl(port, S3C2410_ULCON, ulcon); | 798 | wr_regl(port, S3C2410_ULCON, ulcon); |
794 | wr_regl(port, S3C2410_UBRDIV, quot); | 799 | wr_regl(port, S3C2410_UBRDIV, quot); |
800 | |||
801 | umcon = rd_regl(port, S3C2410_UMCON); | ||
802 | if (termios->c_cflag & CRTSCTS) { | ||
803 | umcon |= S3C2410_UMCOM_AFC; | ||
804 | /* Disable RTS when RX FIFO contains 63 bytes */ | ||
805 | umcon &= ~S3C2412_UMCON_AFC_8; | ||
806 | } else { | ||
807 | umcon &= ~S3C2410_UMCOM_AFC; | ||
808 | } | ||
795 | wr_regl(port, S3C2410_UMCON, umcon); | 809 | wr_regl(port, S3C2410_UMCON, umcon); |
796 | 810 | ||
797 | if (ourport->info->has_divslot) | 811 | if (ourport->info->has_divslot) |
@@ -1254,7 +1268,7 @@ static int s3c24xx_serial_probe(struct platform_device *pdev) | |||
1254 | ourport->baudclk = ERR_PTR(-EINVAL); | 1268 | ourport->baudclk = ERR_PTR(-EINVAL); |
1255 | ourport->info = ourport->drv_data->info; | 1269 | ourport->info = ourport->drv_data->info; |
1256 | ourport->cfg = (dev_get_platdata(&pdev->dev)) ? | 1270 | ourport->cfg = (dev_get_platdata(&pdev->dev)) ? |
1257 | (struct s3c2410_uartcfg *)dev_get_platdata(&pdev->dev) : | 1271 | dev_get_platdata(&pdev->dev) : |
1258 | ourport->drv_data->def_cfg; | 1272 | ourport->drv_data->def_cfg; |
1259 | 1273 | ||
1260 | ourport->port.fifosize = (ourport->info->fifosize) ? | 1274 | ourport->port.fifosize = (ourport->info->fifosize) ? |
diff --git a/drivers/tty/serial/samsung.h b/drivers/tty/serial/samsung.h index aaa617a6c499..8827e5424cef 100644 --- a/drivers/tty/serial/samsung.h +++ b/drivers/tty/serial/samsung.h | |||
@@ -63,7 +63,7 @@ struct s3c24xx_uart_port { | |||
63 | 63 | ||
64 | /* conversion functions */ | 64 | /* conversion functions */ |
65 | 65 | ||
66 | #define s3c24xx_dev_to_port(__dev) (struct uart_port *)dev_get_drvdata(__dev) | 66 | #define s3c24xx_dev_to_port(__dev) dev_get_drvdata(__dev) |
67 | 67 | ||
68 | /* register access controls */ | 68 | /* register access controls */ |
69 | 69 | ||
diff --git a/drivers/tty/serial/sccnxp.c b/drivers/tty/serial/sccnxp.c index 49e9bbfe6cab..a447f71538ef 100644 --- a/drivers/tty/serial/sccnxp.c +++ b/drivers/tty/serial/sccnxp.c | |||
@@ -986,6 +986,7 @@ static int sccnxp_probe(struct platform_device *pdev) | |||
986 | return 0; | 986 | return 0; |
987 | } | 987 | } |
988 | 988 | ||
989 | uart_unregister_driver(&s->uart); | ||
989 | err_out: | 990 | err_out: |
990 | if (!IS_ERR(s->regulator)) | 991 | if (!IS_ERR(s->regulator)) |
991 | return regulator_disable(s->regulator); | 992 | return regulator_disable(s->regulator); |
diff --git a/drivers/tty/serial/serial-tegra.c b/drivers/tty/serial/serial-tegra.c index 0489a2bdcdf9..dfe79ccc4fb3 100644 --- a/drivers/tty/serial/serial-tegra.c +++ b/drivers/tty/serial/serial-tegra.c | |||
@@ -1018,7 +1018,7 @@ static int tegra_uart_startup(struct uart_port *u) | |||
1018 | goto fail_hw_init; | 1018 | goto fail_hw_init; |
1019 | } | 1019 | } |
1020 | 1020 | ||
1021 | ret = request_irq(u->irq, tegra_uart_isr, IRQF_DISABLED, | 1021 | ret = request_irq(u->irq, tegra_uart_isr, 0, |
1022 | dev_name(u->dev), tup); | 1022 | dev_name(u->dev), tup); |
1023 | if (ret < 0) { | 1023 | if (ret < 0) { |
1024 | dev_err(u->dev, "Failed to register ISR for IRQ %d\n", u->irq); | 1024 | dev_err(u->dev, "Failed to register ISR for IRQ %d\n", u->irq); |
diff --git a/drivers/tty/serial/serial_txx9.c b/drivers/tty/serial/serial_txx9.c index 440a962412da..90a080b1f9ee 100644 --- a/drivers/tty/serial/serial_txx9.c +++ b/drivers/tty/serial/serial_txx9.c | |||
@@ -1220,8 +1220,6 @@ static void pciserial_txx9_remove_one(struct pci_dev *dev) | |||
1220 | { | 1220 | { |
1221 | struct uart_txx9_port *up = pci_get_drvdata(dev); | 1221 | struct uart_txx9_port *up = pci_get_drvdata(dev); |
1222 | 1222 | ||
1223 | pci_set_drvdata(dev, NULL); | ||
1224 | |||
1225 | if (up) { | 1223 | if (up) { |
1226 | serial_txx9_unregister_port(up->port.line); | 1224 | serial_txx9_unregister_port(up->port.line); |
1227 | pci_disable_device(dev); | 1225 | pci_disable_device(dev); |
diff --git a/drivers/tty/serial/sh-sci.c b/drivers/tty/serial/sh-sci.c index 537750261aaa..7d8103cd3e2e 100644 --- a/drivers/tty/serial/sh-sci.c +++ b/drivers/tty/serial/sh-sci.c | |||
@@ -1433,7 +1433,7 @@ static void work_fn_rx(struct work_struct *work) | |||
1433 | desc = s->desc_rx[new]; | 1433 | desc = s->desc_rx[new]; |
1434 | 1434 | ||
1435 | if (dma_async_is_tx_complete(s->chan_rx, s->active_rx, NULL, NULL) != | 1435 | if (dma_async_is_tx_complete(s->chan_rx, s->active_rx, NULL, NULL) != |
1436 | DMA_SUCCESS) { | 1436 | DMA_COMPLETE) { |
1437 | /* Handle incomplete DMA receive */ | 1437 | /* Handle incomplete DMA receive */ |
1438 | struct dma_chan *chan = s->chan_rx; | 1438 | struct dma_chan *chan = s->chan_rx; |
1439 | struct shdma_desc *sh_desc = container_of(desc, | 1439 | struct shdma_desc *sh_desc = container_of(desc, |
diff --git a/drivers/tty/serial/sirfsoc_uart.c b/drivers/tty/serial/sirfsoc_uart.c index 61c1ad03db5b..f186a8fb8887 100644 --- a/drivers/tty/serial/sirfsoc_uart.c +++ b/drivers/tty/serial/sirfsoc_uart.c | |||
@@ -529,7 +529,7 @@ static void sirfsoc_rx_tmo_process_tl(unsigned long param) | |||
529 | while (sirfport->rx_completed != sirfport->rx_issued) { | 529 | while (sirfport->rx_completed != sirfport->rx_issued) { |
530 | sirfsoc_uart_insert_rx_buf_to_tty(sirfport, | 530 | sirfsoc_uart_insert_rx_buf_to_tty(sirfport, |
531 | SIRFSOC_RX_DMA_BUF_SIZE); | 531 | SIRFSOC_RX_DMA_BUF_SIZE); |
532 | sirfsoc_rx_submit_one_dma_desc(port, sirfport->rx_completed++); | 532 | sirfport->rx_completed++; |
533 | sirfport->rx_completed %= SIRFSOC_RX_LOOP_BUF_CNT; | 533 | sirfport->rx_completed %= SIRFSOC_RX_LOOP_BUF_CNT; |
534 | } | 534 | } |
535 | count = CIRC_CNT(sirfport->rx_dma_items[sirfport->rx_issued].xmit.head, | 535 | count = CIRC_CNT(sirfport->rx_dma_items[sirfport->rx_issued].xmit.head, |
@@ -706,12 +706,19 @@ static void sirfsoc_uart_rx_dma_complete_tl(unsigned long param) | |||
706 | { | 706 | { |
707 | struct sirfsoc_uart_port *sirfport = (struct sirfsoc_uart_port *)param; | 707 | struct sirfsoc_uart_port *sirfport = (struct sirfsoc_uart_port *)param; |
708 | struct uart_port *port = &sirfport->port; | 708 | struct uart_port *port = &sirfport->port; |
709 | struct sirfsoc_register *ureg = &sirfport->uart_reg->uart_reg; | ||
710 | struct sirfsoc_int_en *uint_en = &sirfport->uart_reg->uart_int_en; | ||
709 | unsigned long flags; | 711 | unsigned long flags; |
710 | spin_lock_irqsave(&sirfport->rx_lock, flags); | 712 | spin_lock_irqsave(&sirfport->rx_lock, flags); |
711 | while (sirfport->rx_completed != sirfport->rx_issued) { | 713 | while (sirfport->rx_completed != sirfport->rx_issued) { |
712 | sirfsoc_uart_insert_rx_buf_to_tty(sirfport, | 714 | sirfsoc_uart_insert_rx_buf_to_tty(sirfport, |
713 | SIRFSOC_RX_DMA_BUF_SIZE); | 715 | SIRFSOC_RX_DMA_BUF_SIZE); |
714 | sirfsoc_rx_submit_one_dma_desc(port, sirfport->rx_completed++); | 716 | if (rd_regl(port, ureg->sirfsoc_int_en_reg) & |
717 | uint_en->sirfsoc_rx_timeout_en) | ||
718 | sirfsoc_rx_submit_one_dma_desc(port, | ||
719 | sirfport->rx_completed++); | ||
720 | else | ||
721 | sirfport->rx_completed++; | ||
715 | sirfport->rx_completed %= SIRFSOC_RX_LOOP_BUF_CNT; | 722 | sirfport->rx_completed %= SIRFSOC_RX_LOOP_BUF_CNT; |
716 | } | 723 | } |
717 | spin_unlock_irqrestore(&sirfport->rx_lock, flags); | 724 | spin_unlock_irqrestore(&sirfport->rx_lock, flags); |
diff --git a/drivers/tty/serial/sirfsoc_uart.h b/drivers/tty/serial/sirfsoc_uart.h index fb8d0a002607..b7d679c0881b 100644 --- a/drivers/tty/serial/sirfsoc_uart.h +++ b/drivers/tty/serial/sirfsoc_uart.h | |||
@@ -368,15 +368,6 @@ struct sirfsoc_uart_register sirfsoc_uart = { | |||
368 | #define SIRFSOC_UART_NR 6 | 368 | #define SIRFSOC_UART_NR 6 |
369 | #define SIRFSOC_PORT_TYPE 0xa5 | 369 | #define SIRFSOC_PORT_TYPE 0xa5 |
370 | 370 | ||
371 | /* Baud Rate Calculation */ | ||
372 | #define SIRF_MIN_SAMPLE_DIV 0xf | ||
373 | #define SIRF_MAX_SAMPLE_DIV 0x3f | ||
374 | #define SIRF_IOCLK_DIV_MAX 0xffff | ||
375 | #define SIRF_SAMPLE_DIV_SHIFT 16 | ||
376 | #define SIRF_IOCLK_DIV_MASK 0xffff | ||
377 | #define SIRF_SAMPLE_DIV_MASK 0x3f0000 | ||
378 | #define SIRF_BAUD_RATE_SUPPORT_NR 18 | ||
379 | |||
380 | /* Uart Common Use Macro*/ | 371 | /* Uart Common Use Macro*/ |
381 | #define SIRFSOC_RX_DMA_BUF_SIZE 256 | 372 | #define SIRFSOC_RX_DMA_BUF_SIZE 256 |
382 | #define BYTES_TO_ALIGN(dma_addr) ((unsigned long)(dma_addr) & 0x3) | 373 | #define BYTES_TO_ALIGN(dma_addr) ((unsigned long)(dma_addr) & 0x3) |
@@ -453,9 +444,6 @@ struct sirfsoc_uart_port { | |||
453 | int rx_issued; | 444 | int rx_issued; |
454 | }; | 445 | }; |
455 | 446 | ||
456 | /* Hardware Flow Control */ | ||
457 | #define SIRFUART_AFC_CTRL_RX_THD 0x70 | ||
458 | |||
459 | /* Register Access Control */ | 447 | /* Register Access Control */ |
460 | #define portaddr(port, reg) ((port)->membase + (reg)) | 448 | #define portaddr(port, reg) ((port)->membase + (reg)) |
461 | #define rd_regb(port, reg) (__raw_readb(portaddr(port, reg))) | 449 | #define rd_regb(port, reg) (__raw_readb(portaddr(port, reg))) |
diff --git a/drivers/tty/serial/sunsab.c b/drivers/tty/serial/sunsab.c index 5d6136b2a04a..380fb5355cb2 100644 --- a/drivers/tty/serial/sunsab.c +++ b/drivers/tty/serial/sunsab.c | |||
@@ -894,7 +894,7 @@ static int sunsab_console_setup(struct console *con, char *options) | |||
894 | case B115200: baud = 115200; break; | 894 | case B115200: baud = 115200; break; |
895 | case B230400: baud = 230400; break; | 895 | case B230400: baud = 230400; break; |
896 | case B460800: baud = 460800; break; | 896 | case B460800: baud = 460800; break; |
897 | }; | 897 | } |
898 | 898 | ||
899 | /* | 899 | /* |
900 | * Temporary fix. | 900 | * Temporary fix. |
diff --git a/drivers/tty/serial/sunsu.c b/drivers/tty/serial/sunsu.c index 699cc1b5f6aa..db79b76f5c8e 100644 --- a/drivers/tty/serial/sunsu.c +++ b/drivers/tty/serial/sunsu.c | |||
@@ -522,7 +522,7 @@ static void receive_kbd_ms_chars(struct uart_sunsu_port *up, int is_break) | |||
522 | serio_interrupt(&up->serio, ch, 0); | 522 | serio_interrupt(&up->serio, ch, 0); |
523 | #endif | 523 | #endif |
524 | break; | 524 | break; |
525 | }; | 525 | } |
526 | } | 526 | } |
527 | } while (serial_in(up, UART_LSR) & UART_LSR_DR); | 527 | } while (serial_in(up, UART_LSR) & UART_LSR_DR); |
528 | } | 528 | } |
diff --git a/drivers/tty/serial/sunzilog.c b/drivers/tty/serial/sunzilog.c index 135a15203532..45a8c6aa5837 100644 --- a/drivers/tty/serial/sunzilog.c +++ b/drivers/tty/serial/sunzilog.c | |||
@@ -319,7 +319,7 @@ static void sunzilog_kbdms_receive_chars(struct uart_sunzilog_port *up, | |||
319 | serio_interrupt(&up->serio, ch, 0); | 319 | serio_interrupt(&up->serio, ch, 0); |
320 | #endif | 320 | #endif |
321 | break; | 321 | break; |
322 | }; | 322 | } |
323 | } | 323 | } |
324 | } | 324 | } |
325 | 325 | ||
@@ -897,7 +897,7 @@ sunzilog_convert_to_zs(struct uart_sunzilog_port *up, unsigned int cflag, | |||
897 | up->curregs[R5] |= Tx8; | 897 | up->curregs[R5] |= Tx8; |
898 | up->parity_mask = 0xff; | 898 | up->parity_mask = 0xff; |
899 | break; | 899 | break; |
900 | }; | 900 | } |
901 | up->curregs[R4] &= ~0x0c; | 901 | up->curregs[R4] &= ~0x0c; |
902 | if (cflag & CSTOPB) | 902 | if (cflag & CSTOPB) |
903 | up->curregs[R4] |= SB2; | 903 | up->curregs[R4] |= SB2; |
@@ -1239,7 +1239,7 @@ static int __init sunzilog_console_setup(struct console *con, char *options) | |||
1239 | default: case B9600: baud = 9600; break; | 1239 | default: case B9600: baud = 9600; break; |
1240 | case B19200: baud = 19200; break; | 1240 | case B19200: baud = 19200; break; |
1241 | case B38400: baud = 38400; break; | 1241 | case B38400: baud = 38400; break; |
1242 | }; | 1242 | } |
1243 | 1243 | ||
1244 | brg = BPS_TO_BRG(baud, ZS_CLOCK / ZS_CLOCK_DIVISOR); | 1244 | brg = BPS_TO_BRG(baud, ZS_CLOCK / ZS_CLOCK_DIVISOR); |
1245 | 1245 | ||
diff --git a/drivers/tty/serial/ucc_uart.c b/drivers/tty/serial/ucc_uart.c index 88317482b81f..d569ca58bab6 100644 --- a/drivers/tty/serial/ucc_uart.c +++ b/drivers/tty/serial/ucc_uart.c | |||
@@ -25,6 +25,8 @@ | |||
25 | #include <linux/tty.h> | 25 | #include <linux/tty.h> |
26 | #include <linux/tty_flip.h> | 26 | #include <linux/tty_flip.h> |
27 | #include <linux/io.h> | 27 | #include <linux/io.h> |
28 | #include <linux/of_address.h> | ||
29 | #include <linux/of_irq.h> | ||
28 | #include <linux/of_platform.h> | 30 | #include <linux/of_platform.h> |
29 | #include <linux/dma-mapping.h> | 31 | #include <linux/dma-mapping.h> |
30 | 32 | ||
@@ -269,7 +271,7 @@ static unsigned int qe_uart_tx_empty(struct uart_port *port) | |||
269 | return 1; | 271 | return 1; |
270 | 272 | ||
271 | bdp++; | 273 | bdp++; |
272 | }; | 274 | } |
273 | } | 275 | } |
274 | 276 | ||
275 | /* | 277 | /* |
diff --git a/drivers/tty/serial/xilinx_uartps.c b/drivers/tty/serial/xilinx_uartps.c index 7e4150aa69c6..f619ad5b5eae 100644 --- a/drivers/tty/serial/xilinx_uartps.c +++ b/drivers/tty/serial/xilinx_uartps.c | |||
@@ -1,7 +1,7 @@ | |||
1 | /* | 1 | /* |
2 | * Xilinx PS UART driver | 2 | * Xilinx PS UART driver |
3 | * | 3 | * |
4 | * 2011 (c) Xilinx Inc. | 4 | * 2011 - 2013 (C) Xilinx Inc. |
5 | * | 5 | * |
6 | * This program is free software; you can redistribute it | 6 | * This program is free software; you can redistribute it |
7 | * and/or modify it under the terms of the GNU General Public | 7 | * and/or modify it under the terms of the GNU General Public |
@@ -11,13 +11,17 @@ | |||
11 | * | 11 | * |
12 | */ | 12 | */ |
13 | 13 | ||
14 | #if defined(CONFIG_SERIAL_XILINX_PS_UART_CONSOLE) && defined(CONFIG_MAGIC_SYSRQ) | ||
15 | #define SUPPORT_SYSRQ | ||
16 | #endif | ||
17 | |||
14 | #include <linux/platform_device.h> | 18 | #include <linux/platform_device.h> |
15 | #include <linux/serial.h> | 19 | #include <linux/serial.h> |
20 | #include <linux/console.h> | ||
16 | #include <linux/serial_core.h> | 21 | #include <linux/serial_core.h> |
17 | #include <linux/slab.h> | 22 | #include <linux/slab.h> |
18 | #include <linux/tty.h> | 23 | #include <linux/tty.h> |
19 | #include <linux/tty_flip.h> | 24 | #include <linux/tty_flip.h> |
20 | #include <linux/console.h> | ||
21 | #include <linux/clk.h> | 25 | #include <linux/clk.h> |
22 | #include <linux/irq.h> | 26 | #include <linux/irq.h> |
23 | #include <linux/io.h> | 27 | #include <linux/io.h> |
@@ -29,12 +33,22 @@ | |||
29 | #define XUARTPS_MAJOR 0 /* use dynamic node allocation */ | 33 | #define XUARTPS_MAJOR 0 /* use dynamic node allocation */ |
30 | #define XUARTPS_MINOR 0 /* works best with devtmpfs */ | 34 | #define XUARTPS_MINOR 0 /* works best with devtmpfs */ |
31 | #define XUARTPS_NR_PORTS 2 | 35 | #define XUARTPS_NR_PORTS 2 |
32 | #define XUARTPS_FIFO_SIZE 16 /* FIFO size */ | 36 | #define XUARTPS_FIFO_SIZE 64 /* FIFO size */ |
33 | #define XUARTPS_REGISTER_SPACE 0xFFF | 37 | #define XUARTPS_REGISTER_SPACE 0xFFF |
34 | 38 | ||
35 | #define xuartps_readl(offset) ioread32(port->membase + offset) | 39 | #define xuartps_readl(offset) ioread32(port->membase + offset) |
36 | #define xuartps_writel(val, offset) iowrite32(val, port->membase + offset) | 40 | #define xuartps_writel(val, offset) iowrite32(val, port->membase + offset) |
37 | 41 | ||
42 | /* Rx Trigger level */ | ||
43 | static int rx_trigger_level = 56; | ||
44 | module_param(rx_trigger_level, uint, S_IRUGO); | ||
45 | MODULE_PARM_DESC(rx_trigger_level, "Rx trigger level, 1-63 bytes"); | ||
46 | |||
47 | /* Rx Timeout */ | ||
48 | static int rx_timeout = 10; | ||
49 | module_param(rx_timeout, uint, S_IRUGO); | ||
50 | MODULE_PARM_DESC(rx_timeout, "Rx timeout, 1-255"); | ||
51 | |||
38 | /********************************Register Map********************************/ | 52 | /********************************Register Map********************************/ |
39 | /** UART | 53 | /** UART |
40 | * | 54 | * |
@@ -128,6 +142,9 @@ | |||
128 | #define XUARTPS_IXR_RXEMPTY 0x00000002 /* RX FIFO empty interrupt. */ | 142 | #define XUARTPS_IXR_RXEMPTY 0x00000002 /* RX FIFO empty interrupt. */ |
129 | #define XUARTPS_IXR_MASK 0x00001FFF /* Valid bit mask */ | 143 | #define XUARTPS_IXR_MASK 0x00001FFF /* Valid bit mask */ |
130 | 144 | ||
145 | /* Goes in read_status_mask for break detection as the HW doesn't do it*/ | ||
146 | #define XUARTPS_IXR_BRK 0x80000000 | ||
147 | |||
131 | /** Channel Status Register | 148 | /** Channel Status Register |
132 | * | 149 | * |
133 | * The channel status register (CSR) is provided to enable the control logic | 150 | * The channel status register (CSR) is provided to enable the control logic |
@@ -139,15 +156,27 @@ | |||
139 | #define XUARTPS_SR_TXFULL 0x00000010 /* TX FIFO full */ | 156 | #define XUARTPS_SR_TXFULL 0x00000010 /* TX FIFO full */ |
140 | #define XUARTPS_SR_RXTRIG 0x00000001 /* Rx Trigger */ | 157 | #define XUARTPS_SR_RXTRIG 0x00000001 /* Rx Trigger */ |
141 | 158 | ||
159 | /* baud dividers min/max values */ | ||
160 | #define XUARTPS_BDIV_MIN 4 | ||
161 | #define XUARTPS_BDIV_MAX 255 | ||
162 | #define XUARTPS_CD_MAX 65535 | ||
163 | |||
142 | /** | 164 | /** |
143 | * struct xuartps - device data | 165 | * struct xuartps - device data |
144 | * @refclk Reference clock | 166 | * @port Pointer to the UART port |
145 | * @aperclk APB clock | 167 | * @refclk Reference clock |
168 | * @aperclk APB clock | ||
169 | * @baud Current baud rate | ||
170 | * @clk_rate_change_nb Notifier block for clock changes | ||
146 | */ | 171 | */ |
147 | struct xuartps { | 172 | struct xuartps { |
173 | struct uart_port *port; | ||
148 | struct clk *refclk; | 174 | struct clk *refclk; |
149 | struct clk *aperclk; | 175 | struct clk *aperclk; |
176 | unsigned int baud; | ||
177 | struct notifier_block clk_rate_change_nb; | ||
150 | }; | 178 | }; |
179 | #define to_xuartps(_nb) container_of(_nb, struct xuartps, clk_rate_change_nb); | ||
151 | 180 | ||
152 | /** | 181 | /** |
153 | * xuartps_isr - Interrupt handler | 182 | * xuartps_isr - Interrupt handler |
@@ -171,6 +200,23 @@ static irqreturn_t xuartps_isr(int irq, void *dev_id) | |||
171 | */ | 200 | */ |
172 | isrstatus = xuartps_readl(XUARTPS_ISR_OFFSET); | 201 | isrstatus = xuartps_readl(XUARTPS_ISR_OFFSET); |
173 | 202 | ||
203 | /* | ||
204 | * There is no hardware break detection, so we interpret framing | ||
205 | * error with all-zeros data as a break sequence. Most of the time, | ||
206 | * there's another non-zero byte at the end of the sequence. | ||
207 | */ | ||
208 | |||
209 | if (isrstatus & XUARTPS_IXR_FRAMING) { | ||
210 | while (!(xuartps_readl(XUARTPS_SR_OFFSET) & | ||
211 | XUARTPS_SR_RXEMPTY)) { | ||
212 | if (!xuartps_readl(XUARTPS_FIFO_OFFSET)) { | ||
213 | port->read_status_mask |= XUARTPS_IXR_BRK; | ||
214 | isrstatus &= ~XUARTPS_IXR_FRAMING; | ||
215 | } | ||
216 | } | ||
217 | xuartps_writel(XUARTPS_IXR_FRAMING, XUARTPS_ISR_OFFSET); | ||
218 | } | ||
219 | |||
174 | /* drop byte with parity error if IGNPAR specified */ | 220 | /* drop byte with parity error if IGNPAR specified */ |
175 | if (isrstatus & port->ignore_status_mask & XUARTPS_IXR_PARITY) | 221 | if (isrstatus & port->ignore_status_mask & XUARTPS_IXR_PARITY) |
176 | isrstatus &= ~(XUARTPS_IXR_RXTRIG | XUARTPS_IXR_TOUT); | 222 | isrstatus &= ~(XUARTPS_IXR_RXTRIG | XUARTPS_IXR_TOUT); |
@@ -184,6 +230,32 @@ static irqreturn_t xuartps_isr(int irq, void *dev_id) | |||
184 | while ((xuartps_readl(XUARTPS_SR_OFFSET) & | 230 | while ((xuartps_readl(XUARTPS_SR_OFFSET) & |
185 | XUARTPS_SR_RXEMPTY) != XUARTPS_SR_RXEMPTY) { | 231 | XUARTPS_SR_RXEMPTY) != XUARTPS_SR_RXEMPTY) { |
186 | data = xuartps_readl(XUARTPS_FIFO_OFFSET); | 232 | data = xuartps_readl(XUARTPS_FIFO_OFFSET); |
233 | |||
234 | /* Non-NULL byte after BREAK is garbage (99%) */ | ||
235 | if (data && (port->read_status_mask & | ||
236 | XUARTPS_IXR_BRK)) { | ||
237 | port->read_status_mask &= ~XUARTPS_IXR_BRK; | ||
238 | port->icount.brk++; | ||
239 | if (uart_handle_break(port)) | ||
240 | continue; | ||
241 | } | ||
242 | |||
243 | #ifdef SUPPORT_SYSRQ | ||
244 | /* | ||
245 | * uart_handle_sysrq_char() doesn't work if | ||
246 | * spinlocked, for some reason | ||
247 | */ | ||
248 | if (port->sysrq) { | ||
249 | spin_unlock(&port->lock); | ||
250 | if (uart_handle_sysrq_char(port, | ||
251 | (unsigned char)data)) { | ||
252 | spin_lock(&port->lock); | ||
253 | continue; | ||
254 | } | ||
255 | spin_lock(&port->lock); | ||
256 | } | ||
257 | #endif | ||
258 | |||
187 | port->icount.rx++; | 259 | port->icount.rx++; |
188 | 260 | ||
189 | if (isrstatus & XUARTPS_IXR_PARITY) { | 261 | if (isrstatus & XUARTPS_IXR_PARITY) { |
@@ -247,63 +319,196 @@ static irqreturn_t xuartps_isr(int irq, void *dev_id) | |||
247 | } | 319 | } |
248 | 320 | ||
249 | /** | 321 | /** |
250 | * xuartps_set_baud_rate - Calculate and set the baud rate | 322 | * xuartps_calc_baud_divs - Calculate baud rate divisors |
251 | * @port: Handle to the uart port structure | 323 | * @clk: UART module input clock |
252 | * @baud: Baud rate to set | 324 | * @baud: Desired baud rate |
253 | * | 325 | * @rbdiv: BDIV value (return value) |
326 | * @rcd: CD value (return value) | ||
327 | * @div8: Value for clk_sel bit in mod (return value) | ||
254 | * Returns baud rate, requested baud when possible, or actual baud when there | 328 | * Returns baud rate, requested baud when possible, or actual baud when there |
255 | * was too much error | 329 | * was too much error, zero if no valid divisors are found. |
256 | **/ | 330 | * |
257 | static unsigned int xuartps_set_baud_rate(struct uart_port *port, | 331 | * Formula to obtain baud rate is |
258 | unsigned int baud) | 332 | * baud_tx/rx rate = clk/CD * (BDIV + 1) |
333 | * input_clk = (Uart User Defined Clock or Apb Clock) | ||
334 | * depends on UCLKEN in MR Reg | ||
335 | * clk = input_clk or input_clk/8; | ||
336 | * depends on CLKS in MR reg | ||
337 | * CD and BDIV depends on values in | ||
338 | * baud rate generate register | ||
339 | * baud rate clock divisor register | ||
340 | */ | ||
341 | static unsigned int xuartps_calc_baud_divs(unsigned int clk, unsigned int baud, | ||
342 | u32 *rbdiv, u32 *rcd, int *div8) | ||
259 | { | 343 | { |
260 | unsigned int sel_clk; | 344 | u32 cd, bdiv; |
261 | unsigned int calc_baud = 0; | 345 | unsigned int calc_baud; |
262 | unsigned int brgr_val, brdiv_val; | 346 | unsigned int bestbaud = 0; |
263 | unsigned int bauderror; | 347 | unsigned int bauderror; |
348 | unsigned int besterror = ~0; | ||
264 | 349 | ||
265 | /* Formula to obtain baud rate is | 350 | if (baud < clk / ((XUARTPS_BDIV_MAX + 1) * XUARTPS_CD_MAX)) { |
266 | * baud_tx/rx rate = sel_clk/CD * (BDIV + 1) | 351 | *div8 = 1; |
267 | * input_clk = (Uart User Defined Clock or Apb Clock) | 352 | clk /= 8; |
268 | * depends on UCLKEN in MR Reg | 353 | } else { |
269 | * sel_clk = input_clk or input_clk/8; | 354 | *div8 = 0; |
270 | * depends on CLKS in MR reg | 355 | } |
271 | * CD and BDIV depends on values in | ||
272 | * baud rate generate register | ||
273 | * baud rate clock divisor register | ||
274 | */ | ||
275 | sel_clk = port->uartclk; | ||
276 | if (xuartps_readl(XUARTPS_MR_OFFSET) & XUARTPS_MR_CLKSEL) | ||
277 | sel_clk = sel_clk / 8; | ||
278 | |||
279 | /* Find the best values for baud generation */ | ||
280 | for (brdiv_val = 4; brdiv_val < 255; brdiv_val++) { | ||
281 | 356 | ||
282 | brgr_val = sel_clk / (baud * (brdiv_val + 1)); | 357 | for (bdiv = XUARTPS_BDIV_MIN; bdiv <= XUARTPS_BDIV_MAX; bdiv++) { |
283 | if (brgr_val < 2 || brgr_val > 65535) | 358 | cd = DIV_ROUND_CLOSEST(clk, baud * (bdiv + 1)); |
359 | if (cd < 1 || cd > XUARTPS_CD_MAX) | ||
284 | continue; | 360 | continue; |
285 | 361 | ||
286 | calc_baud = sel_clk / (brgr_val * (brdiv_val + 1)); | 362 | calc_baud = clk / (cd * (bdiv + 1)); |
287 | 363 | ||
288 | if (baud > calc_baud) | 364 | if (baud > calc_baud) |
289 | bauderror = baud - calc_baud; | 365 | bauderror = baud - calc_baud; |
290 | else | 366 | else |
291 | bauderror = calc_baud - baud; | 367 | bauderror = calc_baud - baud; |
292 | 368 | ||
293 | /* use the values when percent error is acceptable */ | 369 | if (besterror > bauderror) { |
294 | if (((bauderror * 100) / baud) < 3) { | 370 | *rbdiv = bdiv; |
295 | calc_baud = baud; | 371 | *rcd = cd; |
296 | break; | 372 | bestbaud = calc_baud; |
373 | besterror = bauderror; | ||
297 | } | 374 | } |
298 | } | 375 | } |
376 | /* use the values when percent error is acceptable */ | ||
377 | if (((besterror * 100) / baud) < 3) | ||
378 | bestbaud = baud; | ||
299 | 379 | ||
300 | /* Set the values for the new baud rate */ | 380 | return bestbaud; |
301 | xuartps_writel(brgr_val, XUARTPS_BAUDGEN_OFFSET); | 381 | } |
302 | xuartps_writel(brdiv_val, XUARTPS_BAUDDIV_OFFSET); | 382 | |
383 | /** | ||
384 | * xuartps_set_baud_rate - Calculate and set the baud rate | ||
385 | * @port: Handle to the uart port structure | ||
386 | * @baud: Baud rate to set | ||
387 | * Returns baud rate, requested baud when possible, or actual baud when there | ||
388 | * was too much error, zero if no valid divisors are found. | ||
389 | */ | ||
390 | static unsigned int xuartps_set_baud_rate(struct uart_port *port, | ||
391 | unsigned int baud) | ||
392 | { | ||
393 | unsigned int calc_baud; | ||
394 | u32 cd = 0, bdiv = 0; | ||
395 | u32 mreg; | ||
396 | int div8; | ||
397 | struct xuartps *xuartps = port->private_data; | ||
398 | |||
399 | calc_baud = xuartps_calc_baud_divs(port->uartclk, baud, &bdiv, &cd, | ||
400 | &div8); | ||
401 | |||
402 | /* Write new divisors to hardware */ | ||
403 | mreg = xuartps_readl(XUARTPS_MR_OFFSET); | ||
404 | if (div8) | ||
405 | mreg |= XUARTPS_MR_CLKSEL; | ||
406 | else | ||
407 | mreg &= ~XUARTPS_MR_CLKSEL; | ||
408 | xuartps_writel(mreg, XUARTPS_MR_OFFSET); | ||
409 | xuartps_writel(cd, XUARTPS_BAUDGEN_OFFSET); | ||
410 | xuartps_writel(bdiv, XUARTPS_BAUDDIV_OFFSET); | ||
411 | xuartps->baud = baud; | ||
303 | 412 | ||
304 | return calc_baud; | 413 | return calc_baud; |
305 | } | 414 | } |
306 | 415 | ||
416 | #ifdef CONFIG_COMMON_CLK | ||
417 | /** | ||
418 | * xuartps_clk_notitifer_cb - Clock notifier callback | ||
419 | * @nb: Notifier block | ||
420 | * @event: Notify event | ||
421 | * @data: Notifier data | ||
422 | * Returns NOTIFY_OK on success, NOTIFY_BAD on error. | ||
423 | */ | ||
424 | static int xuartps_clk_notifier_cb(struct notifier_block *nb, | ||
425 | unsigned long event, void *data) | ||
426 | { | ||
427 | u32 ctrl_reg; | ||
428 | struct uart_port *port; | ||
429 | int locked = 0; | ||
430 | struct clk_notifier_data *ndata = data; | ||
431 | unsigned long flags = 0; | ||
432 | struct xuartps *xuartps = to_xuartps(nb); | ||
433 | |||
434 | port = xuartps->port; | ||
435 | if (port->suspended) | ||
436 | return NOTIFY_OK; | ||
437 | |||
438 | switch (event) { | ||
439 | case PRE_RATE_CHANGE: | ||
440 | { | ||
441 | u32 bdiv; | ||
442 | u32 cd; | ||
443 | int div8; | ||
444 | |||
445 | /* | ||
446 | * Find out if current baud-rate can be achieved with new clock | ||
447 | * frequency. | ||
448 | */ | ||
449 | if (!xuartps_calc_baud_divs(ndata->new_rate, xuartps->baud, | ||
450 | &bdiv, &cd, &div8)) | ||
451 | return NOTIFY_BAD; | ||
452 | |||
453 | spin_lock_irqsave(&xuartps->port->lock, flags); | ||
454 | |||
455 | /* Disable the TX and RX to set baud rate */ | ||
456 | xuartps_writel(xuartps_readl(XUARTPS_CR_OFFSET) | | ||
457 | (XUARTPS_CR_TX_DIS | XUARTPS_CR_RX_DIS), | ||
458 | XUARTPS_CR_OFFSET); | ||
459 | |||
460 | spin_unlock_irqrestore(&xuartps->port->lock, flags); | ||
461 | |||
462 | return NOTIFY_OK; | ||
463 | } | ||
464 | case POST_RATE_CHANGE: | ||
465 | /* | ||
466 | * Set clk dividers to generate correct baud with new clock | ||
467 | * frequency. | ||
468 | */ | ||
469 | |||
470 | spin_lock_irqsave(&xuartps->port->lock, flags); | ||
471 | |||
472 | locked = 1; | ||
473 | port->uartclk = ndata->new_rate; | ||
474 | |||
475 | xuartps->baud = xuartps_set_baud_rate(xuartps->port, | ||
476 | xuartps->baud); | ||
477 | /* fall through */ | ||
478 | case ABORT_RATE_CHANGE: | ||
479 | if (!locked) | ||
480 | spin_lock_irqsave(&xuartps->port->lock, flags); | ||
481 | |||
482 | /* Set TX/RX Reset */ | ||
483 | xuartps_writel(xuartps_readl(XUARTPS_CR_OFFSET) | | ||
484 | (XUARTPS_CR_TXRST | XUARTPS_CR_RXRST), | ||
485 | XUARTPS_CR_OFFSET); | ||
486 | |||
487 | while (xuartps_readl(XUARTPS_CR_OFFSET) & | ||
488 | (XUARTPS_CR_TXRST | XUARTPS_CR_RXRST)) | ||
489 | cpu_relax(); | ||
490 | |||
491 | /* | ||
492 | * Clear the RX disable and TX disable bits and then set the TX | ||
493 | * enable bit and RX enable bit to enable the transmitter and | ||
494 | * receiver. | ||
495 | */ | ||
496 | xuartps_writel(rx_timeout, XUARTPS_RXTOUT_OFFSET); | ||
497 | ctrl_reg = xuartps_readl(XUARTPS_CR_OFFSET); | ||
498 | xuartps_writel( | ||
499 | (ctrl_reg & ~(XUARTPS_CR_TX_DIS | XUARTPS_CR_RX_DIS)) | | ||
500 | (XUARTPS_CR_TX_EN | XUARTPS_CR_RX_EN), | ||
501 | XUARTPS_CR_OFFSET); | ||
502 | |||
503 | spin_unlock_irqrestore(&xuartps->port->lock, flags); | ||
504 | |||
505 | return NOTIFY_OK; | ||
506 | default: | ||
507 | return NOTIFY_DONE; | ||
508 | } | ||
509 | } | ||
510 | #endif | ||
511 | |||
307 | /*----------------------Uart Operations---------------------------*/ | 512 | /*----------------------Uart Operations---------------------------*/ |
308 | 513 | ||
309 | /** | 514 | /** |
@@ -346,7 +551,7 @@ static void xuartps_start_tx(struct uart_port *port) | |||
346 | port->state->xmit.tail = (port->state->xmit.tail + 1) & | 551 | port->state->xmit.tail = (port->state->xmit.tail + 1) & |
347 | (UART_XMIT_SIZE - 1); | 552 | (UART_XMIT_SIZE - 1); |
348 | } | 553 | } |
349 | 554 | xuartps_writel(XUARTPS_IXR_TXEMPTY, XUARTPS_ISR_OFFSET); | |
350 | /* Enable the TX Empty interrupt */ | 555 | /* Enable the TX Empty interrupt */ |
351 | xuartps_writel(XUARTPS_IXR_TXEMPTY, XUARTPS_IER_OFFSET); | 556 | xuartps_writel(XUARTPS_IXR_TXEMPTY, XUARTPS_IER_OFFSET); |
352 | 557 | ||
@@ -437,7 +642,7 @@ static void xuartps_set_termios(struct uart_port *port, | |||
437 | struct ktermios *termios, struct ktermios *old) | 642 | struct ktermios *termios, struct ktermios *old) |
438 | { | 643 | { |
439 | unsigned int cval = 0; | 644 | unsigned int cval = 0; |
440 | unsigned int baud; | 645 | unsigned int baud, minbaud, maxbaud; |
441 | unsigned long flags; | 646 | unsigned long flags; |
442 | unsigned int ctrl_reg, mode_reg; | 647 | unsigned int ctrl_reg, mode_reg; |
443 | 648 | ||
@@ -454,8 +659,14 @@ static void xuartps_set_termios(struct uart_port *port, | |||
454 | (XUARTPS_CR_TX_DIS | XUARTPS_CR_RX_DIS), | 659 | (XUARTPS_CR_TX_DIS | XUARTPS_CR_RX_DIS), |
455 | XUARTPS_CR_OFFSET); | 660 | XUARTPS_CR_OFFSET); |
456 | 661 | ||
457 | /* Min baud rate = 6bps and Max Baud Rate is 10Mbps for 100Mhz clk */ | 662 | /* |
458 | baud = uart_get_baud_rate(port, termios, old, 0, 10000000); | 663 | * Min baud rate = 6bps and Max Baud Rate is 10Mbps for 100Mhz clk |
664 | * min and max baud should be calculated here based on port->uartclk. | ||
665 | * this way we get a valid baud and can safely call set_baud() | ||
666 | */ | ||
667 | minbaud = port->uartclk / ((XUARTPS_BDIV_MAX + 1) * XUARTPS_CD_MAX * 8); | ||
668 | maxbaud = port->uartclk / (XUARTPS_BDIV_MIN + 1); | ||
669 | baud = uart_get_baud_rate(port, termios, old, minbaud, maxbaud); | ||
459 | baud = xuartps_set_baud_rate(port, baud); | 670 | baud = xuartps_set_baud_rate(port, baud); |
460 | if (tty_termios_baud_rate(termios)) | 671 | if (tty_termios_baud_rate(termios)) |
461 | tty_termios_encode_baud_rate(termios, baud, baud); | 672 | tty_termios_encode_baud_rate(termios, baud, baud); |
@@ -480,7 +691,7 @@ static void xuartps_set_termios(struct uart_port *port, | |||
480 | | (XUARTPS_CR_TX_EN | XUARTPS_CR_RX_EN), | 691 | | (XUARTPS_CR_TX_EN | XUARTPS_CR_RX_EN), |
481 | XUARTPS_CR_OFFSET); | 692 | XUARTPS_CR_OFFSET); |
482 | 693 | ||
483 | xuartps_writel(10, XUARTPS_RXTOUT_OFFSET); | 694 | xuartps_writel(rx_timeout, XUARTPS_RXTOUT_OFFSET); |
484 | 695 | ||
485 | port->read_status_mask = XUARTPS_IXR_TXEMPTY | XUARTPS_IXR_RXTRIG | | 696 | port->read_status_mask = XUARTPS_IXR_TXEMPTY | XUARTPS_IXR_RXTRIG | |
486 | XUARTPS_IXR_OVERRUN | XUARTPS_IXR_TOUT; | 697 | XUARTPS_IXR_OVERRUN | XUARTPS_IXR_TOUT; |
@@ -531,13 +742,17 @@ static void xuartps_set_termios(struct uart_port *port, | |||
531 | cval |= XUARTPS_MR_PARITY_MARK; | 742 | cval |= XUARTPS_MR_PARITY_MARK; |
532 | else | 743 | else |
533 | cval |= XUARTPS_MR_PARITY_SPACE; | 744 | cval |= XUARTPS_MR_PARITY_SPACE; |
534 | } else if (termios->c_cflag & PARODD) | 745 | } else { |
746 | if (termios->c_cflag & PARODD) | ||
535 | cval |= XUARTPS_MR_PARITY_ODD; | 747 | cval |= XUARTPS_MR_PARITY_ODD; |
536 | else | 748 | else |
537 | cval |= XUARTPS_MR_PARITY_EVEN; | 749 | cval |= XUARTPS_MR_PARITY_EVEN; |
538 | } else | 750 | } |
751 | } else { | ||
539 | cval |= XUARTPS_MR_PARITY_NONE; | 752 | cval |= XUARTPS_MR_PARITY_NONE; |
540 | xuartps_writel(cval , XUARTPS_MR_OFFSET); | 753 | } |
754 | cval |= mode_reg & 1; | ||
755 | xuartps_writel(cval, XUARTPS_MR_OFFSET); | ||
541 | 756 | ||
542 | spin_unlock_irqrestore(&port->lock, flags); | 757 | spin_unlock_irqrestore(&port->lock, flags); |
543 | } | 758 | } |
@@ -583,11 +798,17 @@ static int xuartps_startup(struct uart_port *port) | |||
583 | | XUARTPS_MR_PARITY_NONE | XUARTPS_MR_CHARLEN_8_BIT, | 798 | | XUARTPS_MR_PARITY_NONE | XUARTPS_MR_CHARLEN_8_BIT, |
584 | XUARTPS_MR_OFFSET); | 799 | XUARTPS_MR_OFFSET); |
585 | 800 | ||
586 | /* Set the RX FIFO Trigger level to 14 assuming FIFO size as 16 */ | 801 | /* |
587 | xuartps_writel(14, XUARTPS_RXWM_OFFSET); | 802 | * Set the RX FIFO Trigger level to use most of the FIFO, but it |
803 | * can be tuned with a module parameter | ||
804 | */ | ||
805 | xuartps_writel(rx_trigger_level, XUARTPS_RXWM_OFFSET); | ||
588 | 806 | ||
589 | /* Receive Timeout register is enabled with value of 10 */ | 807 | /* |
590 | xuartps_writel(10, XUARTPS_RXTOUT_OFFSET); | 808 | * Receive Timeout register is enabled but it |
809 | * can be tuned with a module parameter | ||
810 | */ | ||
811 | xuartps_writel(rx_timeout, XUARTPS_RXTOUT_OFFSET); | ||
591 | 812 | ||
592 | /* Clear out any pending interrupts before enabling them */ | 813 | /* Clear out any pending interrupts before enabling them */ |
593 | xuartps_writel(xuartps_readl(XUARTPS_ISR_OFFSET), XUARTPS_ISR_OFFSET); | 814 | xuartps_writel(xuartps_readl(XUARTPS_ISR_OFFSET), XUARTPS_ISR_OFFSET); |
@@ -727,6 +948,54 @@ static void xuartps_enable_ms(struct uart_port *port) | |||
727 | /* N/A */ | 948 | /* N/A */ |
728 | } | 949 | } |
729 | 950 | ||
951 | #ifdef CONFIG_CONSOLE_POLL | ||
952 | static int xuartps_poll_get_char(struct uart_port *port) | ||
953 | { | ||
954 | u32 imr; | ||
955 | int c; | ||
956 | |||
957 | /* Disable all interrupts */ | ||
958 | imr = xuartps_readl(XUARTPS_IMR_OFFSET); | ||
959 | xuartps_writel(imr, XUARTPS_IDR_OFFSET); | ||
960 | |||
961 | /* Check if FIFO is empty */ | ||
962 | if (xuartps_readl(XUARTPS_SR_OFFSET) & XUARTPS_SR_RXEMPTY) | ||
963 | c = NO_POLL_CHAR; | ||
964 | else /* Read a character */ | ||
965 | c = (unsigned char) xuartps_readl(XUARTPS_FIFO_OFFSET); | ||
966 | |||
967 | /* Enable interrupts */ | ||
968 | xuartps_writel(imr, XUARTPS_IER_OFFSET); | ||
969 | |||
970 | return c; | ||
971 | } | ||
972 | |||
973 | static void xuartps_poll_put_char(struct uart_port *port, unsigned char c) | ||
974 | { | ||
975 | u32 imr; | ||
976 | |||
977 | /* Disable all interrupts */ | ||
978 | imr = xuartps_readl(XUARTPS_IMR_OFFSET); | ||
979 | xuartps_writel(imr, XUARTPS_IDR_OFFSET); | ||
980 | |||
981 | /* Wait until FIFO is empty */ | ||
982 | while (!(xuartps_readl(XUARTPS_SR_OFFSET) & XUARTPS_SR_TXEMPTY)) | ||
983 | cpu_relax(); | ||
984 | |||
985 | /* Write a character */ | ||
986 | xuartps_writel(c, XUARTPS_FIFO_OFFSET); | ||
987 | |||
988 | /* Wait until FIFO is empty */ | ||
989 | while (!(xuartps_readl(XUARTPS_SR_OFFSET) & XUARTPS_SR_TXEMPTY)) | ||
990 | cpu_relax(); | ||
991 | |||
992 | /* Enable interrupts */ | ||
993 | xuartps_writel(imr, XUARTPS_IER_OFFSET); | ||
994 | |||
995 | return; | ||
996 | } | ||
997 | #endif | ||
998 | |||
730 | /** The UART operations structure | 999 | /** The UART operations structure |
731 | */ | 1000 | */ |
732 | static struct uart_ops xuartps_ops = { | 1001 | static struct uart_ops xuartps_ops = { |
@@ -759,6 +1028,10 @@ static struct uart_ops xuartps_ops = { | |||
759 | .config_port = xuartps_config_port, /* Configure when driver | 1028 | .config_port = xuartps_config_port, /* Configure when driver |
760 | * adds a xuartps port | 1029 | * adds a xuartps port |
761 | */ | 1030 | */ |
1031 | #ifdef CONFIG_CONSOLE_POLL | ||
1032 | .poll_get_char = xuartps_poll_get_char, | ||
1033 | .poll_put_char = xuartps_poll_put_char, | ||
1034 | #endif | ||
762 | }; | 1035 | }; |
763 | 1036 | ||
764 | static struct uart_port xuartps_port[2]; | 1037 | static struct uart_port xuartps_port[2]; |
@@ -837,7 +1110,7 @@ static void xuartps_console_write(struct console *co, const char *s, | |||
837 | { | 1110 | { |
838 | struct uart_port *port = &xuartps_port[co->index]; | 1111 | struct uart_port *port = &xuartps_port[co->index]; |
839 | unsigned long flags; | 1112 | unsigned long flags; |
840 | unsigned int imr; | 1113 | unsigned int imr, ctrl; |
841 | int locked = 1; | 1114 | int locked = 1; |
842 | 1115 | ||
843 | if (oops_in_progress) | 1116 | if (oops_in_progress) |
@@ -849,9 +1122,19 @@ static void xuartps_console_write(struct console *co, const char *s, | |||
849 | imr = xuartps_readl(XUARTPS_IMR_OFFSET); | 1122 | imr = xuartps_readl(XUARTPS_IMR_OFFSET); |
850 | xuartps_writel(imr, XUARTPS_IDR_OFFSET); | 1123 | xuartps_writel(imr, XUARTPS_IDR_OFFSET); |
851 | 1124 | ||
1125 | /* | ||
1126 | * Make sure that the tx part is enabled. Set the TX enable bit and | ||
1127 | * clear the TX disable bit to enable the transmitter. | ||
1128 | */ | ||
1129 | ctrl = xuartps_readl(XUARTPS_CR_OFFSET); | ||
1130 | xuartps_writel((ctrl & ~XUARTPS_CR_TX_DIS) | XUARTPS_CR_TX_EN, | ||
1131 | XUARTPS_CR_OFFSET); | ||
1132 | |||
852 | uart_console_write(port, s, count, xuartps_console_putchar); | 1133 | uart_console_write(port, s, count, xuartps_console_putchar); |
853 | xuartps_console_wait_tx(port); | 1134 | xuartps_console_wait_tx(port); |
854 | 1135 | ||
1136 | xuartps_writel(ctrl, XUARTPS_CR_OFFSET); | ||
1137 | |||
855 | /* restore interrupt state, it seems like there may be a h/w bug | 1138 | /* restore interrupt state, it seems like there may be a h/w bug |
856 | * in that the interrupt enable register should not need to be | 1139 | * in that the interrupt enable register should not need to be |
857 | * written based on the data sheet | 1140 | * written based on the data sheet |
@@ -933,6 +1216,119 @@ static struct uart_driver xuartps_uart_driver = { | |||
933 | #endif | 1216 | #endif |
934 | }; | 1217 | }; |
935 | 1218 | ||
1219 | #ifdef CONFIG_PM_SLEEP | ||
1220 | /** | ||
1221 | * xuartps_suspend - suspend event | ||
1222 | * @device: Pointer to the device structure | ||
1223 | * | ||
1224 | * Returns 0 | ||
1225 | */ | ||
1226 | static int xuartps_suspend(struct device *device) | ||
1227 | { | ||
1228 | struct uart_port *port = dev_get_drvdata(device); | ||
1229 | struct tty_struct *tty; | ||
1230 | struct device *tty_dev; | ||
1231 | int may_wake = 0; | ||
1232 | |||
1233 | /* Get the tty which could be NULL so don't assume it's valid */ | ||
1234 | tty = tty_port_tty_get(&port->state->port); | ||
1235 | if (tty) { | ||
1236 | tty_dev = tty->dev; | ||
1237 | may_wake = device_may_wakeup(tty_dev); | ||
1238 | tty_kref_put(tty); | ||
1239 | } | ||
1240 | |||
1241 | /* | ||
1242 | * Call the API provided in serial_core.c file which handles | ||
1243 | * the suspend. | ||
1244 | */ | ||
1245 | uart_suspend_port(&xuartps_uart_driver, port); | ||
1246 | if (console_suspend_enabled && !may_wake) { | ||
1247 | struct xuartps *xuartps = port->private_data; | ||
1248 | |||
1249 | clk_disable(xuartps->refclk); | ||
1250 | clk_disable(xuartps->aperclk); | ||
1251 | } else { | ||
1252 | unsigned long flags = 0; | ||
1253 | |||
1254 | spin_lock_irqsave(&port->lock, flags); | ||
1255 | /* Empty the receive FIFO 1st before making changes */ | ||
1256 | while (!(xuartps_readl(XUARTPS_SR_OFFSET) & XUARTPS_SR_RXEMPTY)) | ||
1257 | xuartps_readl(XUARTPS_FIFO_OFFSET); | ||
1258 | /* set RX trigger level to 1 */ | ||
1259 | xuartps_writel(1, XUARTPS_RXWM_OFFSET); | ||
1260 | /* disable RX timeout interrups */ | ||
1261 | xuartps_writel(XUARTPS_IXR_TOUT, XUARTPS_IDR_OFFSET); | ||
1262 | spin_unlock_irqrestore(&port->lock, flags); | ||
1263 | } | ||
1264 | |||
1265 | return 0; | ||
1266 | } | ||
1267 | |||
1268 | /** | ||
1269 | * xuartps_resume - Resume after a previous suspend | ||
1270 | * @device: Pointer to the device structure | ||
1271 | * | ||
1272 | * Returns 0 | ||
1273 | */ | ||
1274 | static int xuartps_resume(struct device *device) | ||
1275 | { | ||
1276 | struct uart_port *port = dev_get_drvdata(device); | ||
1277 | unsigned long flags = 0; | ||
1278 | u32 ctrl_reg; | ||
1279 | struct tty_struct *tty; | ||
1280 | struct device *tty_dev; | ||
1281 | int may_wake = 0; | ||
1282 | |||
1283 | /* Get the tty which could be NULL so don't assume it's valid */ | ||
1284 | tty = tty_port_tty_get(&port->state->port); | ||
1285 | if (tty) { | ||
1286 | tty_dev = tty->dev; | ||
1287 | may_wake = device_may_wakeup(tty_dev); | ||
1288 | tty_kref_put(tty); | ||
1289 | } | ||
1290 | |||
1291 | if (console_suspend_enabled && !may_wake) { | ||
1292 | struct xuartps *xuartps = port->private_data; | ||
1293 | |||
1294 | clk_enable(xuartps->aperclk); | ||
1295 | clk_enable(xuartps->refclk); | ||
1296 | |||
1297 | spin_lock_irqsave(&port->lock, flags); | ||
1298 | |||
1299 | /* Set TX/RX Reset */ | ||
1300 | xuartps_writel(xuartps_readl(XUARTPS_CR_OFFSET) | | ||
1301 | (XUARTPS_CR_TXRST | XUARTPS_CR_RXRST), | ||
1302 | XUARTPS_CR_OFFSET); | ||
1303 | while (xuartps_readl(XUARTPS_CR_OFFSET) & | ||
1304 | (XUARTPS_CR_TXRST | XUARTPS_CR_RXRST)) | ||
1305 | cpu_relax(); | ||
1306 | |||
1307 | /* restore rx timeout value */ | ||
1308 | xuartps_writel(rx_timeout, XUARTPS_RXTOUT_OFFSET); | ||
1309 | /* Enable Tx/Rx */ | ||
1310 | ctrl_reg = xuartps_readl(XUARTPS_CR_OFFSET); | ||
1311 | xuartps_writel( | ||
1312 | (ctrl_reg & ~(XUARTPS_CR_TX_DIS | XUARTPS_CR_RX_DIS)) | | ||
1313 | (XUARTPS_CR_TX_EN | XUARTPS_CR_RX_EN), | ||
1314 | XUARTPS_CR_OFFSET); | ||
1315 | |||
1316 | spin_unlock_irqrestore(&port->lock, flags); | ||
1317 | } else { | ||
1318 | spin_lock_irqsave(&port->lock, flags); | ||
1319 | /* restore original rx trigger level */ | ||
1320 | xuartps_writel(rx_trigger_level, XUARTPS_RXWM_OFFSET); | ||
1321 | /* enable RX timeout interrupt */ | ||
1322 | xuartps_writel(XUARTPS_IXR_TOUT, XUARTPS_IER_OFFSET); | ||
1323 | spin_unlock_irqrestore(&port->lock, flags); | ||
1324 | } | ||
1325 | |||
1326 | return uart_resume_port(&xuartps_uart_driver, port); | ||
1327 | } | ||
1328 | #endif /* ! CONFIG_PM_SLEEP */ | ||
1329 | |||
1330 | static SIMPLE_DEV_PM_OPS(xuartps_dev_pm_ops, xuartps_suspend, xuartps_resume); | ||
1331 | |||
936 | /* --------------------------------------------------------------------- | 1332 | /* --------------------------------------------------------------------- |
937 | * Platform bus binding | 1333 | * Platform bus binding |
938 | */ | 1334 | */ |
@@ -949,27 +1345,26 @@ static int xuartps_probe(struct platform_device *pdev) | |||
949 | struct resource *res, *res2; | 1345 | struct resource *res, *res2; |
950 | struct xuartps *xuartps_data; | 1346 | struct xuartps *xuartps_data; |
951 | 1347 | ||
952 | xuartps_data = kzalloc(sizeof(*xuartps_data), GFP_KERNEL); | 1348 | xuartps_data = devm_kzalloc(&pdev->dev, sizeof(*xuartps_data), |
1349 | GFP_KERNEL); | ||
953 | if (!xuartps_data) | 1350 | if (!xuartps_data) |
954 | return -ENOMEM; | 1351 | return -ENOMEM; |
955 | 1352 | ||
956 | xuartps_data->aperclk = clk_get(&pdev->dev, "aper_clk"); | 1353 | xuartps_data->aperclk = devm_clk_get(&pdev->dev, "aper_clk"); |
957 | if (IS_ERR(xuartps_data->aperclk)) { | 1354 | if (IS_ERR(xuartps_data->aperclk)) { |
958 | dev_err(&pdev->dev, "aper_clk clock not found.\n"); | 1355 | dev_err(&pdev->dev, "aper_clk clock not found.\n"); |
959 | rc = PTR_ERR(xuartps_data->aperclk); | 1356 | return PTR_ERR(xuartps_data->aperclk); |
960 | goto err_out_free; | ||
961 | } | 1357 | } |
962 | xuartps_data->refclk = clk_get(&pdev->dev, "ref_clk"); | 1358 | xuartps_data->refclk = devm_clk_get(&pdev->dev, "ref_clk"); |
963 | if (IS_ERR(xuartps_data->refclk)) { | 1359 | if (IS_ERR(xuartps_data->refclk)) { |
964 | dev_err(&pdev->dev, "ref_clk clock not found.\n"); | 1360 | dev_err(&pdev->dev, "ref_clk clock not found.\n"); |
965 | rc = PTR_ERR(xuartps_data->refclk); | 1361 | return PTR_ERR(xuartps_data->refclk); |
966 | goto err_out_clk_put_aper; | ||
967 | } | 1362 | } |
968 | 1363 | ||
969 | rc = clk_prepare_enable(xuartps_data->aperclk); | 1364 | rc = clk_prepare_enable(xuartps_data->aperclk); |
970 | if (rc) { | 1365 | if (rc) { |
971 | dev_err(&pdev->dev, "Unable to enable APER clock.\n"); | 1366 | dev_err(&pdev->dev, "Unable to enable APER clock.\n"); |
972 | goto err_out_clk_put; | 1367 | return rc; |
973 | } | 1368 | } |
974 | rc = clk_prepare_enable(xuartps_data->refclk); | 1369 | rc = clk_prepare_enable(xuartps_data->refclk); |
975 | if (rc) { | 1370 | if (rc) { |
@@ -989,13 +1384,21 @@ static int xuartps_probe(struct platform_device *pdev) | |||
989 | goto err_out_clk_disable; | 1384 | goto err_out_clk_disable; |
990 | } | 1385 | } |
991 | 1386 | ||
1387 | #ifdef CONFIG_COMMON_CLK | ||
1388 | xuartps_data->clk_rate_change_nb.notifier_call = | ||
1389 | xuartps_clk_notifier_cb; | ||
1390 | if (clk_notifier_register(xuartps_data->refclk, | ||
1391 | &xuartps_data->clk_rate_change_nb)) | ||
1392 | dev_warn(&pdev->dev, "Unable to register clock notifier.\n"); | ||
1393 | #endif | ||
1394 | |||
992 | /* Initialize the port structure */ | 1395 | /* Initialize the port structure */ |
993 | port = xuartps_get_port(); | 1396 | port = xuartps_get_port(); |
994 | 1397 | ||
995 | if (!port) { | 1398 | if (!port) { |
996 | dev_err(&pdev->dev, "Cannot get uart_port structure\n"); | 1399 | dev_err(&pdev->dev, "Cannot get uart_port structure\n"); |
997 | rc = -ENODEV; | 1400 | rc = -ENODEV; |
998 | goto err_out_clk_disable; | 1401 | goto err_out_notif_unreg; |
999 | } else { | 1402 | } else { |
1000 | /* Register the port. | 1403 | /* Register the port. |
1001 | * This function also registers this device with the tty layer | 1404 | * This function also registers this device with the tty layer |
@@ -1006,26 +1409,26 @@ static int xuartps_probe(struct platform_device *pdev) | |||
1006 | port->dev = &pdev->dev; | 1409 | port->dev = &pdev->dev; |
1007 | port->uartclk = clk_get_rate(xuartps_data->refclk); | 1410 | port->uartclk = clk_get_rate(xuartps_data->refclk); |
1008 | port->private_data = xuartps_data; | 1411 | port->private_data = xuartps_data; |
1412 | xuartps_data->port = port; | ||
1009 | platform_set_drvdata(pdev, port); | 1413 | platform_set_drvdata(pdev, port); |
1010 | rc = uart_add_one_port(&xuartps_uart_driver, port); | 1414 | rc = uart_add_one_port(&xuartps_uart_driver, port); |
1011 | if (rc) { | 1415 | if (rc) { |
1012 | dev_err(&pdev->dev, | 1416 | dev_err(&pdev->dev, |
1013 | "uart_add_one_port() failed; err=%i\n", rc); | 1417 | "uart_add_one_port() failed; err=%i\n", rc); |
1014 | goto err_out_clk_disable; | 1418 | goto err_out_notif_unreg; |
1015 | } | 1419 | } |
1016 | return 0; | 1420 | return 0; |
1017 | } | 1421 | } |
1018 | 1422 | ||
1423 | err_out_notif_unreg: | ||
1424 | #ifdef CONFIG_COMMON_CLK | ||
1425 | clk_notifier_unregister(xuartps_data->refclk, | ||
1426 | &xuartps_data->clk_rate_change_nb); | ||
1427 | #endif | ||
1019 | err_out_clk_disable: | 1428 | err_out_clk_disable: |
1020 | clk_disable_unprepare(xuartps_data->refclk); | 1429 | clk_disable_unprepare(xuartps_data->refclk); |
1021 | err_out_clk_dis_aper: | 1430 | err_out_clk_dis_aper: |
1022 | clk_disable_unprepare(xuartps_data->aperclk); | 1431 | clk_disable_unprepare(xuartps_data->aperclk); |
1023 | err_out_clk_put: | ||
1024 | clk_put(xuartps_data->refclk); | ||
1025 | err_out_clk_put_aper: | ||
1026 | clk_put(xuartps_data->aperclk); | ||
1027 | err_out_free: | ||
1028 | kfree(xuartps_data); | ||
1029 | 1432 | ||
1030 | return rc; | 1433 | return rc; |
1031 | } | 1434 | } |
@@ -1043,13 +1446,14 @@ static int xuartps_remove(struct platform_device *pdev) | |||
1043 | int rc; | 1446 | int rc; |
1044 | 1447 | ||
1045 | /* Remove the xuartps port from the serial core */ | 1448 | /* Remove the xuartps port from the serial core */ |
1449 | #ifdef CONFIG_COMMON_CLK | ||
1450 | clk_notifier_unregister(xuartps_data->refclk, | ||
1451 | &xuartps_data->clk_rate_change_nb); | ||
1452 | #endif | ||
1046 | rc = uart_remove_one_port(&xuartps_uart_driver, port); | 1453 | rc = uart_remove_one_port(&xuartps_uart_driver, port); |
1047 | port->mapbase = 0; | 1454 | port->mapbase = 0; |
1048 | clk_disable_unprepare(xuartps_data->refclk); | 1455 | clk_disable_unprepare(xuartps_data->refclk); |
1049 | clk_disable_unprepare(xuartps_data->aperclk); | 1456 | clk_disable_unprepare(xuartps_data->aperclk); |
1050 | clk_put(xuartps_data->refclk); | ||
1051 | clk_put(xuartps_data->aperclk); | ||
1052 | kfree(xuartps_data); | ||
1053 | return rc; | 1457 | return rc; |
1054 | } | 1458 | } |
1055 | 1459 | ||
@@ -1067,6 +1471,7 @@ static struct platform_driver xuartps_platform_driver = { | |||
1067 | .owner = THIS_MODULE, | 1471 | .owner = THIS_MODULE, |
1068 | .name = XUARTPS_NAME, /* Driver name */ | 1472 | .name = XUARTPS_NAME, /* Driver name */ |
1069 | .of_match_table = xuartps_of_match, | 1473 | .of_match_table = xuartps_of_match, |
1474 | .pm = &xuartps_dev_pm_ops, | ||
1070 | }, | 1475 | }, |
1071 | }; | 1476 | }; |
1072 | 1477 | ||
diff --git a/drivers/tty/sysrq.c b/drivers/tty/sysrq.c index 40a9fe9d3b10..ce396ecdf412 100644 --- a/drivers/tty/sysrq.c +++ b/drivers/tty/sysrq.c | |||
@@ -51,7 +51,7 @@ | |||
51 | #include <asm/irq_regs.h> | 51 | #include <asm/irq_regs.h> |
52 | 52 | ||
53 | /* Whether we react on sysrq keys or just ignore them */ | 53 | /* Whether we react on sysrq keys or just ignore them */ |
54 | static int __read_mostly sysrq_enabled = SYSRQ_DEFAULT_ENABLE; | 54 | static int __read_mostly sysrq_enabled = CONFIG_MAGIC_SYSRQ_DEFAULT_ENABLE; |
55 | static bool __read_mostly sysrq_always_enabled; | 55 | static bool __read_mostly sysrq_always_enabled; |
56 | 56 | ||
57 | unsigned short platform_sysrq_reset_seq[] __weak = { KEY_RESERVED }; | 57 | unsigned short platform_sysrq_reset_seq[] __weak = { KEY_RESERVED }; |
diff --git a/drivers/tty/tty_io.c b/drivers/tty/tty_io.c index 3a1a01af9a80..c74a00ad7add 100644 --- a/drivers/tty/tty_io.c +++ b/drivers/tty/tty_io.c | |||
@@ -2086,6 +2086,7 @@ retry_open: | |||
2086 | filp->f_op = &tty_fops; | 2086 | filp->f_op = &tty_fops; |
2087 | goto retry_open; | 2087 | goto retry_open; |
2088 | } | 2088 | } |
2089 | clear_bit(TTY_HUPPED, &tty->flags); | ||
2089 | tty_unlock(tty); | 2090 | tty_unlock(tty); |
2090 | 2091 | ||
2091 | 2092 | ||
diff --git a/drivers/tty/tty_ldsem.c b/drivers/tty/tty_ldsem.c index 22fad8ad5ac2..d8a55e87877f 100644 --- a/drivers/tty/tty_ldsem.c +++ b/drivers/tty/tty_ldsem.c | |||
@@ -86,11 +86,21 @@ static inline long ldsem_atomic_update(long delta, struct ld_semaphore *sem) | |||
86 | return atomic_long_add_return(delta, (atomic_long_t *)&sem->count); | 86 | return atomic_long_add_return(delta, (atomic_long_t *)&sem->count); |
87 | } | 87 | } |
88 | 88 | ||
89 | /* | ||
90 | * ldsem_cmpxchg() updates @*old with the last-known sem->count value. | ||
91 | * Returns 1 if count was successfully changed; @*old will have @new value. | ||
92 | * Returns 0 if count was not changed; @*old will have most recent sem->count | ||
93 | */ | ||
89 | static inline int ldsem_cmpxchg(long *old, long new, struct ld_semaphore *sem) | 94 | static inline int ldsem_cmpxchg(long *old, long new, struct ld_semaphore *sem) |
90 | { | 95 | { |
91 | long tmp = *old; | 96 | long tmp = atomic_long_cmpxchg(&sem->count, *old, new); |
92 | *old = atomic_long_cmpxchg(&sem->count, *old, new); | 97 | if (tmp == *old) { |
93 | return *old == tmp; | 98 | *old = new; |
99 | return 1; | ||
100 | } else { | ||
101 | *old = tmp; | ||
102 | return 0; | ||
103 | } | ||
94 | } | 104 | } |
95 | 105 | ||
96 | /* | 106 | /* |
diff --git a/drivers/tty/tty_port.c b/drivers/tty/tty_port.c index f597e88a705d..c94d2349dd06 100644 --- a/drivers/tty/tty_port.c +++ b/drivers/tty/tty_port.c | |||
@@ -140,6 +140,10 @@ EXPORT_SYMBOL(tty_port_destroy); | |||
140 | static void tty_port_destructor(struct kref *kref) | 140 | static void tty_port_destructor(struct kref *kref) |
141 | { | 141 | { |
142 | struct tty_port *port = container_of(kref, struct tty_port, kref); | 142 | struct tty_port *port = container_of(kref, struct tty_port, kref); |
143 | |||
144 | /* check if last port ref was dropped before tty release */ | ||
145 | if (WARN_ON(port->itty)) | ||
146 | return; | ||
143 | if (port->xmit_buf) | 147 | if (port->xmit_buf) |
144 | free_page((unsigned long)port->xmit_buf); | 148 | free_page((unsigned long)port->xmit_buf); |
145 | tty_port_destroy(port); | 149 | tty_port_destroy(port); |
@@ -480,8 +484,6 @@ int tty_port_close_start(struct tty_port *port, | |||
480 | 484 | ||
481 | if (port->count) { | 485 | if (port->count) { |
482 | spin_unlock_irqrestore(&port->lock, flags); | 486 | spin_unlock_irqrestore(&port->lock, flags); |
483 | if (port->ops->drop) | ||
484 | port->ops->drop(port); | ||
485 | return 0; | 487 | return 0; |
486 | } | 488 | } |
487 | set_bit(ASYNCB_CLOSING, &port->flags); | 489 | set_bit(ASYNCB_CLOSING, &port->flags); |
@@ -500,9 +502,7 @@ int tty_port_close_start(struct tty_port *port, | |||
500 | /* Flush the ldisc buffering */ | 502 | /* Flush the ldisc buffering */ |
501 | tty_ldisc_flush(tty); | 503 | tty_ldisc_flush(tty); |
502 | 504 | ||
503 | /* Don't call port->drop for the last reference. Callers will want | 505 | /* Report to caller this is the last port reference */ |
504 | to drop the last active reference in ->shutdown() or the tty | ||
505 | shutdown path */ | ||
506 | return 1; | 506 | return 1; |
507 | } | 507 | } |
508 | EXPORT_SYMBOL(tty_port_close_start); | 508 | EXPORT_SYMBOL(tty_port_close_start); |
diff --git a/drivers/tty/vt/vt.c b/drivers/tty/vt/vt.c index 9a8e8c5a0c73..61b1137d7e56 100644 --- a/drivers/tty/vt/vt.c +++ b/drivers/tty/vt/vt.c | |||
@@ -1300,21 +1300,30 @@ static void csi_m(struct vc_data *vc) | |||
1300 | case 27: | 1300 | case 27: |
1301 | vc->vc_reverse = 0; | 1301 | vc->vc_reverse = 0; |
1302 | break; | 1302 | break; |
1303 | case 38: /* ANSI X3.64-1979 (SCO-ish?) | 1303 | case 38: |
1304 | * Enables underscore, white foreground | 1304 | case 48: /* ITU T.416 |
1305 | * with white underscore (Linux - use | 1305 | * Higher colour modes. |
1306 | * default foreground). | 1306 | * They break the usual properties of SGR codes |
1307 | * and thus need to be detected and ignored by | ||
1308 | * hand. Strictly speaking, that standard also | ||
1309 | * wants : rather than ; as separators, contrary | ||
1310 | * to ECMA-48, but no one produces such codes | ||
1311 | * and almost no one accepts them. | ||
1307 | */ | 1312 | */ |
1308 | vc->vc_color = (vc->vc_def_color & 0x0f) | (vc->vc_color & 0xf0); | 1313 | i++; |
1309 | vc->vc_underline = 1; | 1314 | if (i > vc->vc_npar) |
1315 | break; | ||
1316 | if (vc->vc_par[i] == 5) /* 256 colours */ | ||
1317 | i++; /* ubiquitous */ | ||
1318 | else if (vc->vc_par[i] == 2) /* 24 bit colours */ | ||
1319 | i += 3; /* extremely rare */ | ||
1320 | /* Subcommands 3 (CMY) and 4 (CMYK) are so insane | ||
1321 | * that detecting them is not worth the few extra | ||
1322 | * bytes of kernel's size. | ||
1323 | */ | ||
1310 | break; | 1324 | break; |
1311 | case 39: /* ANSI X3.64-1979 (SCO-ish?) | 1325 | case 39: |
1312 | * Disable underline option. | ||
1313 | * Reset colour to default? It did this | ||
1314 | * before... | ||
1315 | */ | ||
1316 | vc->vc_color = (vc->vc_def_color & 0x0f) | (vc->vc_color & 0xf0); | 1326 | vc->vc_color = (vc->vc_def_color & 0x0f) | (vc->vc_color & 0xf0); |
1317 | vc->vc_underline = 0; | ||
1318 | break; | 1327 | break; |
1319 | case 49: | 1328 | case 49: |
1320 | vc->vc_color = (vc->vc_def_color & 0xf0) | (vc->vc_color & 0x0f); | 1329 | vc->vc_color = (vc->vc_def_color & 0xf0) | (vc->vc_color & 0x0f); |