[U-Boot] [RFC][PATCH] cmd: clk: Add trivial implementation of clock dump for DM

Ley Foon Tan ley.foon.tan at intel.com
Thu Aug 9 08:42:07 UTC 2018


On Wed, 2018-08-08 at 22:10 +0200, Marek Vasut wrote:
> Add trivial implementation of the clk dump in case DM is enabled.
> This implementation just iterates over all the clock registered
> with the CLK uclass and prints their rate.
> 
> Signed-off-by: Marek Vasut <marex at denx.de>
> Cc: Chin Liang See <chin.liang.see at intel.com>
> Cc: Dinh Nguyen <dinguyen at kernel.org>
> Cc: Ley Foon Tan <ley.foon.tan at intel.com>
> Cc: Simon Glass <sjg at chromium.org>
> Cc: Tom Rini <trini at konsulko.com>
> ---
>  cmd/clk.c | 37 +++++++++++++++++++++++++++++++++++++
>  1 file changed, 37 insertions(+)
> 
> diff --git a/cmd/clk.c b/cmd/clk.c
> index 73fb25092b..fd4231589c 100644
> --- a/cmd/clk.c
> +++ b/cmd/clk.c
> @@ -5,11 +5,48 @@
>  #include <common.h>
>  #include <command.h>
>  #include <clk.h>
> +#if defined(CONFIG_DM) && defined(CONFIG_CLK)
> +#include <dm.h>
> +#include <dm/device-internal.h>
> +#endif
>  
>  int __weak soc_clk_dump(void)
>  {
> +#if defined(CONFIG_DM) && defined(CONFIG_CLK)
> +	struct udevice *dev;
> +	struct uclass *uc;
> +	struct clk clk;
> +	int ret;
> +
> +	/* Device addresses start at 1 */
> +	ret = uclass_get(UCLASS_CLK, &uc);
> +	if (ret)
> +		return ret;
> +
> +	uclass_foreach_dev(dev, uc) {
> +		memset(&clk, 0, sizeof(clk));
> +		ret = device_probe(dev);
> +		if (ret) {
> +			printf("%-30.30s : ? Hz\n", dev->name);
> +			continue;
> +		}
> +
> +		ret = clk_request(dev, &clk);
> +		if (ret) {
> +			printf("%-30.30s : ? Hz\n", dev->name);
> +			continue;
> +		}
> +
> +		printf("%-30.30s : %lu Hz\n", dev->name,
> clk_get_rate(&clk));
> +
> +		clk_free(&clk);
> +	}
> +
> +	return 0;
> +#else
>  	puts("Not implemented\n");
>  	return 1;
> +#endif
>  }
>  
>  static int do_clk_dump(cmd_tbl_t *cmdtp, int flag, int argc,

Reviewed-by: Ley Foon Tan <ley.foon.tan at intel.com>


More information about the U-Boot mailing list