Home | History | Annotate | Download | only in arch-tegra
      1 /* SPDX-License-Identifier: GPL-2.0+ */
      2 /*
      3  * Copyright (c) 2011, Google Inc. All rights reserved.
      4  */
      5 
      6 #ifndef _TEGRA_GPIO_H_
      7 #define _TEGRA_GPIO_H_
      8 
      9 #include <dt-bindings/gpio/tegra-gpio.h>
     10 
     11 #define TEGRA_GPIOS_PER_PORT	8
     12 #define TEGRA_PORTS_PER_BANK	4
     13 #define MAX_NUM_GPIOS           (TEGRA_GPIO_PORTS * TEGRA_GPIO_BANKS * 8)
     14 #define GPIO_NAME_SIZE		20	/* gpio_request max label len */
     15 
     16 #define GPIO_BANK(x)		((x) >> 5)
     17 #define GPIO_PORT(x)		(((x) >> 3) & 0x3)
     18 #define GPIO_FULLPORT(x)	((x) >> 3)
     19 #define GPIO_BIT(x)		((x) & 0x7)
     20 
     21 enum tegra_gpio_init {
     22 	TEGRA_GPIO_INIT_IN,
     23 	TEGRA_GPIO_INIT_OUT0,
     24 	TEGRA_GPIO_INIT_OUT1,
     25 };
     26 
     27 struct tegra_gpio_config {
     28 	u32 gpio:16;
     29 	u32 init:2;
     30 };
     31 
     32 /**
     33  * Configure a list of GPIOs
     34  *
     35  * @param config	List of GPIO configurations
     36  * @param len		Number of config items in list
     37  */
     38 void gpio_config_table(const struct tegra_gpio_config *config, int len);
     39 
     40 #endif	/* TEGRA_GPIO_H_ */
     41