aboutsummaryrefslogtreecommitdiff
path: root/cmd/timer.c
diff options
context:
space:
mode:
authorBin Meng <bin.meng@windriver.com>2020-10-13 18:45:06 +0800
committerTom Rini <trini@konsulko.com>2020-10-23 13:33:07 -0400
commit3c7bb897183fb0d5617c34030857c264efe503d3 (patch)
tree8fb74389de3dcaa28388ee70ab1b28c0d64b736b /cmd/timer.c
parent16060854095036d5becc2c850641955a47d327d1 (diff)
downloadu-boot-3c7bb897183fb0d5617c34030857c264efe503d3.zip
u-boot-3c7bb897183fb0d5617c34030857c264efe503d3.tar.gz
u-boot-3c7bb897183fb0d5617c34030857c264efe503d3.tar.bz2
cmd: Split out timer command from the sleep command
CONFIG_CMD_TIMER merits a single file instead of co-exist in the sleep command file. Signed-off-by: Bin Meng <bin.meng@windriver.com>
Diffstat (limited to 'cmd/timer.c')
-rw-r--r--cmd/timer.c34
1 files changed, 34 insertions, 0 deletions
diff --git a/cmd/timer.c b/cmd/timer.c
new file mode 100644
index 0000000..551be5d
--- /dev/null
+++ b/cmd/timer.c
@@ -0,0 +1,34 @@
+// SPDX-License-Identifier: GPL-2.0+
+/*
+ * (C) Copyright 2001
+ * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
+ */
+
+#include <common.h>
+#include <command.h>
+
+static int do_timer(struct cmd_tbl *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;
+}
+
+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'."
+);