]> git.sur5r.net Git - u-boot/blobdiff - common/cmd_misc.c
Merge branch 'master' of git://www.denx.de/git/u-boot-coldfire
[u-boot] / common / cmd_misc.c
index e3e0e44869133b60b2db37151424eba8d7ef251d..126b538ce8d551ecf5e0e1df85e9d0e5924bc932 100644 (file)
 #include <common.h>
 #include <command.h>
 
-#if (CONFIG_COMMANDS & CFG_CMD_MISC)
-
 int do_sleep (cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
 {
+       ulong start = get_timer(0);
        ulong delay;
 
        if (argc != 2) {
@@ -38,19 +37,32 @@ 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;
 }
 
-#endif /* CFG_CMD_MISC */
+/* Implemented in $(CPU)/interrupts.c */
+#if defined(CONFIG_CMD_IRQ)
+int do_irqinfo (cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]);
+
+U_BOOT_CMD(
+       irqinfo,    1,    1,     do_irqinfo,
+       "irqinfo - print information about IRQs\n",
+       NULL
+);
+#endif
+
+U_BOOT_CMD(
+       sleep ,    2,    1,     do_sleep,
+       "sleep   - delay execution for some time\n",
+       "N\n"
+       "    - delay execution for N seconds (N is _decimal_ !!!)\n"
+);