aboutsummaryrefslogtreecommitdiffstats
path: root/xen/drivers
diff options
context:
space:
mode:
authorAndre Przywara <andre.przywara@linaro.org>2013-08-13 17:12:35 +0200
committerIan Campbell <ian.campbell@citrix.com>2013-08-21 10:29:07 +0100
commit874f76a86adf1da70921884f5a868eec105cf8cd (patch)
treef4456f90dcdb8e792b2fc6cee897207b53759500 /xen/drivers
parent5263507b1b4ad5417871d8297f315d7b204426d4 (diff)
downloadxen-874f76a86adf1da70921884f5a868eec105cf8cd.tar.gz
xen-874f76a86adf1da70921884f5a868eec105cf8cd.tar.bz2
xen-874f76a86adf1da70921884f5a868eec105cf8cd.zip
PL011: fix reverse logic for interrupt mask register
The PL011 IMSC register description is somehow fuzzy in the documentation; by comparing it with the Linux implementation one can see that the logic is actually reversed to Xen's implementation: A "0" in field means interrupt disabled, a "1" enables it. Therefore we enabled all interrupts instead of disabling them in the beginning and later on masked the wrong interrupts. Unclear how this worked on the Versatile Express, but this fix is needed to get Calxeda Midway running (and works on VExpress, too). Signed-off-by: Andre Przywara <andre.przywara@linaro.org> Acked-by: Ian Campbell <ian.campbell@citrix.com>
Diffstat (limited to 'xen/drivers')
-rw-r--r--xen/drivers/char/pl011.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/xen/drivers/char/pl011.c b/xen/drivers/char/pl011.c
index 3747c166a0..0e1eb64601 100644
--- a/xen/drivers/char/pl011.c
+++ b/xen/drivers/char/pl011.c
@@ -87,7 +87,7 @@ static void __init pl011_init_preirq(struct serial_port *port)
unsigned int divisor;
/* No interrupts, please. */
- pl011_write(uart, IMSC, ALLI);
+ pl011_write(uart, IMSC, 0);
/* Definitely no DMA */
pl011_write(uart, DMACR, 0x0);
@@ -115,7 +115,7 @@ static void __init pl011_init_preirq(struct serial_port *port)
pl011_write(uart, RSR, 0);
/* Mask and clear the interrupts */
- pl011_write(uart, IMSC, ALLI);
+ pl011_write(uart, IMSC, 0);
pl011_write(uart, ICR, ALLI);
/* Enable the UART for RX and TX; no flow ctrl */
@@ -140,7 +140,7 @@ static void __init pl011_init_postirq(struct serial_port *port)
pl011_write(uart, ICR, OEI|BEI|PEI|FEI);
/* Unmask interrupts */
- pl011_write(uart, IMSC, RTI|DSRMI|DCDMI|CTSMI|RIMI);
+ pl011_write(uart, IMSC, OEI|BEI|PEI|FEI|TXI|RXI);
}
static void pl011_suspend(struct serial_port *port)