xref: /freebsd/sys/arm/ti/ti_gpio.c (revision 0e97acdf58fe27b09c4824a474b0344daf997c5f)
1 /*-
2  * Copyright (c) 2011
3  *	Ben Gray <ben.r.gray@gmail.com>.
4  * All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions
8  * are met:
9  * 1. Redistributions of source code must retain the above copyright
10  *    notice, this list of conditions and the following disclaimer.
11  * 2. Redistributions in binary form must reproduce the above copyright
12  *    notice, this list of conditions and the following disclaimer in the
13  *    documentation and/or other materials provided with the distribution.
14  *
15  * THIS SOFTWARE IS PROVIDED BY AUTHOR AND CONTRIBUTORS ``AS IS'' AND
16  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18  * ARE DISCLAIMED.  IN NO EVENT SHALL AUTHOR OR CONTRIBUTORS BE LIABLE
19  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
20  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
21  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
22  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
23  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
24  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
25  * SUCH DAMAGE.
26  */
27 
28 /**
29  *	Very simple GPIO (general purpose IO) driver module for TI OMAP SoC's.
30  *
31  *	Currently this driver only does the basics, get a value on a pin & set a
32  *	value on a pin. Hopefully over time I'll expand this to be a bit more generic
33  *	and support interrupts and other various bits on the SoC can do ... in the
34  *	meantime this is all you get.
35  *
36  *	Beware the OMA datasheet(s) lists GPIO banks 1-6, whereas I've used 0-5 here
37  *	in the code.
38  *
39  *
40  */
41 
42 #include <sys/cdefs.h>
43 __FBSDID("$FreeBSD$");
44 
45 #include <sys/param.h>
46 #include <sys/systm.h>
47 #include <sys/bus.h>
48 
49 #include <sys/kernel.h>
50 #include <sys/module.h>
51 #include <sys/rman.h>
52 #include <sys/lock.h>
53 #include <sys/mutex.h>
54 #include <sys/gpio.h>
55 
56 #include <machine/bus.h>
57 #include <machine/resource.h>
58 
59 #include <arm/ti/ti_cpuid.h>
60 #include <arm/ti/ti_gpio.h>
61 #include <arm/ti/ti_scm.h>
62 #include <arm/ti/ti_prcm.h>
63 
64 #include <dev/fdt/fdt_common.h>
65 #include <dev/ofw/openfirm.h>
66 #include <dev/ofw/ofw_bus.h>
67 #include <dev/ofw/ofw_bus_subr.h>
68 
69 #include "gpio_if.h"
70 #include "ti_gpio_if.h"
71 
72 /* Register definitions */
73 #define	TI_GPIO_REVISION		0x0000
74 #define	TI_GPIO_SYSCONFIG		0x0010
75 #if defined(SOC_OMAP4) || defined(SOC_TI_AM335X)
76 #define	TI_GPIO_IRQSTATUS_RAW_0		0x0024
77 #define	TI_GPIO_IRQSTATUS_RAW_1		0x0028
78 #define	TI_GPIO_IRQSTATUS_0		0x002C
79 #define	TI_GPIO_IRQSTATUS_1		0x0030
80 #define	TI_GPIO_IRQSTATUS_SET_0		0x0034
81 #define	TI_GPIO_IRQSTATUS_SET_1		0x0038
82 #define	TI_GPIO_IRQSTATUS_CLR_0		0x003C
83 #define	TI_GPIO_IRQSTATUS_CLR_1		0x0040
84 #define	TI_GPIO_IRQWAKEN_0		0x0044
85 #define	TI_GPIO_IRQWAKEN_1		0x0048
86 #define	TI_GPIO_SYSSTATUS		0x0114
87 #define	TI_GPIO_IRQSTATUS1		0x0118
88 #define	TI_GPIO_IRQENABLE1		0x011C
89 #define	TI_GPIO_WAKEUPENABLE		0x0120
90 #define	TI_GPIO_IRQSTATUS2		0x0128
91 #define	TI_GPIO_IRQENABLE2		0x012C
92 #define	TI_GPIO_CTRL			0x0130
93 #define	TI_GPIO_OE			0x0134
94 #define	TI_GPIO_DATAIN			0x0138
95 #define	TI_GPIO_DATAOUT			0x013C
96 #define	TI_GPIO_LEVELDETECT0		0x0140
97 #define	TI_GPIO_LEVELDETECT1		0x0144
98 #define	TI_GPIO_RISINGDETECT		0x0148
99 #define	TI_GPIO_FALLINGDETECT		0x014C
100 #define	TI_GPIO_DEBOUNCENABLE		0x0150
101 #define	TI_GPIO_DEBOUNCINGTIME		0x0154
102 #define	TI_GPIO_CLEARWKUPENA		0x0180
103 #define	TI_GPIO_SETWKUENA		0x0184
104 #define	TI_GPIO_CLEARDATAOUT		0x0190
105 #define	TI_GPIO_SETDATAOUT		0x0194
106 #else
107 #error "Unknown SoC"
108 #endif
109 
110 /* Other SoC Specific definitions */
111 #define	OMAP4_MAX_GPIO_BANKS		6
112 #define	OMAP4_FIRST_GPIO_BANK		1
113 #define	OMAP4_INTR_PER_BANK		1
114 #define	OMAP4_GPIO_REV			0x50600801
115 #define	AM335X_MAX_GPIO_BANKS		4
116 #define	AM335X_FIRST_GPIO_BANK		0
117 #define	AM335X_INTR_PER_BANK		2
118 #define	AM335X_GPIO_REV			0x50600801
119 #define	PINS_PER_BANK			32
120 
121 static u_int
122 ti_max_gpio_banks(void)
123 {
124 	switch(ti_chip()) {
125 #ifdef SOC_OMAP4
126 	case CHIP_OMAP_4:
127 		return (OMAP4_MAX_GPIO_BANKS);
128 #endif
129 #ifdef SOC_TI_AM335X
130 	case CHIP_AM335X:
131 		return (AM335X_MAX_GPIO_BANKS);
132 #endif
133 	}
134 	return (0);
135 }
136 
137 static u_int
138 ti_max_gpio_intrs(void)
139 {
140 	switch(ti_chip()) {
141 #ifdef SOC_OMAP4
142 	case CHIP_OMAP_4:
143 		return (OMAP4_MAX_GPIO_BANKS * OMAP4_INTR_PER_BANK);
144 #endif
145 #ifdef SOC_TI_AM335X
146 	case CHIP_AM335X:
147 		return (AM335X_MAX_GPIO_BANKS * AM335X_INTR_PER_BANK);
148 #endif
149 	}
150 	return (0);
151 }
152 
153 static u_int
154 ti_first_gpio_bank(void)
155 {
156 	switch(ti_chip()) {
157 #ifdef SOC_OMAP4
158 	case CHIP_OMAP_4:
159 		return (OMAP4_FIRST_GPIO_BANK);
160 #endif
161 #ifdef SOC_TI_AM335X
162 	case CHIP_AM335X:
163 		return (AM335X_FIRST_GPIO_BANK);
164 #endif
165 	}
166 	return (0);
167 }
168 
169 static uint32_t
170 ti_gpio_rev(void)
171 {
172 	switch(ti_chip()) {
173 #ifdef SOC_OMAP4
174 	case CHIP_OMAP_4:
175 		return (OMAP4_GPIO_REV);
176 #endif
177 #ifdef SOC_TI_AM335X
178 	case CHIP_AM335X:
179 		return (AM335X_GPIO_REV);
180 #endif
181 	}
182 	return (0);
183 }
184 
185 /**
186  *	ti_gpio_mem_spec - Resource specification used when allocating resources
187  *	ti_gpio_irq_spec - Resource specification used when allocating resources
188  *
189  *	This driver module can have up to six independent memory regions, each
190  *	region typically controls 32 GPIO pins.
191  *
192  *	On OMAP3 and OMAP4 there is only one physical interrupt line per bank,
193  *	but there are two set of registers which control the interrupt delivery
194  *	to internal subsystems.  The first set of registers control the
195  *	interrupts delivery to the MPU and the second set control the
196  *	interrupts delivery to the DSP.
197  *
198  *	On AM335x there are two physical interrupt lines for each GPIO module.
199  *	Each interrupt line is controlled by a set of registers.
200  */
201 static struct resource_spec ti_gpio_mem_spec[] = {
202 	{ SYS_RES_MEMORY,   0,  RF_ACTIVE },
203 	{ SYS_RES_MEMORY,   1,  RF_ACTIVE | RF_OPTIONAL },
204 	{ SYS_RES_MEMORY,   2,  RF_ACTIVE | RF_OPTIONAL },
205 	{ SYS_RES_MEMORY,   3,  RF_ACTIVE | RF_OPTIONAL },
206 #if !defined(SOC_TI_AM335X)
207 	{ SYS_RES_MEMORY,   4,  RF_ACTIVE | RF_OPTIONAL },
208 	{ SYS_RES_MEMORY,   5,  RF_ACTIVE | RF_OPTIONAL },
209 #endif
210 	{ -1,               0,  0 }
211 };
212 static struct resource_spec ti_gpio_irq_spec[] = {
213 	{ SYS_RES_IRQ,      0,  RF_ACTIVE },
214 	{ SYS_RES_IRQ,      1,  RF_ACTIVE | RF_OPTIONAL },
215 	{ SYS_RES_IRQ,      2,  RF_ACTIVE | RF_OPTIONAL },
216 	{ SYS_RES_IRQ,      3,  RF_ACTIVE | RF_OPTIONAL },
217 	{ SYS_RES_IRQ,      4,  RF_ACTIVE | RF_OPTIONAL },
218 	{ SYS_RES_IRQ,      5,  RF_ACTIVE | RF_OPTIONAL },
219 #if defined(SOC_TI_AM335X)
220 	{ SYS_RES_IRQ,      6,  RF_ACTIVE | RF_OPTIONAL },
221 	{ SYS_RES_IRQ,      7,  RF_ACTIVE | RF_OPTIONAL },
222 #endif
223 	{ -1,               0,  0 }
224 };
225 
226 /**
227  *	Macros for driver mutex locking
228  */
229 #define	TI_GPIO_LOCK(_sc)		mtx_lock(&(_sc)->sc_mtx)
230 #define	TI_GPIO_UNLOCK(_sc)		mtx_unlock(&(_sc)->sc_mtx)
231 #define	TI_GPIO_LOCK_INIT(_sc)		\
232 	mtx_init(&_sc->sc_mtx, device_get_nameunit(_sc->sc_dev), \
233 	    "ti_gpio", MTX_DEF)
234 #define	TI_GPIO_LOCK_DESTROY(_sc)	mtx_destroy(&_sc->sc_mtx)
235 #define	TI_GPIO_ASSERT_LOCKED(_sc)	mtx_assert(&_sc->sc_mtx, MA_OWNED)
236 #define	TI_GPIO_ASSERT_UNLOCKED(_sc)	mtx_assert(&_sc->sc_mtx, MA_NOTOWNED)
237 
238 /**
239  *	ti_gpio_read_4 - reads a 16-bit value from one of the PADCONFS registers
240  *	@sc: GPIO device context
241  *	@bank: The bank to read from
242  *	@off: The offset of a register from the GPIO register address range
243  *
244  *
245  *	RETURNS:
246  *	32-bit value read from the register.
247  */
248 static inline uint32_t
249 ti_gpio_read_4(struct ti_gpio_softc *sc, unsigned int bank, bus_size_t off)
250 {
251 	return (bus_read_4(sc->sc_mem_res[bank], off));
252 }
253 
254 /**
255  *	ti_gpio_write_4 - writes a 32-bit value to one of the PADCONFS registers
256  *	@sc: GPIO device context
257  *	@bank: The bank to write to
258  *	@off: The offset of a register from the GPIO register address range
259  *	@val: The value to write into the register
260  *
261  *	RETURNS:
262  *	nothing
263  */
264 static inline void
265 ti_gpio_write_4(struct ti_gpio_softc *sc, unsigned int bank, bus_size_t off,
266                  uint32_t val)
267 {
268 	bus_write_4(sc->sc_mem_res[bank], off, val);
269 }
270 
271 static inline void
272 ti_gpio_intr_clr(struct ti_gpio_softc *sc, unsigned int bank, uint32_t mask)
273 {
274 
275 	/* We clear both set of registers. */
276 #if defined(SOC_OMAP4) || defined(SOC_TI_AM335X)
277 	ti_gpio_write_4(sc, bank, TI_GPIO_IRQSTATUS_CLR_0, mask);
278 	ti_gpio_write_4(sc, bank, TI_GPIO_IRQSTATUS_CLR_1, mask);
279 #else
280 	ti_gpio_write_4(sc, bank, TI_GPIO_CLEARIRQENABLE1, mask);
281 	ti_gpio_write_4(sc, bank, TI_GPIO_CLEARIRQENABLE2, mask);
282 #endif
283 }
284 
285 /**
286  *	ti_gpio_pin_max - Returns the maximum number of GPIO pins
287  *	@dev: gpio device handle
288  *	@maxpin: pointer to a value that upon return will contain the maximum number
289  *	         of pins in the device.
290  *
291  *
292  *	LOCKING:
293  *	Internally locks the context
294  *
295  *	RETURNS:
296  *	Returns 0 on success otherwise an error code
297  */
298 static int
299 ti_gpio_pin_max(device_t dev, int *maxpin)
300 {
301 	struct ti_gpio_softc *sc = device_get_softc(dev);
302 	unsigned int i;
303 	unsigned int banks = 0;
304 
305 	TI_GPIO_LOCK(sc);
306 
307 	/* Calculate how many valid banks we have and then multiply that by 32 to
308 	 * give use the total number of pins.
309 	 */
310 	for (i = 0; i < ti_max_gpio_banks(); i++) {
311 		if (sc->sc_mem_res[i] != NULL)
312 			banks++;
313 	}
314 
315 	*maxpin = (banks * PINS_PER_BANK) - 1;
316 
317 	TI_GPIO_UNLOCK(sc);
318 
319 	return (0);
320 }
321 
322 /**
323  *	ti_gpio_pin_getcaps - Gets the capabilties of a given pin
324  *	@dev: gpio device handle
325  *	@pin: the number of the pin
326  *	@caps: pointer to a value that upon return will contain the capabilities
327  *
328  *	Currently all pins have the same capability, notably:
329  *	  - GPIO_PIN_INPUT
330  *	  - GPIO_PIN_OUTPUT
331  *	  - GPIO_PIN_PULLUP
332  *	  - GPIO_PIN_PULLDOWN
333  *
334  *	LOCKING:
335  *	Internally locks the context
336  *
337  *	RETURNS:
338  *	Returns 0 on success otherwise an error code
339  */
340 static int
341 ti_gpio_pin_getcaps(device_t dev, uint32_t pin, uint32_t *caps)
342 {
343 	struct ti_gpio_softc *sc = device_get_softc(dev);
344 	uint32_t bank = (pin / PINS_PER_BANK);
345 
346 	TI_GPIO_LOCK(sc);
347 
348 	/* Sanity check the pin number is valid */
349 	if ((bank >= ti_max_gpio_banks()) || (sc->sc_mem_res[bank] == NULL)) {
350 		TI_GPIO_UNLOCK(sc);
351 		return (EINVAL);
352 	}
353 
354 	*caps = (GPIO_PIN_INPUT | GPIO_PIN_OUTPUT |GPIO_PIN_PULLUP |
355 	    GPIO_PIN_PULLDOWN);
356 
357 	TI_GPIO_UNLOCK(sc);
358 
359 	return (0);
360 }
361 
362 /**
363  *	ti_gpio_pin_getflags - Gets the current flags of a given pin
364  *	@dev: gpio device handle
365  *	@pin: the number of the pin
366  *	@flags: upon return will contain the current flags of the pin
367  *
368  *	Reads the current flags of a given pin, here we actually read the H/W
369  *	registers to determine the flags, rather than storing the value in the
370  *	setflags call.
371  *
372  *	LOCKING:
373  *	Internally locks the context
374  *
375  *	RETURNS:
376  *	Returns 0 on success otherwise an error code
377  */
378 static int
379 ti_gpio_pin_getflags(device_t dev, uint32_t pin, uint32_t *flags)
380 {
381 	struct ti_gpio_softc *sc = device_get_softc(dev);
382 	uint32_t bank = (pin / PINS_PER_BANK);
383 
384 	TI_GPIO_LOCK(sc);
385 
386 	/* Sanity check the pin number is valid */
387 	if ((bank >= ti_max_gpio_banks()) || (sc->sc_mem_res[bank] == NULL)) {
388 		TI_GPIO_UNLOCK(sc);
389 		return (EINVAL);
390 	}
391 
392 	/* Get the current pin state */
393 	TI_GPIO_GET_FLAGS(dev, pin, flags);
394 
395 	TI_GPIO_UNLOCK(sc);
396 
397 	return (0);
398 }
399 
400 /**
401  *	ti_gpio_pin_getname - Gets the name of a given pin
402  *	@dev: gpio device handle
403  *	@pin: the number of the pin
404  *	@name: buffer to put the name in
405  *
406  *	The driver simply calls the pins gpio_n, where 'n' is obviously the number
407  *	of the pin.
408  *
409  *	LOCKING:
410  *	Internally locks the context
411  *
412  *	RETURNS:
413  *	Returns 0 on success otherwise an error code
414  */
415 static int
416 ti_gpio_pin_getname(device_t dev, uint32_t pin, char *name)
417 {
418 	struct ti_gpio_softc *sc = device_get_softc(dev);
419 	uint32_t bank = (pin / PINS_PER_BANK);
420 
421 	TI_GPIO_LOCK(sc);
422 
423 	/* Sanity check the pin number is valid */
424 	if ((bank >= ti_max_gpio_banks()) || (sc->sc_mem_res[bank] == NULL)) {
425 		TI_GPIO_UNLOCK(sc);
426 		return (EINVAL);
427 	}
428 
429 	/* Set a very simple name */
430 	snprintf(name, GPIOMAXNAME, "gpio_%u", pin);
431 	name[GPIOMAXNAME - 1] = '\0';
432 
433 	TI_GPIO_UNLOCK(sc);
434 
435 	return (0);
436 }
437 
438 /**
439  *	ti_gpio_pin_setflags - Sets the flags for a given pin
440  *	@dev: gpio device handle
441  *	@pin: the number of the pin
442  *	@flags: the flags to set
443  *
444  *	The flags of the pin correspond to things like input/output mode, pull-ups,
445  *	pull-downs, etc.  This driver doesn't support all flags, only the following:
446  *	  - GPIO_PIN_INPUT
447  *	  - GPIO_PIN_OUTPUT
448  *	  - GPIO_PIN_PULLUP
449  *	  - GPIO_PIN_PULLDOWN
450  *
451  *	LOCKING:
452  *	Internally locks the context
453  *
454  *	RETURNS:
455  *	Returns 0 on success otherwise an error code
456  */
457 static int
458 ti_gpio_pin_setflags(device_t dev, uint32_t pin, uint32_t flags)
459 {
460 	struct ti_gpio_softc *sc = device_get_softc(dev);
461 	uint32_t bank = (pin / PINS_PER_BANK);
462 	uint32_t mask = (1UL << (pin % PINS_PER_BANK));
463 	uint32_t reg_val;
464 
465 	/* Sanity check the flags supplied are valid, i.e. not input and output */
466 	if ((flags & (GPIO_PIN_INPUT|GPIO_PIN_OUTPUT)) == 0x0000)
467 		return (EINVAL);
468 	if ((flags & (GPIO_PIN_INPUT|GPIO_PIN_OUTPUT)) ==
469 	    (GPIO_PIN_INPUT|GPIO_PIN_OUTPUT))
470 		return (EINVAL);
471 	if ((flags & (GPIO_PIN_PULLUP|GPIO_PIN_PULLDOWN)) ==
472 	    (GPIO_PIN_PULLUP|GPIO_PIN_PULLDOWN))
473 		return (EINVAL);
474 
475 	TI_GPIO_LOCK(sc);
476 
477 	/* Sanity check the pin number is valid */
478 	if ((bank >= ti_max_gpio_banks()) || (sc->sc_mem_res[bank] == NULL)) {
479 		TI_GPIO_UNLOCK(sc);
480 		return (EINVAL);
481 	}
482 
483 	/* Set the GPIO mode and state */
484 	if (TI_GPIO_SET_FLAGS(dev, pin, flags) != 0) {
485 		TI_GPIO_UNLOCK(sc);
486 		return (EINVAL);
487 	}
488 
489 	/* If configuring as an output set the "output enable" bit */
490 	reg_val = ti_gpio_read_4(sc, bank, TI_GPIO_OE);
491 	if (flags & GPIO_PIN_INPUT)
492 		reg_val |= mask;
493 	else
494 		reg_val &= ~mask;
495 	ti_gpio_write_4(sc, bank, TI_GPIO_OE, reg_val);
496 
497 	TI_GPIO_UNLOCK(sc);
498 
499 	return (0);
500 }
501 
502 /**
503  *	ti_gpio_pin_set - Sets the current level on a GPIO pin
504  *	@dev: gpio device handle
505  *	@pin: the number of the pin
506  *	@value: non-zero value will drive the pin high, otherwise the pin is
507  *	        driven low.
508  *
509  *
510  *	LOCKING:
511  *	Internally locks the context
512  *
513  *	RETURNS:
514  *	Returns 0 on success otherwise a error code
515  */
516 static int
517 ti_gpio_pin_set(device_t dev, uint32_t pin, unsigned int value)
518 {
519 	struct ti_gpio_softc *sc = device_get_softc(dev);
520 	uint32_t bank = (pin / PINS_PER_BANK);
521 	uint32_t mask = (1UL << (pin % PINS_PER_BANK));
522 
523 	TI_GPIO_LOCK(sc);
524 
525 	/* Sanity check the pin number is valid */
526 	if ((bank >= ti_max_gpio_banks()) || (sc->sc_mem_res[bank] == NULL)) {
527 		TI_GPIO_UNLOCK(sc);
528 		return (EINVAL);
529 	}
530 
531 	ti_gpio_write_4(sc, bank, (value == GPIO_PIN_LOW) ? TI_GPIO_CLEARDATAOUT
532 	    : TI_GPIO_SETDATAOUT, mask);
533 
534 	TI_GPIO_UNLOCK(sc);
535 
536 	return (0);
537 }
538 
539 /**
540  *	ti_gpio_pin_get - Gets the current level on a GPIO pin
541  *	@dev: gpio device handle
542  *	@pin: the number of the pin
543  *	@value: pointer to a value that upond return will contain the pin value
544  *
545  *	The pin must be configured as an input pin beforehand, otherwise this
546  *	function will fail.
547  *
548  *	LOCKING:
549  *	Internally locks the context
550  *
551  *	RETURNS:
552  *	Returns 0 on success otherwise a error code
553  */
554 static int
555 ti_gpio_pin_get(device_t dev, uint32_t pin, unsigned int *value)
556 {
557 	struct ti_gpio_softc *sc = device_get_softc(dev);
558 	uint32_t bank = (pin / PINS_PER_BANK);
559 	uint32_t mask = (1UL << (pin % PINS_PER_BANK));
560 	uint32_t val = 0;
561 
562 	TI_GPIO_LOCK(sc);
563 
564 	/* Sanity check the pin number is valid */
565 	if ((bank >= ti_max_gpio_banks()) || (sc->sc_mem_res[bank] == NULL)) {
566 		TI_GPIO_UNLOCK(sc);
567 		return (EINVAL);
568 	}
569 
570 	/* Sanity check the pin is not configured as an output */
571 	val = ti_gpio_read_4(sc, bank, TI_GPIO_OE);
572 
573 	/* Read the value on the pin */
574 	if (val & mask)
575 		*value = (ti_gpio_read_4(sc, bank, TI_GPIO_DATAIN) & mask) ? 1 : 0;
576 	else
577 		*value = (ti_gpio_read_4(sc, bank, TI_GPIO_DATAOUT) & mask) ? 1 : 0;
578 
579 	TI_GPIO_UNLOCK(sc);
580 
581 	return (0);
582 }
583 
584 /**
585  *	ti_gpio_pin_toggle - Toggles a given GPIO pin
586  *	@dev: gpio device handle
587  *	@pin: the number of the pin
588  *
589  *
590  *	LOCKING:
591  *	Internally locks the context
592  *
593  *	RETURNS:
594  *	Returns 0 on success otherwise a error code
595  */
596 static int
597 ti_gpio_pin_toggle(device_t dev, uint32_t pin)
598 {
599 	struct ti_gpio_softc *sc = device_get_softc(dev);
600 	uint32_t bank = (pin / PINS_PER_BANK);
601 	uint32_t mask = (1UL << (pin % PINS_PER_BANK));
602 	uint32_t val;
603 
604 	TI_GPIO_LOCK(sc);
605 
606 	/* Sanity check the pin number is valid */
607 	if ((bank >= ti_max_gpio_banks()) || (sc->sc_mem_res[bank] == NULL)) {
608 		TI_GPIO_UNLOCK(sc);
609 		return (EINVAL);
610 	}
611 
612 	/* Toggle the pin */
613 	val = ti_gpio_read_4(sc, bank, TI_GPIO_DATAOUT);
614 	if (val & mask)
615 		ti_gpio_write_4(sc, bank, TI_GPIO_CLEARDATAOUT, mask);
616 	else
617 		ti_gpio_write_4(sc, bank, TI_GPIO_SETDATAOUT, mask);
618 
619 	TI_GPIO_UNLOCK(sc);
620 
621 	return (0);
622 }
623 
624 /**
625  *	ti_gpio_intr - ISR for all GPIO modules
626  *	@arg: the soft context pointer
627  *
628  *	Unsused
629  *
630  *	LOCKING:
631  *	Internally locks the context
632  *
633  */
634 static void
635 ti_gpio_intr(void *arg)
636 {
637 	struct ti_gpio_softc *sc = arg;
638 
639 	TI_GPIO_LOCK(sc);
640 	/* TODO: something useful */
641 	TI_GPIO_UNLOCK(sc);
642 }
643 
644 static int
645 ti_gpio_attach_intr(device_t dev)
646 {
647 	int i;
648 	struct ti_gpio_softc *sc;
649 
650 	sc = device_get_softc(dev);
651 	for (i = 0; i < ti_max_gpio_intrs(); i++) {
652 		if (sc->sc_irq_res[i] == NULL)
653 			break;
654 
655 		/*
656 		 * Register our interrupt handler for each of the IRQ resources.
657 		 */
658 		if (bus_setup_intr(dev, sc->sc_irq_res[i],
659 		    INTR_TYPE_MISC | INTR_MPSAFE, NULL, ti_gpio_intr, sc,
660 		    &sc->sc_irq_hdl[i]) != 0) {
661 			device_printf(dev,
662 			    "WARNING: unable to register interrupt handler\n");
663 			return (-1);
664 		}
665 	}
666 
667 	return (0);
668 }
669 
670 static int
671 ti_gpio_detach_intr(device_t dev)
672 {
673 	int i;
674 	struct ti_gpio_softc *sc;
675 
676 	/* Teardown our interrupt handlers. */
677 	sc = device_get_softc(dev);
678 	for (i = 0; i < ti_max_gpio_intrs(); i++) {
679 		if (sc->sc_irq_res[i] == NULL)
680 			break;
681 
682 		if (sc->sc_irq_hdl[i]) {
683 			bus_teardown_intr(dev, sc->sc_irq_res[i],
684 			    sc->sc_irq_hdl[i]);
685 		}
686 	}
687 
688 	return (0);
689 }
690 
691 static int
692 ti_gpio_bank_init(device_t dev, int bank)
693 {
694 	int pin;
695 	struct ti_gpio_softc *sc;
696 	uint32_t flags, reg_oe;
697 
698 	sc = device_get_softc(dev);
699 
700 	/* Enable the interface and functional clocks for the module. */
701 	ti_prcm_clk_enable(GPIO0_CLK + ti_first_gpio_bank() + bank);
702 
703 	/*
704 	 * Read the revision number of the module.  TI don't publish the
705 	 * actual revision numbers, so instead the values have been
706 	 * determined by experimentation.
707 	 */
708 	sc->sc_revision[bank] = ti_gpio_read_4(sc, bank, TI_GPIO_REVISION);
709 
710 	/* Check the revision. */
711 	if (sc->sc_revision[bank] != ti_gpio_rev()) {
712 		device_printf(dev, "Warning: could not determine the revision "
713 		    "of %u GPIO module (revision:0x%08x)\n",
714 		    bank, sc->sc_revision[bank]);
715 		return (EINVAL);
716 	}
717 
718 	/* Disable interrupts for all pins. */
719 	ti_gpio_intr_clr(sc, bank, 0xffffffff);
720 
721 	/* Init OE register based on pads configuration. */
722 	reg_oe = 0xffffffff;
723 	for (pin = 0; pin < PINS_PER_BANK; pin++) {
724 		TI_GPIO_GET_FLAGS(dev, PINS_PER_BANK * bank + pin, &flags);
725 		if (flags & GPIO_PIN_OUTPUT)
726 			reg_oe &= ~(1UL << pin);
727 	}
728 	ti_gpio_write_4(sc, bank, TI_GPIO_OE, reg_oe);
729 
730 	return (0);
731 }
732 
733 /**
734  *	ti_gpio_attach - attach function for the driver
735  *	@dev: gpio device handle
736  *
737  *	Allocates and sets up the driver context for all GPIO banks.  This function
738  *	expects the memory ranges and IRQs to already be allocated to the driver.
739  *
740  *	LOCKING:
741  *	None
742  *
743  *	RETURNS:
744  *	Always returns 0
745  */
746 static int
747 ti_gpio_attach(device_t dev)
748 {
749 	struct ti_gpio_softc *sc;
750 	unsigned int i;
751 	int err;
752 
753  	sc = device_get_softc(dev);
754 	sc->sc_dev = dev;
755 
756 	TI_GPIO_LOCK_INIT(sc);
757 
758 	/* There are up to 6 different GPIO register sets located in different
759 	 * memory areas on the chip.  The memory range should have been set for
760 	 * the driver when it was added as a child.
761 	 */
762 	if (bus_alloc_resources(dev, ti_gpio_mem_spec, sc->sc_mem_res) != 0) {
763 		device_printf(dev, "Error: could not allocate mem resources\n");
764 		return (ENXIO);
765 	}
766 
767 	/* Request the IRQ resources */
768 	if (bus_alloc_resources(dev, ti_gpio_irq_spec, sc->sc_irq_res) != 0) {
769 		bus_release_resources(dev, ti_gpio_mem_spec, sc->sc_mem_res);
770 		device_printf(dev, "Error: could not allocate irq resources\n");
771 		return (ENXIO);
772 	}
773 
774 	/* Setup the IRQ resources */
775 	if (ti_gpio_attach_intr(dev) != 0) {
776 		ti_gpio_detach_intr(dev);
777 		bus_release_resources(dev, ti_gpio_irq_spec, sc->sc_irq_res);
778 		bus_release_resources(dev, ti_gpio_mem_spec, sc->sc_mem_res);
779 		return (ENXIO);
780 	}
781 
782 	/* We need to go through each block and ensure the clocks are running and
783 	 * the module is enabled.  It might be better to do this only when the
784 	 * pins are configured which would result in less power used if the GPIO
785 	 * pins weren't used ...
786 	 */
787 	for (i = 0; i < ti_max_gpio_banks(); i++) {
788 		if (sc->sc_mem_res[i] != NULL) {
789 			/* Initialize the GPIO module. */
790 			err = ti_gpio_bank_init(dev, i);
791 			if (err != 0) {
792 				ti_gpio_detach_intr(dev);
793 				bus_release_resources(dev, ti_gpio_irq_spec,
794 				    sc->sc_irq_res);
795 				bus_release_resources(dev, ti_gpio_mem_spec,
796 				    sc->sc_mem_res);
797 				return (err);
798 			}
799 		}
800 	}
801 
802 	/* Finish of the probe call */
803 	device_add_child(dev, "gpioc", -1);
804 	device_add_child(dev, "gpiobus", -1);
805 
806 	return (bus_generic_attach(dev));
807 }
808 
809 /**
810  *	ti_gpio_detach - detach function for the driver
811  *	@dev: scm device handle
812  *
813  *	Allocates and sets up the driver context, this simply entails creating a
814  *	bus mappings for the SCM register set.
815  *
816  *	LOCKING:
817  *	None
818  *
819  *	RETURNS:
820  *	Always returns 0
821  */
822 static int
823 ti_gpio_detach(device_t dev)
824 {
825 	struct ti_gpio_softc *sc = device_get_softc(dev);
826 	unsigned int i;
827 
828 	KASSERT(mtx_initialized(&sc->sc_mtx), ("gpio mutex not initialized"));
829 
830 	/* Disable all interrupts */
831 	for (i = 0; i < ti_max_gpio_banks(); i++) {
832 		if (sc->sc_mem_res[i] != NULL)
833 			ti_gpio_intr_clr(sc, i, 0xffffffff);
834 	}
835 
836 	bus_generic_detach(dev);
837 
838 	/* Release the memory and IRQ resources. */
839 	ti_gpio_detach_intr(dev);
840 	bus_release_resources(dev, ti_gpio_irq_spec, sc->sc_irq_res);
841 	bus_release_resources(dev, ti_gpio_mem_spec, sc->sc_mem_res);
842 
843 	TI_GPIO_LOCK_DESTROY(sc);
844 
845 	return (0);
846 }
847 
848 static phandle_t
849 ti_gpio_get_node(device_t bus, device_t dev)
850 {
851 
852 	/* We only have one child, the GPIO bus, which needs our own node. */
853 	return (ofw_bus_get_node(bus));
854 }
855 
856 static device_method_t ti_gpio_methods[] = {
857 	DEVMETHOD(device_attach, ti_gpio_attach),
858 	DEVMETHOD(device_detach, ti_gpio_detach),
859 
860 	/* GPIO protocol */
861 	DEVMETHOD(gpio_pin_max, ti_gpio_pin_max),
862 	DEVMETHOD(gpio_pin_getname, ti_gpio_pin_getname),
863 	DEVMETHOD(gpio_pin_getflags, ti_gpio_pin_getflags),
864 	DEVMETHOD(gpio_pin_getcaps, ti_gpio_pin_getcaps),
865 	DEVMETHOD(gpio_pin_setflags, ti_gpio_pin_setflags),
866 	DEVMETHOD(gpio_pin_get, ti_gpio_pin_get),
867 	DEVMETHOD(gpio_pin_set, ti_gpio_pin_set),
868 	DEVMETHOD(gpio_pin_toggle, ti_gpio_pin_toggle),
869 
870 	/* ofw_bus interface */
871 	DEVMETHOD(ofw_bus_get_node, ti_gpio_get_node),
872 
873 	{0, 0},
874 };
875 
876 driver_t ti_gpio_driver = {
877 	"gpio",
878 	ti_gpio_methods,
879 	sizeof(struct ti_gpio_softc),
880 };
881