虹科分享 | 平衡速度和优先级:为多样化的实时需求打造嵌入式网络(4)——从理论到实践:CANopen源代码配置

正如前文所述,CANopen的适应性在满足实时应用需求方面发挥着至关重要的作用。本系列文章的最后一部分将向您展示 CANopen 源代码配置的技术细节,以及实现高效实时性能的优化方法。

前文回顾:
虹科分享 | 平衡速度和优先级:为多样化的实时需求打造嵌入式网络(1)——选择正确的实时范围
虹科分享 | 平衡速度和优先级:为多样化的实时需求打造嵌入式网络(2)——实时通信系统的需求
虹科分享 | 平衡速度与优先级:为多样化的实时需求打造嵌入式网络(3)——CAN与CANopen的实时能力与局限性

本文将基于虹科CANopen源码来研究具体示例,从而阐明配置、优化和微调CANopen协议栈的过程,以满足高级时间要求和可能的系统约束。

无论您是经验丰富希望提高优化技能的CAN系统设计人员,还是希望了解实时CANopen 配置的细微差别的新手,本部分都旨在提供全面的见解和指导,将我们获得的理论知识转化为实际实施。

1. 不同的CANopen PDO配置及其对响应时间的影响

CANopen PDO(过程数据对象)的配置在确定各种应用中的响应时间方面起着至关重要的作用。根据所需的响应时间和跨多个节点同步信号的必要性,可以应用不同的PDO触发机制。

1)100ms响应时间

对于所需响应时间为100毫秒或更长的应用,通常有两种运行良好的配置方法(也可以组合使用):

  • PDO按事件时间触发(循环传输):这里,PDO以指定的时间间隔循环传输,例如每50ms。这种周期性传输确保了一致的响应时间。
  • 带禁止时间的状态变化(COS)检测:此配置根据状态变化传输PDO,传输之间具有最短时间(禁止时间)。该禁止时间确保切换输入不会产生back-to-back消息。
    在这里插入图片描述

2)更短的响应时间或跨多个节点的同步信号

对于需要较小响应时间或需要跨多个节点同步信号的应用,SYNC 模式成为首选方法。

SYNC模式:在此配置中,一个SYNC生成器以稳定的重复间隔(例如每10毫秒)生成SYNC CANopen消息。此SYNC消息用作触发机制,网络中的所有设备使用它来同时同步应用数据。

高级SYNC:使用CANopen SYNC模式时,您可以利用两个高级功能。首先,大多数SYNC消费者允许使用SYNC CAN消息标识符的配置。因此,您可以将系统配置为使用多个SYNC触发消息,并选择哪些设备对哪个触发做出反应。其次,最新版本的CANopen支持使用带有集成可配置计数器的SYNC。例如,可以将其配置为计数到4。在SYNC使用者端,您可以配置每个使用者侦听的计数值,再次提供对设备进行分组以对系统上的特定SYNC做出反应的选项。

选择正确的PDO配置对于实现最短的响应时间至关重要。虽然循环传输和具有禁止时间的COS检测适用于更宽松的响应时间要求,但在处理更严格的时间限制或需要同步多个设备时,SYNC模式变得至关重要。

2. CANopen协议栈中的数据流

下图说明了CANopen系统中的数据流。在最低硬件级别,CAN控制器将接收CAN帧(此处通过连接的收发器从左开始)。根据过滤器的不同,它们可能会被放入预先选择的缓冲区或队列中,并且将生成中断信号。实现处理CAN控制器代码的处理器(通常是“驱动程序”)开始处理“CAN接收中断服务”。更通用的驱动程序可以实现另一个软件队列以供以后处理。每当CANopen协议处理代码被触发处理接收到的消息时,它就会从驱动程序获取消息并更新对象字典。

反之亦然,应用程序可能随时更新对象字典中的一些过程数据以通过CANopen传输。这是由CANopen协议处理程序检测到的,如果触发条件正确,将触发传输PDO并传递给驱动程序,驱动程序会将其放置在适当的传输缓冲区或队列中。
CANopen 设备中的数据流

请注意:通常这不是单个连续的代码流。CAN接收通常在中断级别进行处理,而CANopen协议栈处理则不然。

为了保持CANopen协议栈处于活动状态,通常需要频繁调用协议栈函数,(例如在“main while(1)”后台循环中)。该类函数通常会首先检查是否接收到 CANopen消息;如果是,则对其进行处理。如果数据涉及更新过程数据,则通常有一个回调函数来通知应用程序新的过程数据已到达。

当处理完所有接收到的CANopen消息后,该函数会检查是否有任何内容需要传输。它可以检测到传出的过程数据被应用程序修改,并根据定时器的配置和传输模式,启动相应的CANopen消息的传输。

此类传输通常会传递到驱动程序级别,可能会传递到传输队列中,并且具体何时将此CANopen消息传递到CAN控制器进行传输取决于驱动程序配置。

1)基本配置和控制选项

除非所需的处理和响应时间小于100毫秒,否则这样的数据流对于大多数应用程序来说已经足够好了。如果所需的响应时间变短,您应该开始考虑可能的优化。在查看上面的通用数据流时,可能的优化包括:

  • 针对接收的CAN驱动程序优化:芯片制造商(甚至CANopen协议栈提供商)提供的许多默认驱动程序可能无法充分利用CAN控制器的特定功能。第一个可能的优化检查之一是确保在可能的情况下利用硬件接收过滤和硬件接收缓冲区或队列,从而消除对长延迟软件接收队列的需要。
  • 针对传输的CAN驱动程序优化:在优化之前,请考虑该设备是否可以连续传输尽可能多的CAN帧,或者是否应该对传输进行某种程度的节流以确保没有任何单个设备可能会产生太长时间的高优先级back-to-back流量。如果应该对其进行限制,请考虑实施基于计时器的传输触发,例如需要每毫秒传输一个CAN帧,则我们可以使用1ms定时器中断来执行此操作,通过相应Check函数检查传输队列中是否有内容。如果是,则在此调用周期中仅将一个报文帧传递到传输缓冲区,从而将传输频率限制为每毫秒最多一次。如果需要更快的吞吐量,则可以使用更快的中断,或可以考虑使用前文提到的协议栈处理函数"Process()"的方法。

2)协议处理函数

有关协议栈处理的一个典型问题是,应该多长时间调用一次,最坏情况下的执行时间是多少。有些人喜欢从固定的定时器中断而不是后台循环中调用它。这些问题没有通用的答案。常见做法是:

while (Process());

这将不断重新调用该函数,直到所有待处理的CANopen任务都已执行完毕。

3)直接任务触发

协议栈处理函数主要是为那些不想深入了解从内部执行的所有CANopen任务的详细信息的人提供服务。当然为了进一步优化,我们也可以直接实现更具体的协议栈功能函数,比如RxPDO和TxPDO,或者是基于毫秒计时器实现的计时触发函数等,从而可以更精确地调整性能和响应能力。

3. CAN驱动程序、CANopen协议栈和应用

在大多数基于32位的微控制器上,到目前为止讨论的增强功能适合将总响应时间降低到10毫秒到“几毫秒”的范围。这可以在不需要优化的情况下实现,而优化可能会导致完全自定义的实现,而这种实现可能难以维护。这些优化仅限于在需要时利用单独触发的CANopen堆栈进程。
一般来说,这可以进一步进行。然而,在系统的这种内在级别上进行更改可能会使维护或在必要时移植到不同的体系结构变得更具挑战性。因此,以下内容更多的是说明“理论上可能的情况”,将优化推向超出系统易于测试、维护和移植的范围。

在最低硬件级别,检查您的CAN控制器是否配置为通过接收SYNC消息直接创建CAN接收中断,以及您是否可以轻松检测到与任何其他CANopen消息(例如自己的过滤器/接收缓冲区)的差异。

为了进一步提高实时性,唯一合理的CANopen PDO通信模式是CANopen SYNC模式。如果使用它并且我们集中精力优化它,那么之前的其他优化可能会变得多余。

专注于SYNC优化需要我们修改CAN接收中断服务例程,以便在收到SYNC信号时直接调用负责SYNC处理的CANopen堆栈函数。当从中断服务程序中执行此操作时,请记住:

  • 不要将此SYNC存储在常规接收队列中(我们已经处理过它)。
  • 对于SYNC相关的发送和接收数据,将调用应用程序的回调函数——仍然在中断服务级别执行。
  • 当使用RTOS时,更好的解决方案是在收到SYNC的中断中设置触发信号,随后在中断完成后立即触发执行任务。

通过这样的修改,可以实现毫秒内的响应时间。如果参与SYNC通信的所有设备都以相同的优化来实现SYNC处理,则设备之间的变化(例如,当它们各自同步应用其输出时)可以低至几微秒。

然而,这些都是在测试和实验室环境中观察到的极端值。对于要求如此短响应或同步时间的实际应用程序,需要仔细测试以确保在所有实际情况下都能达到这些目标。

全文总结:通过战略选择来应对复杂性

  • 硬件选择:所需的响应时间决定了所需的硬件功能,影响对模块、可能是微控制器和其他重要组件的决策。
  • 操作系统注意事项:无论是使用 RTOS还是实现更具体的定制系统,响应时间都会严重影响操作系统的配置方式。
  • 网络技术:根据所需的吞吐量和速度,必须考虑不同的网络协议和技术。作为一个例子,本系列研究了CANopen及其配置的细节,说明了满足不同应用需求所需的细微选择。
  • 优化选择:也许最深刻的见解之一是认识到优化并不是一种万能的方法。根据所需的响应时间,某些优化变得至关重要,而其他优化则可以绕过。这是一个微调的问题,了解哪些内容需要利用,哪些内容可以在不影响性能的情况下保持不变。
  • 战略无知:与利用一切可能的优势的本能相反,在某些情况下,时间框架允许故意忽略某些优化。并非网络控制器提供的每个寄存器都需要被利用;这是性能和特定应用程序的需求之间的平衡。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/202912.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

linux resin的安装

1. 下载安装包 1.1 下载地址:https://caucho.com/products/resin/download 这里我下载的是普通版本的resin,没有选resin pro 版本。 科普一下,从性能上来说 resin和resin pro 版本的性能没区别。 resin pro 版本的 和resin 普通版本的文件是…

Unity求向量A在平面L上的投影向量

如题&#xff1a;求向量A在平面L上的投影向量(图左) 即求 其实等价于求向量&#xff0c;那在中&#xff0c;,所以只需要求即可 而就是在平面L的法向量的投影坐标&#xff0c;所以代码就是 /// <summary>/// 求向量A在平面B上的投影向量/// </summary>/// <para…

EI级 | Matlab实现TCN-LSTM-Multihead-Attention多头注意力机制多变量时间序列预测

EI级 | Matlab实现TCN-LSTM-Multihead-Attention多头注意力机制多变量时间序列预测 目录 EI级 | Matlab实现TCN-LSTM-Multihead-Attention多头注意力机制多变量时间序列预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 1.【EI级】Matlab实现TCN-LSTM-Multihead-Attent…

java:IDEA中Maven常用操作

文章目录 背景1、Reload All Maven Projects:2、Generate Sources and Update Folders For All Projects:3、Download Sources and/or Documentation:4、Add Maven Projects5、Run Maven Build6、Execute Maven Goal7、Toggle Offline Mode8、Toggle Skip Tests Mode9、Collaps…

相机标定张正友、opencv和halcon对比(1)

本文将从基本标定开始&#xff0c;结合实际工作经验&#xff0c;分析张正友、opencv和halcon三者相机标定的深层原理与不同之处&#xff0c;内容比较多&#xff0c;如果出现错误请指正。 相机光学模型 我们使用的镜头都是由多组镜片组成&#xff0c;它实际上是一种厚透镜模型…

易基因:人精子H3K4me3 ChIP-seq和DNA甲基化WGBS揭示与生育和发育相关重叠区域

大家好&#xff0c;这里是专注表观组学十余年&#xff0c;领跑多组学科研服务的易基因。 目前&#xff0c;六分之一的夫妇患有不孕不育&#xff0c;其中多达一半的病例由男性因素引起&#xff0c;在过去的40年中&#xff0c;精子数量下降了50%。尽管导致精子质量和数量下降的因…

Javase | Java常用类 (不断补充中...)

目录: 1.Object类2.String类3.StringBuffer类4.Math类5.Random类6.包装类(不断补充中...) 1.Object类 Object类是Java语言中的所有类的超类&#xff0c;即所有类的根。它中描述的所有方法&#xff0c;所有类都可以使用。 equals( ) : 指示其他某个对象与此对象“是否相等” (比…

【C/C++笔试练习】this指针的概念、初始化列表、const对象调用、构造和析构函数、继承和组合、重载和多态、虚函数的定义、计算日期到天数转换、幸运的袋子

文章目录 C/C笔试练习选择部分&#xff08;1&#xff09;this指针的概念&#xff08;2&#xff09;初始化列表&#xff08;3&#xff09;const对象调用&#xff08;4&#xff09;构造和析构函数&#xff08;5&#xff09;继承和组合&#xff08;6&#xff09;重载和多态&#x…

力扣 --- 三数之和

目录 题目描述&#xff1a; 思路描述&#xff1a; 代码&#xff1a; 提交结果&#xff1a; 官方代码&#xff1a; 官方提交结果&#xff1a; 题目描述&#xff1a; 给你一个整数数组 nums &#xff0c;判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i ! j、i ! k…

implementation和api的区别是什么

前言&#xff1a; 平时在做开发的时候&#xff0c;各种依赖三方库。一般就是在build.gradle中添加如下代码&#xff1a; dependencies {implementation com.google.android.material:material:1.9.0 } 这里随便举个例子。 今天在开发的时候&#xff0c;遇到如下错误&#xf…

day32_Git

今日内容 零、 复习昨日 零、 复习昨日 一、引言 在单人开发过程中&#xff0c;需要进行版本管理&#xff0c;以利于开发进度的控制。 在多人开发过程中&#xff0c;不仅需要版本管理&#xff0c;还需要进行多人协同控制。 版本控制(VS) SVN GIT 二、介绍 Git是一个开源的…

vue3+vite搭建cesium项目

1.创建项目 cnpm create vite 2.安装依赖 npm i cesium vite-plugin-cesium vite -D 3.在vite.config.js里进行配置 import { defineConfig } from vite import vue from vitejs/plugin-vue import cesium from vite-plugin-cesium; export default defineConfig({plugins…

vue项目运行时,报错:ValidationError: webpack Dev Server Invalid Options

在运行vue项目中&#xff0c;遇到报错&#xff1a;ValidationError: webpack Dev Server Invalid Options&#xff0c;如下图截图&#xff1a; 主要由于vue.config.js配置文件错误导致的&#xff0c;具体定位到proxy配置代理不能为空&#xff0c;导致运行项目报错&#xff0c;需…

Apache Flink(二):数据架构演变

&#x1f3e1; 个人主页&#xff1a;IT贫道_大数据OLAP体系技术栈,Apache Doris,Clickhouse 技术-CSDN博客 &#x1f6a9; 私聊博主&#xff1a;加入大数据技术讨论群聊&#xff0c;获取更多大数据资料。 &#x1f514; 博主个人B栈地址&#xff1a;豹哥教你大数据的个人空间-豹…

CSS:calc() 函数 / 动态计算长度值 / 不同场景使用

一、理解 css calc() 函数 CSS calc() 函数是一个用于计算 CSS 属性值的函数。它可以在 CSS 属性值中使用数学表达式&#xff0c;从而实现动态计算属性值的效果。calc() 函数可以使用加减乘除四种基本数学运算符来计算属性值&#xff0c;还可以使用括号来改变优先级。 二、ca…

堆在排序中的应用

堆排序 1、堆排序原理 堆排序是利用到了堆这种数据结构&#xff0c;我们首先回顾一下二叉堆的特性&#xff1a; 最大堆的堆顶是整个堆中的最大元素。最小堆的堆顶是整个堆中的最小元素。 以最大堆为例&#xff0c;如果删除一个最大堆的堆顶&#xff08;并不是完全删除&…

【MATLAB】RLMD分解+FFT+HHT组合算法

有意向获取代码&#xff0c;请转文末观看代码获取方式~也可转原文链接获取~ 1 基本定义 RLMD分解FFTHHT组合算法是一种强大的分析方法&#xff0c;结合了局部均值分解&#xff08;LMD&#xff09;、快速傅里叶变换&#xff08;FFT&#xff09;和希尔伯特-黄变换&#xff08;H…

Wireshark之Intro, HTTP, DNS

源码地址&#x1f447; moranzcw/Computer-Networking-A-Top-Down-Approach-NOTES: 《计算机网络&#xff0d;自顶向下方法(原书第6版)》编程作业&#xff0c;Wireshark实验文档的翻译和解答。 (github.com) 目录 &#x1f33c;Introduce &#x1f3a7;前置 &#x1f3a7;过…

基于YOLOv8深度学习的PCB板缺陷检测系统【python源码+Pyqt5界面+数据集+训练代码】目标检测

《博主简介》 小伙伴们好&#xff0c;我是阿旭。专注于人工智能AI、python、计算机视觉相关分享研究。 ✌更多学习资源&#xff0c;可关注公-仲-hao:【阿旭算法与机器学习】&#xff0c;共同学习交流~ &#x1f44d;感谢小伙伴们点赞、关注&#xff01; 《------往期经典推荐--…

基于three.js生成动态波浪背景效果

文章目录 前言一、安装three二、新建waves.js文件三、引入waves.js文件比查看效果如有启发&#xff0c;可点赞收藏哟~ 前言 基于three.js生成动态波浪背景效果 一、安装three npm i three -S二、新建waves.js文件 注意geometry.setAttribute和geometry.addAttribute和在不同…
最新文章