Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/arm/broadcom Support configuration of alternate fun...
details: https://anonhg.NetBSD.org/src/rev/bdfa57f3dee6
branches: trunk
changeset: 839127:bdfa57f3dee6
user: mlelstv <mlelstv%NetBSD.org@localhost>
date: Thu Feb 07 21:16:35 2019 +0000
description:
Support configuration of alternate functions.
diffstat:
sys/arch/arm/broadcom/bcm2835_gpio.c | 49 ++++++++++++++++++++++++++++++-----
1 files changed, 42 insertions(+), 7 deletions(-)
diffs (104 lines):
diff -r 2151cbc5f884 -r bdfa57f3dee6 sys/arch/arm/broadcom/bcm2835_gpio.c
--- a/sys/arch/arm/broadcom/bcm2835_gpio.c Thu Feb 07 20:56:27 2019 +0000
+++ b/sys/arch/arm/broadcom/bcm2835_gpio.c Thu Feb 07 21:16:35 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: bcm2835_gpio.c,v 1.9 2019/01/26 14:38:29 thorpej Exp $ */
+/* $NetBSD: bcm2835_gpio.c,v 1.10 2019/02/07 21:16:35 mlelstv Exp $ */
/*-
* Copyright (c) 2013, 2014, 2017 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: bcm2835_gpio.c,v 1.9 2019/01/26 14:38:29 thorpej Exp $");
+__KERNEL_RCSID(0, "$NetBSD: bcm2835_gpio.c,v 1.10 2019/02/07 21:16:35 mlelstv Exp $");
/*
* Driver for BCM2835 GPIO
@@ -288,7 +288,10 @@
sc->sc_gpio_pins[pin].pin_caps = GPIO_PIN_INPUT |
GPIO_PIN_OUTPUT |
GPIO_PIN_PUSHPULL | GPIO_PIN_TRISTATE |
- GPIO_PIN_PULLUP | GPIO_PIN_PULLDOWN;
+ GPIO_PIN_PULLUP | GPIO_PIN_PULLDOWN |
+ GPIO_PIN_ALT0 | GPIO_PIN_ALT1 |
+ GPIO_PIN_ALT2 | GPIO_PIN_ALT3 |
+ GPIO_PIN_ALT4 | GPIO_PIN_ALT5;
sc->sc_gpio_pins[pin].pin_intrcaps =
GPIO_INTR_POS_EDGE |
GPIO_INTR_NEG_EDGE |
@@ -299,11 +302,11 @@
/* read initial state */
sc->sc_gpio_pins[pin].pin_state =
bcm2835gpio_gpio_pin_read(sc, pin);
- DPRINTF(1, ("%s: attach pin %d\n", device_xname(sc->sc_dev), pin));
+ aprint_debug_dev(sc->sc_dev, "attach pin %d\n", pin);
} else {
sc->sc_gpio_pins[pin].pin_caps = 0;
sc->sc_gpio_pins[pin].pin_state = 0;
- DPRINTF(1, ("%s: skip pin %d - func = 0x%x\n", device_xname(sc->sc_dev), pin, func));
+ aprint_debug_dev(sc->sc_dev, "skip pin %d - func = %x\n", pin, func);
}
}
@@ -329,7 +332,7 @@
MIN((bank * 32) + 31, BCMGPIO_MAXPINS),
intrstr);
} else {
- aprint_normal_dev(self,
+ aprint_error_dev(self,
"failed to establish interrupt for pins %d..%d\n",
bank * 32,
MIN((bank * 32) + 31, BCMGPIO_MAXPINS));
@@ -787,17 +790,49 @@
{
struct bcmgpio_softc *sc = arg;
uint32_t cmd;
+ uint32_t altmask = GPIO_PIN_ALT0 | GPIO_PIN_ALT1 |
+ GPIO_PIN_ALT2 | GPIO_PIN_ALT3 |
+ GPIO_PIN_ALT4 | GPIO_PIN_ALT5;
DPRINTF(2, ("%s: gpio_ctl pin %d flags 0x%x\n", device_xname(sc->sc_dev), pin, flags));
mutex_enter(&sc->sc_lock);
if (flags & (GPIO_PIN_OUTPUT|GPIO_PIN_INPUT)) {
- if ((flags & GPIO_PIN_INPUT) || !(flags & GPIO_PIN_OUTPUT)) {
+ if ((flags & GPIO_PIN_INPUT) != 0) {
/* for safety INPUT will overide output */
bcm283x_pin_setfunc(sc, pin, BCM2835_GPIO_IN);
} else {
bcm283x_pin_setfunc(sc, pin, BCM2835_GPIO_OUT);
}
+ } else if ((flags & altmask) != 0) {
+ u_int func;
+
+ switch (flags & altmask) {
+ case GPIO_PIN_ALT0:
+ func = BCM2835_GPIO_ALT0;
+ break;
+ case GPIO_PIN_ALT1:
+ func = BCM2835_GPIO_ALT1;
+ break;
+ case GPIO_PIN_ALT2:
+ func = BCM2835_GPIO_ALT2;
+ break;
+ case GPIO_PIN_ALT3:
+ func = BCM2835_GPIO_ALT3;
+ break;
+ case GPIO_PIN_ALT4:
+ func = BCM2835_GPIO_ALT4;
+ break;
+ case GPIO_PIN_ALT5:
+ func = BCM2835_GPIO_ALT5;
+ break;
+ default:
+ /* ignored below */
+ func = BCM2835_GPIO_IN;
+ break;
+ }
+ if (func != BCM2835_GPIO_IN)
+ bcm283x_pin_setfunc(sc, pin, func);
}
if (flags & (GPIO_PIN_PULLUP|GPIO_PIN_PULLDOWN)) {
Home |
Main Index |
Thread Index |
Old Index