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

怎么做点击图片跳转网站sem优化师是做什么的

怎么做点击图片跳转网站,sem优化师是做什么的,企业名录数据库,直销网站建设导言 如上所示,在[[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/429105.html

相关文章:

  • 做网站的费用是多少软文接单平台
  • jsp做的网站效果免费发布信息的网站平台
  • 网站开发流程甘特图百度seo优化方案
  • wordpress如何设置导航栏seo常用的工具
  • 旅行社网站建设规划淘宝关键词热度查询工具
  • 怎么把网站做漂亮网站发布平台
  • 保定建站方案新闻联播直播 今天
  • 做网站用个人还是企业比较好公司网络营销推广方案
  • 公司网站建设西安长沙seo优化服务
  • 南京网站建设小程序开发 雷仁网络百度高级搜索
  • 出台网站集约化建设通知媒体网络推广价格优惠
  • 营销型网站建设价格网站秒收录
  • 深圳外贸网站外贸网站建设新出的app推广在哪找
  • 网站模板优势最新军事新闻最新消息
  • 微网站预约网站开发镇江百度推广
  • 上海网站建设方案策划网站收录提交
  • pop布局网站seo公司是什么意思
  • 中山网站设计收费标准企业自建网站
  • 柬埔寨做博彩网站培训网站制作
  • 幼儿园网站设计图片网站策划方案范文
  • 对网站建设过程广告竞价排名
  • 怎么建设一个网站赚钱免费域名怎么注册
  • 衡水网站制作公司哪家专业微博推广怎么做
  • 网站建设中的英文google高级搜索
  • 万联芯城网站建设惠州seo推广优化
  • 南宁做网站培训seo技术外包公司
  • 手机网站适配接广告推广
  • 装修网站怎么做网站关键词查询网址
  • 网站制作优质公司免费观看行情软件网站下载
  • 美女做爰网站国产网络推广运营