cpu.c 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678
  1. /*
  2. * (C) Copyright 2000-2007
  3. * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
  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. * CPU specific code
  25. *
  26. * written or collected and sometimes rewritten by
  27. * Magnus Damm <damm@bitsmart.com>
  28. *
  29. * minor modifications by
  30. * Wolfgang Denk <wd@denx.de>
  31. */
  32. #include <common.h>
  33. #include <watchdog.h>
  34. #include <command.h>
  35. #include <asm/cache.h>
  36. #include <ppc4xx.h>
  37. DECLARE_GLOBAL_DATA_PTR;
  38. void board_reset(void);
  39. #if defined(CONFIG_405GP) || \
  40. defined(CONFIG_440EP) || defined(CONFIG_440GR) || \
  41. defined(CONFIG_440EPX) || defined(CONFIG_440GRX)
  42. #define PCI_ASYNC
  43. static int pci_async_enabled(void)
  44. {
  45. #if defined(CONFIG_405GP)
  46. return (mfdcr(strap) & PSR_PCI_ASYNC_EN);
  47. #endif
  48. #if defined(CONFIG_440EP) || defined(CONFIG_440GR) || \
  49. defined(CONFIG_440EPX) || defined(CONFIG_440GRX) || \
  50. defined(CONFIG_460EX) || defined(CONFIG_460GT)
  51. unsigned long val;
  52. mfsdr(sdr_sdstp1, val);
  53. return (val & SDR0_SDSTP1_PAME_MASK);
  54. #endif
  55. }
  56. #endif
  57. #if defined(CONFIG_PCI) && !defined(CONFIG_IOP480) && \
  58. !defined(CONFIG_405) && !defined(CONFIG_405EX)
  59. static int pci_arbiter_enabled(void)
  60. {
  61. #if defined(CONFIG_405GP)
  62. return (mfdcr(strap) & PSR_PCI_ARBIT_EN);
  63. #endif
  64. #if defined(CONFIG_405EP)
  65. return (mfdcr(cpc0_pci) & CPC0_PCI_ARBIT_EN);
  66. #endif
  67. #if defined(CONFIG_440GP)
  68. return (mfdcr(cpc0_strp1) & CPC0_STRP1_PAE_MASK);
  69. #endif
  70. #if defined(CONFIG_440GX) || defined(CONFIG_440SP) || defined(CONFIG_440SPE)
  71. unsigned long val;
  72. mfsdr(sdr_xcr, val);
  73. return (val & 0x80000000);
  74. #endif
  75. #if defined(CONFIG_440EP) || defined(CONFIG_440GR) || \
  76. defined(CONFIG_440EPX) || defined(CONFIG_440GRX) || \
  77. defined(CONFIG_460EX) || defined(CONFIG_460GT)
  78. unsigned long val;
  79. mfsdr(sdr_pci0, val);
  80. return (val & 0x80000000);
  81. #endif
  82. }
  83. #endif
  84. #if defined(CONFIG_405EP)
  85. #define I2C_BOOTROM
  86. static int i2c_bootrom_enabled(void)
  87. {
  88. #if defined(CONFIG_405EP)
  89. return (mfdcr(cpc0_boot) & CPC0_BOOT_SEP);
  90. #else
  91. unsigned long val;
  92. mfsdr(sdr_sdcs, val);
  93. return (val & SDR0_SDCS_SDD);
  94. #endif
  95. }
  96. #endif
  97. #if defined(CONFIG_440GX)
  98. #define SDR0_PINSTP_SHIFT 29
  99. static char *bootstrap_str[] = {
  100. "EBC (16 bits)",
  101. "EBC (8 bits)",
  102. "EBC (32 bits)",
  103. "EBC (8 bits)",
  104. "PCI",
  105. "I2C (Addr 0x54)",
  106. "Reserved",
  107. "I2C (Addr 0x50)",
  108. };
  109. static char bootstrap_char[] = { 'A', 'B', 'C', 'B', 'D', 'E', 'x', 'F' };
  110. #endif
  111. #if defined(CONFIG_440SP) || defined(CONFIG_440SPE)
  112. #define SDR0_PINSTP_SHIFT 30
  113. static char *bootstrap_str[] = {
  114. "EBC (8 bits)",
  115. "PCI",
  116. "I2C (Addr 0x54)",
  117. "I2C (Addr 0x50)",
  118. };
  119. static char bootstrap_char[] = { 'A', 'B', 'C', 'D'};
  120. #endif
  121. #if defined(CONFIG_440EP) || defined(CONFIG_440GR)
  122. #define SDR0_PINSTP_SHIFT 29
  123. static char *bootstrap_str[] = {
  124. "EBC (8 bits)",
  125. "PCI",
  126. "NAND (8 bits)",
  127. "EBC (16 bits)",
  128. "EBC (16 bits)",
  129. "I2C (Addr 0x54)",
  130. "PCI",
  131. "I2C (Addr 0x52)",
  132. };
  133. static char bootstrap_char[] = { 'A', 'B', 'C', 'D', 'E', 'G', 'F', 'H' };
  134. #endif
  135. #if defined(CONFIG_440EPX) || defined(CONFIG_440GRX)
  136. #define SDR0_PINSTP_SHIFT 29
  137. static char *bootstrap_str[] = {
  138. "EBC (8 bits)",
  139. "EBC (16 bits)",
  140. "EBC (16 bits)",
  141. "NAND (8 bits)",
  142. "PCI",
  143. "I2C (Addr 0x54)",
  144. "PCI",
  145. "I2C (Addr 0x52)",
  146. };
  147. static char bootstrap_char[] = { 'A', 'B', 'C', 'D', 'E', 'G', 'F', 'H' };
  148. #endif
  149. #if defined(CONFIG_460EX) || defined(CONFIG_460GT)
  150. #define SDR0_PINSTP_SHIFT 29
  151. static char *bootstrap_str[] = {
  152. "EBC (8 bits)",
  153. "EBC (16 bits)",
  154. "PCI",
  155. "PCI",
  156. "EBC (16 bits)",
  157. "NAND (8 bits)",
  158. "I2C (Addr 0x54)", /* A8 */
  159. "I2C (Addr 0x52)", /* A4 */
  160. };
  161. static char bootstrap_char[] = { 'A', 'B', 'C', 'D', 'E', 'G', 'F', 'H' };
  162. #endif
  163. #if defined(CONFIG_460SX)
  164. #define SDR0_PINSTP_SHIFT 29
  165. static char *bootstrap_str[] = {
  166. "EBC (8 bits)",
  167. "EBC (16 bits)",
  168. "EBC (32 bits)",
  169. "NAND (8 bits)",
  170. "I2C (Addr 0x54)", /* A8 */
  171. "I2C (Addr 0x52)", /* A4 */
  172. };
  173. static char bootstrap_char[] = { 'A', 'B', 'C', 'D', 'E', 'G' };
  174. #endif
  175. #if defined(CONFIG_405EZ)
  176. #define SDR0_PINSTP_SHIFT 28
  177. static char *bootstrap_str[] = {
  178. "EBC (8 bits)",
  179. "SPI (fast)",
  180. "NAND (512 page, 4 addr cycle)",
  181. "I2C (Addr 0x50)",
  182. "EBC (32 bits)",
  183. "I2C (Addr 0x50)",
  184. "NAND (2K page, 5 addr cycle)",
  185. "I2C (Addr 0x50)",
  186. "EBC (16 bits)",
  187. "Reserved",
  188. "NAND (2K page, 4 addr cycle)",
  189. "I2C (Addr 0x50)",
  190. "NAND (512 page, 3 addr cycle)",
  191. "I2C (Addr 0x50)",
  192. "SPI (slow)",
  193. "I2C (Addr 0x50)",
  194. };
  195. static char bootstrap_char[] = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', \
  196. 'I', 'x', 'K', 'L', 'M', 'N', 'O', 'P' };
  197. #endif
  198. #if defined(CONFIG_405EX)
  199. #define SDR0_PINSTP_SHIFT 29
  200. static char *bootstrap_str[] = {
  201. "EBC (8 bits)",
  202. "EBC (16 bits)",
  203. "EBC (16 bits)",
  204. "NAND (8 bits)",
  205. "NAND (8 bits)",
  206. "I2C (Addr 0x54)",
  207. "EBC (8 bits)",
  208. "I2C (Addr 0x52)",
  209. };
  210. static char bootstrap_char[] = { 'A', 'B', 'C', 'D', 'E', 'G', 'F', 'H' };
  211. #endif
  212. #if defined(SDR0_PINSTP_SHIFT)
  213. static int bootstrap_option(void)
  214. {
  215. unsigned long val;
  216. mfsdr(SDR_PINSTP, val);
  217. return ((val & 0xf0000000) >> SDR0_PINSTP_SHIFT);
  218. }
  219. #endif /* SDR0_PINSTP_SHIFT */
  220. #if defined(CONFIG_440)
  221. static int do_chip_reset (unsigned long sys0, unsigned long sys1)
  222. {
  223. /* Changes to cpc0_sys0 and cpc0_sys1 require chip
  224. * reset.
  225. */
  226. mtdcr (cntrl0, mfdcr (cntrl0) | 0x80000000); /* Set SWE */
  227. mtdcr (cpc0_sys0, sys0);
  228. mtdcr (cpc0_sys1, sys1);
  229. mtdcr (cntrl0, mfdcr (cntrl0) & ~0x80000000); /* Clr SWE */
  230. mtspr (dbcr0, 0x20000000); /* Reset the chip */
  231. return 1;
  232. }
  233. #endif
  234. int checkcpu (void)
  235. {
  236. #if !defined(CONFIG_405) /* not used on Xilinx 405 FPGA implementations */
  237. uint pvr = get_pvr();
  238. ulong clock = gd->cpu_clk;
  239. char buf[32];
  240. #if !defined(CONFIG_IOP480)
  241. char addstr[64] = "";
  242. sys_info_t sys_info;
  243. puts ("CPU: ");
  244. get_sys_info(&sys_info);
  245. #if defined(CONFIG_XILINX_440)
  246. puts("IBM PowerPC 4");
  247. #else
  248. puts("AMCC PowerPC 4");
  249. #endif
  250. #if defined(CONFIG_405GP) || defined(CONFIG_405CR) || \
  251. defined(CONFIG_405EP) || defined(CONFIG_405EZ) || \
  252. defined(CONFIG_405EX)
  253. puts("05");
  254. #endif
  255. #if defined(CONFIG_440)
  256. #if defined(CONFIG_460EX) || defined(CONFIG_460GT)
  257. puts("60");
  258. #else
  259. puts("40");
  260. #endif
  261. #endif
  262. switch (pvr) {
  263. case PVR_405GP_RB:
  264. puts("GP Rev. B");
  265. break;
  266. case PVR_405GP_RC:
  267. puts("GP Rev. C");
  268. break;
  269. case PVR_405GP_RD:
  270. puts("GP Rev. D");
  271. break;
  272. #ifdef CONFIG_405GP
  273. case PVR_405GP_RE: /* 405GP rev E and 405CR rev C have same PVR */
  274. puts("GP Rev. E");
  275. break;
  276. #endif
  277. case PVR_405CR_RA:
  278. puts("CR Rev. A");
  279. break;
  280. case PVR_405CR_RB:
  281. puts("CR Rev. B");
  282. break;
  283. #ifdef CONFIG_405CR
  284. case PVR_405CR_RC: /* 405GP rev E and 405CR rev C have same PVR */
  285. puts("CR Rev. C");
  286. break;
  287. #endif
  288. case PVR_405GPR_RB:
  289. puts("GPr Rev. B");
  290. break;
  291. case PVR_405EP_RB:
  292. puts("EP Rev. B");
  293. break;
  294. case PVR_405EZ_RA:
  295. puts("EZ Rev. A");
  296. break;
  297. case PVR_405EX1_RA:
  298. puts("EX Rev. A");
  299. strcpy(addstr, "Security support");
  300. break;
  301. case PVR_405EX2_RA:
  302. puts("EX Rev. A");
  303. strcpy(addstr, "No Security support");
  304. break;
  305. case PVR_405EXR1_RA:
  306. puts("EXr Rev. A");
  307. strcpy(addstr, "Security support");
  308. break;
  309. case PVR_405EXR2_RA:
  310. puts("EXr Rev. A");
  311. strcpy(addstr, "No Security support");
  312. break;
  313. case PVR_405EX1_RC:
  314. puts("EX Rev. C");
  315. strcpy(addstr, "Security support");
  316. break;
  317. case PVR_405EX2_RC:
  318. puts("EX Rev. C");
  319. strcpy(addstr, "No Security support");
  320. break;
  321. case PVR_405EXR1_RC:
  322. puts("EXr Rev. C");
  323. strcpy(addstr, "Security support");
  324. break;
  325. case PVR_405EXR2_RC:
  326. puts("EXr Rev. C");
  327. strcpy(addstr, "No Security support");
  328. break;
  329. #if defined(CONFIG_440)
  330. case PVR_440GP_RB:
  331. puts("GP Rev. B");
  332. /* See errata 1.12: CHIP_4 */
  333. if ((mfdcr(cpc0_sys0) != mfdcr(cpc0_strp0)) ||
  334. (mfdcr(cpc0_sys1) != mfdcr(cpc0_strp1)) ){
  335. puts ( "\n\t CPC0_SYSx DCRs corrupted. "
  336. "Resetting chip ...\n");
  337. udelay( 1000 * 1000 ); /* Give time for serial buf to clear */
  338. do_chip_reset ( mfdcr(cpc0_strp0),
  339. mfdcr(cpc0_strp1) );
  340. }
  341. break;
  342. case PVR_440GP_RC:
  343. puts("GP Rev. C");
  344. break;
  345. case PVR_440GX_RA:
  346. puts("GX Rev. A");
  347. break;
  348. case PVR_440GX_RB:
  349. puts("GX Rev. B");
  350. break;
  351. case PVR_440GX_RC:
  352. puts("GX Rev. C");
  353. break;
  354. case PVR_440GX_RF:
  355. puts("GX Rev. F");
  356. break;
  357. case PVR_440EP_RA:
  358. puts("EP Rev. A");
  359. break;
  360. #ifdef CONFIG_440EP
  361. case PVR_440EP_RB: /* 440EP rev B and 440GR rev A have same PVR */
  362. puts("EP Rev. B");
  363. break;
  364. case PVR_440EP_RC: /* 440EP rev C and 440GR rev B have same PVR */
  365. puts("EP Rev. C");
  366. break;
  367. #endif /* CONFIG_440EP */
  368. #ifdef CONFIG_440GR
  369. case PVR_440GR_RA: /* 440EP rev B and 440GR rev A have same PVR */
  370. puts("GR Rev. A");
  371. break;
  372. case PVR_440GR_RB: /* 440EP rev C and 440GR rev B have same PVR */
  373. puts("GR Rev. B");
  374. break;
  375. #endif /* CONFIG_440GR */
  376. #endif /* CONFIG_440 */
  377. #ifdef CONFIG_440EPX
  378. case PVR_440EPX1_RA: /* 440EPx rev A and 440GRx rev A have same PVR */
  379. puts("EPx Rev. A");
  380. strcpy(addstr, "Security/Kasumi support");
  381. break;
  382. case PVR_440EPX2_RA: /* 440EPx rev A and 440GRx rev A have same PVR */
  383. puts("EPx Rev. A");
  384. strcpy(addstr, "No Security/Kasumi support");
  385. break;
  386. #endif /* CONFIG_440EPX */
  387. #ifdef CONFIG_440GRX
  388. case PVR_440GRX1_RA: /* 440EPx rev A and 440GRx rev A have same PVR */
  389. puts("GRx Rev. A");
  390. strcpy(addstr, "Security/Kasumi support");
  391. break;
  392. case PVR_440GRX2_RA: /* 440EPx rev A and 440GRx rev A have same PVR */
  393. puts("GRx Rev. A");
  394. strcpy(addstr, "No Security/Kasumi support");
  395. break;
  396. #endif /* CONFIG_440GRX */
  397. case PVR_440SP_6_RAB:
  398. puts("SP Rev. A/B");
  399. strcpy(addstr, "RAID 6 support");
  400. break;
  401. case PVR_440SP_RAB:
  402. puts("SP Rev. A/B");
  403. strcpy(addstr, "No RAID 6 support");
  404. break;
  405. case PVR_440SP_6_RC:
  406. puts("SP Rev. C");
  407. strcpy(addstr, "RAID 6 support");
  408. break;
  409. case PVR_440SP_RC:
  410. puts("SP Rev. C");
  411. strcpy(addstr, "No RAID 6 support");
  412. break;
  413. case PVR_440SPe_6_RA:
  414. puts("SPe Rev. A");
  415. strcpy(addstr, "RAID 6 support");
  416. break;
  417. case PVR_440SPe_RA:
  418. puts("SPe Rev. A");
  419. strcpy(addstr, "No RAID 6 support");
  420. break;
  421. case PVR_440SPe_6_RB:
  422. puts("SPe Rev. B");
  423. strcpy(addstr, "RAID 6 support");
  424. break;
  425. case PVR_440SPe_RB:
  426. puts("SPe Rev. B");
  427. strcpy(addstr, "No RAID 6 support");
  428. break;
  429. case PVR_460EX_RA:
  430. puts("EX Rev. A");
  431. strcpy(addstr, "No Security/Kasumi support");
  432. break;
  433. case PVR_460EX_SE_RA:
  434. puts("EX Rev. A");
  435. strcpy(addstr, "Security/Kasumi support");
  436. break;
  437. case PVR_460GT_RA:
  438. puts("GT Rev. A");
  439. strcpy(addstr, "No Security/Kasumi support");
  440. break;
  441. case PVR_460GT_SE_RA:
  442. puts("GT Rev. A");
  443. strcpy(addstr, "Security/Kasumi support");
  444. break;
  445. case PVR_460SX_RA:
  446. puts("SX Rev. A");
  447. strcpy(addstr, "Security support");
  448. break;
  449. case PVR_460SX_RA_V1:
  450. puts("SX Rev. A");
  451. strcpy(addstr, "No Security support");
  452. break;
  453. case PVR_460GX_RA:
  454. puts("GX Rev. A");
  455. strcpy(addstr, "Security support");
  456. break;
  457. case PVR_460GX_RA_V1:
  458. puts("GX Rev. A");
  459. strcpy(addstr, "No Security support");
  460. break;
  461. case PVR_VIRTEX5:
  462. puts("x5 VIRTEX5");
  463. break;
  464. default:
  465. printf (" UNKNOWN (PVR=%08x)", pvr);
  466. break;
  467. }
  468. printf (" at %s MHz (PLB=%lu, OPB=%lu, EBC=%lu MHz)\n", strmhz(buf, clock),
  469. sys_info.freqPLB / 1000000,
  470. get_OPB_freq() / 1000000,
  471. sys_info.freqEBC / 1000000);
  472. if (addstr[0] != 0)
  473. printf(" %s\n", addstr);
  474. #if defined(I2C_BOOTROM)
  475. printf (" I2C boot EEPROM %sabled\n", i2c_bootrom_enabled() ? "en" : "dis");
  476. #endif /* I2C_BOOTROM */
  477. #if defined(SDR0_PINSTP_SHIFT)
  478. printf (" Bootstrap Option %c - ", bootstrap_char[bootstrap_option()]);
  479. printf ("Boot ROM Location %s\n", bootstrap_str[bootstrap_option()]);
  480. #endif /* SDR0_PINSTP_SHIFT */
  481. #if defined(CONFIG_PCI) && !defined(CONFIG_405EX)
  482. printf (" Internal PCI arbiter %sabled", pci_arbiter_enabled() ? "en" : "dis");
  483. #endif
  484. #if defined(PCI_ASYNC)
  485. if (pci_async_enabled()) {
  486. printf (", PCI async ext clock used");
  487. } else {
  488. printf (", PCI sync clock at %lu MHz",
  489. sys_info.freqPLB / sys_info.pllPciDiv / 1000000);
  490. }
  491. #endif
  492. #if defined(CONFIG_PCI) && !defined(CONFIG_405EX)
  493. putc('\n');
  494. #endif
  495. #if defined(CONFIG_405EP) || defined(CONFIG_405EZ) || defined(CONFIG_405EX)
  496. printf (" 16 kB I-Cache 16 kB D-Cache");
  497. #elif defined(CONFIG_440)
  498. printf (" 32 kB I-Cache 32 kB D-Cache");
  499. #else
  500. printf (" 16 kB I-Cache %d kB D-Cache",
  501. ((pvr | 0x00000001) == PVR_405GPR_RB) ? 16 : 8);
  502. #endif
  503. #endif /* !defined(CONFIG_IOP480) */
  504. #if defined(CONFIG_IOP480)
  505. printf ("PLX IOP480 (PVR=%08x)", pvr);
  506. printf (" at %s MHz:", strmhz(buf, clock));
  507. printf (" %u kB I-Cache", 4);
  508. printf (" %u kB D-Cache", 2);
  509. #endif
  510. #endif /* !defined(CONFIG_405) */
  511. putc ('\n');
  512. return 0;
  513. }
  514. int ppc440spe_revB() {
  515. unsigned int pvr;
  516. pvr = get_pvr();
  517. if ((pvr == PVR_440SPe_6_RB) || (pvr == PVR_440SPe_RB))
  518. return 1;
  519. else
  520. return 0;
  521. }
  522. /* ------------------------------------------------------------------------- */
  523. int do_reset (cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
  524. {
  525. #if defined(CONFIG_BOARD_RESET)
  526. board_reset();
  527. #else
  528. #if defined(CFG_4xx_RESET_TYPE)
  529. mtspr(dbcr0, CFG_4xx_RESET_TYPE << 28);
  530. #else
  531. /*
  532. * Initiate system reset in debug control register DBCR
  533. */
  534. mtspr(dbcr0, 0x30000000);
  535. #endif /* defined(CFG_4xx_RESET_TYPE) */
  536. #endif /* defined(CONFIG_BOARD_RESET) */
  537. return 1;
  538. }
  539. /*
  540. * Get timebase clock frequency
  541. */
  542. unsigned long get_tbclk (void)
  543. {
  544. #if !defined(CONFIG_IOP480)
  545. sys_info_t sys_info;
  546. get_sys_info(&sys_info);
  547. return (sys_info.freqProcessor);
  548. #else
  549. return (66000000);
  550. #endif
  551. }
  552. #if defined(CONFIG_WATCHDOG)
  553. void watchdog_reset(void)
  554. {
  555. int re_enable = disable_interrupts();
  556. reset_4xx_watchdog();
  557. if (re_enable) enable_interrupts();
  558. }
  559. void reset_4xx_watchdog(void)
  560. {
  561. /*
  562. * Clear TSR(WIS) bit
  563. */
  564. mtspr(tsr, 0x40000000);
  565. }
  566. #endif /* CONFIG_WATCHDOG */