]> git.kernelconcepts.de Git - karo-tx-uboot.git/blobdiff - common/cmd_misc.c
x86: Add CBMEM console driver for coreboot
[karo-tx-uboot.git] / common / cmd_misc.c
index e3e0e44869133b60b2db37151424eba8d7ef251d..dc2772e85df24a8ae85303a70c5d5c9b42c30f01 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[])
+static int do_sleep(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
 {
+       ulong start = get_timer(0);
        ulong delay;
 
-       if (argc != 2) {
-               printf ("Usage:\n%s\n", cmdtp->usage);
-               return 1;
+       if (argc != 2)
+               return CMD_RET_USAGE;
+
+       delay = simple_strtoul(argv[1], NULL, 10) * CONFIG_SYS_HZ;
+
+       while (get_timer(start) < delay) {
+               if (ctrlc())
+                       return (-1);
+
+               udelay(100);
        }
 
-       delay = simple_strtoul(argv[1], NULL, 10);
-
-       while (delay) {
-               int i;
-               for (i=0; i<1000; ++i) {
-                       if (ctrlc ()) {
-                               return (-1);
-                       }
-                       udelay (1000);
-               }
-               --delay;
+       return 0;
+}
+
+U_BOOT_CMD(
+       sleep ,    2,    1,     do_sleep,
+       "delay execution for some time",
+       "N\n"
+       "    - delay execution for N seconds (N is _decimal_ !!!)"
+);
+
+#ifdef CONFIG_CMD_TIMER
+static int do_timer(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
+{
+       static ulong start;
+
+       if (argc != 2)
+               return CMD_RET_USAGE;
+
+       if (!strcmp(argv[1], "start"))
+               start = get_timer(0);
+
+       if (!strcmp(argv[1], "get")) {
+               ulong msecs = get_timer(start) * 1000 / CONFIG_SYS_HZ;
+               printf("%ld.%03d\n", msecs / 1000, (int)(msecs % 1000));
        }
+
        return 0;
 }
 
-#endif /* CFG_CMD_MISC */
+U_BOOT_CMD(
+       timer,    2,    1,     do_timer,
+       "access the system timer",
+       "start - Reset the timer reference.\n"
+       "timer get   - Print the time since 'start'."
+);
+#endif