7ecdb16fe6
This change separates two aspects of struct pinctrl: a) The data representation of the parsed mapping table, into: 1) The top-level struct pinctrl object, a single entity returned by pinctrl_get(). 2) The parsed version of each mapping table entry, struct pinctrl_setting, of which there is one per mapping table entry. b) The code that handles this; the code for (1) above is in core.c, and the code to parse/execute each entry in (2) above is in pinmux.c, while the iteration over multiple settings is lifted to core.c. This will allow the following future changes: 1) pinctrl_get() API rework, so that struct pinctrl represents all states for the device, and the device can select between them without calling put()/get() again. 2) To support that, a struct pinctrl_state object will be inserted into the data model between the struct pinctrl and struct pinctrl_setting. 3) The mapping table will be extended to allow specification of pin config settings too. To support this, struct pinctrl_setting will be enhanced to store either mux settings or config settings, and functions will be added to pinconf.c to parse/execute pin configuration settings. Signed-off-by: Stephen Warren <swarren@nvidia.com> Acked-by: Linus Walleij <linus.walleij@linaro.org> Acked-by: Dong Aisheng <dong.aisheng@linaro.org> Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
92 lines
2.3 KiB
C
92 lines
2.3 KiB
C
/*
|
|
* Internal interface between the core pin control system and the
|
|
* pinmux portions
|
|
*
|
|
* Copyright (C) 2011 ST-Ericsson SA
|
|
* Written on behalf of Linaro for ST-Ericsson
|
|
* Based on bits of regulator core, gpio core and clk core
|
|
*
|
|
* Author: Linus Walleij <linus.walleij@linaro.org>
|
|
*
|
|
* License terms: GNU General Public License (GPL) version 2
|
|
*/
|
|
#ifdef CONFIG_PINMUX
|
|
|
|
int pinmux_check_ops(struct pinctrl_dev *pctldev);
|
|
|
|
int pinmux_request_gpio(struct pinctrl_dev *pctldev,
|
|
struct pinctrl_gpio_range *range,
|
|
unsigned pin, unsigned gpio);
|
|
void pinmux_free_gpio(struct pinctrl_dev *pctldev, unsigned pin,
|
|
struct pinctrl_gpio_range *range);
|
|
int pinmux_gpio_direction(struct pinctrl_dev *pctldev,
|
|
struct pinctrl_gpio_range *range,
|
|
unsigned pin, bool input);
|
|
|
|
int pinmux_map_to_setting(struct pinctrl_map const *map,
|
|
struct pinctrl_setting *setting);
|
|
void pinmux_free_setting(struct pinctrl_setting const *setting);
|
|
int pinmux_enable_setting(struct pinctrl_setting const *setting);
|
|
void pinmux_disable_setting(struct pinctrl_setting const *setting);
|
|
|
|
void pinmux_dbg_show(struct seq_file *s, struct pinctrl_setting const *setting);
|
|
void pinmux_init_device_debugfs(struct dentry *devroot,
|
|
struct pinctrl_dev *pctldev);
|
|
|
|
#else
|
|
|
|
static inline int pinmux_check_ops(struct pinctrl_dev *pctldev)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static inline int pinmux_request_gpio(struct pinctrl_dev *pctldev,
|
|
struct pinctrl_gpio_range *range,
|
|
unsigned pin, unsigned gpio)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static inline void pinmux_free_gpio(struct pinctrl_dev *pctldev,
|
|
unsigned pin,
|
|
struct pinctrl_gpio_range *range)
|
|
{
|
|
}
|
|
|
|
static inline int pinmux_gpio_direction(struct pinctrl_dev *pctldev,
|
|
struct pinctrl_gpio_range *range,
|
|
unsigned pin, bool input)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static inline int pinmux_map_to_setting(struct pinctrl_map const *map,
|
|
struct pinctrl_setting *setting)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static inline void pinmux_free_setting(struct pinctrl_setting const *setting)
|
|
{
|
|
}
|
|
|
|
static inline int pinmux_enable_setting(struct pinctrl_setting const *setting)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static inline void pinmux_disable_setting(
|
|
struct pinctrl_setting const *setting)
|
|
{
|
|
}
|
|
|
|
static inline void pinmux_init_device_debugfs(struct dentry *devroot,
|
|
struct pinctrl_dev *pctldev)
|
|
{
|
|
}
|
|
|
|
static inline void pinmux_dbg_show(struct seq_file *s, struct pinctrl *p)
|
|
{
|
|
}
|
|
|
|
#endif
|