虹科分享 | 平衡速度和优先级:为多样化的实时需求打造嵌入式网络(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.rhkb.cn/news/209652.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

git打tag和版本控制规范

我们在开发中经常会遇到要打tag的情况,但这个tag应该如何打呢?我不知道大家平时是怎么打的,但我基本就是从1.0.0开始进行往上递增,至于如何递增,基本凭感觉。今天同事新打了一个tag进行发版,然后被架构点名…

博捷芯:半导体芯片切割,一道精细工艺的科技之门

在半导体制造的过程中,芯片切割是一道重要的环节,它不仅决定了芯片的尺寸和形状,还直接影响到芯片的性能和使用效果。随着科技的不断进步,芯片切割技术也在不断发展,成为半导体制造领域中一道精细工艺的科技之门。 芯片…

git的安装及ssh配置(Linux)

环境 CentOS Linux release 7.9.2009 (Core) Xftp7 安装 方法一:yum安装 yum是一个客户端软件,就好比手机上的应用商店,帮助我们对软件的下载、安装和卸载 1、首先查看自己是否安装过git [rootxiaoxi ~]# git -bash: git: command not fo…

小米秒享3--非小米电脑

小米妙享中心是小米最新推出的一款功能,能够为用户们提供更加舒适便利的操作体验。简单的说可以让你的笔记本和你的小米手机联动,比如你在手机的文档,连接小米共享后,可以通过电脑进行操作。 对于非小米电脑想要体验终版秒享AIOT…

如何使用内网穿透工具实现公网访问GeoServe Web管理界面

文章目录 前言1.安装GeoServer2. windows 安装 cpolar3. 创建公网访问地址4. 公网访问Geo Servcer服务5. 固定公网HTTP地址6. 结语 前言 GeoServer是OGC Web服务器规范的J2EE实现,利用GeoServer可以方便地发布地图数据,允许用户对要素数据进行更新、删除…

第九节HarmonyOS 常用基础组件1-Text

一、组件介绍 组件(Component)是界面搭建与显示的最小单位,HarmonyOS ArkUI声名式为开发者提供了丰富多样的UI组件,我们可以使用这些组件轻松的编写出更加丰富、漂亮的界面。 组件根据功能可以分为以下五大类:基础组件…

WordPress自动采集伪原创发布工具

在当今数字化时代,随着信息爆炸式增长,网站内容的更新速度飞快。对于拥有WordPress网站的用户而言,如何轻松而又快速地批量采集伪原创内容成为一项具有挑战性的任务。本文将专心分享一些方法和技巧,帮助WordPress用户实现批量采集…

SQL Server 数据库,多表查询

4.2使用T-SQL实现多表查询 前面讲述过的所有查询都是基于单个数据库表的查询,如果一个查询需要对多个表进行操作, 就称为联接查询,联接查询的结果集或结果称为表之间的联接。 联接查询实际上是通过各个表之间共同列的关联性来查询数据的&…

Leetcode—409.最长回文串【简单】

2023每日刷题(四十八) Leetcode—409.最长回文串 强烈吐槽!!! 非常不理解,同样的代码,为什么C跑不了C就跑得了,力扣编译器是对C语言有歧视吗???…

如何使用cpolar+Plex在Windows系统上搭建私人媒体影音站点公网可访问

文章目录 1.前言2. Plex网站搭建2.1 Plex下载和安装2.2 Plex网页测试2.3 cpolar的安装和注册 3. 本地网页发布3.1 Cpolar云端设置3.2 Cpolar本地设置 4. 公网访问测试5. 结语 1.前言 用手机或者平板电脑看视频,已经算是生活中稀松平常的场景了,特别是各…

Wnmp本地搭建结合内网穿透实现远程访问本地Wnmp服务

文章目录 前言1.Wnmp下载安装2.Wnmp设置3.安装cpolar内网穿透3.1 注册账号3.2 下载cpolar客户端3.3 登录cpolar web ui管理界面3.4 创建公网地址 4.固定公网地址访问 正文开始前给大家推荐个网站,前些天发现了一个巨牛的 人工智能学习网站, 通俗易懂&a…

openEuler Linux 部署 FineBi

openEuler Linux 部署 FineBi 部署环境 环境版本openEuler Linux22.03MySQL8.0.35JDK1.8Tomcat9.0.83FineBi6.0 环境准备 升级系统内核和软件 yum -y updatereboot安装常用工具软件 yum -y install vim tar net-tools 安装MySQL8 将 MySQL Yum 存储库添加到系统的存储库…

Oracle(2-8)Configuring the Database Archiving Mode

文章目录 一、基础知识1、Redo Log History2、NOARCHIVELOG Mode 非归档模式3、ARCHIVELOG Mode 归档模式4、Changing the Archiving Mode 更改归档模式![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/d6a09f9a6de24de7bbcdad90b8d6b9ca.png)5、Auto and Manual Ar…

【问题解决】Linux内核编译安装后磁盘空间已满问题

Linux内核编译安装后磁盘空间已满问题解决过程 【注】本文为个人遇到Linux内核经过make,make modules……乃至最后install以后VMware磁盘空间爆炸的情况后,而又不想重装虚拟机,自己找资料实现解决的,文章中一些链接是来自别的博主…

csdn语法说明/csdn新手指导/csdn入门指导/csdn博文助手

文章目录 1、文章目录2、标题3、文本样式3.1、强调、加粗、黄色标记、删除、引用、乘方,化学表达式3.2、标红、按钮效果 4、功能快捷键5、注脚、注释6、链接7、图片8、列表9、表格 本篇博文主要写一下csdn博文中的语法说明。 1、文章目录 [TOC](这里写自定义目录标…

合成相机模型【图形学】

相机在计算机图形学中有两个方面的考虑:相机的位置和相机的形状。 要了解后者,我们需要了解相机的工作原理。 NSDT工具推荐: Three.js AI纹理开发包 - YOLO合成数据生成器 - GLTF/GLB在线编辑 - 3D模型格式在线转换 - 可编程3D场景编辑器 - R…

【开源】基于JAVA的大学计算机课程管理平台

项目编号: S 028 ,文末获取源码。 \color{red}{项目编号:S028,文末获取源码。} 项目编号:S028,文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 实验课程档案模块2.2 实验资源模块2…

无限移动的风景 css3 动画 鼠标移入暂停

<style>*{margin:0;padding:0;/* box-sizing: border-box; */}ul{list-style: none;}#nav{width:900px;height:100px;border:2px solid rgb(70, 69, 69);margin:100px auto; overflow: hidden;}#nav ul{animation:moving 5s linear infinite;width:200%; /*怎么模拟动画…

C++继承(详解)

一、继承的概念 1.1、继承的概念 继承(inheritance)机制是面向对象程序设计使代码可以复用的最重要的手段&#xff0c;它允许程序员在保持原有类特性的基础上进行扩展&#xff0c;增加功能&#xff0c;这样产生新的类&#xff0c;称派生类。继承呈现了面向对象程序设计的层次结…

SpringBoot2.x整合WebService实现远程接口调用

一、添加依赖 <!-- SpringBoot 2.4 以下版本--> <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web-services</artifactId> </dependency><dependency><groupId>org.apach…