完善资料让更多小伙伴认识你,还能领取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库做了限制。 |
|
|
|
只有小组成员才能发言,加入小组>>
imx6ull 和 lan8742 工作起来不正常, ping 老是丢包
2461 浏览 0 评论
3341 浏览 9 评论
3022 浏览 16 评论
3514 浏览 1 评论
9118 浏览 16 评论
1243浏览 3评论
636浏览 2评论
const uint16_t Tab[10]={0}; const uint16_t *p; p = Tab;//报错是怎么回事?
627浏览 2评论
用NUC131单片机UART3作为打印口,但printf没有输出东西是什么原因?
2373浏览 2评论
NUC980DK61YC启动随机性出现Err-DDR是为什么?
1936浏览 2评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-1-24 05:03 , Processed in 0.954275 second(s), Total 47, Slave 38 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号