aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/pinctrl/pinconf.c
diff options
context:
space:
mode:
authorLinus Walleij <linus.walleij@linaro.org>2011-11-24 12:27:15 -0500
committerLinus Walleij <linus.walleij@linaro.org>2012-03-12 17:49:02 -0400
commit394349f7789fdfcdc74b61afcac84046535c40b7 (patch)
tree20dd88e7a1f2dba0a1c227f53960013bf956fa43 /drivers/pinctrl/pinconf.c
parent70b36378d44d7f5e62458a830b1a9bb1c570f28a (diff)
pinctrl: introduce generic pin config
This is a split-off from the earlier patch set which adds generic pin configuration for the pin controllers that want it. Since we may have a system with mixed generic and custom pin controllers, we pass a boolean in the pin controller ops vtable to indicate if it is generic. ChangeLog v1->v5: - Follow parent patch versioning number system. - Document the semantic meaning of return values from pin config get functions, so we can iterate over pins and check their properties from debugfs as part of the generic config code. - Use proper cast functions in the generic debugfs pin config file. - Expand generic config to optionally cover groups too. ChangeLog v5->v6: - Update to match underlying changes. ChangeLog v6->v7: - Drop DRIVE_OFF parameter, use bias high impedance for this - Delete argument for drive modes push-pull, od and os. These are now just state transitions. - Delete slew rate rising/falling due to discussions on on proper semantics - Drop config wakeup, struct irq_chip does this for now, add back if need be. - Set PIN_CONFIG_END to 0x7fff making room for custom config parameters from 0x8000 and up. - Prefix accessor functions with pinconf_
Diffstat (limited to 'drivers/pinctrl/pinconf.c')
-rw-r--r--drivers/pinctrl/pinconf.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/drivers/pinctrl/pinconf.c b/drivers/pinctrl/pinconf.c
index b40ac1b4fb17..7321e8601294 100644
--- a/drivers/pinctrl/pinconf.c
+++ b/drivers/pinctrl/pinconf.c
@@ -54,7 +54,7 @@ int pinconf_validate_map(struct pinctrl_map const *map, int i)
54 return 0; 54 return 0;
55} 55}
56 56
57static int pin_config_get_for_pin(struct pinctrl_dev *pctldev, unsigned pin, 57int pin_config_get_for_pin(struct pinctrl_dev *pctldev, unsigned pin,
58 unsigned long *config) 58 unsigned long *config)
59{ 59{
60 const struct pinconf_ops *ops = pctldev->desc->confops; 60 const struct pinconf_ops *ops = pctldev->desc->confops;
@@ -439,6 +439,8 @@ static void pinconf_dump_pin(struct pinctrl_dev *pctldev,
439{ 439{
440 const struct pinconf_ops *ops = pctldev->desc->confops; 440 const struct pinconf_ops *ops = pctldev->desc->confops;
441 441
442 /* no-op when not using generic pin config */
443 pinconf_generic_dump_pin(pctldev, s, pin);
442 if (ops && ops->pin_config_dbg_show) 444 if (ops && ops->pin_config_dbg_show)
443 ops->pin_config_dbg_show(pctldev, s, pin); 445 ops->pin_config_dbg_show(pctldev, s, pin);
444} 446}
@@ -482,6 +484,8 @@ static void pinconf_dump_group(struct pinctrl_dev *pctldev,
482{ 484{
483 const struct pinconf_ops *ops = pctldev->desc->confops; 485 const struct pinconf_ops *ops = pctldev->desc->confops;
484 486
487 /* no-op when not using generic pin config */
488 pinconf_generic_dump_group(pctldev, s, gname);
485 if (ops && ops->pin_config_group_dbg_show) 489 if (ops && ops->pin_config_group_dbg_show)
486 ops->pin_config_group_dbg_show(pctldev, s, selector); 490 ops->pin_config_group_dbg_show(pctldev, s, selector);
487} 491}