/* * Copyright 2013 Freescale Semiconductor, Inc. * * SPDX-License-Identifier: GPL-2.0+ */ #ifndef __ARCH_ARM_MACH_VF610_CCM_REGS_H__ #define __ARCH_ARM_MACH_VF610_CCM_REGS_H__ #ifndef __ASSEMBLY__ /* Clock Controller Module (CCM) */ struct ccm_reg { u32 ccr; u32 csr; u32 ccsr; u32 cacrr; u32 cscmr1; u32 cscdr1; u32 cscdr2; u32 cscdr3; u32 cscmr2; u32 cscdr4; u32 ctor; u32 clpcr; u32 cisr; u32 cimr; u32 ccosr; u32 cgpr; u32 ccgr0; u32 ccgr1; u32 ccgr2; u32 ccgr3; u32 ccgr4; u32 ccgr5; u32 ccgr6; u32 ccgr7; u32 ccgr8; u32 ccgr9; u32 ccgr10; u32 ccgr11; u32 cmeor0; u32 cmeor1; u32 cmeor2; u32 cmeor3; u32 cmeor4; u32 cmeor5; u32 cppdsr; u32 ccowr; u32 ccpgr0; u32 ccpgr1; u32 ccpgr2; u32 ccpgr3; }; /* Analog components control digital interface (ANADIG) */ struct anadig_reg { u32 pll3_ctrl; u32 resv0[3]; u32 pll7_ctrl; u32 resv1[3]; u32 pll2_ctrl; u32 resv2[3]; u32 pll2_ss; u32 resv3[3]; u32 pll2_num; u32 resv4[3]; u32 pll2_denom; u32 resv5[3]; u32 pll4_ctrl; u32 resv6[3]; u32 pll4_num; u32 resv7[3]; u32 pll4_denom; u32 pll6_ctrl; u32 resv8[3]; u32 pll6_num; u32 resv9[3]; u32 pll6_denom; u32 resv10[3]; u32 pll5_ctrl; u32 resv11[3]; u32 pll3_pfd; u32 resv12[3]; u32 pll2_pfd; u32 resv13[3]; u32 reg_1p1; u32 resv14[3]; u32 reg_3p0; u32 resv15[3]; u32 reg_2p5; u32 resv16[7]; u32 ana_misc0; u32 resv17[3]; u32 ana_misc1; u32 resv18[63]; u32 anadig_digprog; u32 resv19[3]; u32 pll1_ctrl; u32 resv20[3]; u32 pll1_ss; u32 resv21[3]; u32 pll1_num; u32 resv22[3]; u32 pll1_denom; u32 resv23[3]; u32 pll1_pdf; u32 resv24[3]; u32 pll_lock; }; #endif #define CCM_CCR_FIRC_EN (1 << 16) #define CCM_CCR_OSCNT_MASK 0xff #define CCM_CCR_OSCNT(v) ((v) & 0xff) #define CCM_CCSR_PLL2_PFD_CLK_SEL_OFFSET 19 #define CCM_CCSR_PLL2_PFD_CLK_SEL_MASK (0x7 << 19) #define CCM_CCSR_PLL2_PFD_CLK_SEL(v) (((v) & 0x7) << 19) #define CCM_CCSR_PLL1_PFD_CLK_SEL_OFFSET 16 #define CCM_CCSR_PLL1_PFD_CLK_SEL_MASK (0x7 << 16) #define CCM_CCSR_PLL1_PFD_CLK_SEL(v) (((v) & 0x7) << 16) #define CCM_CCSR_PLL2_PFD4_EN (1 << 15) #define CCM_CCSR_PLL2_PFD3_EN (1 << 14) #define CCM_CCSR_PLL2_PFD2_EN (1 << 13) #define CCM_CCSR_PLL2_PFD1_EN (1 << 12) #define CCM_CCSR_PLL1_PFD4_EN (1 << 11) #define CCM_CCSR_PLL1_PFD3_EN (1 << 10) #define CCM_CCSR_PLL1_PFD2_EN (1 << 9) #define CCM_CCSR_PLL1_PFD1_EN (1 << 8) #define CCM_CCSR_DDRC_CLK_SEL(v) ((v) << 6) #define CCM_CCSR_FAST_CLK_SEL(v) ((v) << 5) #define CCM_CCSR_SYS_CLK_SEL_OFFSET 0 #define CCM_CCSR_SYS_CLK_SEL_MASK 0x7 #define CCM_CCSR_SYS_CLK_SEL(v) ((v) & 0x7) #define CCM_CACRR_IPG_CLK_DIV_OFFSET 11 #define CCM_CACRR_IPG_CLK_DIV_MASK (0x3 << 11) #define CCM_CACRR_IPG_CLK_DIV(v) (((v) & 0x3) << 11) #define CCM_CACRR_BUS_CLK_DIV_OFFSET 3 #define CCM_CACRR_BUS_CLK_DIV_MASK (0x7 << 3) #define CCM_CACRR_BUS_CLK_DIV(v) (((v) & 0x7) << 3) #define CCM_CACRR_ARM_CLK_DIV_OFFSET 0 #define CCM_CACRR_ARM_CLK_DIV_MASK 0x7 #define CCM_CACRR_ARM_CLK_DIV(v) ((v) & 0x7) #define CCM_CSCMR1_ESDHC1_CLK_SEL_OFFSET 18 #define CCM_CSCMR1_ESDHC1_CLK_SEL_MASK (0x3 << 18) #define CCM_CSCMR1_ESDHC1_CLK_SEL(v) (((v) & 0x3) << 18) #define CCM_CSCDR1_RMII_CLK_EN (1 << 24) #define CCM_CSCDR2_ESDHC1_EN (1 << 29) #define CCM_CSCDR2_ESDHC1_CLK_DIV_OFFSET 20 #define CCM_CSCDR2_ESDHC1_CLK_DIV_MASK (0xf << 20) #define CCM_CSCDR2_ESDHC1_CLK_DIV(v) (((v) & 0xf) << 20) #define CCM_CSCMR2_RMII_CLK_SEL_OFFSET 4 #define CCM_CSCMR2_RMII_CLK_SEL_MASK (0x3 << 4) #define CCM_CSCMR2_RMII_CLK_SEL(v) (((v) & 0x3) << 4) #define CCM_REG_CTRL_MASK 0xffffffff #define CCM_CCGR0_UART1_CTRL_MASK (0x3 << 16) #define CCM_CCGR1_PIT_CTRL_MASK (0x3 << 14) #define CCM_CCGR1_WDOGA5_CTRL_MASK (0x3 << 28) #define CCM_CCGR2_IOMUXC_CTRL_MASK (0x3 << 16) #define CCM_CCGR2_PORTA_CTRL_MASK (0x3 << 18) #define CCM_CCGR2_PORTB_CTRL_MASK (0x3 << 20) #define CCM_CCGR2_PORTC_CTRL_MASK (0x3 << 22) #define CCM_CCGR2_PORTD_CTRL_MASK (0x3 << 24) #define CCM_CCGR2_PORTE_CTRL_MASK (0x3 << 26) #define CCM_CCGR3_ANADIG_CTRL_MASK 0x3 #define CCM_CCGR4_WKUP_CTRL_MASK (0x3 << 20) #define CCM_CCGR4_CCM_CTRL_MASK (0x3 << 22) #define CCM_CCGR4_GPC_CTRL_MASK (0x3 << 24) #define CCM_CCGR6_OCOTP_CTRL_MASK (0x3 << 10) #define CCM_CCGR6_DDRMC_CTRL_MASK (0x3 << 28) #define CCM_CCGR7_SDHC1_CTRL_MASK (0x3 << 4) #define CCM_CCGR9_FEC0_CTRL_MASK 0x3 #define CCM_CCGR9_FEC1_CTRL_MASK (0x3 << 2) #define ANADIG_PLL2_CTRL_ENABLE (1 << 13) #define ANADIG_PLL2_CTRL_POWERDOWN (1 << 12) #define ANADIG_PLL2_CTRL_DIV_SELECT 1 #define ANADIG_PLL1_CTRL_ENABLE (1 << 13) #define ANADIG_PLL1_CTRL_POWERDOWN (1 << 12) #define ANADIG_PLL1_CTRL_DIV_SELECT 1 #define FASE_CLK_FREQ 24000000 #define SLOW_CLK_FREQ 32000 #define PLL1_PFD1_FREQ 500000000 #define PLL1_PFD2_FREQ 452000000 #define PLL1_PFD3_FREQ 396000000 #define PLL1_PFD4_FREQ 528000000 #define PLL1_MAIN_FREQ 528000000 #define PLL2_PFD1_FREQ 500000000 #define PLL2_PFD2_FREQ 396000000 #define PLL2_PFD3_FREQ 339000000 #define PLL2_PFD4_FREQ 413000000 #define PLL2_MAIN_FREQ 528000000 #define PLL3_MAIN_FREQ 480000000 #define PLL3_PFD3_FREQ 298000000 #define PLL5_MAIN_FREQ 500000000 #define ENET_EXTERNAL_CLK 50000000 #define AUDIO_EXTERNAL_CLK 24576000 #endif /*__ARCH_ARM_MACH_VF610_CCM_REGS_H__ */