完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
|
我正在为 STM32H7A3 上的 HyperRAM 和内存映射模式写入中的 OctoSPI2 苦苦挣扎。
为了检查对 HyperRAM 的访问是否正常,我正在运行一个循环,将所有 0 / 0x55555555 / 0xAAAAAAAA(具有 32 位访问权限)写入 RAM,然后测试是否正常。在调试器内存转储中,我看到大多数字都写得很好,但几乎经常在 256 字节块的最后 4 个字节上并不总是写入数据。 信号看起来不错。我尝试降低时钟频率、更改时序参数等,但都没有成功。 有没有人知道什么可能是错的? void MX_OCTOSPI2_Init(void) { /* 用户代码开始 OCTOSPI2_Init 0 */ /* 用户代码结束 OCTOSPI2_Init 0 */ OSPIM_CfgTypeDef sOspiManagerCfg = {0}; OSPI_HyperbusCfgTypeDef sHyperBusCfg = {0}; /* 用户代码开始 OCTOSPI2_Init 1 */ // 24 = 设备 16 兆字节大小 // // 预分频器: // 3 = 93 兆赫 // 4 = 70 兆赫! // 5 = 56 兆赫 // 8 = 35 兆赫 // 16 = 17.5 兆赫 // // /* 用户代码结束 OCTOSPI2_Init 1 */ hospi2.Instance = OCTOSPI2; hospi2.Init.FifoThreshold = 4; hospi2.Init.DualQuad = HAL_OSPI_DUALQUAD_DISABLE; hospi2.Init.MemoryType = HAL_OSPI_MEMTYPE_HYPERBUS; hospi2.Init.DeviceSize = 24; hospi2.Init.ChipSelectHightime = 1; hospi2.Init.FreeRunningClock = HAL_OSPI_FREERUNCLK_DISABLE; hospi2.Init.ClockMode = HAL_OSPI_CLOCK_MODE_0; hospi2.Init.WrapSize = HAL_OSPI_WRAP_NOT_SUPPORTED; hospi2.Init.ClockPrescaler = 5; hospi2.Init.SampleShifting = HAL_OSPI_SAMPLE_SHIFTING_NONE; hospi2.Init.DelayHoldQuarterCycle = HAL_OSPI_DHQC_ENABLE; hospi2.Init.ChipSelectBoundary = 23; /* 内存管芯边界 2^23=8MBs*/ hospi2.Init.DelayBlockBypass = HAL_OSPI_DELAY_BLOCK_USED; hospi2.Init.MaxTran = 0; hospi2.Init.Refresh = 200; 如果 (HAL_OSPI_Init(&hospi2) != HAL_OK) { 错误处理程序(); } sOspiManagerCfg.ClkPort = 2; sOspiManagerCfg.DQSPort = 2; sOspiManagerCfg.NCSPort = 2; sOspiManagerCfg.IOLowPort = HAL_OSPIM_IOPORT_2_LOW; sOspiManagerCfg.IOHighPort = HAL_OSPIM_IOPORT_2_HIGH; sOspiManagerCfg.Req2AckTime = 1; 如果 (HAL_OSPIM_Config(&hospi2, &sOspiManagerCfg, HAL_OSPI_TIMEOUT_DEFAULT_VALUE) != HAL_OK) { 错误处理程序(); } sHyperBusCfg.RWRecoveryTime = 3; sHyperBusCfg.AccessTime = 6; sHyperBusCfg.WriteZeroLatency = HAL_OSPI_LATENCY_ON_WRITE; sHyperBusCfg.LatencyMode = HAL_OSPI_FIXED_LATENCY; 如果 (HAL_OSPI_HyperbusCfg(&hospi2, &sHyperBusCfg, HAL_OSPI_TIMEOUT_DEFAULT_VALUE) != HAL_OK) { 错误处理程序(); } S70KL1281_EnableMemoryMappedMode(&hospi2); } int32_t S70KL1281_EnableMemoryMappedMode(OSPI_HandleTypeDef *Ctx) { OSPI_HyperbusCmdTypeDef sCommand; OSPI_MemoryMappedTypeDef sMemMappedCfg; /* OctoSPI Hyperbus 命令配置 */ sCommand.AddressSpace = HAL_OSPI_MEMORY_ADDRESS_SPACE; sCommand.AddressSize = HAL_OSPI_ADDRESS_32_BITS; sCommand.Address = 0; sCommand.DQSMode = HAL_OSPI_DQS_ENABLE; sCommand.NbData = 1; 如果 (HAL_OSPI_HyperbusCmd(Ctx, &sCommand, HAL_OSPI_TIMEOUT_DEFAULT_VALUE) != HAL_OK) { 返回 S70KL1281_ERROR; } /* OctoSPI 激活内存映射模式 */ sMemMappedCfg.TimeOutActivation = HAL_OSPI_TIMEOUT_COUNTER_DISABLE; 如果 (HAL_OSPI_MemoryMapped(Ctx, &sMemMappedCfg) != HAL_OK) { 返回 S70KL1281_ERROR; } 返回 S70KL1281_OK; } |
|
相关推荐
1个回答
|
|
|
|
|
|
|
|
只有小组成员才能发言,加入小组>>
stm32mp157的异核通信的rpmsg_sdb的m4固件和a7驱动该如何编写?
1453 浏览 0 评论
stm32f103用freertos对一个采样率为1kHz的传感器,进行采样,数据出差
1502 浏览 0 评论
请教:在使用UDE STK时,单片机使用SPC560D30L1,在配置文件怎么设置或选择?里面只有SPC560D40的选项
3649 浏览 1 评论
3842 浏览 1 评论
请问是否有通过UART连接的两个微处理器之间实现双向值交换的方法?
2461 浏览 1 评论
STM32H7打开DCache后,出现了串口接收信息为空的现象,是哪里出了问题?
727浏览 5评论
用NANO STM32F103RBT6的开发板烧录不了是哪里出了问题?
661浏览 5评论
710浏览 5评论
外部中断触发类型为双边沿触发,进入中断回调后有什么办法判断该边沿是上升沿还是下降沿?
941浏览 5评论
STM32L071CBT6低温环境下无法正常工作是什么原因引起的?
745浏览 5评论
/9
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-12-1 22:53 , Processed in 0.536926 second(s), Total 42, Slave 35 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191

淘帖
265