boards/stm32f411-minimum: add support for /dev/gpio*

This patch allows user to simply select which GPIOs he wants to use
and access them via /dev/gpio_a0 or similar device with standard
gpio driver.

By default gpio names match pin names printed on the board. So when
enabling A3 pin, it will show as /dev/gpio_a3 in runtime. This name
can be changed in kconfig.

User can also select pin function (input, output, interrupt) as well
as standard pin settings like, pull up/down, output type
pushpull/open drain etc.

All pins that are exposed via boards goldpins are listed in Kconfig.
Extra pins that are supported by chiip but are not exposed for easy
usage are not listed.

To have this nice Kconfig configuration and for things to be easily
debugable/understandable it requires code to have big Kconfig and
header file with all possible definitions

Because of file sizes I decided to split gpio related kconfig and
header into separate files. Otherwise it would really make original
files hard to read and find anything.

Signed-off-by: Michał Łyszczek <michal.lyszczek@bofc.pl>
This commit is contained in:
Michał Łyszczek 2024-02-27 20:17:02 +01:00 committed by Alan Carvalho de Assis
parent 4b086f595e
commit 85b2cbaca6
8 changed files with 5325 additions and 0 deletions

View File

@ -75,4 +75,12 @@ config STM32F411MINIMUM_HX711_DATA_PIN
endif # STM32F411MINIMUM_HX711 endif # STM32F411MINIMUM_HX711
menuconfig STM32F411MINIMUM_GPIO
select DEV_GPIO
bool "enable gpio subsystem"
if STM32F411MINIMUM_GPIO
source "boards/arm/stm32/stm32f411-minimum/Kconfig.gpio"
endif
endif endif

File diff suppressed because it is too large Load Diff

View File

@ -44,6 +44,10 @@ if(CONFIG_USBDEV_COMPOSITE)
list(APPEND SRCS stm32_composite.c) list(APPEND SRCS stm32_composite.c)
endif() endif()
if(CONFIG_STM32F411MINIMUM_GPIO)
list(APPEND SRCS stm32_gpio.c)
endif()
if(CONFIG_USBMSC) if(CONFIG_USBMSC)
list(APPEND SRCS stm32_usbmsc.c) list(APPEND SRCS stm32_usbmsc.c)
endif() endif()

View File

@ -38,6 +38,10 @@ ifeq ($(CONFIG_SPI),y)
CSRCS += stm32_spi.c CSRCS += stm32_spi.c
endif endif
ifeq ($(CONFIG_STM32F411MINIMUM_GPIO),y)
CSRCS += stm32_gpio.c
endif
ifeq ($(CONFIG_MTD_W25),y) ifeq ($(CONFIG_MTD_W25),y)
CSRCS += stm32_w25.c CSRCS += stm32_w25.c
endif endif

View File

@ -84,6 +84,14 @@ int stm32_bringup(void)
{ {
int ret = OK; int ret = OK;
#ifdef CONFIG_STM32F411MINIMUM_GPIO
ret = stm32_gpio_initialize();
if (ret != OK)
{
gerr("ERROR: Failed to initialize gpio: %d\n", ret);
}
#endif
#ifdef CONFIG_ADC_HX711 #ifdef CONFIG_ADC_HX711
ret = stm32_hx711_initialize(); ret = stm32_hx711_initialize();
if (ret != OK) if (ret != OK)

View File

@ -0,0 +1,739 @@
/****************************************************************************
* boards/arm/stm32/stm32f411-minimum/src/stm32_gpio.c
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#include <stdbool.h>
#include <assert.h>
#include <debug.h>
#include <nuttx/clock.h>
#include <nuttx/wdog.h>
#include <nuttx/ioexpander/gpio.h>
#include <arch/board/board.h>
#include "chip.h"
#include "stm32.h"
#include "stm32f411-minimum.h"
#if defined(CONFIG_DEV_GPIO) && !defined(CONFIG_GPIO_LOWER_HALF)
/****************************************************************************
* Private Types
****************************************************************************/
struct stm32gpio_dev_s
{
struct gpio_dev_s gpio;
uint8_t id;
};
struct stm32gpint_dev_s
{
struct stm32gpio_dev_s stm32gpio;
pin_interrupt_t callback;
};
struct stm32gpio_info_s
{
uint32_t pin;
const char *pinname; /* Holds pin name like gpio_a0, gpio_custom_name */
};
/****************************************************************************
* Private Function Prototypes
****************************************************************************/
#if BOARD_NGPIO_IN > 0
static int gpin_read(struct gpio_dev_s *dev, bool *value);
#endif
#if BOARD_NGPIO_OUT > 0
static int gpout_read(struct gpio_dev_s *dev, bool *value);
static int gpout_write(struct gpio_dev_s *dev, bool value);
#endif
#if BOARD_NGPIO_INT > 0
static int gpint_read(struct gpio_dev_s *dev, bool *value);
static int gpint_enable(struct gpio_dev_s *dev, bool enable);
static int gpint_attach(struct gpio_dev_s *dev, pin_interrupt_t callback);
#endif
/****************************************************************************
* Private Data
****************************************************************************/
#if BOARD_NGPIO_IN > 0
static const struct gpio_operations_s gpin_ops =
{
.go_read = gpin_read,
.go_write = NULL,
.go_attach = NULL,
.go_enable = NULL,
};
static struct stm32gpio_dev_s g_gpin[BOARD_NGPIO_IN];
static const struct stm32gpio_info_s g_gpio_inputs[BOARD_NGPIO_IN] =
{
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A0_IN
{ .pin = GPIO_A0_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A0_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A1_IN
{ .pin = GPIO_A1_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A1_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A2_IN
{ .pin = GPIO_A2_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A2_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A3_IN
{ .pin = GPIO_A3_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A3_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A4_IN
{ .pin = GPIO_A4_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A4_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A5_IN
{ .pin = GPIO_A5_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A5_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A6_IN
{ .pin = GPIO_A6_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A6_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A7_IN
{ .pin = GPIO_A7_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A7_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A8_IN
{ .pin = GPIO_A8_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A8_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A9_IN
{ .pin = GPIO_A9_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A9_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A10_IN
{ .pin = GPIO_A10_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A10_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A11_IN
{ .pin = GPIO_A11_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A11_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A12_IN
{ .pin = GPIO_A12_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A12_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A15_IN
{ .pin = GPIO_A15_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A15_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B0_IN
{ .pin = GPIO_B0_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B0_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B1_IN
{ .pin = GPIO_B1_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B1_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B2_IN
{ .pin = GPIO_B2_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B2_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B3_IN
{ .pin = GPIO_B3_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B3_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B4_IN
{ .pin = GPIO_B4_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B4_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B5_IN
{ .pin = GPIO_B5_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B5_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B6_IN
{ .pin = GPIO_B6_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B6_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B7_IN
{ .pin = GPIO_B7_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B7_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B8_IN
{ .pin = GPIO_B8_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B8_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B9_IN
{ .pin = GPIO_B9_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B9_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B10_IN
{ .pin = GPIO_B10_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B10_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B12_IN
{ .pin = GPIO_B12_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B12_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B13_IN
{ .pin = GPIO_B13_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B13_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B14_IN
{ .pin = GPIO_B14_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B14_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B15_IN
{ .pin = GPIO_B15_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B15_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_C13_IN
{ .pin = GPIO_C13_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_C13_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_C14_IN
{ .pin = GPIO_C14_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_C14_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_C15_IN
{ .pin = GPIO_C15_IN, .pinname = CONFIG_STM32F411MINIMUM_GPIO_C15_NAME },
#endif
};
#endif /* BOARD_NGPIO_IN > 0 */
#if BOARD_NGPIO_OUT > 0
static const struct gpio_operations_s gpout_ops =
{
.go_read = gpout_read,
.go_write = gpout_write,
.go_attach = NULL,
.go_enable = NULL,
};
static struct stm32gpio_dev_s g_gpout[BOARD_NGPIO_OUT];
static const struct stm32gpio_info_s g_gpio_outputs[BOARD_NGPIO_OUT] =
{
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A0_OUT
{ .pin = GPIO_A0_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A0_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A1_OUT
{ .pin = GPIO_A1_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A1_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A2_OUT
{ .pin = GPIO_A2_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A2_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A3_OUT
{ .pin = GPIO_A3_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A3_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A4_OUT
{ .pin = GPIO_A4_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A4_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A5_OUT
{ .pin = GPIO_A5_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A5_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A6_OUT
{ .pin = GPIO_A6_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A6_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A7_OUT
{ .pin = GPIO_A7_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A7_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A8_OUT
{ .pin = GPIO_A8_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A8_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A9_OUT
{ .pin = GPIO_A9_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A9_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A10_OUT
{ .pin = GPIO_A10_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A10_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A11_OUT
{ .pin = GPIO_A11_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A11_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A12_OUT
{ .pin = GPIO_A12_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A12_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A15_OUT
{ .pin = GPIO_A15_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A15_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B0_OUT
{ .pin = GPIO_B0_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B0_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B1_OUT
{ .pin = GPIO_B1_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B1_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B2_OUT
{ .pin = GPIO_B2_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B2_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B3_OUT
{ .pin = GPIO_B3_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B3_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B4_OUT
{ .pin = GPIO_B4_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B4_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B5_OUT
{ .pin = GPIO_B5_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B5_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B6_OUT
{ .pin = GPIO_B6_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B6_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B7_OUT
{ .pin = GPIO_B7_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B7_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B8_OUT
{ .pin = GPIO_B8_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B8_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B9_OUT
{ .pin = GPIO_B9_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B9_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B10_OUT
{ .pin = GPIO_B10_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B10_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B12_OUT
{ .pin = GPIO_B12_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B12_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B13_OUT
{ .pin = GPIO_B13_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B13_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B14_OUT
{ .pin = GPIO_B14_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B14_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B15_OUT
{ .pin = GPIO_B15_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B15_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_C13_OUT
{ .pin = GPIO_C13_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_C13_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_C14_OUT
{ .pin = GPIO_C14_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_C14_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_C15_OUT
{ .pin = GPIO_C15_OUT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_C15_NAME },
#endif
};
#endif /* BOARD_NGPIO_OUT > 0 */
#if BOARD_NGPIO_INT > 0
static const struct gpio_operations_s gpint_ops =
{
.go_read = gpint_read,
.go_write = NULL,
.go_attach = gpint_attach,
.go_enable = gpint_enable,
};
static struct stm32gpint_dev_s g_gpint[BOARD_NGPIO_INT];
static const struct stm32gpio_info_s g_gpio_int_inputs[BOARD_NGPIO_INT] =
{
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A0_INT
{ .pin = GPIO_A0_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A0_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A1_INT
{ .pin = GPIO_A1_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A1_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A2_INT
{ .pin = GPIO_A2_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A2_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A3_INT
{ .pin = GPIO_A3_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A3_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A4_INT
{ .pin = GPIO_A4_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A4_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A5_INT
{ .pin = GPIO_A5_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A5_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A6_INT
{ .pin = GPIO_A6_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A6_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A7_INT
{ .pin = GPIO_A7_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A7_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A8_INT
{ .pin = GPIO_A8_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A8_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A9_INT
{ .pin = GPIO_A9_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A9_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A10_INT
{ .pin = GPIO_A10_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A10_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A11_INT
{ .pin = GPIO_A11_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A11_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A12_INT
{ .pin = GPIO_A12_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A12_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_A15_INT
{ .pin = GPIO_A15_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_A15_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B0_INT
{ .pin = GPIO_B0_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B0_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B1_INT
{ .pin = GPIO_B1_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B1_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B2_INT
{ .pin = GPIO_B2_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B2_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B3_INT
{ .pin = GPIO_B3_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B3_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B4_INT
{ .pin = GPIO_B4_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B4_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B5_INT
{ .pin = GPIO_B5_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B5_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B6_INT
{ .pin = GPIO_B6_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B6_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B7_INT
{ .pin = GPIO_B7_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B7_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B8_INT
{ .pin = GPIO_B8_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B8_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B9_INT
{ .pin = GPIO_B9_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B9_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B10_INT
{ .pin = GPIO_B10_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B10_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B12_INT
{ .pin = GPIO_B12_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B12_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B13_INT
{ .pin = GPIO_B13_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B13_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B14_INT
{ .pin = GPIO_B14_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B14_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_B15_INT
{ .pin = GPIO_B15_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_B15_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_C13_INT
{ .pin = GPIO_C13_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_C13_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_C14_INT
{ .pin = GPIO_C14_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_C14_NAME },
#endif
#ifdef CONFIG_STM32F411MINIMUM_GPIO_C15_INT
{ .pin = GPIO_C15_INT, .pinname = CONFIG_STM32F411MINIMUM_GPIO_C15_NAME },
#endif
};
#endif /* BOARD_NGPIO_INT > 0 */
/****************************************************************************
* Private Functions
****************************************************************************/
/****************************************************************************
* Name: gpin_read
****************************************************************************/
#if BOARD_NGPIO_IN > 0
static int gpin_read(struct gpio_dev_s *dev, bool *value)
{
struct stm32gpio_dev_s *stm32gpio =
(struct stm32gpio_dev_s *)dev;
DEBUGASSERT(stm32gpio != NULL && value != NULL);
DEBUGASSERT(stm32gpio->id < BOARD_NGPIO_IN);
gpioinfo("Reading...\n");
*value = stm32_gpioread(g_gpio_inputs[stm32gpio->id].pin);
return OK;
}
#endif
/****************************************************************************
* Name: gpout_read
****************************************************************************/
#if BOARD_NGPIO_OUT > 0
static int gpout_read(struct gpio_dev_s *dev, bool *value)
{
struct stm32gpio_dev_s *stm32gpio =
(struct stm32gpio_dev_s *)dev;
DEBUGASSERT(stm32gpio != NULL && value != NULL);
DEBUGASSERT(stm32gpio->id < BOARD_NGPIO_OUT);
gpioinfo("Reading...\n");
*value = stm32_gpioread(g_gpio_outputs[stm32gpio->id].pin);
return OK;
}
#endif
/****************************************************************************
* Name: gpout_write
****************************************************************************/
#if BOARD_NGPIO_OUT > 0
static int gpout_write(struct gpio_dev_s *dev, bool value)
{
struct stm32gpio_dev_s *stm32gpio =
(struct stm32gpio_dev_s *)dev;
DEBUGASSERT(stm32gpio != NULL);
DEBUGASSERT(stm32gpio->id < BOARD_NGPIO_OUT);
gpioinfo("Writing %d\n", (int)value);
stm32_gpiowrite(g_gpio_outputs[stm32gpio->id].pin, value);
return OK;
}
#endif
/****************************************************************************
* Name: gpint_read
****************************************************************************/
#if BOARD_NGPIO_INT > 0
static int gpint_read(struct gpio_dev_s *dev, bool *value)
{
struct stm32gpint_dev_s *stm32gpint =
(struct stm32gpint_dev_s *)dev;
DEBUGASSERT(stm32gpint != NULL && value != NULL);
DEBUGASSERT(stm32gpint->stm32gpio.id < BOARD_NGPIO_INT);
gpioinfo("Reading int pin...\n");
*value = stm32_gpioread(g_gpio_int_inputs[stm32gpint->stm32gpio.id].pin);
return OK;
}
#endif
/****************************************************************************
* Name: stm32gpio_interrupt
****************************************************************************/
#if BOARD_NGPIO_INT > 0
static int stm32gpio_interrupt(int irq, void *context, void *arg)
{
struct stm32gpint_dev_s *stm32gpint =
(struct stm32gpint_dev_s *)arg;
DEBUGASSERT(stm32gpint != NULL && stm32gpint->callback != NULL);
gpioinfo("Interrupt! callback=%p\n", stm32gpint->callback);
stm32gpint->callback(&stm32gpint->stm32gpio.gpio,
stm32gpint->stm32gpio.id);
return OK;
}
#endif
/****************************************************************************
* Name: gpint_attach
****************************************************************************/
#if BOARD_NGPIO_INT > 0
static int gpint_attach(struct gpio_dev_s *dev,
pin_interrupt_t callback)
{
struct stm32gpint_dev_s *stm32gpint =
(struct stm32gpint_dev_s *)dev;
gpioinfo("Attaching the callback\n");
/* Make sure the interrupt is disabled */
stm32_gpiosetevent(g_gpio_int_inputs[stm32gpint->stm32gpio.id].pin, false,
false, false, NULL, NULL);
gpioinfo("Attach %p\n", callback);
stm32gpint->callback = callback;
return OK;
}
#endif
/****************************************************************************
* Name: gpint_enable
****************************************************************************/
#if BOARD_NGPIO_INT > 0
static int gpint_enable(struct gpio_dev_s *dev, bool enable)
{
struct stm32gpint_dev_s *stm32gpint =
(struct stm32gpint_dev_s *)dev;
if (enable)
{
if (stm32gpint->callback != NULL)
{
gpioinfo("Enabling the interrupt\n");
/* Configure the interrupt for rising edge */
stm32_gpiosetevent(g_gpio_int_inputs[stm32gpint->stm32gpio.id].pin,
true, false, false, stm32gpio_interrupt,
&g_gpint[stm32gpint->stm32gpio.id]);
}
}
else
{
gpioinfo("Disable the interrupt\n");
stm32_gpiosetevent(g_gpio_int_inputs[stm32gpint->stm32gpio.id].pin,
false, false, false, NULL, NULL);
}
return OK;
}
#endif
/****************************************************************************
* Public Functions
****************************************************************************/
/****************************************************************************
* Name: stm32_gpio_initialize
*
* Description:
* Initialize GPIO drivers
*
****************************************************************************/
int stm32_gpio_initialize(void)
{
int i;
#if BOARD_NGPIO_IN > 0
for (i = 0; i < BOARD_NGPIO_IN; i++)
{
/* Setup and register the GPIO pin */
g_gpin[i].gpio.gp_pintype = GPIO_INPUT_PIN;
g_gpin[i].gpio.gp_ops = &gpin_ops;
g_gpin[i].id = i;
gpio_pin_register_byname(&g_gpin[i].gpio, g_gpio_inputs[i].pinname);
/* Configure the pin that will be used as input */
stm32_configgpio(g_gpio_inputs[i].pin);
}
#endif
#if BOARD_NGPIO_OUT > 0
for (i = 0; i < BOARD_NGPIO_OUT; i++)
{
/* Setup and register the GPIO pin */
g_gpout[i].gpio.gp_pintype = GPIO_OUTPUT_PIN;
g_gpout[i].gpio.gp_ops = &gpout_ops;
g_gpout[i].id = i;
gpio_pin_register_byname(&g_gpout[i].gpio, g_gpio_outputs[i].pinname);
/* Configure the pin that will be used as output */
stm32_gpiowrite(g_gpio_outputs[i].pin, 0);
stm32_configgpio(g_gpio_outputs[i].pin);
}
#endif
#if BOARD_NGPIO_INT > 0
for (i = 0; i < BOARD_NGPIO_INT; i++)
{
/* Setup and register the GPIO pin */
g_gpint[i].stm32gpio.gpio.gp_pintype = GPIO_INTERRUPT_PIN;
g_gpint[i].stm32gpio.gpio.gp_ops = &gpint_ops;
g_gpint[i].stm32gpio.id = i;
gpio_pin_register_byname(&g_gpint[i].stm32gpio.gpio,
g_gpio_int_inputs[i].pinname);
/* Configure the pin that will be used as interrupt input */
stm32_configgpio(g_gpio_int_inputs[i].pin);
}
#endif
return 0;
}
#endif /* CONFIG_DEV_GPIO && !CONFIG_GPIO_LOWER_HALF */

File diff suppressed because it is too large Load Diff

View File

@ -27,9 +27,14 @@
#include <nuttx/config.h> #include <nuttx/config.h>
#include <nuttx/compiler.h> #include <nuttx/compiler.h>
#include <arch/chip/chip.h>
#include <stdint.h> #include <stdint.h>
#ifdef CONFIG_STM32F411MINIMUM_GPIO
#include "stm32f411-minimum-gpio.h"
#endif
/**************************************************************************** /****************************************************************************
* Pre-processor Definitions * Pre-processor Definitions
****************************************************************************/ ****************************************************************************/
@ -183,6 +188,18 @@ void stm32_usbinitialize(void);
int stm32_usbhost_initialize(void); int stm32_usbhost_initialize(void);
#endif #endif
/****************************************************************************
* Name: stm32_gpio_initialize
*
* Description:
* Initialize GPIO drivers
*
****************************************************************************/
#ifdef CONFIG_STM32F411MINIMUM_GPIO
int stm32_gpio_initialize(void);
#endif
/**************************************************************************** /****************************************************************************
* Name: stm32_bringup * Name: stm32_bringup
* *