m5275evb.c 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. /*
  2. * (C) Copyright 2000-2003
  3. * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
  4. *
  5. * Copyright (C) 2005-2008 Arthur Shipkowski (art@videon-central.com)
  6. *
  7. * Copyright (C) 2012 Freescale Semiconductor, Inc. All Rights Reserved.
  8. *
  9. * SPDX-License-Identifier: GPL-2.0+
  10. */
  11. #include <common.h>
  12. #include <asm/immap.h>
  13. #include <asm/io.h>
  14. #define PERIOD 13 /* system bus period in ns */
  15. #define SDRAM_TREFI 7800 /* in ns */
  16. int checkboard(void)
  17. {
  18. puts("Board: ");
  19. puts("Freescale MCF5275 EVB\n");
  20. return 0;
  21. };
  22. phys_size_t initdram(int board_type)
  23. {
  24. sdramctrl_t *sdp = (sdramctrl_t *)(MMAP_SDRAM);
  25. gpio_t *gpio_reg = (gpio_t *)(MMAP_GPIO);
  26. /* Enable SDRAM */
  27. out_be16(&gpio_reg->par_sdram, 0x3FF);
  28. /* Set up chip select */
  29. out_be32(&sdp->sdbar0, CONFIG_SYS_SDRAM_BASE);
  30. out_be32(&sdp->sdbmr0, MCF_SDRAMC_SDMRn_BAM_32M | MCF_SDRAMC_SDMRn_V);
  31. /* Set up timing */
  32. out_be32(&sdp->sdcfg1, 0x83711630);
  33. out_be32(&sdp->sdcfg2, 0x46770000);
  34. /* Enable clock */
  35. out_be32(&sdp->sdcr, MCF_SDRAMC_SDCR_MODE_EN | MCF_SDRAMC_SDCR_CKE);
  36. /* Set precharge */
  37. setbits_be32(&sdp->sdcr, MCF_SDRAMC_SDCR_IPALL);
  38. /* Dummy write to start SDRAM */
  39. *((volatile unsigned long *)CONFIG_SYS_SDRAM_BASE) = 0xa5a59696;
  40. /* Send LEMR */
  41. setbits_be32(&sdp->sdmr,
  42. MCF_SDRAMC_SDMR_BNKAD_LEMR | MCF_SDRAMC_SDMR_AD(0x0) |
  43. MCF_SDRAMC_SDMR_CMD);
  44. *((volatile unsigned long *)CONFIG_SYS_SDRAM_BASE) = 0xa5a59696;
  45. /* Send LMR */
  46. out_be32(&sdp->sdmr, 0x058d0000);
  47. *((volatile unsigned long *)CONFIG_SYS_SDRAM_BASE) = 0xa5a59696;
  48. /* Stop sending commands */
  49. clrbits_be32(&sdp->sdmr, MCF_SDRAMC_SDMR_CMD);
  50. /* Set precharge */
  51. setbits_be32(&sdp->sdcr, MCF_SDRAMC_SDCR_IPALL);
  52. *((volatile unsigned long *)CONFIG_SYS_SDRAM_BASE) = 0xa5a59696;
  53. /* Stop manual precharge, send 2 IREF */
  54. clrbits_be32(&sdp->sdcr, MCF_SDRAMC_SDCR_IPALL);
  55. setbits_be32(&sdp->sdcr, MCF_SDRAMC_SDCR_IREF);
  56. *((volatile unsigned long *)CONFIG_SYS_SDRAM_BASE) = 0xa5a59696;
  57. *((volatile unsigned long *)CONFIG_SYS_SDRAM_BASE) = 0xa5a59696;
  58. out_be32(&sdp->sdmr, 0x018d0000);
  59. *((volatile unsigned long *)CONFIG_SYS_SDRAM_BASE) = 0xa5a59696;
  60. /* Stop sending commands */
  61. clrbits_be32(&sdp->sdmr, MCF_SDRAMC_SDMR_CMD);
  62. clrbits_be32(&sdp->sdcr, MCF_SDRAMC_SDCR_MODE_EN);
  63. /* Turn on auto refresh, lock SDMR */
  64. out_be32(&sdp->sdcr,
  65. MCF_SDRAMC_SDCR_CKE
  66. | MCF_SDRAMC_SDCR_REF
  67. | MCF_SDRAMC_SDCR_MUX(1)
  68. /* 1 added to round up */
  69. | MCF_SDRAMC_SDCR_RCNT((SDRAM_TREFI/(PERIOD*64)) - 1 + 1)
  70. | MCF_SDRAMC_SDCR_DQS_OE(0x3));
  71. return CONFIG_SYS_SDRAM_SIZE * 1024 * 1024;
  72. };
  73. int testdram(void)
  74. {
  75. /* TODO: XXX XXX XXX */
  76. printf("DRAM test not implemented!\n");
  77. return (0);
  78. }