|
|
|
#ifndef _ORANGEPI_H
|
|
|
|
#define _ORANGEPI_H
|
|
|
|
|
|
|
|
#ifdef CONFIG_ORANGEPI_2G_IOT
|
|
|
|
/********** OrangePi 2G-IOT *************/
|
|
|
|
/*
|
|
|
|
* GPIOA_BASE 0x20930000
|
|
|
|
* GPIOB_BASE 0x20931000
|
|
|
|
* GPIOC_BASE 0x11A08000
|
|
|
|
* GPIOD_BASE 0x20932000
|
|
|
|
*/
|
|
|
|
|
|
|
|
/********* local data ************/
|
|
|
|
#define GPIOA_BASE 0x20930000
|
|
|
|
#define GPIOB_BASE 0x20931000
|
|
|
|
#define GPIOC_BASE 0x11A08000
|
|
|
|
#define GPIOD_BASE 0x20932000
|
|
|
|
#define GPIO_NUM (0x80)
|
|
|
|
#define GPIO_BIT(x) (1UL << (x))
|
|
|
|
|
|
|
|
#define OEN_VAL_REGISTER (0x00)
|
|
|
|
#define OEN_SET_OUT_REGISTER (0x04)
|
|
|
|
#define SET_IN_REGISTER (0x08)
|
|
|
|
#define VAL_REGISTER (0x0C)
|
|
|
|
#define SET_REGISTER (0x10)
|
|
|
|
#define CLR_REGISTER (0x14)
|
|
|
|
|
|
|
|
#define MEM_INFO (512)
|
|
|
|
#define MAP_SIZE_L (4 * 4096)
|
|
|
|
|
|
|
|
#endif /* CONFIG_ORANGEPI_2G_IOT */
|
|
|
|
|
|
|
|
#if CONFIG_ORANGEPI_PC2 || CONFIG_ORANGEPI_ZEROPLUS || CONFIG_ORANGEPI_ZEROPLUS2_H5 || CONFIG_ORANGEPI_PRIME
|
|
|
|
/************** OrangePi H5 ***********************/
|
|
|
|
#define GPIOA_BASE (0x01C20000)
|
|
|
|
#define GPIO_NUM (0x40)
|
|
|
|
#define GPIO_BASE_MAP (0x01C20800)
|
|
|
|
#define MEM_INFO (1024)
|
|
|
|
#define GPIOL_BASE (0x01F02c00)
|
|
|
|
#define GPIOL_BASE_MAP (0x01F02000)
|
|
|
|
#define MAP_SIZE_L (4096 * 2)
|
|
|
|
#define GPIO_PWM_OP (0x01C21000)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/************** OrangePi A64 ***********************/
|
|
|
|
#ifdef CONFIG_ORANGEPI_A64
|
|
|
|
#define GPIOA_BASE (0x01C20000)
|
|
|
|
#define GPIO_NUM (0x40)
|
|
|
|
#define GPIO_BASE_MAP (0x01C20800)
|
|
|
|
#define MEM_INFO (1024)
|
|
|
|
#define GPIOL_BASE (0x01F02c00)
|
|
|
|
#define GPIOL_BASE_MAP (0x01F02000)
|
|
|
|
#define MAP_SIZE_L (4096 * 2)
|
|
|
|
#define GPIO_PWM_OP (0x01C21000)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/************** OrangePi H3 ***********************/
|
|
|
|
#if CONFIG_ORANGEPI_H3 || CONFIG_ORANGEPI_ZEROPLUS2_H3 || CONFIG_ORANGEPI_ZERO
|
|
|
|
#define GPIOA_BASE (0x01C20000)
|
|
|
|
#define GPIO_NUM (0x40)
|
|
|
|
#define GPIO_BASE_MAP (0x01C20800)
|
|
|
|
#define MEM_INFO (1024)
|
|
|
|
#define GPIOL_BASE (0x01F02c00)
|
|
|
|
#define GPIOL_BASE_MAP (0x01F02000)
|
|
|
|
#define MAP_SIZE_L (4096 * 2)
|
|
|
|
#define GPIO_PWM_OP (0x01C21000)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/*********** OrangePi LITE2/OnePlus/PC3 *************/
|
|
|
|
#if CONFIG_ORANGEPI_LITE2 || CONFIG_ORANGEPI_3
|
|
|
|
#define GPIOA_BASE (0x0300B000)
|
|
|
|
#define GPIO_NUM (0x40)
|
|
|
|
#define GPIO_BASE_MAP (0x0300B000)
|
|
|
|
#define MEM_INFO (1024)
|
|
|
|
#define GPIOL_BASE (0x07022000)
|
|
|
|
#define GPIOL_BASE_MAP (0x07022000)
|
|
|
|
#define MAP_SIZE_L (4096 * 1)
|
|
|
|
#define GPIO_PWM_OP (0x0300A000)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/*********** OrangePi RK3399 *************/
|
|
|
|
#if CONFIG_ORANGEPI_RK3399 || CONFIG_ORANGEPI_4
|
|
|
|
|
|
|
|
#define GPIO1_BASE 0xff730000
|
|
|
|
#define GPIO2_BASE 0xff780000
|
|
|
|
#define GPIO4_BASE 0xff790000
|
|
|
|
#define GPIO_NUM (0x40)
|
|
|
|
#define GPIO_BIT(x) (1UL << (x))
|
|
|
|
#define GPIO_SWPORTA_DR_OFFSET 0x00
|
|
|
|
#define GPIO_SWPORTA_DDR_OFFSET 0x04
|
|
|
|
#define GPIO_EXT_PORTA_OFFSET 0x50
|
|
|
|
|
|
|
|
#define PMUGRF_BASE 0xff320000
|
|
|
|
#define PMUGRF_GPIO1A_IOMUX 0x00010
|
|
|
|
#define PMUGRF_GPIO1B_IOMUX 0x00014
|
|
|
|
#define PMUGRF_GPIO1C_IOMUX 0x00018
|
|
|
|
#define PMUGRF_GPIO1D_IOMUX 0x0001c
|
|
|
|
|
|
|
|
#define GRF_BASE 0xff77e000
|
|
|
|
#define GRF_GPIO2A_IOMUX_OFFSET 0x00
|
|
|
|
#define GRF_GPIO2B_IOMUX_OFFSET 0x04
|
|
|
|
#define GRF_GPIO2C_IOMUX_OFFSET 0x08
|
|
|
|
#define GRF_GPIO2D_IOMUX_OFFSET 0x0c
|
|
|
|
|
|
|
|
#define GRF_GPIO4A_IOMUX_OFFSET 0x20
|
|
|
|
#define GRF_GPIO4B_IOMUX_OFFSET 0x24
|
|
|
|
#define GRF_GPIO4C_IOMUX_OFFSET 0x28
|
|
|
|
#define GRF_GPIO4D_IOMUX_OFFSET 0x2c
|
|
|
|
|
|
|
|
|
|
|
|
#define CRU_BASE 0xff760000
|
|
|
|
#define PMUCRU_BASE 0xff750000
|
|
|
|
#define CRU_CLKGATE_CON31_OFFSET 0x037c //bit 3 4 5
|
|
|
|
#define PMUCRU_CLKGATE_CON1_OFFSET 0x0104
|
|
|
|
|
|
|
|
#define MEM_INFO (2048)
|
|
|
|
#define MAP_SIZE_L (4*1024)
|
|
|
|
|
|
|
|
extern volatile unsigned int *gpio2_base;
|
|
|
|
extern volatile unsigned int *grf_base;
|
|
|
|
extern volatile unsigned int *cru_base;
|
|
|
|
extern volatile unsigned int *pmucru_base;
|
|
|
|
extern volatile unsigned int *pmugrf_base;
|
|
|
|
extern volatile unsigned int *gpio1_base;
|
|
|
|
extern volatile unsigned int *gpio4_base;
|
|
|
|
|
|
|
|
#endif /* CONFIG_ORANGEPI_RK3399 */
|
|
|
|
//csy 2019.1.8
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/****************** Global data *********************/
|
|
|
|
/* Current version */
|
|
|
|
#define PI_MAKER_ORANGEPI 4
|
|
|
|
#define MAX_PIN_NUM GPIO_NUM
|
|
|
|
#define MAP_SIZE MAP_SIZE_L
|
|
|
|
#define MAP_MASK (MAP_SIZE - 1)
|
|
|
|
#define PI_GPIO_MASK (~(GPIO_NUM - 1))
|
|
|
|
#define GPIO_BASE GPIOA_BASE
|
|
|
|
#define ORANGEPI_MEM_INFO MEM_INFO
|
|
|
|
#define GPIO_PWM GPIO_PWM_OP
|
|
|
|
|
|
|
|
|
|
|
|
//sunxi_pwm
|
|
|
|
#define SUNXI_PWM_BASE (0x01c21400)
|
|
|
|
#define SUNXI_PWM_CTRL_REG (SUNXI_PWM_BASE)
|
|
|
|
#define SUNXI_PWM_CH0_PERIOD (SUNXI_PWM_BASE + 0x4)
|
|
|
|
#define SUNXI_PWM_CH1_PERIOD (SUNXI_PWM_BASE + 0x8)
|
|
|
|
|
|
|
|
#define SUNXI_PWM_CH0_EN (1 << 4)
|
|
|
|
#define SUNXI_PWM_CH0_ACT_STA (1 << 5)
|
|
|
|
#define SUNXI_PWM_SCLK_CH0_GATING (1 << 6)
|
|
|
|
#define SUNXI_PWM_CH0_MS_MODE (1 << 7) //pulse mode
|
|
|
|
#define SUNXI_PWM_CH0_PUL_START (1 << 8)
|
|
|
|
|
|
|
|
#define PWM_CLK_DIV_120 0
|
|
|
|
#define PWM_CLK_DIV_180 1
|
|
|
|
#define PWM_CLK_DIV_240 2
|
|
|
|
#define PWM_CLK_DIV_360 3
|
|
|
|
#define PWM_CLK_DIV_480 4
|
|
|
|
#define PWM_CLK_DIV_12K 8
|
|
|
|
#define PWM_CLK_DIV_24K 9
|
|
|
|
#define PWM_CLK_DIV_36K 10
|
|
|
|
#define PWM_CLK_DIV_48K 11
|
|
|
|
#define PWM_CLK_DIV_72K 12
|
|
|
|
|
|
|
|
extern int pinToGpioOrangePi[64];
|
|
|
|
extern int physToGpioOrangePi[64];
|
|
|
|
extern int physToPinOrangePi[64];
|
|
|
|
extern int physToWpiOrangePi[64];
|
|
|
|
extern volatile unsigned int *OrangePi_gpio;
|
|
|
|
extern volatile unsigned int *OrangePi_gpioC;
|
|
|
|
|
|
|
|
extern int pinToGpioR3[64];
|
|
|
|
extern int physToGpioR3[64];
|
|
|
|
extern int physToPinR3[64];
|
|
|
|
extern int pwmmode;
|
|
|
|
|
|
|
|
extern unsigned int readR(unsigned int addr);
|
|
|
|
extern void writeR(unsigned int val, unsigned int addr);
|
|
|
|
extern int OrangePi_set_gpio_mode(int pin, int mode);
|
|
|
|
extern int OrangePi_get_gpio_mode(int pin);
|
|
|
|
extern int isOrangePi_2G_IOT(void);
|
|
|
|
extern int isOrangePi(void);
|
|
|
|
extern unsigned int readR(unsigned int addr);
|
|
|
|
extern void writeR(unsigned int val, unsigned int addr);
|
|
|
|
extern int OrangePi_digitalWrite(int pin, int value);
|
|
|
|
extern int OrangePi_digitalRead(int pin);
|
|
|
|
|
|
|
|
extern void print_pwm_reg(void);
|
|
|
|
extern void sunxi_pwm_set_enable(int en);
|
|
|
|
extern void sunxi_pwm_set_mode(int mode);
|
|
|
|
extern void sunxi_pwm_set_clk(int clk);
|
|
|
|
extern int sunxi_pwm_get_period(void);
|
|
|
|
extern int sunxi_pwm_get_act(void);
|
|
|
|
extern void sunxi_pwm_set_period(int period_cys);
|
|
|
|
extern void sunxi_pwm_set_act(int act_cys);
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef CONFIG_ORANGEPI
|
|
|
|
extern const char *piModelNames[6];
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef CONFIG_ORANGEPI_2G_IOT
|
|
|
|
extern int ORANGEPI_PIN_MASK[4][32];
|
|
|
|
#elif CONFIG_ORANGEPI_PC2 || CONFIG_ORANGEPI_PRIME
|
|
|
|
extern int ORANGEPI_PIN_MASK[9][32];
|
|
|
|
#elif CONFIG_ORANGEPI_A64
|
|
|
|
extern int ORANGEPI_PIN_MASK[12][32];
|
|
|
|
#elif CONFIG_ORANGEPI_H3
|
|
|
|
extern int ORANGEPI_PIN_MASK[9][32];
|
|
|
|
#elif CONFIG_ORANGEPI_ZERO || CONFIG_ORANGEPI_ZEROPLUS2_H3 || CONFIG_ORANGEPI_ZEROPLUS || CONFIG_ORANGEPI_ZEROPLUS2_H5
|
|
|
|
extern int ORANGEPI_PIN_MASK[12][32];
|
|
|
|
#elif CONFIG_ORANGEPI_RK3399
|
|
|
|
extern int ORANGEPI_PIN_MASK[5][32];
|
|
|
|
|
|
|
|
#endif
|
|
|
|
#endif
|