[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [Xen-devel] [PATCH V9 2/3] drivers/pl011: Use combination of UARTRIS and UARTMSC instead of UARTMIS
On Thu, 9 Jun 2016, Shanker Donthineni wrote: > The Masked interrupt status register (UARTMIS) is not described in ARM > SBSA 2.x document. Anding of two registers UARTMSC and UARTRIS values > gives the same information as register UARTMIS. > > UARTRIS, UARTMSC and UARTMIS definitions are found in PrimeCell UART > PL011 (Revision: r1p4). > - 3.3.10 Interrupt mask set/clear register, UARTIMSC > - 3.3.11 Raw interrupt status register, UARTRIS > - 3.3.12 Masked interrupt status register, UARTMIS > > This change is necessary for driver to be SBSA compliant v2.x without > affecting the current driver functionality. > > Signed-off-by: Shanker Donthineni <shankerd@xxxxxxxxxxxxxx> > Reviewed-by: Julien Grall <julien.grall@xxxxxxx> > > Changes since v8: > Fixed white spaces. > > Changes since v7: > Moved comment 'To compatible with SBSA v2.x document, all accesses should be > 32-bit' to #3 > > Changes since v1: > Added a new function to return an interrupt status. > > xen/drivers/char/pl011.c | 10 ++++++++-- > 1 file changed, 8 insertions(+), 2 deletions(-) > > diff --git a/xen/drivers/char/pl011.c b/xen/drivers/char/pl011.c > index 6a3c21b..7e19c4a 100644 > --- a/xen/drivers/char/pl011.c > +++ b/xen/drivers/char/pl011.c > @@ -53,11 +53,17 @@ static struct pl011 { > #define pl011_read(uart, off) readl((uart)->regs + (off)) > #define pl011_write(uart, off,val) writel((val), (uart)->regs + (off)) > > +static unsigned int pl011_intr_status(struct pl011 *uart) Maybe this should be static inline? In any case the series is good, I am happy to queue it up for 4.8. > +{ > + /* UARTMIS is not documented in SBSA v2.x, so use UARTRIS/UARTIMSC. */ > + return (pl011_read(uart, RIS) & pl011_read(uart, IMSC)); > +} > + > static void pl011_interrupt(int irq, void *data, struct cpu_user_regs *regs) > { > struct serial_port *port = data; > struct pl011 *uart = port->uart; > - unsigned int status = pl011_read(uart, MIS); > + unsigned int status = pl011_intr_status(uart); > > if ( status ) > { > @@ -76,7 +82,7 @@ static void pl011_interrupt(int irq, void *data, struct > cpu_user_regs *regs) > if ( status & (TXI) ) > serial_tx_interrupt(port, regs); > > - status = pl011_read(uart, MIS); > + status = pl011_intr_status(uart); > } while (status != 0); > } > } > -- > Qualcomm Technologies, Inc. on behalf of Qualcomm Innovation Center, Inc. > Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, > a Linux Foundation Collaborative Project > _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxx http://lists.xen.org/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |