SWM341_sdram.c 4.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. /******************************************************************************************************************************************
  2. * 文件名称: SWM341_sdram.c
  3. * 功能说明: SWM341单片机的SDRAM驱动程序
  4. * 技术支持: http://www.synwit.com.cn/e/tool/gbook/?bid=1
  5. * 注意事项:
  6. * 版本日期: V1.1.0 2017年10月25日
  7. * 升级记录:
  8. *
  9. *
  10. *******************************************************************************************************************************************
  11. * @attention
  12. *
  13. * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS WITH CODING INFORMATION
  14. * REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE TIME. AS A RESULT, SYNWIT SHALL NOT BE HELD LIABLE
  15. * FOR ANY DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING FROM THE CONTENT
  16. * OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING INFORMATION CONTAINED HEREIN IN CONN-
  17. * -ECTION WITH THEIR PRODUCTS.
  18. *
  19. * COPYRIGHT 2012 Synwit Technology
  20. *******************************************************************************************************************************************/
  21. #include "SWM341.h"
  22. #include "SWM341_sdram.h"
  23. /******************************************************************************************************************************************
  24. * 函数名称: SDRAM_Init()
  25. * 功能说明: SDRAM控制器初始化
  26. * 输 入: SDRAM_InitStructure * initStruct 包含 SDRAM 控制器相关设定值的结构体
  27. * 输 出: 无
  28. * 注意事项: 无
  29. ******************************************************************************************************************************************/
  30. void SDRAM_Init(SDRAM_InitStructure * initStruct)
  31. {
  32. uint32_t cyclesPerUs = CyclesPerUs / (initStruct->ClkDiv + 1); // 1us有多少个SDRAM_CLK周期
  33. uint32_t row_n;
  34. SYS->CLKEN1 |= (1 << SYS_CLKEN1_SDRAM_Pos);
  35. SDRAMC->TIM = (initStruct->TimeTRP << SDRAMC_TIM_TRP_Pos) |
  36. (initStruct->TimeTRCD << SDRAMC_TIM_TRCD_Pos) |
  37. (initStruct->TimeTRC << SDRAMC_TIM_TRC_Pos) |
  38. ((cyclesPerUs * 200) << SDRAMC_TIM_T100US_Pos); // 要求大于100us
  39. SDRAMC->CFG = (initStruct->Size << SDRAMC_CFG_SIZE_Pos) |
  40. (initStruct->ClkDiv << SDRAMC_CFG_CLKDIV_Pos) |
  41. (initStruct->CASLatency << SDRAMC_CFG_CASDELAY_Pos) |
  42. (((SystemCoreClock / (initStruct->ClkDiv + 1)) > 66000000) << SDRAMC_CFG_HIGHFREQ_Pos);
  43. switch(initStruct->Size)
  44. {
  45. case SDRAM_SIZE_2MB: row_n = 2048; break;
  46. case SDRAM_SIZE_8MB: row_n = 4096; break;
  47. case SDRAM_SIZE_16MB: row_n = 4096; break;
  48. case SDRAM_SIZE_32MB: row_n = 8192; break;
  49. default: row_n = 4096; break;
  50. }
  51. SDRAMC->T64 = (initStruct->RefreshTime * 1000 / row_n + 1) * cyclesPerUs;
  52. SDRAMC->CR = (1 << SDRAMC_CR_PWRON_Pos);
  53. while(SDRAMC->CR & SDRAMC_CR_PWRON_Msk) __NOP(); //等待初始完成
  54. }
  55. /******************************************************************************************************************************************
  56. * 函数名称: SDRAM_Enable()
  57. * 功能说明: SDRAM使能,使能后可读写SDRAM
  58. * 输 入: 无
  59. * 输 出: 无
  60. * 注意事项: 无
  61. ******************************************************************************************************************************************/
  62. void SDRAM_Enable(void)
  63. {
  64. SDRAMC->CR &= ~SDRAMC_CR_ENTERSRF_Msk;
  65. for(int i = 0; i < 100; i++) __NOP();
  66. }
  67. /******************************************************************************************************************************************
  68. * 函数名称: SDRAM_Disable()
  69. * 功能说明: SDRAM禁能,禁能后SDRAM颗粒进入低功耗模式、并自刷新,不可读写
  70. * 输 入: 无
  71. * 输 出: 无
  72. * 注意事项: 无
  73. ******************************************************************************************************************************************/
  74. void SDRAM_Disable(void)
  75. {
  76. SDRAMC->CR |= SDRAMC_CR_ENTERSRF_Msk;
  77. for(int i = 0; i < 100; i++) __NOP();
  78. }