blob: db8c1892df4a437050e39bff6c0f3cc6b29ba444 [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Che-liang Chiouca366d02011-10-06 23:40:48 +00002/*
3 * Copyright (c) 2011 The Chromium OS Authors.
Che-liang Chiouca366d02011-10-06 23:40:48 +00004 */
5
Tom Rinid678a592024-05-18 20:20:43 -06006#include <common.h>
Che-liang Chiouca366d02011-10-06 23:40:48 +00007#include <command.h>
8
Che-liang Chiouca366d02011-10-06 23:40:48 +00009static void report_time(ulong cycles)
10{
11 ulong minutes, seconds, milliseconds;
12 ulong total_seconds, remainder;
13
14 total_seconds = cycles / CONFIG_SYS_HZ;
15 remainder = cycles % CONFIG_SYS_HZ;
16 minutes = total_seconds / 60;
17 seconds = total_seconds % 60;
18 /* approximate millisecond value */
19 milliseconds = (remainder * 1000 + CONFIG_SYS_HZ / 2) / CONFIG_SYS_HZ;
20
21 printf("\ntime:");
22 if (minutes)
23 printf(" %lu minutes,", minutes);
Masahiro Yamada1d643772014-04-18 17:46:13 +090024 printf(" %lu.%03lu seconds\n", seconds, milliseconds);
Che-liang Chiouca366d02011-10-06 23:40:48 +000025}
26
Simon Glass09140112020-05-10 11:40:03 -060027static int do_time(struct cmd_tbl *cmdtp, int flag, int argc,
28 char *const argv[])
Che-liang Chiouca366d02011-10-06 23:40:48 +000029{
30 ulong cycles = 0;
31 int retval = 0;
Tom Rini146dda32017-09-26 21:12:05 -040032 int repeatable = 0;
Che-liang Chiouca366d02011-10-06 23:40:48 +000033
34 if (argc == 1)
Simon Glass4c12eeb2011-12-10 08:44:01 +000035 return CMD_RET_USAGE;
Che-liang Chiouca366d02011-10-06 23:40:48 +000036
Richard Genoud34765e82012-12-03 06:28:28 +000037 retval = cmd_process(0, argc - 1, argv + 1, &repeatable, &cycles);
Che-liang Chiouca366d02011-10-06 23:40:48 +000038 report_time(cycles);
39
40 return retval;
41}
42
43U_BOOT_CMD(time, CONFIG_SYS_MAXARGS, 0, do_time,
44 "run commands and summarize execution time",
45 "command [args...]\n");