mip405.c 22 KB

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