Commit aa6b517e authored by Uwe Kleine-König's avatar Uwe Kleine-König Committed by Greg Kroah-Hartman

serial: imx: ensure UCR3 and UFCR are setup correctly

commit 6df765dc upstream.

Commit e61c38d8 ("serial: imx: setup DCEDTE early and ensure DCD and
RI irqs to be off") has a flaw: While UCR3 and UFCR were modified using
read-modify-write before it switched to write register values
independent of the previous state. That's a good idea in principle (and
that's why I did it) but needs more care.

This patch reinstates read-modify-write for UFCR and for UCR3 ensures
that RXDMUXSEL and ADNIMP are set for post imx1.

Fixes: e61c38d8 ("serial: imx: setup DCEDTE early and ensure DCD and RI irqs to be off")
Signed-off-by: default avatarUwe Kleine-König <u.kleine-koenig@pengutronix.de>
Acked-by: default avatarMika Penttilä <mika.penttila@nextfour.com>
Tested-by: default avatarMika Penttilä <mika.penttila@nextfour.com>
Acked-by: default avatarSteve Twiss <stwiss.opensource@diasemi.com>
Tested-by: default avatarSteve Twiss <stwiss.opensource@diasemi.com>
Cc: Chris Ruehl <chris.ruehl@gtsys.com.hk>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 23fb8f79
...@@ -2145,7 +2145,9 @@ static int serial_imx_probe(struct platform_device *pdev) ...@@ -2145,7 +2145,9 @@ static int serial_imx_probe(struct platform_device *pdev)
* and DCD (when they are outputs) or enables the respective * and DCD (when they are outputs) or enables the respective
* irqs. So set this bit early, i.e. before requesting irqs. * irqs. So set this bit early, i.e. before requesting irqs.
*/ */
writel(UFCR_DCEDTE, sport->port.membase + UFCR); reg = readl(sport->port.membase + UFCR);
if (!(reg & UFCR_DCEDTE))
writel(reg | UFCR_DCEDTE, sport->port.membase + UFCR);
/* /*
* Disable UCR3_RI and UCR3_DCD irqs. They are also not * Disable UCR3_RI and UCR3_DCD irqs. They are also not
...@@ -2156,7 +2158,15 @@ static int serial_imx_probe(struct platform_device *pdev) ...@@ -2156,7 +2158,15 @@ static int serial_imx_probe(struct platform_device *pdev)
sport->port.membase + UCR3); sport->port.membase + UCR3);
} else { } else {
writel(0, sport->port.membase + UFCR); unsigned long ucr3 = UCR3_DSR;
reg = readl(sport->port.membase + UFCR);
if (reg & UFCR_DCEDTE)
writel(reg & ~UFCR_DCEDTE, sport->port.membase + UFCR);
if (!is_imx1_uart(sport))
ucr3 |= IMX21_UCR3_RXDMUXSEL | UCR3_ADNIMP;
writel(ucr3, sport->port.membase + UCR3);
} }
clk_disable_unprepare(sport->clk_ipg); clk_disable_unprepare(sport->clk_ipg);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment