diff mbox series

[U-Boot] riscv : serial: use rx watermark to indicate rx data is present

Message ID 1562675024-31648-2-git-send-email-sagar.kadam@sifive.com
State Accepted
Commit 8836384c754295b1bbbb2910664c0d07de0dbde4
Delegated to: Andes
Headers show
Series [U-Boot] riscv : serial: use rx watermark to indicate rx data is present | expand

Commit Message

Sagar Shrikant Kadam July 9, 2019, 12:23 p.m. UTC
In y-modem transfer mode, tstc/getc fail to check if there is any
data available / received in RX FIFO, and so y-modem transfer never
succeeds. Using receive watermark bit within ip register fixes the
issue.

This patch is based on commit c7392b7bc4e1 ("Use the RX watermark
interrupt pending bit for TSTC") available at[1]

[1] https://github.com/sifive/HiFive_U-Boot/tree/regression

Signed-off-by: Sagar Shrikant Kadam <sagar.kadam@sifive.com>
---

 drivers/serial/serial_sifive.c | 23 +++++++----------------
 1 file changed, 7 insertions(+), 16 deletions(-)

Comments

Anup Patel July 10, 2019, 4:33 a.m. UTC | #1
On Tue, Jul 9, 2019 at 5:55 PM Sagar Shrikant Kadam
<sagar.kadam@sifive.com> wrote:
>
> In y-modem transfer mode, tstc/getc fail to check if there is any
> data available / received in RX FIFO, and so y-modem transfer never
> succeeds. Using receive watermark bit within ip register fixes the
> issue.
>
> This patch is based on commit c7392b7bc4e1 ("Use the RX watermark
> interrupt pending bit for TSTC") available at[1]
>
> [1] https://github.com/sifive/HiFive_U-Boot/tree/regression
>
> Signed-off-by: Sagar Shrikant Kadam <sagar.kadam@sifive.com>
> ---
>
>  drivers/serial/serial_sifive.c | 23 +++++++----------------
>  1 file changed, 7 insertions(+), 16 deletions(-)
>
> diff --git a/drivers/serial/serial_sifive.c b/drivers/serial/serial_sifive.c
> index fdfef69..c142ccd 100644
> --- a/drivers/serial/serial_sifive.c
> +++ b/drivers/serial/serial_sifive.c
> @@ -22,6 +22,9 @@ DECLARE_GLOBAL_DATA_PTR;
>  #define UART_TXCTRL_TXEN       0x1
>  #define UART_RXCTRL_RXEN       0x1
>
> +/* IP register */
> +#define UART_IP_RXWM            0x2
> +
>  struct uart_sifive {
>         u32 txfifo;
>         u32 rxfifo;
> @@ -34,7 +37,6 @@ struct uart_sifive {
>
>  struct sifive_uart_platdata {
>         unsigned long clock;
> -       int saved_input_char;
>         struct uart_sifive *regs;
>  };
>
> @@ -94,7 +96,7 @@ static int _sifive_serial_getc(struct uart_sifive *regs)
>                 return -EAGAIN;
>         ch &= UART_RXFIFO_DATA;
>
> -       return (!ch) ? -EAGAIN : ch;
> +       return ch;
>  }
>
>  static int sifive_serial_setbrg(struct udevice *dev, int baudrate)
> @@ -133,7 +135,6 @@ static int sifive_serial_probe(struct udevice *dev)
>         if (gd->flags & GD_FLG_RELOC)
>                 return 0;
>
> -       platdata->saved_input_char = 0;
>         _sifive_serial_init(platdata->regs);
>
>         return 0;
> @@ -145,12 +146,6 @@ static int sifive_serial_getc(struct udevice *dev)
>         struct sifive_uart_platdata *platdata = dev_get_platdata(dev);
>         struct uart_sifive *regs = platdata->regs;
>
> -       if (platdata->saved_input_char > 0) {
> -               c = platdata->saved_input_char;
> -               platdata->saved_input_char = 0;
> -               return c;
> -       }
> -
>         while ((c = _sifive_serial_getc(regs)) == -EAGAIN) ;
>
>         return c;
> @@ -171,14 +166,10 @@ static int sifive_serial_pending(struct udevice *dev, bool input)
>         struct sifive_uart_platdata *platdata = dev_get_platdata(dev);
>         struct uart_sifive *regs = platdata->regs;
>
> -       if (input) {
> -               if (platdata->saved_input_char > 0)
> -                       return 1;
> -               platdata->saved_input_char = _sifive_serial_getc(regs);
> -               return (platdata->saved_input_char > 0) ? 1 : 0;
> -       } else {
> +       if (input)
> +               return (readl(&regs->ip) & UART_IP_RXWM);
> +       else
>                 return !!(readl(&regs->txfifo) & UART_TXFIFO_FULL);
> -       }
>  }
>
>  static int sifive_serial_ofdata_to_platdata(struct udevice *dev)
> --
> 2.7.4
>

Looks good to me.

Reviewed-by: Anup Patel <anup.patel@wdc.com>
Tested-by: Anup Patel <anup.patel@wdc.com>

Regards,
Anup
Sagar Shrikant Kadam July 10, 2019, 5:11 a.m. UTC | #2
Hi Anup,

On Wed, Jul 10, 2019 at 10:03 AM Anup Patel <anup@brainfault.org> wrote:
>
> On Tue, Jul 9, 2019 at 5:55 PM Sagar Shrikant Kadam
> <sagar.kadam@sifive.com> wrote:
> >
> > In y-modem transfer mode, tstc/getc fail to check if there is any
> > data available / received in RX FIFO, and so y-modem transfer never
> > succeeds. Using receive watermark bit within ip register fixes the
> > issue.
> >
> > This patch is based on commit c7392b7bc4e1 ("Use the RX watermark
> > interrupt pending bit for TSTC") available at[1]
> >
> > [1] https://github.com/sifive/HiFive_U-Boot/tree/regression
> >
> > Signed-off-by: Sagar Shrikant Kadam <sagar.kadam@sifive.com>
> > ---
> >
> >  drivers/serial/serial_sifive.c | 23 +++++++----------------
> >  1 file changed, 7 insertions(+), 16 deletions(-)
> >
> > diff --git a/drivers/serial/serial_sifive.c b/drivers/serial/serial_sifive.c
> > index fdfef69..c142ccd 100644
> > --- a/drivers/serial/serial_sifive.c
> > +++ b/drivers/serial/serial_sifive.c
> > @@ -22,6 +22,9 @@ DECLARE_GLOBAL_DATA_PTR;
> >  #define UART_TXCTRL_TXEN       0x1
> >  #define UART_RXCTRL_RXEN       0x1
> >
> > +/* IP register */
> > +#define UART_IP_RXWM            0x2
> > +
> >  struct uart_sifive {
> >         u32 txfifo;
> >         u32 rxfifo;
> > @@ -34,7 +37,6 @@ struct uart_sifive {
> >
> >  struct sifive_uart_platdata {
> >         unsigned long clock;
> > -       int saved_input_char;
> >         struct uart_sifive *regs;
> >  };
> >
> > @@ -94,7 +96,7 @@ static int _sifive_serial_getc(struct uart_sifive *regs)
> >                 return -EAGAIN;
> >         ch &= UART_RXFIFO_DATA;
> >
> > -       return (!ch) ? -EAGAIN : ch;
> > +       return ch;
> >  }
> >
> >  static int sifive_serial_setbrg(struct udevice *dev, int baudrate)
> > @@ -133,7 +135,6 @@ static int sifive_serial_probe(struct udevice *dev)
> >         if (gd->flags & GD_FLG_RELOC)
> >                 return 0;
> >
> > -       platdata->saved_input_char = 0;
> >         _sifive_serial_init(platdata->regs);
> >
> >         return 0;
> > @@ -145,12 +146,6 @@ static int sifive_serial_getc(struct udevice *dev)
> >         struct sifive_uart_platdata *platdata = dev_get_platdata(dev);
> >         struct uart_sifive *regs = platdata->regs;
> >
> > -       if (platdata->saved_input_char > 0) {
> > -               c = platdata->saved_input_char;
> > -               platdata->saved_input_char = 0;
> > -               return c;
> > -       }
> > -
> >         while ((c = _sifive_serial_getc(regs)) == -EAGAIN) ;
> >
> >         return c;
> > @@ -171,14 +166,10 @@ static int sifive_serial_pending(struct udevice *dev, bool input)
> >         struct sifive_uart_platdata *platdata = dev_get_platdata(dev);
> >         struct uart_sifive *regs = platdata->regs;
> >
> > -       if (input) {
> > -               if (platdata->saved_input_char > 0)
> > -                       return 1;
> > -               platdata->saved_input_char = _sifive_serial_getc(regs);
> > -               return (platdata->saved_input_char > 0) ? 1 : 0;
> > -       } else {
> > +       if (input)
> > +               return (readl(&regs->ip) & UART_IP_RXWM);
> > +       else
> >                 return !!(readl(&regs->txfifo) & UART_TXFIFO_FULL);
> > -       }
> >  }
> >
> >  static int sifive_serial_ofdata_to_platdata(struct udevice *dev)
> > --
> > 2.7.4
> >
>
> Looks good to me.
>
> Reviewed-by: Anup Patel <anup.patel@wdc.com>
> Tested-by: Anup Patel <anup.patel@wdc.com>
>
Thank you for testing it.

> Regards,
> Anup
Padmarao Begari July 15, 2019, 12:01 p.m. UTC | #3
Reviewed-by: Padmarao Begari <padmarao.begari@microchip.com>
Tested-by: Padmarao Begari <padmarao.begari@microchip.com>

Regards
Padmarao

On Tue, Jul 9, 2019 at 5:56 PM Sagar Shrikant Kadam <sagar.kadam@sifive.com>
wrote:

> In y-modem transfer mode, tstc/getc fail to check if there is any
> data available / received in RX FIFO, and so y-modem transfer never
> succeeds. Using receive watermark bit within ip register fixes the
> issue.
>
> This patch is based on commit c7392b7bc4e1 ("Use the RX watermark
> interrupt pending bit for TSTC") available at[1]
>
> [1] https://github.com/sifive/HiFive_U-Boot/tree/regression
>
> Signed-off-by: Sagar Shrikant Kadam <sagar.kadam@sifive.com>
> ---
>
>  drivers/serial/serial_sifive.c | 23 +++++++----------------
>  1 file changed, 7 insertions(+), 16 deletions(-)
>
> diff --git a/drivers/serial/serial_sifive.c
> b/drivers/serial/serial_sifive.c
> index fdfef69..c142ccd 100644
> --- a/drivers/serial/serial_sifive.c
> +++ b/drivers/serial/serial_sifive.c
> @@ -22,6 +22,9 @@ DECLARE_GLOBAL_DATA_PTR;
>  #define UART_TXCTRL_TXEN       0x1
>  #define UART_RXCTRL_RXEN       0x1
>
> +/* IP register */
> +#define UART_IP_RXWM            0x2
> +
>  struct uart_sifive {
>         u32 txfifo;
>         u32 rxfifo;
> @@ -34,7 +37,6 @@ struct uart_sifive {
>
>  struct sifive_uart_platdata {
>         unsigned long clock;
> -       int saved_input_char;
>         struct uart_sifive *regs;
>  };
>
> @@ -94,7 +96,7 @@ static int _sifive_serial_getc(struct uart_sifive *regs)
>                 return -EAGAIN;
>         ch &= UART_RXFIFO_DATA;
>
> -       return (!ch) ? -EAGAIN : ch;
> +       return ch;
>  }
>
>  static int sifive_serial_setbrg(struct udevice *dev, int baudrate)
> @@ -133,7 +135,6 @@ static int sifive_serial_probe(struct udevice *dev)
>         if (gd->flags & GD_FLG_RELOC)
>                 return 0;
>
> -       platdata->saved_input_char = 0;
>         _sifive_serial_init(platdata->regs);
>
>         return 0;
> @@ -145,12 +146,6 @@ static int sifive_serial_getc(struct udevice *dev)
>         struct sifive_uart_platdata *platdata = dev_get_platdata(dev);
>         struct uart_sifive *regs = platdata->regs;
>
> -       if (platdata->saved_input_char > 0) {
> -               c = platdata->saved_input_char;
> -               platdata->saved_input_char = 0;
> -               return c;
> -       }
> -
>         while ((c = _sifive_serial_getc(regs)) == -EAGAIN) ;
>
>         return c;
> @@ -171,14 +166,10 @@ static int sifive_serial_pending(struct udevice
> *dev, bool input)
>         struct sifive_uart_platdata *platdata = dev_get_platdata(dev);
>         struct uart_sifive *regs = platdata->regs;
>
> -       if (input) {
> -               if (platdata->saved_input_char > 0)
> -                       return 1;
> -               platdata->saved_input_char = _sifive_serial_getc(regs);
> -               return (platdata->saved_input_char > 0) ? 1 : 0;
> -       } else {
> +       if (input)
> +               return (readl(&regs->ip) & UART_IP_RXWM);
> +       else
>                 return !!(readl(&regs->txfifo) & UART_TXFIFO_FULL);
> -       }
>  }
>
>  static int sifive_serial_ofdata_to_platdata(struct udevice *dev)
> --
> 2.7.4
>
> _______________________________________________
> U-Boot mailing list
> U-Boot@lists.denx.de
> https://lists.denx.de/listinfo/u-boot
>
Sagar Shrikant Kadam July 15, 2019, 12:22 p.m. UTC | #4
Hi Padmarao,

On Mon, Jul 15, 2019 at 5:31 PM Padmarao Begari <padmarao.b@gmail.com> wrote:
>
> Reviewed-by: Padmarao Begari <padmarao.begari@microchip.com>
> Tested-by: Padmarao Begari <padmarao.begari@microchip.com>
>

Thank you for the review and testing the changes.

> Regards
> Padmarao
>

BR,
Sagar Kadam
> On Tue, Jul 9, 2019 at 5:56 PM Sagar Shrikant Kadam <sagar.kadam@sifive.com> wrote:
>>
>> In y-modem transfer mode, tstc/getc fail to check if there is any
>> data available / received in RX FIFO, and so y-modem transfer never
>> succeeds. Using receive watermark bit within ip register fixes the
>> issue.
>>
>> This patch is based on commit c7392b7bc4e1 ("Use the RX watermark
>> interrupt pending bit for TSTC") available at[1]
>>
>> [1] https://github.com/sifive/HiFive_U-Boot/tree/regression
>>
>> Signed-off-by: Sagar Shrikant Kadam <sagar.kadam@sifive.com>
>> ---
>>
>>  drivers/serial/serial_sifive.c | 23 +++++++----------------
>>  1 file changed, 7 insertions(+), 16 deletions(-)
>>
>> diff --git a/drivers/serial/serial_sifive.c b/drivers/serial/serial_sifive.c
>> index fdfef69..c142ccd 100644
>> --- a/drivers/serial/serial_sifive.c
>> +++ b/drivers/serial/serial_sifive.c
>> @@ -22,6 +22,9 @@ DECLARE_GLOBAL_DATA_PTR;
>>  #define UART_TXCTRL_TXEN       0x1
>>  #define UART_RXCTRL_RXEN       0x1
>>
>> +/* IP register */
>> +#define UART_IP_RXWM            0x2
>> +
>>  struct uart_sifive {
>>         u32 txfifo;
>>         u32 rxfifo;
>> @@ -34,7 +37,6 @@ struct uart_sifive {
>>
>>  struct sifive_uart_platdata {
>>         unsigned long clock;
>> -       int saved_input_char;
>>         struct uart_sifive *regs;
>>  };
>>
>> @@ -94,7 +96,7 @@ static int _sifive_serial_getc(struct uart_sifive *regs)
>>                 return -EAGAIN;
>>         ch &= UART_RXFIFO_DATA;
>>
>> -       return (!ch) ? -EAGAIN : ch;
>> +       return ch;
>>  }
>>
>>  static int sifive_serial_setbrg(struct udevice *dev, int baudrate)
>> @@ -133,7 +135,6 @@ static int sifive_serial_probe(struct udevice *dev)
>>         if (gd->flags & GD_FLG_RELOC)
>>                 return 0;
>>
>> -       platdata->saved_input_char = 0;
>>         _sifive_serial_init(platdata->regs);
>>
>>         return 0;
>> @@ -145,12 +146,6 @@ static int sifive_serial_getc(struct udevice *dev)
>>         struct sifive_uart_platdata *platdata = dev_get_platdata(dev);
>>         struct uart_sifive *regs = platdata->regs;
>>
>> -       if (platdata->saved_input_char > 0) {
>> -               c = platdata->saved_input_char;
>> -               platdata->saved_input_char = 0;
>> -               return c;
>> -       }
>> -
>>         while ((c = _sifive_serial_getc(regs)) == -EAGAIN) ;
>>
>>         return c;
>> @@ -171,14 +166,10 @@ static int sifive_serial_pending(struct udevice *dev, bool input)
>>         struct sifive_uart_platdata *platdata = dev_get_platdata(dev);
>>         struct uart_sifive *regs = platdata->regs;
>>
>> -       if (input) {
>> -               if (platdata->saved_input_char > 0)
>> -                       return 1;
>> -               platdata->saved_input_char = _sifive_serial_getc(regs);
>> -               return (platdata->saved_input_char > 0) ? 1 : 0;
>> -       } else {
>> +       if (input)
>> +               return (readl(&regs->ip) & UART_IP_RXWM);
>> +       else
>>                 return !!(readl(&regs->txfifo) & UART_TXFIFO_FULL);
>> -       }
>>  }
>>
>>  static int sifive_serial_ofdata_to_platdata(struct udevice *dev)
>> --
>> 2.7.4
>>
>> _______________________________________________
>> U-Boot mailing list
>> U-Boot@lists.denx.de
>> https://lists.denx.de/listinfo/u-boot
Rick Chen July 26, 2019, 7:01 a.m. UTC | #5
Hi Sagar

> From: Sagar Kadam [mailto:sagar.kadam@sifive.com]
> Sent: Friday, July 19, 2019 7:37 PM
> To: Rick Jian-Zhi Chen(陳建志)
> Subject: Re: [U-Boot] [PATCH] riscv : serial: use rx watermark to indicate rx data is present
>
> Hello Rick,
>
> I missed to CC you while submitting the patch[1] Can you please provide your view's on the patch.

Sorry for the late response.
I am OK with your patch.
I will pull it into riscv tree ASAP :)

B.R
Rick

>
> [1] https://patchwork.ozlabs.org/patch/1129736/
>
>
> Thanks & Regards,
> Sagar Kadam
>
> > Thank you for the review and testing the changes.
>
> On Fri, Jul 19, 2019 at 5:04 PM Sagar Kadam <sagar.kadam@sifive.com> wrote:
> >
> > Hello Rick,
> >
> Sorry accidently pressed the send button after this :)
>
> > On Mon, Jul 15, 2019 at 5:52 PM Sagar Kadam <sagar.kadam@sifive.com> wrote:
> > >
> > > Hi Padmarao,
> > >
> > > On Mon, Jul 15, 2019 at 5:31 PM Padmarao Begari <padmarao.b@gmail.com> wrote:
> > > >
> > > > Reviewed-by: Padmarao Begari <padmarao.begari@microchip.com>
> > > > Tested-by: Padmarao Begari <padmarao.begari@microchip.com>
> > > >
> > >
> > >
> > > > Regards
> > > > Padmarao
> > > >
> > >
> > > BR,
> > > Sagar Kadam
> > > > On Tue, Jul 9, 2019 at 5:56 PM Sagar Shrikant Kadam <sagar.kadam@sifive.com> wrote:
> > > >>
> > > >> In y-modem transfer mode, tstc/getc fail to check if there is any
> > > >> data available / received in RX FIFO, and so y-modem transfer
> > > >> never succeeds. Using receive watermark bit within ip register
> > > >> fixes the issue.
> > > >>
> > > >> This patch is based on commit c7392b7bc4e1 ("Use the RX watermark
> > > >> interrupt pending bit for TSTC") available at[1]
> > > >>
> > > >> [1] https://github.com/sifive/HiFive_U-Boot/tree/regression
> > > >>
> > > >> Signed-off-by: Sagar Shrikant Kadam <sagar.kadam@sifive.com>
> > > >> ---
> > > >>
> > > >>  drivers/serial/serial_sifive.c | 23 +++++++----------------
> > > >>  1 file changed, 7 insertions(+), 16 deletions(-)
> > > >>
> > > >> diff --git a/drivers/serial/serial_sifive.c
> > > >> b/drivers/serial/serial_sifive.c index fdfef69..c142ccd 100644
> > > >> --- a/drivers/serial/serial_sifive.c
> > > >> +++ b/drivers/serial/serial_sifive.c
> > > >> @@ -22,6 +22,9 @@ DECLARE_GLOBAL_DATA_PTR;
> > > >>  #define UART_TXCTRL_TXEN       0x1
> > > >>  #define UART_RXCTRL_RXEN       0x1
> > > >>
> > > >> +/* IP register */
> > > >> +#define UART_IP_RXWM            0x2
> > > >> +
> > > >>  struct uart_sifive {
> > > >>         u32 txfifo;
> > > >>         u32 rxfifo;
> > > >> @@ -34,7 +37,6 @@ struct uart_sifive {
> > > >>
> > > >>  struct sifive_uart_platdata {
> > > >>         unsigned long clock;
> > > >> -       int saved_input_char;
> > > >>         struct uart_sifive *regs;  };
> > > >>
> > > >> @@ -94,7 +96,7 @@ static int _sifive_serial_getc(struct uart_sifive *regs)
> > > >>                 return -EAGAIN;
> > > >>         ch &= UART_RXFIFO_DATA;
> > > >>
> > > >> -       return (!ch) ? -EAGAIN : ch;
> > > >> +       return ch;
> > > >>  }
> > > >>
> > > >>  static int sifive_serial_setbrg(struct udevice *dev, int
> > > >> baudrate) @@ -133,7 +135,6 @@ static int sifive_serial_probe(struct udevice *dev)
> > > >>         if (gd->flags & GD_FLG_RELOC)
> > > >>                 return 0;
> > > >>
> > > >> -       platdata->saved_input_char = 0;
> > > >>         _sifive_serial_init(platdata->regs);
> > > >>
> > > >>         return 0;
> > > >> @@ -145,12 +146,6 @@ static int sifive_serial_getc(struct udevice *dev)
> > > >>         struct sifive_uart_platdata *platdata = dev_get_platdata(dev);
> > > >>         struct uart_sifive *regs = platdata->regs;
> > > >>
> > > >> -       if (platdata->saved_input_char > 0) {
> > > >> -               c = platdata->saved_input_char;
> > > >> -               platdata->saved_input_char = 0;
> > > >> -               return c;
> > > >> -       }
> > > >> -
> > > >>         while ((c = _sifive_serial_getc(regs)) == -EAGAIN) ;
> > > >>
> > > >>         return c;
> > > >> @@ -171,14 +166,10 @@ static int sifive_serial_pending(struct udevice *dev, bool input)
> > > >>         struct sifive_uart_platdata *platdata = dev_get_platdata(dev);
> > > >>         struct uart_sifive *regs = platdata->regs;
> > > >>
> > > >> -       if (input) {
> > > >> -               if (platdata->saved_input_char > 0)
> > > >> -                       return 1;
> > > >> -               platdata->saved_input_char = _sifive_serial_getc(regs);
> > > >> -               return (platdata->saved_input_char > 0) ? 1 : 0;
> > > >> -       } else {
> > > >> +       if (input)
> > > >> +               return (readl(&regs->ip) & UART_IP_RXWM);
> > > >> +       else
> > > >>                 return !!(readl(&regs->txfifo) & UART_TXFIFO_FULL);
> > > >> -       }
> > > >>  }
> > > >>
> > > >>  static int sifive_serial_ofdata_to_platdata(struct udevice *dev)
> > > >> --
> > > >> 2.7.4
Sagar Shrikant Kadam July 26, 2019, 10:14 a.m. UTC | #6
Hi Rick,

On Fri, Jul 26, 2019 at 12:32 PM Rick Chen <rickchen36@gmail.com> wrote:
>
> Hi Sagar
>
> > From: Sagar Kadam [mailto:sagar.kadam@sifive.com]
> > Sent: Friday, July 19, 2019 7:37 PM
> > To: Rick Jian-Zhi Chen(陳建志)
> > Subject: Re: [U-Boot] [PATCH] riscv : serial: use rx watermark to indicate rx data is present
> >
> > Hello Rick,
> >
> > I missed to CC you while submitting the patch[1] Can you please provide your view's on the patch.
>
> Sorry for the late response.
> I am OK with your patch.
> I will pull it into riscv tree ASAP :)
>
> B.R
> Rick
>
Thanks  for acknowledgement :)

Regards,
Sagar
> >
> > [1] https://patchwork.ozlabs.org/patch/1129736/
> >
> >
> > Thanks & Regards,
> > Sagar Kadam
> >
> > > Thank you for the review and testing the changes.
> >
> > On Fri, Jul 19, 2019 at 5:04 PM Sagar Kadam <sagar.kadam@sifive.com> wrote:
> > >
> > > Hello Rick,
> > >
> > Sorry accidently pressed the send button after this :)
> >
> > > On Mon, Jul 15, 2019 at 5:52 PM Sagar Kadam <sagar.kadam@sifive.com> wrote:
> > > >
> > > > Hi Padmarao,
> > > >
> > > > On Mon, Jul 15, 2019 at 5:31 PM Padmarao Begari <padmarao.b@gmail.com> wrote:
> > > > >
> > > > > Reviewed-by: Padmarao Begari <padmarao.begari@microchip.com>
> > > > > Tested-by: Padmarao Begari <padmarao.begari@microchip.com>
> > > > >
> > > >
> > > >
> > > > > Regards
> > > > > Padmarao
> > > > >
> > > >
> > > > BR,
> > > > Sagar Kadam
> > > > > On Tue, Jul 9, 2019 at 5:56 PM Sagar Shrikant Kadam <sagar.kadam@sifive.com> wrote:
> > > > >>
> > > > >> In y-modem transfer mode, tstc/getc fail to check if there is any
> > > > >> data available / received in RX FIFO, and so y-modem transfer
> > > > >> never succeeds. Using receive watermark bit within ip register
> > > > >> fixes the issue.
> > > > >>
> > > > >> This patch is based on commit c7392b7bc4e1 ("Use the RX watermark
> > > > >> interrupt pending bit for TSTC") available at[1]
> > > > >>
> > > > >> [1] https://github.com/sifive/HiFive_U-Boot/tree/regression
> > > > >>
> > > > >> Signed-off-by: Sagar Shrikant Kadam <sagar.kadam@sifive.com>
> > > > >> ---
> > > > >>
> > > > >>  drivers/serial/serial_sifive.c | 23 +++++++----------------
> > > > >>  1 file changed, 7 insertions(+), 16 deletions(-)
> > > > >>
> > > > >> diff --git a/drivers/serial/serial_sifive.c
> > > > >> b/drivers/serial/serial_sifive.c index fdfef69..c142ccd 100644
> > > > >> --- a/drivers/serial/serial_sifive.c
> > > > >> +++ b/drivers/serial/serial_sifive.c
> > > > >> @@ -22,6 +22,9 @@ DECLARE_GLOBAL_DATA_PTR;
> > > > >>  #define UART_TXCTRL_TXEN       0x1
> > > > >>  #define UART_RXCTRL_RXEN       0x1
> > > > >>
> > > > >> +/* IP register */
> > > > >> +#define UART_IP_RXWM            0x2
> > > > >> +
> > > > >>  struct uart_sifive {
> > > > >>         u32 txfifo;
> > > > >>         u32 rxfifo;
> > > > >> @@ -34,7 +37,6 @@ struct uart_sifive {
> > > > >>
> > > > >>  struct sifive_uart_platdata {
> > > > >>         unsigned long clock;
> > > > >> -       int saved_input_char;
> > > > >>         struct uart_sifive *regs;  };
> > > > >>
> > > > >> @@ -94,7 +96,7 @@ static int _sifive_serial_getc(struct uart_sifive *regs)
> > > > >>                 return -EAGAIN;
> > > > >>         ch &= UART_RXFIFO_DATA;
> > > > >>
> > > > >> -       return (!ch) ? -EAGAIN : ch;
> > > > >> +       return ch;
> > > > >>  }
> > > > >>
> > > > >>  static int sifive_serial_setbrg(struct udevice *dev, int
> > > > >> baudrate) @@ -133,7 +135,6 @@ static int sifive_serial_probe(struct udevice *dev)
> > > > >>         if (gd->flags & GD_FLG_RELOC)
> > > > >>                 return 0;
> > > > >>
> > > > >> -       platdata->saved_input_char = 0;
> > > > >>         _sifive_serial_init(platdata->regs);
> > > > >>
> > > > >>         return 0;
> > > > >> @@ -145,12 +146,6 @@ static int sifive_serial_getc(struct udevice *dev)
> > > > >>         struct sifive_uart_platdata *platdata = dev_get_platdata(dev);
> > > > >>         struct uart_sifive *regs = platdata->regs;
> > > > >>
> > > > >> -       if (platdata->saved_input_char > 0) {
> > > > >> -               c = platdata->saved_input_char;
> > > > >> -               platdata->saved_input_char = 0;
> > > > >> -               return c;
> > > > >> -       }
> > > > >> -
> > > > >>         while ((c = _sifive_serial_getc(regs)) == -EAGAIN) ;
> > > > >>
> > > > >>         return c;
> > > > >> @@ -171,14 +166,10 @@ static int sifive_serial_pending(struct udevice *dev, bool input)
> > > > >>         struct sifive_uart_platdata *platdata = dev_get_platdata(dev);
> > > > >>         struct uart_sifive *regs = platdata->regs;
> > > > >>
> > > > >> -       if (input) {
> > > > >> -               if (platdata->saved_input_char > 0)
> > > > >> -                       return 1;
> > > > >> -               platdata->saved_input_char = _sifive_serial_getc(regs);
> > > > >> -               return (platdata->saved_input_char > 0) ? 1 : 0;
> > > > >> -       } else {
> > > > >> +       if (input)
> > > > >> +               return (readl(&regs->ip) & UART_IP_RXWM);
> > > > >> +       else
> > > > >>                 return !!(readl(&regs->txfifo) & UART_TXFIFO_FULL);
> > > > >> -       }
> > > > >>  }
> > > > >>
> > > > >>  static int sifive_serial_ofdata_to_platdata(struct udevice *dev)
> > > > >> --
> > > > >> 2.7.4
Anup Patel July 26, 2019, 10:42 a.m. UTC | #7
Hi Rick,

On Fri, Jul 26, 2019 at 12:32 PM Rick Chen <rickchen36@gmail.com> wrote:
>
> Hi Sagar
>
> > From: Sagar Kadam [mailto:sagar.kadam@sifive.com]
> > Sent: Friday, July 19, 2019 7:37 PM
> > To: Rick Jian-Zhi Chen(陳建志)
> > Subject: Re: [U-Boot] [PATCH] riscv : serial: use rx watermark to indicate rx data is present
> >
> > Hello Rick,
> >
> > I missed to CC you while submitting the patch[1] Can you please provide your view's on the patch.
>
> Sorry for the late response.
> I am OK with your patch.
> I will pull it into riscv tree ASAP :)

All SiFive driver update patches have been merged
except one documentation update patch.

"[U-Boot,v12,1/1] doc: sifive-fu540: Update README to explicitly load
DTB for Linux"
https://patchwork.ozlabs.org/patch/1137215/

Can you take this patch via RISCV tree ?

Regards,
Anup
Rick Chen July 31, 2019, 3:06 a.m. UTC | #8
Hi Anup

> Hi Rick,
>
> On Fri, Jul 26, 2019 at 12:32 PM Rick Chen <rickchen36@gmail.com> wrote:
> >
> > Hi Sagar
> >
> > > From: Sagar Kadam [mailto:sagar.kadam@sifive.com]
> > > Sent: Friday, July 19, 2019 7:37 PM
> > > To: Rick Jian-Zhi Chen(陳建志)
> > > Subject: Re: [U-Boot] [PATCH] riscv : serial: use rx watermark to indicate rx data is present
> > >
> > > Hello Rick,
> > >
> > > I missed to CC you while submitting the patch[1] Can you please provide your view's on the patch.
> >
> > Sorry for the late response.
> > I am OK with your patch.
> > I will pull it into riscv tree ASAP :)
>
> All SiFive driver update patches have been merged
> except one documentation update patch.
>
> "[U-Boot,v12,1/1] doc: sifive-fu540: Update README to explicitly load
> DTB for Linux"
> https://patchwork.ozlabs.org/patch/1137215/
>
> Can you take this patch via RISCV tree ?

OK
I will pull it later.

B.R
Rick

>
> Regards,
> Anup
Rick Chen Aug. 1, 2019, 3:08 a.m. UTC | #9
> > From: U-Boot [mailto:u-boot-bounces@lists.denx.de] On Behalf Of Anup Patel
> > Sent: Friday, July 26, 2019 6:43 PM
> > To: Rick Chen
> > Cc: Alan Quey-Liang Kao(高魁良); Alexander Graf; U-Boot Mailing List; K.C.
> > Kuen-Chern Lin(林坤成)
> > Subject: Re: [U-Boot] [PATCH] riscv : serial: use rx watermark to indicate rx data
> > is present
> >
> > Hi Rick,
> >
> > On Fri, Jul 26, 2019 at 12:32 PM Rick Chen <rickchen36@gmail.com> wrote:
> > >
> > > Hi Sagar
> > >
> > > > From: Sagar Kadam [mailto:sagar.kadam@sifive.com]
> > > > Sent: Friday, July 19, 2019 7:37 PM
> > > > To: Rick Jian-Zhi Chen(陳建志)
> > > > Subject: Re: [U-Boot] [PATCH] riscv : serial: use rx watermark to
> > > > indicate rx data is present
> > > >
> > > > Hello Rick,
> > > >
> > > > I missed to CC you while submitting the patch[1] Can you please provide
> > your view's on the patch.
> > >
> > > Sorry for the late response.
> > > I am OK with your patch.
> > > I will pull it into riscv tree ASAP :)
> >
> > All SiFive driver update patches have been merged except one documentation
> > update patch.
> >
> > "[U-Boot,v12,1/1] doc: sifive-fu540: Update README to explicitly load DTB for
> > Linux"
> > https://patchwork.ozlabs.org/patch/1137215/
> >
> > Can you take this patch via RISCV tree ?

Applied to u-boot-riscv/master, thanks!

Rick
diff mbox series

Patch

diff --git a/drivers/serial/serial_sifive.c b/drivers/serial/serial_sifive.c
index fdfef69..c142ccd 100644
--- a/drivers/serial/serial_sifive.c
+++ b/drivers/serial/serial_sifive.c
@@ -22,6 +22,9 @@  DECLARE_GLOBAL_DATA_PTR;
 #define UART_TXCTRL_TXEN	0x1
 #define UART_RXCTRL_RXEN	0x1
 
+/* IP register */
+#define UART_IP_RXWM            0x2
+
 struct uart_sifive {
 	u32 txfifo;
 	u32 rxfifo;
@@ -34,7 +37,6 @@  struct uart_sifive {
 
 struct sifive_uart_platdata {
 	unsigned long clock;
-	int saved_input_char;
 	struct uart_sifive *regs;
 };
 
@@ -94,7 +96,7 @@  static int _sifive_serial_getc(struct uart_sifive *regs)
 		return -EAGAIN;
 	ch &= UART_RXFIFO_DATA;
 
-	return (!ch) ? -EAGAIN : ch;
+	return ch;
 }
 
 static int sifive_serial_setbrg(struct udevice *dev, int baudrate)
@@ -133,7 +135,6 @@  static int sifive_serial_probe(struct udevice *dev)
 	if (gd->flags & GD_FLG_RELOC)
 		return 0;
 
-	platdata->saved_input_char = 0;
 	_sifive_serial_init(platdata->regs);
 
 	return 0;
@@ -145,12 +146,6 @@  static int sifive_serial_getc(struct udevice *dev)
 	struct sifive_uart_platdata *platdata = dev_get_platdata(dev);
 	struct uart_sifive *regs = platdata->regs;
 
-	if (platdata->saved_input_char > 0) {
-		c = platdata->saved_input_char;
-		platdata->saved_input_char = 0;
-		return c;
-	}
-
 	while ((c = _sifive_serial_getc(regs)) == -EAGAIN) ;
 
 	return c;
@@ -171,14 +166,10 @@  static int sifive_serial_pending(struct udevice *dev, bool input)
 	struct sifive_uart_platdata *platdata = dev_get_platdata(dev);
 	struct uart_sifive *regs = platdata->regs;
 
-	if (input) {
-		if (platdata->saved_input_char > 0)
-			return 1;
-		platdata->saved_input_char = _sifive_serial_getc(regs);
-		return (platdata->saved_input_char > 0) ? 1 : 0;
-	} else {
+	if (input)
+		return (readl(&regs->ip) & UART_IP_RXWM);
+	else
 		return !!(readl(&regs->txfifo) & UART_TXFIFO_FULL);
-	}
 }
 
 static int sifive_serial_ofdata_to_platdata(struct udevice *dev)