[U-Boot] [PATCH 09/20] Add a 'cpu' command to print CPU information

Bin Meng bmeng.cn at gmail.com
Tue Apr 28 09:34:01 CEST 2015


On Tue, Apr 28, 2015 at 6:48 AM, Simon Glass <sjg at chromium.org> wrote:
> Add a simple command which provides access to a list of available CPUs along
> with descriptions and basic information.
>
> Signed-off-by: Simon Glass <sjg at chromium.org>
> ---
>
>  common/Kconfig   |   8 ++++
>  common/Makefile  |   1 +
>  common/cmd_cpu.c | 113 +++++++++++++++++++++++++++++++++++++++++++++++++++++++
>  3 files changed, 122 insertions(+)
>  create mode 100644 common/cmd_cpu.c
>
> diff --git a/common/Kconfig b/common/Kconfig
> index 5d7e48a..15759f7 100644
> --- a/common/Kconfig
> +++ b/common/Kconfig
> @@ -31,6 +31,14 @@ config CMD_CONSOLE
>         help
>           Print console devices and information.
>
> +config CMD_CPU
> +       bool "cpu"
> +       help
> +         Print information about available CPUs. This normally shows the
> +         number of CPUs, type (e.g. manufacturer, architecture, product or
> +         internal name) and clock frequency. Other information may be
> +         available depending on the CPU driver.
> +
>  config CMD_LICENSE
>         bool "license"
>         help
> diff --git a/common/Makefile b/common/Makefile
> index fba3830..9084c73 100644
> --- a/common/Makefile
> +++ b/common/Makefile
> @@ -74,6 +74,7 @@ obj-$(CONFIG_CMD_CBFS) += cmd_cbfs.o
>  obj-$(CONFIG_CMD_CLK) += cmd_clk.o
>  obj-$(CONFIG_CMD_CONSOLE) += cmd_console.o
>  obj-$(CONFIG_CMD_CPLBINFO) += cmd_cplbinfo.o
> +obj-$(CONFIG_CMD_CPU) += cmd_cpu.o
>  obj-$(CONFIG_DATAFLASH_MMC_SELECT) += cmd_dataflash_mmc_mux.o
>  obj-$(CONFIG_CMD_DATE) += cmd_date.o
>  obj-$(CONFIG_CMD_DEMO) += cmd_demo.o
> diff --git a/common/cmd_cpu.c b/common/cmd_cpu.c
> new file mode 100644
> index 0000000..c3e229f
> --- /dev/null
> +++ b/common/cmd_cpu.c
> @@ -0,0 +1,113 @@
> +/*
> + * Copyright (c) 2015 Google, Inc
> + * Written by Simon Glass <sjg at chromium.org>
> + *
> + * SPDX-License-Identifier:    GPL-2.0+
> + */
> +
> +#include <common.h>
> +#include <command.h>
> +#include <cpu.h>
> +#include <dm.h>
> +
> +static const char *cpu_feature_name[CPU_FEAT_COUNT] = {
> +       "L1 cache",
> +       "MMU",
> +};
> +
> +static int print_cpu_list(bool detail)
> +{
> +       struct udevice *dev;
> +       struct uclass *uc;
> +       char buf[100];
> +       int ret;
> +
> +       ret = uclass_get(UCLASS_CPU, &uc);
> +       if (ret) {
> +               printf("Cannot find CPU uclass\n");
> +               return ret;
> +       }
> +       uclass_foreach_dev(dev, uc) {
> +               struct cpu_platdata *plat = dev_get_parent_platdata(dev);
> +               struct cpu_info info;
> +               bool first;
> +               int i;
> +
> +               ret = cpu_get_desc(dev, buf, sizeof(buf));
> +               printf("%3d: %-10s %s\n", dev->seq, dev->name,
> +                      ret ? "<no description>" : buf);
> +               if (!detail)
> +                       continue;
> +               ret = cpu_get_info(dev, &info);
> +               if (ret) {
> +                       printf("\t(no detail available");
> +                       if (ret != -ENOSYS)
> +                               printf(": err=%d\n", ret);
> +                       printf(")\n");
> +                       continue;
> +               }
> +               printf("\tID = %d, freq = ", plat->cpu_id);
> +               print_freq(info.cpu_freq, "");
> +               first = true;
> +               for (i = 0; i < CPU_FEAT_COUNT; i++) {
> +                       if (info.features & (1 << i)) {
> +                               printf("%s%s", first ? ": " : ", ",
> +                                      cpu_feature_name[i]);
> +                               first = false;
> +                       }
> +               }
> +               printf("\n");
> +       }
> +
> +       return 0;
> +}
> +
> +static int do_cpu_list(cmd_tbl_t *cmdtp, int flag, int argc, char *const argv[])
> +{
> +       if (print_cpu_list(false))
> +               return CMD_RET_FAILURE;
> +
> +       return 0;
> +}
> +
> +static int do_cpu_detail(cmd_tbl_t *cmdtp, int flag, int argc,
> +                        char *const argv[])
> +{
> +       if (print_cpu_list(true))
> +               return CMD_RET_FAILURE;
> +
> +       return 0;
> +}
> +
> +static cmd_tbl_t cmd_cpu_sub[] = {
> +       U_BOOT_CMD_MKENT(list, 2, 1, do_cpu_list, "", ""),
> +       U_BOOT_CMD_MKENT(detail, 4, 0, do_cpu_detail, "", ""),
> +};
> +
> +/*
> + * Process a cpu sub-command
> + */
> +static int do_cpu(cmd_tbl_t *cmdtp, int flag, int argc,
> +                      char * const argv[])
> +{
> +       cmd_tbl_t *c = NULL;
> +
> +       /* Strip off leading 'cpu' command argument */
> +       argc--;
> +       argv++;
> +
> +       if (argc)
> +               c = find_cmd_tbl(argv[0], cmd_cpu_sub, ARRAY_SIZE(cmd_cpu_sub));
> +
> +       if (c)
> +               return c->cmd(cmdtp, flag, argc, argv);
> +       else
> +               return CMD_RET_USAGE;
> +}
> +
> +U_BOOT_CMD(
> +       cpu, 2, 1, do_cpu,
> +       "display information about CPUs",
> +       "list   - list available CPUs\n"
> +       "cpu detail     - show CPU detail"
> +);
> --

Reviewed-by: Bin Meng <bmeng.cn at gmail.com>


More information about the U-Boot mailing list