搜索
bottom↓
回复: 0

求教, GD32F350CBT6的QSPI, 没有预想的快

[复制链接]

出0入362汤圆

发表于 2021-6-22 15:10:37 | 显示全部楼层 |阅读模式
通过SFUD库, 读W25Q16, 调通了DMA读取, 其中读DMA函数如下:
  1. void SPI1_Read_DMA(void* buf, int count)
  2. {
  3.     dma_channel_disable(DMA_CH3);
  4.     dma_channel_disable(DMA_CH4);
  5.     DMA_CHCNT (DMA_CH3) = count;
  6.     DMA_CHCNT (DMA_CH4) = count;
  7.     DMA_CHMADDR (DMA_CH3) = (unsigned long)(buf);
  8.     dma_channel_enable(DMA_CH3);
  9.     dma_channel_enable(DMA_CH4);
  10.     spi_dma_enable(SPI1, SPI_DMA_TRANSMIT);
  11.     spi_dma_enable(SPI1, SPI_DMA_RECEIVE);
  12.     while(!dma_flag_get(DMA_CH3, DMA_FLAG_FTF));
  13.     dma_flag_clear(DMA_CH3, DMA_FLAG_FTF);
  14.     dma_flag_clear(DMA_CH4, DMA_FLAG_FTF);
  15. }
复制代码

实测主要耗时的就是    while(!dma_flag_get(DMA_CH3, DMA_FLAG_FTF)); 这一行.
不开QSPI时读8192字节数据, 用时142509个时钟周期, 平均17.5个时钟周期读1字节, 比较正常, SPI是主频2分频那就得至少16个周期了.

开QSPI时读8192字节居然还得109920个时钟周期, 平均13.5个时钟周期读1字节, 比预想的慢多了, 本来觉得应该是4~6个时钟周期读1字节的.

实拍SCK脚波形如下, 每两个脉冲之间有停顿:


现在不知道是我哪里没配置合适呢? 还是GD32F350的QSPI就这个水平? 要是硬件问题的话我也就不折腾了.

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

阿莫论坛20周年了!感谢大家的支持与爱护!!

如果想吃一顿饺子,就得从冰箱里取出肉,剁馅儿,倒面粉、揉面、醒面,擀成皮儿,下锅……
一整个繁琐流程,就是为了出锅时那一嘴滚烫流油的热饺子。

如果这个过程,禁不住饿,零食下肚了,饺子出锅时也就不香了……《非诚勿扰3》
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-3-29 00:03

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表