Fix problem with sleep in NetConsole (use get_timer())
authorStefan Roese <sr@denx.de>
Thu, 20 Oct 2005 14:36:44 +0000 (16:36 +0200)
committerStefan Roese <sr@denx.de>
Thu, 20 Oct 2005 14:36:44 +0000 (16:36 +0200)
Patch by Stefan Roese, 20 Oct 2005

CHANGELOG
common/cmd_misc.c

index 2dd56169ba286096805857c3570c6c8e17067f06..a063a01db9db1544b34f1ad7021f0c5d49018b46 100644 (file)
--- a/CHANGELOG
+++ b/CHANGELOG
@@ -2,6 +2,9 @@
 Changes for U-Boot 1.1.4:
 ======================================================================
 
+* Fix problem with sleep in NetConsole (use get_timer())
+  Patch by Stefan Roese, 20 Oct 2005
+
 * Add NetConsole Support for AMCC eval boards
   Patch by Stefan Roese, 20 Oct 2005
 
index 674eafca3f18d5081fbf101a583003b33d4f3cc2..67ee9e8a83de02eabaa3aa85ad80a5472b8756d9 100644 (file)
@@ -31,6 +31,7 @@
 
 int do_sleep (cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
 {
+       ulong start = get_timer(0);
        ulong delay;
 
        if (argc != 2) {
@@ -38,20 +39,18 @@ int do_sleep (cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
                return 1;
        }
 
-       delay = simple_strtoul(argv[1], NULL, 10);
+       delay = simple_strtoul(argv[1], NULL, 10) * CFG_HZ;
 
-       while (delay) {
-               int i;
-               for (i=0; i<1000; ++i) {
-                       if (ctrlc ()) {
-                               return (-1);
-                       }
-                       udelay (1000);
+       while (get_timer(start) < delay) {
+               if (ctrlc ()) {
+                       return (-1);
                }
-               --delay;
+               udelay (100);
        }
+
        return 0;
 }
+
 /* Implemented in $(CPU)/interrupts.c */
 #if (CONFIG_COMMANDS & CFG_CMD_IRQ)
 int do_irqinfo (cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]);