[U-Boot] [PATCH 3/6 v3] nios2: add gpio support to nios2-generic board

Scott McNutt smcnutt at psyent.com
Tue May 25 21:40:08 CEST 2010


Applied to:

   git://git.denx.de/u-boot-nios.git next

Thanks,
--Scott


Thomas Chou wrote:
> This patch adds gpio support of Altera PIO component to the
> nios2-generic board. Though it drives only gpio_led at the
> moment, it supports bidirectional port to control bit-banging
> I2C, NAND flash busy status or button switches, etc.
> 
> Signed-off-by: Thomas Chou <thomas at wytron.com.tw>
> ---
> v3: split patches for gpio and spi, based gpio on altera pio core.
> v2: remove mmc_spi_init()
> 
>  board/altera/nios2-generic/Makefile |    1 +
>  board/altera/nios2-generic/gpio.c   |   55 +++++++++++++++++++++++++++++++++++
>  include/configs/nios2-generic.h     |    6 ++--
>  3 files changed, 59 insertions(+), 3 deletions(-)
>  create mode 100644 board/altera/nios2-generic/gpio.c
> 
> diff --git a/board/altera/nios2-generic/Makefile b/board/altera/nios2-generic/Makefile
> index 6780872..d1fca70 100644
> --- a/board/altera/nios2-generic/Makefile
> +++ b/board/altera/nios2-generic/Makefile
> @@ -32,6 +32,7 @@ LIB	= $(obj)lib$(BOARD).a
>  COBJS-y	:= $(BOARD).o
>  COBJS-$(CONFIG_CMD_IDE) += ../common/cfide.o
>  COBJS-$(CONFIG_EPLED) += ../common/epled.o
> +COBJS-$(CONFIG_GPIO) += gpio.o
>  COBJS-$(CONFIG_SEVENSEG) += ../common/sevenseg.o
>  
>  SOBJS-y	:= text_base.o
> diff --git a/board/altera/nios2-generic/gpio.c b/board/altera/nios2-generic/gpio.c
> new file mode 100644
> index 0000000..6c9c6c2
> --- /dev/null
> +++ b/board/altera/nios2-generic/gpio.c
> @@ -0,0 +1,55 @@
> +/*
> + * board gpio driver
> + *
> + * Copyright (C) 2010 Thomas Chou <thomas at wytron.com.tw>
> + * Licensed under the GPL-2 or later.
> + */
> +#include <common.h>
> +#include <asm/io.h>
> +
> +#ifndef CONFIG_SYS_GPIO_BASE
> +
> +#define ALTERA_PIO_BASE LED_PIO_BASE
> +#define ALTERA_PIO_DATA (ALTERA_PIO_BASE + 0)
> +#define ALTERA_PIO_DIR (ALTERA_PIO_BASE + 4)
> +static u32 pio_data_reg;
> +static u32 pio_dir_reg;
> +
> +int gpio_direction_input(unsigned gpio)
> +{
> +	u32 mask = 1 << gpio;
> +	writel(pio_dir_reg &= ~mask, ALTERA_PIO_DIR);
> +	return 0;
> +}
> +
> +int gpio_direction_output(unsigned gpio, int value)
> +{
> +	u32 mask = 1 << gpio;
> +	if (value)
> +		pio_data_reg |= mask;
> +	else
> +		pio_data_reg &= ~mask;
> +	writel(pio_data_reg, ALTERA_PIO_DATA);
> +	writel(pio_dir_reg |= mask, ALTERA_PIO_DIR);
> +	return 0;
> +}
> +
> +int gpio_get_value(unsigned gpio)
> +{
> +	u32 mask = 1 << gpio;
> +	if (pio_dir_reg & mask)
> +		return (pio_data_reg & mask) ? 1 : 0;
> +	else
> +		return (readl(ALTERA_PIO_DATA) & mask) ? 1 : 0;
> +}
> +
> +void gpio_set_value(unsigned gpio, int value)
> +{
> +	u32 mask = 1 << gpio;
> +	if (value)
> +		pio_data_reg |= mask;
> +	else
> +		pio_data_reg &= ~mask;
> +	writel(pio_data_reg, ALTERA_PIO_DATA);
> +}
> +#endif
> diff --git a/include/configs/nios2-generic.h b/include/configs/nios2-generic.h
> index e83e1e3..e4bf57b 100644
> --- a/include/configs/nios2-generic.h
> +++ b/include/configs/nios2-generic.h
> @@ -63,10 +63,10 @@
>   * STATUS LED
>   */
>  #define CONFIG_STATUS_LED		/* Enable status driver */
> -#define CONFIG_EPLED			/* Enable LED PIO driver */
> -#define CONFIG_SYS_LEDPIO_ADDR		LED_PIO_BASE
> +#define CONFIG_GPIO_LED		/* Enable GPIO LED driver */
> +#define CONFIG_GPIO			/* Enable GPIO driver */
>  
> -#define STATUS_LED_BIT			1	/* Bit-0 on PIO */
> +#define STATUS_LED_BIT			0	/* Bit-0 on GPIO */
>  #define STATUS_LED_STATE		1	/* Blinking */
>  #define STATUS_LED_PERIOD	(500 / CONFIG_SYS_NIOS_TMRMS) /* 500 msec */
>  


More information about the U-Boot mailing list