xref: /rk3399_rockchip-uboot/include/faraday/ftpmu010.h (revision d6150db2dcb509835df6a01eb5c61e4154f9dc66)
1*d6150db2SPo-Yu Chuang /*
2*d6150db2SPo-Yu Chuang  * (C) Copyright 2009 Faraday Technology
3*d6150db2SPo-Yu Chuang  * Po-Yu Chuang <ratbert@faraday-tech.com>
4*d6150db2SPo-Yu Chuang  *
5*d6150db2SPo-Yu Chuang  * This program is free software; you can redistribute it and/or modify
6*d6150db2SPo-Yu Chuang  * it under the terms of the GNU General Public License as published by
7*d6150db2SPo-Yu Chuang  * the Free Software Foundation; either version 2 of the License, or
8*d6150db2SPo-Yu Chuang  * (at your option) any later version.
9*d6150db2SPo-Yu Chuang  *
10*d6150db2SPo-Yu Chuang  * This program is distributed in the hope that it will be useful,
11*d6150db2SPo-Yu Chuang  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12*d6150db2SPo-Yu Chuang  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13*d6150db2SPo-Yu Chuang  * GNU General Public License for more details.
14*d6150db2SPo-Yu Chuang  *
15*d6150db2SPo-Yu Chuang  * You should have received a copy of the GNU General Public License
16*d6150db2SPo-Yu Chuang  * along with this program; if not, write to the Free Software
17*d6150db2SPo-Yu Chuang  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
18*d6150db2SPo-Yu Chuang  */
19*d6150db2SPo-Yu Chuang 
20*d6150db2SPo-Yu Chuang /*
21*d6150db2SPo-Yu Chuang  * Power Management Unit
22*d6150db2SPo-Yu Chuang  */
23*d6150db2SPo-Yu Chuang #ifndef __FTPMU010_H
24*d6150db2SPo-Yu Chuang #define __FTPMU010_H
25*d6150db2SPo-Yu Chuang 
26*d6150db2SPo-Yu Chuang struct ftpmu010 {
27*d6150db2SPo-Yu Chuang 	unsigned int	IDNMBR0;	/* 0x00 */
28*d6150db2SPo-Yu Chuang 	unsigned int	reserved0;	/* 0x04 */
29*d6150db2SPo-Yu Chuang 	unsigned int	OSCC;		/* 0x08 */
30*d6150db2SPo-Yu Chuang 	unsigned int	PMODE;		/* 0x0C */
31*d6150db2SPo-Yu Chuang 	unsigned int	PMCR;		/* 0x10 */
32*d6150db2SPo-Yu Chuang 	unsigned int	PED;		/* 0x14 */
33*d6150db2SPo-Yu Chuang 	unsigned int	PEDSR;		/* 0x18 */
34*d6150db2SPo-Yu Chuang 	unsigned int	reserved1;	/* 0x1C */
35*d6150db2SPo-Yu Chuang 	unsigned int	PMSR;		/* 0x20 */
36*d6150db2SPo-Yu Chuang 	unsigned int	PGSR;		/* 0x24 */
37*d6150db2SPo-Yu Chuang 	unsigned int	MFPSR;		/* 0x28 */
38*d6150db2SPo-Yu Chuang 	unsigned int	MISC;		/* 0x2C */
39*d6150db2SPo-Yu Chuang 	unsigned int	PDLLCR0;	/* 0x30 */
40*d6150db2SPo-Yu Chuang 	unsigned int	PDLLCR1;	/* 0x34 */
41*d6150db2SPo-Yu Chuang 	unsigned int	AHBMCLKOFF;	/* 0x38 */
42*d6150db2SPo-Yu Chuang 	unsigned int	APBMCLKOFF;	/* 0x3C */
43*d6150db2SPo-Yu Chuang 	unsigned int	DCSRCR0;	/* 0x40 */
44*d6150db2SPo-Yu Chuang 	unsigned int	DCSRCR1;	/* 0x44 */
45*d6150db2SPo-Yu Chuang 	unsigned int	DCSRCR2;	/* 0x48 */
46*d6150db2SPo-Yu Chuang 	unsigned int	SDRAMHTC;	/* 0x4C */
47*d6150db2SPo-Yu Chuang 	unsigned int	PSPR0;		/* 0x50 */
48*d6150db2SPo-Yu Chuang 	unsigned int	PSPR1;		/* 0x54 */
49*d6150db2SPo-Yu Chuang 	unsigned int	PSPR2;		/* 0x58 */
50*d6150db2SPo-Yu Chuang 	unsigned int	PSPR3;		/* 0x5C */
51*d6150db2SPo-Yu Chuang 	unsigned int	PSPR4;		/* 0x60 */
52*d6150db2SPo-Yu Chuang 	unsigned int	PSPR5;		/* 0x64 */
53*d6150db2SPo-Yu Chuang 	unsigned int	PSPR6;		/* 0x68 */
54*d6150db2SPo-Yu Chuang 	unsigned int	PSPR7;		/* 0x6C */
55*d6150db2SPo-Yu Chuang 	unsigned int	PSPR8;		/* 0x70 */
56*d6150db2SPo-Yu Chuang 	unsigned int	PSPR9;		/* 0x74 */
57*d6150db2SPo-Yu Chuang 	unsigned int	PSPR10;		/* 0x78 */
58*d6150db2SPo-Yu Chuang 	unsigned int	PSPR11;		/* 0x7C */
59*d6150db2SPo-Yu Chuang 	unsigned int	PSPR12;		/* 0x80 */
60*d6150db2SPo-Yu Chuang 	unsigned int	PSPR13;		/* 0x84 */
61*d6150db2SPo-Yu Chuang 	unsigned int	PSPR14;		/* 0x88 */
62*d6150db2SPo-Yu Chuang 	unsigned int	PSPR15;		/* 0x8C */
63*d6150db2SPo-Yu Chuang 	unsigned int	AHBDMA_RACCS;	/* 0x90 */
64*d6150db2SPo-Yu Chuang 	unsigned int	reserved2;	/* 0x94 */
65*d6150db2SPo-Yu Chuang 	unsigned int	reserved3;	/* 0x98 */
66*d6150db2SPo-Yu Chuang 	unsigned int	JSS;		/* 0x9C */
67*d6150db2SPo-Yu Chuang 	unsigned int	CFC_RACC;	/* 0xA0 */
68*d6150db2SPo-Yu Chuang 	unsigned int	SSP1_RACC;	/* 0xA4 */
69*d6150db2SPo-Yu Chuang 	unsigned int	UART1TX_RACC;	/* 0xA8 */
70*d6150db2SPo-Yu Chuang 	unsigned int	UART1RX_RACC;	/* 0xAC */
71*d6150db2SPo-Yu Chuang 	unsigned int	UART2TX_RACC;	/* 0xB0 */
72*d6150db2SPo-Yu Chuang 	unsigned int	UART2RX_RACC;	/* 0xB4 */
73*d6150db2SPo-Yu Chuang 	unsigned int	SDC_RACC;	/* 0xB8 */
74*d6150db2SPo-Yu Chuang 	unsigned int	I2SAC97_RACC;	/* 0xBC */
75*d6150db2SPo-Yu Chuang 	unsigned int	IRDATX_RACC;	/* 0xC0 */
76*d6150db2SPo-Yu Chuang 	unsigned int	reserved4;	/* 0xC4 */
77*d6150db2SPo-Yu Chuang 	unsigned int	USBD_RACC;	/* 0xC8 */
78*d6150db2SPo-Yu Chuang 	unsigned int	IRDARX_RACC;	/* 0xCC */
79*d6150db2SPo-Yu Chuang 	unsigned int	IRDA_RACC;	/* 0xD0 */
80*d6150db2SPo-Yu Chuang 	unsigned int	ED0_RACC;	/* 0xD4 */
81*d6150db2SPo-Yu Chuang 	unsigned int	ED1_RACC;	/* 0xD8 */
82*d6150db2SPo-Yu Chuang };
83*d6150db2SPo-Yu Chuang 
84*d6150db2SPo-Yu Chuang /*
85*d6150db2SPo-Yu Chuang  * ID Number 0 Register
86*d6150db2SPo-Yu Chuang  */
87*d6150db2SPo-Yu Chuang #define FTPMU010_ID_A320A	0x03200000
88*d6150db2SPo-Yu Chuang #define FTPMU010_ID_A320C	0x03200010
89*d6150db2SPo-Yu Chuang #define FTPMU010_ID_A320D	0x03200030
90*d6150db2SPo-Yu Chuang 
91*d6150db2SPo-Yu Chuang /*
92*d6150db2SPo-Yu Chuang  * OSC Control Register
93*d6150db2SPo-Yu Chuang  */
94*d6150db2SPo-Yu Chuang #define FTPMU010_OSCC_OSCH_TRI		(1 << 11)
95*d6150db2SPo-Yu Chuang #define FTPMU010_OSCC_OSCH_STABLE	(1 << 9)
96*d6150db2SPo-Yu Chuang #define FTPMU010_OSCC_OSCH_OFF		(1 << 8)
97*d6150db2SPo-Yu Chuang 
98*d6150db2SPo-Yu Chuang #define FTPMU010_OSCC_OSCL_TRI		(1 << 3)
99*d6150db2SPo-Yu Chuang #define FTPMU010_OSCC_OSCL_RTCLSEL	(1 << 2)
100*d6150db2SPo-Yu Chuang #define FTPMU010_OSCC_OSCL_STABLE	(1 << 1)
101*d6150db2SPo-Yu Chuang #define FTPMU010_OSCC_OSCL_OFF		(1 << 0)
102*d6150db2SPo-Yu Chuang 
103*d6150db2SPo-Yu Chuang /*
104*d6150db2SPo-Yu Chuang  * Power Mode Register
105*d6150db2SPo-Yu Chuang  */
106*d6150db2SPo-Yu Chuang #define FTPMU010_PMODE_DIVAHBCLK_MASK	(0x7 << 4)
107*d6150db2SPo-Yu Chuang #define FTPMU010_PMODE_DIVAHBCLK_2	(0x0 << 4)
108*d6150db2SPo-Yu Chuang #define FTPMU010_PMODE_DIVAHBCLK_3	(0x1 << 4)
109*d6150db2SPo-Yu Chuang #define FTPMU010_PMODE_DIVAHBCLK_4	(0x2 << 4)
110*d6150db2SPo-Yu Chuang #define FTPMU010_PMODE_DIVAHBCLK_6	(0x3 << 4)
111*d6150db2SPo-Yu Chuang #define FTPMU010_PMODE_DIVAHBCLK_8	(0x4 << 4)
112*d6150db2SPo-Yu Chuang #define FTPMU010_PMODE_DIVAHBCLK(pmode)	(((pmode) >> 4) & 0x7)
113*d6150db2SPo-Yu Chuang #define FTPMU010_PMODE_FCS		(1 << 2)
114*d6150db2SPo-Yu Chuang #define FTPMU010_PMODE_TURBO		(1 << 1)
115*d6150db2SPo-Yu Chuang #define FTPMU010_PMODE_SLEEP		(1 << 0)
116*d6150db2SPo-Yu Chuang 
117*d6150db2SPo-Yu Chuang /*
118*d6150db2SPo-Yu Chuang  * Power Manager Status Register
119*d6150db2SPo-Yu Chuang  */
120*d6150db2SPo-Yu Chuang #define FTPMU010_PMSR_SMR	(1 << 10)
121*d6150db2SPo-Yu Chuang 
122*d6150db2SPo-Yu Chuang #define FTPMU010_PMSR_RDH	(1 << 2)
123*d6150db2SPo-Yu Chuang #define FTPMU010_PMSR_PH	(1 << 1)
124*d6150db2SPo-Yu Chuang #define FTPMU010_PMSR_CKEHLOW	(1 << 0)
125*d6150db2SPo-Yu Chuang 
126*d6150db2SPo-Yu Chuang /*
127*d6150db2SPo-Yu Chuang  * Multi-Function Port Setting Register
128*d6150db2SPo-Yu Chuang  */
129*d6150db2SPo-Yu Chuang #define FTPMU010_MFPSR_MODEMPINSEL	(1 << 14)
130*d6150db2SPo-Yu Chuang #define FTPMU010_MFPSR_AC97CLKOUTSEL	(1 << 13)
131*d6150db2SPo-Yu Chuang #define FTPMU010_MFPSR_AC97PINSEL	(1 << 3)
132*d6150db2SPo-Yu Chuang 
133*d6150db2SPo-Yu Chuang /*
134*d6150db2SPo-Yu Chuang  * PLL/DLL Control Register 0
135*d6150db2SPo-Yu Chuang  */
136*d6150db2SPo-Yu Chuang #define FTPMU010_PDLLCR0_HCLKOUTDIS(cr0)	(((cr0) >> 20) & 0xf)
137*d6150db2SPo-Yu Chuang #define FTPMU010_PDLLCR0_DLLFRAG		(1 << 19)
138*d6150db2SPo-Yu Chuang #define FTPMU010_PDLLCR0_DLLSTSEL		(1 << 18)
139*d6150db2SPo-Yu Chuang #define FTPMU010_PDLLCR0_DLLSTABLE		(1 << 17)
140*d6150db2SPo-Yu Chuang #define FTPMU010_PDLLCR0_DLLDIS			(1 << 16)
141*d6150db2SPo-Yu Chuang #define FTPMU010_PDLLCR0_PLL1NS(cr0)		(((cr0) >> 3) & 0x1ff)
142*d6150db2SPo-Yu Chuang #define FTPMU010_PDLLCR0_PLL1STSEL		(1 << 2)
143*d6150db2SPo-Yu Chuang #define FTPMU010_PDLLCR0_PLL1STABLE		(1 << 1)
144*d6150db2SPo-Yu Chuang #define FTPMU010_PDLLCR0_PLL1DIS		(1 << 0)
145*d6150db2SPo-Yu Chuang 
146*d6150db2SPo-Yu Chuang void ftpmu010_32768osc_enable(void);
147*d6150db2SPo-Yu Chuang void ftpmu010_dlldis_disable(void);
148*d6150db2SPo-Yu Chuang void ftpmu010_sdram_clk_disable(unsigned int cr0);
149*d6150db2SPo-Yu Chuang 
150*d6150db2SPo-Yu Chuang #endif	/* __FTPMU010_H */
151