STM32的SPI速度怎么这么慢?

2019-12-14 13:23发布

本帖最后由 prince2010 于 2018-12-6 10:08 编辑

代码如下——

        SPI1_CS0_Enable();
        for(i = 0; i < 1000; i++)
        {
            SPI1->DR = DataIn;
            while(!(SPI1->SR & SPI_I2S_FLAG_RXNE)); //等待一个字节接收完
            DataOut = SPI1->DR;  //返回SPI1接收的数据
        }
        SPI1_CS0_Disable();

系统时钟72MHz,可是用示波器观察,循环体就这么几句代码,字节间发送间隔竟然达到1us!!!

大家帮忙看看

补充:以下是SPI 时钟引脚的波形。


友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
26条回答
wuha
1楼-- · 2019-12-14 17:41
你用的是硬件SPI?那得看你是如何配置速率的,比如时钟,分频等。
huarana
2楼-- · 2019-12-14 19:40
 精彩回答 2  元偷偷看……
prince2010
3楼-- · 2019-12-15 00:10
wuha 发表于 2018-12-6 09:33
你用的是硬件SPI?那得看你是如何配置速率的,比如时钟,分频等。

是36MHz——

    SPI_InitStructure.SPI_Direction = SPI_Direction_2Lines_FullDuplex;  //设置SPI单向或者双向的数据模式:SPI设置为双线双向全双工
    SPI_InitStructure.SPI_Mode = SPI_Mode_Master;       //设置SPI工作模式:设置为主SPI
    SPI_InitStructure.SPI_DataSize = SPI_DataSize_8b;       //设置SPI的数据大小:SPI发送接收8位帧结构
    SPI_InitStructure.SPI_CPOL = SPI_CPOL_Low;     //选择了串行时钟的稳态:时钟悬空高  1
    SPI_InitStructure.SPI_CPHA = SPI_CPHA_1Edge;    //数据捕获于第1个时钟沿           0
    SPI_InitStructure.SPI_NSS = SPI_NSS_Soft;       //NSS信号由硬件(NSS管脚)还是软件(使用SSI位)管理:内部NSS信号有SSI位控制
    SPI_InitStructure.SPI_BaudRatePrescaler = SPI_BaudRatePrescaler_2;        //定义波特率预分频的值:波特率预分频值为16
    SPI_InitStructure.SPI_FirstBit = SPI_FirstBit_MSB;  //指定数据传输从MSB位还是LSB位开始:数据传输从MSB位开始
    SPI_InitStructure.SPI_CRCPolynomial = 7;    //CRC值计算的多项式
    SPI_Init(SPI1, &SPI_InitStructure);  //根据SPI_InitStruct中指定的参数初始化外设SPIx寄存器
wshtyr
4楼-- · 2019-12-15 03:14
LZ试试这个。。

  1. int txcnt, rxcnt;
  2. uint32_t sr;
  3. SPI1_CS0_Enable();
  4. txcnt = SPI1->DR;//空读
  5. txcnt = rxcnt = 0;
  6. while(1)
  7. {
  8.     sr = SPI1->SR;
  9.     if(sr & SPI_I2S_FLAG_TXE)
  10.     {
  11.         if(txcnt < 1000)
  12.             SPI1->DR = DataIn[txcnt++];
  13.     }
  14.     if(sr & SPI_I2S_FLAG_RXNE)
  15.     {
  16.         if(rxcnt < 1000)
  17.             DataOut[rxcnt++] = SPI1->DR;
  18.     }
  19.     if(rxcnt >= 1000 && txcnt >= 1000)
  20.     {
  21.         break;
  22.     }
  23. }
  24. SPI1_CS0_Disable();
复制代码
aammoo
5楼-- · 2019-12-15 03:20
想快就用DMA,这个波形是连续的
cloudboy
6楼-- · 2019-12-15 05:02
楼主不用奇怪,把反汇编打开来看看,再看看优化等级,另外一些总线寄存器访问并不是单、双周期的,可能要等很久,再另外程序在flash上面跑并不是全速的,反正存在各种可能的原因

一周热门 更多>