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

做美工的网站seo点击器

做美工的网站,seo点击器,移动网站性能,wordpress下滑显示导航导言 如上所示,在[[STM32F103_HAL库寄存器学习笔记19 - CAN发送中断CAN接收中断接收所有CAN报文ringbuffer数据结构]]的基础上,为CAN发送端也引入了ringbuffer(环形缓冲区)机制。CAN发送有三个发送邮箱,为什么还另外需…

导言


在这里插入图片描述
如上所示,在[[STM32F103_HAL库+寄存器学习笔记19 - CAN发送中断+CAN接收中断+接收所有CAN报文+ringbuffer数据结构]]的基础上,为CAN发送端也引入了ringbuffer(环形缓冲区)机制。CAN发送有三个发送邮箱,为什么还另外需要ringbuffer?

  1. 三邮箱限制:STM32F103 的 CAN 控制器只有三个发送邮箱,当应用层在短时间内产生超过3条待发帧时,多余的帧无法立即写入邮箱,只能被丢弃或阻塞等待(阻塞更可靠,但可能降低响应速度)。
  2. 突发流量平滑:环形缓冲区可以暂存超出邮箱数的那些帧,在邮箱空闲时再依次发送,避免丢帧。
  3. 解耦业务与硬件:应用层只需往环形缓冲区写入数据,不用关心底层邮箱是否空闲,降低了发送接口的耦合度。

总结来说,在CAN发送链路中引入ringbuffer,能有效解决上述问题,尤其是邮箱数量限制和突发流量平滑问题。

项目地址:
github:

  • HAL库: https://github.com/q164129345/MCU_Develop/tree/main/stm32f103_hal_library20_Can_Send_Rec_With_RB
  • 寄存器方式: https://github.com/q164129345/MCU_Develop/tree/main/stm32f103_ll_library20_Can_Send_Rec_With_RB
    gitee(国内):
  • HAL库: https://gitee.com/wallace89/MCU_Develop/tree/main/stm32f103_hal_library20_Can_Send_Rec_With_RB
  • 寄存器方式: https://gitee.com/wallace89/MCU_Develop/tree/main/stm32f103_ll_library20_Can_Send_Rec_With_RB

使用for循环一口气发送50条CAN报文

为验证ringbuffer对“三邮箱限制”和“突发流量平滑”问题的缓解效果。在主循环里调用for循环,一口气发送50条CAN报文,看看效果!
在这里插入图片描述
在这里插入图片描述
如上所示:

  1. 在debug模式里,将对应的全局变量置1,就可以运行对应的测试函数。

测试一口气发送50条CAN报文,没有ringbuffer

在这里插入图片描述
如图所示,将全局变量 test 置为1,运行函数 CAN_Test_Send50Frames() 连续发送50条报文。结果显示,CAN分析仪仅接收到3条报文。原因很简单,另外47条报文因为发送邮箱挤满了,所以都溢出了。

测试一口气发送50条CAN报文,有ringbuffer

在这里插入图片描述
如上所示,将全局变量testRB置1,运行函数CAN_Test_Send50Frames_Use_Ringbuffer()一口气发送50条报文。接着,CAN分析仪接收到50条报文。实践证明,ringbuffer作为二级缓存能有效解决突发高流量问题与三个邮箱的局限性问题。

一、代码(HAL库)


1.1、myCanDrive.c

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

1.2、stm32f1xx_it.c

在这里插入图片描述

1.3、main.c

在这里插入图片描述
在这里插入图片描述

1.4、代码编译

在这里插入图片描述

二、代码(寄存器方式)


1.1、myCanDrive_reg.c

在这里插入图片描述
如上所示,RX Ringbuffer与TX Ringbuffer都是二级缓存。
在这里插入图片描述
在这里插入图片描述
如上所示,这两个函数基本跟HAL库一样,只是开与关中断的函数改为寄存器方式直接操作。
在这里插入图片描述
如上所示,在CAN发送完成中断函数USB_HP_CAN1_TX_IRQHandler()里调用函数CAN_Get_CANMsg_From_RB_To_TXMailBox_IT(),在中断里将ringbuffer里的CAN报文放入空闲的发送邮箱。

1.2、main.c

在这里插入图片描述
在这里插入图片描述

1.3、代码编译

在这里插入图片描述

1.4、测试

在这里插入图片描述
如上所示,测试结果跟HAL库一样。

http://www.dtcms.com/wzjs/8749.html

相关文章:

  • 平价网站平价网站建设建设成都计算机培训机构排名前十
  • 怎么上传网站图片的链接快推广app下载
  • 海南专业网站建设定制怎么制作网站教程
  • 东营网站制作搜索引擎营销与seo优化
  • wordpress 播客网站百度发视频步骤
  • 手机网站数据加载软件开发网
  • 衡水网站建设找谁建立网站平台需要多少钱
  • 棋牌游戏网站开发百度人工客服
  • wordpress官网打不开网络优化的流程
  • 外贸建站模板下载汽车网站建设
  • 的wordpress主机名知乎关键词优化软件
  • 顺德做网站公司哪家好广州 竞价托管
  • 科技流小说aso具体优化
  • 网站备案号 如何添加平台推广广告宣传词
  • 动态网站建设常用技术不包括查看网站流量的工具
  • 宿迁建站网电商网站订烟平台官网
  • 企业网站建设需求广告推送平台
  • 餐饮公司网站模板如何让新网站被收录
  • wordpress 在线文章插件seo顾问服务福建
  • 北京城乡和住房建设委员会网站关键词排名优化公司
  • 有私人做网站的吗网站推广策划书
  • 网站排名靠前怎么做口碑最好的it培训机构
  • 网站的标题与关键词搜云seo
  • 网站建设seo优化推广网站推广120种方法
  • 哪个网站建设好台州seo排名公司
  • 网站做搜索引擎的作用是什么百度答主招募入口官网
  • 做外单要上什么网站网络营销计划的七个步骤
  • 行业 专业 网站建设百度客服24小时人工服务
  • 响应式网站好么搜索引擎推广的优势
  • wordpress4.5.2主题seo优化方案报价