专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
STM32
使用STM32H743II FMC访问外部SRAM时序问题
2020-01-07 19:19
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
STM32/STM8
6181
9
9
本帖最后由 jjj 于 2019-6-5 16:43 编辑
我使用STM32H743II FMC访问外部SRAM,发现一个写操作(*p_fram++=i)出现4个写时序,数据也能写进去,也能正确读出来,但是就是不知道为什么。程序如下:
微信图片_20190605162841.jpg
(271.95 KB, 下载次数: 0)
下载附件
2019-6-5 16:43 上传
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
8条回答
cht-rtos
1楼-- · 2020-01-08 01:15
配置成了按字节访问了吧,然后指针类型又是4字节的
加载中...
smaret
2楼-- · 2020-01-08 15:28
搞好了, 需要配置MPU
//MPU related define
#define FPGA_ADDRESS_START (0x60000000UL)
#define FPGA_SIZE MPU_REGION_SIZE_64MB
#define FPGA_REGION_NUMBER MPU_REGION_NUMBER0
#define FPGA_ACCESS_PERMISSION MPU_REGION_FULL_ACCESS
void MPU_Config(void)
{
MPU_Region_InitTypeDef MPU_InitStruct;
/* Disable MPU */
HAL_MPU_Disable();
/* Configure FPGA region as Region N?, 64MB of size and R/W region */
MPU_InitStruct.Enable = MPU_REGION_ENABLE;
MPU_InitStruct.BaseAddress = FPGA_ADDRESS_START;
MPU_InitStruct.Size = FPGA_SIZE;
MPU_InitStruct.AccessPermission = FPGA_ACCESS_PERMISSION;
MPU_InitStruct.IsBufferable = MPU_ACCESS_NOT_BUFFERABLE;
MPU_InitStruct.IsCacheable = MPU_ACCESS_NOT_CACHEABLE;
MPU_InitStruct.IsShareable = MPU_ACCESS_NOT_SHAREABLE;
MPU_InitStruct.Number = FPGA_REGION_NUMBER;
MPU_InitStruct.TypeExtField = MPU_TEX_LEVEL0;
MPU_InitStruct.SubRegionDisable = 0x00;
MPU_InitStruct.DisableExec = MPU_INSTRUCTION_ACCESS_DISABLE;
HAL_MPU_ConfigRegion(&MPU_InitStruct);
/* Enable MPU */
HAL_MPU_Enable(MPU_PRIVILEGED_DEFAULT);
}
加载中...
jjj
3楼-- · 2020-01-07 20:10
感觉很奇怪,一个写操作不是1个写时序就搞定 了吗,怎么实际是4个写写周期。
加载中...
jjj
4楼-- · 2020-01-08 04:33
本帖最后由 jjj 于 2019-6-6 08:17 编辑
应该不是,就算配置成了按字节访问, 我这是写进去16bit数据,分2次也能写完呀
加载中...
lingdianhao
5楼-- · 2020-01-08 08:33
可能是非对齐访问。
加载中...
jjj
6楼-- · 2020-01-08 09:23
精彩回答 2 元偷偷看……
加载中...
1
2
下一页
一周热门
更多
>
相关问题
STM32F4上I2C(在PROTEUS中模拟)调试不通的问题
6 个回答
芯片供应紧张,准备换个MCU,MM32L系列替换STM32L系列的怎么样?
7 个回答
STM32同时使用两个串口进行数据收发时数据丢包的问题
5 个回答
STM32F103串口通信死机问题
4 个回答
STM32WLE5CC连接SX1268在LoRa模式下能与 SX1278互通吗?
2 个回答
STM32开发板免费用活动
7 个回答
stm32 处理 DHT11占用太多时间,大家程序是怎么设计的
8 个回答
分享一个STM32单片机做的离线编程器代码
9 个回答
相关文章
ST公司第一款无线低功耗单片机模块有效提高物联网设计生产效率
0个评论
如何实现对单片机寄存器的访问
0个评论
通过USB用STM32片内自带Bootloader下载程序及注意事项
0个评论
欲练此功必先自宫之STM32汇编启动,放慢是为了更好的前行
0个评论
×
关闭
采纳回答
向帮助了您的网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
STM32
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
关闭
您已邀请
15
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
//MPU related define
#define FPGA_ADDRESS_START (0x60000000UL)
#define FPGA_SIZE MPU_REGION_SIZE_64MB
#define FPGA_REGION_NUMBER MPU_REGION_NUMBER0
#define FPGA_ACCESS_PERMISSION MPU_REGION_FULL_ACCESS
void MPU_Config(void)
{
MPU_Region_InitTypeDef MPU_InitStruct;
/* Disable MPU */
HAL_MPU_Disable();
/* Configure FPGA region as Region N?, 64MB of size and R/W region */
MPU_InitStruct.Enable = MPU_REGION_ENABLE;
MPU_InitStruct.BaseAddress = FPGA_ADDRESS_START;
MPU_InitStruct.Size = FPGA_SIZE;
MPU_InitStruct.AccessPermission = FPGA_ACCESS_PERMISSION;
MPU_InitStruct.IsBufferable = MPU_ACCESS_NOT_BUFFERABLE;
MPU_InitStruct.IsCacheable = MPU_ACCESS_NOT_CACHEABLE;
MPU_InitStruct.IsShareable = MPU_ACCESS_NOT_SHAREABLE;
MPU_InitStruct.Number = FPGA_REGION_NUMBER;
MPU_InitStruct.TypeExtField = MPU_TEX_LEVEL0;
MPU_InitStruct.SubRegionDisable = 0x00;
MPU_InitStruct.DisableExec = MPU_INSTRUCTION_ACCESS_DISABLE;
HAL_MPU_ConfigRegion(&MPU_InitStruct);
/* Enable MPU */
HAL_MPU_Enable(MPU_PRIVILEGED_DEFAULT);
}
应该不是,就算配置成了按字节访问, 我这是写进去16bit数据,分2次也能写完呀
一周热门 更多>