pmc440.c 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887
  1. /*
  2. * (Cg) Copyright 2007-2008
  3. * Matthias Fuchs, esd gmbh, matthias.fuchs@esd-electronics.com.
  4. * Based on board/amcc/sequoia/sequoia.c
  5. *
  6. * (C) Copyright 2006
  7. * Stefan Roese, DENX Software Engineering, sr@denx.de.
  8. *
  9. * (C) Copyright 2006
  10. * Jacqueline Pira-Ferriol, AMCC/IBM, jpira-ferriol@fr.ibm.com
  11. * Alain Saurel, AMCC/IBM, alain.saurel@fr.ibm.com
  12. *
  13. * This program is free software; you can redistribute it and/or
  14. * modify it under the terms of the GNU General Public License as
  15. * published by the Free Software Foundation; either version 2 of
  16. * the License, or (at your option) any later version.
  17. *
  18. * This program is distributed in the hope that it will be useful,
  19. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  20. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  21. * GNU General Public License for more details.
  22. *
  23. * You should have received a copy of the GNU General Public License
  24. * along with this program; if not, write to the Free Software
  25. * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
  26. * MA 02111-1307 USA
  27. */
  28. #include <common.h>
  29. #include <libfdt.h>
  30. #include <fdt_support.h>
  31. #include <asm/ppc440.h>
  32. #include <asm/processor.h>
  33. #include <asm/io.h>
  34. #include <asm/bitops.h>
  35. #include <command.h>
  36. #include <i2c.h>
  37. #ifdef CONFIG_RESET_PHY_R
  38. #include <miiphy.h>
  39. #endif
  40. #include <serial.h>
  41. #include <asm/4xx_pci.h>
  42. #include "fpga.h"
  43. #include "pmc440.h"
  44. DECLARE_GLOBAL_DATA_PTR;
  45. extern flash_info_t flash_info[CONFIG_SYS_MAX_FLASH_BANKS]; /* info for FLASH chips */
  46. extern void __ft_board_setup(void *blob, bd_t *bd);
  47. ulong flash_get_size(ulong base, int banknum);
  48. int pci_is_66mhz(void);
  49. int is_monarch(void);
  50. int bootstrap_eeprom_read(unsigned dev_addr, unsigned offset,
  51. uchar *buffer, unsigned cnt);
  52. struct serial_device *default_serial_console(void)
  53. {
  54. uchar buf[4];
  55. ulong delay;
  56. int i;
  57. ulong val;
  58. /*
  59. * Use default console on P4 when strapping jumper
  60. * is installed (bootstrap option != 'H').
  61. */
  62. mfsdr(SDR0_PINSTP, val);
  63. if (((val & 0xf0000000) >> 29) != 7)
  64. return &eserial2_device;
  65. ulong scratchreg = in_be32((void*)GPIO0_ISR3L);
  66. if (!(scratchreg & 0x80)) {
  67. /* mark scratchreg valid */
  68. scratchreg = (scratchreg & 0xffffff00) | 0x80;
  69. i = bootstrap_eeprom_read(CONFIG_SYS_I2C_BOOT_EEPROM_ADDR,
  70. 0x10, buf, 4);
  71. if ((i != -1) && (buf[0] == 0x19) && (buf[1] == 0x75)) {
  72. scratchreg |= buf[2];
  73. /* bringup delay for console */
  74. for (delay=0; delay<(1000 * (ulong)buf[3]); delay++) {
  75. udelay(1000);
  76. }
  77. } else
  78. scratchreg |= 0x01;
  79. out_be32((void*)GPIO0_ISR3L, scratchreg);
  80. }
  81. if (scratchreg & 0x01)
  82. return &eserial2_device;
  83. else
  84. return &eserial1_device;
  85. }
  86. int board_early_init_f(void)
  87. {
  88. u32 sdr0_cust0;
  89. u32 sdr0_pfc1, sdr0_pfc2;
  90. u32 reg;
  91. /* general EBC configuration (disable EBC timeouts) */
  92. mtdcr(EBC0_CFGADDR, EBC0_CFG);
  93. mtdcr(EBC0_CFGDATA, 0xf8400000);
  94. /*
  95. * Setup the GPIO pins
  96. * TODO: setup GPIOs via CONFIG_SYS_4xx_GPIO_TABLE in board's config file
  97. */
  98. out_be32((void *)GPIO0_OR, 0x40000102);
  99. out_be32((void *)GPIO0_TCR, 0x4c90011f);
  100. out_be32((void *)GPIO0_OSRL, 0x28051400);
  101. out_be32((void *)GPIO0_OSRH, 0x55005000);
  102. out_be32((void *)GPIO0_TSRL, 0x08051400);
  103. out_be32((void *)GPIO0_TSRH, 0x55005000);
  104. out_be32((void *)GPIO0_ISR1L, 0x54000000);
  105. out_be32((void *)GPIO0_ISR1H, 0x00000000);
  106. out_be32((void *)GPIO0_ISR2L, 0x44000000);
  107. out_be32((void *)GPIO0_ISR2H, 0x00000100);
  108. out_be32((void *)GPIO0_ISR3L, 0x00000000);
  109. out_be32((void *)GPIO0_ISR3H, 0x00000000);
  110. out_be32((void *)GPIO1_OR, 0x80002408);
  111. out_be32((void *)GPIO1_TCR, 0xd6003c08);
  112. out_be32((void *)GPIO1_OSRL, 0x0a5a0000);
  113. out_be32((void *)GPIO1_OSRH, 0x00000000);
  114. out_be32((void *)GPIO1_TSRL, 0x00000000);
  115. out_be32((void *)GPIO1_TSRH, 0x00000000);
  116. out_be32((void *)GPIO1_ISR1L, 0x00005555);
  117. out_be32((void *)GPIO1_ISR1H, 0x40000000);
  118. out_be32((void *)GPIO1_ISR2L, 0x04010000);
  119. out_be32((void *)GPIO1_ISR2H, 0x00000000);
  120. out_be32((void *)GPIO1_ISR3L, 0x01400000);
  121. out_be32((void *)GPIO1_ISR3H, 0x00000000);
  122. /* patch PLB:PCI divider for 66MHz PCI */
  123. mfcpr(CPR0_SPCID, reg);
  124. if (pci_is_66mhz() && (reg != 0x02000000)) {
  125. mtcpr(CPR0_SPCID, 0x02000000); /* 133MHZ : 2 for 66MHz PCI */
  126. mfcpr(CPR0_ICFG, reg);
  127. reg |= CPR0_ICFG_RLI_MASK;
  128. mtcpr(CPR0_ICFG, reg);
  129. mtspr(SPRN_DBCR0, 0x20000000); /* do chip reset */
  130. }
  131. /*
  132. * Setup the interrupt controller polarities, triggers, etc.
  133. */
  134. mtdcr(UIC0SR, 0xffffffff); /* clear all */
  135. mtdcr(UIC0ER, 0x00000000); /* disable all */
  136. mtdcr(UIC0CR, 0x00000005); /* ATI & UIC1 crit are critical */
  137. mtdcr(UIC0PR, 0xfffff7ef);
  138. mtdcr(UIC0TR, 0x00000000);
  139. mtdcr(UIC0VR, 0x00000000); /* int31 highest, base=0x000 */
  140. mtdcr(UIC0SR, 0xffffffff); /* clear all */
  141. mtdcr(UIC1SR, 0xffffffff); /* clear all */
  142. mtdcr(UIC1ER, 0x00000000); /* disable all */
  143. mtdcr(UIC1CR, 0x00000000); /* all non-critical */
  144. mtdcr(UIC1PR, 0xffffc7f5);
  145. mtdcr(UIC1TR, 0x00000000);
  146. mtdcr(UIC1VR, 0x00000000); /* int31 highest, base=0x000 */
  147. mtdcr(UIC1SR, 0xffffffff); /* clear all */
  148. mtdcr(UIC2SR, 0xffffffff); /* clear all */
  149. mtdcr(UIC2ER, 0x00000000); /* disable all */
  150. mtdcr(UIC2CR, 0x00000000); /* all non-critical */
  151. mtdcr(UIC2PR, 0x27ffffff);
  152. mtdcr(UIC2TR, 0x00000000);
  153. mtdcr(UIC2VR, 0x00000000); /* int31 highest, base=0x000 */
  154. mtdcr(UIC2SR, 0xffffffff); /* clear all */
  155. /* select Ethernet pins */
  156. mfsdr(SDR0_PFC1, sdr0_pfc1);
  157. sdr0_pfc1 = (sdr0_pfc1 & ~SDR0_PFC1_SELECT_MASK) |
  158. SDR0_PFC1_SELECT_CONFIG_4;
  159. mfsdr(SDR0_PFC2, sdr0_pfc2);
  160. sdr0_pfc2 = (sdr0_pfc2 & ~SDR0_PFC2_SELECT_MASK) |
  161. SDR0_PFC2_SELECT_CONFIG_4;
  162. /* enable 2nd IIC */
  163. sdr0_pfc1 = (sdr0_pfc1 & ~SDR0_PFC1_SIS_MASK) | SDR0_PFC1_SIS_IIC1_SEL;
  164. mtsdr(SDR0_PFC2, sdr0_pfc2);
  165. mtsdr(SDR0_PFC1, sdr0_pfc1);
  166. /* setup NAND FLASH */
  167. mfsdr(SDR0_CUST0, sdr0_cust0);
  168. sdr0_cust0 = SDR0_CUST0_MUX_NDFC_SEL |
  169. SDR0_CUST0_NDFC_ENABLE |
  170. SDR0_CUST0_NDFC_BW_8_BIT |
  171. SDR0_CUST0_NDFC_ARE_MASK |
  172. (0x80000000 >> (28 + CONFIG_SYS_NAND_CS));
  173. mtsdr(SDR0_CUST0, sdr0_cust0);
  174. return 0;
  175. }
  176. #if defined(CONFIG_MISC_INIT_F)
  177. int misc_init_f(void)
  178. {
  179. struct pci_controller hose;
  180. hose.first_busno = 0;
  181. hose.last_busno = 0;
  182. hose.region_count = 0;
  183. if (getenv("pciearly") && (!is_monarch())) {
  184. printf("PCI: early target init\n");
  185. pci_setup_indirect(&hose, PCIL0_CFGADR, PCIL0_CFGDATA);
  186. pci_target_init(&hose);
  187. }
  188. return 0;
  189. }
  190. #endif
  191. /*
  192. * misc_init_r.
  193. */
  194. int misc_init_r(void)
  195. {
  196. uint pbcr;
  197. int size_val = 0;
  198. u32 reg;
  199. unsigned long usb2d0cr = 0;
  200. unsigned long usb2phy0cr, usb2h0cr = 0;
  201. unsigned long sdr0_pfc1;
  202. unsigned long sdr0_srst0, sdr0_srst1;
  203. char *act = getenv("usbact");
  204. /*
  205. * FLASH stuff...
  206. */
  207. /* Re-do sizing to get full correct info */
  208. /* adjust flash start and offset */
  209. gd->bd->bi_flashstart = 0 - gd->bd->bi_flashsize;
  210. gd->bd->bi_flashoffset = 0;
  211. #if defined(CONFIG_NAND_U_BOOT) || defined(CONFIG_NAND_SPL)
  212. mtdcr(EBC0_CFGADDR, PB2CR);
  213. #else
  214. mtdcr(EBC0_CFGADDR, PB0CR);
  215. #endif
  216. pbcr = mfdcr(EBC0_CFGDATA);
  217. size_val = ffs(gd->bd->bi_flashsize) - 21;
  218. pbcr = (pbcr & 0x0001ffff) | gd->bd->bi_flashstart | (size_val << 17);
  219. #if defined(CONFIG_NAND_U_BOOT) || defined(CONFIG_NAND_SPL)
  220. mtdcr(EBC0_CFGADDR, PB2CR);
  221. #else
  222. mtdcr(EBC0_CFGADDR, PB0CR);
  223. #endif
  224. mtdcr(EBC0_CFGDATA, pbcr);
  225. /*
  226. * Re-check to get correct base address
  227. */
  228. flash_get_size(gd->bd->bi_flashstart, 0);
  229. #ifdef CONFIG_ENV_IS_IN_FLASH
  230. /* Monitor protection ON by default */
  231. (void)flash_protect(FLAG_PROTECT_SET,
  232. -CONFIG_SYS_MONITOR_LEN,
  233. 0xffffffff,
  234. &flash_info[0]);
  235. /* Env protection ON by default */
  236. (void)flash_protect(FLAG_PROTECT_SET,
  237. CONFIG_ENV_ADDR_REDUND,
  238. CONFIG_ENV_ADDR_REDUND + 2*CONFIG_ENV_SECT_SIZE - 1,
  239. &flash_info[0]);
  240. #endif
  241. /*
  242. * USB suff...
  243. */
  244. if ((act == NULL || strcmp(act, "host") == 0) &&
  245. !(in_be32((void*)GPIO0_IR) & GPIO0_USB_PRSNT)){
  246. /* SDR Setting */
  247. mfsdr(SDR0_PFC1, sdr0_pfc1);
  248. mfsdr(SDR0_USB2D0CR, usb2d0cr);
  249. mfsdr(SDR0_USB2PHY0CR, usb2phy0cr);
  250. mfsdr(SDR0_USB2H0CR, usb2h0cr);
  251. usb2phy0cr = usb2phy0cr &~SDR0_USB2PHY0CR_XOCLK_MASK;
  252. usb2phy0cr = usb2phy0cr | SDR0_USB2PHY0CR_XOCLK_EXTERNAL;
  253. usb2phy0cr = usb2phy0cr &~SDR0_USB2PHY0CR_WDINT_MASK;
  254. usb2phy0cr = usb2phy0cr | SDR0_USB2PHY0CR_WDINT_16BIT_30MHZ;
  255. usb2phy0cr = usb2phy0cr &~SDR0_USB2PHY0CR_DVBUS_MASK;
  256. usb2phy0cr = usb2phy0cr | SDR0_USB2PHY0CR_DVBUS_PURDIS;
  257. usb2phy0cr = usb2phy0cr &~SDR0_USB2PHY0CR_DWNSTR_MASK;
  258. usb2phy0cr = usb2phy0cr | SDR0_USB2PHY0CR_DWNSTR_HOST;
  259. usb2phy0cr = usb2phy0cr &~SDR0_USB2PHY0CR_UTMICN_MASK;
  260. usb2phy0cr = usb2phy0cr | SDR0_USB2PHY0CR_UTMICN_HOST;
  261. /*
  262. * An 8-bit/60MHz interface is the only possible alternative
  263. * when connecting the Device to the PHY
  264. */
  265. usb2h0cr = usb2h0cr &~SDR0_USB2H0CR_WDINT_MASK;
  266. usb2h0cr = usb2h0cr | SDR0_USB2H0CR_WDINT_16BIT_30MHZ;
  267. usb2d0cr = usb2d0cr &~SDR0_USB2D0CR_USB2DEV_EBC_SEL_MASK;
  268. sdr0_pfc1 = sdr0_pfc1 &~SDR0_PFC1_UES_MASK;
  269. mtsdr(SDR0_PFC1, sdr0_pfc1);
  270. mtsdr(SDR0_USB2D0CR, usb2d0cr);
  271. mtsdr(SDR0_USB2PHY0CR, usb2phy0cr);
  272. mtsdr(SDR0_USB2H0CR, usb2h0cr);
  273. /*
  274. * Take USB out of reset:
  275. * -Initial status = all cores are in reset
  276. * -deassert reset to OPB1, P4OPB0, OPB2, PLB42OPB1 OPB2PLB40 cores
  277. * -wait 1 ms
  278. * -deassert reset to PHY
  279. * -wait 1 ms
  280. * -deassert reset to HOST
  281. * -wait 4 ms
  282. * -deassert all other resets
  283. */
  284. mfsdr(SDR0_SRST1, sdr0_srst1);
  285. sdr0_srst1 &= ~(SDR0_SRST1_OPBA1 | \
  286. SDR0_SRST1_P4OPB0 | \
  287. SDR0_SRST1_OPBA2 | \
  288. SDR0_SRST1_PLB42OPB1 | \
  289. SDR0_SRST1_OPB2PLB40);
  290. mtsdr(SDR0_SRST1, sdr0_srst1);
  291. udelay(1000);
  292. mfsdr(SDR0_SRST1, sdr0_srst1);
  293. sdr0_srst1 &= ~SDR0_SRST1_USB20PHY;
  294. mtsdr(SDR0_SRST1, sdr0_srst1);
  295. udelay(1000);
  296. mfsdr(SDR0_SRST0, sdr0_srst0);
  297. sdr0_srst0 &= ~SDR0_SRST0_USB2H;
  298. mtsdr(SDR0_SRST0, sdr0_srst0);
  299. udelay(4000);
  300. /* finally all the other resets */
  301. mtsdr(SDR0_SRST1, 0x00000000);
  302. mtsdr(SDR0_SRST0, 0x00000000);
  303. if (!(in_be32((void*)GPIO0_IR) & GPIO0_USB_PRSNT)) {
  304. /* enable power on USB socket */
  305. out_be32((void*)GPIO1_OR,
  306. in_be32((void*)GPIO1_OR) & ~GPIO1_USB_PWR_N);
  307. }
  308. printf("USB: Host\n");
  309. } else if ((strcmp(act, "dev") == 0) ||
  310. (in_be32((void*)GPIO0_IR) & GPIO0_USB_PRSNT)) {
  311. mfsdr(SDR0_USB2PHY0CR, usb2phy0cr);
  312. usb2phy0cr = usb2phy0cr &~SDR0_USB2PHY0CR_XOCLK_MASK;
  313. usb2phy0cr = usb2phy0cr | SDR0_USB2PHY0CR_XOCLK_EXTERNAL;
  314. usb2phy0cr = usb2phy0cr &~SDR0_USB2PHY0CR_DVBUS_MASK;
  315. usb2phy0cr = usb2phy0cr | SDR0_USB2PHY0CR_DVBUS_PURDIS;
  316. usb2phy0cr = usb2phy0cr &~SDR0_USB2PHY0CR_DWNSTR_MASK;
  317. usb2phy0cr = usb2phy0cr | SDR0_USB2PHY0CR_DWNSTR_HOST;
  318. usb2phy0cr = usb2phy0cr &~SDR0_USB2PHY0CR_UTMICN_MASK;
  319. usb2phy0cr = usb2phy0cr | SDR0_USB2PHY0CR_UTMICN_HOST;
  320. mtsdr(SDR0_USB2PHY0CR, usb2phy0cr);
  321. udelay (1000);
  322. mtsdr(SDR0_SRST1, 0x672c6000);
  323. udelay (1000);
  324. mtsdr(SDR0_SRST0, 0x00000080);
  325. udelay (1000);
  326. mtsdr(SDR0_SRST1, 0x60206000);
  327. *(unsigned int *)(0xe0000350) = 0x00000001;
  328. udelay (1000);
  329. mtsdr(SDR0_SRST1, 0x60306000);
  330. /* SDR Setting */
  331. mfsdr(SDR0_USB2PHY0CR, usb2phy0cr);
  332. mfsdr(SDR0_USB2H0CR, usb2h0cr);
  333. mfsdr(SDR0_USB2D0CR, usb2d0cr);
  334. mfsdr(SDR0_PFC1, sdr0_pfc1);
  335. usb2phy0cr = usb2phy0cr &~SDR0_USB2PHY0CR_XOCLK_MASK;
  336. usb2phy0cr = usb2phy0cr | SDR0_USB2PHY0CR_XOCLK_EXTERNAL;
  337. usb2phy0cr = usb2phy0cr &~SDR0_USB2PHY0CR_WDINT_MASK;
  338. usb2phy0cr = usb2phy0cr | SDR0_USB2PHY0CR_WDINT_8BIT_60MHZ;
  339. usb2phy0cr = usb2phy0cr &~SDR0_USB2PHY0CR_DVBUS_MASK;
  340. usb2phy0cr = usb2phy0cr | SDR0_USB2PHY0CR_DVBUS_PUREN;
  341. usb2phy0cr = usb2phy0cr &~SDR0_USB2PHY0CR_DWNSTR_MASK;
  342. usb2phy0cr = usb2phy0cr | SDR0_USB2PHY0CR_DWNSTR_DEV;
  343. usb2phy0cr = usb2phy0cr &~SDR0_USB2PHY0CR_UTMICN_MASK;
  344. usb2phy0cr = usb2phy0cr | SDR0_USB2PHY0CR_UTMICN_DEV;
  345. usb2h0cr = usb2h0cr &~SDR0_USB2H0CR_WDINT_MASK;
  346. usb2h0cr = usb2h0cr | SDR0_USB2H0CR_WDINT_8BIT_60MHZ;
  347. usb2d0cr = usb2d0cr &~SDR0_USB2D0CR_USB2DEV_EBC_SEL_MASK;
  348. sdr0_pfc1 = sdr0_pfc1 &~SDR0_PFC1_UES_MASK;
  349. sdr0_pfc1 = sdr0_pfc1 | SDR0_PFC1_UES_EBCHR_SEL;
  350. mtsdr(SDR0_USB2H0CR, usb2h0cr);
  351. mtsdr(SDR0_USB2PHY0CR, usb2phy0cr);
  352. mtsdr(SDR0_USB2D0CR, usb2d0cr);
  353. mtsdr(SDR0_PFC1, sdr0_pfc1);
  354. /*clear resets*/
  355. udelay(1000);
  356. mtsdr(SDR0_SRST1, 0x00000000);
  357. udelay(1000);
  358. mtsdr(SDR0_SRST0, 0x00000000);
  359. printf("USB: Device\n");
  360. }
  361. /*
  362. * Clear PLB4A0_ACR[WRP]
  363. * This fix will make the MAL burst disabling patch for the Linux
  364. * EMAC driver obsolete.
  365. */
  366. reg = mfdcr(PLB4A0_ACR) & ~PLB4Ax_ACR_WRP_MASK;
  367. mtdcr(PLB4A0_ACR, reg);
  368. #ifdef CONFIG_FPGA
  369. pmc440_init_fpga();
  370. #endif
  371. /* turn off POST LED */
  372. out_be32((void*)GPIO1_OR, in_be32((void*)GPIO1_OR) & ~GPIO1_POST_N);
  373. /* turn on RUN LED */
  374. out_be32((void*)GPIO0_OR, in_be32((void*)GPIO0_OR) & ~GPIO0_LED_RUN_N);
  375. return 0;
  376. }
  377. int is_monarch(void)
  378. {
  379. if (in_be32((void*)GPIO1_IR) & GPIO1_NONMONARCH)
  380. return 0;
  381. return 1;
  382. }
  383. int pci_is_66mhz(void)
  384. {
  385. if (in_be32((void*)GPIO1_IR) & GPIO1_M66EN)
  386. return 1;
  387. return 0;
  388. }
  389. int board_revision(void)
  390. {
  391. return (int)((in_be32((void*)GPIO1_IR) & GPIO1_HWID_MASK) >> 4);
  392. }
  393. int checkboard(void)
  394. {
  395. puts("Board: esd GmbH - PMC440");
  396. gd->board_type = board_revision();
  397. printf(", Rev 1.%ld, ", gd->board_type);
  398. if (!is_monarch()) {
  399. puts("non-");
  400. }
  401. printf("monarch, PCI=%s MHz\n", pci_is_66mhz() ? "66" : "33");
  402. return (0);
  403. }
  404. #if defined(CONFIG_PCI) && defined(CONFIG_PCI_PNP)
  405. /*
  406. * Assign interrupts to PCI devices. Some OSs rely on this.
  407. */
  408. void board_pci_fixup_irq(struct pci_controller *hose, pci_dev_t dev)
  409. {
  410. unsigned char int_line[] = {IRQ_PCIC, IRQ_PCID, IRQ_PCIA, IRQ_PCIB};
  411. pci_hose_write_config_byte(hose, dev, PCI_INTERRUPT_LINE,
  412. int_line[PCI_DEV(dev) & 0x03]);
  413. }
  414. #endif
  415. /*
  416. * pci_target_init
  417. *
  418. * The bootstrap configuration provides default settings for the pci
  419. * inbound map (PIM). But the bootstrap config choices are limited and
  420. * may not be sufficient for a given board.
  421. */
  422. #if defined(CONFIG_PCI) && defined(CONFIG_SYS_PCI_TARGET_INIT)
  423. void pci_target_init(struct pci_controller *hose)
  424. {
  425. char *ptmla_str, *ptmms_str;
  426. /*
  427. * Set up Direct MMIO registers
  428. */
  429. /*
  430. * PowerPC440EPX PCI Master configuration.
  431. * Map one 1Gig range of PLB/processor addresses to PCI memory space.
  432. * PLB address 0x80000000-0xBFFFFFFF
  433. * ==> PCI address 0x80000000-0xBFFFFFFF
  434. * Use byte reversed out routines to handle endianess.
  435. * Make this region non-prefetchable.
  436. */
  437. out32r(PCIL0_PMM0MA, 0x00000000); /* PMM0 Mask/Attribute */
  438. /* - disabled b4 setting */
  439. out32r(PCIL0_PMM0LA, CONFIG_SYS_PCI_MEMBASE); /* PMM0 Local Address */
  440. out32r(PCIL0_PMM0PCILA, CONFIG_SYS_PCI_MEMBASE); /* PMM0 PCI Low Address */
  441. out32r(PCIL0_PMM0PCIHA, 0x00000000); /* PMM0 PCI High Address */
  442. out32r(PCIL0_PMM0MA, 0xc0000001); /* 1G + No prefetching, */
  443. /* and enable region */
  444. if (!is_monarch()) {
  445. ptmla_str = getenv("ptm1la");
  446. ptmms_str = getenv("ptm1ms");
  447. if(NULL != ptmla_str && NULL != ptmms_str ) {
  448. out32r(PCIL0_PTM1MS,
  449. simple_strtoul(ptmms_str, NULL, 16));
  450. out32r(PCIL0_PTM1LA,
  451. simple_strtoul(ptmla_str, NULL, 16));
  452. } else {
  453. /* BAR1: default top 64MB of RAM */
  454. out32r(PCIL0_PTM1MS, 0xfc000001);
  455. out32r(PCIL0_PTM1LA, 0x0c000000);
  456. }
  457. } else {
  458. /* BAR1: default: complete 256MB RAM */
  459. out32r(PCIL0_PTM1MS, 0xf0000001);
  460. out32r(PCIL0_PTM1LA, 0x00000000);
  461. }
  462. ptmla_str = getenv("ptm2la"); /* Local Addr. Reg */
  463. ptmms_str = getenv("ptm2ms"); /* Memory Size/Attribute */
  464. if(NULL != ptmla_str && NULL != ptmms_str ) {
  465. out32r(PCIL0_PTM2MS, simple_strtoul(ptmms_str, NULL, 16));
  466. out32r(PCIL0_PTM2LA, simple_strtoul(ptmla_str, NULL, 16));
  467. } else {
  468. /* BAR2: default: 4MB FPGA */
  469. out32r(PCIL0_PTM2MS, 0xffc00001); /* Memory Size/Attribute */
  470. out32r(PCIL0_PTM2LA, 0xef000000); /* Local Addr. Reg */
  471. }
  472. if (is_monarch()) {
  473. /* BAR2: map FPGA registers behind system memory at 1GB */
  474. pci_hose_write_config_dword(hose, 0, PCI_BASE_ADDRESS_2, 0x40000008);
  475. }
  476. /*
  477. * Set up Configuration registers
  478. */
  479. /* Program the board's vendor id */
  480. pci_hose_write_config_word(hose, 0, PCI_SUBSYSTEM_VENDOR_ID,
  481. CONFIG_SYS_PCI_SUBSYS_VENDORID);
  482. /* disabled for PMC405 backward compatibility */
  483. /* Configure command register as bus master */
  484. /* pci_write_config_word(0, PCI_COMMAND, PCI_COMMAND_MASTER); */
  485. /* 240nS PCI clock */
  486. pci_hose_write_config_word(hose, 0, PCI_LATENCY_TIMER, 1);
  487. /* No error reporting */
  488. pci_hose_write_config_word(hose, 0, PCI_ERREN, 0);
  489. if (!is_monarch()) {
  490. /* Program the board's subsystem id/classcode */
  491. pci_hose_write_config_word(hose, 0, PCI_SUBSYSTEM_ID,
  492. CONFIG_SYS_PCI_SUBSYS_ID_NONMONARCH);
  493. pci_hose_write_config_word(hose, 0, PCI_CLASS_SUB_CODE,
  494. CONFIG_SYS_PCI_CLASSCODE_NONMONARCH);
  495. /* PCI configuration done: release ERREADY */
  496. out_be32((void*)GPIO1_OR,
  497. in_be32((void*)GPIO1_OR) | GPIO1_PPC_EREADY);
  498. out_be32((void*)GPIO1_TCR,
  499. in_be32((void*)GPIO1_TCR) | GPIO1_PPC_EREADY);
  500. } else {
  501. /* Program the board's subsystem id/classcode */
  502. pci_hose_write_config_word(hose, 0, PCI_SUBSYSTEM_ID,
  503. CONFIG_SYS_PCI_SUBSYS_ID_MONARCH);
  504. pci_hose_write_config_word(hose, 0, PCI_CLASS_SUB_CODE,
  505. CONFIG_SYS_PCI_CLASSCODE_MONARCH);
  506. }
  507. /* enable host configuration */
  508. pci_hose_write_config_dword(hose, 0, PCI_BRDGOPT2, 0x00000101);
  509. }
  510. #endif /* defined(CONFIG_PCI) && defined(CONFIG_SYS_PCI_TARGET_INIT) */
  511. /*
  512. * Override weak default pci_master_init()
  513. */
  514. #if defined(CONFIG_PCI) && defined(CONFIG_SYS_PCI_MASTER_INIT)
  515. void pci_master_init(struct pci_controller *hose)
  516. {
  517. /*
  518. * Only configure the master in monach mode
  519. */
  520. if (is_monarch())
  521. __pci_master_init(hose);
  522. }
  523. #endif /* defined(CONFIG_PCI) && defined(CONFIG_SYS_PCI_MASTER_INIT) */
  524. static void wait_for_pci_ready(void)
  525. {
  526. if (!(in_be32((void*)GPIO1_IR) & GPIO1_PPC_EREADY)) {
  527. printf("PCI: Waiting for EREADY (CTRL-C to skip) ... ");
  528. while (1) {
  529. if (ctrlc()) {
  530. puts("abort\n");
  531. break;
  532. }
  533. if (in_be32((void*)GPIO1_IR) & GPIO1_PPC_EREADY) {
  534. printf("done\n");
  535. break;
  536. }
  537. }
  538. }
  539. }
  540. /*
  541. * Override weak is_pci_host()
  542. *
  543. * This routine is called to determine if a pci scan should be
  544. * performed. With various hardware environments (especially cPCI and
  545. * PPMC) it's insufficient to depend on the state of the arbiter enable
  546. * bit in the strap register, or generic host/adapter assumptions.
  547. *
  548. * Rather than hard-code a bad assumption in the general 440 code, the
  549. * 440 pci code requires the board to decide at runtime.
  550. *
  551. * Return 0 for adapter mode, non-zero for host (monarch) mode.
  552. */
  553. #if defined(CONFIG_PCI)
  554. int is_pci_host(struct pci_controller *hose)
  555. {
  556. char *s = getenv("pciscan");
  557. if (s == NULL)
  558. if (is_monarch()) {
  559. wait_for_pci_ready();
  560. return 1;
  561. } else
  562. return 0;
  563. else if (!strcmp(s, "yes"))
  564. return 1;
  565. return 0;
  566. }
  567. #endif /* defined(CONFIG_PCI) */
  568. #ifdef CONFIG_RESET_PHY_R
  569. void reset_phy(void)
  570. {
  571. char *s;
  572. unsigned short val_method, val_behavior;
  573. /* special LED setup for NGCC/CANDES */
  574. if ((s = getenv("bd_type")) &&
  575. ((!strcmp(s, "ngcc")) || (!strcmp(s, "candes")))) {
  576. val_method = 0x0e0a;
  577. val_behavior = 0x0cf2;
  578. } else {
  579. /* PMC440 standard type */
  580. val_method = 0x0e10;
  581. val_behavior = 0x0cf0;
  582. }
  583. if (miiphy_write("ppc_4xx_eth0", CONFIG_PHY_ADDR, 0x1f, 0x0001) == 0) {
  584. miiphy_write("ppc_4xx_eth0", CONFIG_PHY_ADDR, 0x11, 0x0010);
  585. miiphy_write("ppc_4xx_eth0", CONFIG_PHY_ADDR, 0x11, val_behavior);
  586. miiphy_write("ppc_4xx_eth0", CONFIG_PHY_ADDR, 0x10, val_method);
  587. miiphy_write("ppc_4xx_eth0", CONFIG_PHY_ADDR, 0x1f, 0x0000);
  588. }
  589. if (miiphy_write("ppc_4xx_eth1", CONFIG_PHY1_ADDR, 0x1f, 0x0001) == 0) {
  590. miiphy_write("ppc_4xx_eth1", CONFIG_PHY1_ADDR, 0x11, 0x0010);
  591. miiphy_write("ppc_4xx_eth1", CONFIG_PHY1_ADDR, 0x11, val_behavior);
  592. miiphy_write("ppc_4xx_eth1", CONFIG_PHY1_ADDR, 0x10, val_method);
  593. miiphy_write("ppc_4xx_eth1", CONFIG_PHY1_ADDR, 0x1f, 0x0000);
  594. }
  595. }
  596. #endif
  597. #if defined(CONFIG_SYS_EEPROM_WREN)
  598. /*
  599. * Input: <dev_addr> I2C address of EEPROM device to enable.
  600. * <state> -1: deliver current state
  601. * 0: disable write
  602. * 1: enable write
  603. * Returns: -1: wrong device address
  604. * 0: dis-/en- able done
  605. * 0/1: current state if <state> was -1.
  606. */
  607. int eeprom_write_enable(unsigned dev_addr, int state)
  608. {
  609. if ((CONFIG_SYS_I2C_EEPROM_ADDR != dev_addr) &&
  610. (CONFIG_SYS_I2C_BOOT_EEPROM_ADDR != dev_addr)) {
  611. return -1;
  612. } else {
  613. switch (state) {
  614. case 1:
  615. /* Enable write access, clear bit GPIO_SINT2. */
  616. out_be32((void *)GPIO0_OR,
  617. in_be32((void *)GPIO0_OR) & ~GPIO0_EP_EEP);
  618. state = 0;
  619. break;
  620. case 0:
  621. /* Disable write access, set bit GPIO_SINT2. */
  622. out_be32((void *)GPIO0_OR,
  623. in_be32((void *)GPIO0_OR) | GPIO0_EP_EEP);
  624. state = 0;
  625. break;
  626. default:
  627. /* Read current status back. */
  628. state = (0 == (in_be32((void *)GPIO0_OR)
  629. & GPIO0_EP_EEP));
  630. break;
  631. }
  632. }
  633. return state;
  634. }
  635. #endif /* #if defined(CONFIG_SYS_EEPROM_WREN) */
  636. #define CONFIG_SYS_BOOT_EEPROM_PAGE_WRITE_BITS 3
  637. int bootstrap_eeprom_write(unsigned dev_addr, unsigned offset,
  638. uchar *buffer, unsigned cnt)
  639. {
  640. unsigned end = offset + cnt;
  641. unsigned blk_off;
  642. int rcode = 0;
  643. #if defined(CONFIG_SYS_EEPROM_WREN)
  644. eeprom_write_enable(dev_addr, 1);
  645. #endif
  646. /*
  647. * Write data until done or would cross a write page boundary.
  648. * We must write the address again when changing pages
  649. * because the address counter only increments within a page.
  650. */
  651. while (offset < end) {
  652. unsigned alen, len;
  653. unsigned maxlen;
  654. uchar addr[2];
  655. blk_off = offset & 0xFF; /* block offset */
  656. addr[0] = offset >> 8; /* block number */
  657. addr[1] = blk_off; /* block offset */
  658. alen = 2;
  659. addr[0] |= dev_addr; /* insert device address */
  660. len = end - offset;
  661. #define BOOT_EEPROM_PAGE_SIZE (1 << CONFIG_SYS_BOOT_EEPROM_PAGE_WRITE_BITS)
  662. #define BOOT_EEPROM_PAGE_OFFSET(x) ((x) & (BOOT_EEPROM_PAGE_SIZE - 1))
  663. maxlen = BOOT_EEPROM_PAGE_SIZE -
  664. BOOT_EEPROM_PAGE_OFFSET(blk_off);
  665. if (maxlen > I2C_RXTX_LEN)
  666. maxlen = I2C_RXTX_LEN;
  667. if (len > maxlen)
  668. len = maxlen;
  669. if (i2c_write (addr[0], offset, alen-1, buffer, len) != 0)
  670. rcode = 1;
  671. buffer += len;
  672. offset += len;
  673. #if defined(CONFIG_SYS_EEPROM_PAGE_WRITE_DELAY_MS)
  674. udelay(CONFIG_SYS_EEPROM_PAGE_WRITE_DELAY_MS * 1000);
  675. #endif
  676. }
  677. #if defined(CONFIG_SYS_EEPROM_WREN)
  678. eeprom_write_enable(dev_addr, 0);
  679. #endif
  680. return rcode;
  681. }
  682. int bootstrap_eeprom_read (unsigned dev_addr, unsigned offset,
  683. uchar *buffer, unsigned cnt)
  684. {
  685. unsigned end = offset + cnt;
  686. unsigned blk_off;
  687. int rcode = 0;
  688. /*
  689. * Read data until done or would cross a page boundary.
  690. * We must write the address again when changing pages
  691. * because the next page may be in a different device.
  692. */
  693. while (offset < end) {
  694. unsigned alen, len;
  695. unsigned maxlen;
  696. uchar addr[2];
  697. blk_off = offset & 0xFF; /* block offset */
  698. addr[0] = offset >> 8; /* block number */
  699. addr[1] = blk_off; /* block offset */
  700. alen = 2;
  701. addr[0] |= dev_addr; /* insert device address */
  702. len = end - offset;
  703. maxlen = 0x100 - blk_off;
  704. if (maxlen > I2C_RXTX_LEN)
  705. maxlen = I2C_RXTX_LEN;
  706. if (len > maxlen)
  707. len = maxlen;
  708. if (i2c_read (addr[0], offset, alen-1, buffer, len) != 0)
  709. rcode = 1;
  710. buffer += len;
  711. offset += len;
  712. }
  713. return rcode;
  714. }
  715. #if defined(CONFIG_USB_OHCI_NEW) && defined(CONFIG_SYS_USB_OHCI_BOARD_INIT)
  716. int usb_board_init(void)
  717. {
  718. char *act = getenv("usbact");
  719. int i;
  720. if ((act == NULL || strcmp(act, "host") == 0) &&
  721. !(in_be32((void*)GPIO0_IR) & GPIO0_USB_PRSNT))
  722. /* enable power on USB socket */
  723. out_be32((void*)GPIO1_OR,
  724. in_be32((void*)GPIO1_OR) & ~GPIO1_USB_PWR_N);
  725. for (i=0; i<1000; i++)
  726. udelay(1000);
  727. return 0;
  728. }
  729. int usb_board_stop(void)
  730. {
  731. /* disable power on USB socket */
  732. out_be32((void*)GPIO1_OR, in_be32((void*)GPIO1_OR) | GPIO1_USB_PWR_N);
  733. return 0;
  734. }
  735. int usb_board_init_fail(void)
  736. {
  737. usb_board_stop();
  738. return 0;
  739. }
  740. #endif /* defined(CONFIG_USB_OHCI) && defined(CONFIG_SYS_USB_OHCI_BOARD_INIT) */
  741. #if defined(CONFIG_OF_LIBFDT) && defined(CONFIG_OF_BOARD_SETUP)
  742. void ft_board_setup(void *blob, bd_t *bd)
  743. {
  744. int rc;
  745. __ft_board_setup(blob, bd);
  746. /*
  747. * Disable PCI in non-monarch mode.
  748. */
  749. if (!is_monarch()) {
  750. rc = fdt_find_and_setprop(blob, "/plb/pci@1ec000000", "status",
  751. "disabled", sizeof("disabled"), 1);
  752. if (rc) {
  753. printf("Unable to update property status in PCI node, err=%s\n",
  754. fdt_strerror(rc));
  755. }
  756. }
  757. }
  758. #endif /* defined(CONFIG_OF_LIBFDT) && defined(CONFIG_OF_BOARD_SETUP) */