📄 omap2420h4.c
字号:
/* * Copyright (C) 2005 Texas Instruments. * Jian Zhang <jzhang@ti.com> * Richard Woodruff <r-woodruff2@ti.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 */#include <common.h>#include <asm/arch/omap2420.h>#include <asm/arch/bits.h>#include <asm/arch/mem.h>#include <asm/arch/sys_info.h>#include <asm/arch/clocks.h>static void wait_for_command_complete(unsigned int wd_base);static void watchdog_init(void);static void peripheral_enable(void);static void muxSetupUART1(void);static u32 get_cpu_rev(void);/******************************************************* * Routine: delay * Description: spinning delay to use before udelay works ******************************************************/static inline void delay (unsigned long loops){ __asm__ volatile ("1:\n" "subs %0, %1, #1\n" "bne 1b":"=r" (loops):"0" (loops));}/***************************************** * Routine: board_init * Description: Early hardware init. *****************************************/int board_init (void){ return 0;}#ifdef CFG_SDRAM_DDRvoidconfig_sdram_ddr(u32 rev){ /* ball D11, mode 0 */ __raw_writeb(0x08, 0x48000032); /* SDRC_CS0 Configuration */ if (rev == CPU_2420_2422_ES1) { __raw_writel(H4_2422_SDRC_MDCFG_0_DDR, SDRC_MCFG_0); __raw_writel(H4_2422_SDRC_SHARING, SDRC_SHARING); } else { __raw_writel(H4_2420_SDRC_MDCFG_0_DDR, SDRC_MCFG_0); __raw_writel(H4_2420_SDRC_SHARING, SDRC_SHARING); } __raw_writel(H4_242x_SDRC_RFR_CTRL_ES1, SDRC_RFR_CTRL); __raw_writel(H4_242x_SDRC_ACTIM_CTRLA_0_ES1, SDRC_ACTIM_CTRLA_0); __raw_writel(H4_242x_SDRC_ACTIM_CTRLB_0_ES1, SDRC_ACTIM_CTRLB_0); /* Manual Command sequence */ __raw_writel(CMD_NOP, SDRC_MANUAL_0); __raw_writel(CMD_PRECHARGE, SDRC_MANUAL_0); __raw_writel(CMD_AUTOREFRESH, SDRC_MANUAL_0); __raw_writel(CMD_AUTOREFRESH, SDRC_MANUAL_0); /* * CS0 SDRC Mode Register * Burst length = 4 - DDR memory * Serial mode * CAS latency = 3 */ __raw_writel(0x00000032, SDRC_MR_0); /* SDRC DLLA control register */ /* Delay is 90 degrees */ if (rev == CPU_2420_2422_ES1) { /* Enable DLL, Load counter with 115 (middle of range) */ __raw_writel(0x00000002, SDRC_DLLA_CTRL); /* Enable DLL, Load counter with 128 (middle of range) */ __raw_writel(0x00000002, SDRC_DLLB_CTRL); } else { /* Enable DLL, Load counter with 115 (middle of range) */ __raw_writel(0x00000008, SDRC_DLLA_CTRL); // ES2.x /* Enable DLL, Load counter with 128 (middle of range) */ __raw_writel(0x00000008, SDRC_DLLB_CTRL); // ES2.x }}#endif // CFG_SDRAM_DDR#ifdef CFG_SDRAM_COMBO voidconfig_sdram_combo(u32 rev){ u32 dllctrl=0; /* ball C12, mode 0 */ __raw_writeb(0x00, 0x480000a1); /* ball D11, mode 0 */ __raw_writeb(0x00, 0x48000032); /* ball B13, mode 0 - for CKE1 (not needed rkw for combo) */ __raw_writeb(0x00, 0x480000a3); /*configure sdrc 32 bit for COMBO ddr sdram. Issue soft reset */ __raw_writel(0x00000012, SDRC_SYSCONFIG); delay(200000); __raw_writel(0x00000010, SDRC_SYSCONFIG); /* SDRCTriState: no Tris */ /* CS0MuxCfg: 000 (32-bit SDRAM on D31..0) */ __raw_writel(H4_2420_SDRC_SHARING, SDRC_SHARING); /* CS0 SDRC Memory Configuration, */ /* DDR-SDRAM, External SDRAM is x32bit, */ /* Configure to MUX9: 1x8Mbx32 */ __raw_writel(H4_2420_COMBO_MDCFG_0_DDR, SDRC_MCFG_0); __raw_writel(H4_2420_SDRC_ACTIM_CTRLA_0, SDRC_ACTIM_CTRLA_0); __raw_writel(H4_2420_SDRC_ACTIM_CTRLB_0, SDRC_ACTIM_CTRLB_0); __raw_writel(H4_242x_SDRC_RFR_CTRL_ES1, SDRC_RFR_CTRL); /* Manual Command sequence */ __raw_writel(CMD_NOP, SDRC_MANUAL_0); __raw_writel(CMD_PRECHARGE, SDRC_MANUAL_0); __raw_writel(CMD_AUTOREFRESH, SDRC_MANUAL_0); __raw_writel(CMD_AUTOREFRESH, SDRC_MANUAL_0); /* CS0 SDRC Mode Register */ /* Burst length = 4 - DDR memory */ /* Serial mode */ /* CAS latency = 3 */ __raw_writel(H4_2422_SDRC_MR_0_DDR, SDRC_MR_0); /* CS1 SDRC Memory Configuration, */ /* DDR-SDRAM, External SDRAM is x32bit, */ /* Configure to MUX9: 1x8Mbx32 */ __raw_writel(H4_2420_COMBO_MDCFG_0_DDR, SDRC_MCFG_1); __raw_writel(H4_242X_SDRC_ACTIM_CTRLA_0_100MHz, SDRC_ACTIM_CTRLA_1); __raw_writel(H4_2420_SDRC_ACTIM_CTRLB_0, SDRC_ACTIM_CTRLB_1); __raw_writel(H4_242x_SDRC_RFR_CTRL_ES1, 0x680090d4); /* Manual Command sequence */ __raw_writel(CMD_NOP, SDRC_MANUAL_1); __raw_writel(CMD_PRECHARGE, SDRC_MANUAL_1); __raw_writel(CMD_AUTOREFRESH, SDRC_MANUAL_1); __raw_writel(CMD_AUTOREFRESH, SDRC_MANUAL_1); /* CS1 SDRC Mode Register */ /* Burst length = 4 - DDR memory */ /* Serial mode */ /* CAS latency = 3 */ __raw_writel(H4_2422_SDRC_MR_0_DDR, SDRC_MR_1); /* SDRC DLLA control register */ /* Delay is 90 degrees */ if (rev == CPU_242X_ES1) dllctrl = (BIT0|BIT3); else dllctrl = BIT0; if (rev == CPU_2420_2422_ES1) { /* Enable DLL, Load counter with 115 (middle of range) */ __raw_writel(0x00007306, SDRC_DLLA_CTRL); __raw_writel(0x00007302, SDRC_DLLA_CTRL); /* Enable DLL, Load counter with 128 (middle of range) */ __raw_writel(0x00007306, SDRC_DLLB_CTRL); /* load ctr value */ __raw_writel(0x00007302, SDRC_DLLB_CTRL); /* lock and go */ } else { /* Enable DLL, Load counter with 115 (middle of range) */ __raw_writel(H4_2420_SDRC_DLLAB_CTRL, SDRC_DLLA_CTRL); // ES2.x __raw_writel(H4_2420_SDRC_DLLAB_CTRL & ~(LOADDLL|dllctrl), SDRC_DLLA_CTRL); // ES2.x __raw_writel(H4_2420_SDRC_DLLAB_CTRL, SDRC_DLLB_CTRL); // ES2.x ? __raw_writel(H4_2420_SDRC_DLLAB_CTRL & ~(LOADDLL|dllctrl), SDRC_DLLB_CTRL); // ES2.x }}#endif // CFG_SDRAM_COMBO#ifdef CFG_SDRAM_SDR voidconfig_sdram_sdr(u32 rev){ u32 dllctrl=0; /* ball D11, mode 0 */ __raw_writeb(0x00, 0x48000032); __raw_writel(0x00000012, SDRC_SYSCONFIG); delay(200000); __raw_writel(0x00000010, SDRC_SYSCONFIG); /* Chip-level shared interface management */ /* SDRCTriState: no Tris */ /* CS0MuxCfg: 000 (32-bit SDRAM on D31..0) */ /* CS1MuxCfg: 000 (32-bit SDRAM on D31..0) */ if (rev == CPU_2420_2422_ES1) __raw_writel(H4_2422_SDRC_SHARING, SDRC_SHARING); else __raw_writel(H4_2420_SDRC_SHARING, SDRC_SHARING); /* CS0 SDRC Memory Configuration, */ /* DDR-SDRAM, External SDRAM is x32bit, */ /* Configure to MUX14: 32Mbx32 */ __raw_writel(H4_2420_SDRC_MDCFG_0_SDR, SDRC_MCFG_0); /* diff from combo case */ __raw_writel(H4_2420_SDRC_ACTIM_CTRLA_0, SDRC_ACTIM_CTRLA_0); __raw_writel(H4_2420_SDRC_ACTIM_CTRLB_0, SDRC_ACTIM_CTRLB_0); __raw_writel(H4_242x_SDRC_RFR_CTRL_ES1, SDRC_RFR_CTRL); /* Manual Command sequence */ __raw_writel(CMD_NOP, SDRC_MANUAL_0); __raw_writel(CMD_PRECHARGE, SDRC_MANUAL_0); __raw_writel(CMD_AUTOREFRESH, SDRC_MANUAL_0); __raw_writel(CMD_AUTOREFRESH, SDRC_MANUAL_0); /* CS0 SDRC Mode Register */ /* Burst length = 2 - SDR memory */ /* Serial mode */ /* CAS latency = 3 */ __raw_writel(H4_2420_SDRC_MR_0_SDR, SDRC_MR_0); /* diff from combo case */ /* SDRC DLLA control register */ /* Enable DLL, Load counter with 115 (middle of range) */ /* Delay is 90 degrees */ if (rev == CPU_242X_ES1) dllctrl = (BIT0|BIT3); else dllctrl = BIT0; if (rev == CPU_2420_2422_ES1) { __raw_writel(0x00007306, SDRC_DLLA_CTRL); __raw_writel(0x00007302, SDRC_DLLA_CTRL); /* Enable DLL, Load counter with 128 (middle of range) */ __raw_writel(0x00007306, SDRC_DLLB_CTRL); /* load ctr value */ __raw_writel(0x00007302, SDRC_DLLB_CTRL); /* lock and go */ } else { __raw_writel(H4_2420_SDRC_DLLAB_CTRL, SDRC_DLLA_CTRL); // ES2.x __raw_writel(H4_2420_SDRC_DLLAB_CTRL & ~(LOADDLL|dllctrl), SDRC_DLLA_CTRL); // ES2.x /* Enable DLL, Load counter with 128 (middle of range) */ __raw_writel(H4_2420_SDRC_DLLAB_CTRL, SDRC_DLLB_CTRL); // ES2.x __raw_writel(H4_2420_SDRC_DLLAB_CTRL & ~(LOADDLL|dllctrl), SDRC_DLLB_CTRL); // ES2.x } }#endif // CFG_SDRAM_SDR#ifdef CFG_SDRAM_STACKED voidconfig_sdram_stacked(u32 rev){ /* Pin Muxing for SDRC */ __raw_writeb(0x00, 0x480000a1); /* mux mode 0 (CS1) */ __raw_writeb(0x00, 0x480000a3); /* mux mode 0 (CKE1) */ __raw_writeb(0x00, 0x48000032); /* connect sdrc_a12 */ __raw_writeb(0x00, 0x48000031); /* connect sdrc_a13 */ /* configure sdrc 32 bit for COMBO ddr sdram */ __raw_writel(0x00000010, SDRC_SYSCONFIG); /* no idle ack and RESET enable */ delay(200000); __raw_writel(0x00000010, SDRC_SYSCONFIG); /* smart idle mode */ /* SDRC_SHARING */ /* U-boot is writing 0x00000100 though (H4_2420_SDRC_SHARING ) */ //__raw_writel(H4_2420_SDRC_SHARING, SDRC_SHARING); __raw_writel(0x00004900, SDRC_SHARING); /* SDRC_CS0 Configuration */ /* None for ES2.1 */ /* SDRC_CS1 Configuration */ __raw_writel(0x00000000, SDRC_CS_CFG); /* Remap CS1 to 0x80000000 */ /* Disable power down of CKE */ __raw_writel(0x00000085, SDRC_POWER);
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -