RE: [PATCH V2] tty/serial: add support for Xilinx PS UART

From: John Linn
Date: Fri Apr 22 2011 - 11:55:45 EST


> -----Original Message-----
> From: glikely@xxxxxxxxxxxx [mailto:glikely@xxxxxxxxxxxx] On Behalf Of
> Grant Likely
> Sent: Friday, April 22, 2011 9:46 AM
> To: John Linn
> Cc: linux-kernel@xxxxxxxxxxxxxxx; linux-serial@xxxxxxxxxxxxxxx;
> alan@xxxxxxxxxxxxxxxxxxx; greg@xxxxxxxxx
> Subject: Re: [PATCH V2] tty/serial: add support for Xilinx PS UART
>
> On Fri, Apr 22, 2011 at 9:40 AM, Grant Likely
> <grant.likely@xxxxxxxxxxxx> wrote:
> > On Wed, Apr 20, 2011 at 1:03 PM, John Linn <john.linn@xxxxxxxxxx>
> wrote:
> >> The Xilinx PS Uart is used on the new ARM based SoC. This
> >> UART is not compatible with others such that a seperate
> >> driver is required.
> >>
> >> Signed-off-by: John Linn <john.linn@xxxxxxxxxx>
> >
> > Out of curiosity, who is the vendor of this uart IP block?  Is it new
> > hardware created by xilinx for zinq, or is it provided by a third
> > party.  If its from a third party it is within the realm of
> > possibility that a driver already exists for it.
> >
> > g.
> >> +/********************************Register
> Map********************************/
> >> +/** UART
> >> + *
> >> + * Register offsets for the UART.
> >> + *
> >> + */
> >> +#define XUARTPS_CR_OFFSET      0x00  /* Control Register [8:0] */
> >> +#define XUARTPS_MR_OFFSET      0x04  /* Mode Register [10:0] */
> >> +#define XUARTPS_IER_OFFSET     0x08  /* Interrupt Enable [10:0] */
> >> +#define XUARTPS_IDR_OFFSET     0x0C  /* Interrupt Disable [10:0] */
> >> +#define XUARTPS_IMR_OFFSET     0x10  /* Interrupt Mask [10:0] */
> >> +#define XUARTPS_ISR_OFFSET     0x14  /* Interrupt Status [10:0]*/
> >> +#define XUARTPS_BAUDGEN_OFFSET 0x18  /* Baud Rate Generator [15:0]
> */
> >> +#define XUARTPS_RXTOUT_OFFSET  0x1C  /* RX Timeout [7:0] */
> >> +#define XUARTPS_RXWM_OFFSET    0x20  /* RX FIFO Trigger Level [5:0]
> */
> >> +#define XUARTPS_MODEMCR_OFFSET 0x24  /* Modem Control [5:0] */
> >> +#define XUARTPS_MODEMSR_OFFSET 0x28  /* Modem Status [8:0] */
> >> +#define XUARTPS_SR_OFFSET      0x2C  /* Channel Status [11:0] */
> >> +#define XUARTPS_FIFO_OFFSET    0x30  /* FIFO [15:0] or [7:0] */
> >> +#define XUARTPS_BAUDDIV_OFFSET 0x34  /* Baud Rate Divider [7:0] */
> >> +#define XUARTPS_FLOWDEL_OFFSET 0x38  /* Flow Delay [15:0] */
> >> +#define XUARTPS_IRRX_PWIDTH_OFFSET 0x3C /* IR Minimum Received
> Pulse
> >> +                                               Width [15:0] */
> >> +#define XUARTPS_IRTX_PWIDTH_OFFSET 0x40 /* IR Transmitted pulse
> >> +                                               Width [7:0] */
> >> +#define XUARTPS_TXWM_OFFSET    0x44  /* TX FIFO Trigger Level [5:0]
> */
>
> After a quick search:
>
> from include/linux/atmel_serial.h
> #define ATMEL_US_CR 0x00 /* Control
> Register */
> #define ATMEL_US_MR 0x04 /* Mode
> Register */
> #define ATMEL_US_IER 0x08 /* Interrupt
> Enable Register */
> #define ATMEL_US_IDR 0x0c /* Interrupt
> Disable Register */
> #define ATMEL_US_IMR 0x10 /* Interrupt
> Mask Register */
> #define ATMEL_US_CSR 0x14 /* Channel
> Status Register */
> #define ATMEL_US_RHR 0x18 /* Receiver
> Holding Register */
> #define ATMEL_US_THR 0x1c /* Transmitter
> Holding Register */
> #define ATMEL_US_BRGR 0x20 /* Baud Rate
> Generator Register */
> #define ATMEL_US_RTOR 0x24 /* Receiver
> Time-out Register */
> #define ATMEL_US_TTGR 0x28 /* Transmitter
> Timeguard Register */
> #define ATMEL_US_FIDI 0x40 /* FI DI Ratio
> Register */
> #define ATMEL_US_NER 0x44 /* Number of
> Errors Register */
> #define ATMEL_US_IF 0x4c /* IrDA Filter
> Register */
>
>
> Not exactly the same, but worth exploring

Yes that's the one I found closest also, but no cigar as not the same and
different enough so I don't think it makes sense to try to reuse it.

The world doesn't need any more round wheels, but some must be more shiny than
others to some people. Until hardware is open source I'm afraid that's the
way it will be.

Thanks,
John

Please ignore the footer that follows as I'm working with corporate to see if
we get it removed and be a better open source citizen.


This email and any attachments are intended for the sole use of the named recipient(s) and contain(s) confidential information that may be proprietary, privileged or copyrighted under applicable law. If you are not the intended recipient, do not read, copy, or forward this email message or any attachments. Delete this email message and any attachments immediately.


--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/