diff options
author | Antoine Tenart <antoine.tenart@free-electrons.com> | 2015-05-15 19:16:09 -0400 |
---|---|---|
committer | Sebastian Hesselbarth <sebastian.hesselbarth@gmail.com> | 2015-05-18 11:52:46 -0400 |
commit | f52bf55cba63811e1a9e16318557caa19670fbe0 (patch) | |
tree | c3d1d79ff64da2972b4a7b8f7f06e2a588e645c9 | |
parent | bfff6296180c56ccaf4ac36808440f8849aad7c1 (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.c | 8 | ||||
-rw-r--r-- | drivers/pinctrl/berlin/berlin-bg2cd.c | 8 | ||||
-rw-r--r-- | drivers/pinctrl/berlin/berlin-bg2q.c | 8 | ||||
-rw-r--r-- | drivers/pinctrl/berlin/berlin.c | 7 |
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 | }; |
230 | MODULE_DEVICE_TABLE(of, berlin2_pinctrl_match); | 238 | MODULE_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 | }; |
173 | MODULE_DEVICE_TABLE(of, berlin2cd_pinctrl_match); | 181 | MODULE_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 | }; |
392 | MODULE_DEVICE_TABLE(of, berlin2q_pinctrl_match); | 400 | MODULE_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) |