0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

多线程RTOS应用程序的五个最佳实践

星星科技指导员 来源:嵌入式计算设计 作者:Dr. Johan Kraft 2022-06-21 09:45 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

多线程 RTOS 应用程序的一个更被低估的方面是您不能只查看代码来完全了解应用程序的工作原理

你需要知道它的各个部分是如何相互通信的,并且你需要很多其他信息:任务执行需要多长时间,是否有任何潜在的竞争条件或死锁,你是否满足你的时间要求等等。

您希望代码做什么和它实际做什么可能在许多方面有所不同,这些方面既难以在代码中看到,也难以测试。这对所有使用多线程代码的开发人员来说都是一个挑战,无论他们使用的是 RTOS 还是 Linux,最好使用可视化跟踪诊断工具进行管理,让您深入了解我所说的代码的“黑暗面”——您可以从字面上理解看看它在执行时的行为。

视觉时间线是一个很好的起点。在许多情况下,查看随时间分布的软件事件、消息和任务执行很重要,例如当错误的精确位置从症状中不明显时——计算机可能在数字处理和文本日志中搜索方面表现出色,但通常你不知道要搜索什么。在视觉模式识别方面,人脑表现出色。

poYBAGKxIueAGXUIAAHh_MLBOpY601.png

显示软件事件的可视化时间线可以让您大致了解嵌入式应用程序的内部工作原理,如果您需要深入挖掘以查找错误,这是一个很好的起点。

调试时更好的洞察力意味着将有更少的猜测,并且更有可能找到根本原因。在无法使用传统方法(如在断点处暂停系统)的情况下,它也是一个很大的帮助。

你说 printf 调试怎么样?是的,printf 很容易部署,有时它确实是你所需要的,但它的价格很高。将调试打印输出放在对时间敏感的应用程序代码中是有风险的,并且不能很好地扩展到更复杂的应用程序和更快的处理器。此外, printf 通常非常慢,每次打印输出大约为几毫秒。相比之下,针对软件事件跟踪的优化解决方案可以比这快大约 100 倍,允许您在同一时期收集更多信息。

确保在整个开发项目中测量时间和性能。做得对,这可以确保您可以在开发过程中发现并解决任何问题,而不是在承诺的交付日期之前与时间赛跑。

满足时序规范对于具有严格要求的实时系统至关重要,但对于几乎所有嵌入式系统的用户体验也很重要。没有人喜欢迟缓的触摸屏或无法提供承诺吞吐量的慢速 wifi 路由器。同样,根本原因从源代码中可能并不明显,如果真正的问题是糟糕的软件设计,那么简单地切换到更快的处理器可能没有任何好处。

如果你发现自己在一个项目中“调试地狱”,大量的调试会消耗房间里的所有能量并阻止项目向前推进,那么视觉跟踪诊断可以帮助你。在基于 RTOS 的应用程序的软件设计中未能遵循最佳实践通常是一个主要的促成因素,并且它可能以例如性能差、处理器负载高或瞬态错误的形式出现。任务之间的大量依赖是另一个可以改进设计的常见信号

即使是架构糟糕的系统也可能在今天运行,但它们将具有复杂和混乱的行为以及较差的可测试性,这增加了泄漏到生产设备中的难以捉摸的错误的风险。而且它们几乎肯定会很脆弱,因此代码或环境中的微小变化都会导致它们失败。

可视化跟踪诊断帮助开发人员分析和改进他们的软件设计,确保系统行为稳定可靠。当您可以更早地发现软件设计缺陷时,修复它们所需的更改就会更少。设计改进还可以带来更好的系统性能和响应能力,这反过来又可以让您选择更具成本效益的处理器来降低 BoM 成本或使用更低的时钟频率来延长电池寿命。

使用您的跟踪工具将跟踪数据连续流式传输到主机,如果需要,您可以在其中存储很长的记录,甚至在屏幕上实时显示数据。跟踪流使您能够监控系统测试或寻找难以重现的罕见错误。视觉跟踪诊断允许在高级视觉概览中发现异常并深入到特定事件以准确找出发生了什么。

最后,可视化跟踪诊断可以实现为纯软件解决方案,不需要额外的硬件,甚至不需要调试探针。在内存和处理器使用方面存在成本,但通常不会超过您可以在整个开发、测试甚至部署过程中将其保留在系统中(如果您愿意)。在所有阶段都能获得这些信息意味着每个人每天都能从中受益。

这种方法允许记录来自应用程序的任何相关信息,包括在运行时未公开的内部数据和状态。数据可以与可视化执行时间线并行绘制,以便在运行时深入了解您的应用程序。这样,您就可以制作出能够击败竞争对手的出色产品。

遵循这五个最佳实践,在系统级别获得对实时行为所需的可见性,以提高产品质量并加快开发速度,从而更快地进入市场。

审核编辑:郭婷

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 处理器
    +关注

    关注

    68

    文章

    20152

    浏览量

    247301
  • RTOS
    +关注

    关注

    25

    文章

    862

    浏览量

    122617
  • 代码
    +关注

    关注

    30

    文章

    4942

    浏览量

    73158
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    多线程的系统

    多线程系统的事件响应也是在中断中完成的,但事件的处理是在线程中完成的。在多线程系统中,线程跟中断一样,也具有优先级,优先级高的线程会被优先执
    发表于 12-08 07:55

    Linux多线程对比单线程的优势

    ,而单线程则需要通过进程间通信来实现。「上下文切换开销小」:线程的上下文切换比进程小,因为它们共享相同的地址空间。「提高响应性」:多线程可以使程序更加响应用户输入或其他事件,避免阻塞。
    发表于 12-01 06:11

    如何采用SAFERTOS和ESM保护嵌入式系统安全

    信任根的重要组成部分是实时操作系统(RTOS),它为应用程序的运行提供了一安全的平台。嵌入式系统的具体安全要求取决于其架构以及所面临的威胁。在本博客中,我们将探讨RTOS的安全性,以
    的头像 发表于 10-24 15:51 1164次阅读

    rt-thread studio 如何进行多线程编译?

    ,使用的是5800h+32g内存+sn550 ssd,开启16线程编译时cpu的占用率也只能到30%,编译完整个工程需要3分钟 感觉多线程编译设置没有生效,有办法提高编译速度吗 rtthread studio版本是 2.2.9
    发表于 10-11 09:16

    【HZ-T536开发板免费体验】—— linux创建线程

    线程与进程 一进程指的是一正在执行的应用程序,而线程的功能是执行应用程序中的某个具体任务。
    发表于 09-01 21:31

    【RA4E2开发板评测】LED1及LED2轮流点亮并同时亮8秒,体验FreeRTOS多线程

    我们要多线程操作时,就需要用到RTOS(Real-Time Operating System)。FreeRTOS实时操作系统开发里面使用到vTaskDelay函数,它是对CPU的时分复用,系统将这个
    发表于 08-24 17:24

    UVC+MSC实现中MSC线程未运行的原因?

    应用程序所需的线程和对象。这是一致命错误,我们无法 * 继续。 */ /* 在此处添加自定义恢复或调试操作 */ while ( 1 ); } } ```
    发表于 07-16 07:08

    多线程的安全注意事项

    和模块需要支持多线程安全,否则可能会导致多线程数据竞争问题,造成应用程序异常或崩溃。 在TaskPool或Worker的工作线程中支持使用以下模块,其他模块在使用时需要验证是否满足
    发表于 06-20 07:49

    使用Percepio View免费跟踪工具分析Zephyr应用

    Percepio View免费跟踪工具现在可以针对Zephyr应用程序进行跟踪和可视化分析了。Percepio View可以帮助开发人员理解和调试Zephyr中的固定优先级的多线程行为及复杂的线程交互。
    的头像 发表于 05-27 15:08 590次阅读
    使用Percepio View免费跟踪工具分析Zephyr应用

    天马荣获新财富杂志“2024 ESG最佳实践奖”

    天马可持续发展•ESG表现再获认可,上榜2024年新财富杂志最佳上市公司评选“ESG最佳实践榜单”。
    的头像 发表于 05-21 14:43 730次阅读

    RTOS如何在FX3中工作?

    大家好, 我正在使用 FX3 进行一项目。 我想知道 RTOS 调度是如何工作的。 我知道调用“CyU3PKernelEntry();”后 RTOS 就会开始工作。 如果我只注册一
    发表于 05-06 13:20

    请问如何在Python中实现多线程与多进程的协作?

    大家好!我最近在开发一Python项目时,需要同时处理多个任务,且每个任务需要不同的计算资源。我想通过多线程和多进程的组合来实现并发,但遇到了一些问题。 具体来说,我有两任务,一
    发表于 03-11 06:57

    使用Ozone调试基于nRF9160 Zephyr应用程序

    Ozone是SEGGER免费的嵌入式软件调试器。它是一强大的工具,可以让你深入了解嵌入式系统中发生的事情。它在调试nRF9160 Zephyr应用程序时特别有用。整理多个线程和多映像构建可能很困难,但这就是你想要的工具。
    的头像 发表于 02-25 17:07 1430次阅读
    使用Ozone调试基于nRF9160 Zephyr<b class='flag-5'>应用程序</b>

    请问rt-thread studio如何进行多线程编译?

    ,使用的是5800h+32g内存+sn550 ssd,开启16线程编译时cpu的占用率也只能到30%,编译完整个工程需要3分钟 感觉多线程编译设置没有生效,有办法提高编译速度吗
    发表于 02-19 08:30

    EE-303:将VisualDSP线程安全库与第三方RTOS配合使用

    电子发烧友网站提供《EE-303:将VisualDSP线程安全库与第三方RTOS配合使用.pdf》资料免费下载
    发表于 01-07 14:09 0次下载
    EE-303:将VisualDSP<b class='flag-5'>线程</b>安全库与第三方<b class='flag-5'>RTOS</b>配合使用