# 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_WIN
# 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 H616 *************/
# if CONFIG_ORANGEPI_ZERO2
# 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 || CONFIG_ORANGEPI_4_LTS || CONFIG_ORANGEPI_800
# 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
/*********** OrangePi R1PLUS *************/
# if CONFIG_ORANGEPI_R1PLUS
# define GPIO2_BASE 0xff230000
# define GPIO3_BASE 0xff240000
# define GPIO_NUM (0x40)
# define GPIO_SWPORTA_DR_OFFSET 0x00
# define GPIO_SWPORTA_DDR_OFFSET 0x04
# define GPIO_EXT_PORTA_OFFSET 0x50
# define GRF_BASE 0xff100000
# define GRF_GPIO2A_IOMUX_OFFSET 0x20
# define GRF_GPIO2BL_IOMUX_OFFSET 0x24
# define GRF_GPIO2BH_IOMUX_OFFSET 0x28
# define GRF_GPIO2CL_IOMUX_OFFSET 0x2c
# define GRF_GPIO2CH_IOMUX_OFFSET 0x30
# define GRF_GPIO2D_IOMUX_OFFSET 0x34
# define GRF_GPIO3AL_IOMUX_OFFSET 0x38
# define GRF_GPIO3AH_IOMUX_OFFSET 0x3c
# define GRF_GPIO3BL_IOMUX_OFFSET 0x40
# define GRF_GPIO3BH_IOMUX_OFFSET 0x44
# define GRF_GPIO3C_IOMUX_OFFSET 0x48
# define GRF_GPIO3D_IOMUX_OFFSET 0x4c
# define CRU_BASE 0xff440000
# define CRU_CLKGATE_CON16_OFFSET 0x0240 //bit 7 8 9 10 9877
# define MEM_INFO (2048)
# define MAP_SIZE_L (4*1024)
extern volatile unsigned int * gpio2_base ;
extern volatile unsigned int * gpio3_base ;
extern volatile unsigned int * cru_base ;
extern volatile unsigned int * grf_base ;
# endif /* CONFIG_ORANGEPI_R1PLUS */
//FG 2020.11.26
/****************** 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 ) ;
# if !(defined CONFIG_ORANGEPI_RK3399 || defined CONFIG_ORANGEPI_4 || defined CONFIG_ORANGEPI_4_LTS || defined CONFIG_ORANGEPI_800 || defined CONFIG_ORANGEPI_R1PLUS || CONFIG_ORANGEPI_2G_IOT)
extern int OrangePi_set_gpio_alt ( int pin , int mode ) ;
# endif
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_WIN
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 ] ;
# elif CONFIG_ORANGEPI_R1PLUS
extern int ORANGEPI_PIN_MASK [ 5 ] [ 32 ] ;
# endif
# endif