Commit 71467e46 authored by Xiubo Li's avatar Xiubo Li Committed by Mark Brown

ASoC: simple-card: Add device's module clock selection.

Try to get the device's module clock if the dt has no clocks and
system-clock-frequency properties.
Signed-off-by: default avatarXiubo Li <Li.Xiubo@freescale.com>
Signed-off-by: default avatarMark Brown <broonie@linaro.org>
parent e874ddea
...@@ -90,14 +90,29 @@ asoc_simple_card_sub_parse_of(struct device_node *np, ...@@ -90,14 +90,29 @@ asoc_simple_card_sub_parse_of(struct device_node *np,
* dai->sysclk come from * dai->sysclk come from
* "clocks = <&xxx>" (if system has common clock) * "clocks = <&xxx>" (if system has common clock)
* or "system-clock-frequency = <xxx>" * or "system-clock-frequency = <xxx>"
* or device's module clock.
*/ */
if (of_property_read_bool(np, "clocks")) {
clk = of_clk_get(np, 0); clk = of_clk_get(np, 0);
if (IS_ERR(clk)) if (IS_ERR(clk)) {
ret = PTR_ERR(clk);
goto parse_error;
}
dai->sysclk = clk_get_rate(clk);
} else if (of_property_read_bool(np, "system-clock-frequency")) {
of_property_read_u32(np, of_property_read_u32(np,
"system-clock-frequency", "system-clock-frequency",
&dai->sysclk); &dai->sysclk);
else } else {
clk = of_clk_get(*node, 0);
if (IS_ERR(clk)) {
ret = PTR_ERR(clk);
goto parse_error;
}
dai->sysclk = clk_get_rate(clk); dai->sysclk = clk_get_rate(clk);
}
ret = 0; ret = 0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment