xref: /rk3399_rockchip-uboot/include/faraday/ftpmu010.h (revision 326ea986ac150acdc7656d57fca647db80b50158)
1d6150db2SPo-Yu Chuang /*
2d6150db2SPo-Yu Chuang  * (C) Copyright 2009 Faraday Technology
3d6150db2SPo-Yu Chuang  * Po-Yu Chuang <ratbert@faraday-tech.com>
4d6150db2SPo-Yu Chuang  *
5*1a459660SWolfgang Denk  * SPDX-License-Identifier:	GPL-2.0+
6d6150db2SPo-Yu Chuang  */
7d6150db2SPo-Yu Chuang 
8d6150db2SPo-Yu Chuang /*
9d6150db2SPo-Yu Chuang  * Power Management Unit
10d6150db2SPo-Yu Chuang  */
11d6150db2SPo-Yu Chuang #ifndef __FTPMU010_H
12d6150db2SPo-Yu Chuang #define __FTPMU010_H
13d6150db2SPo-Yu Chuang 
14d228710fSMacpaul Lin #ifndef __ASSEMBLY__
15d6150db2SPo-Yu Chuang struct ftpmu010 {
16d6150db2SPo-Yu Chuang 	unsigned int	IDNMBR0;	/* 0x00 */
17d6150db2SPo-Yu Chuang 	unsigned int	reserved0;	/* 0x04 */
18d6150db2SPo-Yu Chuang 	unsigned int	OSCC;		/* 0x08 */
19d6150db2SPo-Yu Chuang 	unsigned int	PMODE;		/* 0x0C */
20d6150db2SPo-Yu Chuang 	unsigned int	PMCR;		/* 0x10 */
21d6150db2SPo-Yu Chuang 	unsigned int	PED;		/* 0x14 */
22d6150db2SPo-Yu Chuang 	unsigned int	PEDSR;		/* 0x18 */
23d6150db2SPo-Yu Chuang 	unsigned int	reserved1;	/* 0x1C */
24d6150db2SPo-Yu Chuang 	unsigned int	PMSR;		/* 0x20 */
25d6150db2SPo-Yu Chuang 	unsigned int	PGSR;		/* 0x24 */
26d6150db2SPo-Yu Chuang 	unsigned int	MFPSR;		/* 0x28 */
27d6150db2SPo-Yu Chuang 	unsigned int	MISC;		/* 0x2C */
28d6150db2SPo-Yu Chuang 	unsigned int	PDLLCR0;	/* 0x30 */
29d6150db2SPo-Yu Chuang 	unsigned int	PDLLCR1;	/* 0x34 */
30d6150db2SPo-Yu Chuang 	unsigned int	AHBMCLKOFF;	/* 0x38 */
31d6150db2SPo-Yu Chuang 	unsigned int	APBMCLKOFF;	/* 0x3C */
32d6150db2SPo-Yu Chuang 	unsigned int	DCSRCR0;	/* 0x40 */
33d6150db2SPo-Yu Chuang 	unsigned int	DCSRCR1;	/* 0x44 */
34d6150db2SPo-Yu Chuang 	unsigned int	DCSRCR2;	/* 0x48 */
35d6150db2SPo-Yu Chuang 	unsigned int	SDRAMHTC;	/* 0x4C */
36d6150db2SPo-Yu Chuang 	unsigned int	PSPR0;		/* 0x50 */
37d6150db2SPo-Yu Chuang 	unsigned int	PSPR1;		/* 0x54 */
38d6150db2SPo-Yu Chuang 	unsigned int	PSPR2;		/* 0x58 */
39d6150db2SPo-Yu Chuang 	unsigned int	PSPR3;		/* 0x5C */
40d6150db2SPo-Yu Chuang 	unsigned int	PSPR4;		/* 0x60 */
41d6150db2SPo-Yu Chuang 	unsigned int	PSPR5;		/* 0x64 */
42d6150db2SPo-Yu Chuang 	unsigned int	PSPR6;		/* 0x68 */
43d6150db2SPo-Yu Chuang 	unsigned int	PSPR7;		/* 0x6C */
44d6150db2SPo-Yu Chuang 	unsigned int	PSPR8;		/* 0x70 */
45d6150db2SPo-Yu Chuang 	unsigned int	PSPR9;		/* 0x74 */
46d6150db2SPo-Yu Chuang 	unsigned int	PSPR10;		/* 0x78 */
47d6150db2SPo-Yu Chuang 	unsigned int	PSPR11;		/* 0x7C */
48d6150db2SPo-Yu Chuang 	unsigned int	PSPR12;		/* 0x80 */
49d6150db2SPo-Yu Chuang 	unsigned int	PSPR13;		/* 0x84 */
50d6150db2SPo-Yu Chuang 	unsigned int	PSPR14;		/* 0x88 */
51d6150db2SPo-Yu Chuang 	unsigned int	PSPR15;		/* 0x8C */
52d6150db2SPo-Yu Chuang 	unsigned int	AHBDMA_RACCS;	/* 0x90 */
53d6150db2SPo-Yu Chuang 	unsigned int	reserved2;	/* 0x94 */
54d6150db2SPo-Yu Chuang 	unsigned int	reserved3;	/* 0x98 */
55d6150db2SPo-Yu Chuang 	unsigned int	JSS;		/* 0x9C */
56d6150db2SPo-Yu Chuang 	unsigned int	CFC_RACC;	/* 0xA0 */
57d6150db2SPo-Yu Chuang 	unsigned int	SSP1_RACC;	/* 0xA4 */
58d6150db2SPo-Yu Chuang 	unsigned int	UART1TX_RACC;	/* 0xA8 */
59d6150db2SPo-Yu Chuang 	unsigned int	UART1RX_RACC;	/* 0xAC */
60d6150db2SPo-Yu Chuang 	unsigned int	UART2TX_RACC;	/* 0xB0 */
61d6150db2SPo-Yu Chuang 	unsigned int	UART2RX_RACC;	/* 0xB4 */
62d6150db2SPo-Yu Chuang 	unsigned int	SDC_RACC;	/* 0xB8 */
63d6150db2SPo-Yu Chuang 	unsigned int	I2SAC97_RACC;	/* 0xBC */
64d6150db2SPo-Yu Chuang 	unsigned int	IRDATX_RACC;	/* 0xC0 */
65d6150db2SPo-Yu Chuang 	unsigned int	reserved4;	/* 0xC4 */
66d6150db2SPo-Yu Chuang 	unsigned int	USBD_RACC;	/* 0xC8 */
67d6150db2SPo-Yu Chuang 	unsigned int	IRDARX_RACC;	/* 0xCC */
68d6150db2SPo-Yu Chuang 	unsigned int	IRDA_RACC;	/* 0xD0 */
69d6150db2SPo-Yu Chuang 	unsigned int	ED0_RACC;	/* 0xD4 */
70d6150db2SPo-Yu Chuang 	unsigned int	ED1_RACC;	/* 0xD8 */
71d6150db2SPo-Yu Chuang };
72d228710fSMacpaul Lin #endif /* __ASSEMBLY__ */
73d6150db2SPo-Yu Chuang 
74d6150db2SPo-Yu Chuang /*
75d6150db2SPo-Yu Chuang  * ID Number 0 Register
76d6150db2SPo-Yu Chuang  */
77d6150db2SPo-Yu Chuang #define FTPMU010_ID_A320A	0x03200000
78d6150db2SPo-Yu Chuang #define FTPMU010_ID_A320C	0x03200010
79d6150db2SPo-Yu Chuang #define FTPMU010_ID_A320D	0x03200030
80d6150db2SPo-Yu Chuang 
81d6150db2SPo-Yu Chuang /*
82d6150db2SPo-Yu Chuang  * OSC Control Register
83d6150db2SPo-Yu Chuang  */
84d6150db2SPo-Yu Chuang #define FTPMU010_OSCC_OSCH_TRI		(1 << 11)
85d6150db2SPo-Yu Chuang #define FTPMU010_OSCC_OSCH_STABLE	(1 << 9)
86d6150db2SPo-Yu Chuang #define FTPMU010_OSCC_OSCH_OFF		(1 << 8)
87d6150db2SPo-Yu Chuang 
88d6150db2SPo-Yu Chuang #define FTPMU010_OSCC_OSCL_TRI		(1 << 3)
89d6150db2SPo-Yu Chuang #define FTPMU010_OSCC_OSCL_RTCLSEL	(1 << 2)
90d6150db2SPo-Yu Chuang #define FTPMU010_OSCC_OSCL_STABLE	(1 << 1)
91d6150db2SPo-Yu Chuang #define FTPMU010_OSCC_OSCL_OFF		(1 << 0)
92d6150db2SPo-Yu Chuang 
93d6150db2SPo-Yu Chuang /*
94d6150db2SPo-Yu Chuang  * Power Mode Register
95d6150db2SPo-Yu Chuang  */
96d6150db2SPo-Yu Chuang #define FTPMU010_PMODE_DIVAHBCLK_MASK	(0x7 << 4)
97d6150db2SPo-Yu Chuang #define FTPMU010_PMODE_DIVAHBCLK_2	(0x0 << 4)
98d6150db2SPo-Yu Chuang #define FTPMU010_PMODE_DIVAHBCLK_3	(0x1 << 4)
99d6150db2SPo-Yu Chuang #define FTPMU010_PMODE_DIVAHBCLK_4	(0x2 << 4)
100d6150db2SPo-Yu Chuang #define FTPMU010_PMODE_DIVAHBCLK_6	(0x3 << 4)
101d6150db2SPo-Yu Chuang #define FTPMU010_PMODE_DIVAHBCLK_8	(0x4 << 4)
102d6150db2SPo-Yu Chuang #define FTPMU010_PMODE_DIVAHBCLK(pmode)	(((pmode) >> 4) & 0x7)
103d6150db2SPo-Yu Chuang #define FTPMU010_PMODE_FCS		(1 << 2)
104d6150db2SPo-Yu Chuang #define FTPMU010_PMODE_TURBO		(1 << 1)
105d6150db2SPo-Yu Chuang #define FTPMU010_PMODE_SLEEP		(1 << 0)
106d6150db2SPo-Yu Chuang 
107d6150db2SPo-Yu Chuang /*
108d6150db2SPo-Yu Chuang  * Power Manager Status Register
109d6150db2SPo-Yu Chuang  */
110d6150db2SPo-Yu Chuang #define FTPMU010_PMSR_SMR	(1 << 10)
111d6150db2SPo-Yu Chuang 
112d6150db2SPo-Yu Chuang #define FTPMU010_PMSR_RDH	(1 << 2)
113d6150db2SPo-Yu Chuang #define FTPMU010_PMSR_PH	(1 << 1)
114d6150db2SPo-Yu Chuang #define FTPMU010_PMSR_CKEHLOW	(1 << 0)
115d6150db2SPo-Yu Chuang 
116d6150db2SPo-Yu Chuang /*
117d6150db2SPo-Yu Chuang  * Multi-Function Port Setting Register
118d6150db2SPo-Yu Chuang  */
119caddb8e4SMacpaul Lin #define FTPMU010_MFPSR_DEBUGSEL		(1 << 17)
120caddb8e4SMacpaul Lin #define FTPMU010_MFPSR_DMA0PINSEL	(1 << 16)
121caddb8e4SMacpaul Lin #define FTPMU010_MFPSR_DMA1PINSEL	(1 << 15)
122d6150db2SPo-Yu Chuang #define FTPMU010_MFPSR_MODEMPINSEL	(1 << 14)
123d6150db2SPo-Yu Chuang #define FTPMU010_MFPSR_AC97CLKOUTSEL	(1 << 13)
124caddb8e4SMacpaul Lin #define FTPMU010_MFPSR_PWM1PINSEL	(1 << 11)
125caddb8e4SMacpaul Lin #define FTPMU010_MFPSR_PWM0PINSEL	(1 << 10)
126caddb8e4SMacpaul Lin #define FTPMU010_MFPSR_IRDACLKSEL	(1 << 9)
127caddb8e4SMacpaul Lin #define FTPMU010_MFPSR_UARTCLKSEL	(1 << 8)
128caddb8e4SMacpaul Lin #define FTPMU010_MFPSR_SSPCLKSEL	(1 << 6)
129caddb8e4SMacpaul Lin #define FTPMU010_MFPSR_I2SCLKSEL	(1 << 5)
130caddb8e4SMacpaul Lin #define FTPMU010_MFPSR_AC97CLKSEL	(1 << 4)
131d6150db2SPo-Yu Chuang #define FTPMU010_MFPSR_AC97PINSEL	(1 << 3)
132caddb8e4SMacpaul Lin #define FTPMU010_MFPSR_TRIAHBDIS	(1 << 1)
133caddb8e4SMacpaul Lin #define FTPMU010_MFPSR_TRIAHBDBG	(1 << 0)
134d6150db2SPo-Yu Chuang 
135d6150db2SPo-Yu Chuang /*
136d6150db2SPo-Yu Chuang  * PLL/DLL Control Register 0
137caddb8e4SMacpaul Lin  * Note:
138caddb8e4SMacpaul Lin  *  1. FTPMU010_PDLLCR0_HCLKOUTDIS:
139caddb8e4SMacpaul Lin  *	Datasheet indicated it starts at bit #21 which was wrong.
140caddb8e4SMacpaul Lin  *  2. FTPMU010_PDLLCR0_DLLFRAG:
141caddb8e4SMacpaul Lin  * 	Datasheet indicated it has 2 bit which was wrong.
142d6150db2SPo-Yu Chuang  */
143caddb8e4SMacpaul Lin #define FTPMU010_PDLLCR0_HCLKOUTDIS(cr0)	(((cr0) & 0xf) << 20)
144caddb8e4SMacpaul Lin #define FTPMU010_PDLLCR0_DLLFRAG(cr0)		(1 << 19)
145d6150db2SPo-Yu Chuang #define FTPMU010_PDLLCR0_DLLSTSEL		(1 << 18)
146d6150db2SPo-Yu Chuang #define FTPMU010_PDLLCR0_DLLSTABLE		(1 << 17)
147d6150db2SPo-Yu Chuang #define FTPMU010_PDLLCR0_DLLDIS			(1 << 16)
148caddb8e4SMacpaul Lin #define FTPMU010_PDLLCR0_PLL1FRANG(cr0)		(((cr0) & 0x3) << 12)
149caddb8e4SMacpaul Lin #define FTPMU010_PDLLCR0_PLL1NS(cr0)		(((cr0) & 0x1ff) << 3)
150d6150db2SPo-Yu Chuang #define FTPMU010_PDLLCR0_PLL1STSEL		(1 << 2)
151d6150db2SPo-Yu Chuang #define FTPMU010_PDLLCR0_PLL1STABLE		(1 << 1)
152d6150db2SPo-Yu Chuang #define FTPMU010_PDLLCR0_PLL1DIS		(1 << 0)
153d6150db2SPo-Yu Chuang 
154caddb8e4SMacpaul Lin /*
155caddb8e4SMacpaul Lin  * SDRAM Signal Hold Time Control Register
156caddb8e4SMacpaul Lin  */
157caddb8e4SMacpaul Lin #define FTPMU010_SDRAMHTC_RCLK_DLY(x)		(((x) & 0xf) << 28)
158caddb8e4SMacpaul Lin #define FTPMU010_SDRAMHTC_CTL_WCLK_DLY(x)	(((x) & 0xf) << 24)
159caddb8e4SMacpaul Lin #define FTPMU010_SDRAMHTC_DAT_WCLK_DLY(x)	(((x) & 0xf) << 20)
160caddb8e4SMacpaul Lin #define FTPMU010_SDRAMHTC_EBICTRL_DCSR		(1 << 18)
161caddb8e4SMacpaul Lin #define FTPMU010_SDRAMHTC_EBIDATA_DCSR		(1 << 17)
162caddb8e4SMacpaul Lin #define FTPMU010_SDRAMHTC_SDRAMCS_DCSR		(1 << 16)
163caddb8e4SMacpaul Lin #define FTPMU010_SDRAMHTC_SDRAMCTL_DCSR		(1 << 15)
164caddb8e4SMacpaul Lin #define FTPMU010_SDRAMHTC_CKE_DCSR		(1 << 14)
165caddb8e4SMacpaul Lin #define FTPMU010_SDRAMHTC_DQM_DCSR		(1 << 13)
166caddb8e4SMacpaul Lin #define FTPMU010_SDRAMHTC_SDCLK_DCSR		(1 << 12)
167caddb8e4SMacpaul Lin 
168d228710fSMacpaul Lin #ifndef __ASSEMBLY__
169d6150db2SPo-Yu Chuang void ftpmu010_32768osc_enable(void);
170d6150db2SPo-Yu Chuang void ftpmu010_dlldis_disable(void);
171ac560326SMacpaul Lin void ftpmu010_mfpsr_diselect_dev(unsigned int dev);
172ac560326SMacpaul Lin void ftpmu010_mfpsr_select_dev(unsigned int dev);
173d6150db2SPo-Yu Chuang void ftpmu010_sdram_clk_disable(unsigned int cr0);
174ac560326SMacpaul Lin void ftpmu010_sdramhtc_set(unsigned int val);
175d228710fSMacpaul Lin #endif
176d228710fSMacpaul Lin 
177d228710fSMacpaul Lin #ifdef __ASSEMBLY__
178d228710fSMacpaul Lin #define FTPMU010_IDNMBR0	0x00
179d228710fSMacpaul Lin #define FTPMU010_reserved0	0x04
180d228710fSMacpaul Lin #define FTPMU010_OSCC		0x08
181d228710fSMacpaul Lin #define FTPMU010_PMODE		0x0C
182d228710fSMacpaul Lin #define FTPMU010_PMCR		0x10
183d228710fSMacpaul Lin #define FTPMU010_PED		0x14
184d228710fSMacpaul Lin #define FTPMU010_PEDSR		0x18
185d228710fSMacpaul Lin #define FTPMU010_reserved1	0x1C
186d228710fSMacpaul Lin #define FTPMU010_PMSR		0x20
187d228710fSMacpaul Lin #define FTPMU010_PGSR		0x24
188d228710fSMacpaul Lin #define FTPMU010_MFPSR		0x28
189d228710fSMacpaul Lin #define FTPMU010_MISC		0x2C
190d228710fSMacpaul Lin #define FTPMU010_PDLLCR0	0x30
191d228710fSMacpaul Lin #define FTPMU010_PDLLCR1	0x34
192d228710fSMacpaul Lin #define FTPMU010_AHBMCLKOFF	0x38
193d228710fSMacpaul Lin #define FTPMU010_APBMCLKOFF	0x3C
194d228710fSMacpaul Lin #define FTPMU010_DCSRCR0	0x40
195d228710fSMacpaul Lin #define FTPMU010_DCSRCR1	0x44
196d228710fSMacpaul Lin #define FTPMU010_DCSRCR2	0x48
197d228710fSMacpaul Lin #define FTPMU010_SDRAMHTC	0x4C
198d228710fSMacpaul Lin #define FTPMU010_PSPR0		0x50
199d228710fSMacpaul Lin #define FTPMU010_PSPR1		0x54
200d228710fSMacpaul Lin #define FTPMU010_PSPR2		0x58
201d228710fSMacpaul Lin #define FTPMU010_PSPR3		0x5C
202d228710fSMacpaul Lin #define FTPMU010_PSPR4		0x60
203d228710fSMacpaul Lin #define FTPMU010_PSPR5		0x64
204d228710fSMacpaul Lin #define FTPMU010_PSPR6		0x68
205d228710fSMacpaul Lin #define FTPMU010_PSPR7		0x6C
206d228710fSMacpaul Lin #define FTPMU010_PSPR8		0x70
207d228710fSMacpaul Lin #define FTPMU010_PSPR9		0x74
208d228710fSMacpaul Lin #define FTPMU010_PSPR10		0x78
209d228710fSMacpaul Lin #define FTPMU010_PSPR11		0x7C
210d228710fSMacpaul Lin #define FTPMU010_PSPR12		0x80
211d228710fSMacpaul Lin #define FTPMU010_PSPR13		0x84
212d228710fSMacpaul Lin #define FTPMU010_PSPR14		0x88
213d228710fSMacpaul Lin #define FTPMU010_PSPR15		0x8C
214d228710fSMacpaul Lin #define FTPMU010_AHBDMA_RACCS	0x90
215d228710fSMacpaul Lin #define FTPMU010_reserved2	0x94
216d228710fSMacpaul Lin #define FTPMU010_reserved3	0x98
217d228710fSMacpaul Lin #define FTPMU010_JSS		0x9C
218d228710fSMacpaul Lin #define FTPMU010_CFC_RACC	0xA0
219d228710fSMacpaul Lin #define FTPMU010_SSP1_RACC	0xA4
220d228710fSMacpaul Lin #define FTPMU010_UART1TX_RACC	0xA8
221d228710fSMacpaul Lin #define FTPMU010_UART1RX_RACC	0xAC
222d228710fSMacpaul Lin #define FTPMU010_UART2TX_RACC	0xB0
223d228710fSMacpaul Lin #define FTPMU010_UART2RX_RACC	0xB4
224d228710fSMacpaul Lin #define FTPMU010_SDC_RACC	0xB8
225d228710fSMacpaul Lin #define FTPMU010_I2SAC97_RACC	0xBC
226d228710fSMacpaul Lin #define FTPMU010_IRDATX_RACC	0xC0
227d228710fSMacpaul Lin #define FTPMU010_reserved4	0xC4
228d228710fSMacpaul Lin #define FTPMU010_USBD_RACC	0xC8
229d228710fSMacpaul Lin #define FTPMU010_IRDARX_RACC	0xCC
230d228710fSMacpaul Lin #define FTPMU010_IRDA_RACC	0xD0
231d228710fSMacpaul Lin #define FTPMU010_ED0_RACC	0xD4
232d228710fSMacpaul Lin #define FTPMU010_ED1_RACC	0xD8
233d228710fSMacpaul Lin #endif /* __ASSEMBLY__ */
234d6150db2SPo-Yu Chuang 
235d6150db2SPo-Yu Chuang #endif	/* __FTPMU010_H */
236