1e35377d7SHans de Goede /* 2e35377d7SHans de Goede * sun9i clock register definitions 3e35377d7SHans de Goede * 4e35377d7SHans de Goede * (C) Copyright 2015 Hans de Goede <hdegoede@redhat.com> 5e35377d7SHans de Goede * 6e35377d7SHans de Goede * SPDX-License-Identifier: GPL-2.0+ 7e35377d7SHans de Goede */ 8e35377d7SHans de Goede 9e35377d7SHans de Goede #ifndef _SUNXI_CLOCK_SUN9I_H 10e35377d7SHans de Goede #define _SUNXI_CLOCK_SUN9I_H 11e35377d7SHans de Goede 12e35377d7SHans de Goede struct sunxi_ccm_reg { 13e35377d7SHans de Goede u32 pll1_c0_cfg; /* 0x00 c0cpu# pll configuration */ 14e35377d7SHans de Goede u32 pll2_c1_cfg; /* 0x04 c1cpu# pll configuration */ 15e35377d7SHans de Goede u32 pll3_audio_cfg; /* 0x08 audio pll configuration */ 16e35377d7SHans de Goede u32 pll4_periph0_cfg; /* 0x0c peripheral0 pll configuration */ 17e35377d7SHans de Goede u32 pll5_ve_cfg; /* 0x10 videoengine pll configuration */ 18e35377d7SHans de Goede u32 pll6_ddr_cfg; /* 0x14 ddr pll configuration */ 19e35377d7SHans de Goede u32 pll7_video0_cfg; /* 0x18 video0 pll configuration */ 20e35377d7SHans de Goede u32 pll8_video1_cfg; /* 0x1c video1 pll configuration */ 21e35377d7SHans de Goede u32 pll9_gpu_cfg; /* 0x20 gpu pll configuration */ 22e35377d7SHans de Goede u32 pll10_de_cfg; /* 0x24 displayengine pll configuration */ 23e35377d7SHans de Goede u32 pll11_isp_cfg; /* 0x28 isp pll6 ontrol */ 24e35377d7SHans de Goede u32 pll12_periph1_cfg; /* 0x2c peripheral1 pll configuration */ 25e35377d7SHans de Goede u8 reserved1[0x20]; /* 0x30 */ 26e35377d7SHans de Goede u32 cpu_clk_source; /* 0x50 cpu clk source configuration */ 27e35377d7SHans de Goede u32 c0_cfg; /* 0x54 cpu cluster 0 clock configuration */ 28e35377d7SHans de Goede u32 c1_cfg; /* 0x58 cpu cluster 1 clock configuration */ 29e35377d7SHans de Goede u32 gtbus_cfg; /* 0x5c gtbus clock configuration */ 30e35377d7SHans de Goede u32 ahb0_cfg; /* 0x60 ahb0 clock configuration */ 31e35377d7SHans de Goede u32 ahb1_cfg; /* 0x64 ahb1 clock configuration */ 32e35377d7SHans de Goede u32 ahb2_cfg; /* 0x68 ahb2 clock configuration */ 33e35377d7SHans de Goede u8 reserved2[0x04]; /* 0x6c */ 34e35377d7SHans de Goede u32 apb0_cfg; /* 0x70 apb0 clock configuration */ 35e35377d7SHans de Goede u32 apb1_cfg; /* 0x74 apb1 clock configuration */ 36e35377d7SHans de Goede u32 cci400_cfg; /* 0x78 cci400 clock configuration */ 37e35377d7SHans de Goede u8 reserved3[0x04]; /* 0x7c */ 38e35377d7SHans de Goede u32 ats_cfg; /* 0x80 ats clock configuration */ 39e35377d7SHans de Goede u32 trace_cfg; /* 0x84 trace clock configuration */ 40297bb9e0SPhilipp Tomsich u8 reserved4[0x14]; /* 0x88 */ 41297bb9e0SPhilipp Tomsich u32 pll_stable_status; /* 0x9c */ 42297bb9e0SPhilipp Tomsich u8 reserved5[0xe0]; /* 0xa0 */ 43e35377d7SHans de Goede u32 clk_output_a; /* 0x180 clk_output_a */ 44e35377d7SHans de Goede u32 clk_output_b; /* 0x184 clk_output_a */ 45297bb9e0SPhilipp Tomsich u8 reserved6[0x278]; /* 0x188 */ 46e35377d7SHans de Goede 47d0f42003SRoy Spliet u32 nand0_clk_cfg; /* 0x400 nand0 clock configuration0 */ 48e35377d7SHans de Goede u32 nand0_clk_cfg1; /* 0x404 nand1 clock configuration */ 49297bb9e0SPhilipp Tomsich u8 reserved7[0x08]; /* 0x408 */ 50e35377d7SHans de Goede u32 sd0_clk_cfg; /* 0x410 sd0 clock configuration */ 51e35377d7SHans de Goede u32 sd1_clk_cfg; /* 0x414 sd1 clock configuration */ 52e35377d7SHans de Goede u32 sd2_clk_cfg; /* 0x418 sd2 clock configuration */ 53e35377d7SHans de Goede u32 sd3_clk_cfg; /* 0x41c sd3 clock configuration */ 54297bb9e0SPhilipp Tomsich u8 reserved8[0x08]; /* 0x420 */ 55e35377d7SHans de Goede u32 ts_clk_cfg; /* 0x428 transport stream clock cfg */ 56e35377d7SHans de Goede u32 ss_clk_cfg; /* 0x42c security system clock cfg */ 57e35377d7SHans de Goede u32 spi0_clk_cfg; /* 0x430 spi0 clock configuration */ 58e35377d7SHans de Goede u32 spi1_clk_cfg; /* 0x434 spi1 clock configuration */ 59e35377d7SHans de Goede u32 spi2_clk_cfg; /* 0x438 spi2 clock configuration */ 60e35377d7SHans de Goede u32 spi3_clk_cfg; /* 0x43c spi3 clock configuration */ 61297bb9e0SPhilipp Tomsich u8 reserved9[0x44]; /* 0x440 */ 62297bb9e0SPhilipp Tomsich u32 dram_clk_cfg; /* 0x484 DRAM (controller) clock config */ 63297bb9e0SPhilipp Tomsich u8 reserved10[0x8]; /* 0x488 */ 64e35377d7SHans de Goede u32 de_clk_cfg; /* 0x490 display engine clock configuration */ 65297bb9e0SPhilipp Tomsich u8 reserved11[0x04]; /* 0x494 */ 66e35377d7SHans de Goede u32 mp_clk_cfg; /* 0x498 mp clock configuration */ 67e35377d7SHans de Goede u32 lcd0_clk_cfg; /* 0x49c LCD0 module clock */ 68e35377d7SHans de Goede u32 lcd1_clk_cfg; /* 0x4a0 LCD1 module clock */ 69297bb9e0SPhilipp Tomsich u8 reserved12[0x1c]; /* 0x4a4 */ 70e35377d7SHans de Goede u32 csi_isp_clk_cfg; /* 0x4c0 CSI ISP module clock */ 71e35377d7SHans de Goede u32 csi0_clk_cfg; /* 0x4c4 CSI0 module clock */ 72e35377d7SHans de Goede u32 csi1_clk_cfg; /* 0x4c8 CSI1 module clock */ 73e35377d7SHans de Goede u32 fd_clk_cfg; /* 0x4cc FD module clock */ 74e35377d7SHans de Goede u32 ve_clk_cfg; /* 0x4d0 VE module clock */ 75e35377d7SHans de Goede u32 avs_clk_cfg; /* 0x4d4 AVS module clock */ 76297bb9e0SPhilipp Tomsich u8 reserved13[0x18]; /* 0x4d8 */ 77e35377d7SHans de Goede u32 gpu_core_clk_cfg; /* 0x4f0 GPU core clock config */ 78e35377d7SHans de Goede u32 gpu_mem_clk_cfg; /* 0x4f4 GPU memory clock config */ 79e35377d7SHans de Goede u32 gpu_axi_clk_cfg; /* 0x4f8 GPU AXI clock config */ 80297bb9e0SPhilipp Tomsich u8 reserved14[0x10]; /* 0x4fc */ 81e35377d7SHans de Goede u32 gp_adc_clk_cfg; /* 0x50c General Purpose ADC clk config */ 82297bb9e0SPhilipp Tomsich u8 reserved15[0x70]; /* 0x510 */ 83e35377d7SHans de Goede 84e35377d7SHans de Goede u32 ahb_gate0; /* 0x580 AHB0 Gating Register */ 85e35377d7SHans de Goede u32 ahb_gate1; /* 0x584 AHB1 Gating Register */ 86e35377d7SHans de Goede u32 ahb_gate2; /* 0x588 AHB2 Gating Register */ 87297bb9e0SPhilipp Tomsich u8 reserved16[0x04]; /* 0x58c */ 88e35377d7SHans de Goede u32 apb0_gate; /* 0x590 APB0 Clock Gating Register */ 89e35377d7SHans de Goede u32 apb1_gate; /* 0x594 APB1 Clock Gating Register */ 90297bb9e0SPhilipp Tomsich u8 reserved17[0x08]; /* 0x598 */ 91e35377d7SHans de Goede u32 ahb_reset0_cfg; /* 0x5a0 AHB0 Software Reset Register */ 92e35377d7SHans de Goede u32 ahb_reset1_cfg; /* 0x5a4 AHB1 Software Reset Register */ 93e35377d7SHans de Goede u32 ahb_reset2_cfg; /* 0x5a8 AHB2 Software Reset Register */ 94297bb9e0SPhilipp Tomsich u8 reserved18[0x04]; /* 0x5ac */ 95e35377d7SHans de Goede u32 apb0_reset_cfg; /* 0x5b0 Bus Software Reset Register 3 */ 96e35377d7SHans de Goede u32 apb1_reset_cfg; /* 0x5b4 Bus Software Reset Register 4 */ 97e35377d7SHans de Goede }; 98e35377d7SHans de Goede 99e35377d7SHans de Goede #define CCM_PLL4_CTRL_N_SHIFT 8 100e35377d7SHans de Goede #define CCM_PLL4_CTRL_N_MASK (0xff << CCM_PLL4_CTRL_N_SHIFT) 101e35377d7SHans de Goede #define CCM_PLL4_CTRL_P_SHIFT 16 102e35377d7SHans de Goede #define CCM_PLL4_CTRL_P_MASK (0x1 << CCM_PLL4_CTRL_P_SHIFT) 103e35377d7SHans de Goede #define CCM_PLL4_CTRL_M_SHIFT 18 104e35377d7SHans de Goede #define CCM_PLL4_CTRL_M_MASK (0x1 << CCM_PLL4_CTRL_M_SHIFT) 105e35377d7SHans de Goede 106*7962a8d5SPhilipp Tomsich /* pllx_cfg bits */ 107*7962a8d5SPhilipp Tomsich #define CCM_PLL1_CTRL_N(n) (((n) & 0xff) << 8) 108*7962a8d5SPhilipp Tomsich #define CCM_PLL1_CTRL_P(n) (((n) & 0x1) << 16) 109*7962a8d5SPhilipp Tomsich #define CCM_PLL1_CTRL_EN (1 << 31) 110*7962a8d5SPhilipp Tomsich #define CCM_PLL1_CLOCK_TIME_2 (2 << 24) 111*7962a8d5SPhilipp Tomsich 112*7962a8d5SPhilipp Tomsich #define CCM_PLL2_CTRL_N(n) (((n) & 0xff) << 8) 113*7962a8d5SPhilipp Tomsich #define CCM_PLL2_CTRL_P(n) (((n) & 0x1) << 16) 114*7962a8d5SPhilipp Tomsich #define CCM_PLL2_CTRL_EN (1 << 31) 115*7962a8d5SPhilipp Tomsich #define CCM_PLL2_CLOCK_TIME_2 (2 << 24) 116*7962a8d5SPhilipp Tomsich 117*7962a8d5SPhilipp Tomsich #define CCM_PLL4_CTRL_N(n) (((n) & 0xff) << 8) 118*7962a8d5SPhilipp Tomsich #define CCM_PLL4_CTRL_EN (1 << 31) 119*7962a8d5SPhilipp Tomsich 120*7962a8d5SPhilipp Tomsich #define CCM_PLL6_CTRL_N(n) (((n) & 0xff) << 8) 121*7962a8d5SPhilipp Tomsich #define CCM_PLL6_CTRL_P(p) (((p) & 0x1) << 16) 122*7962a8d5SPhilipp Tomsich #define CCM_PLL6_CTRL_EN (1 << 31) 123*7962a8d5SPhilipp Tomsich #define CCM_PLL6_CFG_UPDATE (1 << 30) 124*7962a8d5SPhilipp Tomsich 125*7962a8d5SPhilipp Tomsich #define CCM_PLL12_CTRL_N(n) (((n) & 0xff) << 8) 126*7962a8d5SPhilipp Tomsich #define CCM_PLL12_CTRL_EN (1 << 31) 127*7962a8d5SPhilipp Tomsich 128*7962a8d5SPhilipp Tomsich #define PLL_C0CPUX_STATUS (1 << 0) 129*7962a8d5SPhilipp Tomsich #define PLL_C1CPUX_STATUS (1 << 1) 130*7962a8d5SPhilipp Tomsich #define PLL_DDR_STATUS (1 << 5) 131*7962a8d5SPhilipp Tomsich #define PLL_PERIPH1_STATUS (1 << 11) 132*7962a8d5SPhilipp Tomsich 133*7962a8d5SPhilipp Tomsich /* cpu_clk_source bits */ 134*7962a8d5SPhilipp Tomsich #define C0_CPUX_CLK_SRC_SHIFT 0 135*7962a8d5SPhilipp Tomsich #define C1_CPUX_CLK_SRC_SHIFT 8 136*7962a8d5SPhilipp Tomsich #define C0_CPUX_CLK_SRC_MASK (1 << C0_CPUX_CLK_SRC_SHIFT) 137*7962a8d5SPhilipp Tomsich #define C1_CPUX_CLK_SRC_MASK (1 << C1_CPUX_CLK_SRC_SHIFT) 138*7962a8d5SPhilipp Tomsich #define C0_CPUX_CLK_SRC_OSC24M (0 << C0_CPUX_CLK_SRC_SHIFT) 139*7962a8d5SPhilipp Tomsich #define C0_CPUX_CLK_SRC_PLL1 (1 << C0_CPUX_CLK_SRC_SHIFT) 140*7962a8d5SPhilipp Tomsich #define C1_CPUX_CLK_SRC_OSC24M (0 << C1_CPUX_CLK_SRC_SHIFT) 141*7962a8d5SPhilipp Tomsich #define C1_CPUX_CLK_SRC_PLL2 (1 << C1_CPUX_CLK_SRC_SHIFT) 142*7962a8d5SPhilipp Tomsich 143*7962a8d5SPhilipp Tomsich /* c0_cfg */ 144*7962a8d5SPhilipp Tomsich #define C0_CFG_AXI0_CLK_DIV_RATIO(n) (((n - 1) & 0x3) << 0) 145*7962a8d5SPhilipp Tomsich #define C0_CFG_APB0_CLK_DIV_RATIO(n) (((n - 1) & 0x3) << 8) 146*7962a8d5SPhilipp Tomsich 147*7962a8d5SPhilipp Tomsich /* ahbx_cfg */ 148*7962a8d5SPhilipp Tomsich #define AHBx_SRC_CLK_SELECT_SHIFT 24 149*7962a8d5SPhilipp Tomsich #define AHBx_SRC_MASK (0x3 << AHBx_SRC_CLK_SELECT_SHIFT) 150*7962a8d5SPhilipp Tomsich #define AHB0_SRC_GTBUS_CLK (0x0 << AHBx_SRC_CLK_SELECT_SHIFT) 151*7962a8d5SPhilipp Tomsich #define AHB1_SRC_GTBUS_CLK (0x0 << AHBx_SRC_CLK_SELECT_SHIFT) 152*7962a8d5SPhilipp Tomsich #define AHB2_SRC_OSC24M (0x0 << AHBx_SRC_CLK_SELECT_SHIFT) 153*7962a8d5SPhilipp Tomsich #define AHBx_SRC_PLL_PERIPH0 (0x1 << AHBx_SRC_CLK_SELECT_SHIFT) 154*7962a8d5SPhilipp Tomsich #define AHBx_SRC_PLL_PERIPH1 (0x2 << AHBx_SRC_CLK_SELECT_SHIFT) 155*7962a8d5SPhilipp Tomsich #define AHBx_CLK_DIV_RATIO(n) (((ffs(n) - 1) & 0x3) << 0) 156*7962a8d5SPhilipp Tomsich 157*7962a8d5SPhilipp Tomsich /* apb0_cfg */ 158*7962a8d5SPhilipp Tomsich #define APB0_SRC_CLK_SELECT_SHIFT 24 159*7962a8d5SPhilipp Tomsich #define APB0_SRC_MASK (0x1 << APB0_SRC_CLK_SELECT_SHIFT) 160*7962a8d5SPhilipp Tomsich #define APB0_SRC_OSC24M (0x0 << APB0_SRC_CLK_SELECT_SHIFT) 161*7962a8d5SPhilipp Tomsich #define APB0_SRC_PLL_PERIPH0 (0x1 << APB0_SRC_CLK_SELECT_SHIFT) 162*7962a8d5SPhilipp Tomsich #define APB0_CLK_DIV_RATIO(n) (((ffs(n) - 1) & 0x3) << 0) 163*7962a8d5SPhilipp Tomsich 164*7962a8d5SPhilipp Tomsich /* gtbus_clk_cfg */ 165*7962a8d5SPhilipp Tomsich #define GTBUS_SRC_CLK_SELECT_SHIFT 24 166*7962a8d5SPhilipp Tomsich #define GTBUS_SRC_MASK (0x3 << GTBUS_SRC_CLK_SELECT_SHIFT) 167*7962a8d5SPhilipp Tomsich #define GTBUS_SRC_OSC24M (0x0 << GTBUS_SRC_CLK_SELECT_SHIFT) 168*7962a8d5SPhilipp Tomsich #define GTBUS_SRC_PLL_PERIPH0 (0x1 << GTBUS_SRC_CLK_SELECT_SHIFT) 169*7962a8d5SPhilipp Tomsich #define GTBUS_SRC_PLL_PERIPH1 (0x2 << GTBUS_SRC_CLK_SELECT_SHIFT) 170*7962a8d5SPhilipp Tomsich #define GTBUS_CLK_DIV_RATIO(n) (((n - 1) & 0x3) << 0) 171*7962a8d5SPhilipp Tomsich 172*7962a8d5SPhilipp Tomsich /* cci400_clk_cfg */ 173*7962a8d5SPhilipp Tomsich #define CCI400_SRC_CLK_SELECT_SHIFT 24 174*7962a8d5SPhilipp Tomsich #define CCI400_SRC_MASK (0x3 << CCI400_SRC_CLK_SELECT_SHIFT) 175*7962a8d5SPhilipp Tomsich #define CCI400_SRC_OSC24M (0x0 << CCI400_SRC_CLK_SELECT_SHIFT) 176*7962a8d5SPhilipp Tomsich #define CCI400_SRC_PLL_PERIPH0 (0x1 << CCI400_SRC_CLK_SELECT_SHIFT) 177*7962a8d5SPhilipp Tomsich #define CCI400_SRC_PLL_PERIPH1 (0x2 << CCI400_SRC_CLK_SELECT_SHIFT) 178*7962a8d5SPhilipp Tomsich #define CCI400_CLK_DIV_RATIO(n) (((n - 1) & 0x3) << 0) 179*7962a8d5SPhilipp Tomsich 180e35377d7SHans de Goede /* sd#_clk_cfg fields */ 181e35377d7SHans de Goede #define CCM_MMC_CTRL_M(x) ((x) - 1) 182e35377d7SHans de Goede #define CCM_MMC_CTRL_OCLK_DLY(x) ((x) << 8) 183e35377d7SHans de Goede #define CCM_MMC_CTRL_N(x) ((x) << 16) 184e35377d7SHans de Goede #define CCM_MMC_CTRL_SCLK_DLY(x) ((x) << 20) 185e35377d7SHans de Goede #define CCM_MMC_CTRL_OSCM24 (0 << 24) 186e35377d7SHans de Goede #define CCM_MMC_CTRL_PLL_PERIPH0 (1 << 24) 187e35377d7SHans de Goede #define CCM_MMC_CTRL_ENABLE (1 << 31) 188e35377d7SHans de Goede 189e35377d7SHans de Goede /* ahb_gate0 fields */ 190297bb9e0SPhilipp Tomsich #define AHB_GATE_OFFSET_MCTL 14 191297bb9e0SPhilipp Tomsich 192e35377d7SHans de Goede /* On sun9i all sdc-s share their ahb gate, so ignore (x) */ 193d0f42003SRoy Spliet #define AHB_GATE_OFFSET_NAND0 13 194e35377d7SHans de Goede #define AHB_GATE_OFFSET_MMC(x) 8 195e35377d7SHans de Goede 196d0f42003SRoy Spliet /* ahb gate1 field */ 197d0f42003SRoy Spliet #define AHB_GATE_OFFSET_DMA 24 198d0f42003SRoy Spliet 199e35377d7SHans de Goede /* apb1_gate fields */ 200e35377d7SHans de Goede #define APB1_GATE_UART_SHIFT 16 201e35377d7SHans de Goede #define APB1_GATE_UART_MASK (0xff << APB1_GATE_UART_SHIFT) 202e35377d7SHans de Goede #define APB1_GATE_TWI_SHIFT 0 203e35377d7SHans de Goede #define APB1_GATE_TWI_MASK (0xf << APB1_GATE_TWI_SHIFT) 204e35377d7SHans de Goede 205e35377d7SHans de Goede /* ahb_reset0_cfg fields */ 206297bb9e0SPhilipp Tomsich #define AHB_RESET_OFFSET_MCTL 14 207297bb9e0SPhilipp Tomsich 208e35377d7SHans de Goede /* On sun9i all sdc-s share their ahb reset, so ignore (x) */ 209e35377d7SHans de Goede #define AHB_RESET_OFFSET_MMC(x) 8 210e35377d7SHans de Goede 211e35377d7SHans de Goede /* apb1_reset_cfg fields */ 212e35377d7SHans de Goede #define APB1_RESET_UART_SHIFT 16 213e35377d7SHans de Goede #define APB1_RESET_UART_MASK (0xff << APB1_RESET_UART_SHIFT) 214e35377d7SHans de Goede #define APB1_RESET_TWI_SHIFT 0 215e35377d7SHans de Goede #define APB1_RESET_TWI_MASK (0xf << APB1_RESET_TWI_SHIFT) 216e35377d7SHans de Goede 217e35377d7SHans de Goede 218e35377d7SHans de Goede #ifndef __ASSEMBLY__ 219*7962a8d5SPhilipp Tomsich void clock_set_pll1(unsigned int clk); 220*7962a8d5SPhilipp Tomsich void clock_set_pll2(unsigned int clk); 221*7962a8d5SPhilipp Tomsich void clock_set_pll4(unsigned int clk); 222*7962a8d5SPhilipp Tomsich void clock_set_pll6(unsigned int clk); 223*7962a8d5SPhilipp Tomsich void clock_set_pll12(unsigned int clk); 224e35377d7SHans de Goede unsigned int clock_get_pll4_periph0(void); 225e35377d7SHans de Goede #endif 226e35377d7SHans de Goede 227e35377d7SHans de Goede #endif /* _SUNXI_CLOCK_SUN9I_H */ 228