2018-09-07 15:00:13 +00:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2018 Atmosphère-NX
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms and conditions of the GNU General Public License,
|
|
|
|
* version 2, as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
|
|
* more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
2018-07-19 20:07:53 +00:00
|
|
|
#ifndef FUSEE_GPIO_H
|
|
|
|
#define FUSEE_GPIO_H
|
|
|
|
|
2018-08-18 16:59:33 +00:00
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
#define GPIO_BASE 0x6000D000
|
|
|
|
#define MAKE_GPIO_REG(n) MAKE_REG32(GPIO_BASE + n)
|
|
|
|
|
2018-07-19 20:07:53 +00:00
|
|
|
#define TEGRA_GPIO_PORTS 4
|
|
|
|
#define TEGRA_GPIO_BANKS 8
|
|
|
|
#define GPIO_BANK_SHIFT 5
|
|
|
|
#define GPIO_PORT_SHIFT 3
|
|
|
|
#define GPIO_PORT_MASK 0x03
|
|
|
|
#define GPIO_PIN_MASK 0x07
|
|
|
|
|
|
|
|
typedef enum {
|
2018-05-04 17:47:05 +00:00
|
|
|
TEGRA_GPIO_PORT_A = 0,
|
|
|
|
TEGRA_GPIO_PORT_B = 1,
|
|
|
|
TEGRA_GPIO_PORT_C = 2,
|
|
|
|
TEGRA_GPIO_PORT_D = 3,
|
|
|
|
TEGRA_GPIO_PORT_E = 4,
|
|
|
|
TEGRA_GPIO_PORT_F = 5,
|
|
|
|
TEGRA_GPIO_PORT_G = 6,
|
|
|
|
TEGRA_GPIO_PORT_H = 7,
|
|
|
|
TEGRA_GPIO_PORT_I = 8,
|
|
|
|
TEGRA_GPIO_PORT_J = 9,
|
|
|
|
TEGRA_GPIO_PORT_K = 10,
|
|
|
|
TEGRA_GPIO_PORT_L = 11,
|
|
|
|
TEGRA_GPIO_PORT_M = 12,
|
|
|
|
TEGRA_GPIO_PORT_N = 13,
|
|
|
|
TEGRA_GPIO_PORT_O = 14,
|
|
|
|
TEGRA_GPIO_PORT_P = 15,
|
|
|
|
TEGRA_GPIO_PORT_Q = 16,
|
|
|
|
TEGRA_GPIO_PORT_R = 17,
|
|
|
|
TEGRA_GPIO_PORT_S = 18,
|
|
|
|
TEGRA_GPIO_PORT_T = 19,
|
|
|
|
TEGRA_GPIO_PORT_U = 20,
|
|
|
|
TEGRA_GPIO_PORT_V = 21,
|
|
|
|
TEGRA_GPIO_PORT_W = 22,
|
|
|
|
TEGRA_GPIO_PORT_X = 23,
|
|
|
|
TEGRA_GPIO_PORT_Y = 24,
|
|
|
|
TEGRA_GPIO_PORT_Z = 25,
|
|
|
|
TEGRA_GPIO_PORT_AA = 26,
|
|
|
|
TEGRA_GPIO_PORT_BB = 27,
|
|
|
|
TEGRA_GPIO_PORT_CC = 28,
|
|
|
|
TEGRA_GPIO_PORT_DD = 29,
|
|
|
|
TEGRA_GPIO_PORT_EE = 30,
|
|
|
|
TEGRA_GPIO_PORT_FF = 31,
|
2018-07-19 20:07:53 +00:00
|
|
|
} tegra_gpio_port;
|
2018-05-04 17:47:05 +00:00
|
|
|
|
2018-07-19 20:07:53 +00:00
|
|
|
typedef struct {
|
2018-05-04 17:47:05 +00:00
|
|
|
uint32_t config[TEGRA_GPIO_PORTS];
|
|
|
|
uint32_t direction[TEGRA_GPIO_PORTS];
|
|
|
|
uint32_t out[TEGRA_GPIO_PORTS];
|
|
|
|
uint32_t in[TEGRA_GPIO_PORTS];
|
|
|
|
uint32_t int_status[TEGRA_GPIO_PORTS];
|
|
|
|
uint32_t int_enable[TEGRA_GPIO_PORTS];
|
|
|
|
uint32_t int_level[TEGRA_GPIO_PORTS];
|
|
|
|
uint32_t int_clear[TEGRA_GPIO_PORTS];
|
|
|
|
uint32_t masked_config[TEGRA_GPIO_PORTS];
|
|
|
|
uint32_t masked_dir_out[TEGRA_GPIO_PORTS];
|
|
|
|
uint32_t masked_out[TEGRA_GPIO_PORTS];
|
|
|
|
uint32_t masked_in[TEGRA_GPIO_PORTS];
|
|
|
|
uint32_t masked_int_status[TEGRA_GPIO_PORTS];
|
|
|
|
uint32_t masked_int_enable[TEGRA_GPIO_PORTS];
|
|
|
|
uint32_t masked_int_level[TEGRA_GPIO_PORTS];
|
|
|
|
uint32_t masked_int_clear[TEGRA_GPIO_PORTS];
|
2018-07-19 20:07:53 +00:00
|
|
|
} tegra_gpio_bank_t;
|
2018-05-04 17:47:05 +00:00
|
|
|
|
2018-07-19 20:07:53 +00:00
|
|
|
typedef struct {
|
|
|
|
tegra_gpio_bank_t bank[TEGRA_GPIO_BANKS];
|
|
|
|
} tegra_gpio_t;
|
2018-05-04 17:47:05 +00:00
|
|
|
|
2018-07-19 20:07:53 +00:00
|
|
|
static inline volatile tegra_gpio_t *gpio_get_regs(void)
|
2018-05-04 17:47:05 +00:00
|
|
|
{
|
2018-08-18 16:59:33 +00:00
|
|
|
return (volatile tegra_gpio_t *)GPIO_BASE;
|
2018-05-04 17:47:05 +00:00
|
|
|
}
|
|
|
|
|
2018-07-19 20:07:53 +00:00
|
|
|
#define TEGRA_GPIO(port, offset) \
|
|
|
|
((TEGRA_GPIO_PORT_##port * 8) + offset)
|
2018-05-04 17:47:05 +00:00
|
|
|
|
2018-07-19 20:07:53 +00:00
|
|
|
/* Mode select */
|
|
|
|
#define GPIO_MODE_GPIO 0
|
|
|
|
#define GPIO_MODE_SFIO 1
|
2018-05-04 17:47:05 +00:00
|
|
|
|
2018-07-19 20:07:53 +00:00
|
|
|
/* Direction */
|
|
|
|
#define GPIO_DIRECTION_INPUT 0
|
|
|
|
#define GPIO_DIRECTION_OUTPUT 1
|
2018-05-04 17:47:05 +00:00
|
|
|
|
2018-07-19 20:07:53 +00:00
|
|
|
/* Level */
|
|
|
|
#define GPIO_LEVEL_LOW 0
|
|
|
|
#define GPIO_LEVEL_HIGH 1
|
2018-05-04 17:47:05 +00:00
|
|
|
|
2018-07-19 20:07:53 +00:00
|
|
|
/* Named GPIOs */
|
2018-08-18 16:59:33 +00:00
|
|
|
#define GPIO_BUTTON_VOL_DOWN TEGRA_GPIO(X, 7)
|
|
|
|
#define GPIO_BUTTON_VOL_UP TEGRA_GPIO(X, 6)
|
2018-07-19 20:07:53 +00:00
|
|
|
#define GPIO_MICROSD_CARD_DETECT TEGRA_GPIO(Z, 1)
|
|
|
|
#define GPIO_MICROSD_WRITE_PROTECT TEGRA_GPIO(Z, 4)
|
|
|
|
#define GPIO_MICROSD_SUPPLY_ENABLE TEGRA_GPIO(E, 4)
|
2018-08-18 16:59:33 +00:00
|
|
|
#define GPIO_LCD_BL_P5V TEGRA_GPIO(I, 0)
|
|
|
|
#define GPIO_LCD_BL_N5V TEGRA_GPIO(I, 1)
|
|
|
|
#define GPIO_LCD_BL_PWM TEGRA_GPIO(V, 0)
|
|
|
|
#define GPIO_LCD_BL_EN TEGRA_GPIO(V, 1)
|
|
|
|
#define GPIO_LCD_BL_RST TEGRA_GPIO(V, 2)
|
2018-05-04 17:47:05 +00:00
|
|
|
|
2018-07-19 20:07:53 +00:00
|
|
|
void gpio_configure_mode(uint32_t pin, uint32_t mode);
|
|
|
|
void gpio_configure_direction(uint32_t pin, uint32_t dir);
|
|
|
|
void gpio_write(uint32_t pin, uint32_t value);
|
|
|
|
uint32_t gpio_read(uint32_t pin);
|
2018-05-04 17:47:05 +00:00
|
|
|
|
|
|
|
#endif
|