]>
git.ipfire.org Git - people/ms/u-boot.git/blob - arch/arm/cpu/armv7/am33xx/board.c
78db3a50e5f295b18db7e4d0c324853e39dec870
4 * Common board functions for AM33XX based boards
6 * Copyright (C) 2011, Texas Instruments, Incorporated - http://www.ti.com/
8 * This program is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU General Public License as
10 * published by the Free Software Foundation; either version 2 of
11 * the License, or (at your option) any later version.
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR /PURPOSE. See the
16 * GNU General Public License for more details.
20 #include <asm/arch/cpu.h>
21 #include <asm/arch/hardware.h>
22 #include <asm/arch/ddr_defs.h>
23 #include <asm/arch/clock.h>
26 DECLARE_GLOBAL_DATA_PTR
;
28 struct wd_timer
*wdtimer
= (struct wd_timer
*)WDT_BASE
;
29 struct gptimer
*timer_base
= (struct gptimer
*)CONFIG_SYS_TIMERBASE
;
32 * early system init of muxing and clocks.
34 void s_init(u32 in_ddr
)
36 /* WDT1 is already running when the bootloader gets control
37 * Disable it to avoid "random" resets
39 writel(0xAAAA, &wdtimer
->wdtwspr
);
40 while (readl(&wdtimer
->wdtwwps
) != 0x0)
42 writel(0x5555, &wdtimer
->wdtwspr
);
43 while (readl(&wdtimer
->wdtwwps
) != 0x0)
46 /* Setup the PLLs and the clocks for the peripherals */
47 #ifdef CONFIG_SETUP_PLL
54 /* Initialize timer */
58 writel(0x2, (&timer_base
->tscir
));
60 /* Wait until the reset is done */
61 while (readl(&timer_base
->tiocp_cfg
) & 1)
65 writel(0x1, (&timer_base
->tclr
));