Adding support for MOXA ART SoC. Testing port of linux-2.6.32.60-moxart.
[linux-3.6.7-moxart.git] / drivers / staging / bcm / DDRInit.c
blob8c696b64ab247a749743833032e78d17cc4361ee
1 #include "headers.h"
5 #define DDR_DUMP_INTERNAL_DEVICE_MEMORY 0xBFC02B00
6 #define MIPS_CLOCK_REG 0x0f000820
8 //DDR INIT-133Mhz
9 #define T3_SKIP_CLOCK_PROGRAM_DUMP_133MHZ 12 //index for 0x0F007000
10 static struct bcm_ddr_setting asT3_DDRSetting133MHz[]= {// # DPLL Clock Setting
11 {0x0F000800,0x00007212},
12 {0x0f000820,0x07F13FFF},
13 {0x0f000810,0x00000F95},
14 {0x0f000860,0x00000000},
15 {0x0f000880,0x000003DD},
16 // Changed source for X-bar and MIPS clock to APLL
17 {0x0f000840,0x0FFF1B00},
18 {0x0f000870,0x00000002},
19 {0x0F00a044,0x1fffffff},
20 {0x0F00a040,0x1f000000},
21 {0x0F00a084,0x1Cffffff},
22 {0x0F00a080,0x1C000000},
23 {0x0F00a04C,0x0000000C},
24 //Memcontroller Default values
25 {0x0F007000,0x00010001},
26 {0x0F007004,0x01010100},
27 {0x0F007008,0x01000001},
28 {0x0F00700c,0x00000000},
29 {0x0F007010,0x01000000},
30 {0x0F007014,0x01000100},
31 {0x0F007018,0x01000000},
32 {0x0F00701c,0x01020001},// POP - 0x00020001 Normal 0x01020001
33 {0x0F007020,0x04030107}, //Normal - 0x04030107 POP - 0x05030107
34 {0x0F007024,0x02000007},
35 {0x0F007028,0x02020202},
36 {0x0F00702c,0x0206060a},//ROB- 0x0205050a,//0x0206060a
37 {0x0F007030,0x05000000},
38 {0x0F007034,0x00000003},
39 {0x0F007038,0x110a0200},//ROB - 0x110a0200,//0x180a0200,// 0x1f0a0200
40 {0x0F00703C,0x02101010},//ROB - 0x02101010,//0x02101018},
41 {0x0F007040,0x45751200},//ROB - 0x45751200,//0x450f1200},
42 {0x0F007044,0x110a0d00},//ROB - 0x110a0d00//0x111f0d00
43 {0x0F007048,0x081b0306},
44 {0x0F00704c,0x00000000},
45 {0x0F007050,0x0000001c},
46 {0x0F007054,0x00000000},
47 {0x0F007058,0x00000000},
48 {0x0F00705c,0x00000000},
49 {0x0F007060,0x0010246c},
50 {0x0F007064,0x00000010},
51 {0x0F007068,0x00000000},
52 {0x0F00706c,0x00000001},
53 {0x0F007070,0x00007000},
54 {0x0F007074,0x00000000},
55 {0x0F007078,0x00000000},
56 {0x0F00707C,0x00000000},
57 {0x0F007080,0x00000000},
58 {0x0F007084,0x00000000},
59 //# Enable BW improvement within memory controller
60 {0x0F007094,0x00000104},
61 //# Enable 2 ports within X-bar
62 {0x0F00A000,0x00000016},
63 //# Enable start bit within memory controller
64 {0x0F007018,0x01010000}
66 //80Mhz
67 #define T3_SKIP_CLOCK_PROGRAM_DUMP_80MHZ 10 //index for 0x0F007000
68 static struct bcm_ddr_setting asT3_DDRSetting80MHz[]= {// # DPLL Clock Setting
69 {0x0f000810,0x00000F95},
70 {0x0f000820,0x07f1ffff},
71 {0x0f000860,0x00000000},
72 {0x0f000880,0x000003DD},
73 {0x0F00a044,0x1fffffff},
74 {0x0F00a040,0x1f000000},
75 {0x0F00a084,0x1Cffffff},
76 {0x0F00a080,0x1C000000},
77 {0x0F00a000,0x00000016},
78 {0x0F00a04C,0x0000000C},
79 //Memcontroller Default values
80 {0x0F007000,0x00010001},
81 {0x0F007004,0x01000000},
82 {0x0F007008,0x01000001},
83 {0x0F00700c,0x00000000},
84 {0x0F007010,0x01000000},
85 {0x0F007014,0x01000100},
86 {0x0F007018,0x01000000},
87 {0x0F00701c,0x01020000},
88 {0x0F007020,0x04020107},
89 {0x0F007024,0x00000007},
90 {0x0F007028,0x02020201},
91 {0x0F00702c,0x0204040a},
92 {0x0F007030,0x04000000},
93 {0x0F007034,0x00000002},
94 {0x0F007038,0x1F060200},
95 {0x0F00703C,0x1C22221F},
96 {0x0F007040,0x8A006600},
97 {0x0F007044,0x221a0800},
98 {0x0F007048,0x02690204},
99 {0x0F00704c,0x00000000},
100 {0x0F007050,0x0000001c},
101 {0x0F007054,0x00000000},
102 {0x0F007058,0x00000000},
103 {0x0F00705c,0x00000000},
104 {0x0F007060,0x000A15D6},
105 {0x0F007064,0x0000000A},
106 {0x0F007068,0x00000000},
107 {0x0F00706c,0x00000001},
108 {0x0F007070,0x00004000},
109 {0x0F007074,0x00000000},
110 {0x0F007078,0x00000000},
111 {0x0F00707C,0x00000000},
112 {0x0F007080,0x00000000},
113 {0x0F007084,0x00000000},
114 {0x0F007094,0x00000104},
115 //# Enable start bit within memory controller
116 {0x0F007018,0x01010000}
118 //100Mhz
119 #define T3_SKIP_CLOCK_PROGRAM_DUMP_100MHZ 13 //index for 0x0F007000
120 static struct bcm_ddr_setting asT3_DDRSetting100MHz[]= {// # DPLL Clock Setting
121 {0x0F000800,0x00007008},
122 {0x0f000810,0x00000F95},
123 {0x0f000820,0x07F13E3F},
124 {0x0f000860,0x00000000},
125 {0x0f000880,0x000003DD},
126 // Changed source for X-bar and MIPS clock to APLL
127 //0x0f000840,0x0FFF1800,
128 {0x0f000840,0x0FFF1B00},
129 {0x0f000870,0x00000002},
130 {0x0F00a044,0x1fffffff},
131 {0x0F00a040,0x1f000000},
132 {0x0F00a084,0x1Cffffff},
133 {0x0F00a080,0x1C000000},
134 {0x0F00a04C,0x0000000C},
135 //# Enable 2 ports within X-bar
136 {0x0F00A000,0x00000016},
137 //Memcontroller Default values
138 {0x0F007000,0x00010001},
139 {0x0F007004,0x01010100},
140 {0x0F007008,0x01000001},
141 {0x0F00700c,0x00000000},
142 {0x0F007010,0x01000000},
143 {0x0F007014,0x01000100},
144 {0x0F007018,0x01000000},
145 {0x0F00701c,0x01020001}, // POP - 0x00020000 Normal 0x01020000
146 {0x0F007020,0x04020107},//Normal - 0x04030107 POP - 0x05030107
147 {0x0F007024,0x00000007},
148 {0x0F007028,0x01020201},
149 {0x0F00702c,0x0204040A},
150 {0x0F007030,0x06000000},
151 {0x0F007034,0x00000004},
152 {0x0F007038,0x20080200},
153 {0x0F00703C,0x02030320},
154 {0x0F007040,0x6E7F1200},
155 {0x0F007044,0x01190A00},
156 {0x0F007048,0x06120305},//0x02690204 // 0x06120305
157 {0x0F00704c,0x00000000},
158 {0x0F007050,0x0000001C},
159 {0x0F007054,0x00000000},
160 {0x0F007058,0x00000000},
161 {0x0F00705c,0x00000000},
162 {0x0F007060,0x00082ED6},
163 {0x0F007064,0x0000000A},
164 {0x0F007068,0x00000000},
165 {0x0F00706c,0x00000001},
166 {0x0F007070,0x00005000},
167 {0x0F007074,0x00000000},
168 {0x0F007078,0x00000000},
169 {0x0F00707C,0x00000000},
170 {0x0F007080,0x00000000},
171 {0x0F007084,0x00000000},
172 //# Enable BW improvement within memory controller
173 {0x0F007094,0x00000104},
174 //# Enable start bit within memory controller
175 {0x0F007018,0x01010000}
178 //Net T3B DDR Settings
179 //DDR INIT-133Mhz
180 static struct bcm_ddr_setting asDPLL_266MHZ[] = {
181 {0x0F000800,0x00007212},
182 {0x0f000820,0x07F13FFF},
183 {0x0f000810,0x00000F95},
184 {0x0f000860,0x00000000},
185 {0x0f000880,0x000003DD},
186 // Changed source for X-bar and MIPS clock to APLL
187 {0x0f000840,0x0FFF1B00},
188 {0x0f000870,0x00000002}
191 #define T3B_SKIP_CLOCK_PROGRAM_DUMP_133MHZ 11 //index for 0x0F007000
192 static struct bcm_ddr_setting asT3B_DDRSetting133MHz[] = {// # DPLL Clock Setting
193 {0x0f000810,0x00000F95},
194 {0x0f000810,0x00000F95},
195 {0x0f000810,0x00000F95},
196 {0x0f000820,0x07F13652},
197 {0x0f000840,0x0FFF0800},
198 // Changed source for X-bar and MIPS clock to APLL
199 {0x0f000880,0x000003DD},
200 {0x0f000860,0x00000000},
201 // Changed source for X-bar and MIPS clock to APLL
202 {0x0F00a044,0x1fffffff},
203 {0x0F00a040,0x1f000000},
204 {0x0F00a084,0x1Cffffff},
205 {0x0F00a080,0x1C000000},
206 //# Enable 2 ports within X-bar
207 {0x0F00A000,0x00000016},
208 //Memcontroller Default values
209 {0x0F007000,0x00010001},
210 {0x0F007004,0x01010100},
211 {0x0F007008,0x01000001},
212 {0x0F00700c,0x00000000},
213 {0x0F007010,0x01000000},
214 {0x0F007014,0x01000100},
215 {0x0F007018,0x01000000},
216 {0x0F00701c,0x01020001},// POP - 0x00020001 Normal 0x01020001
217 {0x0F007020,0x04030107}, //Normal - 0x04030107 POP - 0x05030107
218 {0x0F007024,0x02000007},
219 {0x0F007028,0x02020202},
220 {0x0F00702c,0x0206060a},//ROB- 0x0205050a,//0x0206060a
221 {0x0F007030,0x05000000},
222 {0x0F007034,0x00000003},
223 {0x0F007038,0x130a0200},//ROB - 0x110a0200,//0x180a0200,// 0x1f0a0200
224 {0x0F00703C,0x02101012},//ROB - 0x02101010,//0x02101018},
225 {0x0F007040,0x457D1200},//ROB - 0x45751200,//0x450f1200},
226 {0x0F007044,0x11130d00},//ROB - 0x110a0d00//0x111f0d00
227 {0x0F007048,0x040D0306},
228 {0x0F00704c,0x00000000},
229 {0x0F007050,0x0000001c},
230 {0x0F007054,0x00000000},
231 {0x0F007058,0x00000000},
232 {0x0F00705c,0x00000000},
233 {0x0F007060,0x0010246c},
234 {0x0F007064,0x00000012},
235 {0x0F007068,0x00000000},
236 {0x0F00706c,0x00000001},
237 {0x0F007070,0x00007000},
238 {0x0F007074,0x00000000},
239 {0x0F007078,0x00000000},
240 {0x0F00707C,0x00000000},
241 {0x0F007080,0x00000000},
242 {0x0F007084,0x00000000},
243 //# Enable BW improvement within memory controller
244 {0x0F007094,0x00000104},
245 //# Enable start bit within memory controller
246 {0x0F007018,0x01010000},
249 #define T3B_SKIP_CLOCK_PROGRAM_DUMP_80MHZ 9 //index for 0x0F007000
250 static struct bcm_ddr_setting asT3B_DDRSetting80MHz[] = {// # DPLL Clock Setting
251 {0x0f000810,0x00000F95},
252 {0x0f000820,0x07F13FFF},
253 {0x0f000840,0x0FFF1F00},
254 {0x0f000880,0x000003DD},
255 {0x0f000860,0x00000000},
257 {0x0F00a044,0x1fffffff},
258 {0x0F00a040,0x1f000000},
259 {0x0F00a084,0x1Cffffff},
260 {0x0F00a080,0x1C000000},
261 {0x0F00a000,0x00000016},
262 //Memcontroller Default values
263 {0x0F007000,0x00010001},
264 {0x0F007004,0x01000000},
265 {0x0F007008,0x01000001},
266 {0x0F00700c,0x00000000},
267 {0x0F007010,0x01000000},
268 {0x0F007014,0x01000100},
269 {0x0F007018,0x01000000},
270 {0x0F00701c,0x01020000},
271 {0x0F007020,0x04020107},
272 {0x0F007024,0x00000007},
273 {0x0F007028,0x02020201},
274 {0x0F00702c,0x0204040a},
275 {0x0F007030,0x04000000},
276 {0x0F007034,0x02000002},
277 {0x0F007038,0x1F060202},
278 {0x0F00703C,0x1C22221F},
279 {0x0F007040,0x8A006600},
280 {0x0F007044,0x221a0800},
281 {0x0F007048,0x02690204},
282 {0x0F00704c,0x00000000},
283 {0x0F007050,0x0100001c},
284 {0x0F007054,0x00000000},
285 {0x0F007058,0x00000000},
286 {0x0F00705c,0x00000000},
287 {0x0F007060,0x000A15D6},
288 {0x0F007064,0x0000000A},
289 {0x0F007068,0x00000000},
290 {0x0F00706c,0x00000001},
291 {0x0F007070,0x00004000},
292 {0x0F007074,0x00000000},
293 {0x0F007078,0x00000000},
294 {0x0F00707C,0x00000000},
295 {0x0F007080,0x00000000},
296 {0x0F007084,0x00000000},
297 {0x0F007094,0x00000104},
298 //# Enable start bit within memory controller
299 {0x0F007018,0x01010000}
302 //100Mhz
303 #define T3B_SKIP_CLOCK_PROGRAM_DUMP_100MHZ 9 //index for 0x0F007000
304 static struct bcm_ddr_setting asT3B_DDRSetting100MHz[] = {// # DPLL Clock Setting
305 {0x0f000810,0x00000F95},
306 {0x0f000820,0x07F1369B},
307 {0x0f000840,0x0FFF0800},
308 {0x0f000880,0x000003DD},
309 {0x0f000860,0x00000000},
310 {0x0F00a044,0x1fffffff},
311 {0x0F00a040,0x1f000000},
312 {0x0F00a084,0x1Cffffff},
313 {0x0F00a080,0x1C000000},
314 //# Enable 2 ports within X-bar
315 {0x0F00A000,0x00000016},
316 //Memcontroller Default values
317 {0x0F007000,0x00010001},
318 {0x0F007004,0x01010100},
319 {0x0F007008,0x01000001},
320 {0x0F00700c,0x00000000},
321 {0x0F007010,0x01000000},
322 {0x0F007014,0x01000100},
323 {0x0F007018,0x01000000},
324 {0x0F00701c,0x01020000}, // POP - 0x00020000 Normal 0x01020000
325 {0x0F007020,0x04020107},//Normal - 0x04030107 POP - 0x05030107
326 {0x0F007024,0x00000007},
327 {0x0F007028,0x01020201},
328 {0x0F00702c,0x0204040A},
329 {0x0F007030,0x06000000},
330 {0x0F007034,0x02000004},
331 {0x0F007038,0x20080200},
332 {0x0F00703C,0x02030320},
333 {0x0F007040,0x6E7F1200},
334 {0x0F007044,0x01190A00},
335 {0x0F007048,0x06120305},//0x02690204 // 0x06120305
336 {0x0F00704c,0x00000000},
337 {0x0F007050,0x0100001C},
338 {0x0F007054,0x00000000},
339 {0x0F007058,0x00000000},
340 {0x0F00705c,0x00000000},
341 {0x0F007060,0x00082ED6},
342 {0x0F007064,0x0000000A},
343 {0x0F007068,0x00000000},
344 {0x0F00706c,0x00000001},
345 {0x0F007070,0x00005000},
346 {0x0F007074,0x00000000},
347 {0x0F007078,0x00000000},
348 {0x0F00707C,0x00000000},
349 {0x0F007080,0x00000000},
350 {0x0F007084,0x00000000},
351 //# Enable BW improvement within memory controller
352 {0x0F007094,0x00000104},
353 //# Enable start bit within memory controller
354 {0x0F007018,0x01010000}
358 #define T3LP_SKIP_CLOCK_PROGRAM_DUMP_133MHZ 9 //index for 0x0F007000
359 static struct bcm_ddr_setting asT3LP_DDRSetting133MHz[]= {// # DPLL Clock Setting
360 {0x0f000820,0x03F1365B},
361 {0x0f000810,0x00002F95},
362 {0x0f000880,0x000003DD},
363 // Changed source for X-bar and MIPS clock to APLL
364 {0x0f000840,0x0FFF0000},
365 {0x0f000860,0x00000000},
366 {0x0F00a044,0x1fffffff},
367 {0x0F00a040,0x1f000000},
368 {0x0F00a084,0x1Cffffff},
369 {0x0F00a080,0x1C000000},
370 {0x0F00A000,0x00000016},
371 //Memcontroller Default values
372 {0x0F007000,0x00010001},
373 {0x0F007004,0x01010100},
374 {0x0F007008,0x01000001},
375 {0x0F00700c,0x00000000},
376 {0x0F007010,0x01000000},
377 {0x0F007014,0x01000100},
378 {0x0F007018,0x01000000},
379 {0x0F00701c,0x01020001},// POP - 0x00020001 Normal 0x01020001
380 {0x0F007020,0x04030107}, //Normal - 0x04030107 POP - 0x05030107
381 {0x0F007024,0x02000007},
382 {0x0F007028,0x02020200},
383 {0x0F00702c,0x0206060a},//ROB- 0x0205050a,//0x0206060a
384 {0x0F007030,0x05000000},
385 {0x0F007034,0x00000003},
386 {0x0F007038,0x200a0200},//ROB - 0x110a0200,//0x180a0200,// 0x1f0a0200
387 {0x0F00703C,0x02101020},//ROB - 0x02101010,//0x02101018,
388 {0x0F007040,0x45711200},//ROB - 0x45751200,//0x450f1200,
389 {0x0F007044,0x110D0D00},//ROB - 0x110a0d00//0x111f0d00
390 {0x0F007048,0x04080306},
391 {0x0F00704c,0x00000000},
392 {0x0F007050,0x0100001c},
393 {0x0F007054,0x00000000},
394 {0x0F007058,0x00000000},
395 {0x0F00705c,0x00000000},
396 {0x0F007060,0x0010245F},
397 {0x0F007064,0x00000010},
398 {0x0F007068,0x00000000},
399 {0x0F00706c,0x00000001},
400 {0x0F007070,0x00007000},
401 {0x0F007074,0x00000000},
402 {0x0F007078,0x00000000},
403 {0x0F00707C,0x00000000},
404 {0x0F007080,0x00000000},
405 {0x0F007084,0x00000000},
406 {0x0F007088,0x01000001},
407 {0x0F00708c,0x00000101},
408 {0x0F007090,0x00000000},
409 //# Enable BW improvement within memory controller
410 {0x0F007094,0x00040000},
411 {0x0F007098,0x00000000},
412 {0x0F0070c8,0x00000104},
413 //# Enable 2 ports within X-bar
414 //# Enable start bit within memory controller
415 {0x0F007018,0x01010000}
418 #define T3LP_SKIP_CLOCK_PROGRAM_DUMP_100MHZ 11 //index for 0x0F007000
419 static struct bcm_ddr_setting asT3LP_DDRSetting100MHz[]= {// # DPLL Clock Setting
420 {0x0f000810,0x00002F95},
421 {0x0f000820,0x03F1369B},
422 {0x0f000840,0x0fff0000},
423 {0x0f000860,0x00000000},
424 {0x0f000880,0x000003DD},
425 // Changed source for X-bar and MIPS clock to APLL
426 {0x0f000840,0x0FFF0000},
427 {0x0F00a044,0x1fffffff},
428 {0x0F00a040,0x1f000000},
429 {0x0F00a084,0x1Cffffff},
430 {0x0F00a080,0x1C000000},
431 //Memcontroller Default values
432 {0x0F007000,0x00010001},
433 {0x0F007004,0x01010100},
434 {0x0F007008,0x01000001},
435 {0x0F00700c,0x00000000},
436 {0x0F007010,0x01000000},
437 {0x0F007014,0x01000100},
438 {0x0F007018,0x01000000},
439 {0x0F00701c,0x01020000},// POP - 0x00020001 Normal 0x01020001
440 {0x0F007020,0x04020107}, //Normal - 0x04030107 POP - 0x05030107
441 {0x0F007024,0x00000007},
442 {0x0F007028,0x01020200},
443 {0x0F00702c,0x0204040a},//ROB- 0x0205050a,//0x0206060a
444 {0x0F007030,0x06000000},
445 {0x0F007034,0x00000004},
446 {0x0F007038,0x1F080200},//ROB - 0x110a0200,//0x180a0200,// 0x1f0a0200
447 {0x0F00703C,0x0203031F},//ROB - 0x02101010,//0x02101018,
448 {0x0F007040,0x6e001200},//ROB - 0x45751200,//0x450f1200,
449 {0x0F007044,0x011a0a00},//ROB - 0x110a0d00//0x111f0d00
450 {0x0F007048,0x03000305},
451 {0x0F00704c,0x00000000},
452 {0x0F007050,0x0100001c},
453 {0x0F007054,0x00000000},
454 {0x0F007058,0x00000000},
455 {0x0F00705c,0x00000000},
456 {0x0F007060,0x00082ED6},
457 {0x0F007064,0x0000000A},
458 {0x0F007068,0x00000000},
459 {0x0F00706c,0x00000001},
460 {0x0F007070,0x00005000},
461 {0x0F007074,0x00000000},
462 {0x0F007078,0x00000000},
463 {0x0F00707C,0x00000000},
464 {0x0F007080,0x00000000},
465 {0x0F007084,0x00000000},
466 {0x0F007088,0x01000001},
467 {0x0F00708c,0x00000101},
468 {0x0F007090,0x00000000},
469 {0x0F007094,0x00010000},
470 {0x0F007098,0x00000000},
471 {0x0F0070C8,0x00000104},
472 //# Enable 2 ports within X-bar
473 {0x0F00A000,0x00000016},
474 //# Enable start bit within memory controller
475 {0x0F007018,0x01010000}
478 #define T3LP_SKIP_CLOCK_PROGRAM_DUMP_80MHZ 9 //index for 0x0F007000
479 static struct bcm_ddr_setting asT3LP_DDRSetting80MHz[]= {// # DPLL Clock Setting
480 {0x0f000820,0x07F13FFF},
481 {0x0f000810,0x00002F95},
482 {0x0f000860,0x00000000},
483 {0x0f000880,0x000003DD},
484 {0x0f000840,0x0FFF1F00},
485 {0x0F00a044,0x1fffffff},
486 {0x0F00a040,0x1f000000},
487 {0x0F00a084,0x1Cffffff},
488 {0x0F00a080,0x1C000000},
489 {0x0F00A000,0x00000016},
490 {0x0f007000,0x00010001},
491 {0x0f007004,0x01000000},
492 {0x0f007008,0x01000001},
493 {0x0f00700c,0x00000000},
494 {0x0f007010,0x01000000},
495 {0x0f007014,0x01000100},
496 {0x0f007018,0x01000000},
497 {0x0f00701c,0x01020000},
498 {0x0f007020,0x04020107},
499 {0x0f007024,0x00000007},
500 {0x0f007028,0x02020200},
501 {0x0f00702c,0x0204040a},
502 {0x0f007030,0x04000000},
503 {0x0f007034,0x00000002},
504 {0x0f007038,0x1d060200},
505 {0x0f00703c,0x1c22221d},
506 {0x0f007040,0x8A116600},
507 {0x0f007044,0x222d0800},
508 {0x0f007048,0x02690204},
509 {0x0f00704c,0x00000000},
510 {0x0f007050,0x0100001c},
511 {0x0f007054,0x00000000},
512 {0x0f007058,0x00000000},
513 {0x0f00705c,0x00000000},
514 {0x0f007060,0x000A15D6},
515 {0x0f007064,0x0000000A},
516 {0x0f007068,0x00000000},
517 {0x0f00706c,0x00000001},
518 {0x0f007070,0x00004000},
519 {0x0f007074,0x00000000},
520 {0x0f007078,0x00000000},
521 {0x0f00707c,0x00000000},
522 {0x0f007080,0x00000000},
523 {0x0f007084,0x00000000},
524 {0x0f007088,0x01000001},
525 {0x0f00708c,0x00000101},
526 {0x0f007090,0x00000000},
527 {0x0f007094,0x00010000},
528 {0x0f007098,0x00000000},
529 {0x0F0070C8,0x00000104},
530 {0x0F007018,0x01010000}
536 ///T3 LP-B (UMA-B)
538 #define T3LPB_SKIP_CLOCK_PROGRAM_DUMP_160MHZ 7 //index for 0x0F007000
539 static struct bcm_ddr_setting asT3LPB_DDRSetting160MHz[]= {// # DPLL Clock Setting
541 {0x0f000820,0x03F137DB},
542 {0x0f000810,0x01842795},
543 {0x0f000860,0x00000000},
544 {0x0f000880,0x000003DD},
545 {0x0f000840,0x0FFF0400},
546 {0x0F00a044,0x1fffffff},
547 {0x0F00a040,0x1f000000},
548 {0x0f003050,0x00000021},//this is flash/eeprom clock divisor which set the flash clock to 20 MHz
549 {0x0F00a084,0x1Cffffff},//Now dump from her in internal memory
550 {0x0F00a080,0x1C000000},
551 {0x0F00A000,0x00000016},
552 {0x0f007000,0x00010001},
553 {0x0f007004,0x01000001},
554 {0x0f007008,0x01000101},
555 {0x0f00700c,0x00000000},
556 {0x0f007010,0x01000100},
557 {0x0f007014,0x01000100},
558 {0x0f007018,0x01000000},
559 {0x0f00701c,0x01020000},
560 {0x0f007020,0x04030107},
561 {0x0f007024,0x02000007},
562 {0x0f007028,0x02020200},
563 {0x0f00702c,0x0206060a},
564 {0x0f007030,0x050d0d00},
565 {0x0f007034,0x00000003},
566 {0x0f007038,0x170a0200},
567 {0x0f00703c,0x02101012},
568 {0x0f007040,0x45161200},
569 {0x0f007044,0x11250c00},
570 {0x0f007048,0x04da0307},
571 {0x0f00704c,0x00000000},
572 {0x0f007050,0x0000001c},
573 {0x0f007054,0x00000000},
574 {0x0f007058,0x00000000},
575 {0x0f00705c,0x00000000},
576 {0x0f007060,0x00142bb6},
577 {0x0f007064,0x20430014},
578 {0x0f007068,0x00000000},
579 {0x0f00706c,0x00000001},
580 {0x0f007070,0x00009000},
581 {0x0f007074,0x00000000},
582 {0x0f007078,0x00000000},
583 {0x0f00707c,0x00000000},
584 {0x0f007080,0x00000000},
585 {0x0f007084,0x00000000},
586 {0x0f007088,0x01000001},
587 {0x0f00708c,0x00000101},
588 {0x0f007090,0x00000000},
589 {0x0f007094,0x00040000},
590 {0x0f007098,0x00000000},
591 {0x0F0070C8,0x00000104},
592 {0x0F007018,0x01010000}
596 #define T3LPB_SKIP_CLOCK_PROGRAM_DUMP_133MHZ 7 //index for 0x0F007000
597 static struct bcm_ddr_setting asT3LPB_DDRSetting133MHz[]= {// # DPLL Clock Setting
598 {0x0f000820,0x03F1365B},
599 {0x0f000810,0x00002F95},
600 {0x0f000880,0x000003DD},
601 // Changed source for X-bar and MIPS clock to APLL
602 {0x0f000840,0x0FFF0000},
603 {0x0f000860,0x00000000},
604 {0x0F00a044,0x1fffffff},
605 {0x0F00a040,0x1f000000},
606 {0x0f003050,0x00000021},//flash/eeprom clock divisor which set the flash clock to 20 MHz
607 {0x0F00a084,0x1Cffffff},//dump from here in internal memory
608 {0x0F00a080,0x1C000000},
609 {0x0F00A000,0x00000016},
610 //Memcontroller Default values
611 {0x0F007000,0x00010001},
612 {0x0F007004,0x01010100},
613 {0x0F007008,0x01000001},
614 {0x0F00700c,0x00000000},
615 {0x0F007010,0x01000000},
616 {0x0F007014,0x01000100},
617 {0x0F007018,0x01000000},
618 {0x0F00701c,0x01020001},// POP - 0x00020001 Normal 0x01020001
619 {0x0F007020,0x04030107}, //Normal - 0x04030107 POP - 0x05030107
620 {0x0F007024,0x02000007},
621 {0x0F007028,0x02020200},
622 {0x0F00702c,0x0206060a},//ROB- 0x0205050a,//0x0206060a
623 {0x0F007030,0x05000000},
624 {0x0F007034,0x00000003},
625 {0x0F007038,0x190a0200},//ROB - 0x110a0200,//0x180a0200,// 0x1f0a0200
626 {0x0F00703C,0x02101017},//ROB - 0x02101010,//0x02101018,
627 {0x0F007040,0x45171200},//ROB - 0x45751200,//0x450f1200,
628 {0x0F007044,0x11290D00},//ROB - 0x110a0d00//0x111f0d00
629 {0x0F007048,0x04080306},
630 {0x0F00704c,0x00000000},
631 {0x0F007050,0x0100001c},
632 {0x0F007054,0x00000000},
633 {0x0F007058,0x00000000},
634 {0x0F00705c,0x00000000},
635 {0x0F007060,0x0010245F},
636 {0x0F007064,0x00000010},
637 {0x0F007068,0x00000000},
638 {0x0F00706c,0x00000001},
639 {0x0F007070,0x00007000},
640 {0x0F007074,0x00000000},
641 {0x0F007078,0x00000000},
642 {0x0F00707C,0x00000000},
643 {0x0F007080,0x00000000},
644 {0x0F007084,0x00000000},
645 {0x0F007088,0x01000001},
646 {0x0F00708c,0x00000101},
647 {0x0F007090,0x00000000},
648 //# Enable BW improvement within memory controller
649 {0x0F007094,0x00040000},
650 {0x0F007098,0x00000000},
651 {0x0F0070c8,0x00000104},
652 //# Enable 2 ports within X-bar
653 //# Enable start bit within memory controller
654 {0x0F007018,0x01010000}
657 #define T3LPB_SKIP_CLOCK_PROGRAM_DUMP_100MHZ 8 //index for 0x0F007000
658 static struct bcm_ddr_setting asT3LPB_DDRSetting100MHz[]= {// # DPLL Clock Setting
659 {0x0f000810,0x00002F95},
660 {0x0f000820,0x03F1369B},
661 {0x0f000840,0x0fff0000},
662 {0x0f000860,0x00000000},
663 {0x0f000880,0x000003DD},
664 // Changed source for X-bar and MIPS clock to APLL
665 {0x0f000840,0x0FFF0000},
666 {0x0F00a044,0x1fffffff},
667 {0x0F00a040,0x1f000000},
668 {0x0f003050,0x00000021},//flash/eeprom clock divisor which set the flash clock to 20 MHz
669 {0x0F00a084,0x1Cffffff}, //dump from here in internal memory
670 {0x0F00a080,0x1C000000},
671 //Memcontroller Default values
672 {0x0F007000,0x00010001},
673 {0x0F007004,0x01010100},
674 {0x0F007008,0x01000001},
675 {0x0F00700c,0x00000000},
676 {0x0F007010,0x01000000},
677 {0x0F007014,0x01000100},
678 {0x0F007018,0x01000000},
679 {0x0F00701c,0x01020000},// POP - 0x00020001 Normal 0x01020001
680 {0x0F007020,0x04020107}, //Normal - 0x04030107 POP - 0x05030107
681 {0x0F007024,0x00000007},
682 {0x0F007028,0x01020200},
683 {0x0F00702c,0x0204040a},//ROB- 0x0205050a,//0x0206060a
684 {0x0F007030,0x06000000},
685 {0x0F007034,0x00000004},
686 {0x0F007038,0x1F080200},//ROB - 0x110a0200,//0x180a0200,// 0x1f0a0200
687 {0x0F00703C,0x0203031F},//ROB - 0x02101010,//0x02101018,
688 {0x0F007040,0x6e001200},//ROB - 0x45751200,//0x450f1200,
689 {0x0F007044,0x011a0a00},//ROB - 0x110a0d00//0x111f0d00
690 {0x0F007048,0x03000305},
691 {0x0F00704c,0x00000000},
692 {0x0F007050,0x0100001c},
693 {0x0F007054,0x00000000},
694 {0x0F007058,0x00000000},
695 {0x0F00705c,0x00000000},
696 {0x0F007060,0x00082ED6},
697 {0x0F007064,0x0000000A},
698 {0x0F007068,0x00000000},
699 {0x0F00706c,0x00000001},
700 {0x0F007070,0x00005000},
701 {0x0F007074,0x00000000},
702 {0x0F007078,0x00000000},
703 {0x0F00707C,0x00000000},
704 {0x0F007080,0x00000000},
705 {0x0F007084,0x00000000},
706 {0x0F007088,0x01000001},
707 {0x0F00708c,0x00000101},
708 {0x0F007090,0x00000000},
709 {0x0F007094,0x00010000},
710 {0x0F007098,0x00000000},
711 {0x0F0070C8,0x00000104},
712 //# Enable 2 ports within X-bar
713 {0x0F00A000,0x00000016},
714 //# Enable start bit within memory controller
715 {0x0F007018,0x01010000}
718 #define T3LPB_SKIP_CLOCK_PROGRAM_DUMP_80MHZ 7 //index for 0x0F007000
719 static struct bcm_ddr_setting asT3LPB_DDRSetting80MHz[]= {// # DPLL Clock Setting
720 {0x0f000820,0x07F13FFF},
721 {0x0f000810,0x00002F95},
722 {0x0f000860,0x00000000},
723 {0x0f000880,0x000003DD},
724 {0x0f000840,0x0FFF1F00},
725 {0x0F00a044,0x1fffffff},
726 {0x0F00a040,0x1f000000},
727 {0x0f003050,0x00000021},//flash/eeprom clock divisor which set the flash clock to 20 MHz
728 {0x0F00a084,0x1Cffffff},// dump from here in internal memory
729 {0x0F00a080,0x1C000000},
730 {0x0F00A000,0x00000016},
731 {0x0f007000,0x00010001},
732 {0x0f007004,0x01000000},
733 {0x0f007008,0x01000001},
734 {0x0f00700c,0x00000000},
735 {0x0f007010,0x01000000},
736 {0x0f007014,0x01000100},
737 {0x0f007018,0x01000000},
738 {0x0f00701c,0x01020000},
739 {0x0f007020,0x04020107},
740 {0x0f007024,0x00000007},
741 {0x0f007028,0x02020200},
742 {0x0f00702c,0x0204040a},
743 {0x0f007030,0x04000000},
744 {0x0f007034,0x00000002},
745 {0x0f007038,0x1d060200},
746 {0x0f00703c,0x1c22221d},
747 {0x0f007040,0x8A116600},
748 {0x0f007044,0x222d0800},
749 {0x0f007048,0x02690204},
750 {0x0f00704c,0x00000000},
751 {0x0f007050,0x0100001c},
752 {0x0f007054,0x00000000},
753 {0x0f007058,0x00000000},
754 {0x0f00705c,0x00000000},
755 {0x0f007060,0x000A15D6},
756 {0x0f007064,0x0000000A},
757 {0x0f007068,0x00000000},
758 {0x0f00706c,0x00000001},
759 {0x0f007070,0x00004000},
760 {0x0f007074,0x00000000},
761 {0x0f007078,0x00000000},
762 {0x0f00707c,0x00000000},
763 {0x0f007080,0x00000000},
764 {0x0f007084,0x00000000},
765 {0x0f007088,0x01000001},
766 {0x0f00708c,0x00000101},
767 {0x0f007090,0x00000000},
768 {0x0f007094,0x00010000},
769 {0x0f007098,0x00000000},
770 {0x0F0070C8,0x00000104},
771 {0x0F007018,0x01010000}
775 int ddr_init(struct bcm_mini_adapter *Adapter)
777 struct bcm_ddr_setting *psDDRSetting=NULL;
778 ULONG RegCount=0;
779 UINT value = 0;
780 UINT uiResetValue = 0;
781 UINT uiClockSetting = 0;
782 int retval = STATUS_SUCCESS;
784 switch (Adapter->chip_id)
786 case 0xbece3200:
787 switch (Adapter->DDRSetting)
789 case DDR_80_MHZ:
790 psDDRSetting=asT3LP_DDRSetting80MHz;
791 RegCount=(sizeof(asT3LP_DDRSetting80MHz)/
792 sizeof(struct bcm_ddr_setting));
793 break;
794 case DDR_100_MHZ:
795 psDDRSetting=asT3LP_DDRSetting100MHz;
796 RegCount=(sizeof(asT3LP_DDRSetting100MHz)/
797 sizeof(struct bcm_ddr_setting));
798 break;
799 case DDR_133_MHZ:
800 psDDRSetting=asT3LP_DDRSetting133MHz;
801 RegCount=(sizeof(asT3LP_DDRSetting133MHz)/
802 sizeof(struct bcm_ddr_setting));
803 if(Adapter->bMipsConfig == MIPS_200_MHZ)
805 uiClockSetting = 0x03F13652;
807 else
809 uiClockSetting = 0x03F1365B;
811 break;
812 default:
813 return -EINVAL;
816 break;
817 case T3LPB:
818 case BCS220_2:
819 case BCS220_2BC:
820 case BCS250_BC:
821 case BCS220_3 :
822 /* Set bit 2 and bit 6 to 1 for BBIC 2mA drive
823 * (please check current value and additionally set these bits)
825 if( (Adapter->chip_id != BCS220_2) &&
826 (Adapter->chip_id != BCS220_2BC) &&
827 (Adapter->chip_id != BCS220_3) )
829 retval= rdmalt(Adapter,(UINT)0x0f000830, &uiResetValue, sizeof(uiResetValue));
830 if(retval < 0) {
831 BCM_DEBUG_PRINT(Adapter,CMHOST, RDM, DBG_LVL_ALL, "%s:%d RDM failed\n", __FUNCTION__, __LINE__);
832 return retval;
834 uiResetValue |= 0x44;
835 retval = wrmalt(Adapter,(UINT)0x0f000830, &uiResetValue, sizeof(uiResetValue));
836 if(retval < 0) {
837 BCM_DEBUG_PRINT(Adapter,CMHOST, WRM, DBG_LVL_ALL, "%s:%d WRM failed\n", __FUNCTION__, __LINE__);
838 return retval;
841 switch(Adapter->DDRSetting)
846 case DDR_80_MHZ:
847 psDDRSetting = asT3LPB_DDRSetting80MHz;
848 RegCount=(sizeof(asT3B_DDRSetting80MHz)/
849 sizeof(struct bcm_ddr_setting));
850 break;
851 case DDR_100_MHZ:
852 psDDRSetting=asT3LPB_DDRSetting100MHz;
853 RegCount=(sizeof(asT3B_DDRSetting100MHz)/
854 sizeof(struct bcm_ddr_setting));
855 break;
856 case DDR_133_MHZ:
857 psDDRSetting = asT3LPB_DDRSetting133MHz;
858 RegCount=(sizeof(asT3B_DDRSetting133MHz)/
859 sizeof(struct bcm_ddr_setting));
861 if(Adapter->bMipsConfig == MIPS_200_MHZ)
863 uiClockSetting = 0x03F13652;
865 else
867 uiClockSetting = 0x03F1365B;
869 break;
871 case DDR_160_MHZ:
872 psDDRSetting = asT3LPB_DDRSetting160MHz;
873 RegCount = sizeof(asT3LPB_DDRSetting160MHz)/sizeof(struct bcm_ddr_setting);
875 if(Adapter->bMipsConfig == MIPS_200_MHZ)
877 uiClockSetting = 0x03F137D2;
879 else
881 uiClockSetting = 0x03F137DB;
884 break;
886 case 0xbece0110:
887 case 0xbece0120:
888 case 0xbece0121:
889 case 0xbece0130:
890 case 0xbece0300:
891 BCM_DEBUG_PRINT(Adapter,DBG_TYPE_INITEXIT, DRV_ENTRY, DBG_LVL_ALL, "DDR Setting: %x\n", Adapter->DDRSetting);
892 switch (Adapter->DDRSetting)
894 case DDR_80_MHZ:
895 psDDRSetting = asT3_DDRSetting80MHz;
896 RegCount = (sizeof(asT3_DDRSetting80MHz)/
897 sizeof(struct bcm_ddr_setting));
898 break;
899 case DDR_100_MHZ:
900 psDDRSetting = asT3_DDRSetting100MHz;
901 RegCount = (sizeof(asT3_DDRSetting100MHz)/
902 sizeof(struct bcm_ddr_setting));
903 break;
904 case DDR_133_MHZ:
905 psDDRSetting = asT3_DDRSetting133MHz;
906 RegCount = (sizeof(asT3_DDRSetting133MHz)/
907 sizeof(struct bcm_ddr_setting));
908 break;
909 default:
910 return -EINVAL;
912 case 0xbece0310:
914 switch (Adapter->DDRSetting)
916 case DDR_80_MHZ:
917 psDDRSetting = asT3B_DDRSetting80MHz;
918 RegCount=(sizeof(asT3B_DDRSetting80MHz)/
919 sizeof(struct bcm_ddr_setting));
920 break;
921 case DDR_100_MHZ:
922 psDDRSetting=asT3B_DDRSetting100MHz;
923 RegCount=(sizeof(asT3B_DDRSetting100MHz)/
924 sizeof(struct bcm_ddr_setting));
925 break;
926 case DDR_133_MHZ:
928 if(Adapter->bDPLLConfig == PLL_266_MHZ)//266Mhz PLL selected.
930 memcpy(asT3B_DDRSetting133MHz, asDPLL_266MHZ,
931 sizeof(asDPLL_266MHZ));
932 psDDRSetting = asT3B_DDRSetting133MHz;
933 RegCount=(sizeof(asT3B_DDRSetting133MHz)/
934 sizeof(struct bcm_ddr_setting));
936 else
938 psDDRSetting = asT3B_DDRSetting133MHz;
939 RegCount=(sizeof(asT3B_DDRSetting133MHz)/
940 sizeof(struct bcm_ddr_setting));
941 if(Adapter->bMipsConfig == MIPS_200_MHZ)
943 uiClockSetting = 0x07F13652;
945 else
947 uiClockSetting = 0x07F1365B;
950 break;
951 default:
952 return -EINVAL;
954 break;
957 default:
958 return -EINVAL;
961 value=0;
962 BCM_DEBUG_PRINT(Adapter,DBG_TYPE_INITEXIT, DRV_ENTRY, DBG_LVL_ALL, "Register Count is =%lu\n", RegCount);
963 while(RegCount && !retval)
965 if(uiClockSetting && psDDRSetting->ulRegAddress == MIPS_CLOCK_REG)
967 value = uiClockSetting;
969 else
971 value = psDDRSetting->ulRegValue;
973 retval = wrmalt(Adapter, psDDRSetting->ulRegAddress, &value, sizeof(value));
974 if(STATUS_SUCCESS != retval) {
975 BCM_DEBUG_PRINT(Adapter,DBG_TYPE_PRINTK, 0, 0,"%s:%d\n", __FUNCTION__, __LINE__);
976 break;
979 RegCount--;
980 psDDRSetting++;
983 if(Adapter->chip_id >= 0xbece3300 )
986 mdelay(3);
987 if( (Adapter->chip_id != BCS220_2)&&
988 (Adapter->chip_id != BCS220_2BC)&&
989 (Adapter->chip_id != BCS220_3))
991 /* drive MDDR to half in case of UMA-B: */
992 uiResetValue = 0x01010001;
993 retval = wrmalt(Adapter, (UINT)0x0F007018, &uiResetValue, sizeof(uiResetValue));
994 if(retval < 0) {
995 BCM_DEBUG_PRINT(Adapter,CMHOST, RDM, DBG_LVL_ALL, "%s:%d RDM failed\n", __FUNCTION__, __LINE__);
996 return retval;
998 uiResetValue = 0x00040020;
999 retval = wrmalt(Adapter, (UINT)0x0F007094, &uiResetValue, sizeof(uiResetValue));
1000 if(retval < 0) {
1001 BCM_DEBUG_PRINT(Adapter,CMHOST, RDM, DBG_LVL_ALL, "%s:%d RDM failed\n", __FUNCTION__, __LINE__);
1002 return retval;
1004 uiResetValue = 0x01020101;
1005 retval = wrmalt(Adapter, (UINT)0x0F00701c, &uiResetValue, sizeof(uiResetValue));
1006 if(retval < 0) {
1007 BCM_DEBUG_PRINT(Adapter,CMHOST, RDM, DBG_LVL_ALL, "%s:%d RDM failed\n", __FUNCTION__, __LINE__);
1008 return retval;
1010 uiResetValue = 0x01010000;
1011 retval = wrmalt(Adapter, (UINT)0x0F007018, &uiResetValue, sizeof(uiResetValue));
1012 if(retval < 0) {
1013 BCM_DEBUG_PRINT(Adapter,CMHOST, RDM, DBG_LVL_ALL, "%s:%d RDM failed\n", __FUNCTION__, __LINE__);
1014 return retval;
1017 mdelay(3);
1019 /* DC/DC standby change...
1020 * This is to be done only for Hybrid PMU mode.
1021 * with the current h/w there is no way to detect this.
1022 * and since we dont have internal PMU lets do it under UMA-B chip id.
1023 * we will change this when we will have internal PMU.
1025 if(Adapter->PmuMode == HYBRID_MODE_7C)
1027 retval = rdmalt(Adapter,(UINT)0x0f000c00, &uiResetValue, sizeof(uiResetValue));
1028 if(retval < 0) {
1029 BCM_DEBUG_PRINT(Adapter,CMHOST, RDM, DBG_LVL_ALL, "%s:%d RDM failed\n", __FUNCTION__, __LINE__);
1030 return retval;
1032 retval = rdmalt(Adapter,(UINT)0x0f000c00, &uiResetValue, sizeof(uiResetValue));
1033 if(retval < 0) {
1034 BCM_DEBUG_PRINT(Adapter,CMHOST, RDM, DBG_LVL_ALL, "%s:%d RDM failed\n", __FUNCTION__, __LINE__);
1035 return retval;
1037 uiResetValue = 0x1322a8;
1038 retval = wrmalt(Adapter, (UINT)0x0f000d1c, &uiResetValue, sizeof(uiResetValue));
1039 if(retval < 0) {
1040 BCM_DEBUG_PRINT(Adapter,CMHOST, RDM, DBG_LVL_ALL, "%s:%d RDM failed\n", __FUNCTION__, __LINE__);
1041 return retval;
1043 retval = rdmalt(Adapter,(UINT)0x0f000c00, &uiResetValue, sizeof(uiResetValue));
1044 if(retval < 0) {
1045 BCM_DEBUG_PRINT(Adapter,DBG_TYPE_PRINTK, RDM, DBG_LVL_ALL, "%s:%d RDM failed\n", __FUNCTION__, __LINE__);
1046 return retval;
1048 retval = rdmalt(Adapter,(UINT)0x0f000c00, &uiResetValue, sizeof(uiResetValue));
1049 if(retval < 0) {
1050 BCM_DEBUG_PRINT(Adapter,CMHOST, RDM, DBG_LVL_ALL, "%s:%d RDM failed\n", __FUNCTION__, __LINE__);
1051 return retval;
1053 uiResetValue = 0x132296;
1054 retval = wrmalt(Adapter, (UINT)0x0f000d14, &uiResetValue, sizeof(uiResetValue));
1055 if(retval < 0) {
1056 BCM_DEBUG_PRINT(Adapter,CMHOST, RDM, DBG_LVL_ALL, "%s:%d RDM failed\n", __FUNCTION__, __LINE__);
1057 return retval;
1060 else if(Adapter->PmuMode == HYBRID_MODE_6 )
1063 retval = rdmalt(Adapter,(UINT)0x0f000c00, &uiResetValue, sizeof(uiResetValue));
1064 if(retval < 0) {
1065 BCM_DEBUG_PRINT(Adapter,CMHOST, RDM, DBG_LVL_ALL, "%s:%d RDM failed\n", __FUNCTION__, __LINE__);
1066 return retval;
1068 retval = rdmalt(Adapter,(UINT)0x0f000c00, &uiResetValue, sizeof(uiResetValue));
1069 if(retval < 0) {
1070 BCM_DEBUG_PRINT(Adapter,CMHOST, RDM, DBG_LVL_ALL, "%s:%d RDM failed\n", __FUNCTION__, __LINE__);
1071 return retval;
1073 uiResetValue = 0x6003229a;
1074 retval = wrmalt(Adapter, (UINT)0x0f000d14, &uiResetValue, sizeof(uiResetValue));
1075 if(retval < 0) {
1076 BCM_DEBUG_PRINT(Adapter,CMHOST, RDM, DBG_LVL_ALL, "%s:%d RDM failed\n", __FUNCTION__, __LINE__);
1077 return retval;
1079 retval = rdmalt(Adapter,(UINT)0x0f000c00, &uiResetValue, sizeof(uiResetValue));
1080 if(retval < 0) {
1081 BCM_DEBUG_PRINT(Adapter,CMHOST, RDM, DBG_LVL_ALL, "%s:%d RDM failed\n", __FUNCTION__, __LINE__);
1082 return retval;
1084 retval = rdmalt(Adapter,(UINT)0x0f000c00, &uiResetValue, sizeof(uiResetValue));
1085 if(retval < 0) {
1086 BCM_DEBUG_PRINT(Adapter,CMHOST, RDM, DBG_LVL_ALL, "%s:%d RDM failed\n", __FUNCTION__, __LINE__);
1087 return retval;
1089 uiResetValue = 0x1322a8;
1090 retval = wrmalt(Adapter, (UINT)0x0f000d1c, &uiResetValue, sizeof(uiResetValue));
1091 if(retval < 0) {
1092 BCM_DEBUG_PRINT(Adapter,CMHOST, RDM, DBG_LVL_ALL, "%s:%d RDM failed\n", __FUNCTION__, __LINE__);
1093 return retval;
1098 Adapter->bDDRInitDone = TRUE;
1099 return retval;
1102 int download_ddr_settings(struct bcm_mini_adapter *Adapter)
1104 struct bcm_ddr_setting *psDDRSetting=NULL;
1105 ULONG RegCount=0;
1106 unsigned long ul_ddr_setting_load_addr = DDR_DUMP_INTERNAL_DEVICE_MEMORY;
1107 UINT value = 0;
1108 int retval = STATUS_SUCCESS;
1109 BOOLEAN bOverrideSelfRefresh = FALSE;
1111 switch (Adapter->chip_id)
1113 case 0xbece3200:
1114 switch (Adapter->DDRSetting)
1116 case DDR_80_MHZ:
1117 psDDRSetting = asT3LP_DDRSetting80MHz;
1118 RegCount = ARRAY_SIZE(asT3LP_DDRSetting80MHz);
1119 RegCount -= T3LP_SKIP_CLOCK_PROGRAM_DUMP_80MHZ ;
1120 psDDRSetting += T3LP_SKIP_CLOCK_PROGRAM_DUMP_80MHZ;
1121 break;
1122 case DDR_100_MHZ:
1123 psDDRSetting = asT3LP_DDRSetting100MHz;
1124 RegCount = ARRAY_SIZE(asT3LP_DDRSetting100MHz);
1125 RegCount -= T3LP_SKIP_CLOCK_PROGRAM_DUMP_100MHZ ;
1126 psDDRSetting += T3LP_SKIP_CLOCK_PROGRAM_DUMP_100MHZ;
1127 break;
1128 case DDR_133_MHZ:
1129 bOverrideSelfRefresh = TRUE;
1130 psDDRSetting = asT3LP_DDRSetting133MHz;
1131 RegCount = ARRAY_SIZE(asT3LP_DDRSetting133MHz);
1132 RegCount -= T3LP_SKIP_CLOCK_PROGRAM_DUMP_133MHZ ;
1133 psDDRSetting += T3LP_SKIP_CLOCK_PROGRAM_DUMP_133MHZ;
1134 break;
1135 default:
1136 return -EINVAL;
1138 break;
1140 case T3LPB:
1141 case BCS220_2:
1142 case BCS220_2BC:
1143 case BCS250_BC:
1144 case BCS220_3 :
1145 switch (Adapter->DDRSetting)
1147 case DDR_80_MHZ:
1148 psDDRSetting = asT3LPB_DDRSetting80MHz;
1149 RegCount=ARRAY_SIZE(asT3LPB_DDRSetting80MHz);
1150 RegCount -= T3LPB_SKIP_CLOCK_PROGRAM_DUMP_80MHZ ;
1151 psDDRSetting += T3LPB_SKIP_CLOCK_PROGRAM_DUMP_80MHZ;
1152 break;
1153 case DDR_100_MHZ:
1154 psDDRSetting = asT3LPB_DDRSetting100MHz;
1155 RegCount = ARRAY_SIZE(asT3LPB_DDRSetting100MHz);
1156 RegCount -= T3LPB_SKIP_CLOCK_PROGRAM_DUMP_100MHZ ;
1157 psDDRSetting += T3LPB_SKIP_CLOCK_PROGRAM_DUMP_100MHZ;
1158 break;
1159 case DDR_133_MHZ:
1160 bOverrideSelfRefresh = TRUE;
1161 psDDRSetting = asT3LPB_DDRSetting133MHz;
1162 RegCount = ARRAY_SIZE(asT3LPB_DDRSetting133MHz);
1163 RegCount -= T3LPB_SKIP_CLOCK_PROGRAM_DUMP_133MHZ ;
1164 psDDRSetting += T3LPB_SKIP_CLOCK_PROGRAM_DUMP_133MHZ;
1165 break;
1167 case DDR_160_MHZ:
1168 bOverrideSelfRefresh = TRUE;
1169 psDDRSetting = asT3LPB_DDRSetting160MHz;
1170 RegCount = ARRAY_SIZE(asT3LPB_DDRSetting160MHz);
1171 RegCount -= T3LPB_SKIP_CLOCK_PROGRAM_DUMP_160MHZ;
1172 psDDRSetting += T3LPB_SKIP_CLOCK_PROGRAM_DUMP_160MHZ;
1174 break;
1175 default:
1176 return -EINVAL;
1178 break;
1179 case 0xbece0300:
1180 switch (Adapter->DDRSetting)
1182 case DDR_80_MHZ:
1183 psDDRSetting = asT3_DDRSetting80MHz;
1184 RegCount = ARRAY_SIZE(asT3_DDRSetting80MHz);
1185 RegCount-=T3_SKIP_CLOCK_PROGRAM_DUMP_80MHZ ;
1186 psDDRSetting += T3_SKIP_CLOCK_PROGRAM_DUMP_80MHZ;
1187 break;
1188 case DDR_100_MHZ:
1189 psDDRSetting = asT3_DDRSetting100MHz;
1190 RegCount = ARRAY_SIZE(asT3_DDRSetting100MHz);
1191 RegCount-=T3_SKIP_CLOCK_PROGRAM_DUMP_100MHZ ;
1192 psDDRSetting += T3_SKIP_CLOCK_PROGRAM_DUMP_100MHZ;
1193 break;
1194 case DDR_133_MHZ:
1195 psDDRSetting = asT3_DDRSetting133MHz;
1196 RegCount = ARRAY_SIZE(asT3_DDRSetting133MHz);
1197 RegCount-=T3_SKIP_CLOCK_PROGRAM_DUMP_133MHZ ;
1198 psDDRSetting += T3_SKIP_CLOCK_PROGRAM_DUMP_133MHZ ;
1199 break;
1200 default:
1201 return -EINVAL;
1203 break;
1204 case 0xbece0310:
1206 switch (Adapter->DDRSetting)
1208 case DDR_80_MHZ:
1209 psDDRSetting = asT3B_DDRSetting80MHz;
1210 RegCount = ARRAY_SIZE(asT3B_DDRSetting80MHz);
1211 RegCount -= T3B_SKIP_CLOCK_PROGRAM_DUMP_80MHZ ;
1212 psDDRSetting += T3B_SKIP_CLOCK_PROGRAM_DUMP_80MHZ;
1213 break;
1214 case DDR_100_MHZ:
1215 psDDRSetting = asT3B_DDRSetting100MHz;
1216 RegCount = ARRAY_SIZE(asT3B_DDRSetting100MHz);
1217 RegCount -= T3B_SKIP_CLOCK_PROGRAM_DUMP_100MHZ ;
1218 psDDRSetting += T3B_SKIP_CLOCK_PROGRAM_DUMP_100MHZ;
1219 break;
1220 case DDR_133_MHZ:
1221 bOverrideSelfRefresh = TRUE;
1222 psDDRSetting = asT3B_DDRSetting133MHz;
1223 RegCount = ARRAY_SIZE(asT3B_DDRSetting133MHz);
1224 RegCount -= T3B_SKIP_CLOCK_PROGRAM_DUMP_133MHZ ;
1225 psDDRSetting += T3B_SKIP_CLOCK_PROGRAM_DUMP_133MHZ;
1226 break;
1228 break;
1230 default:
1231 return -EINVAL;
1233 //total number of Register that has to be dumped
1234 value =RegCount ;
1235 retval = wrmalt(Adapter, ul_ddr_setting_load_addr, &value, sizeof(value));
1236 if(retval)
1238 BCM_DEBUG_PRINT(Adapter,DBG_TYPE_PRINTK, 0, 0,"%s:%d\n", __FUNCTION__, __LINE__);
1240 return retval;
1242 ul_ddr_setting_load_addr+=sizeof(ULONG);
1243 /*signature */
1244 value =(0x1d1e0dd0);
1245 retval = wrmalt(Adapter, ul_ddr_setting_load_addr, &value, sizeof(value));
1246 if(retval)
1248 BCM_DEBUG_PRINT(Adapter,DBG_TYPE_PRINTK, 0, 0,"%s:%d\n", __FUNCTION__, __LINE__);
1249 return retval;
1252 ul_ddr_setting_load_addr+=sizeof(ULONG);
1253 RegCount*=(sizeof(struct bcm_ddr_setting)/sizeof(ULONG));
1255 while(RegCount && !retval)
1257 value = psDDRSetting->ulRegAddress ;
1258 retval = wrmalt( Adapter, ul_ddr_setting_load_addr, &value, sizeof(value));
1259 ul_ddr_setting_load_addr+=sizeof(ULONG);
1260 if(!retval)
1262 if(bOverrideSelfRefresh && (psDDRSetting->ulRegAddress == 0x0F007018))
1264 value = (psDDRSetting->ulRegValue |(1<<8));
1265 if(STATUS_SUCCESS != wrmalt(Adapter, ul_ddr_setting_load_addr,
1266 &value, sizeof(value))){
1267 BCM_DEBUG_PRINT(Adapter,DBG_TYPE_PRINTK, 0, 0,"%s:%d\n", __FUNCTION__, __LINE__);
1268 break;
1271 else
1273 value = psDDRSetting->ulRegValue;
1275 if(STATUS_SUCCESS != wrmalt(Adapter, ul_ddr_setting_load_addr ,
1276 &value, sizeof(value))){
1277 BCM_DEBUG_PRINT(Adapter,DBG_TYPE_PRINTK, 0, 0,"%s:%d\n", __FUNCTION__, __LINE__);
1278 break;
1282 ul_ddr_setting_load_addr+=sizeof(ULONG);
1283 RegCount--;
1284 psDDRSetting++;
1286 return retval;