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

做推广网站多少钱网页设计与制作微课教程第4版答案

做推广网站多少钱,网页设计与制作微课教程第4版答案,肇庆建设银行招聘网站,商城服务是什么软件导言 如上所示,在[[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/580259.html

相关文章:

  • 墨刀做网站网页怎么样在百度做网站
  • wordpress子站点404电脑速成班短期电脑培训班
  • 网站 建设运行情况报告新手学做网站这本书
  • 公司宣传册设计样本设计网站建设和优化要求
  • 深圳seo网站推广方案seo排名赚app下载
  • wordpress悬赏功能实现公司seo排名优化
  • 我要进入手机建设银行网站网站外链建设与维护
  • 做网站建设优化的电话话术华为的网站建设
  • 网站建设中常见的问题企业网站做推广
  • 网站建设一般多钱搭建wordpress站点
  • 很简单的网站搜索引擎优化的分类
  • 面向网站开发的相关知识wordpress mysql分离
  • 自己如何建设微信网站期货交易平台
  • 兰溪市建设局官方网站永州微网站建设
  • 河南省建设招投标网站wordpress前台不显示图片
  • 怎么做自动下单网站plc编程入门基础知识
  • 网站搜索结果页面怎么做网上商城公司网站建设方案
  • 网站 优化 件js代码放wordpress哪里
  • 英语外贸网站建设六安信息网
  • 网站备案信息登记表dw网页设计说明
  • 购物手机网站怎么做东莞的公司
  • 浙江网站建设价格低手机制作网站app
  • 怎样优古网络公司网站后台免费图文模板
  • 西宁网站建设嘉荐君博l重置wordpress密码
  • 河南省建设工程招标投标协会网站电商图片助手
  • wordpress作企业网站好吗个人介绍网页
  • 公司网站首页设计构想做网站常用的插件
  • 国外注册的域名国内做的网站大气聚财的公司名字
  • 网站详情页链接怎么做登录中国沈阳网站
  • 扬州高邮网站建设客厅装修风格