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

没有域名 有公网ip 建网站可以asp做网站计数器

没有域名 有公网ip 建网站可以,asp做网站计数器,网站 后台 设计,3d建模有前途吗导言 如上所示,在[[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/583128.html

相关文章:

  • 移动端网站怎么做的wordpress外贸网店主题
  • 网站index.php被修改成都网络科技公司排名
  • 网站 内页美工常用找素材网站
  • 佛山网站营销浏览器网站免费进入
  • 什么网站能让小孩做算术题网络培训机构排名前十
  • 网站制作作业域名类型
  • 旅游类网站策划建设_零投入开网店
  • 网站建设试题卷访问网页
  • 淄博专业网站建设价格上海排名seo公司
  • 做商城网站费用企业管理培训是做什么的
  • 网站制作设计正规公司曹县网站开发
  • 槐荫区网站建设wordpress文件浏览插件
  • 杭州做购物网站动漫网站做毕业设计简单吗
  • 广州品牌网站设计开发用自己的网站做淘客
  • 网站搜索怎么做的网站建设公司宣传
  • 网站建设网站优化动画制作软件flash
  • 淘宝客网站怎么做推广屏蔽wordpress头像
  • 怎么做qq可信任网站做甲方去哪个网站应聘
  • 行业网站建设费用八上数学优化设计答案
  • 双鸭山住房和城乡建设局网站网站该怎么找
  • 网站百度收录秒收方法wordpress 百度编辑器
  • 网站添加js广告位iis关闭网站
  • 做免费小说网站怎样赚钱内网门户网站建设方案
  • 档案门户网站建设方案网站备案 个人 单位
  • 手机网站建设推广软文wordpress配合七牛云
  • h5 php mysql网站开发东莞网页制作网站
  • 大型的网站建设公司温州网站建设平台
  • 网站策划的内容包含了什么?网站制作完成后为了
  • 织梦手机网站有广告域名ip
  • 上街免费网站建设键词优化排名