2 * Texas Instruments TNETV107X SoC Support
4 * Copyright (C) 2010 Texas Instruments
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License as
8 * published by the Free Software Foundation version 2.
10 * This program is distributed "as is" WITHOUT ANY WARRANTY of any
11 * kind, whether express or implied; without even the implied warranty
12 * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 #include <linux/gpio.h>
16 #include <linux/kernel.h>
17 #include <linux/init.h>
18 #include <linux/clk.h>
20 #include <linux/err.h>
21 #include <linux/platform_device.h>
22 #include <linux/reboot.h>
24 #include <asm/mach/map.h>
26 #include <mach/common.h>
27 #include <mach/time.h>
28 #include <mach/cputype.h>
30 #include <mach/cp_intc.h>
31 #include <mach/irqs.h>
32 #include <mach/hardware.h>
33 #include <mach/tnetv107x.h>
34 #include <mach/gpio-davinci.h>
39 /* Base addresses for on-chip devices */
40 #define TNETV107X_INTC_BASE 0x03000000
41 #define TNETV107X_TIMER0_BASE 0x08086500
42 #define TNETV107X_TIMER1_BASE 0x08086600
43 #define TNETV107X_CHIP_CFG_BASE 0x08087000
44 #define TNETV107X_GPIO_BASE 0x08088000
45 #define TNETV107X_CLOCK_CONTROL_BASE 0x0808a000
46 #define TNETV107X_PSC_BASE 0x0808b000
48 /* Reference clock frequencies */
49 #define OSC_FREQ_ONCHIP (24000 * 1000)
50 #define OSC_FREQ_OFFCHIP_SYS (25000 * 1000)
51 #define OSC_FREQ_OFFCHIP_ETH (25000 * 1000)
52 #define OSC_FREQ_OFFCHIP_TDM (19200 * 1000)
56 /* Clock Control Registers */
57 struct clk_ctrl_regs
{
81 /* Watchdog Timer Registers */
93 static struct clk_ctrl_regs __iomem
*clk_ctrl_regs
;
95 static struct sspll_regs __iomem
*sspll_regs
[N_PLLS
];
96 static int sspll_regs_base
[N_PLLS
] = { 0x40, 0x80, 0xc0 };
98 /* PLL bypass bit shifts in clk_ctrl_regs->pll_bypass register */
99 static u32 bypass_mask
[N_PLLS
] = { BIT(0), BIT(2), BIT(1) };
101 /* offchip (external) reference clock frequencies */
102 static u32 pll_ext_freq
[] = {
103 OSC_FREQ_OFFCHIP_SYS
,
104 OSC_FREQ_OFFCHIP_TDM
,
108 /* PSC control registers */
109 static u32 psc_regs
[] = { TNETV107X_PSC_BASE
};
111 /* Host map for interrupt controller */
112 static u32 intc_host_map
[] = { 0x01010000, 0x01010101, -1 };
114 static unsigned long clk_sspll_recalc(struct clk
*clk
);
116 /* Level 1 - the PLLs */
117 #define define_pll_clk(cname, pll, divmask, base) \
118 static struct pll_data pll_##cname##_data = { \
120 .div_ratio_mask = divmask, \
121 .phys_base = base + \
122 TNETV107X_CLOCK_CONTROL_BASE, \
124 static struct clk pll_##cname##_clk = { \
125 .name = "pll_" #cname "_clk", \
126 .pll_data = &pll_##cname##_data, \
128 .recalc = clk_sspll_recalc, \
131 define_pll_clk(sys
, 0, 0x1ff, 0x600);
132 define_pll_clk(tdm
, 1, 0x0ff, 0x200);
133 define_pll_clk(eth
, 2, 0x0ff, 0x400);
135 /* Level 2 - divided outputs from the PLLs */
136 #define define_pll_div_clk(pll, cname, div) \
137 static struct clk pll##_##cname##_clk = { \
138 .name = #pll "_" #cname "_clk", \
139 .parent = &pll_##pll##_clk, \
141 .div_reg = PLLDIV##div, \
142 .set_rate = davinci_set_sysclk_rate, \
145 define_pll_div_clk(sys
, arm1176
, 1);
146 define_pll_div_clk(sys
, dsp
, 2);
147 define_pll_div_clk(sys
, ddr
, 3);
148 define_pll_div_clk(sys
, full
, 4);
149 define_pll_div_clk(sys
, lcd
, 5);
150 define_pll_div_clk(sys
, vlynq_ref
, 6);
151 define_pll_div_clk(sys
, tsc
, 7);
152 define_pll_div_clk(sys
, half
, 8);
154 define_pll_div_clk(eth
, 5mhz
, 1);
155 define_pll_div_clk(eth
, 50mhz
, 2);
156 define_pll_div_clk(eth
, 125mhz
, 3);
157 define_pll_div_clk(eth
, 250mhz
, 4);
158 define_pll_div_clk(eth
, 25mhz
, 5);
160 define_pll_div_clk(tdm
, 0, 1);
161 define_pll_div_clk(tdm
, extra
, 2);
162 define_pll_div_clk(tdm
, 1, 3);
165 /* Level 3 - LPSC gated clocks */
166 #define __lpsc_clk(cname, _parent, mod, flg) \
167 static struct clk clk_##cname = { \
169 .parent = &_parent, \
170 .lpsc = TNETV107X_LPSC_##mod,\
174 #define lpsc_clk_enabled(cname, parent, mod) \
175 __lpsc_clk(cname, parent, mod, ALWAYS_ENABLED)
177 #define lpsc_clk(cname, parent, mod) \
178 __lpsc_clk(cname, parent, mod, 0)
180 lpsc_clk_enabled(arm
, sys_arm1176_clk
, ARM
);
181 lpsc_clk_enabled(gem
, sys_dsp_clk
, GEM
);
182 lpsc_clk_enabled(ddr2_phy
, sys_ddr_clk
, DDR2_PHY
);
183 lpsc_clk_enabled(tpcc
, sys_full_clk
, TPCC
);
184 lpsc_clk_enabled(tptc0
, sys_full_clk
, TPTC0
);
185 lpsc_clk_enabled(tptc1
, sys_full_clk
, TPTC1
);
186 lpsc_clk_enabled(ram
, sys_full_clk
, RAM
);
187 lpsc_clk_enabled(aemif
, sys_full_clk
, AEMIF
);
188 lpsc_clk_enabled(chipcfg
, sys_half_clk
, CHIP_CFG
);
189 lpsc_clk_enabled(rom
, sys_half_clk
, ROM
);
190 lpsc_clk_enabled(secctl
, sys_half_clk
, SECCTL
);
191 lpsc_clk_enabled(keymgr
, sys_half_clk
, KEYMGR
);
192 lpsc_clk_enabled(gpio
, sys_half_clk
, GPIO
);
193 lpsc_clk_enabled(debugss
, sys_half_clk
, DEBUGSS
);
194 lpsc_clk_enabled(system
, sys_half_clk
, SYSTEM
);
195 lpsc_clk_enabled(ddr2_vrst
, sys_ddr_clk
, DDR2_EMIF1_VRST
);
196 lpsc_clk_enabled(ddr2_vctl_rst
, sys_ddr_clk
, DDR2_EMIF2_VCTL_RST
);
197 lpsc_clk_enabled(wdt_arm
, sys_half_clk
, WDT_ARM
);
198 lpsc_clk_enabled(timer1
, sys_half_clk
, TIMER1
);
200 lpsc_clk(mbx_lite
, sys_arm1176_clk
, MBX_LITE
);
201 lpsc_clk(ethss
, eth_125mhz_clk
, ETHSS
);
202 lpsc_clk(tsc
, sys_tsc_clk
, TSC
);
203 lpsc_clk(uart0
, sys_half_clk
, UART0
);
204 lpsc_clk(uart1
, sys_half_clk
, UART1
);
205 lpsc_clk(uart2
, sys_half_clk
, UART2
);
206 lpsc_clk(pktsec
, sys_half_clk
, PKTSEC
);
207 lpsc_clk(keypad
, sys_half_clk
, KEYPAD
);
208 lpsc_clk(mdio
, sys_half_clk
, MDIO
);
209 lpsc_clk(sdio0
, sys_half_clk
, SDIO0
);
210 lpsc_clk(sdio1
, sys_half_clk
, SDIO1
);
211 lpsc_clk(timer0
, sys_half_clk
, TIMER0
);
212 lpsc_clk(wdt_dsp
, sys_half_clk
, WDT_DSP
);
213 lpsc_clk(ssp
, sys_half_clk
, SSP
);
214 lpsc_clk(tdm0
, tdm_0_clk
, TDM0
);
215 lpsc_clk(tdm1
, tdm_1_clk
, TDM1
);
216 lpsc_clk(vlynq
, sys_vlynq_ref_clk
, VLYNQ
);
217 lpsc_clk(mcdma
, sys_half_clk
, MCDMA
);
218 lpsc_clk(usbss
, sys_half_clk
, USBSS
);
219 lpsc_clk(usb0
, clk_usbss
, USB0
);
220 lpsc_clk(usb1
, clk_usbss
, USB1
);
221 lpsc_clk(ethss_rgmii
, eth_250mhz_clk
, ETHSS_RGMII
);
222 lpsc_clk(imcop
, sys_dsp_clk
, IMCOP
);
223 lpsc_clk(spare
, sys_half_clk
, SPARE
);
225 /* LCD needs a full power down to clear controller state */
226 __lpsc_clk(lcd
, sys_lcd_clk
, LCD
, PSC_SWRSTDISABLE
);
229 /* Level 4 - leaf clocks for LPSC modules shared across drivers */
230 static struct clk clk_rng
= { .name
= "rng", .parent
= &clk_pktsec
};
231 static struct clk clk_pka
= { .name
= "pka", .parent
= &clk_pktsec
};
233 static struct clk_lookup clks
[] = {
234 CLK(NULL
, "pll_sys_clk", &pll_sys_clk
),
235 CLK(NULL
, "pll_eth_clk", &pll_eth_clk
),
236 CLK(NULL
, "pll_tdm_clk", &pll_tdm_clk
),
237 CLK(NULL
, "sys_arm1176_clk", &sys_arm1176_clk
),
238 CLK(NULL
, "sys_dsp_clk", &sys_dsp_clk
),
239 CLK(NULL
, "sys_ddr_clk", &sys_ddr_clk
),
240 CLK(NULL
, "sys_full_clk", &sys_full_clk
),
241 CLK(NULL
, "sys_lcd_clk", &sys_lcd_clk
),
242 CLK(NULL
, "sys_vlynq_ref_clk", &sys_vlynq_ref_clk
),
243 CLK(NULL
, "sys_tsc_clk", &sys_tsc_clk
),
244 CLK(NULL
, "sys_half_clk", &sys_half_clk
),
245 CLK(NULL
, "eth_5mhz_clk", ð_5mhz_clk
),
246 CLK(NULL
, "eth_50mhz_clk", ð_50mhz_clk
),
247 CLK(NULL
, "eth_125mhz_clk", ð_125mhz_clk
),
248 CLK(NULL
, "eth_250mhz_clk", ð_250mhz_clk
),
249 CLK(NULL
, "eth_25mhz_clk", ð_25mhz_clk
),
250 CLK(NULL
, "tdm_0_clk", &tdm_0_clk
),
251 CLK(NULL
, "tdm_extra_clk", &tdm_extra_clk
),
252 CLK(NULL
, "tdm_1_clk", &tdm_1_clk
),
253 CLK(NULL
, "clk_arm", &clk_arm
),
254 CLK(NULL
, "clk_gem", &clk_gem
),
255 CLK(NULL
, "clk_ddr2_phy", &clk_ddr2_phy
),
256 CLK(NULL
, "clk_tpcc", &clk_tpcc
),
257 CLK(NULL
, "clk_tptc0", &clk_tptc0
),
258 CLK(NULL
, "clk_tptc1", &clk_tptc1
),
259 CLK(NULL
, "clk_ram", &clk_ram
),
260 CLK(NULL
, "clk_mbx_lite", &clk_mbx_lite
),
261 CLK("tnetv107x-fb.0", NULL
, &clk_lcd
),
262 CLK(NULL
, "clk_ethss", &clk_ethss
),
263 CLK(NULL
, "aemif", &clk_aemif
),
264 CLK(NULL
, "clk_chipcfg", &clk_chipcfg
),
265 CLK("tnetv107x-ts.0", NULL
, &clk_tsc
),
266 CLK(NULL
, "clk_rom", &clk_rom
),
267 CLK(NULL
, "uart2", &clk_uart2
),
268 CLK(NULL
, "clk_pktsec", &clk_pktsec
),
269 CLK("tnetv107x-rng.0", NULL
, &clk_rng
),
270 CLK("tnetv107x-pka.0", NULL
, &clk_pka
),
271 CLK(NULL
, "clk_secctl", &clk_secctl
),
272 CLK(NULL
, "clk_keymgr", &clk_keymgr
),
273 CLK("tnetv107x-keypad.0", NULL
, &clk_keypad
),
274 CLK(NULL
, "clk_gpio", &clk_gpio
),
275 CLK(NULL
, "clk_mdio", &clk_mdio
),
276 CLK("dm6441-mmc.0", NULL
, &clk_sdio0
),
277 CLK(NULL
, "uart0", &clk_uart0
),
278 CLK(NULL
, "uart1", &clk_uart1
),
279 CLK(NULL
, "timer0", &clk_timer0
),
280 CLK(NULL
, "timer1", &clk_timer1
),
281 CLK("tnetv107x_wdt.0", NULL
, &clk_wdt_arm
),
282 CLK(NULL
, "clk_wdt_dsp", &clk_wdt_dsp
),
283 CLK("ti-ssp", NULL
, &clk_ssp
),
284 CLK(NULL
, "clk_tdm0", &clk_tdm0
),
285 CLK(NULL
, "clk_vlynq", &clk_vlynq
),
286 CLK(NULL
, "clk_mcdma", &clk_mcdma
),
287 CLK(NULL
, "clk_usbss", &clk_usbss
),
288 CLK(NULL
, "clk_usb0", &clk_usb0
),
289 CLK(NULL
, "clk_usb1", &clk_usb1
),
290 CLK(NULL
, "clk_tdm1", &clk_tdm1
),
291 CLK(NULL
, "clk_debugss", &clk_debugss
),
292 CLK(NULL
, "clk_ethss_rgmii", &clk_ethss_rgmii
),
293 CLK(NULL
, "clk_system", &clk_system
),
294 CLK(NULL
, "clk_imcop", &clk_imcop
),
295 CLK(NULL
, "clk_spare", &clk_spare
),
296 CLK("dm6441-mmc.1", NULL
, &clk_sdio1
),
297 CLK(NULL
, "clk_ddr2_vrst", &clk_ddr2_vrst
),
298 CLK(NULL
, "clk_ddr2_vctl_rst", &clk_ddr2_vctl_rst
),
299 CLK(NULL
, NULL
, NULL
),
302 static const struct mux_config pins
[] = {
303 #ifdef CONFIG_DAVINCI_MUX
304 MUX_CFG(TNETV107X
, ASR_A00
, 0, 0, 0x1f, 0x00, false)
305 MUX_CFG(TNETV107X
, GPIO32
, 0, 0, 0x1f, 0x04, false)
306 MUX_CFG(TNETV107X
, ASR_A01
, 0, 5, 0x1f, 0x00, false)
307 MUX_CFG(TNETV107X
, GPIO33
, 0, 5, 0x1f, 0x04, false)
308 MUX_CFG(TNETV107X
, ASR_A02
, 0, 10, 0x1f, 0x00, false)
309 MUX_CFG(TNETV107X
, GPIO34
, 0, 10, 0x1f, 0x04, false)
310 MUX_CFG(TNETV107X
, ASR_A03
, 0, 15, 0x1f, 0x00, false)
311 MUX_CFG(TNETV107X
, GPIO35
, 0, 15, 0x1f, 0x04, false)
312 MUX_CFG(TNETV107X
, ASR_A04
, 0, 20, 0x1f, 0x00, false)
313 MUX_CFG(TNETV107X
, GPIO36
, 0, 20, 0x1f, 0x04, false)
314 MUX_CFG(TNETV107X
, ASR_A05
, 0, 25, 0x1f, 0x00, false)
315 MUX_CFG(TNETV107X
, GPIO37
, 0, 25, 0x1f, 0x04, false)
316 MUX_CFG(TNETV107X
, ASR_A06
, 1, 0, 0x1f, 0x00, false)
317 MUX_CFG(TNETV107X
, GPIO38
, 1, 0, 0x1f, 0x04, false)
318 MUX_CFG(TNETV107X
, ASR_A07
, 1, 5, 0x1f, 0x00, false)
319 MUX_CFG(TNETV107X
, GPIO39
, 1, 5, 0x1f, 0x04, false)
320 MUX_CFG(TNETV107X
, ASR_A08
, 1, 10, 0x1f, 0x00, false)
321 MUX_CFG(TNETV107X
, GPIO40
, 1, 10, 0x1f, 0x04, false)
322 MUX_CFG(TNETV107X
, ASR_A09
, 1, 15, 0x1f, 0x00, false)
323 MUX_CFG(TNETV107X
, GPIO41
, 1, 15, 0x1f, 0x04, false)
324 MUX_CFG(TNETV107X
, ASR_A10
, 1, 20, 0x1f, 0x00, false)
325 MUX_CFG(TNETV107X
, GPIO42
, 1, 20, 0x1f, 0x04, false)
326 MUX_CFG(TNETV107X
, ASR_A11
, 1, 25, 0x1f, 0x00, false)
327 MUX_CFG(TNETV107X
, BOOT_STRP_0
, 1, 25, 0x1f, 0x04, false)
328 MUX_CFG(TNETV107X
, ASR_A12
, 2, 0, 0x1f, 0x00, false)
329 MUX_CFG(TNETV107X
, BOOT_STRP_1
, 2, 0, 0x1f, 0x04, false)
330 MUX_CFG(TNETV107X
, ASR_A13
, 2, 5, 0x1f, 0x00, false)
331 MUX_CFG(TNETV107X
, GPIO43
, 2, 5, 0x1f, 0x04, false)
332 MUX_CFG(TNETV107X
, ASR_A14
, 2, 10, 0x1f, 0x00, false)
333 MUX_CFG(TNETV107X
, GPIO44
, 2, 10, 0x1f, 0x04, false)
334 MUX_CFG(TNETV107X
, ASR_A15
, 2, 15, 0x1f, 0x00, false)
335 MUX_CFG(TNETV107X
, GPIO45
, 2, 15, 0x1f, 0x04, false)
336 MUX_CFG(TNETV107X
, ASR_A16
, 2, 20, 0x1f, 0x00, false)
337 MUX_CFG(TNETV107X
, GPIO46
, 2, 20, 0x1f, 0x04, false)
338 MUX_CFG(TNETV107X
, ASR_A17
, 2, 25, 0x1f, 0x00, false)
339 MUX_CFG(TNETV107X
, GPIO47
, 2, 25, 0x1f, 0x04, false)
340 MUX_CFG(TNETV107X
, ASR_A18
, 3, 0, 0x1f, 0x00, false)
341 MUX_CFG(TNETV107X
, GPIO48
, 3, 0, 0x1f, 0x04, false)
342 MUX_CFG(TNETV107X
, SDIO1_DATA3_0
, 3, 0, 0x1f, 0x1c, false)
343 MUX_CFG(TNETV107X
, ASR_A19
, 3, 5, 0x1f, 0x00, false)
344 MUX_CFG(TNETV107X
, GPIO49
, 3, 5, 0x1f, 0x04, false)
345 MUX_CFG(TNETV107X
, SDIO1_DATA2_0
, 3, 5, 0x1f, 0x1c, false)
346 MUX_CFG(TNETV107X
, ASR_A20
, 3, 10, 0x1f, 0x00, false)
347 MUX_CFG(TNETV107X
, GPIO50
, 3, 10, 0x1f, 0x04, false)
348 MUX_CFG(TNETV107X
, SDIO1_DATA1_0
, 3, 10, 0x1f, 0x1c, false)
349 MUX_CFG(TNETV107X
, ASR_A21
, 3, 15, 0x1f, 0x00, false)
350 MUX_CFG(TNETV107X
, GPIO51
, 3, 15, 0x1f, 0x04, false)
351 MUX_CFG(TNETV107X
, SDIO1_DATA0_0
, 3, 15, 0x1f, 0x1c, false)
352 MUX_CFG(TNETV107X
, ASR_A22
, 3, 20, 0x1f, 0x00, false)
353 MUX_CFG(TNETV107X
, GPIO52
, 3, 20, 0x1f, 0x04, false)
354 MUX_CFG(TNETV107X
, SDIO1_CMD_0
, 3, 20, 0x1f, 0x1c, false)
355 MUX_CFG(TNETV107X
, ASR_A23
, 3, 25, 0x1f, 0x00, false)
356 MUX_CFG(TNETV107X
, GPIO53
, 3, 25, 0x1f, 0x04, false)
357 MUX_CFG(TNETV107X
, SDIO1_CLK_0
, 3, 25, 0x1f, 0x1c, false)
358 MUX_CFG(TNETV107X
, ASR_BA_1
, 4, 0, 0x1f, 0x00, false)
359 MUX_CFG(TNETV107X
, GPIO54
, 4, 0, 0x1f, 0x04, false)
360 MUX_CFG(TNETV107X
, SYS_PLL_CLK
, 4, 0, 0x1f, 0x1c, false)
361 MUX_CFG(TNETV107X
, ASR_CS0
, 4, 5, 0x1f, 0x00, false)
362 MUX_CFG(TNETV107X
, ASR_CS1
, 4, 10, 0x1f, 0x00, false)
363 MUX_CFG(TNETV107X
, ASR_CS2
, 4, 15, 0x1f, 0x00, false)
364 MUX_CFG(TNETV107X
, TDM_PLL_CLK
, 4, 15, 0x1f, 0x1c, false)
365 MUX_CFG(TNETV107X
, ASR_CS3
, 4, 20, 0x1f, 0x00, false)
366 MUX_CFG(TNETV107X
, ETH_PHY_CLK
, 4, 20, 0x1f, 0x0c, false)
367 MUX_CFG(TNETV107X
, ASR_D00
, 4, 25, 0x1f, 0x00, false)
368 MUX_CFG(TNETV107X
, GPIO55
, 4, 25, 0x1f, 0x1c, false)
369 MUX_CFG(TNETV107X
, ASR_D01
, 5, 0, 0x1f, 0x00, false)
370 MUX_CFG(TNETV107X
, GPIO56
, 5, 0, 0x1f, 0x1c, false)
371 MUX_CFG(TNETV107X
, ASR_D02
, 5, 5, 0x1f, 0x00, false)
372 MUX_CFG(TNETV107X
, GPIO57
, 5, 5, 0x1f, 0x1c, false)
373 MUX_CFG(TNETV107X
, ASR_D03
, 5, 10, 0x1f, 0x00, false)
374 MUX_CFG(TNETV107X
, GPIO58
, 5, 10, 0x1f, 0x1c, false)
375 MUX_CFG(TNETV107X
, ASR_D04
, 5, 15, 0x1f, 0x00, false)
376 MUX_CFG(TNETV107X
, GPIO59_0
, 5, 15, 0x1f, 0x1c, false)
377 MUX_CFG(TNETV107X
, ASR_D05
, 5, 20, 0x1f, 0x00, false)
378 MUX_CFG(TNETV107X
, GPIO60_0
, 5, 20, 0x1f, 0x1c, false)
379 MUX_CFG(TNETV107X
, ASR_D06
, 5, 25, 0x1f, 0x00, false)
380 MUX_CFG(TNETV107X
, GPIO61_0
, 5, 25, 0x1f, 0x1c, false)
381 MUX_CFG(TNETV107X
, ASR_D07
, 6, 0, 0x1f, 0x00, false)
382 MUX_CFG(TNETV107X
, GPIO62_0
, 6, 0, 0x1f, 0x1c, false)
383 MUX_CFG(TNETV107X
, ASR_D08
, 6, 5, 0x1f, 0x00, false)
384 MUX_CFG(TNETV107X
, GPIO63_0
, 6, 5, 0x1f, 0x1c, false)
385 MUX_CFG(TNETV107X
, ASR_D09
, 6, 10, 0x1f, 0x00, false)
386 MUX_CFG(TNETV107X
, GPIO64_0
, 6, 10, 0x1f, 0x1c, false)
387 MUX_CFG(TNETV107X
, ASR_D10
, 6, 15, 0x1f, 0x00, false)
388 MUX_CFG(TNETV107X
, SDIO1_DATA3_1
, 6, 15, 0x1f, 0x1c, false)
389 MUX_CFG(TNETV107X
, ASR_D11
, 6, 20, 0x1f, 0x00, false)
390 MUX_CFG(TNETV107X
, SDIO1_DATA2_1
, 6, 20, 0x1f, 0x1c, false)
391 MUX_CFG(TNETV107X
, ASR_D12
, 6, 25, 0x1f, 0x00, false)
392 MUX_CFG(TNETV107X
, SDIO1_DATA1_1
, 6, 25, 0x1f, 0x1c, false)
393 MUX_CFG(TNETV107X
, ASR_D13
, 7, 0, 0x1f, 0x00, false)
394 MUX_CFG(TNETV107X
, SDIO1_DATA0_1
, 7, 0, 0x1f, 0x1c, false)
395 MUX_CFG(TNETV107X
, ASR_D14
, 7, 5, 0x1f, 0x00, false)
396 MUX_CFG(TNETV107X
, SDIO1_CMD_1
, 7, 5, 0x1f, 0x1c, false)
397 MUX_CFG(TNETV107X
, ASR_D15
, 7, 10, 0x1f, 0x00, false)
398 MUX_CFG(TNETV107X
, SDIO1_CLK_1
, 7, 10, 0x1f, 0x1c, false)
399 MUX_CFG(TNETV107X
, ASR_OE
, 7, 15, 0x1f, 0x00, false)
400 MUX_CFG(TNETV107X
, BOOT_STRP_2
, 7, 15, 0x1f, 0x04, false)
401 MUX_CFG(TNETV107X
, ASR_RNW
, 7, 20, 0x1f, 0x00, false)
402 MUX_CFG(TNETV107X
, GPIO29_0
, 7, 20, 0x1f, 0x04, false)
403 MUX_CFG(TNETV107X
, ASR_WAIT
, 7, 25, 0x1f, 0x00, false)
404 MUX_CFG(TNETV107X
, GPIO30_0
, 7, 25, 0x1f, 0x04, false)
405 MUX_CFG(TNETV107X
, ASR_WE
, 8, 0, 0x1f, 0x00, false)
406 MUX_CFG(TNETV107X
, BOOT_STRP_3
, 8, 0, 0x1f, 0x04, false)
407 MUX_CFG(TNETV107X
, ASR_WE_DQM0
, 8, 5, 0x1f, 0x00, false)
408 MUX_CFG(TNETV107X
, GPIO31
, 8, 5, 0x1f, 0x04, false)
409 MUX_CFG(TNETV107X
, LCD_PD17_0
, 8, 5, 0x1f, 0x1c, false)
410 MUX_CFG(TNETV107X
, ASR_WE_DQM1
, 8, 10, 0x1f, 0x00, false)
411 MUX_CFG(TNETV107X
, ASR_BA0_0
, 8, 10, 0x1f, 0x04, false)
412 MUX_CFG(TNETV107X
, VLYNQ_CLK
, 9, 0, 0x1f, 0x00, false)
413 MUX_CFG(TNETV107X
, GPIO14
, 9, 0, 0x1f, 0x04, false)
414 MUX_CFG(TNETV107X
, LCD_PD19_0
, 9, 0, 0x1f, 0x1c, false)
415 MUX_CFG(TNETV107X
, VLYNQ_RXD0
, 9, 5, 0x1f, 0x00, false)
416 MUX_CFG(TNETV107X
, GPIO15
, 9, 5, 0x1f, 0x04, false)
417 MUX_CFG(TNETV107X
, LCD_PD20_0
, 9, 5, 0x1f, 0x1c, false)
418 MUX_CFG(TNETV107X
, VLYNQ_RXD1
, 9, 10, 0x1f, 0x00, false)
419 MUX_CFG(TNETV107X
, GPIO16
, 9, 10, 0x1f, 0x04, false)
420 MUX_CFG(TNETV107X
, LCD_PD21_0
, 9, 10, 0x1f, 0x1c, false)
421 MUX_CFG(TNETV107X
, VLYNQ_TXD0
, 9, 15, 0x1f, 0x00, false)
422 MUX_CFG(TNETV107X
, GPIO17
, 9, 15, 0x1f, 0x04, false)
423 MUX_CFG(TNETV107X
, LCD_PD22_0
, 9, 15, 0x1f, 0x1c, false)
424 MUX_CFG(TNETV107X
, VLYNQ_TXD1
, 9, 20, 0x1f, 0x00, false)
425 MUX_CFG(TNETV107X
, GPIO18
, 9, 20, 0x1f, 0x04, false)
426 MUX_CFG(TNETV107X
, LCD_PD23_0
, 9, 20, 0x1f, 0x1c, false)
427 MUX_CFG(TNETV107X
, SDIO0_CLK
, 10, 0, 0x1f, 0x00, false)
428 MUX_CFG(TNETV107X
, GPIO19
, 10, 0, 0x1f, 0x04, false)
429 MUX_CFG(TNETV107X
, SDIO0_CMD
, 10, 5, 0x1f, 0x00, false)
430 MUX_CFG(TNETV107X
, GPIO20
, 10, 5, 0x1f, 0x04, false)
431 MUX_CFG(TNETV107X
, SDIO0_DATA0
, 10, 10, 0x1f, 0x00, false)
432 MUX_CFG(TNETV107X
, GPIO21
, 10, 10, 0x1f, 0x04, false)
433 MUX_CFG(TNETV107X
, SDIO0_DATA1
, 10, 15, 0x1f, 0x00, false)
434 MUX_CFG(TNETV107X
, GPIO22
, 10, 15, 0x1f, 0x04, false)
435 MUX_CFG(TNETV107X
, SDIO0_DATA2
, 10, 20, 0x1f, 0x00, false)
436 MUX_CFG(TNETV107X
, GPIO23
, 10, 20, 0x1f, 0x04, false)
437 MUX_CFG(TNETV107X
, SDIO0_DATA3
, 10, 25, 0x1f, 0x00, false)
438 MUX_CFG(TNETV107X
, GPIO24
, 10, 25, 0x1f, 0x04, false)
439 MUX_CFG(TNETV107X
, EMU0
, 11, 0, 0x1f, 0x00, false)
440 MUX_CFG(TNETV107X
, EMU1
, 11, 5, 0x1f, 0x00, false)
441 MUX_CFG(TNETV107X
, RTCK
, 12, 0, 0x1f, 0x00, false)
442 MUX_CFG(TNETV107X
, TRST_N
, 12, 5, 0x1f, 0x00, false)
443 MUX_CFG(TNETV107X
, TCK
, 12, 10, 0x1f, 0x00, false)
444 MUX_CFG(TNETV107X
, TDI
, 12, 15, 0x1f, 0x00, false)
445 MUX_CFG(TNETV107X
, TDO
, 12, 20, 0x1f, 0x00, false)
446 MUX_CFG(TNETV107X
, TMS
, 12, 25, 0x1f, 0x00, false)
447 MUX_CFG(TNETV107X
, TDM1_CLK
, 13, 0, 0x1f, 0x00, false)
448 MUX_CFG(TNETV107X
, TDM1_RX
, 13, 5, 0x1f, 0x00, false)
449 MUX_CFG(TNETV107X
, TDM1_TX
, 13, 10, 0x1f, 0x00, false)
450 MUX_CFG(TNETV107X
, TDM1_FS
, 13, 15, 0x1f, 0x00, false)
451 MUX_CFG(TNETV107X
, KEYPAD_R0
, 14, 0, 0x1f, 0x00, false)
452 MUX_CFG(TNETV107X
, KEYPAD_R1
, 14, 5, 0x1f, 0x00, false)
453 MUX_CFG(TNETV107X
, KEYPAD_R2
, 14, 10, 0x1f, 0x00, false)
454 MUX_CFG(TNETV107X
, KEYPAD_R3
, 14, 15, 0x1f, 0x00, false)
455 MUX_CFG(TNETV107X
, KEYPAD_R4
, 14, 20, 0x1f, 0x00, false)
456 MUX_CFG(TNETV107X
, KEYPAD_R5
, 14, 25, 0x1f, 0x00, false)
457 MUX_CFG(TNETV107X
, KEYPAD_R6
, 15, 0, 0x1f, 0x00, false)
458 MUX_CFG(TNETV107X
, GPIO12
, 15, 0, 0x1f, 0x04, false)
459 MUX_CFG(TNETV107X
, KEYPAD_R7
, 15, 5, 0x1f, 0x00, false)
460 MUX_CFG(TNETV107X
, GPIO10
, 15, 5, 0x1f, 0x04, false)
461 MUX_CFG(TNETV107X
, KEYPAD_C0
, 15, 10, 0x1f, 0x00, false)
462 MUX_CFG(TNETV107X
, KEYPAD_C1
, 15, 15, 0x1f, 0x00, false)
463 MUX_CFG(TNETV107X
, KEYPAD_C2
, 15, 20, 0x1f, 0x00, false)
464 MUX_CFG(TNETV107X
, KEYPAD_C3
, 15, 25, 0x1f, 0x00, false)
465 MUX_CFG(TNETV107X
, KEYPAD_C4
, 16, 0, 0x1f, 0x00, false)
466 MUX_CFG(TNETV107X
, KEYPAD_C5
, 16, 5, 0x1f, 0x00, false)
467 MUX_CFG(TNETV107X
, KEYPAD_C6
, 16, 10, 0x1f, 0x00, false)
468 MUX_CFG(TNETV107X
, GPIO13
, 16, 10, 0x1f, 0x04, false)
469 MUX_CFG(TNETV107X
, TEST_CLK_IN
, 16, 10, 0x1f, 0x0c, false)
470 MUX_CFG(TNETV107X
, KEYPAD_C7
, 16, 15, 0x1f, 0x00, false)
471 MUX_CFG(TNETV107X
, GPIO11
, 16, 15, 0x1f, 0x04, false)
472 MUX_CFG(TNETV107X
, SSP0_0
, 17, 0, 0x1f, 0x00, false)
473 MUX_CFG(TNETV107X
, SCC_DCLK
, 17, 0, 0x1f, 0x04, false)
474 MUX_CFG(TNETV107X
, LCD_PD20_1
, 17, 0, 0x1f, 0x0c, false)
475 MUX_CFG(TNETV107X
, SSP0_1
, 17, 5, 0x1f, 0x00, false)
476 MUX_CFG(TNETV107X
, SCC_CS_N
, 17, 5, 0x1f, 0x04, false)
477 MUX_CFG(TNETV107X
, LCD_PD21_1
, 17, 5, 0x1f, 0x0c, false)
478 MUX_CFG(TNETV107X
, SSP0_2
, 17, 10, 0x1f, 0x00, false)
479 MUX_CFG(TNETV107X
, SCC_D
, 17, 10, 0x1f, 0x04, false)
480 MUX_CFG(TNETV107X
, LCD_PD22_1
, 17, 10, 0x1f, 0x0c, false)
481 MUX_CFG(TNETV107X
, SSP0_3
, 17, 15, 0x1f, 0x00, false)
482 MUX_CFG(TNETV107X
, SCC_RESETN
, 17, 15, 0x1f, 0x04, false)
483 MUX_CFG(TNETV107X
, LCD_PD23_1
, 17, 15, 0x1f, 0x0c, false)
484 MUX_CFG(TNETV107X
, SSP1_0
, 18, 0, 0x1f, 0x00, false)
485 MUX_CFG(TNETV107X
, GPIO25
, 18, 0, 0x1f, 0x04, false)
486 MUX_CFG(TNETV107X
, UART2_CTS
, 18, 0, 0x1f, 0x0c, false)
487 MUX_CFG(TNETV107X
, SSP1_1
, 18, 5, 0x1f, 0x00, false)
488 MUX_CFG(TNETV107X
, GPIO26
, 18, 5, 0x1f, 0x04, false)
489 MUX_CFG(TNETV107X
, UART2_RD
, 18, 5, 0x1f, 0x0c, false)
490 MUX_CFG(TNETV107X
, SSP1_2
, 18, 10, 0x1f, 0x00, false)
491 MUX_CFG(TNETV107X
, GPIO27
, 18, 10, 0x1f, 0x04, false)
492 MUX_CFG(TNETV107X
, UART2_RTS
, 18, 10, 0x1f, 0x0c, false)
493 MUX_CFG(TNETV107X
, SSP1_3
, 18, 15, 0x1f, 0x00, false)
494 MUX_CFG(TNETV107X
, GPIO28
, 18, 15, 0x1f, 0x04, false)
495 MUX_CFG(TNETV107X
, UART2_TD
, 18, 15, 0x1f, 0x0c, false)
496 MUX_CFG(TNETV107X
, UART0_CTS
, 19, 0, 0x1f, 0x00, false)
497 MUX_CFG(TNETV107X
, UART0_RD
, 19, 5, 0x1f, 0x00, false)
498 MUX_CFG(TNETV107X
, UART0_RTS
, 19, 10, 0x1f, 0x00, false)
499 MUX_CFG(TNETV107X
, UART0_TD
, 19, 15, 0x1f, 0x00, false)
500 MUX_CFG(TNETV107X
, UART1_RD
, 19, 20, 0x1f, 0x00, false)
501 MUX_CFG(TNETV107X
, UART1_TD
, 19, 25, 0x1f, 0x00, false)
502 MUX_CFG(TNETV107X
, LCD_AC_NCS
, 20, 0, 0x1f, 0x00, false)
503 MUX_CFG(TNETV107X
, LCD_HSYNC_RNW
, 20, 5, 0x1f, 0x00, false)
504 MUX_CFG(TNETV107X
, LCD_VSYNC_A0
, 20, 10, 0x1f, 0x00, false)
505 MUX_CFG(TNETV107X
, LCD_MCLK
, 20, 15, 0x1f, 0x00, false)
506 MUX_CFG(TNETV107X
, LCD_PD16_0
, 20, 15, 0x1f, 0x0c, false)
507 MUX_CFG(TNETV107X
, LCD_PCLK_E
, 20, 20, 0x1f, 0x00, false)
508 MUX_CFG(TNETV107X
, LCD_PD00
, 20, 25, 0x1f, 0x00, false)
509 MUX_CFG(TNETV107X
, LCD_PD01
, 21, 0, 0x1f, 0x00, false)
510 MUX_CFG(TNETV107X
, LCD_PD02
, 21, 5, 0x1f, 0x00, false)
511 MUX_CFG(TNETV107X
, LCD_PD03
, 21, 10, 0x1f, 0x00, false)
512 MUX_CFG(TNETV107X
, LCD_PD04
, 21, 15, 0x1f, 0x00, false)
513 MUX_CFG(TNETV107X
, LCD_PD05
, 21, 20, 0x1f, 0x00, false)
514 MUX_CFG(TNETV107X
, LCD_PD06
, 21, 25, 0x1f, 0x00, false)
515 MUX_CFG(TNETV107X
, LCD_PD07
, 22, 0, 0x1f, 0x00, false)
516 MUX_CFG(TNETV107X
, LCD_PD08
, 22, 5, 0x1f, 0x00, false)
517 MUX_CFG(TNETV107X
, GPIO59_1
, 22, 5, 0x1f, 0x0c, false)
518 MUX_CFG(TNETV107X
, LCD_PD09
, 22, 10, 0x1f, 0x00, false)
519 MUX_CFG(TNETV107X
, GPIO60_1
, 22, 10, 0x1f, 0x0c, false)
520 MUX_CFG(TNETV107X
, LCD_PD10
, 22, 15, 0x1f, 0x00, false)
521 MUX_CFG(TNETV107X
, ASR_BA0_1
, 22, 15, 0x1f, 0x04, false)
522 MUX_CFG(TNETV107X
, GPIO61_1
, 22, 15, 0x1f, 0x0c, false)
523 MUX_CFG(TNETV107X
, LCD_PD11
, 22, 20, 0x1f, 0x00, false)
524 MUX_CFG(TNETV107X
, GPIO62_1
, 22, 20, 0x1f, 0x0c, false)
525 MUX_CFG(TNETV107X
, LCD_PD12
, 22, 25, 0x1f, 0x00, false)
526 MUX_CFG(TNETV107X
, GPIO63_1
, 22, 25, 0x1f, 0x0c, false)
527 MUX_CFG(TNETV107X
, LCD_PD13
, 23, 0, 0x1f, 0x00, false)
528 MUX_CFG(TNETV107X
, GPIO64_1
, 23, 0, 0x1f, 0x0c, false)
529 MUX_CFG(TNETV107X
, LCD_PD14
, 23, 5, 0x1f, 0x00, false)
530 MUX_CFG(TNETV107X
, GPIO29_1
, 23, 5, 0x1f, 0x0c, false)
531 MUX_CFG(TNETV107X
, LCD_PD15
, 23, 10, 0x1f, 0x00, false)
532 MUX_CFG(TNETV107X
, GPIO30_1
, 23, 10, 0x1f, 0x0c, false)
533 MUX_CFG(TNETV107X
, EINT0
, 24, 0, 0x1f, 0x00, false)
534 MUX_CFG(TNETV107X
, GPIO08
, 24, 0, 0x1f, 0x04, false)
535 MUX_CFG(TNETV107X
, EINT1
, 24, 5, 0x1f, 0x00, false)
536 MUX_CFG(TNETV107X
, GPIO09
, 24, 5, 0x1f, 0x04, false)
537 MUX_CFG(TNETV107X
, GPIO00
, 24, 10, 0x1f, 0x00, false)
538 MUX_CFG(TNETV107X
, LCD_PD20_2
, 24, 10, 0x1f, 0x04, false)
539 MUX_CFG(TNETV107X
, TDM_CLK_IN_2
, 24, 10, 0x1f, 0x0c, false)
540 MUX_CFG(TNETV107X
, GPIO01
, 24, 15, 0x1f, 0x00, false)
541 MUX_CFG(TNETV107X
, LCD_PD21_2
, 24, 15, 0x1f, 0x04, false)
542 MUX_CFG(TNETV107X
, 24M_CLK_OUT_1
, 24, 15, 0x1f, 0x0c, false)
543 MUX_CFG(TNETV107X
, GPIO02
, 24, 20, 0x1f, 0x00, false)
544 MUX_CFG(TNETV107X
, LCD_PD22_2
, 24, 20, 0x1f, 0x04, false)
545 MUX_CFG(TNETV107X
, GPIO03
, 24, 25, 0x1f, 0x00, false)
546 MUX_CFG(TNETV107X
, LCD_PD23_2
, 24, 25, 0x1f, 0x04, false)
547 MUX_CFG(TNETV107X
, GPIO04
, 25, 0, 0x1f, 0x00, false)
548 MUX_CFG(TNETV107X
, LCD_PD16_1
, 25, 0, 0x1f, 0x04, false)
549 MUX_CFG(TNETV107X
, USB0_RXERR
, 25, 0, 0x1f, 0x0c, false)
550 MUX_CFG(TNETV107X
, GPIO05
, 25, 5, 0x1f, 0x00, false)
551 MUX_CFG(TNETV107X
, LCD_PD17_1
, 25, 5, 0x1f, 0x04, false)
552 MUX_CFG(TNETV107X
, TDM_CLK_IN_1
, 25, 5, 0x1f, 0x0c, false)
553 MUX_CFG(TNETV107X
, GPIO06
, 25, 10, 0x1f, 0x00, false)
554 MUX_CFG(TNETV107X
, LCD_PD18
, 25, 10, 0x1f, 0x04, false)
555 MUX_CFG(TNETV107X
, 24M_CLK_OUT_2
, 25, 10, 0x1f, 0x0c, false)
556 MUX_CFG(TNETV107X
, GPIO07
, 25, 15, 0x1f, 0x00, false)
557 MUX_CFG(TNETV107X
, LCD_PD19_1
, 25, 15, 0x1f, 0x04, false)
558 MUX_CFG(TNETV107X
, USB1_RXERR
, 25, 15, 0x1f, 0x0c, false)
559 MUX_CFG(TNETV107X
, ETH_PLL_CLK
, 25, 15, 0x1f, 0x1c, false)
560 MUX_CFG(TNETV107X
, MDIO
, 26, 0, 0x1f, 0x00, false)
561 MUX_CFG(TNETV107X
, MDC
, 26, 5, 0x1f, 0x00, false)
562 MUX_CFG(TNETV107X
, AIC_MUTE_STAT_N
, 26, 10, 0x1f, 0x00, false)
563 MUX_CFG(TNETV107X
, TDM0_CLK
, 26, 10, 0x1f, 0x04, false)
564 MUX_CFG(TNETV107X
, AIC_HNS_EN_N
, 26, 15, 0x1f, 0x00, false)
565 MUX_CFG(TNETV107X
, TDM0_FS
, 26, 15, 0x1f, 0x04, false)
566 MUX_CFG(TNETV107X
, AIC_HDS_EN_STAT_N
, 26, 20, 0x1f, 0x00, false)
567 MUX_CFG(TNETV107X
, TDM0_TX
, 26, 20, 0x1f, 0x04, false)
568 MUX_CFG(TNETV107X
, AIC_HNF_EN_STAT_N
, 26, 25, 0x1f, 0x00, false)
569 MUX_CFG(TNETV107X
, TDM0_RX
, 26, 25, 0x1f, 0x04, false)
573 /* FIQ are pri 0-1; otherwise 2-7, with 7 lowest priority */
574 static u8 irq_prios
[TNETV107X_N_CP_INTC_IRQ
] = {
575 /* fill in default priority 7 */
576 [0 ... (TNETV107X_N_CP_INTC_IRQ
- 1)] = 7,
577 /* now override as needed, e.g. [xxx] = 5 */
580 /* Contents of JTAG ID register used to identify exact cpu type */
581 static struct davinci_id ids
[] = {
585 .manufacturer
= 0x017,
586 .cpu_id
= DAVINCI_CPU_ID_TNETV107X
,
587 .name
= "tnetv107x rev 1.0",
592 .manufacturer
= 0x017,
593 .cpu_id
= DAVINCI_CPU_ID_TNETV107X
,
594 .name
= "tnetv107x rev 1.1/1.2",
598 static struct davinci_timer_instance timer_instance
[2] = {
600 .base
= TNETV107X_TIMER0_BASE
,
601 .bottom_irq
= IRQ_TNETV107X_TIMER_0_TINT12
,
602 .top_irq
= IRQ_TNETV107X_TIMER_0_TINT34
,
605 .base
= TNETV107X_TIMER1_BASE
,
606 .bottom_irq
= IRQ_TNETV107X_TIMER_1_TINT12
,
607 .top_irq
= IRQ_TNETV107X_TIMER_1_TINT34
,
611 static struct davinci_timer_info timer_info
= {
612 .timers
= timer_instance
,
613 .clockevent_id
= T0_BOT
,
614 .clocksource_id
= T0_TOP
,
618 * TNETV107X platforms do not use the static mappings from Davinci
619 * IO_PHYS/IO_VIRT. This SOC's interesting MMRs are at different addresses,
620 * and changing IO_PHYS would break away from existing Davinci SOCs.
622 * The primary impact of the current model is that IO_ADDRESS() is not to be
623 * used to map registers on TNETV107X.
625 * 1. The first chunk is for INTC: This needs to be mapped in via iotable
626 * because ioremap() does not seem to be operational at the time when
627 * irqs are initialized. Without this, consistent dma init bombs.
629 * 2. The second chunk maps in register areas that need to be populated into
630 * davinci_soc_info. Note that alignment restrictions come into play if
631 * low-level debug is enabled (see note in <mach/tnetv107x.h>).
633 static struct map_desc io_desc
[] = {
636 .pfn
= __phys_to_pfn(TNETV107X_INTC_BASE
),
640 { /* Most of the rest */
641 .virtual = TNETV107X_IO_VIRT
,
642 .pfn
= __phys_to_pfn(TNETV107X_IO_BASE
),
643 .length
= IO_SIZE
- SZ_1M
,
648 static unsigned long clk_sspll_recalc(struct clk
*clk
)
651 unsigned long mult
= 0, prediv
= 1, postdiv
= 1;
652 unsigned long ref
= OSC_FREQ_ONCHIP
, ret
;
655 if (WARN_ON(!clk
->pll_data
))
658 if (!clk_ctrl_regs
) {
661 tmp
= ioremap(TNETV107X_CLOCK_CONTROL_BASE
, SZ_4K
);
663 if (WARN(!tmp
, "failed ioremap for clock control regs\n"))
664 return clk
->parent
? clk
->parent
->rate
: 0;
666 for (pll
= 0; pll
< N_PLLS
; pll
++)
667 sspll_regs
[pll
] = tmp
+ sspll_regs_base
[pll
];
672 pll
= clk
->pll_data
->num
;
674 tmp
= __raw_readl(&clk_ctrl_regs
->pll_bypass
);
675 if (!(tmp
& bypass_mask
[pll
])) {
676 mult
= __raw_readl(&sspll_regs
[pll
]->mult_factor
);
677 prediv
= __raw_readl(&sspll_regs
[pll
]->pre_div
) + 1;
678 postdiv
= __raw_readl(&sspll_regs
[pll
]->post_div
) + 1;
681 tmp
= __raw_readl(clk
->pll_data
->base
+ PLLCTL
);
682 if (tmp
& PLLCTL_CLKMODE
)
683 ref
= pll_ext_freq
[pll
];
685 clk
->pll_data
->input_rate
= ref
;
687 tmp
= __raw_readl(clk
->pll_data
->base
+ PLLCTL
);
688 if (!(tmp
& PLLCTL_PLLEN
))
693 ret
+= ((unsigned long long)ref
* mult
) / 256;
695 ret
/= (prediv
* postdiv
);
700 static void tnetv107x_watchdog_reset(struct platform_device
*pdev
)
702 struct wdt_regs __iomem
*regs
;
704 regs
= ioremap(pdev
->resource
[0].start
, SZ_4K
);
706 /* disable watchdog */
707 __raw_writel(0x7777, ®s
->disable_lock
);
708 __raw_writel(0xcccc, ®s
->disable_lock
);
709 __raw_writel(0xdddd, ®s
->disable_lock
);
710 __raw_writel(0, ®s
->disable
);
712 /* program prescale */
713 __raw_writel(0x5a5a, ®s
->prescale_lock
);
714 __raw_writel(0xa5a5, ®s
->prescale_lock
);
715 __raw_writel(0, ®s
->prescale
);
717 /* program countdown */
718 __raw_writel(0x6666, ®s
->change_lock
);
719 __raw_writel(0xbbbb, ®s
->change_lock
);
720 __raw_writel(1, ®s
->change
);
722 /* enable watchdog */
723 __raw_writel(0x7777, ®s
->disable_lock
);
724 __raw_writel(0xcccc, ®s
->disable_lock
);
725 __raw_writel(0xdddd, ®s
->disable_lock
);
726 __raw_writel(1, ®s
->disable
);
729 __raw_writel(0x5555, ®s
->kick_lock
);
730 __raw_writel(0xaaaa, ®s
->kick_lock
);
731 __raw_writel(1, ®s
->kick
);
734 void tnetv107x_restart(enum reboot_mode mode
, const char *cmd
)
736 tnetv107x_watchdog_reset(&tnetv107x_wdt_device
);
739 static struct davinci_soc_info tnetv107x_soc_info
= {
741 .io_desc_num
= ARRAY_SIZE(io_desc
),
743 .ids_num
= ARRAY_SIZE(ids
),
744 .jtag_id_reg
= TNETV107X_CHIP_CFG_BASE
+ 0x018,
746 .psc_bases
= psc_regs
,
747 .psc_bases_num
= ARRAY_SIZE(psc_regs
),
748 .pinmux_base
= TNETV107X_CHIP_CFG_BASE
+ 0x150,
750 .pinmux_pins_num
= ARRAY_SIZE(pins
),
751 .intc_type
= DAVINCI_INTC_TYPE_CP_INTC
,
752 .intc_base
= TNETV107X_INTC_BASE
,
753 .intc_irq_prios
= irq_prios
,
754 .intc_irq_num
= TNETV107X_N_CP_INTC_IRQ
,
755 .intc_host_map
= intc_host_map
,
756 .gpio_base
= TNETV107X_GPIO_BASE
,
757 .gpio_type
= GPIO_TYPE_TNETV107X
,
758 .gpio_num
= TNETV107X_N_GPIO
,
759 .timer_info
= &timer_info
,
760 .serial_dev
= &tnetv107x_serial_device
,
763 void __init
tnetv107x_init(void)
765 davinci_common_init(&tnetv107x_soc_info
);