完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
STM32H750_FMC_SDRAM
使用STM32CUBEMX 初始化FMC部分, SDRAM 关于延时部分参数 模式寄存器 #define SDRAM_MODEREG_BURST_LENGTH_1 ((uint16_t)0x0000) #define SDRAM_MODEREG_BURST_LENGTH_2 ((uint16_t)0x0001) #define SDRAM_MODEREG_BURST_LENGTH_4 ((uint16_t)0x0002) #define SDRAM_MODEREG_BURST_LENGTH_8 ((uint16_t)0x0004) #define SDRAM_MODEREG_BURST_TYPE_SEQUENTIAL ((uint16_t)0x0000) #define SDRAM_MODEREG_BURST_TYPE_INTERLEAVED ((uint16_t)0x0008) #define SDRAM_MODEREG_CAS_LATENCY_2 ((uint16_t)0x0020) #define SDRAM_MODEREG_CAS_LATENCY_3 ((uint16_t)0x0030) #define SDRAM_MODEREG_OPERATING_MODE_STANDARD ((uint16_t)0x0000) #define SDRAM_MODEREG_WRITEBURST_MODE_PROGRAMMED ((uint16_t)0x0000) #define SDRAM_MODEREG_WRITEBURST_MODE_SINGLE ((uint16_t)0x0200) 关于FMC MODE部分在H750参考手册中可以找到 FMC_SDRAM_Command_Mode FMC SDRAM Command Mode #define FMC_SDRAM_CMD_NORMAL_MODE ((uint32_t)0x00000000U) #define FMC_SDRAM_CMD_CLK_ENABLE ((uint32_t)0x00000001U) #define FMC_SDRAM_CMD_PALL ((uint32_t)0x00000002U) #define FMC_SDRAM_CMD_AUTOREFRESH_MODE ((uint32_t)0x00000003U) #define FMC_SDRAM_CMD_LOAD_MODE ((uint32_t)0x00000004U) #define FMC_SDRAM_CMD_SELFREFRESH_MODE ((uint32_t)0x00000005U) #define FMC_SDRAM_CMD_POWERDOWN_MODE ((uint32_t)0x00000006U) SDRAM 结构体初始化,先配置SDRAM_HandleTypeDef hsdram1结构体(行列数,数据位数,时序等),GPIO 部分 SDRAM 初始化流程 就是配置FMC_SDRAM_CommandTypeDef Command结构体使用HAL_SDRAM_SendCommand(&sdramHandle, &Command, SDRAM_TIMEOUT);发送配置命令 static void SDRAM_InitSequence(void) { uint32_t tmpr = 0; /* Step 1 ----------------------------------------------------------------*/ /* 配置命令:开启提供给SDRAM的时钟 */ Command.CommandMode = FMC_SDRAM_CMD_CLK_ENABLE; Command.CommandTarget = FMC_COMMAND_TARGET_BANK; Command.AutoRefreshNumber = 1; Command.ModeRegisterDefinition = 0; /* 发送配置命令 */ HAL_SDRAM_SendCommand(&sdramHandle, &Command, SDRAM_TIMEOUT); /* Step 2: 延时100us */ SDRAM_delay(1); /* Step 3 ----------------------------------------------------------------*/ /* 配置命令:对所以bank预充电 */ Command.CommandMode = FMC_SDRAM_CMD_PALL; Command.CommandTarget = FMC_COMMAND_TARGET_BANK; Command.AutoRefreshNumber = 1; Command.ModeRegisterDefinition = 0; /* 发送配置命令*/ HAL_SDRAM_SendCommand(&sdramHandle, &Command, SDRAM_TIMEOUT); /* Step 4 ----------------------------------------------------------------*/ /*配置命令:自动刷新 */ Command.CommandMode = FMC_SDRAM_CMD_AUTOREFRESH_MODE; Command.CommandTarget = FMC_COMMAND_TARGET_BANK; Command.AutoRefreshNumber = 8; Command.ModeRegisterDefinition = 0; /* 发送配置命令 */ HAL_SDRAM_SendCommand(&sdramHandle, &Command, SDRAM_TIMEOUT); /* Step 5 ----------------------------------------------------------------*/ /* 配置SDRAM寄存器配置*/ tmpr = (uint32_t)SDRAM_MODEREG_BURST_LENGTH_1 | SDRAM_MODEREG_BURST_TYPE_SEQUENTIAL | SDRAM_MODEREG_CAS_LATENCY_3 | SDRAM_MODEREG_OPERATING_MODE_STANDARD | SDRAM_MODEREG_WRITEBURST_MODE_SINGLE; /*配置命令:设置SDRAM寄存器 */ Command.CommandMode = FMC_SDRAM_CMD_LOAD_MODE; Command.CommandTarget = FMC_COMMAND_TARGET_BANK; Command.AutoRefreshNumber = 1; Command.ModeRegisterDefinition = tmpr; /* 发送配置命令 */ HAL_SDRAM_SendCommand(&sdramHandle, &Command, SDRAM_TIMEOUT); /* Step 6 ----------------------------------------------------------------*/ /* 设置刷新计数器 */ /* 刷新周期=64ms/8192行=7.8125us */ /* COUNT=(7.8125us x Freq) - 20 */ /* 设置自刷新速率 */ HAL_SDRAM_ProgramRefreshRate(&sdramHandle, 824); } 相关函数 HAL_SDRAM_GetState(&hsdram1)//获取SDRAM标志 HAL_SDRAM_WriteProtection_Disable(&hsdram1);//禁止写保护 BANK的起始地址就在地址映射表中查得 总结:SDRAM 结构体,GPIO等配置时,比较繁琐,需要仔细配置,特别时GPIO部分,配置部分没问题之后,就是SDRAM的初始化,用发送命令的函数进行SDRAM初始化(类似于QSPI部分发送命令) SDRAM时序参数配置时,HAL库会有参数限制,实际配置完参数需要修改一下,不改参数,SDRAM测试没问题,但是LCD显示时候会出现问题,花屏,最后问题定位到SDRAM问题,就是时序参数不对,HAL库做了限制。 |
|
|
|
只有小组成员才能发言,加入小组>>
3278 浏览 9 评论
2956 浏览 16 评论
3458 浏览 1 评论
9000 浏览 16 评论
4051 浏览 18 评论
1110浏览 3评论
572浏览 2评论
const uint16_t Tab[10]={0}; const uint16_t *p; p = Tab;//报错是怎么回事?
569浏览 2评论
用NUC131单片机UART3作为打印口,但printf没有输出东西是什么原因?
2302浏览 2评论
NUC980DK61YC启动随机性出现Err-DDR是为什么?
1859浏览 2评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-24 20:21 , Processed in 1.176265 second(s), Total 81, Slave 61 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号