blob: 0a07523b12337a0205636d5dbc05c13ac1c8f45c [file] [log] [blame]
Sergey Kubushyne8f39122007-08-10 20:26:18 +02001/*
2 * Copyright (C) 2007 Sergey Kubushyn <ksi@koi8.net>
3 *
4 * Parts are shamelessly stolen from various TI sources, original copyright
5 * follows:
6 * -----------------------------------------------------------------
7 *
8 * Copyright (C) 2004 Texas Instruments.
9 *
10 * ----------------------------------------------------------------------------
11 * This program is free software; you can redistribute it and/or modify
12 * it under the terms of the GNU General Public License as published by
13 * the Free Software Foundation; either version 2 of the License, or
14 * (at your option) any later version.
15 *
16 * This program is distributed in the hope that it will be useful,
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 * GNU General Public License for more details.
20 *
21 * You should have received a copy of the GNU General Public License
22 * along with this program; if not, write to the Free Software
23 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
24 * ----------------------------------------------------------------------------
25 */
26
27#include <common.h>
28#include <i2c.h>
29#include <asm/arch/hardware.h>
30#include <asm/arch/emac_defs.h>
31
32#define MACH_TYPE_SCHMOOGIE 1255
33
Dirk Behmef2b171c2007-09-15 11:55:42 +020034DECLARE_GLOBAL_DATA_PTR;
35
Sergey Kubushyne8f39122007-08-10 20:26:18 +020036extern void i2c_init(int speed, int slaveaddr);
37extern void timer_init(void);
38extern int eth_hw_init(void);
39extern phy_t phy;
40
41
42/* Works on Always On power domain only (no PD argument) */
43void lpsc_on(unsigned int id)
44{
45 dv_reg_p mdstat, mdctl;
46
47 if (id >= DAVINCI_LPSC_GEM)
48 return; /* Don't work on DSP Power Domain */
49
50 mdstat = REG_P(PSC_MDSTAT_BASE + (id * 4));
51 mdctl = REG_P(PSC_MDCTL_BASE + (id * 4));
52
53 while (REG(PSC_PTSTAT) & 0x01) {;}
54
55 if ((*mdstat & 0x1f) == 0x03)
56 return; /* Already on and enabled */
57
58 *mdctl |= 0x03;
59
60 /* Special treatment for some modules as for sprue14 p.7.4.2 */
61 if ( (id == DAVINCI_LPSC_VPSSSLV) ||
62 (id == DAVINCI_LPSC_EMAC) ||
63 (id == DAVINCI_LPSC_EMAC_WRAPPER) ||
64 (id == DAVINCI_LPSC_MDIO) ||
65 (id == DAVINCI_LPSC_USB) ||
66 (id == DAVINCI_LPSC_ATA) ||
67 (id == DAVINCI_LPSC_VLYNQ) ||
68 (id == DAVINCI_LPSC_UHPI) ||
69 (id == DAVINCI_LPSC_DDR_EMIF) ||
70 (id == DAVINCI_LPSC_AEMIF) ||
71 (id == DAVINCI_LPSC_MMC_SD) ||
72 (id == DAVINCI_LPSC_MEMSTICK) ||
73 (id == DAVINCI_LPSC_McBSP) ||
74 (id == DAVINCI_LPSC_GPIO)
75 )
76 *mdctl |= 0x200;
77
78 REG(PSC_PTCMD) = 0x01;
79
80 while (REG(PSC_PTSTAT) & 0x03) {;}
81 while ((*mdstat & 0x1f) != 0x03) {;} /* Probably an overkill... */
82}
83
84void dsp_on(void)
85{
86 int i;
87
88 if (REG(PSC_PDSTAT1) & 0x1f)
89 return; /* Already on */
90
91 REG(PSC_GBLCTL) |= 0x01;
92 REG(PSC_PDCTL1) |= 0x01;
93 REG(PSC_PDCTL1) &= ~0x100;
94 REG(PSC_MDCTL_BASE + (DAVINCI_LPSC_GEM * 4)) |= 0x03;
95 REG(PSC_MDCTL_BASE + (DAVINCI_LPSC_GEM * 4)) &= 0xfffffeff;
96 REG(PSC_MDCTL_BASE + (DAVINCI_LPSC_IMCOP * 4)) |= 0x03;
97 REG(PSC_MDCTL_BASE + (DAVINCI_LPSC_IMCOP * 4)) &= 0xfffffeff;
98 REG(PSC_PTCMD) = 0x02;
99
100 for (i = 0; i < 100; i++) {
101 if (REG(PSC_EPCPR) & 0x02)
102 break;
103 }
104
105 REG(PSC_CHP_SHRTSW) = 0x01;
106 REG(PSC_PDCTL1) |= 0x100;
107 REG(PSC_EPCCR) = 0x02;
108
109 for (i = 0; i < 100; i++) {
110 if (!(REG(PSC_PTSTAT) & 0x02))
111 break;
112 }
113
114 REG(PSC_GBLCTL) &= ~0x1f;
115}
116
117
118int board_init(void)
119{
Sergey Kubushyne8f39122007-08-10 20:26:18 +0200120 /* arch number of the board */
121 gd->bd->bi_arch_number = MACH_TYPE_SCHMOOGIE;
122
123 /* address of boot parameters */
124 gd->bd->bi_boot_params = LINUX_BOOT_PARAM_ADDR;
125
126 /* Workaround for TMS320DM6446 errata 1.3.22 */
127 REG(PSC_SILVER_BULLET) = 0;
128
129 /* Power on required peripherals */
130 lpsc_on(DAVINCI_LPSC_EMAC);
131 lpsc_on(DAVINCI_LPSC_EMAC_WRAPPER);
132 lpsc_on(DAVINCI_LPSC_MDIO);
133 lpsc_on(DAVINCI_LPSC_I2C);
134 lpsc_on(DAVINCI_LPSC_UART0);
135 lpsc_on(DAVINCI_LPSC_TIMER1);
136 lpsc_on(DAVINCI_LPSC_GPIO);
137
138 /* Powerup the DSP */
139 dsp_on();
140
141 /* Bringup UART0 out of reset */
142 REG(UART0_PWREMU_MGMT) = 0x0000e003;
143
144 /* Enable GIO3.3V cells used for EMAC */
145 REG(VDD3P3V_PWDN) = 0;
146
147 /* Enable UART0 MUX lines */
148 REG(PINMUX1) |= 1;
149
150 /* Enable EMAC and AEMIF pins */
151 REG(PINMUX0) = 0x80000c1f;
152
153 /* Enable I2C pin Mux */
154 REG(PINMUX1) |= (1 << 7);
155
156 /* Set the Bus Priority Register to appropriate value */
157 REG(VBPR) = 0x20;
158
159 timer_init();
160
161 return(0);
162}
163
164int misc_init_r (void)
165{
166 u_int8_t tmp[20], buf[10];
167 int i = 0;
168 int clk = 0;
169
170 /* Set serial number from UID chip */
171 u_int8_t crc_tbl[256] = {
172 0x00, 0x5e, 0xbc, 0xe2, 0x61, 0x3f, 0xdd, 0x83,
173 0xc2, 0x9c, 0x7e, 0x20, 0xa3, 0xfd, 0x1f, 0x41,
174 0x9d, 0xc3, 0x21, 0x7f, 0xfc, 0xa2, 0x40, 0x1e,
175 0x5f, 0x01, 0xe3, 0xbd, 0x3e, 0x60, 0x82, 0xdc,
176 0x23, 0x7d, 0x9f, 0xc1, 0x42, 0x1c, 0xfe, 0xa0,
177 0xe1, 0xbf, 0x5d, 0x03, 0x80, 0xde, 0x3c, 0x62,
178 0xbe, 0xe0, 0x02, 0x5c, 0xdf, 0x81, 0x63, 0x3d,
179 0x7c, 0x22, 0xc0, 0x9e, 0x1d, 0x43, 0xa1, 0xff,
180 0x46, 0x18, 0xfa, 0xa4, 0x27, 0x79, 0x9b, 0xc5,
181 0x84, 0xda, 0x38, 0x66, 0xe5, 0xbb, 0x59, 0x07,
182 0xdb, 0x85, 0x67, 0x39, 0xba, 0xe4, 0x06, 0x58,
183 0x19, 0x47, 0xa5, 0xfb, 0x78, 0x26, 0xc4, 0x9a,
184 0x65, 0x3b, 0xd9, 0x87, 0x04, 0x5a, 0xb8, 0xe6,
185 0xa7, 0xf9, 0x1b, 0x45, 0xc6, 0x98, 0x7a, 0x24,
186 0xf8, 0xa6, 0x44, 0x1a, 0x99, 0xc7, 0x25, 0x7b,
187 0x3a, 0x64, 0x86, 0xd8, 0x5b, 0x05, 0xe7, 0xb9,
188 0x8c, 0xd2, 0x30, 0x6e, 0xed, 0xb3, 0x51, 0x0f,
189 0x4e, 0x10, 0xf2, 0xac, 0x2f, 0x71, 0x93, 0xcd,
190 0x11, 0x4f, 0xad, 0xf3, 0x70, 0x2e, 0xcc, 0x92,
191 0xd3, 0x8d, 0x6f, 0x31, 0xb2, 0xec, 0x0e, 0x50,
192 0xaf, 0xf1, 0x13, 0x4d, 0xce, 0x90, 0x72, 0x2c,
193 0x6d, 0x33, 0xd1, 0x8f, 0x0c, 0x52, 0xb0, 0xee,
194 0x32, 0x6c, 0x8e, 0xd0, 0x53, 0x0d, 0xef, 0xb1,
195 0xf0, 0xae, 0x4c, 0x12, 0x91, 0xcf, 0x2d, 0x73,
196 0xca, 0x94, 0x76, 0x28, 0xab, 0xf5, 0x17, 0x49,
197 0x08, 0x56, 0xb4, 0xea, 0x69, 0x37, 0xd5, 0x8b,
198 0x57, 0x09, 0xeb, 0xb5, 0x36, 0x68, 0x8a, 0xd4,
199 0x95, 0xcb, 0x29, 0x77, 0xf4, 0xaa, 0x48, 0x16,
200 0xe9, 0xb7, 0x55, 0x0b, 0x88, 0xd6, 0x34, 0x6a,
201 0x2b, 0x75, 0x97, 0xc9, 0x4a, 0x14, 0xf6, 0xa8,
202 0x74, 0x2a, 0xc8, 0x96, 0x15, 0x4b, 0xa9, 0xf7,
203 0xb6, 0xe8, 0x0a, 0x54, 0xd7, 0x89, 0x6b, 0x35
204 };
205
206 clk = ((REG(PLL2_PLLM) + 1) * 27) / ((REG(PLL2_DIV2) & 0x1f) + 1);
207
208 printf ("ARM Clock : %dMHz\n", ((REG(PLL1_PLLM) + 1) * 27 ) / 2);
209 printf ("DDR Clock : %dMHz\n", (clk / 2));
210
211 /* Set serial number from UID chip */
212 if (i2c_read(CFG_UID_ADDR, 0, 1, buf, 8)) {
213 printf("\nUID @ 0x%02x read FAILED!!!\n", CFG_UID_ADDR);
214 forceenv("serial#", "FAILED");
215 } else {
216 if (buf[0] != 0x70) { /* Device Family Code */
217 printf("\nUID @ 0x%02x read FAILED!!!\n", CFG_UID_ADDR);
218 forceenv("serial#", "FAILED");
219 }
220 }
221 /* Now check CRC */
222 tmp[0] = 0;
223 for (i = 0; i < 8; i++)
224 tmp[0] = crc_tbl[tmp[0] ^ buf[i]];
225
226 if (tmp[0] != 0) {
227 printf("\nUID @ 0x%02x - BAD CRC!!!\n", CFG_UID_ADDR);
228 forceenv("serial#", "FAILED");
229 } else {
230 /* CRC OK, set "serial" env variable */
ksi@koi8.net1d41ce42007-08-14 10:02:16 -0700231 sprintf((char *)&tmp[0], "%02x%02x%02x%02x%02x%02x",
Sergey Kubushyne8f39122007-08-10 20:26:18 +0200232 buf[6], buf[5], buf[4], buf[3], buf[2], buf[1]);
233 forceenv("serial#", (char *)&tmp[0]);
234 }
235
236 if (!eth_hw_init()) {
237 printf("ethernet init failed!\n");
238 } else {
239 printf("ETH PHY : %s\n", phy.name);
240 }
241
242 return(0);
243}
244
245int dram_init(void)
246{
Sergey Kubushyne8f39122007-08-10 20:26:18 +0200247 gd->bd->bi_dram[0].start = PHYS_SDRAM_1;
248 gd->bd->bi_dram[0].size = PHYS_SDRAM_1_SIZE;
249
250 return(0);
251}