Merge remote-tracking branch 'asoc/topic/qcom' into asoc-next
[deliverable/linux.git] / include / linux / pinctrl / consumer.h
CommitLineData
28a8d14c
LW
1/*
2 * Consumer interface the pin control subsystem
3 *
4 * Copyright (C) 2012 ST-Ericsson SA
5 * Written on behalf of Linaro for ST-Ericsson
6 * Based on bits of regulator core, gpio core and clk core
7 *
8 * Author: Linus Walleij <linus.walleij@linaro.org>
9 *
10 * License terms: GNU General Public License (GPL) version 2
11 */
12#ifndef __LINUX_PINCTRL_CONSUMER_H
13#define __LINUX_PINCTRL_CONSUMER_H
14
6e5e959d 15#include <linux/err.h>
28a8d14c
LW
16#include <linux/list.h>
17#include <linux/seq_file.h>
a1ce3928 18#include <linux/pinctrl/pinctrl-state.h>
28a8d14c
LW
19
20/* This struct is private to the core and should be regarded as a cookie */
e93bcee0 21struct pinctrl;
6e5e959d 22struct pinctrl_state;
ac5aa7f9 23struct device;
28a8d14c 24
befe5bdf 25#ifdef CONFIG_PINCTRL
28a8d14c 26
befe5bdf 27/* External interface to pin control */
e93bcee0
LW
28extern int pinctrl_request_gpio(unsigned gpio);
29extern void pinctrl_free_gpio(unsigned gpio);
30extern int pinctrl_gpio_direction_input(unsigned gpio);
31extern int pinctrl_gpio_direction_output(unsigned gpio);
6e5e959d
SW
32
33extern struct pinctrl * __must_check pinctrl_get(struct device *dev);
e93bcee0 34extern void pinctrl_put(struct pinctrl *p);
6e5e959d
SW
35extern struct pinctrl_state * __must_check pinctrl_lookup_state(
36 struct pinctrl *p,
37 const char *name);
38extern int pinctrl_select_state(struct pinctrl *p, struct pinctrl_state *s);
28a8d14c 39
6d4ca1fb
SW
40extern struct pinctrl * __must_check devm_pinctrl_get(struct device *dev);
41extern void devm_pinctrl_put(struct pinctrl *p);
42
14005ee2
LW
43#ifdef CONFIG_PM
44extern int pinctrl_pm_select_default_state(struct device *dev);
45extern int pinctrl_pm_select_sleep_state(struct device *dev);
46extern int pinctrl_pm_select_idle_state(struct device *dev);
47#else
48static inline int pinctrl_pm_select_default_state(struct device *dev)
49{
50 return 0;
51}
52static inline int pinctrl_pm_select_sleep_state(struct device *dev)
53{
54 return 0;
55}
56static inline int pinctrl_pm_select_idle_state(struct device *dev)
57{
58 return 0;
59}
60#endif
61
befe5bdf 62#else /* !CONFIG_PINCTRL */
28a8d14c 63
e93bcee0 64static inline int pinctrl_request_gpio(unsigned gpio)
28a8d14c
LW
65{
66 return 0;
67}
68
e93bcee0 69static inline void pinctrl_free_gpio(unsigned gpio)
28a8d14c
LW
70{
71}
72
e93bcee0 73static inline int pinctrl_gpio_direction_input(unsigned gpio)
28a8d14c
LW
74{
75 return 0;
76}
77
e93bcee0 78static inline int pinctrl_gpio_direction_output(unsigned gpio)
28a8d14c
LW
79{
80 return 0;
81}
82
6e5e959d 83static inline struct pinctrl * __must_check pinctrl_get(struct device *dev)
28a8d14c 84{
40eeb111 85 return NULL;
28a8d14c
LW
86}
87
e93bcee0 88static inline void pinctrl_put(struct pinctrl *p)
28a8d14c
LW
89{
90}
91
6e5e959d
SW
92static inline struct pinctrl_state * __must_check pinctrl_lookup_state(
93 struct pinctrl *p,
94 const char *name)
28a8d14c 95{
40eeb111 96 return NULL;
28a8d14c
LW
97}
98
6e5e959d
SW
99static inline int pinctrl_select_state(struct pinctrl *p,
100 struct pinctrl_state *s)
28a8d14c 101{
6e5e959d 102 return 0;
28a8d14c
LW
103}
104
6d4ca1fb
SW
105static inline struct pinctrl * __must_check devm_pinctrl_get(struct device *dev)
106{
40eeb111 107 return NULL;
6d4ca1fb
SW
108}
109
110static inline void devm_pinctrl_put(struct pinctrl *p)
111{
112}
113
ff73ceed
LW
114static inline int pinctrl_pm_select_default_state(struct device *dev)
115{
116 return 0;
117}
118
119static inline int pinctrl_pm_select_sleep_state(struct device *dev)
120{
121 return 0;
122}
123
124static inline int pinctrl_pm_select_idle_state(struct device *dev)
125{
126 return 0;
127}
128
befe5bdf 129#endif /* CONFIG_PINCTRL */
28a8d14c 130
6e5e959d
SW
131static inline struct pinctrl * __must_check pinctrl_get_select(
132 struct device *dev, const char *name)
133{
134 struct pinctrl *p;
135 struct pinctrl_state *s;
136 int ret;
137
138 p = pinctrl_get(dev);
139 if (IS_ERR(p))
140 return p;
141
142 s = pinctrl_lookup_state(p, name);
143 if (IS_ERR(s)) {
144 pinctrl_put(p);
66eb3bd8 145 return ERR_CAST(s);
6e5e959d
SW
146 }
147
148 ret = pinctrl_select_state(p, s);
149 if (ret < 0) {
150 pinctrl_put(p);
151 return ERR_PTR(ret);
152 }
153
154 return p;
155}
156
157static inline struct pinctrl * __must_check pinctrl_get_select_default(
158 struct device *dev)
159{
160 return pinctrl_get_select(dev, PINCTRL_STATE_DEFAULT);
6d4ca1fb
SW
161}
162
163static inline struct pinctrl * __must_check devm_pinctrl_get_select(
164 struct device *dev, const char *name)
165{
166 struct pinctrl *p;
167 struct pinctrl_state *s;
168 int ret;
169
170 p = devm_pinctrl_get(dev);
171 if (IS_ERR(p))
172 return p;
173
174 s = pinctrl_lookup_state(p, name);
175 if (IS_ERR(s)) {
176 devm_pinctrl_put(p);
e60bc2df 177 return ERR_CAST(s);
6d4ca1fb
SW
178 }
179
180 ret = pinctrl_select_state(p, s);
181 if (ret < 0) {
182 devm_pinctrl_put(p);
183 return ERR_PTR(ret);
184 }
185
186 return p;
187}
188
189static inline struct pinctrl * __must_check devm_pinctrl_get_select_default(
190 struct device *dev)
191{
192 return devm_pinctrl_get_select(dev, PINCTRL_STATE_DEFAULT);
6e5e959d
SW
193}
194
28a8d14c 195#endif /* __LINUX_PINCTRL_CONSUMER_H */
This page took 0.390336 seconds and 5 git commands to generate.