Commit 4162dd5b authored by Jerome Brunet's avatar Jerome Brunet Committed by Neil Armstrong

clk: meson: use hhi syscon if available

On gxbb and axg, try to get the hhi regmap from the parent DT node, which
should be the HHI system controller once the necessary changes have been
made in amlogic's DTs

Until then, if getting regmap through the system controller fails, the
clock controller will fall back to the old way, requesting memory region
directly and then registering the regmap itself.

This should allow a smooth transition to syscon
Signed-off-by: default avatarJerome Brunet <jbrunet@baylibre.com>
Signed-off-by: default avatarNeil Armstrong <narmstrong@baylibre.com>
parent 03a6519e
...@@ -22,6 +22,7 @@ config COMMON_CLK_GXBB ...@@ -22,6 +22,7 @@ config COMMON_CLK_GXBB
depends on COMMON_CLK_AMLOGIC depends on COMMON_CLK_AMLOGIC
select RESET_CONTROLLER select RESET_CONTROLLER
select COMMON_CLK_REGMAP_MESON select COMMON_CLK_REGMAP_MESON
select MFD_SYSCON
help help
Support for the clock controller on AmLogic S905 devices, aka gxbb. Support for the clock controller on AmLogic S905 devices, aka gxbb.
Say Y if you want peripherals and CPU frequency scaling to work. Say Y if you want peripherals and CPU frequency scaling to work.
...@@ -31,6 +32,7 @@ config COMMON_CLK_AXG ...@@ -31,6 +32,7 @@ config COMMON_CLK_AXG
depends on COMMON_CLK_AMLOGIC depends on COMMON_CLK_AMLOGIC
select RESET_CONTROLLER select RESET_CONTROLLER
select COMMON_CLK_REGMAP_MESON select COMMON_CLK_REGMAP_MESON
select MFD_SYSCON
help help
Support for the clock controller on AmLogic A113D devices, aka axg. Support for the clock controller on AmLogic A113D devices, aka axg.
Say Y if you want peripherals and CPU frequency scaling to work. Say Y if you want peripherals and CPU frequency scaling to work.
...@@ -14,6 +14,7 @@ ...@@ -14,6 +14,7 @@
#include <linux/init.h> #include <linux/init.h>
#include <linux/of_address.h> #include <linux/of_address.h>
#include <linux/of_device.h> #include <linux/of_device.h>
#include <linux/mfd/syscon.h>
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/regmap.h> #include <linux/regmap.h>
...@@ -850,25 +851,41 @@ static int axg_clkc_probe(struct platform_device *pdev) ...@@ -850,25 +851,41 @@ static int axg_clkc_probe(struct platform_device *pdev)
{ {
struct device *dev = &pdev->dev; struct device *dev = &pdev->dev;
struct resource *res; struct resource *res;
void __iomem *clk_base; void __iomem *clk_base = NULL;
struct regmap *map; struct regmap *map;
int ret, i; int ret, i;
/* Generic clocks and PLLs */ /* Get the hhi system controller node if available */
res = platform_get_resource(pdev, IORESOURCE_MEM, 0); map = syscon_node_to_regmap(of_get_parent(dev->of_node));
if (!res) if (IS_ERR(map)) {
return -EINVAL; dev_err(dev,
"failed to get HHI regmap - Trying obsolete regs\n");
/*
* FIXME: HHI registers should be accessed through
* the appropriate system controller. This is required because
* there is more than just clocks in this register space
*
* This fallback method is only provided temporarily until
* all the platform DTs are properly using the syscon node
*/
res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
if (!res)
return -EINVAL;
clk_base = devm_ioremap(dev, res->start, resource_size(res));
if (!clk_base) {
dev_err(dev, "Unable to map clk base\n");
return -ENXIO;
}
clk_base = devm_ioremap(dev, res->start, resource_size(res)); map = devm_regmap_init_mmio(dev, clk_base,
if (!clk_base) { &clkc_regmap_config);
dev_err(dev, "Unable to map clk base\n"); if (IS_ERR(map))
return -ENXIO; return PTR_ERR(map);
} }
map = devm_regmap_init_mmio(dev, clk_base, &clkc_regmap_config);
if (IS_ERR(map))
return PTR_ERR(map);
/* Populate regmap for the regmap backed clocks */ /* Populate regmap for the regmap backed clocks */
for (i = 0; i < ARRAY_SIZE(axg_clk_regmaps); i++) for (i = 0; i < ARRAY_SIZE(axg_clk_regmaps); i++)
axg_clk_regmaps[i]->map = map; axg_clk_regmaps[i]->map = map;
......
...@@ -22,6 +22,7 @@ ...@@ -22,6 +22,7 @@
#include <linux/init.h> #include <linux/init.h>
#include <linux/of_address.h> #include <linux/of_address.h>
#include <linux/of_device.h> #include <linux/of_device.h>
#include <linux/mfd/syscon.h>
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/regmap.h> #include <linux/regmap.h>
...@@ -2045,19 +2046,35 @@ static int gxbb_clkc_probe(struct platform_device *pdev) ...@@ -2045,19 +2046,35 @@ static int gxbb_clkc_probe(struct platform_device *pdev)
if (!clkc_data) if (!clkc_data)
return -EINVAL; return -EINVAL;
res = platform_get_resource(pdev, IORESOURCE_MEM, 0); /* Get the hhi system controller node if available */
if (!res) map = syscon_node_to_regmap(of_get_parent(dev->of_node));
return -EINVAL; if (IS_ERR(map)) {
dev_err(dev,
"failed to get HHI regmap - Trying obsolete regs\n");
clk_base = devm_ioremap(dev, res->start, resource_size(res)); /*
if (!clk_base) { * FIXME: HHI registers should be accessed through
pr_err("%s: Unable to map clk base\n", __func__); * the appropriate system controller. This is required because
return -ENXIO; * there is more than just clocks in this register space
} *
* This fallback method is only provided temporarily until
* all the platform DTs are properly using the syscon node
*/
res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
if (!res)
return -EINVAL;
clk_base = devm_ioremap(dev, res->start, resource_size(res));
if (!clk_base) {
dev_err(dev, "Unable to map clk base\n");
return -ENXIO;
}
map = devm_regmap_init_mmio(dev, clk_base, &clkc_regmap_config); map = devm_regmap_init_mmio(dev, clk_base,
if (IS_ERR(map)) &clkc_regmap_config);
return PTR_ERR(map); if (IS_ERR(map))
return PTR_ERR(map);
}
/* Populate regmap for the common regmap backed clocks */ /* Populate regmap for the common regmap backed clocks */
for (i = 0; i < ARRAY_SIZE(gx_clk_regmaps); i++) for (i = 0; i < ARRAY_SIZE(gx_clk_regmaps); i++)
......
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