aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/pinctrl
diff options
context:
space:
mode:
authorLee Jones <lee.jones@linaro.org>2013-01-31 06:07:40 -0500
committerLinus Walleij <linus.walleij@linaro.org>2013-02-06 16:38:48 -0500
commitf30a3839b33c560b374c69be9ba2621d3d6a3d10 (patch)
tree97cb517942efbf5a3dd611824c7ad3809d39b2b4 /drivers/pinctrl
parentb9fab6e45d2d41de5495f7d40808e9e131652f92 (diff)
pinctrl/abx500: add Device Tree support
This patch will allow the ABX500 Pinctrl driver to be probed when Device Tree is enabled with an appropriate node contained. Signed-off-by: Lee Jones <lee.jones@linaro.org> Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
Diffstat (limited to 'drivers/pinctrl')
-rw-r--r--drivers/pinctrl/pinctrl-abx500.c36
1 files changed, 31 insertions, 5 deletions
diff --git a/drivers/pinctrl/pinctrl-abx500.c b/drivers/pinctrl/pinctrl-abx500.c
index a9e720ffabfb..17508b5820f5 100644
--- a/drivers/pinctrl/pinctrl-abx500.c
+++ b/drivers/pinctrl/pinctrl-abx500.c
@@ -14,6 +14,8 @@
14#include <linux/init.h> 14#include <linux/init.h>
15#include <linux/module.h> 15#include <linux/module.h>
16#include <linux/err.h> 16#include <linux/err.h>
17#include <linux/of.h>
18#include <linux/of_device.h>
17#include <linux/platform_device.h> 19#include <linux/platform_device.h>
18#include <linux/gpio.h> 20#include <linux/gpio.h>
19#include <linux/irq.h> 21#include <linux/irq.h>
@@ -1106,22 +1108,44 @@ static int abx500_get_gpio_num(struct abx500_pinctrl_soc_data *soc)
1106 return npins; 1108 return npins;
1107} 1109}
1108 1110
1111static const struct of_device_id abx500_gpio_match[] = {
1112 { .compatible = "stericsson,ab8500-gpio", .data = (void *)PINCTRL_AB8500, },
1113 { .compatible = "stericsson,ab8505-gpio", .data = (void *)PINCTRL_AB8505, },
1114 { .compatible = "stericsson,ab8540-gpio", .data = (void *)PINCTRL_AB8540, },
1115 { .compatible = "stericsson,ab9540-gpio", .data = (void *)PINCTRL_AB9540, },
1116};
1117
1109static int abx500_gpio_probe(struct platform_device *pdev) 1118static int abx500_gpio_probe(struct platform_device *pdev)
1110{ 1119{
1111 struct ab8500_platform_data *abx500_pdata = 1120 struct ab8500_platform_data *abx500_pdata =
1112 dev_get_platdata(pdev->dev.parent); 1121 dev_get_platdata(pdev->dev.parent);
1113 struct abx500_gpio_platform_data *pdata; 1122 struct abx500_gpio_platform_data *pdata = NULL;
1123 struct device_node *np = pdev->dev.of_node;
1114 struct abx500_pinctrl *pct; 1124 struct abx500_pinctrl *pct;
1115 const struct platform_device_id *platid = platform_get_device_id(pdev); 1125 const struct platform_device_id *platid = platform_get_device_id(pdev);
1126 unsigned int id = -1;
1116 int ret, err; 1127 int ret, err;
1117 int i; 1128 int i;
1118 1129
1119 pdata = abx500_pdata->gpio; 1130 if (abx500_pdata)
1131 pdata = abx500_pdata->gpio;
1120 if (!pdata) { 1132 if (!pdata) {
1121 dev_err(&pdev->dev, "gpio platform data missing\n"); 1133 if (np) {
1122 return -ENODEV; 1134 const struct of_device_id *match;
1135
1136 match = of_match_device(abx500_gpio_match, &pdev->dev);
1137 if (!match)
1138 return -ENODEV;
1139 id = (unsigned long)match->data;
1140 } else {
1141 dev_err(&pdev->dev, "gpio dt and platform data missing\n");
1142 return -ENODEV;
1143 }
1123 } 1144 }
1124 1145
1146 if (platid)
1147 id = platid->driver_data;
1148
1125 pct = devm_kzalloc(&pdev->dev, sizeof(struct abx500_pinctrl), 1149 pct = devm_kzalloc(&pdev->dev, sizeof(struct abx500_pinctrl),
1126 GFP_KERNEL); 1150 GFP_KERNEL);
1127 if (pct == NULL) { 1151 if (pct == NULL) {
@@ -1136,12 +1160,13 @@ static int abx500_gpio_probe(struct platform_device *pdev)
1136 pct->chip.dev = &pdev->dev; 1160 pct->chip.dev = &pdev->dev;
1137 pct->chip.base = pdata->gpio_base; 1161 pct->chip.base = pdata->gpio_base;
1138 pct->irq_base = pdata->irq_base; 1162 pct->irq_base = pdata->irq_base;
1163 pct->chip.base = (np) ? -1 : pdata->gpio_base;
1139 1164
1140 /* initialize the lock */ 1165 /* initialize the lock */
1141 mutex_init(&pct->lock); 1166 mutex_init(&pct->lock);
1142 1167
1143 /* Poke in other ASIC variants here */ 1168 /* Poke in other ASIC variants here */
1144 switch (platid->driver_data) { 1169 switch (id) {
1145 case PINCTRL_AB8500: 1170 case PINCTRL_AB8500:
1146 abx500_pinctrl_ab8500_init(&pct->soc); 1171 abx500_pinctrl_ab8500_init(&pct->soc);
1147 break; 1172 break;
@@ -1256,6 +1281,7 @@ static struct platform_driver abx500_gpio_driver = {
1256 .driver = { 1281 .driver = {
1257 .name = "abx500-gpio", 1282 .name = "abx500-gpio",
1258 .owner = THIS_MODULE, 1283 .owner = THIS_MODULE,
1284 .of_match_table = abx500_gpio_match,
1259 }, 1285 },
1260 .probe = abx500_gpio_probe, 1286 .probe = abx500_gpio_probe,
1261 .remove = abx500_gpio_remove, 1287 .remove = abx500_gpio_remove,