diff options
Diffstat (limited to 'include/linux')
-rw-r--r-- | include/linux/of.h | 35 | ||||
-rw-r--r-- | include/linux/pinctrl/consumer.h | 44 | ||||
-rw-r--r-- | include/linux/pinctrl/pinconf.h | 5 | ||||
-rw-r--r-- | include/linux/pinctrl/pinctrl.h | 13 | ||||
-rw-r--r-- | include/linux/pinctrl/pinmux.h | 7 | ||||
-rw-r--r-- | include/linux/platform_data/tegra_usb.h | 1 |
6 files changed, 97 insertions, 8 deletions
diff --git a/include/linux/of.h b/include/linux/of.h index fa7fb1d97458..e3f942d9da89 100644 --- a/include/linux/of.h +++ b/include/linux/of.h | |||
@@ -259,6 +259,37 @@ extern void of_detach_node(struct device_node *); | |||
259 | #endif | 259 | #endif |
260 | 260 | ||
261 | #define of_match_ptr(_ptr) (_ptr) | 261 | #define of_match_ptr(_ptr) (_ptr) |
262 | |||
263 | /* | ||
264 | * struct property *prop; | ||
265 | * const __be32 *p; | ||
266 | * u32 u; | ||
267 | * | ||
268 | * of_property_for_each_u32(np, "propname", prop, p, u) | ||
269 | * printk("U32 value: %x\n", u); | ||
270 | */ | ||
271 | const __be32 *of_prop_next_u32(struct property *prop, const __be32 *cur, | ||
272 | u32 *pu); | ||
273 | #define of_property_for_each_u32(np, propname, prop, p, u) \ | ||
274 | for (prop = of_find_property(np, propname, NULL), \ | ||
275 | p = of_prop_next_u32(prop, NULL, &u); \ | ||
276 | p; \ | ||
277 | p = of_prop_next_u32(prop, p, &u)) | ||
278 | |||
279 | /* | ||
280 | * struct property *prop; | ||
281 | * const char *s; | ||
282 | * | ||
283 | * of_property_for_each_string(np, "propname", prop, s) | ||
284 | * printk("String value: %s\n", s); | ||
285 | */ | ||
286 | const char *of_prop_next_string(struct property *prop, const char *cur); | ||
287 | #define of_property_for_each_string(np, propname, prop, s) \ | ||
288 | for (prop = of_find_property(np, propname, NULL), \ | ||
289 | s = of_prop_next_string(prop, NULL); \ | ||
290 | s; \ | ||
291 | s = of_prop_next_string(prop, s)) | ||
292 | |||
262 | #else /* CONFIG_OF */ | 293 | #else /* CONFIG_OF */ |
263 | 294 | ||
264 | static inline bool of_have_populated_dt(void) | 295 | static inline bool of_have_populated_dt(void) |
@@ -349,6 +380,10 @@ static inline int of_machine_is_compatible(const char *compat) | |||
349 | 380 | ||
350 | #define of_match_ptr(_ptr) NULL | 381 | #define of_match_ptr(_ptr) NULL |
351 | #define of_match_node(_matches, _node) NULL | 382 | #define of_match_node(_matches, _node) NULL |
383 | #define of_property_for_each_u32(np, propname, prop, p, u) \ | ||
384 | while (0) | ||
385 | #define of_property_for_each_string(np, propname, prop, s) \ | ||
386 | while (0) | ||
352 | #endif /* CONFIG_OF */ | 387 | #endif /* CONFIG_OF */ |
353 | 388 | ||
354 | /** | 389 | /** |
diff --git a/include/linux/pinctrl/consumer.h b/include/linux/pinctrl/consumer.h index 191e72688481..6dd96fb45482 100644 --- a/include/linux/pinctrl/consumer.h +++ b/include/linux/pinctrl/consumer.h | |||
@@ -36,6 +36,9 @@ extern struct pinctrl_state * __must_check pinctrl_lookup_state( | |||
36 | const char *name); | 36 | const char *name); |
37 | extern int pinctrl_select_state(struct pinctrl *p, struct pinctrl_state *s); | 37 | extern int pinctrl_select_state(struct pinctrl *p, struct pinctrl_state *s); |
38 | 38 | ||
39 | extern struct pinctrl * __must_check devm_pinctrl_get(struct device *dev); | ||
40 | extern void devm_pinctrl_put(struct pinctrl *p); | ||
41 | |||
39 | #else /* !CONFIG_PINCTRL */ | 42 | #else /* !CONFIG_PINCTRL */ |
40 | 43 | ||
41 | static inline int pinctrl_request_gpio(unsigned gpio) | 44 | static inline int pinctrl_request_gpio(unsigned gpio) |
@@ -79,6 +82,15 @@ static inline int pinctrl_select_state(struct pinctrl *p, | |||
79 | return 0; | 82 | return 0; |
80 | } | 83 | } |
81 | 84 | ||
85 | static inline struct pinctrl * __must_check devm_pinctrl_get(struct device *dev) | ||
86 | { | ||
87 | return NULL; | ||
88 | } | ||
89 | |||
90 | static inline void devm_pinctrl_put(struct pinctrl *p) | ||
91 | { | ||
92 | } | ||
93 | |||
82 | #endif /* CONFIG_PINCTRL */ | 94 | #endif /* CONFIG_PINCTRL */ |
83 | 95 | ||
84 | static inline struct pinctrl * __must_check pinctrl_get_select( | 96 | static inline struct pinctrl * __must_check pinctrl_get_select( |
@@ -113,6 +125,38 @@ static inline struct pinctrl * __must_check pinctrl_get_select_default( | |||
113 | return pinctrl_get_select(dev, PINCTRL_STATE_DEFAULT); | 125 | return pinctrl_get_select(dev, PINCTRL_STATE_DEFAULT); |
114 | } | 126 | } |
115 | 127 | ||
128 | static inline struct pinctrl * __must_check devm_pinctrl_get_select( | ||
129 | struct device *dev, const char *name) | ||
130 | { | ||
131 | struct pinctrl *p; | ||
132 | struct pinctrl_state *s; | ||
133 | int ret; | ||
134 | |||
135 | p = devm_pinctrl_get(dev); | ||
136 | if (IS_ERR(p)) | ||
137 | return p; | ||
138 | |||
139 | s = pinctrl_lookup_state(p, name); | ||
140 | if (IS_ERR(s)) { | ||
141 | devm_pinctrl_put(p); | ||
142 | return ERR_PTR(PTR_ERR(s)); | ||
143 | } | ||
144 | |||
145 | ret = pinctrl_select_state(p, s); | ||
146 | if (ret < 0) { | ||
147 | devm_pinctrl_put(p); | ||
148 | return ERR_PTR(ret); | ||
149 | } | ||
150 | |||
151 | return p; | ||
152 | } | ||
153 | |||
154 | static inline struct pinctrl * __must_check devm_pinctrl_get_select_default( | ||
155 | struct device *dev) | ||
156 | { | ||
157 | return devm_pinctrl_get_select(dev, PINCTRL_STATE_DEFAULT); | ||
158 | } | ||
159 | |||
116 | #ifdef CONFIG_PINCONF | 160 | #ifdef CONFIG_PINCONF |
117 | 161 | ||
118 | extern int pin_config_get(const char *dev_name, const char *name, | 162 | extern int pin_config_get(const char *dev_name, const char *name, |
diff --git a/include/linux/pinctrl/pinconf.h b/include/linux/pinctrl/pinconf.h index ec431f03362d..7b9d5f00ed37 100644 --- a/include/linux/pinctrl/pinconf.h +++ b/include/linux/pinctrl/pinconf.h | |||
@@ -33,6 +33,8 @@ struct seq_file; | |||
33 | * per-device info for a certain pin in debugfs | 33 | * per-device info for a certain pin in debugfs |
34 | * @pin_config_group_dbg_show: optional debugfs display hook that will provide | 34 | * @pin_config_group_dbg_show: optional debugfs display hook that will provide |
35 | * per-device info for a certain group in debugfs | 35 | * per-device info for a certain group in debugfs |
36 | * @pin_config_config_dbg_show: optional debugfs display hook that will decode | ||
37 | * and display a driver's pin configuration parameter | ||
36 | */ | 38 | */ |
37 | struct pinconf_ops { | 39 | struct pinconf_ops { |
38 | #ifdef CONFIG_GENERIC_PINCONF | 40 | #ifdef CONFIG_GENERIC_PINCONF |
@@ -56,6 +58,9 @@ struct pinconf_ops { | |||
56 | void (*pin_config_group_dbg_show) (struct pinctrl_dev *pctldev, | 58 | void (*pin_config_group_dbg_show) (struct pinctrl_dev *pctldev, |
57 | struct seq_file *s, | 59 | struct seq_file *s, |
58 | unsigned selector); | 60 | unsigned selector); |
61 | void (*pin_config_config_dbg_show) (struct pinctrl_dev *pctldev, | ||
62 | struct seq_file *s, | ||
63 | unsigned long config); | ||
59 | }; | 64 | }; |
60 | 65 | ||
61 | #endif | 66 | #endif |
diff --git a/include/linux/pinctrl/pinctrl.h b/include/linux/pinctrl/pinctrl.h index 4e9f0788c221..c22d0409d2ef 100644 --- a/include/linux/pinctrl/pinctrl.h +++ b/include/linux/pinctrl/pinctrl.h | |||
@@ -21,9 +21,11 @@ | |||
21 | 21 | ||
22 | struct device; | 22 | struct device; |
23 | struct pinctrl_dev; | 23 | struct pinctrl_dev; |
24 | struct pinctrl_map; | ||
24 | struct pinmux_ops; | 25 | struct pinmux_ops; |
25 | struct pinconf_ops; | 26 | struct pinconf_ops; |
26 | struct gpio_chip; | 27 | struct gpio_chip; |
28 | struct device_node; | ||
27 | 29 | ||
28 | /** | 30 | /** |
29 | * struct pinctrl_pin_desc - boards/machines provide information on their | 31 | * struct pinctrl_pin_desc - boards/machines provide information on their |
@@ -64,9 +66,7 @@ struct pinctrl_gpio_range { | |||
64 | /** | 66 | /** |
65 | * struct pinctrl_ops - global pin control operations, to be implemented by | 67 | * struct pinctrl_ops - global pin control operations, to be implemented by |
66 | * pin controller drivers. | 68 | * pin controller drivers. |
67 | * @list_groups: list the number of selectable named groups available | 69 | * @get_groups_count: Returns the count of total number of groups registered. |
68 | * in this pinmux driver, the core will begin on 0 and call this | ||
69 | * repeatedly as long as it returns >= 0 to enumerate the groups | ||
70 | * @get_group_name: return the group name of the pin group | 70 | * @get_group_name: return the group name of the pin group |
71 | * @get_group_pins: return an array of pins corresponding to a certain | 71 | * @get_group_pins: return an array of pins corresponding to a certain |
72 | * group selector @pins, and the size of the array in @num_pins | 72 | * group selector @pins, and the size of the array in @num_pins |
@@ -74,7 +74,7 @@ struct pinctrl_gpio_range { | |||
74 | * info for a certain pin in debugfs | 74 | * info for a certain pin in debugfs |
75 | */ | 75 | */ |
76 | struct pinctrl_ops { | 76 | struct pinctrl_ops { |
77 | int (*list_groups) (struct pinctrl_dev *pctldev, unsigned selector); | 77 | int (*get_groups_count) (struct pinctrl_dev *pctldev); |
78 | const char *(*get_group_name) (struct pinctrl_dev *pctldev, | 78 | const char *(*get_group_name) (struct pinctrl_dev *pctldev, |
79 | unsigned selector); | 79 | unsigned selector); |
80 | int (*get_group_pins) (struct pinctrl_dev *pctldev, | 80 | int (*get_group_pins) (struct pinctrl_dev *pctldev, |
@@ -83,6 +83,11 @@ struct pinctrl_ops { | |||
83 | unsigned *num_pins); | 83 | unsigned *num_pins); |
84 | void (*pin_dbg_show) (struct pinctrl_dev *pctldev, struct seq_file *s, | 84 | void (*pin_dbg_show) (struct pinctrl_dev *pctldev, struct seq_file *s, |
85 | unsigned offset); | 85 | unsigned offset); |
86 | int (*dt_node_to_map) (struct pinctrl_dev *pctldev, | ||
87 | struct device_node *np_config, | ||
88 | struct pinctrl_map **map, unsigned *num_maps); | ||
89 | void (*dt_free_map) (struct pinctrl_dev *pctldev, | ||
90 | struct pinctrl_map *map, unsigned num_maps); | ||
86 | }; | 91 | }; |
87 | 92 | ||
88 | /** | 93 | /** |
diff --git a/include/linux/pinctrl/pinmux.h b/include/linux/pinctrl/pinmux.h index 47e9237edd47..dd7bef61d066 100644 --- a/include/linux/pinctrl/pinmux.h +++ b/include/linux/pinctrl/pinmux.h | |||
@@ -29,9 +29,8 @@ struct pinctrl_dev; | |||
29 | * is allowed to answer "no" by returning a negative error code | 29 | * is allowed to answer "no" by returning a negative error code |
30 | * @free: the reverse function of the request() callback, frees a pin after | 30 | * @free: the reverse function of the request() callback, frees a pin after |
31 | * being requested | 31 | * being requested |
32 | * @list_functions: list the number of selectable named functions available | 32 | * @get_functions_count: returns number of selectable named functions available |
33 | * in this pinmux driver, the core will begin on 0 and call this | 33 | * in this pinmux driver |
34 | * repeatedly as long as it returns >= 0 to enumerate mux settings | ||
35 | * @get_function_name: return the function name of the muxing selector, | 34 | * @get_function_name: return the function name of the muxing selector, |
36 | * called by the core to figure out which mux setting it shall map a | 35 | * called by the core to figure out which mux setting it shall map a |
37 | * certain device to | 36 | * certain device to |
@@ -62,7 +61,7 @@ struct pinctrl_dev; | |||
62 | struct pinmux_ops { | 61 | struct pinmux_ops { |
63 | int (*request) (struct pinctrl_dev *pctldev, unsigned offset); | 62 | int (*request) (struct pinctrl_dev *pctldev, unsigned offset); |
64 | int (*free) (struct pinctrl_dev *pctldev, unsigned offset); | 63 | int (*free) (struct pinctrl_dev *pctldev, unsigned offset); |
65 | int (*list_functions) (struct pinctrl_dev *pctldev, unsigned selector); | 64 | int (*get_functions_count) (struct pinctrl_dev *pctldev); |
66 | const char *(*get_function_name) (struct pinctrl_dev *pctldev, | 65 | const char *(*get_function_name) (struct pinctrl_dev *pctldev, |
67 | unsigned selector); | 66 | unsigned selector); |
68 | int (*get_function_groups) (struct pinctrl_dev *pctldev, | 67 | int (*get_function_groups) (struct pinctrl_dev *pctldev, |
diff --git a/include/linux/platform_data/tegra_usb.h b/include/linux/platform_data/tegra_usb.h index 6bca5b569acb..66c673fef408 100644 --- a/include/linux/platform_data/tegra_usb.h +++ b/include/linux/platform_data/tegra_usb.h | |||
@@ -26,6 +26,7 @@ struct tegra_ehci_platform_data { | |||
26 | /* power down the phy on bus suspend */ | 26 | /* power down the phy on bus suspend */ |
27 | int power_down_on_bus_suspend; | 27 | int power_down_on_bus_suspend; |
28 | void *phy_config; | 28 | void *phy_config; |
29 | int vbus_gpio; | ||
29 | }; | 30 | }; |
30 | 31 | ||
31 | #endif /* _TEGRA_USB_H_ */ | 32 | #endif /* _TEGRA_USB_H_ */ |