adder.c 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. /*
  2. * Copyright (C) 2004-2005 Arabella Software Ltd.
  3. * Yuli Barcohen <yuli@arabellasw.com>
  4. *
  5. * Support for Analogue&Micro Adder boards family.
  6. * Tested on AdderII and Adder87x.
  7. *
  8. * SPDX-License-Identifier: GPL-2.0+
  9. */
  10. #include <common.h>
  11. #include <mpc8xx.h>
  12. #if defined(CONFIG_OF_LIBFDT)
  13. #include <libfdt.h>
  14. #endif
  15. /*
  16. * SDRAM is single Samsung K4S643232F-T70 chip (8MB)
  17. * or single Micron MT48LC4M32B2TG-7 chip (16MB).
  18. * Minimal CPU frequency is 40MHz.
  19. */
  20. static uint sdram_table[] = {
  21. /* Single read (offset 0x00 in UPM RAM) */
  22. 0x1f07fc24, 0xe0aefc04, 0x10adfc04, 0xe0bbbc00,
  23. 0x10f77c44, 0xf3fffc07, 0xfffffc04, 0xfffffc04,
  24. /* Burst read (offset 0x08 in UPM RAM) */
  25. 0x1f07fc24, 0xe0aefc04, 0x10adfc04, 0xf0affc00,
  26. 0xf0affc00, 0xf0affc00, 0xf0affc00, 0x10a77c44,
  27. 0xf7bffc47, 0xfffffc35, 0xfffffc34, 0xfffffc35,
  28. 0xfffffc35, 0x1ff77c35, 0xfffffc34, 0x1fb57c35,
  29. /* Single write (offset 0x18 in UPM RAM) */
  30. 0x1f27fc24, 0xe0aebc04, 0x00b93c00, 0x13f77c47,
  31. 0xfffdfc04, 0xfffffc04, 0xfffffc04, 0xfffffc04,
  32. /* Burst write (offset 0x20 in UPM RAM) */
  33. 0x1f07fc24, 0xeeaebc00, 0x10ad7c00, 0xf0affc00,
  34. 0xf0affc00, 0xe0abbc00, 0x1fb77c47, 0xfffffc04,
  35. 0xfffffc04, 0xfffffc04, 0xfffffc04, 0xfffffc04,
  36. 0xfffffc04, 0xfffffc04, 0xfffffc04, 0xfffffc04,
  37. /* Refresh (offset 0x30 in UPM RAM) */
  38. 0x1ff5fc84, 0xfffffc04, 0xfffffc04, 0xfffffc04,
  39. 0xfffffc84, 0xfffffc07, 0xfffffc04, 0xfffffc04,
  40. 0xfffffc04, 0xfffffc04, 0xfffffc04, 0xfffffc04,
  41. /* Exception (offset 0x3C in UPM RAM) */
  42. 0xfffffc27, 0xfffffc04, 0xfffffc04, 0xfffffc04
  43. };
  44. phys_size_t initdram (int board_type)
  45. {
  46. long int msize;
  47. volatile immap_t *immap = (volatile immap_t *)CONFIG_SYS_IMMR;
  48. volatile memctl8xx_t *memctl = &immap->im_memctl;
  49. upmconfig(UPMA, sdram_table, sizeof(sdram_table) / sizeof(uint));
  50. /* Configure SDRAM refresh */
  51. memctl->memc_mptpr = MPTPR_PTP_DIV32; /* BRGCLK/32 */
  52. memctl->memc_mamr = (94 << 24) | CONFIG_SYS_MAMR; /* No refresh */
  53. udelay(200);
  54. /* Run precharge from location 0x15 */
  55. memctl->memc_mar = 0x0;
  56. memctl->memc_mcr = 0x80002115;
  57. udelay(200);
  58. /* Run 8 refresh cycles */
  59. memctl->memc_mcr = 0x80002830;
  60. udelay(200);
  61. /* Run MRS pattern from location 0x16 */
  62. memctl->memc_mar = 0x88;
  63. memctl->memc_mcr = 0x80002116;
  64. udelay(200);
  65. memctl->memc_mamr |= MAMR_PTAE; /* Enable refresh */
  66. memctl->memc_or1 = ~(CONFIG_SYS_SDRAM_MAX_SIZE - 1) | OR_CSNT_SAM;
  67. memctl->memc_br1 = CONFIG_SYS_SDRAM_BASE | BR_PS_32 | BR_MS_UPMA | BR_V;
  68. msize = get_ram_size(CONFIG_SYS_SDRAM_BASE, CONFIG_SYS_SDRAM_MAX_SIZE);
  69. memctl->memc_or1 |= ~(msize - 1);
  70. return msize;
  71. }
  72. int checkboard( void )
  73. {
  74. puts("Board: Adder");
  75. #if defined(CONFIG_MPC885_FAMILY)
  76. puts("87x\n");
  77. #elif defined(CONFIG_MPC866_FAMILY)
  78. puts("II\n");
  79. #endif
  80. return 0;
  81. }
  82. #if defined(CONFIG_OF_BOARD_SETUP)
  83. void ft_board_setup(void *blob, bd_t *bd)
  84. {
  85. ft_cpu_setup(blob, bd);
  86. }
  87. #endif