aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAntoine Tenart <antoine.tenart@free-electrons.com>2015-05-15 19:16:09 -0400
committerSebastian Hesselbarth <sebastian.hesselbarth@gmail.com>2015-05-18 11:52:46 -0400
commitf52bf55cba63811e1a9e16318557caa19670fbe0 (patch)
treec3d1d79ff64da2972b4a7b8f7f06e2a588e645c9
parentbfff6296180c56ccaf4ac36808440f8849aad7c1 (diff)
pinctrl: berlin: prepare to use regmap provided by syscon
The Berlin pin controller nodes will be simple-mfd probed sub-nodes of soc-controller and system-controller nodes. The register bank is managed by syscon, which provides a regmap. Prepare to get the regmap from syscon parent node instead of SoC stub provided regmap. Signed-off-by: Antoine Tenart <antoine.tenart@free-electrons.com> Acked-by: Linus Walleij <linus.walleij@linaro.org> Signed-off-by: Sebastian Hesselbarth <sebastian.hesselbarth@gmail.com>
-rw-r--r--drivers/pinctrl/berlin/berlin-bg2.c8
-rw-r--r--drivers/pinctrl/berlin/berlin-bg2cd.c8
-rw-r--r--drivers/pinctrl/berlin/berlin-bg2q.c8
-rw-r--r--drivers/pinctrl/berlin/berlin.c7
4 files changed, 30 insertions, 1 deletions
diff --git a/drivers/pinctrl/berlin/berlin-bg2.c b/drivers/pinctrl/berlin/berlin-bg2.c
index b71a6fffef1b..6931ce4b1e12 100644
--- a/drivers/pinctrl/berlin/berlin-bg2.c
+++ b/drivers/pinctrl/berlin/berlin-bg2.c
@@ -225,6 +225,14 @@ static const struct of_device_id berlin2_pinctrl_match[] = {
225 .compatible = "marvell,berlin2-system-ctrl", 225 .compatible = "marvell,berlin2-system-ctrl",
226 .data = &berlin2_sysmgr_pinctrl_data 226 .data = &berlin2_sysmgr_pinctrl_data
227 }, 227 },
228 {
229 .compatible = "marvell,berlin2-soc-pinctrl",
230 .data = &berlin2_soc_pinctrl_data
231 },
232 {
233 .compatible = "marvell,berlin2-system-pinctrl",
234 .data = &berlin2_sysmgr_pinctrl_data
235 },
228 {} 236 {}
229}; 237};
230MODULE_DEVICE_TABLE(of, berlin2_pinctrl_match); 238MODULE_DEVICE_TABLE(of, berlin2_pinctrl_match);
diff --git a/drivers/pinctrl/berlin/berlin-bg2cd.c b/drivers/pinctrl/berlin/berlin-bg2cd.c
index 19ac5a22c947..18e1af0e6b8c 100644
--- a/drivers/pinctrl/berlin/berlin-bg2cd.c
+++ b/drivers/pinctrl/berlin/berlin-bg2cd.c
@@ -168,6 +168,14 @@ static const struct of_device_id berlin2cd_pinctrl_match[] = {
168 .compatible = "marvell,berlin2cd-system-ctrl", 168 .compatible = "marvell,berlin2cd-system-ctrl",
169 .data = &berlin2cd_sysmgr_pinctrl_data 169 .data = &berlin2cd_sysmgr_pinctrl_data
170 }, 170 },
171 {
172 .compatible = "marvell,berlin2cd-soc-pinctrl",
173 .data = &berlin2cd_soc_pinctrl_data
174 },
175 {
176 .compatible = "marvell,berlin2cd-system-pinctrl",
177 .data = &berlin2cd_sysmgr_pinctrl_data
178 },
171 {} 179 {}
172}; 180};
173MODULE_DEVICE_TABLE(of, berlin2cd_pinctrl_match); 181MODULE_DEVICE_TABLE(of, berlin2cd_pinctrl_match);
diff --git a/drivers/pinctrl/berlin/berlin-bg2q.c b/drivers/pinctrl/berlin/berlin-bg2q.c
index bd9662e57ad3..24e4cbb4d044 100644
--- a/drivers/pinctrl/berlin/berlin-bg2q.c
+++ b/drivers/pinctrl/berlin/berlin-bg2q.c
@@ -387,6 +387,14 @@ static const struct of_device_id berlin2q_pinctrl_match[] = {
387 .compatible = "marvell,berlin2q-system-ctrl", 387 .compatible = "marvell,berlin2q-system-ctrl",
388 .data = &berlin2q_sysmgr_pinctrl_data, 388 .data = &berlin2q_sysmgr_pinctrl_data,
389 }, 389 },
390 {
391 .compatible = "marvell,berlin2q-soc-pinctrl",
392 .data = &berlin2q_soc_pinctrl_data,
393 },
394 {
395 .compatible = "marvell,berlin2q-system-pinctrl",
396 .data = &berlin2q_sysmgr_pinctrl_data,
397 },
390 {} 398 {}
391}; 399};
392MODULE_DEVICE_TABLE(of, berlin2q_pinctrl_match); 400MODULE_DEVICE_TABLE(of, berlin2q_pinctrl_match);
diff --git a/drivers/pinctrl/berlin/berlin.c b/drivers/pinctrl/berlin/berlin.c
index 7f0b0f93242b..28551123d04f 100644
--- a/drivers/pinctrl/berlin/berlin.c
+++ b/drivers/pinctrl/berlin/berlin.c
@@ -11,6 +11,7 @@
11 */ 11 */
12 12
13#include <linux/io.h> 13#include <linux/io.h>
14#include <linux/mfd/syscon.h>
14#include <linux/module.h> 15#include <linux/module.h>
15#include <linux/of.h> 16#include <linux/of.h>
16#include <linux/of_address.h> 17#include <linux/of_address.h>
@@ -295,13 +296,17 @@ int berlin_pinctrl_probe(struct platform_device *pdev,
295 const struct berlin_pinctrl_desc *desc) 296 const struct berlin_pinctrl_desc *desc)
296{ 297{
297 struct device *dev = &pdev->dev; 298 struct device *dev = &pdev->dev;
299 struct device_node *parent_np = of_get_parent(dev->of_node);
298 struct berlin_pinctrl *pctrl; 300 struct berlin_pinctrl *pctrl;
299 struct regmap *regmap; 301 struct regmap *regmap;
300 int ret; 302 int ret;
301 303
302 regmap = dev_get_regmap(&pdev->dev, NULL); 304 regmap = dev_get_regmap(&pdev->dev, NULL);
303 if (!regmap) 305 if (!regmap)
304 return -ENODEV; 306 regmap = syscon_node_to_regmap(parent_np);
307 of_node_put(parent_np);
308 if (IS_ERR(regmap))
309 return PTR_ERR(regmap);
305 310
306 pctrl = devm_kzalloc(dev, sizeof(*pctrl), GFP_KERNEL); 311 pctrl = devm_kzalloc(dev, sizeof(*pctrl), GFP_KERNEL);
307 if (!pctrl) 312 if (!pctrl)