使用STM32H743II FMC访问外部SRAM时序问题

2020-01-07 19:19发布

本帖最后由 jjj 于 2019-6-5 16:43 编辑

我使用STM32H743II FMC访问外部SRAM,发现一个写操作(*p_fram++=i)出现4个写时序,数据也能写进去,也能正确读出来,但是就是不知道为什么。程序如下:
微信图片_20190605162841.jpg (271.95 KB, 下载次数: 0) 下载附件 2019-6-5 16:43 上传
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
9条回答
smaret
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);
}

一周热门 更多>