blob: 9c0e5d1954d87c7d2961a3732e04ed276fbf6f0d [file] [log] [blame]
Mike Frysinger83ebf372010-06-02 04:17:26 -04001/*
2 * Copyright 2006-2009 Analog Devices Inc.
3 *
4 * Licensed under the GPL-2 or later.
5 */
6
7#ifndef __ARCH_BLACKFIN_GPIO_H__
8#define __ARCH_BLACKFIN_GPIO_H__
9
10#define gpio_bank(x) ((x) >> 4)
11#define gpio_bit(x) (1<<((x) & 0xF))
12#define gpio_sub_n(x) ((x) & 0xF)
13
14#define GPIO_BANKSIZE 16
15#define GPIO_BANK_NUM DIV_ROUND_UP(MAX_BLACKFIN_GPIOS, GPIO_BANKSIZE)
16
17#define GPIO_0 0
18#define GPIO_1 1
19#define GPIO_2 2
20#define GPIO_3 3
21#define GPIO_4 4
22#define GPIO_5 5
23#define GPIO_6 6
24#define GPIO_7 7
25#define GPIO_8 8
26#define GPIO_9 9
27#define GPIO_10 10
28#define GPIO_11 11
29#define GPIO_12 12
30#define GPIO_13 13
31#define GPIO_14 14
32#define GPIO_15 15
33#define GPIO_16 16
34#define GPIO_17 17
35#define GPIO_18 18
36#define GPIO_19 19
37#define GPIO_20 20
38#define GPIO_21 21
39#define GPIO_22 22
40#define GPIO_23 23
41#define GPIO_24 24
42#define GPIO_25 25
43#define GPIO_26 26
44#define GPIO_27 27
45#define GPIO_28 28
46#define GPIO_29 29
47#define GPIO_30 30
48#define GPIO_31 31
49#define GPIO_32 32
50#define GPIO_33 33
51#define GPIO_34 34
52#define GPIO_35 35
53#define GPIO_36 36
54#define GPIO_37 37
55#define GPIO_38 38
56#define GPIO_39 39
57#define GPIO_40 40
58#define GPIO_41 41
59#define GPIO_42 42
60#define GPIO_43 43
61#define GPIO_44 44
62#define GPIO_45 45
63#define GPIO_46 46
64#define GPIO_47 47
65
66#define PERIPHERAL_USAGE 1
67#define GPIO_USAGE 0
68
69#ifndef __ASSEMBLY__
70
71#ifndef CONFIG_BF54x
72void set_gpio_dir(unsigned, unsigned short);
73void set_gpio_inen(unsigned, unsigned short);
74void set_gpio_polar(unsigned, unsigned short);
75void set_gpio_edge(unsigned, unsigned short);
76void set_gpio_both(unsigned, unsigned short);
77void set_gpio_data(unsigned, unsigned short);
78void set_gpio_maska(unsigned, unsigned short);
79void set_gpio_maskb(unsigned, unsigned short);
80void set_gpio_toggle(unsigned);
81void set_gpiop_dir(unsigned, unsigned short);
82void set_gpiop_inen(unsigned, unsigned short);
83void set_gpiop_polar(unsigned, unsigned short);
84void set_gpiop_edge(unsigned, unsigned short);
85void set_gpiop_both(unsigned, unsigned short);
86void set_gpiop_data(unsigned, unsigned short);
87void set_gpiop_maska(unsigned, unsigned short);
88void set_gpiop_maskb(unsigned, unsigned short);
89unsigned short get_gpio_dir(unsigned);
90unsigned short get_gpio_inen(unsigned);
91unsigned short get_gpio_polar(unsigned);
92unsigned short get_gpio_edge(unsigned);
93unsigned short get_gpio_both(unsigned);
94unsigned short get_gpio_maska(unsigned);
95unsigned short get_gpio_maskb(unsigned);
96unsigned short get_gpio_data(unsigned);
97unsigned short get_gpiop_dir(unsigned);
98unsigned short get_gpiop_inen(unsigned);
99unsigned short get_gpiop_polar(unsigned);
100unsigned short get_gpiop_edge(unsigned);
101unsigned short get_gpiop_both(unsigned);
102unsigned short get_gpiop_maska(unsigned);
103unsigned short get_gpiop_maskb(unsigned);
104unsigned short get_gpiop_data(unsigned);
105
106struct gpio_port_t {
107 unsigned short data;
108 unsigned short dummy1;
109 unsigned short data_clear;
110 unsigned short dummy2;
111 unsigned short data_set;
112 unsigned short dummy3;
113 unsigned short toggle;
114 unsigned short dummy4;
115 unsigned short maska;
116 unsigned short dummy5;
117 unsigned short maska_clear;
118 unsigned short dummy6;
119 unsigned short maska_set;
120 unsigned short dummy7;
121 unsigned short maska_toggle;
122 unsigned short dummy8;
123 unsigned short maskb;
124 unsigned short dummy9;
125 unsigned short maskb_clear;
126 unsigned short dummy10;
127 unsigned short maskb_set;
128 unsigned short dummy11;
129 unsigned short maskb_toggle;
130 unsigned short dummy12;
131 unsigned short dir;
132 unsigned short dummy13;
133 unsigned short polar;
134 unsigned short dummy14;
135 unsigned short edge;
136 unsigned short dummy15;
137 unsigned short both;
138 unsigned short dummy16;
139 unsigned short inen;
140};
141#endif
142
143#ifdef CONFIG_BFIN_GPIO_TRACK
144void bfin_gpio_labels(void);
145#else
146#define bfin_gpio_labels()
147#define bfin_gpio_request(gpio, label) bfin_gpio_request(gpio)
148#define bfin_special_gpio_request(gpio, label) bfin_special_gpio_request(gpio)
149#endif
150
151#ifdef BFIN_SPECIAL_GPIO_BANKS
152void bfin_special_gpio_free(unsigned gpio);
153int bfin_special_gpio_request(unsigned gpio, const char *label);
154#endif
155
156int bfin_gpio_request(unsigned gpio, const char *label);
157void bfin_gpio_free(unsigned gpio);
158int bfin_gpio_direction_input(unsigned gpio);
159int bfin_gpio_direction_output(unsigned gpio, int value);
160int bfin_gpio_get_value(unsigned gpio);
161void bfin_gpio_set_value(unsigned gpio, int value);
162void bfin_gpio_toggle_value(unsigned gpio);
163
164static inline int gpio_request(unsigned gpio, const char *label)
165{
166 return bfin_gpio_request(gpio, label);
167}
168
169static inline void gpio_free(unsigned gpio)
170{
171 return bfin_gpio_free(gpio);
172}
173
174static inline int gpio_direction_input(unsigned gpio)
175{
176 return bfin_gpio_direction_input(gpio);
177}
178
179static inline int gpio_direction_output(unsigned gpio, int value)
180{
181 return bfin_gpio_direction_output(gpio, value);
182}
183
184static inline int gpio_get_value(unsigned gpio)
185{
186 return bfin_gpio_get_value(gpio);
187}
188
189static inline void gpio_set_value(unsigned gpio, int value)
190{
191 return bfin_gpio_set_value(gpio, value);
192}
193
194static inline int gpio_is_valid(int number)
195{
196 return number >= 0 && number < MAX_BLACKFIN_GPIOS;
197}
198
Mike Frysinger0e71f802011-04-03 04:40:46 -0400199#include <linux/ctype.h>
200
201static inline int name_to_gpio(const char *name)
202{
203 int port_base;
204
205 if (tolower(*name) == 'p') {
206 ++name;
207
208 switch (tolower(*name)) {
209#ifdef GPIO_PA0
210 case 'a': port_base = GPIO_PA0; break;
211#endif
212#ifdef GPIO_PB0
213 case 'b': port_base = GPIO_PB0; break;
214#endif
215#ifdef GPIO_PC0
216 case 'c': port_base = GPIO_PC0; break;
217#endif
218#ifdef GPIO_PD0
219 case 'd': port_base = GPIO_PD0; break;
220#endif
221#ifdef GPIO_PE0
222 case 'e': port_base = GPIO_PE0; break;
223#endif
224#ifdef GPIO_PF0
225 case 'f': port_base = GPIO_PF0; break;
226#endif
227#ifdef GPIO_PG0
228 case 'g': port_base = GPIO_PG0; break;
229#endif
230#ifdef GPIO_PH0
231 case 'h': port_base = GPIO_PH0; break;
232#endif
233#ifdef GPIO_PI0
234 case 'i': port_base = GPIO_PI0; break;
235#endif
236#ifdef GPIO_PJ
237 case 'j': port_base = GPIO_PJ0; break;
238#endif
239 default: return -1;
240 }
241
242 ++name;
243 } else
244 port_base = 0;
245
246 return port_base + simple_strtoul(name, NULL, 10);
247}
248#define name_to_gpio(n) name_to_gpio(n)
249
250#define gpio_status() bfin_gpio_labels()
251
Mike Frysinger83ebf372010-06-02 04:17:26 -0400252#endif /* __ASSEMBLY__ */
253
254#endif /* __ARCH_BLACKFIN_GPIO_H__ */