mip405.c 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803
  1. /*
  2. * (C) Copyright 2001
  3. * Denis Peter, MPL AG Switzerland, d.peter@mpl.ch
  4. *
  5. * SPDX-License-Identifier: GPL-2.0+
  6. *
  7. * TODO: clean-up
  8. */
  9. /*
  10. * How do I program the SDRAM Timing Register (SDRAM0_TR) for a specific SDRAM or DIMM?
  11. *
  12. * As an example, consider a case where PC133 memory with CAS Latency equal to 2 is being
  13. * used with a 200MHz 405GP. For a typical 128Mb, PC133 SDRAM, the relevant minimum
  14. * parameters from the datasheet are:
  15. * Tclk = 7.5ns (CL = 2)
  16. * Trp = 15ns
  17. * Trc = 60ns
  18. * Trcd = 15ns
  19. * Trfc = 66ns
  20. *
  21. * If we are operating the 405GP with the MemClk output frequency set to 100 MHZ, the clock
  22. * period is 10ns and the parameters needed for the Timing Register are:
  23. * CASL = CL = 2 clock cycles
  24. * PTA = Trp = 15ns / 10ns = 2 clock cycles
  25. * CTP = Trc - Trcd - Trp = (60ns - 15ns - 15ns) / 10ns= 3 clock cycles
  26. * LDF = 2 clock cycles (but can be extended to meet board-level timing)
  27. * RFTA = Trfc = 66ns / 10ns= 7 clock cycles
  28. * RCD = Trcd = 15ns / 10ns= 2 clock cycles
  29. *
  30. * The actual bit settings in the register would be:
  31. *
  32. * CASL = 0b01
  33. * PTA = 0b01
  34. * CTP = 0b10
  35. * LDF = 0b01
  36. * RFTA = 0b011
  37. * RCD = 0b01
  38. *
  39. * If Trfc is not specified in the datasheet for PC100 or PC133 memory, set RFTA = Trc
  40. * instead. Figure 24 in the PC SDRAM Specification Rev. 1.7 shows refresh to active delay
  41. * defined as Trc rather than Trfc.
  42. * When using DIMM modules, most but not all of the required timing parameters can be read
  43. * from the Serial Presence Detect (SPD) EEPROM on the module. Specifically, Trc and Trfc
  44. * are not available from the EEPROM
  45. */
  46. #include <common.h>
  47. #include "mip405.h"
  48. #include <asm/processor.h>
  49. #include <asm/ppc4xx.h>
  50. #include <asm/ppc4xx-i2c.h>
  51. #include <miiphy.h>
  52. #include "../common/common_util.h"
  53. #include <stdio_dev.h>
  54. #include <i2c.h>
  55. #include <rtc.h>
  56. DECLARE_GLOBAL_DATA_PTR;
  57. #undef SDRAM_DEBUG
  58. #define ENABLE_ECC /* for ecc boards */
  59. /* stdlib.h causes some compatibility problems; should fixe these! -- wd */
  60. #ifndef __ldiv_t_defined
  61. typedef struct {
  62. long int quot; /* Quotient */
  63. long int rem; /* Remainder */
  64. } ldiv_t;
  65. extern ldiv_t ldiv (long int __numer, long int __denom);
  66. # define __ldiv_t_defined 1
  67. #endif
  68. #define PLD_PART_REG PER_PLD_ADDR + 0
  69. #define PLD_VERS_REG PER_PLD_ADDR + 1
  70. #define PLD_BOARD_CFG_REG PER_PLD_ADDR + 2
  71. #define PLD_IRQ_REG PER_PLD_ADDR + 3
  72. #define PLD_COM_MODE_REG PER_PLD_ADDR + 4
  73. #define PLD_EXT_CONF_REG PER_PLD_ADDR + 5
  74. #define MEGA_BYTE (1024*1024)
  75. typedef struct {
  76. unsigned char boardtype; /* Board revision and Population Options */
  77. unsigned char cal; /* cas Latency (will be programmend as cal-1) */
  78. unsigned char trp; /* datain27 in clocks */
  79. unsigned char trcd; /* datain29 in clocks */
  80. unsigned char tras; /* datain30 in clocks */
  81. unsigned char tctp; /* tras - trcd in clocks */
  82. unsigned char am; /* Address Mod (will be programmed as am-1) */
  83. unsigned char sz; /* log binary => Size = (4MByte<<sz) 5 = 128, 4 = 64, 3 = 32, 2 = 16, 1=8 */
  84. unsigned char ecc; /* if true, ecc is enabled */
  85. } sdram_t;
  86. #if defined(CONFIG_TARGET_MIP405T)
  87. const sdram_t sdram_table[] = {
  88. { 0x0F, /* MIP405T Rev A, 64MByte -1 Board */
  89. 3, /* Case Latenty = 3 */
  90. 3, /* trp 20ns / 7.5 ns datain[27] */
  91. 3, /* trcd 20ns /7.5 ns (datain[29]) */
  92. 6, /* tras 44ns /7.5 ns (datain[30]) */
  93. 4, /* tcpt 44 - 20ns = 24ns */
  94. 2, /* Address Mode = 2 (12x9x4) */
  95. 3, /* size value (32MByte) */
  96. 0}, /* ECC disabled */
  97. { 0xff, /* terminator */
  98. 0xff,
  99. 0xff,
  100. 0xff,
  101. 0xff,
  102. 0xff,
  103. 0xff,
  104. 0xff }
  105. };
  106. #else
  107. const sdram_t sdram_table[] = {
  108. { 0x0f, /* Rev A, 128MByte -1 Board */
  109. 3, /* Case Latenty = 3 */
  110. 3, /* trp 20ns / 7.5 ns datain[27] */
  111. 3, /* trcd 20ns /7.5 ns (datain[29]) */
  112. 6, /* tras 44ns /7.5 ns (datain[30]) */
  113. 4, /* tcpt 44 - 20ns = 24ns */
  114. 3, /* Address Mode = 3 */
  115. 5, /* size value */
  116. 1}, /* ECC enabled */
  117. { 0x07, /* Rev A, 64MByte -2 Board */
  118. 3, /* Case Latenty = 3 */
  119. 3, /* trp 20ns / 7.5 ns datain[27] */
  120. 3, /* trcd 20ns /7.5 ns (datain[29]) */
  121. 6, /* tras 44ns /7.5 ns (datain[30]) */
  122. 4, /* tcpt 44 - 20ns = 24ns */
  123. 2, /* Address Mode = 2 */
  124. 4, /* size value */
  125. 1}, /* ECC enabled */
  126. { 0x03, /* Rev A, 128MByte -4 Board */
  127. 3, /* Case Latenty = 3 */
  128. 3, /* trp 20ns / 7.5 ns datain[27] */
  129. 3, /* trcd 20ns /7.5 ns (datain[29]) */
  130. 6, /* tras 44ns /7.5 ns (datain[30]) */
  131. 4, /* tcpt 44 - 20ns = 24ns */
  132. 3, /* Address Mode = 3 */
  133. 5, /* size value */
  134. 1}, /* ECC enabled */
  135. { 0x1f, /* Rev B, 128MByte -3 Board */
  136. 3, /* Case Latenty = 3 */
  137. 3, /* trp 20ns / 7.5 ns datain[27] */
  138. 3, /* trcd 20ns /7.5 ns (datain[29]) */
  139. 6, /* tras 44ns /7.5 ns (datain[30]) */
  140. 4, /* tcpt 44 - 20ns = 24ns */
  141. 3, /* Address Mode = 3 */
  142. 5, /* size value */
  143. 1}, /* ECC enabled */
  144. { 0x2f, /* Rev C, 128MByte -3 Board */
  145. 3, /* Case Latenty = 3 */
  146. 3, /* trp 20ns / 7.5 ns datain[27] */
  147. 3, /* trcd 20ns /7.5 ns (datain[29]) */
  148. 6, /* tras 44ns /7.5 ns (datain[30]) */
  149. 4, /* tcpt 44 - 20ns = 24ns */
  150. 3, /* Address Mode = 3 */
  151. 5, /* size value */
  152. 1}, /* ECC enabled */
  153. { 0xff, /* terminator */
  154. 0xff,
  155. 0xff,
  156. 0xff,
  157. 0xff,
  158. 0xff,
  159. 0xff,
  160. 0xff }
  161. };
  162. #endif /*CONFIG_TARGET_MIP405T */
  163. void SDRAM_err (const char *s)
  164. {
  165. #ifndef SDRAM_DEBUG
  166. (void) get_clocks ();
  167. gd->baudrate = 9600;
  168. serial_init ();
  169. #endif
  170. serial_puts ("\n");
  171. serial_puts (s);
  172. serial_puts ("\n enable SDRAM_DEBUG for more info\n");
  173. for (;;);
  174. }
  175. unsigned char get_board_revcfg (void)
  176. {
  177. out8 (PER_BOARD_ADDR, 0);
  178. return (in8 (PER_BOARD_ADDR));
  179. }
  180. #ifdef SDRAM_DEBUG
  181. void write_hex (unsigned char i)
  182. {
  183. char cc;
  184. cc = i >> 4;
  185. cc &= 0xf;
  186. if (cc > 9)
  187. serial_putc (cc + 55);
  188. else
  189. serial_putc (cc + 48);
  190. cc = i & 0xf;
  191. if (cc > 9)
  192. serial_putc (cc + 55);
  193. else
  194. serial_putc (cc + 48);
  195. }
  196. void write_4hex (unsigned long val)
  197. {
  198. write_hex ((unsigned char) (val >> 24));
  199. write_hex ((unsigned char) (val >> 16));
  200. write_hex ((unsigned char) (val >> 8));
  201. write_hex ((unsigned char) val);
  202. }
  203. #endif
  204. int init_sdram (void)
  205. {
  206. unsigned long tmp, baseaddr;
  207. unsigned short i;
  208. unsigned char trp_clocks,
  209. trcd_clocks,
  210. tras_clocks,
  211. trc_clocks;
  212. unsigned char cal_val;
  213. unsigned char bc;
  214. unsigned long sdram_tim, sdram_bank;
  215. /*i2c_init (CONFIG_SYS_I2C_SPEED, CONFIG_SYS_I2C_SLAVE);*/
  216. (void) get_clocks ();
  217. gd->baudrate = 9600;
  218. serial_init ();
  219. /* set up the pld */
  220. mtdcr (EBC0_CFGADDR, PB7AP);
  221. mtdcr (EBC0_CFGDATA, PLD_AP);
  222. mtdcr (EBC0_CFGADDR, PB7CR);
  223. mtdcr (EBC0_CFGDATA, PLD_CR);
  224. /* THIS IS OBSOLETE */
  225. /* set up the board rev reg*/
  226. mtdcr (EBC0_CFGADDR, PB5AP);
  227. mtdcr (EBC0_CFGDATA, BOARD_AP);
  228. mtdcr (EBC0_CFGADDR, PB5CR);
  229. mtdcr (EBC0_CFGDATA, BOARD_CR);
  230. #ifdef SDRAM_DEBUG
  231. /* get all informations from PLD */
  232. serial_puts ("\nPLD Part 0x");
  233. bc = in8 (PLD_PART_REG);
  234. write_hex (bc);
  235. serial_puts ("\nPLD Vers 0x");
  236. bc = in8 (PLD_VERS_REG);
  237. write_hex (bc);
  238. serial_puts ("\nBoard Rev 0x");
  239. bc = in8 (PLD_BOARD_CFG_REG);
  240. write_hex (bc);
  241. serial_puts ("\n");
  242. #endif
  243. /* check board */
  244. bc = in8 (PLD_PART_REG);
  245. #if defined(CONFIG_TARGET_MIP405T)
  246. if((bc & 0x80)==0)
  247. SDRAM_err ("U-Boot configured for a MIP405T not for a MIP405!!!\n");
  248. #else
  249. if((bc & 0x80)==0x80)
  250. SDRAM_err ("U-Boot configured for a MIP405 not for a MIP405T!!!\n");
  251. #endif
  252. /* set-up the chipselect machine */
  253. mtdcr (EBC0_CFGADDR, PB0CR); /* get cs0 config reg */
  254. tmp = mfdcr (EBC0_CFGDATA);
  255. if ((tmp & 0x00002000) == 0) {
  256. /* MPS Boot, set up the flash */
  257. mtdcr (EBC0_CFGADDR, PB1AP);
  258. mtdcr (EBC0_CFGDATA, FLASH_AP);
  259. mtdcr (EBC0_CFGADDR, PB1CR);
  260. mtdcr (EBC0_CFGDATA, FLASH_CR);
  261. } else {
  262. /* Flash boot, set up the MPS */
  263. mtdcr (EBC0_CFGADDR, PB1AP);
  264. mtdcr (EBC0_CFGDATA, MPS_AP);
  265. mtdcr (EBC0_CFGADDR, PB1CR);
  266. mtdcr (EBC0_CFGDATA, MPS_CR);
  267. }
  268. /* set up UART0 (CS2) and UART1 (CS3) */
  269. mtdcr (EBC0_CFGADDR, PB2AP);
  270. mtdcr (EBC0_CFGDATA, UART0_AP);
  271. mtdcr (EBC0_CFGADDR, PB2CR);
  272. mtdcr (EBC0_CFGDATA, UART0_CR);
  273. mtdcr (EBC0_CFGADDR, PB3AP);
  274. mtdcr (EBC0_CFGDATA, UART1_AP);
  275. mtdcr (EBC0_CFGADDR, PB3CR);
  276. mtdcr (EBC0_CFGDATA, UART1_CR);
  277. bc = in8 (PLD_BOARD_CFG_REG);
  278. #ifdef SDRAM_DEBUG
  279. serial_puts ("\nstart SDRAM Setup\n");
  280. serial_puts ("\nBoard Rev: ");
  281. write_hex (bc);
  282. serial_puts ("\n");
  283. #endif
  284. i = 0;
  285. baseaddr = CONFIG_SYS_SDRAM_BASE;
  286. while (sdram_table[i].sz != 0xff) {
  287. if (sdram_table[i].boardtype == bc)
  288. break;
  289. i++;
  290. }
  291. if (sdram_table[i].boardtype != bc)
  292. SDRAM_err ("No SDRAM table found for this board!!!\n");
  293. #ifdef SDRAM_DEBUG
  294. serial_puts (" found table ");
  295. write_hex (i);
  296. serial_puts (" \n");
  297. #endif
  298. /* since the ECC initialisation needs some time,
  299. * we show that we're alive
  300. */
  301. if (sdram_table[i].ecc)
  302. serial_puts ("\nInitializing SDRAM, Please stand by");
  303. cal_val = sdram_table[i].cal - 1; /* Cas Latency */
  304. trp_clocks = sdram_table[i].trp; /* 20ns / 7.5 ns datain[27] */
  305. trcd_clocks = sdram_table[i].trcd; /* 20ns /7.5 ns (datain[29]) */
  306. tras_clocks = sdram_table[i].tras; /* 44ns /7.5 ns (datain[30]) */
  307. /* ctp = ((trp + tras) - trp - trcd) => tras - trcd */
  308. /* trc_clocks is sum of trp_clocks + tras_clocks */
  309. trc_clocks = trp_clocks + tras_clocks;
  310. /* get SDRAM timing register */
  311. mtdcr (SDRAM0_CFGADDR, SDRAM0_TR);
  312. sdram_tim = mfdcr (SDRAM0_CFGDATA) & ~0x018FC01F;
  313. /* insert CASL value */
  314. sdram_tim |= ((unsigned long) (cal_val)) << 23;
  315. /* insert PTA value */
  316. sdram_tim |= ((unsigned long) (trp_clocks - 1)) << 18;
  317. /* insert CTP value */
  318. sdram_tim |=
  319. ((unsigned long) (trc_clocks - trp_clocks -
  320. trcd_clocks)) << 16;
  321. /* insert LDF (always 01) */
  322. sdram_tim |= ((unsigned long) 0x01) << 14;
  323. /* insert RFTA value */
  324. sdram_tim |= ((unsigned long) (trc_clocks - 4)) << 2;
  325. /* insert RCD value */
  326. sdram_tim |= ((unsigned long) (trcd_clocks - 1)) << 0;
  327. tmp = ((unsigned long) (sdram_table[i].am - 1) << 13); /* AM = 3 */
  328. /* insert SZ value; */
  329. tmp |= ((unsigned long) sdram_table[i].sz << 17);
  330. /* get SDRAM bank 0 register */
  331. mtdcr (SDRAM0_CFGADDR, SDRAM0_B0CR);
  332. sdram_bank = mfdcr (SDRAM0_CFGDATA) & ~0xFFCEE001;
  333. sdram_bank |= (baseaddr | tmp | 0x01);
  334. #ifdef SDRAM_DEBUG
  335. serial_puts ("sdtr: ");
  336. write_4hex (sdram_tim);
  337. serial_puts ("\n");
  338. #endif
  339. /* write SDRAM timing register */
  340. mtdcr (SDRAM0_CFGADDR, SDRAM0_TR);
  341. mtdcr (SDRAM0_CFGDATA, sdram_tim);
  342. #ifdef SDRAM_DEBUG
  343. serial_puts ("mb0cf: ");
  344. write_4hex (sdram_bank);
  345. serial_puts ("\n");
  346. #endif
  347. /* write SDRAM bank 0 register */
  348. mtdcr (SDRAM0_CFGADDR, SDRAM0_B0CR);
  349. mtdcr (SDRAM0_CFGDATA, sdram_bank);
  350. if (get_bus_freq (tmp) > 110000000) { /* > 110MHz */
  351. /* get SDRAM refresh interval register */
  352. mtdcr (SDRAM0_CFGADDR, SDRAM0_RTR);
  353. tmp = mfdcr (SDRAM0_CFGDATA) & ~0x3FF80000;
  354. tmp |= 0x07F00000;
  355. } else {
  356. /* get SDRAM refresh interval register */
  357. mtdcr (SDRAM0_CFGADDR, SDRAM0_RTR);
  358. tmp = mfdcr (SDRAM0_CFGDATA) & ~0x3FF80000;
  359. tmp |= 0x05F00000;
  360. }
  361. /* write SDRAM refresh interval register */
  362. mtdcr (SDRAM0_CFGADDR, SDRAM0_RTR);
  363. mtdcr (SDRAM0_CFGDATA, tmp);
  364. /* enable ECC if used */
  365. #if defined(ENABLE_ECC) && !defined(CONFIG_BOOT_PCI)
  366. if (sdram_table[i].ecc) {
  367. /* disable checking for all banks */
  368. unsigned long *p;
  369. #ifdef SDRAM_DEBUG
  370. serial_puts ("disable ECC.. ");
  371. #endif
  372. mtdcr (SDRAM0_CFGADDR, SDRAM0_ECCCFG);
  373. tmp = mfdcr (SDRAM0_CFGDATA);
  374. tmp &= 0xff0fffff; /* disable all banks */
  375. mtdcr (SDRAM0_CFGADDR, SDRAM0_ECCCFG);
  376. /* set up SDRAM Controller with ECC enabled */
  377. #ifdef SDRAM_DEBUG
  378. serial_puts ("setup SDRAM Controller.. ");
  379. #endif
  380. mtdcr (SDRAM0_CFGDATA, tmp);
  381. mtdcr (SDRAM0_CFGADDR, SDRAM0_CFG);
  382. tmp = (mfdcr (SDRAM0_CFGDATA) & ~0xFFE00000) | 0x90800000;
  383. mtdcr (SDRAM0_CFGADDR, SDRAM0_CFG);
  384. mtdcr (SDRAM0_CFGDATA, tmp);
  385. udelay (600);
  386. #ifdef SDRAM_DEBUG
  387. serial_puts ("fill the memory..\n");
  388. #endif
  389. serial_puts (".");
  390. /* now, fill all the memory */
  391. tmp = ((4 * MEGA_BYTE) << sdram_table[i].sz);
  392. p = (unsigned long) 0;
  393. while ((unsigned long) p < tmp) {
  394. *p++ = 0L;
  395. if (!((unsigned long) p % 0x00800000)) /* every 8MByte */
  396. serial_puts (".");
  397. }
  398. /* enable bank 0 */
  399. serial_puts (".");
  400. #ifdef SDRAM_DEBUG
  401. serial_puts ("enable ECC\n");
  402. #endif
  403. udelay (400);
  404. mtdcr (SDRAM0_CFGADDR, SDRAM0_ECCCFG);
  405. tmp = mfdcr (SDRAM0_CFGDATA);
  406. tmp |= 0x00800000; /* enable bank 0 */
  407. mtdcr (SDRAM0_CFGDATA, tmp);
  408. udelay (400);
  409. } else
  410. #endif
  411. {
  412. /* enable SDRAM controller with no ECC, 32-bit SDRAM width, 16 byte burst */
  413. mtdcr (SDRAM0_CFGADDR, SDRAM0_CFG);
  414. tmp = (mfdcr (SDRAM0_CFGDATA) & ~0xFFE00000) | 0x80C00000;
  415. mtdcr (SDRAM0_CFGADDR, SDRAM0_CFG);
  416. mtdcr (SDRAM0_CFGDATA, tmp);
  417. udelay (400);
  418. }
  419. serial_puts ("\n");
  420. return (0);
  421. }
  422. int board_early_init_f (void)
  423. {
  424. init_sdram ();
  425. /*-------------------------------------------------------------------------+
  426. | Interrupt controller setup for the PIP405 board.
  427. | Note: IRQ 0-15 405GP internally generated; active high; level sensitive
  428. | IRQ 16 405GP internally generated; active low; level sensitive
  429. | IRQ 17-24 RESERVED
  430. | IRQ 25 (EXT IRQ 0) SouthBridge; active low; level sensitive
  431. | IRQ 26 (EXT IRQ 1) NMI: active low; level sensitive
  432. | IRQ 27 (EXT IRQ 2) SMI: active Low; level sensitive
  433. | IRQ 28 (EXT IRQ 3) PCI SLOT 3; active low; level sensitive
  434. | IRQ 29 (EXT IRQ 4) PCI SLOT 2; active low; level sensitive
  435. | IRQ 30 (EXT IRQ 5) PCI SLOT 1; active low; level sensitive
  436. | IRQ 31 (EXT IRQ 6) PCI SLOT 0; active low; level sensitive
  437. | Note for MIP405 board:
  438. | An interrupt taken for the SouthBridge (IRQ 25) indicates that
  439. | the Interrupt Controller in the South Bridge has caused the
  440. | interrupt. The IC must be read to determine which device
  441. | caused the interrupt.
  442. |
  443. +-------------------------------------------------------------------------*/
  444. mtdcr (UIC0SR, 0xFFFFFFFF); /* clear all ints */
  445. mtdcr (UIC0ER, 0x00000000); /* disable all ints */
  446. mtdcr (UIC0CR, 0x00000000); /* set all to be non-critical (for now) */
  447. mtdcr (UIC0PR, 0xFFFFFF80); /* set int polarities */
  448. mtdcr (UIC0TR, 0x10000000); /* set int trigger levels */
  449. mtdcr (UIC0VCR, 0x00000001); /* set vect base=0,INT0 highest priority */
  450. mtdcr (UIC0SR, 0xFFFFFFFF); /* clear all ints */
  451. return 0;
  452. }
  453. int board_early_init_r(void)
  454. {
  455. int mode;
  456. /*
  457. * since we are relocated, we can finally enable i-cache
  458. * and set up the flash CS correctly
  459. */
  460. icache_enable();
  461. setup_cs_reloc();
  462. /* get and display boot mode */
  463. mode = get_boot_mode();
  464. if (mode & BOOT_PCI)
  465. printf("PCI Boot %s Map\n", (mode & BOOT_MPS) ?
  466. "MPS" : "Flash");
  467. else
  468. printf("%s Boot\n", (mode & BOOT_MPS) ?
  469. "MPS" : "Flash");
  470. return 0;
  471. }
  472. /*
  473. * Get some PLD Registers
  474. */
  475. unsigned short get_pld_parvers (void)
  476. {
  477. unsigned short result;
  478. unsigned char rc;
  479. rc = in8 (PLD_PART_REG);
  480. result = (unsigned short) rc << 8;
  481. rc = in8 (PLD_VERS_REG);
  482. result |= rc;
  483. return result;
  484. }
  485. void user_led0 (unsigned char on)
  486. {
  487. if (on)
  488. out8 (PLD_COM_MODE_REG, (in8 (PLD_COM_MODE_REG) | 0x4));
  489. else
  490. out8 (PLD_COM_MODE_REG, (in8 (PLD_COM_MODE_REG) & 0xfb));
  491. }
  492. void ide_set_reset (int idereset)
  493. {
  494. /* if reset = 1 IDE reset will be asserted */
  495. if (idereset)
  496. out8 (PLD_COM_MODE_REG, (in8 (PLD_COM_MODE_REG) | 0x1));
  497. else {
  498. udelay (10000);
  499. out8 (PLD_COM_MODE_REG, (in8 (PLD_COM_MODE_REG) & 0xfe));
  500. }
  501. }
  502. /* ------------------------------------------------------------------------- */
  503. void get_pcbrev_var(unsigned char *pcbrev, unsigned char *var)
  504. {
  505. #if !defined(CONFIG_TARGET_MIP405T)
  506. unsigned char bc,rc,tmp;
  507. int i;
  508. bc = in8 (PLD_BOARD_CFG_REG);
  509. tmp = ~bc;
  510. tmp &= 0xf;
  511. rc = 0;
  512. for (i = 0; i < 4; i++) {
  513. rc <<= 1;
  514. rc += (tmp & 0x1);
  515. tmp >>= 1;
  516. }
  517. rc++;
  518. if(( (((bc>>4) & 0xf)==0x2) /* Rev C PCB or */
  519. || (((bc>>4) & 0xf)==0x1)) /* Rev B PCB with */
  520. && (rc==0x1)) /* Population Option 1 is a -3 */
  521. rc=3;
  522. *pcbrev=(bc >> 4) & 0xf;
  523. *var=rc;
  524. #else
  525. unsigned char bc;
  526. bc = in8 (PLD_BOARD_CFG_REG);
  527. *pcbrev=(bc >> 4) & 0xf;
  528. *var=16-(bc & 0xf);
  529. #endif
  530. }
  531. /*
  532. * Check Board Identity:
  533. */
  534. /* serial String: "MIP405_1000" OR "MIP405T_1000" */
  535. #if !defined(CONFIG_TARGET_MIP405T)
  536. #define BOARD_NAME "MIP405"
  537. #else
  538. #define BOARD_NAME "MIP405T"
  539. #endif
  540. int checkboard (void)
  541. {
  542. char s[50];
  543. unsigned char bc, var;
  544. int i;
  545. backup_t *b = (backup_t *) s;
  546. puts ("Board: ");
  547. get_pcbrev_var(&bc,&var);
  548. i = getenv_f("serial#", (char *)s, 32);
  549. if ((i == 0) || strncmp ((char *)s, BOARD_NAME,sizeof(BOARD_NAME))) {
  550. get_backup_values (b);
  551. if (strncmp (b->signature, "MPL\0", 4) != 0) {
  552. puts ("### No HW ID - assuming " BOARD_NAME);
  553. printf ("-%d Rev %c", var, 'A' + bc);
  554. } else {
  555. b->serial_name[sizeof(BOARD_NAME)-1] = 0;
  556. printf ("%s-%d Rev %c SN: %s", b->serial_name, var,
  557. 'A' + bc, &b->serial_name[sizeof(BOARD_NAME)]);
  558. }
  559. } else {
  560. s[sizeof(BOARD_NAME)-1] = 0;
  561. printf ("%s-%d Rev %c SN: %s", s, var,'A' + bc,
  562. &s[sizeof(BOARD_NAME)]);
  563. }
  564. bc = in8 (PLD_EXT_CONF_REG);
  565. printf (" Boot Config: 0x%x\n", bc);
  566. return (0);
  567. }
  568. /* ------------------------------------------------------------------------- */
  569. /* ------------------------------------------------------------------------- */
  570. /*
  571. initdram(int board_type) reads EEPROM via I2c. EEPROM contains all of
  572. the necessary info for SDRAM controller configuration
  573. */
  574. /* ------------------------------------------------------------------------- */
  575. /* ------------------------------------------------------------------------- */
  576. static int test_dram (unsigned long ramsize);
  577. phys_size_t initdram (int board_type)
  578. {
  579. unsigned long bank_reg[4], tmp, bank_size;
  580. int i;
  581. unsigned long TotalSize;
  582. /* since the DRAM controller is allready set up, calculate the size with the
  583. bank registers */
  584. mtdcr (SDRAM0_CFGADDR, SDRAM0_B0CR);
  585. bank_reg[0] = mfdcr (SDRAM0_CFGDATA);
  586. mtdcr (SDRAM0_CFGADDR, SDRAM0_B1CR);
  587. bank_reg[1] = mfdcr (SDRAM0_CFGDATA);
  588. mtdcr (SDRAM0_CFGADDR, SDRAM0_B2CR);
  589. bank_reg[2] = mfdcr (SDRAM0_CFGDATA);
  590. mtdcr (SDRAM0_CFGADDR, SDRAM0_B3CR);
  591. bank_reg[3] = mfdcr (SDRAM0_CFGDATA);
  592. TotalSize = 0;
  593. for (i = 0; i < 4; i++) {
  594. if ((bank_reg[i] & 0x1) == 0x1) {
  595. tmp = (bank_reg[i] >> 17) & 0x7;
  596. bank_size = 4 << tmp;
  597. TotalSize += bank_size;
  598. }
  599. }
  600. mtdcr (SDRAM0_CFGADDR, SDRAM0_ECCCFG);
  601. tmp = mfdcr (SDRAM0_CFGDATA);
  602. if (!tmp)
  603. printf ("No ");
  604. printf ("ECC ");
  605. test_dram (TotalSize * MEGA_BYTE);
  606. return (TotalSize * MEGA_BYTE);
  607. }
  608. /* ------------------------------------------------------------------------- */
  609. static int test_dram (unsigned long ramsize)
  610. {
  611. #ifdef SDRAM_DEBUG
  612. mem_test (0L, ramsize, 1);
  613. #endif
  614. /* not yet implemented */
  615. return (1);
  616. }
  617. /* used to check if the time in RTC is valid */
  618. static unsigned long start;
  619. static struct rtc_time tm;
  620. int misc_init_r (void)
  621. {
  622. /* adjust flash start and size as well as the offset */
  623. gd->bd->bi_flashstart=0-flash_info[0].size;
  624. gd->bd->bi_flashsize=flash_info[0].size-CONFIG_SYS_MONITOR_LEN;
  625. gd->bd->bi_flashoffset=0;
  626. /* check, if RTC is running */
  627. rtc_get (&tm);
  628. start=get_timer(0);
  629. /* if MIP405 has booted from PCI, reset CCR0[24] as described in errata PCI_18 */
  630. if (mfdcr(CPC0_PSR) & PSR_ROM_LOC)
  631. mtspr(SPRN_CCR0, (mfspr(SPRN_CCR0) & ~0x80));
  632. return (0);
  633. }
  634. void print_mip405_rev (void)
  635. {
  636. unsigned char part, vers, pcbrev, var;
  637. get_pcbrev_var(&pcbrev,&var);
  638. part = in8 (PLD_PART_REG);
  639. vers = in8 (PLD_VERS_REG);
  640. printf ("Rev: " BOARD_NAME "-%d Rev %c PLD %d Vers %d\n",
  641. var, pcbrev + 'A', part & 0x7F, vers);
  642. }
  643. extern int mk_date (char *, struct rtc_time *);
  644. int last_stage_init (void)
  645. {
  646. unsigned long stop;
  647. struct rtc_time newtm;
  648. char *s;
  649. /* write correct LED configuration */
  650. if (miiphy_write("ppc_4xx_eth0", 0x1, 0x14, 0x2402) != 0) {
  651. printf ("Error writing to the PHY\n");
  652. }
  653. /* since LED/CFG2 is not connected on the -2,
  654. * write to correct capability information */
  655. if (miiphy_write("ppc_4xx_eth0", 0x1, 0x4, 0x01E1) != 0) {
  656. printf ("Error writing to the PHY\n");
  657. }
  658. print_mip405_rev ();
  659. stdio_print_current_devices ();
  660. check_env ();
  661. /* check if RTC time is valid */
  662. stop=get_timer(start);
  663. while(stop<1200) { /* we wait 1.2 sec to check if the RTC is running */
  664. udelay(1000);
  665. stop=get_timer(start);
  666. }
  667. rtc_get (&newtm);
  668. if(tm.tm_sec==newtm.tm_sec) {
  669. s=getenv("defaultdate");
  670. if(!s)
  671. mk_date ("010112001970", &newtm);
  672. else
  673. if(mk_date (s, &newtm)!=0) {
  674. printf("RTC: Bad date format in defaultdate\n");
  675. return 0;
  676. }
  677. rtc_reset ();
  678. rtc_set(&newtm);
  679. }
  680. return 0;
  681. }
  682. /***************************************************************************
  683. * some helping routines
  684. */
  685. int overwrite_console (void)
  686. {
  687. /* return true if console should be overwritten */
  688. return ((in8(PLD_EXT_CONF_REG) & 0x1) == 0);
  689. }
  690. /************************************************************************
  691. * Print MIP405 Info
  692. ************************************************************************/
  693. void print_mip405_info (void)
  694. {
  695. unsigned char part, vers, cfg, irq_reg, com_mode, ext;
  696. part = in8 (PLD_PART_REG);
  697. vers = in8 (PLD_VERS_REG);
  698. cfg = in8 (PLD_BOARD_CFG_REG);
  699. irq_reg = in8 (PLD_IRQ_REG);
  700. com_mode = in8 (PLD_COM_MODE_REG);
  701. ext = in8 (PLD_EXT_CONF_REG);
  702. printf ("PLD Part %d version %d\n", part & 0x7F, vers);
  703. printf ("Board Revision %c\n", ((cfg >> 4) & 0xf) + 'A');
  704. printf ("Population Options %d %d %d %d\n", (cfg) & 0x1,
  705. (cfg >> 1) & 0x1, (cfg >> 2) & 0x1, (cfg >> 3) & 0x1);
  706. printf ("User LED %s\n", (com_mode & 0x4) ? "on" : "off");
  707. printf ("UART Clocks %d\n", (com_mode >> 4) & 0x3);
  708. #if !defined(CONFIG_TARGET_MIP405T)
  709. printf ("User Config Switch %d %d %d %d %d %d %d %d\n",
  710. (ext) & 0x1, (ext >> 1) & 0x1, (ext >> 2) & 0x1,
  711. (ext >> 3) & 0x1, (ext >> 4) & 0x1, (ext >> 5) & 0x1,
  712. (ext >> 6) & 0x1, (ext >> 7) & 0x1);
  713. printf ("SER1 uses handshakes %s\n",
  714. (ext & 0x80) ? "DTR/DSR" : "RTS/CTS");
  715. #else
  716. printf ("User Config Switch %d %d %d %d %d %d %d %d\n",
  717. (ext) & 0x1, (ext >> 1) & 0x1, (ext >> 2) & 0x1,
  718. (ext >> 3) & 0x1, (ext >> 4) & 0x1, (ext >> 5) & 0x1,
  719. (ext >> 6) & 0x1,(ext >> 7) & 0x1);
  720. #endif
  721. printf ("IDE Reset %s\n", (ext & 0x01) ? "asserted" : "not asserted");
  722. printf ("IRQs:\n");
  723. printf (" PIIX INTR: %s\n", (irq_reg & 0x80) ? "inactive" : "active");
  724. #if !defined(CONFIG_TARGET_MIP405T)
  725. printf (" UART0 IRQ: %s\n", (irq_reg & 0x40) ? "inactive" : "active");
  726. printf (" UART1 IRQ: %s\n", (irq_reg & 0x20) ? "inactive" : "active");
  727. #endif
  728. printf (" PIIX SMI: %s\n", (irq_reg & 0x10) ? "inactive" : "active");
  729. printf (" PIIX INIT: %s\n", (irq_reg & 0x8) ? "inactive" : "active");
  730. printf (" PIIX NMI: %s\n", (irq_reg & 0x4) ? "inactive" : "active");
  731. }