summaryrefslogtreecommitdiff
path: root/arch/arm/include/asm/arch-tegra2/clk_rst.h
blob: bd8ad2ca0499118db3de5ee8e094af2e35d4b3a7 (plain)
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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
/*
 *  (C) Copyright 2010,2011
 *  NVIDIA Corporation <www.nvidia.com>
 *
 * See file CREDITS for list of people who contributed to this
 * project.
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License as
 * published by the Free Software Foundation; either version 2 of
 * the License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
 * MA 02111-1307 USA
 */

#ifndef _CLK_RST_H_
#define _CLK_RST_H_

/* Clock/Reset Controller (CLK_RST_CONTROLLER_) regs */
struct clk_rst_ctlr {
	uint crc_rst_src;		/* _RST_SOURCE_0,	0x00 */
	uint crc_rst_dev_l;		/* _RST_DEVICES_L_0,	0x04 */
	uint crc_rst_dev_h;		/* _RST_DEVICES_H_0,	0x08 */
	uint crc_rst_dev_u;		/* _RST_DEVICES_U_0,	0x0C */
	uint crc_clk_out_enb_l;		/* _CLK_OUT_ENB_L_0,	0x10 */
	uint crc_clk_out_enb_h;		/* _CLK_OUT_ENB_H_0,	0x14 */
	uint crc_clk_out_enb_u;		/* _CLK_OUT_ENB_U_0,	0x18 */
	uint crc_reserved0;		/* reserved_0,		0x1C */
	uint crc_cclk_brst_pol;		/* _CCLK_BURST_POLICY_0,0x20 */
	uint crc_super_cclk_div;	/* _SUPER_CCLK_DIVIDER_0,0x24 */
	uint crc_sclk_brst_pol;		/* _SCLK_BURST_POLICY_0, 0x28 */
	uint crc_super_sclk_div;	/* _SUPER_SCLK_DIVIDER_0,0x2C */
	uint crc_clk_sys_rate;		/* _CLK_SYSTEM_RATE_0,	0x30 */
	uint crc_prog_dly_clk;		/* _PROG_DLY_CLK_0,	0x34 */
	uint crc_aud_sync_clk_rate;	/* _AUDIO_SYNC_CLK_RATE_0,0x38 */
	uint crc_reserved1;		/* reserved_1,		0x3C */
	uint crc_cop_clk_skip_plcy;	/* _COP_CLK_SKIP_POLICY_0,0x40 */
	uint crc_clk_mask_arm;		/* _CLK_MASK_ARM_0,	0x44 */
	uint crc_misc_clk_enb;		/* _MISC_CLK_ENB_0,	0x48 */
	uint crc_clk_cpu_cmplx;		/* _CLK_CPU_CMPLX_0,	0x4C */
	uint crc_osc_ctrl;		/* _OSC_CTRL_0,		0x50 */
	uint crc_pll_lfsr;		/* _PLL_LFSR_0,		0x54 */
	uint crc_osc_freq_det;		/* _OSC_FREQ_DET_0,	0x58 */
	uint crc_osc_freq_det_stat;	/* _OSC_FREQ_DET_STATUS_0,0x5C */
	uint crc_reserved2[8];		/* reserved_2[8],	0x60-7C */

	uint crc_pllc_base;		/* _PLLC_BASE_0,	0x80 */
	uint crc_pllc_out;		/* _PLLC_OUT_0,		0x84 */
	uint crc_reserved3;		/* reserved_3,		0x88 */
	uint crc_pllc_misc;		/* _PLLC_MISC_0,	0x8C */

	uint crc_pllm_base;		/* _PLLM_BASE_0,	0x90 */
	uint crc_pllm_out;		/* _PLLM_OUT_0,		0x94 */
	uint crc_reserved4;		/* reserved_4,		0x98 */
	uint crc_pllm_misc;		/* _PLLM_MISC_0,	0x9C */

	uint crc_pllp_base;		/* _PLLP_BASE_0,	0xA0 */
	uint crc_pllp_outa;		/* _PLLP_OUTA_0,	0xA4 */
	uint crc_pllp_outb;		/* _PLLP_OUTB_0,	0xA8 */
	uint crc_pllp_misc;		/* _PLLP_MISC_0,	0xAC */

	uint crc_plla_base;		/* _PLLA_BASE_0,	0xB0 */
	uint crc_plla_out;		/* _PLLA_OUT_0,		0xB4 */
	uint crc_reserved5;		/* reserved_5,		0xB8 */
	uint crc_plla_misc;		/* _PLLA_MISC_0,	0xBC */

	uint crc_pllu_base;		/* _PLLU_BASE_0,	0xC0 */
	uint crc_reserved6;		/* _reserved_6,		0xC4 */
	uint crc_reserved7;		/* _reserved_7,		0xC8 */
	uint crc_pllu_misc;		/* _PLLU_MISC_0,	0xCC */

	uint crc_plld_base;		/* _PLLD_BASE_0,	0xD0 */
	uint crc_reserved8;		/* _reserved_8,		0xD4 */
	uint crc_reserved9;		/* _reserved_9,		0xD8 */
	uint crc_plld_misc;		/* _PLLD_MISC_0,	0xDC */

	uint crc_pllx_base;		/* _PLLX_BASE_0,	0xE0 */
	uint crc_pllx_misc;		/* _PLLX_MISC_0,	0xE4 */

	uint crc_plle_base;		/* _PLLE_BASE_0,	0xE8 */
	uint crc_plle_misc;		/* _PLLE_MISC_0,	0xEC */

	uint crc_plls_base;		/* _PLLS_BASE_0,	0xF0 */
	uint crc_plls_misc;		/* _PLLS_MISC_0,	0xF4 */
	uint crc_reserved10;		/* _reserved_10,	0xF8 */
	uint crc_reserved11;		/* _reserved_11,	0xFC */

	uint crc_clk_src_i2s1;		/*_I2S1_0,		0x100 */
	uint crc_clk_src_i2s2;		/*_I2S2_0,		0x104 */
	uint crc_clk_src_spdif_out;	/*_SPDIF_OUT_0,		0x108 */
	uint crc_clk_src_spdif_in;	/*_SPDIF_IN_0,		0x10C */
	uint crc_clk_src_pwm;		/*_PWM_0,		0x110 */
	uint crc_clk_src_spi1;		/*_SPI1_0,		0x114 */
	uint crc_clk_src_sbc2;		/*_SBC2_0,		0x118 */
	uint crc_clk_src_sbc3;		/*_SBC3_0,		0x11C */
	uint crc_clk_src_xio;		/*_XIO_0,		0x120 */
	uint crc_clk_src_i2c1;		/*_I2C1_0,		0x124 */
	uint crc_clk_src_dvc_i2c;	/*_DVC_I2C_0,		0x128 */
	uint crc_clk_src_twc;		/*_TWC_0,		0x12C */
	uint crc_reserved12;		/*			0x130 */
	uint crc_clk_src_sbc1;		/*_SBC1_0,		0x134 */
	uint crc_clk_src_disp1;		/*_DISP1_0,		0x138 */
	uint crc_clk_src_disp2;		/*_DISP2_0,		0x13C */
	uint crc_clk_src_cve;		/*_CVE_0,		0x140 */
	uint crc_clk_src_ide;		/*_IDE_0,		0x144 */
	uint crc_clk_src_vi;		/*_VI_0,		0x148 */
	uint crc_reserved13;		/*			0x14C */
	uint crc_clk_src_sdmmc1;	/*_SDMMC1_0,		0x150 */
	uint crc_clk_src_sdmmc2;	/*_SDMMC2_0,		0x154 */
	uint crc_clk_src_g3d;		/*_G3D_0,		0x158 */
	uint crc_clk_src_g2d;		/*_G2D_0,		0x15C */
	uint crc_clk_src_ndflash;	/*_NDFLASH_0,		0x160 */
	uint crc_clk_src_sdmmc4;	/*_SDMMC4_0,		0x164 */
	uint crc_clk_src_vfir;		/*_VFIR_0,		0x168 */
	uint crc_clk_src_epp;		/*_EPP_0,		0x16C */
	uint crc_clk_src_mp3;		/*_MPE_0,		0x170 */
	uint crc_clk_src_mipi;		/*_MIPI_0,		0x174 */
	uint crc_clk_src_uarta;		/*_UARTA_0,		0x178 */
	uint crc_clk_src_uartb;		/*_UARTB_0,		0x17C */
	uint crc_clk_src_host1x;	/*_HOST1X_0,		0x180 */
	uint crc_reserved14;		/*			0x184 */
	uint crc_clk_src_tvo;		/*_TVO_0,		0x188 */
	uint crc_clk_src_hdmi;		/*_HDMI_0,		0x18C */
	uint crc_reserved15;		/*			0x190 */
	uint crc_clk_src_tvdac;		/*_TVDAC_0,		0x194 */
	uint crc_clk_src_i2c2;		/*_I2C2_0,		0x198 */
	uint crc_clk_src_emc;		/*_EMC_0,		0x19C */
	uint crc_clk_src_uartc;		/*_UARTC_0,		0x1A0 */
	uint crc_reserved16;		/*			0x1A4 */
	uint crc_clk_src_vi_sensor;	/*_VI_SENSOR_0,		0x1A8 */
	uint crc_reserved17;		/*			0x1AC */
	uint crc_reserved18;		/*			0x1B0 */
	uint crc_clk_src_sbc4;		/*_SBC4_0,		0x1B4 */
	uint crc_clk_src_i2c3;		/*_I2C3_0,		0x1B8 */
	uint crc_clk_src_sdmmc3;	/*_SDMMC3_0,		0x1BC */
	uint crc_clk_src_uartd;		/*_UARTD_0,		0x1C0 */
	uint crc_clk_src_uarte;		/*_UARTE_0,		0x1C4 */
	uint crc_clk_src_vde;		/*_VDE_0,		0x1C8 */
	uint crc_clk_src_owr;		/*_OWR_0,		0x1CC */
	uint crc_clk_src_nor;		/*_NOR_0,		0x1D0 */
	uint crc_clk_src_csite;		/*_CSITE_0,		0x1D4 */
	uint crc_reserved19[9];		/*			0x1D8-1F8 */
	uint crc_clk_src_osc;		/*_OSC_0,		0x1FC */
	uint crc_reserved20[80];	/*			0x200-33C */
	uint crc_cpu_cmplx_set;		/* _CPU_CMPLX_SET_0,	0x340 */
	uint crc_cpu_cmplx_clr;		/* _CPU_CMPLX_CLR_0,	0x344 */
};

#define PLL_BYPASS		(1 << 31)
#define PLL_ENABLE		(1 << 30)
#define PLL_BASE_OVRRIDE	(1 << 28)
#define PLL_DIVP		(1 << 20)	/* post divider, b22:20 */
#define PLL_DIVM		0x0C		/* input divider, b4:0 */

#define SWR_UARTD_RST		(1 << 1)
#define CLK_ENB_UARTD		(1 << 1)
#define SWR_UARTA_RST		(1 << 6)
#define CLK_ENB_UARTA		(1 << 6)

#define SWR_CPU_RST		(1 << 0)
#define CLK_ENB_CPU		(1 << 0)
#define SWR_CSITE_RST		(1 << 9)
#define CLK_ENB_CSITE		(1 << 9)

#define SET_CPURESET0		(1 << 0)
#define SET_DERESET0		(1 << 4)
#define SET_DBGRESET0		(1 << 12)

#define SET_CPURESET1		(1 << 1)
#define SET_DERESET1		(1 << 5)
#define SET_DBGRESET1		(1 << 13)

#define CLR_CPURESET0		(1 << 0)
#define CLR_DERESET0		(1 << 4)
#define CLR_DBGRESET0		(1 << 12)

#define CLR_CPURESET1		(1 << 1)
#define CLR_DERESET1		(1 << 5)
#define CLR_DBGRESET1		(1 << 13)

#define CPU0_CLK_STP		(1 << 8)
#define CPU1_CLK_STP		(1 << 9)

#define CPCON			(1 << 8)

#endif	/* CLK_RST_H */