mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-12 07:57:21 +00:00
eceb3f26f4
The HW-defined procedure for booting Tegra requires that some pins be set up as GPIOs immediately at boot in order to avoid glitches on those pins, when the pinmux is programmed. Add a feature to the GPIO driver which executes a GPIO configuration table. Board files will use this to implement the correct HW initialization procedure. Signed-off-by: Stephen Warren <swarren@nvidia.com> Signed-off-by: Tom Warren <twarren@nvidia.com>
44 lines
904 B
C
44 lines
904 B
C
/*
|
|
* Copyright (c) 2011, Google Inc. All rights reserved.
|
|
* SPDX-License-Identifier: GPL-2.0+
|
|
*/
|
|
|
|
#ifndef _TEGRA_GPIO_H_
|
|
#define _TEGRA_GPIO_H_
|
|
|
|
#define MAX_NUM_GPIOS (TEGRA_GPIO_PORTS * TEGRA_GPIO_BANKS * 8)
|
|
#define GPIO_NAME_SIZE 20 /* gpio_request max label len */
|
|
|
|
#define GPIO_BANK(x) ((x) >> 5)
|
|
#define GPIO_PORT(x) (((x) >> 3) & 0x3)
|
|
#define GPIO_FULLPORT(x) ((x) >> 3)
|
|
#define GPIO_BIT(x) ((x) & 0x7)
|
|
|
|
enum tegra_gpio_init {
|
|
TEGRA_GPIO_INIT_IN,
|
|
TEGRA_GPIO_INIT_OUT0,
|
|
TEGRA_GPIO_INIT_OUT1,
|
|
};
|
|
|
|
struct tegra_gpio_config {
|
|
u32 gpio:16;
|
|
u32 init:2;
|
|
};
|
|
|
|
/*
|
|
* Tegra-specific GPIO API
|
|
*/
|
|
|
|
/**
|
|
* Configure a list of GPIOs
|
|
*
|
|
* @param config List of GPIO configurations
|
|
* @param len Number of config items in list
|
|
*/
|
|
void gpio_config_table(const struct tegra_gpio_config *config, int len);
|
|
|
|
void gpio_info(void);
|
|
|
|
#define gpio_status() gpio_info()
|
|
|
|
#endif /* TEGRA_GPIO_H_ */
|