STM32 SPI DMA 与 I2C DMA 冲突

现象为直接操作I2C DMA模式读写EEPROM数据正常,一旦进行一次SPI1 DMA传输后,EEPROM读写失败,示波器查看没有I2C数据部分波形。

 

分析发现EEPROM使用I2C3,I2C3的接收通道与SPI1的发送通道公用DMA1通道的通道3。但在DMA驱动中已加入互斥操作,逻辑上这样操作是没有问题的。

 

解决:DMA通道是多个外设公用的,比如I2C3的接收与SPI1的发送公用DMA1_CH3。在每个外设中会有独立的DMA通道开关,需要使用是打开,使用结束后需要关闭,否则会影响其他外设。上述问题原因就是因为使用SPI1 DMA传输后,没有关闭SPI1的DMA开关,从而影响到I2C无法接收数据。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
STM32 SPI DMA功能可以提高SPI通信的效率,减少CPU的占用率。具体实现步骤如下: 1. 配置SPI外设的寄存器,包括SPI控制寄存器CR1和CR2、数据帧结构寄存器DSR、数据寄存器DR等。 2. 配置DMA外设的寄存器,包括DMA控制寄存器DMA_CR、DMA通道配置寄存器DMA_CCR等。 3. 配置DMA传输的源地址和目的地址。 4. 开启SPIDMA传输功能。 5. 等待DMA传输完成。 下面是一个简单的SPI DMA发送数据的例子: ```c uint8_t data[10] = {0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A}; uint8_t buffer[10]; // 配置SPIDMA传输 SPI1->CR2 |= SPI_CR2_TXDMAEN; DMA1_Channel3->CCR |= DMA_CCR_DIR | DMA_CCR_MINC | DMA_CCR_TCIE; DMA1_Channel3->CPAR = (uint32_t)&(SPI1->DR); DMA1_Channel3->CMAR = (uint32_t)data; DMA1_Channel3->CNDTR = 10; // 启动DMA传输 DMA1_Channel3->CCR |= DMA_CCR_EN; // 等待DMA传输完成 while((DMA1->ISR & DMA_ISR_TCIF3) == 0); // 读取数据 for(int i=0; i<10; i++) { buffer[i] = SPI1->DR; } ``` 这个例子中,我们通过SPI1发送了10个字节的数据,并通过DMA1的通道3实现了DMA传输。具体步骤如下: 1. 配置SPI1的控制寄存器CR2,使能DMA传输功能。 2. 配置DMA1的通道3,使能传输方向为“从内存到外设”、开启内存递增模式、开启传输完成中断。 3. 配置DMA1的通道3的源地址为data数组首地址,目的地址为SPI1的数据寄存器DR地址,传输数据长度为10个字节。 4. 启动DMA1的通道3传输。 5. 等待DMA传输完成。 6. 读取SPI1的数据寄存器DR中的数据到buffer数组中。 需要注意的是,以上代码仅是SPI DMA传输的一个简单示例,具体实现还需要根据实际应用场景进行相应的调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

stone8761

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值