Skip to content

Commit 5b3aa5f

Browse files
Dong Aishenglinusw
authored andcommitted
pinctrl: add pinctrl_provide_dummies interface for platforms to use
Add a interface pinctrl_provide_dummies for platform to indicate whether it needs use pinctrl dummy state. ChangeLog v3->v4: * remove dummy gpio support in pinctrl subsystem. Let gpio driver decide whether it wants to use pinctrl gpio mux function. ChangeLog v2->v3: * Also changed the missed pinctrl gpio APIs in v1. ChangeLog v1->v2: * Based on sascha's suggestion, drop using kconfig since it will hide pinctrl errors on all other boards. See: https://lkml.org/lkml/2012/4/18/282 It seemed both Linus and Stephen agreed with this way, so i'm ok with it too. * Add dummy gpio support. pinctrl gpio in the same situation as state. * Patch name changed. Original is pinctrl: handle dummy state in core. * Split removing old dt dummy interface into a separate patch Cc: Linus Walleij <linus.walleij@linaro.org> Cc: Sascha Hauer <s.hauer@pengutronix.de> Acked-by: Stephen Warren <swarren@wwwdotorg.org> Signed-off-by: Dong Aisheng <dong.aisheng@linaro.org> Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
1 parent ad6e110 commit 5b3aa5f

File tree

2 files changed

+31
-3
lines changed

2 files changed

+31
-3
lines changed

drivers/pinctrl/core.c

Lines changed: 27 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -43,6 +43,8 @@ struct pinctrl_maps {
4343
unsigned num_maps;
4444
};
4545

46+
static bool pinctrl_dummy_state;
47+
4648
/* Mutex taken by all entry points */
4749
DEFINE_MUTEX(pinctrl_mutex);
4850

@@ -61,6 +63,19 @@ static LIST_HEAD(pinctrl_maps);
6163
_i_ < _maps_node_->num_maps; \
6264
i++, _map_ = &_maps_node_->maps[_i_])
6365

66+
/**
67+
* pinctrl_provide_dummies() - indicate if pinctrl provides dummy state support
68+
*
69+
* Usually this function is called by platforms without pinctrl driver support
70+
* but run with some shared drivers using pinctrl APIs.
71+
* After calling this function, the pinctrl core will return successfully
72+
* with creating a dummy state for the driver to keep going smoothly.
73+
*/
74+
void pinctrl_provide_dummies(void)
75+
{
76+
pinctrl_dummy_state = true;
77+
}
78+
6479
const char *pinctrl_dev_get_name(struct pinctrl_dev *pctldev)
6580
{
6681
/* We're not allowed to register devices without name */
@@ -719,8 +734,18 @@ static struct pinctrl_state *pinctrl_lookup_state_locked(struct pinctrl *p,
719734
struct pinctrl_state *state;
720735

721736
state = find_state(p, name);
722-
if (!state)
723-
return ERR_PTR(-ENODEV);
737+
if (!state) {
738+
if (pinctrl_dummy_state) {
739+
/* create dummy state */
740+
dev_dbg(p->dev, "using pinctrl dummy state (%s)\n",
741+
name);
742+
state = create_state(p, name);
743+
if (IS_ERR(state))
744+
return state;
745+
} else {
746+
return ERR_PTR(-ENODEV);
747+
}
748+
}
724749

725750
return state;
726751
}

include/linux/pinctrl/machine.h

Lines changed: 4 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -154,7 +154,7 @@ struct pinctrl_map {
154154

155155
extern int pinctrl_register_mappings(struct pinctrl_map const *map,
156156
unsigned num_maps);
157-
157+
extern void pinctrl_provide_dummies(void);
158158
#else
159159

160160
static inline int pinctrl_register_mappings(struct pinctrl_map const *map,
@@ -163,5 +163,8 @@ static inline int pinctrl_register_mappings(struct pinctrl_map const *map,
163163
return 0;
164164
}
165165

166+
static inline void pinctrl_provide_dummies(void)
167+
{
168+
}
166169
#endif /* !CONFIG_PINCTRL */
167170
#endif

0 commit comments

Comments
 (0)