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)31void 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)72void 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)86void SDRAM_Disable(void) 87 { 88 SDRAMC->CR |= SDRAMC_CR_ENTERSRF_Msk; 89 90 for(int i = 0; i < 100; i++) __NOP(); 91 } 92