From: Alexander Sverdlin <alexander.sverdlin@gmail.com>
To: u-boot@lists.denx.de
Subject: [U-Boot] xyz-modem: Change getc timeout loop waiting
Date: Wed, 1 Aug 2018 02:15:07 +0200 [thread overview]
Message-ID: <20180801021507.d9061b74b8068bb32edfac5a@gmail.com> (raw)
In-Reply-To: <1479716331-94776-1-git-send-email-tomas.melin@vaisala.com>
Hello!
On Mon, 21 Nov 2016 10:18:51 +0200
Tomas Melin <tomas.melin@vaisala.com> wrote:
> This fixes the loop delay when using a hw watchdog.
>
> In case a watchdog is used that accesses CPU registers,
> the defined delay of 20us in a tight loop will cause a
> huge delay in the actual timeout seen. This is caused
> by the fact that udelay will inheritantly call WATCHDOG_RESET.
> Together with the omap wdt implementation, the seen timeout increases up to
> around 30s. This makes the loop very slow and causes long
> delays when using the modem.
>
> Instead, implement the 2 sec loop by using the timer interface to know
> when to break out of the timeout loop. Watchdog kicking is taken care of
> by getc().
>
> Signed-off-by: Tomas Melin <tomas.melin@vaisala.com>
This commit breaks YMODEM SPL->U-Boot boot on Beagle Bone,
transfer is aborted (because of timeout) after 497kb
(u-boot.img is around 570kb).
Reverting the commit repairs YMODEM boot.
> ---
> common/xyzModem.c | 10 +++++-----
> 1 file changed, 5 insertions(+), 5 deletions(-)
>
> diff --git a/common/xyzModem.c b/common/xyzModem.c
> index 5656aac..e0d87db 100644
> --- a/common/xyzModem.c
> +++ b/common/xyzModem.c
> @@ -71,12 +71,12 @@ typedef int cyg_int32;
> static int
> CYGACC_COMM_IF_GETC_TIMEOUT (char chan, char *c)
> {
> -#define DELAY 20
> - unsigned long counter = 0;
> - while (!tstc () && (counter < xyzModem_CHAR_TIMEOUT * 1000 / DELAY))
> +
> + ulong now = get_timer(0);
> + while (!tstc ())
> {
> - udelay (DELAY);
> - counter++;
> + if (get_timer(now) > xyzModem_CHAR_TIMEOUT)
> + break;
> }
> if (tstc ())
> {
--
Alexander Sverdlin.
next prev parent reply other threads:[~2018-08-01 0:15 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-11-21 8:18 [U-Boot] [PATCH] xyz-modem: Change getc timeout loop waiting Tomas Melin
2016-11-29 1:07 ` [U-Boot] " Tom Rini
2018-08-01 0:15 ` Alexander Sverdlin [this message]
2018-08-01 5:44 ` Tomas Melin
2018-08-01 5:54 ` Alexander Sverdlin
2018-08-01 6:16 ` Tomas Melin
2018-08-02 14:47 ` Alexander Sverdlin
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20180801021507.d9061b74b8068bb32edfac5a@gmail.com \
--to=alexander.sverdlin@gmail.com \
--cc=u-boot@lists.denx.de \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox