LKML Archive on lore.kernel.org help / color / mirror / Atom feed
From: Lee Jones <lee.jones@linaro.org> To: linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Cc: lee.jones@linaro.org, kernel@stlinux.com, mturquette@linaro.org, sboyd@codeaurora.org, devicetree@vger.kernel.org Subject: [PATCH 3/4] clk: st: Provide a clock domain Date: Mon, 26 Jan 2015 11:13:59 +0000 [thread overview] Message-ID: <1422270840-3039-4-git-send-email-lee.jones@linaro.org> (raw) In-Reply-To: <1422270840-3039-1-git-send-email-lee.jones@linaro.org> ST's h/w contains clocks which if turned off would prove fatal. The only way to recover is to restart the board(s). This driver takes references to clocks which are required to be always-on in order to prevent the common clk framework from trying to turn them off during the clk_disabled_unused() procedure. Signed-off-by: Lee Jones <lee.jones@linaro.org> --- drivers/clk/st/Makefile | 2 +- drivers/clk/st/clk-domain.c | 63 +++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 64 insertions(+), 1 deletion(-) create mode 100644 drivers/clk/st/clk-domain.c diff --git a/drivers/clk/st/Makefile b/drivers/clk/st/Makefile index ede7b2f..ac09be6 100644 --- a/drivers/clk/st/Makefile +++ b/drivers/clk/st/Makefile @@ -1 +1 @@ -obj-y += clkgen-mux.o clkgen-pll.o clkgen-fsyn.o clk-flexgen.o +obj-y += clkgen-mux.o clkgen-pll.o clkgen-fsyn.o clk-flexgen.o clk-domain.o diff --git a/drivers/clk/st/clk-domain.c b/drivers/clk/st/clk-domain.c new file mode 100644 index 0000000..e34049b --- /dev/null +++ b/drivers/clk/st/clk-domain.c @@ -0,0 +1,63 @@ +/* + * ST Clock Domain + * + * Copyright (C) 2015 STMicroelectronics – All Rights Reserved + * + * Author: Lee Jones <lee.jones@linaro.org> + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + */ + +#include <linux/clk-private.h> +#include <linux/clk-provider.h> +#include <linux/of_address.h> +#include <linux/of.h> +#include <linux/platform_device.h> + +static void st_clk_domain_hog_clock(struct platform_device *pdev, int index) +{ + struct device_node *np = pdev->dev.of_node; + struct clk *clk; + int ret; + + clk = of_clk_get(np, index); + if (IS_ERR(clk)) { + dev_warn(&pdev->dev, "Failed get clock %s[%d]: %li\n", + np->full_name, index, PTR_ERR(clk)); + return; + } + + ret = clk_prepare_enable(clk); + if (ret) + dev_warn(&pdev->dev, "Failed to enable clock: %s\n", clk->name); +} + +static int st_clk_domain_probe(struct platform_device *pdev) +{ + struct device_node *np = pdev->dev.of_node; + int nclks, i; + + nclks = of_count_phandle_with_args(np, "clocks", "#clock-cells"); + + for (i = 0; i < nclks; i++) + st_clk_domain_hog_clock(pdev, i); + + return 0; +} + +static const struct of_device_id st_clk_domain_match[] = { + { .compatible = "st,clk-domain" }, + { }, +}; + +static struct platform_driver st_clk_domain_driver = { + .probe = st_clk_domain_probe, + .driver = { + .name = "st-clk-domain", + .of_match_table = st_clk_domain_match, + }, +}; +module_platform_driver(st_clk_domain_driver); -- 1.9.1
next prev parent reply other threads:[~2015-01-26 11:14 UTC|newest] Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top 2015-01-26 11:13 [PATCH 0/4] clk: st: New clock domain Lee Jones 2015-01-26 11:13 ` [PATCH 1/4] ARM: sti: stih407-family: Supply defines for CLOCKGEN A0 Lee Jones 2015-01-26 11:13 ` [PATCH 2/4] ARM: sti: stih407-family: Provide Clock Domain information Lee Jones 2015-01-26 11:13 ` Lee Jones [this message] 2015-01-26 11:14 ` [PATCH 4/4] clk: dt: st: Introduce clock domain documentation Lee Jones 2015-01-28 1:19 ` Mike Turquette 2015-01-28 7:58 ` Lee Jones
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=1422270840-3039-4-git-send-email-lee.jones@linaro.org \ --to=lee.jones@linaro.org \ --cc=devicetree@vger.kernel.org \ --cc=kernel@stlinux.com \ --cc=linux-arm-kernel@lists.infradead.org \ --cc=linux-kernel@vger.kernel.org \ --cc=mturquette@linaro.org \ --cc=sboyd@codeaurora.org \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).