aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/tty/serial/mxs-auart.c
diff options
context:
space:
mode:
authorHuang Shijie <b32955@freescale.com>2013-08-03 10:09:14 -0400
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2013-08-05 03:05:17 -0400
commit8418e67d95235c3449df6f2e5b33863343fa72f9 (patch)
treef3a202723dcae7e09158e651f013e2cff0168f0f /drivers/tty/serial/mxs-auart.c
parent5ac1ccb70a3b7d4627c257fcbb2579b2dc4d2a0a (diff)
serial: mxs: enable the DMA only when the RTS/CTS is valid
The original DMA support works only when RTS/CTS is enabled. (see the "e800163 serial: mxs-auart: add the DMA support for mx28") But after several patches, DMA support has lost this limit. (see the "bcc20f9 serial: mxs-auart: move to use generic DMA helper") So an UART without the RTS/CTS lines may also enables the DMA support, in which case the UART may gets unpredictable results. This patch adds an optional property for the UART DT node which indicates the UART has RTS and CTS lines, and it also means you enable the DMA support for this UART. This patch also adds a macro MXS_AUART_RTSCTS, and uses it to check RTS/CTS before we enable the DMA for the UART. Signed-off-by: Huang Shijie <b32955@freescale.com> Signed-off-by: Huang Shijie <shijie8@gmail.com> Acked-by: Shawn Guo <shawn.guo@linaro.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/tty/serial/mxs-auart.c')
-rw-r--r--drivers/tty/serial/mxs-auart.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/drivers/tty/serial/mxs-auart.c b/drivers/tty/serial/mxs-auart.c
index 736e95c1ac4e..eac7b585bc0c 100644
--- a/drivers/tty/serial/mxs-auart.c
+++ b/drivers/tty/serial/mxs-auart.c
@@ -137,6 +137,7 @@ struct mxs_auart_port {
137#define MXS_AUART_DMA_ENABLED 0x2 137#define MXS_AUART_DMA_ENABLED 0x2
138#define MXS_AUART_DMA_TX_SYNC 2 /* bit 2 */ 138#define MXS_AUART_DMA_TX_SYNC 2 /* bit 2 */
139#define MXS_AUART_DMA_RX_READY 3 /* bit 3 */ 139#define MXS_AUART_DMA_RX_READY 3 /* bit 3 */
140#define MXS_AUART_RTSCTS 4 /* bit 4 */
140 unsigned long flags; 141 unsigned long flags;
141 unsigned int ctrl; 142 unsigned int ctrl;
142 enum mxs_auart_type devtype; 143 enum mxs_auart_type devtype;
@@ -639,7 +640,8 @@ static void mxs_auart_settermios(struct uart_port *u,
639 * we can only implement the DMA support for auart 640 * we can only implement the DMA support for auart
640 * in mx28. 641 * in mx28.
641 */ 642 */
642 if (is_imx28_auart(s) && (s->flags & MXS_AUART_DMA_CONFIG)) { 643 if (is_imx28_auart(s) && (s->flags & MXS_AUART_DMA_CONFIG)
644 && test_bit(MXS_AUART_RTSCTS, &s->flags)) {
643 if (!mxs_auart_dma_init(s)) 645 if (!mxs_auart_dma_init(s))
644 /* enable DMA tranfer */ 646 /* enable DMA tranfer */
645 ctrl2 |= AUART_CTRL2_TXDMAE | AUART_CTRL2_RXDMAE 647 ctrl2 |= AUART_CTRL2_TXDMAE | AUART_CTRL2_RXDMAE
@@ -1009,6 +1011,9 @@ static int serial_mxs_probe_dt(struct mxs_auart_port *s,
1009 1011
1010 s->flags |= MXS_AUART_DMA_CONFIG; 1012 s->flags |= MXS_AUART_DMA_CONFIG;
1011 1013
1014 if (of_get_property(np, "fsl,uart-has-rtscts", NULL))
1015 set_bit(MXS_AUART_RTSCTS, &s->flags);
1016
1012 return 0; 1017 return 0;
1013} 1018}
1014 1019