forked from uli/allwinner-bare-metal
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathccu.h
97 lines (91 loc) · 5.69 KB
/
ccu.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
#ifdef __cplusplus
extern "C" {
#endif
// The CCU registers base address.
#define CCU_BASE 0x01C20000
// Structure of CCU registers.
#define PLL_CPUX_CTRL *(volatile uint32_t *)(CCU_BASE + 0X000)
#define PLL_AUDIO_CTRL *(volatile uint32_t *)(CCU_BASE + 0X008)
#define PLL_VIDEO_CTRL *(volatile uint32_t *)(CCU_BASE + 0X010)
#define PLL_VE_CTRL *(volatile uint32_t *)(CCU_BASE + 0X018)
#define PLL_DDR_CTRL *(volatile uint32_t *)(CCU_BASE + 0X020)
#define PLL_PERIPH0_CTRL *(volatile uint32_t *)(CCU_BASE + 0X028)
#define PLL_GPU_CTRL *(volatile uint32_t *)(CCU_BASE + 0X038)
#define PLL_PERIPH1_CTRL *(volatile uint32_t *)(CCU_BASE + 0X044)
#define PLL_DE_CTRL *(volatile uint32_t *)(CCU_BASE + 0X048)
#define CPUX_AXI_CFG *(volatile uint32_t *)(CCU_BASE + 0X050)
#define AHB1_APB1_CFG *(volatile uint32_t *)(CCU_BASE + 0X054)
#define APB2_CFG *(volatile uint32_t *)(CCU_BASE + 0X058)
#define AHB2_CFG *(volatile uint32_t *)(CCU_BASE + 0X05C)
#define BUS_CLK_GATING0 *(volatile uint32_t *)(CCU_BASE + 0X060)
#define BUS_CLK_GATING1 *(volatile uint32_t *)(CCU_BASE + 0X064)
#define BUS_CLK_GATING2 *(volatile uint32_t *)(CCU_BASE + 0X068)
#define BUS_CLK_GATING3 *(volatile uint32_t *)(CCU_BASE + 0X06C)
#define BUS_CLK_GATING4 *(volatile uint32_t *)(CCU_BASE + 0X070)
#define THS_CLK *(volatile uint32_t *)(CCU_BASE + 0X074)
#define NAND_CLK *(volatile uint32_t *)(CCU_BASE + 0X080)
#define SDMMC0_CLK *(volatile uint32_t *)(CCU_BASE + 0X088)
#define SDMMC1_CLK *(volatile uint32_t *)(CCU_BASE + 0X08C)
#define SDMMC2_CLK *(volatile uint32_t *)(CCU_BASE + 0X090)
#define CE_CLK *(volatile uint32_t *)(CCU_BASE + 0X09C)
#define SPI0_CLK *(volatile uint32_t *)(CCU_BASE + 0X0A0)
#define SPI1_CLK *(volatile uint32_t *)(CCU_BASE + 0X0A4)
#define I2S_PCM0_CLK *(volatile uint32_t *)(CCU_BASE + 0X0B0)
#define I2S_PCM1_CLK *(volatile uint32_t *)(CCU_BASE + 0X0B4)
#define I2S_PCM2_CLK *(volatile uint32_t *)(CCU_BASE + 0X0B8)
#define OWA_CLK *(volatile uint32_t *)(CCU_BASE + 0X0C0)
#define USBPHY_CFG *(volatile uint32_t *)(CCU_BASE + 0X0CC)
#define DRAM_CFG *(volatile uint32_t *)(CCU_BASE + 0X0F4)
#define MBUS_RST *(volatile uint32_t *)(CCU_BASE + 0X0FC)
#define DRAM_CLK_GATING *(volatile uint32_t *)(CCU_BASE + 0X100)
#define DE_CLK *(volatile uint32_t *)(CCU_BASE + 0X104)
#define TCON0_CLK *(volatile uint32_t *)(CCU_BASE + 0X118)
#define TVE_CLK *(volatile uint32_t *)(CCU_BASE + 0X120)
#define DEINTERLACE_CLK *(volatile uint32_t *)(CCU_BASE + 0X124)
#define CSI_MISC_CLK *(volatile uint32_t *)(CCU_BASE + 0X130)
#define CSI_CLK *(volatile uint32_t *)(CCU_BASE + 0X134)
#define VE_CLK *(volatile uint32_t *)(CCU_BASE + 0X13C)
#define AC_DIG_CLK *(volatile uint32_t *)(CCU_BASE + 0X140)
#define AVS_CLK *(volatile uint32_t *)(CCU_BASE + 0X144)
#define HDMI_CLK *(volatile uint32_t *)(CCU_BASE + 0X150)
#define HDMI_SLOW_CLK *(volatile uint32_t *)(CCU_BASE + 0X154)
#define MBUS_CLK *(volatile uint32_t *)(CCU_BASE + 0X15C)
#define GPU_CLK *(volatile uint32_t *)(CCU_BASE + 0X1A0)
#define PLL_STABLE_TIME0 *(volatile uint32_t *)(CCU_BASE + 0X200)
#define PLL_STABLE_TIME1 *(volatile uint32_t *)(CCU_BASE + 0X204)
#define PLL_CPUX_BIAS *(volatile uint32_t *)(CCU_BASE + 0X220)
#define PLL_AUDIO_BIAS *(volatile uint32_t *)(CCU_BASE + 0X224)
#define PLL_VIDEO_BIAS *(volatile uint32_t *)(CCU_BASE + 0X228)
#define PLL_VE_BIAS *(volatile uint32_t *)(CCU_BASE + 0X22C)
#define PLL_DDR_BIAS *(volatile uint32_t *)(CCU_BASE + 0X230)
#define PLL_PERIPH0_BIAS *(volatile uint32_t *)(CCU_BASE + 0X234)
#define PLL_GPU_BIAS *(volatile uint32_t *)(CCU_BASE + 0X23C)
#define PLL_PERIPH1_BIAS *(volatile uint32_t *)(CCU_BASE + 0X244)
#define PLL_DE_BIAS *(volatile uint32_t *)(CCU_BASE + 0X248)
#define PLL_CPUX_TUN *(volatile uint32_t *)(CCU_BASE + 0X250)
#define PLL_DDR_TUN *(volatile uint32_t *)(CCU_BASE + 0X260)
#define PLL_CPUX_PAT_CTRL *(volatile uint32_t *)(CCU_BASE + 0X280)
#define PLL_AUDIO_PAT_CTRL0 *(volatile uint32_t *)(CCU_BASE + 0X284)
#define PLL_VIDEO_PAT_CTRL0 *(volatile uint32_t *)(CCU_BASE + 0X288)
#define PLL_VE_PAT_CTRL *(volatile uint32_t *)(CCU_BASE + 0X28C)
#define PLL_DDR_PAT_CTRL0 *(volatile uint32_t *)(CCU_BASE + 0X290)
#define PLL_GPU_PAT_CTRL *(volatile uint32_t *)(CCU_BASE + 0X29C)
#define PLL_PERIPH1_PAT_CTRL1 *(volatile uint32_t *)(CCU_BASE + 0X2A4)
#define PLL_DE_PAT_CTRL *(volatile uint32_t *)(CCU_BASE + 0X2A8)
#define BUS_SOFT_RST0 *(volatile uint32_t *)(CCU_BASE + 0X2C0)
#define BUS_SOFT_RST1 *(volatile uint32_t *)(CCU_BASE + 0X2C4)
#define BUS_SOFT_RST2 *(volatile uint32_t *)(CCU_BASE + 0X2C8)
#define BUS_SOFT_RST3 *(volatile uint32_t *)(CCU_BASE + 0X2D0)
#define BUS_SOFT_RST4 *(volatile uint32_t *)(CCU_BASE + 0X2D8)
#define CCU_SEC_SWITCH *(volatile uint32_t *)(CCU_BASE + 0X2F0)
#define PS_CTRL *(volatile uint32_t *)(CCU_BASE + 0X300)
#define PS_CNT *(volatile uint32_t *)(CCU_BASE + 0X304)
#define R_PRCM_BASE 0x01F01400
#define APB0_CLK_GATING *(volatile uint32_t *)(R_PRCM_BASE + 0x28)
#define PLL_CPUX_FACTOR_K_SHIFT 4
#define PLL_CPUX_FACTOR_N_SHIFT 8
#define PLL_CPUX_FACTOR_K_MASK 0x00000030UL
#define PLL_CPUX_FACTOR_N_MASK 0x00001f00UL
#ifdef __cplusplus
}
#endif