21ic问答首页 - 紧急 !怎么缩短STM32H743 FMC 连续两次读PSRAM的时间间隔?
紧急 !怎么缩短STM32H743 FMC 连续两次读PSRAM的时间间隔?
STM32H743 通过FMC 与FPGA通讯。设计成PSRAM,地址数据复用模式,16bit宽度。连续两次读操作时间间隔最小约130ns,与地址建立时间,地址保持时间,数据保持时间无关。而连续两次写操作时间间隔最小约10ns。请问怎么缩小两次读操作的时间间隔?
旺五行属什么 | 低钾血症吃什么药 | 上嘴唇发黑是什么原因 | 什么旺水命 | 内能与什么因素有关 |
衣服38码相当于什么码 | 梦到车坏了是什么意思 | 尿培养是检查什么病 | 99新是什么意思 | 方寸之地什么意思 |
男人是女人的什么 | 甜字五行属什么 | 三个毛念什么 | 什么叫水印 | 脾虚吃什么药效果最好 |
牙龈发炎吃什么消炎药 | 黄瓜和青瓜有什么区别 | 做生化是检查什么的 | 脑出血有什么后遗症 | 吃火龙果有什么好处和坏处 |
子不问卜自惹祸殃什么意思hcv9jop4ns5r.cn | 1979是什么年jasonfriends.com | 平仓什么意思1949doufunao.com | 擦汗表情是什么意思hcv9jop2ns1r.cn | 存脐带血有什么用hcv9jop4ns2r.cn |
b长什么样hcv8jop7ns4r.cn | 三八妇女节送老婆什么礼物好hcv9jop5ns0r.cn | 双顶径是指什么hcv8jop8ns4r.cn | 身上起火疖子什么原因hcv8jop6ns7r.cn | 焯是什么意思hcv8jop8ns7r.cn |
主动脉壁钙化是什么意思hcv8jop9ns4r.cn | 微量元素是什么hcv9jop5ns3r.cn | 乙肝核心抗体阳性说明什么hcv8jop6ns4r.cn | 前列腺炎吃什么药最好hcv9jop3ns8r.cn | 眼镜片什么材质的好hcv9jop5ns1r.cn |
挑担是什么关系hcv8jop9ns4r.cn | 与世隔绝的绝是什么意思hcv8jop4ns9r.cn | 敖是什么意思hcv7jop9ns9r.cn | edo是什么意思inbungee.com | 什么是比值hcv8jop9ns3r.cn |
赞0
DMA_HandleTypeDef hdma;
void DMA_Config() {
// 使能DMA时钟
__HAL_RCC_DMA1_CLK_ENABLE();
// 配置DMA
hdma.Instance = DMA1_Stream0;
// hdma.Init.Channel = DMA_CHANNEL_0;
hdma.Init.Direction = DMA_MEMORY_TO_MEMORY;
hdma.Init.PeriphInc = DMA_PINC_ENABLE;
hdma.Init.MemInc = DMA_MINC_ENABLE;
hdma.Init.PeriphDataAlignment = DMA_PDATAALIGN_HALFWORD;
hdma.Init.MemDataAlignment = DMA_PDATAALIGN_HALFWORD;
hdma.Init.Mode = DMA_NORMAL;
hdma.Init.Priority = DMA_PRIORITY_HIGH;
HAL_DMA_Init(&hdma);
}
void DMA_Transfer(uint32_t srcAddr, uint32_t destAddr, uint32_t dataSize) {
// 启动DMA传输
HAL_DMA_Start(&hdma, srcAddr, destAddr, dataSize);
}
void MX_FMC_Init(void)
{
/* USER CODE BEGIN FMC_Init 0 */
/* USER CODE END FMC_Init 0 */
FMC_NORSRAM_TimingTypeDef Timing = {0};
/* USER CODE BEGIN FMC_Init 1 */
/* USER CODE END FMC_Init 1 */
/** Perform the SRAM1 memory initialization sequence
*/
hsram1.Instance = FMC_NORSRAM_DEVICE;
hsram1.Extended = FMC_NORSRAM_EXTENDED_DEVICE;
/* hsram1.Init */
hsram1.Init.NSBank = FMC_NORSRAM_BANK1;
hsram1.Init.DataAddressMux = FMC_DATA_ADDRESS_MUX_ENABLE;
hsram1.Init.MemoryType = FMC_MEMORY_TYPE_NOR;
hsram1.Init.MemoryDataWidth = FMC_NORSRAM_MEM_BUS_WIDTH_32;
hsram1.Init.BurstAccessMode = FMC_BURST_ACCESS_MODE_DISABLE;
hsram1.Init.WaitSignalPolarity = FMC_WAIT_SIGNAL_POLARITY_LOW;
hsram1.Init.WaitSignalActive = FMC_WAIT_TIMING_BEFORE_WS;
hsram1.Init.WriteOperation = FMC_WRITE_OPERATION_ENABLE;
hsram1.Init.WaitSignal = FMC_WAIT_SIGNAL_DISABLE;
hsram1.Init.ExtendedMode = FMC_EXTENDED_MODE_DISABLE;
hsram1.Init.AsynchronousWait = FMC_ASYNCHRONOUS_WAIT_DISABLE;
hsram1.Init.WriteBurst = FMC_WRITE_BURST_DISABLE;
hsram1.Init.ContinuousClock = FMC_CONTINUOUS_CLOCK_SYNC_ONLY;
hsram1.Init.WriteFifo = FMC_WRITE_FIFO_DISABLE;
hsram1.Init.PageSize = FMC_PAGE_SIZE_NONE;
/* Timing */
Timing.AddressSetupTime = 4; /* 地址建立时间 范围0 -15个FMC时钟周期个数*/
Timing.AddressHoldTime = 2; /* 地址保持时间,配置为模式A时,用不到此参数 范围1 -15个时钟周期个数 */
Timing.DataSetupTime = 44; /* 数据保持时间,范围1 -255个时钟周期个数 */
Timing.BusTurnAroundDuration = 1;
Timing.CLKDivision = 1;
Timing.DataLatency = 2;
Timing.AccessMode = FMC_ACCESS_MODE_A;
/* ExtTiming */
if (HAL_SRAM_Init(&hsram1, &Timing, NULL) != HAL_OK)
{
Error_Handler( );
}
/* USER CODE BEGIN FMC_Init 2 */
/* USER CODE END FMC_Init 2 */
}
评论
2025-08-04
赞0
参考普通DMA示例,使用内存到内存方式,其中1个地址为FMC所在地址即可,并不需要特殊介绍。
H7的FMC应该没有多主访问冲突的问题了,你最好也看下勘误手册,看看有没FMC相关的注意事项。
评论
2025-08-04
赞0
评论
2025-08-04
赞0
因为读的时候需要目标返回结果后才能进行下一次操作。
这个延迟是不可避免的。你看看是否可以使用连续读来增加吞吐量。
而写的话,只要把指令发出去,CPU就可以进行下一步了。
评论
2025-08-04
虽然在外部信号已经返回,但进入CPU内部还需要时间。
一次完整的读操作,数据已经返回了。NE1和nOE都变成高电平了。所以不是数据延迟返回造成的。
赞0
评论
2025-08-04
赞0
评论
2025-08-04
@zchong :时间消耗在两次读之间。一次读操作时间跟参数设置的时间一样。难道读操作,需要更多的操作代码?如果是这样的话,用DMA应该可以解决。因为DMA是硬件完成的。
@阿尔法99 :可以同步测量观察一下片选和读信号
@阿尔法99 :可以同步测量一下片选和读信号,观察耗时在何处
@阿尔法99 :可以再同步测量一下片选、读信号,看看时间具体消耗在了什么地方
@阿尔法99 :可以再同步测量一下片选、读信号,看看时间具体消耗在了什么地方
我同样的连续写操作,相邻两次写的时间间隔就很小,才10几个ns。写和读都是对地址指针操作。而且还没用到for循环。网上搜索了一下,以前有人也遇到这样的问题,不知道他怎么解决的。下一步我准备用DMA操作一下。
赞0
评论
2025-08-04
赞0
评论
2025-08-04
赞0
FPGA抓的波形。
评论
2025-08-04
您需要登录后才可以回复 登录 | 注册