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 /******************************************************************************************************************************************
25 * 函数名称: SDRAM_Init()
26 * 功能说明: SDRAM控制器初始化
27 * 输    入: SDRAM_InitStructure * initStruct    包含 SDRAM 控制器相关设定值的结构体
28 * 输    出: 无
29 * 注意事项: 无
30 ******************************************************************************************************************************************/
SDRAM_Init(SDRAM_InitStructure * initStruct)31 void SDRAM_Init(SDRAM_InitStructure * initStruct)
32 {
33     uint32_t cyclesPerUs = CyclesPerUs / (initStruct->ClkDiv + 1);  // 1us有多少个SDRAM_CLK周期
34     uint32_t row_n;
35 
36     SYS->CLKEN1 |= (1 << SYS_CLKEN1_SDRAM_Pos);
37 
38     SDRAMC->TIM = (initStruct->TimeTRP  << SDRAMC_TIM_TRP_Pos)  |
39                   (initStruct->TimeTRCD << SDRAMC_TIM_TRCD_Pos) |
40                   (initStruct->TimeTRC  << SDRAMC_TIM_TRC_Pos)  |
41                   ((cyclesPerUs * 200)  << SDRAMC_TIM_T100US_Pos);  // 要求大于100us
42 
43     SDRAMC->CFG = (initStruct->Size       << SDRAMC_CFG_SIZE_Pos)     |
44                   (initStruct->ClkDiv     << SDRAMC_CFG_CLKDIV_Pos)   |
45                   (initStruct->CASLatency << SDRAMC_CFG_CASDELAY_Pos) |
46                   (((SystemCoreClock / (initStruct->ClkDiv + 1)) > 66000000) << SDRAMC_CFG_HIGHFREQ_Pos);
47 
48     switch(initStruct->Size)
49     {
50     case SDRAM_SIZE_2MB:  row_n = 2048; break;
51     case SDRAM_SIZE_8MB:  row_n = 4096; break;
52     case SDRAM_SIZE_16MB: row_n = 4096; break;
53     case SDRAM_SIZE_32MB: row_n = 8192; break;
54     default:              row_n = 4096; break;
55     }
56 
57     SDRAMC->T64 = (initStruct->RefreshTime * 1000 / row_n + 1) * cyclesPerUs;
58 
59     SDRAMC->CR = (1 << SDRAMC_CR_PWRON_Pos);
60 
61     while(SDRAMC->CR & SDRAMC_CR_PWRON_Msk) __NOP();    //等待初始完成
62 }
63 
64 
65 /******************************************************************************************************************************************
66 * 函数名称: SDRAM_Enable()
67 * 功能说明: SDRAM使能,使能后可读写SDRAM
68 * 输    入: 无
69 * 输    出: 无
70 * 注意事项: 无
71 ******************************************************************************************************************************************/
SDRAM_Enable(void)72 void SDRAM_Enable(void)
73 {
74     SDRAMC->CR &= ~SDRAMC_CR_ENTERSRF_Msk;
75 
76     for(int i = 0; i < 100; i++) __NOP();
77 }
78 
79 /******************************************************************************************************************************************
80 * 函数名称: SDRAM_Disable()
81 * 功能说明: SDRAM禁能,禁能后SDRAM颗粒进入低功耗模式、并自刷新,不可读写
82 * 输    入: 无
83 * 输    出: 无
84 * 注意事项: 无
85 ******************************************************************************************************************************************/
SDRAM_Disable(void)86 void SDRAM_Disable(void)
87 {
88     SDRAMC->CR |= SDRAMC_CR_ENTERSRF_Msk;
89 
90     for(int i = 0; i < 100; i++) __NOP();
91 }
92