当前位置: 首页 > news >正文

STM32H723的SPI配置及简单使用!

最近移植工程,需要把F407的工程移植到H7系列中去,原先的工程SPI是直接操作寄存器去发送和接收与其它芯片通信!在移植到H7的工程里后,测试发现,SPI通信的出现问题,通过仿真调试和示波器测试信号(时钟和片选信号),最后发现卡在了判断接收的while判断上!

时钟树配置

 spi的时钟频率为183.3MHZ,2倍频后为91.6MHZ,4倍频为45.8MHZ

spi的代码配置

 在main.c中使用spi的相关库函数去接收和发送,进行验证!

HAL_GPIO_WritePin(GPIOB, GPIO_PIN_0, GPIO_PIN_RESET);//片选拉低
HAL_SPI_TransmitReceive(&hspi1,Txbuf_inv16,Rxbuf_inv16,4,1000);
HAL_GPIO_WritePin(GPIOB, GPIO_PIN_0, GPIO_PIN_SET);//片选拉高
delay(50);//延时50us

在main函数前定义的接收和发送数组,这里发送的是16位数据;

uint16_t Txbuf_inv16[4] = {0x0001,0x0002,0x0003,0x0004};//测试使用
uint16_t Rxbuf_inv16[4] = {0,0,0,0};

通过示波器采集的信号(片选和时钟)如下:总共花费2.6us左右时间!

 频率也为45MHZ,跟预期结果相符!

后面将SPI1的发送和接收修改成操作寄存器:

    HAL_GPIO_WritePin(GPIOB, GPIO_PIN_0, GPIO_PIN_RESET);  // CS低电平(有效)for (uint8_t s = 0; s < 4; s++) {//----------- 发送 -----------//while((SPI1->SR&1<<1)==0);                //等待发送区空*((__IO uint16_t *)&SPI1->TXDR) = Txbuf_inv16[s];	//----------- 接收 -----------//while((SPI1->SR&1<<0)==0);                //等待接收完Rxbuf_inv16[s] = *((__IO uint16_t *)&SPI1->RXDR);}HAL_GPIO_WritePin(GPIOB, GPIO_PIN_0, GPIO_PIN_SET);  // CS高电平(无效)delay(50);//延时50us

发现程序会卡在while((SPI1->SR&1<<0)==0);这一行,导致片选无法拉高,时钟信号没有!

先看一下SR寄存器(状态寄存器)的介绍:

 参考网上一些历程改为:

HAL_GPIO_WritePin(GPIOB, GPIO_PIN_0, GPIO_PIN_RESET);  // CS低电平(有效)
SPI1->CR1|=1<<0;                                //SPE=1,使能SPI1
SPI1->CR1|=1<<9;                                  //CSTART=1,启动传输for (uint8_t s = 0; s < 4; s++) {//----------- 发送 -----------//while((SPI1->SR&1<<1)==0);                //等待发送区空*((__IO uint16_t *)&SPI1->TXDR) = Txbuf_inv16[s];	//----------- 接收 -----------//while((SPI1->SR&1<<0)==0);                //等待接收完一个byte Rxbuf_inv16[s] = *((__IO uint16_t *)&SPI1->RXDR);SPI1->IFCR|=3<<3;                                //EOTC和TXTFC置1,清除EOT和TXTFC位    }SPI1->CR1&=~(1<<0);                   //SPE=0,关闭SPI1,会执行状态机复位/FIFO重置等操作HAL_GPIO_WritePin(GPIOB, GPIO_PIN_0, GPIO_PIN_SET);  // CS高电平(无效)
delay(50);

 发现可以执行,并且可以检测到信号!频率45MHZ,共花费3.28us时间!

 CR1寄存器(控制寄存器 1)

 IFCR(中断/状态标志清零寄存器)寄存器

 后面又将SPI改为2分频,也就是91MHZ,经过测试,库函数和寄存器操作,时钟频率都可以达到91MHZ,并且总共花费时间两者相差不大(1.7~1.8us)!

http://www.xdnf.cn/news/984367.html

相关文章:

  • 【轨物交流】云南科情院赴杭“取经”数字赋能 调研轨物科技探路创新驱动
  • Pip Manager本地Python包管理器
  • 蓝凌的低门槛、可扩展的可视化公式引擎
  • 路径=算法=操作:复杂系统行为的统一数学框架
  • vue防止按钮重复点击方案
  • 随记 minio的图片跨域问题
  • Spring | JDK 动态代理与 CGLIB 代理:原理、区别与实战对比
  • Docker部署minio
  • AIStor 的模型上下文协议 (MCP) 服务器:管理功能
  • 什么是 Solana 上的 MEV?一键狙击是如何保护你的代币启动的?
  • ANeko v1.0.3 | 在手机里养只宠物猫 实时互动 动画细腻
  • 递归,回溯,DFS,Floodfill,记忆化搜索
  • 三.Gitee远程操作标签操作
  • Java使用Selenium反爬虫优化方案
  • 力反馈手套:工业虚拟现实培训领域的革新者
  • [蓝桥杯 2024 国 Python B] 设计
  • Spring Security如何拿到登录用户的信息
  • 安卓9.0系统修改定制化____系列讲解导读篇
  • 【C/C++】怎样设计一个合理的函数
  • 咖啡豆缺陷检测:用YOLOv8+TensorFlow实现工业级质检系统
  • 临时抱佛脚v2
  • 费用流学习笔记
  • C++内存池:减少动态分配开销的高效解决方案
  • R语言缓释制剂QBD解决方案之二
  • 如何使用vue2设计提示框组件
  • 解决华为云服务器无法ping通github问题
  • Java NIO 面试全解析:9大核心考点与深度剖析
  • Langfuse 深度使用指南:构建可观测的LLM应用系统
  • 蓝桥杯刷题
  • 腾讯位置商业授权危险地点查询开发指南