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

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

3天内不再提示

裸机开发遇到的问题

倩倩 来源:芯片之家 作者:芯片之家 2022-08-16 16:34 次阅读

裸机开发遇到的问题

第一、并发性。程序并发工作效率低在写裸机软件时,不可避免的在主程序中会有一个超级大的 while(1) 循环,这里面几乎包含整个项目的所有业务逻辑。因为每个业务逻辑里面都会有 delay 这样的循环等待函数,这样导致了所有的业务逻辑几乎都是串行起来工作的。这个时候CPU就会有很多时间都浪费在了延时函数里,一直在空转,导致软件的并发效率非常差。

第二、模块化:高内聚、低耦合的原则。从软件工程的角度,我们在做软件开发时,都会强调高内聚、低耦合的原则。而裸机的模块化开发难度非常大,模块间的耦合较重,这也导致了无法在大型项目使用裸机来开发。还是刚才 main 函数中大 while(1) 的例子,可以想象到那么多功能都紧紧的挤在一个函数里,不可拆分,模块化开发的困难重重。举一个非常贴切的例子,在一些使用看门狗的项目中,如果使用 delay 延时函数,那得注意点,万一延时过长,主函数来不及喂狗,看门狗就被触发了。最后会产生这样一种感觉,一个简简单单的delay还得考虑喂狗功能,裸机开发时操的心太多了,自然无法应用在大型项目中。

第三、生态:很多高级软件组件,必须依赖于操作系统来实现。比如说,我前些年开源过一个基于FreeModbus的Modbus主机协议栈,因为要考虑各个平台适配问题,原本计划支持各种各样的操作系统,甚至是裸机平台。在各个操作系统上的适配都非常容易,但再去尝试着适配裸机时,发现难度重重,有一些函数在裸机上实现起来非常复杂,而且针对于不同的裸机环境,几乎没有通用性可言,太耗费精力了。所以我最终就放弃了裸机适配,一直到现在,在裸机上还是没法用这个 Modbus 主机协议栈。还有一些软件无法运行在裸机上,比如:乐鑫、Realtek、ti联发科提供的WIFi SOC SDK ,一些蓝牙SO的SDK也都是只支持操作系统,所以,如果你不了解、不会使用操作系统,这些芯片也就玩不转了。

8dc84fee-196d-11ed-ba43-dac502259ad0.jpg

第四、实时性:功能复杂的情况下,实时性无法保证。软件的实时性在一些领域会有一定的要求,软件的每个步骤必须在指定的时间被触发。工控领域就是最常见到的场景,如果实时性无法保证,机械设备可能就无法按照指定时序要求去动作,以至于发生机械事故,甚至会威胁到人的生命。回过来接着看裸机软件,如果软件变得庞大以后,可以想象到,主程序中那么大的一个 while(1) 循环,代码耦合严重,到处都是 delay 延时,要保证实时性几乎是不可能的。

第五、可重用性:软件可重用性差,总是重复造轮子。可重用性与模块化程度有直接的关系。相信大家每个人在工作中都不想做很多重复性的工作,同样在写代码时,也想着尽可能少写一些功能相似的代码。但在这个嵌入式碎片化极其严重的时代,各式各样的芯片,想要让同样的代码,在裸机环境下同时适配不同的硬件,难度非常大。这样也就导致了裸机的代码会过多的依赖于底层硬件,重复造轮子的过程也就不可避免。

操作系统带来的优势

操作系统的优势:线程方式的并发任务处理,解决模块化问题,同时保证实时性。

1、模块化。使用了操作系统以后,整个软件的工作被拆分成了由多个任务来构成(也会被称为线程),每个线程有自己独立的运行空间,即线程堆栈,这个时候每个线程你玩你的,我做我的,咱们大家互补干涉,模块化程度得到很好的提高。

2、并发性。从并发的角度来看,各个线程在使用delay/事件等待 这类函数时,会自动的让出CPU 给其他有需要的线程,不仅书写delay延时函数操的心少了,整个CPU的利用率也得到了提高,最终提升并发性。

3、实时性。再来看实时性,像ucos/RT-Thread这些RTOS本身就被设计为实时的操作系统,各个线程都有不同的优先级别,重要的线程可以设为高优先级,不重要的线程可以降低优先级,做好全局的统筹规划后,这样整个软件的实时性也能得到保证。

4、开发效率。由于操作系统提供了统一的抽象接口层,方便了可重用组件的积累,提高开发效率。操作系统其实是一群软件大牛们智慧的结晶,他们站在应用软件、底层驱动的开发角度,对很多常见的软件功能进行了封装、抽象,比如:信号量、事件通知、邮箱、环形缓冲区、单向链表/双向链表等等,这些功能拿来即用,对于开发者方便极了。还有一些操作系统,比如:Linux和我们国产的RT-Thread ,这些系统对碎片化的硬件,统一封装了一套标准的硬件操作接口,一般称为设备驱动框架。这样我们的应用软件工程师,就可以专攻应用的工作,再也不用怕更换硬件,又需要重复造轮子了。

5、软件生态

生态的丰富带来了量变到质变的过程(自己玩-》大家一起玩)。使用操作系统所带来的软件可模块化、重用性的提升,也使得我们自己在做软件开发时,可以封装一套基于操作系统、适合嵌入式的可重用组件,这些组件不仅可以用在自己的项目中,还能开源出来分享给更多有需要的嵌入式开发者,把软件的价值最大化。

个人感觉这是一件蛮有意义事情,我自己本身也是一名开源极客,也有在 GitHub 上开源一些嵌入式软件。说实话在做开源软件前,能够深入交流嵌入式软件的地方非常少,毕竟大家的代码不是芯片不一样,就是硬件不一样,你的代码给了他,也不一定能运行起来。但是自从用了操作系统后,软件的可重用性提高了,能够让更多的人很迅速的用起来我的开源软件,这个时候能够有更多的人可以一起交流,还接触到了很多的大牛们,甚至是国外的朋友。俗话说:水涨船高,我的能力也从此得到了快速的提升。所以总结下来,有一个能一起交流嵌入式软件圈子还是蛮重要的,自己闭门造车,可能都是在重复造轮子。

常见RTOS优势对比

ucos/freertos/RT-Thread,选择这三款OS的原因是,它们的年限都比较长了,在市面上都蛮有知名度,用过的人比较多,更有说服力。

1、基本功能、性能。各家RTOS差异很小,可比性并不是很大

2、易用性/可读性。这块FreeRTOS应该说是最差,奇葩的匈牙利命名法,代码实现用了很多宏,可读性非常差。ucos可读性还可以,注释也很全。这块做得比较好的是RT-Thread ,它是类Linux的代码风格,面向对象的设计模式,代码简洁易懂。在保证了体积(最小ROM:3K;RAM:1.5K)的同时,还借鉴了Linux的设备驱动框架、虚拟文件系统、Shell等功能,设计更加优雅。

3、组件丰富性。RT-Thread比起传统UCOS、FreeRTOS不仅仅在基础功能上多而全,多达50个以上的可重用软件组件,还有很多物联网组件,对于物联网产品几乎做到开箱即用。RT-Thread还可以运行PythonJava、Lua这些高级语言的脚本,进一步降低开发难度。

4、开发资料。这块ucos做的最好,还有配套相关的书籍,FreeRTOS属于后起之秀,网上也有很多相关资料。RT-Thread这块之前还是略显薄弱的,不过现在RT-Thread对这块非常重视,最直观的可以看到官网上的应用笔记越来越多了,还有一些配套教学视频

5、版权。ucos商业是要收费的,FreeRTOS和RT-Thread版权都很宽松,特别是RT-Thread刚刚使用了Apache许可协议。

6、社区生态。这三款RTOS的社区都比较活跃,现在可以感觉到ucos慢慢的用的人越来越少了,RT-Thread和FreeRTOS用的人都在增多。RT-Thread也是开发者最多的国产 RTOS,并且还拥有国内最大的嵌入式开源软件社区。

审核编辑 :李倩

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

    关注

    37

    文章

    6817

    浏览量

    123317
  • RTOS
    +关注

    关注

    22

    文章

    811

    浏览量

    119610
  • 模块化
    +关注

    关注

    0

    文章

    331

    浏览量

    21344

原文标题:MCU开发中,你选”裸奔“还是RTOS?

文章出处:【微信号:雨飞工作室,微信公众号:雨飞工作室】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    RZ T2H PCIe裸机程序开发和Linux下的配置介绍

    ,还提供2个PCIe Gen3通道等高速外设。本文主要介绍PCIe外设的功能、裸机下EP模式的程序开发、以及在Linux下,如何编译网卡的流程。
    的头像 发表于 12-18 11:14 503次阅读
    RZ T2H PCIe<b class='flag-5'>裸机</b>程序<b class='flag-5'>开发</b>和Linux下的配置介绍

    RAKsmart洛杉矶裸机云服务器的特性和优势

    RAKsmart是一家知名的云服务提供商,以其高质量的基础设施和优质的服务著称。特别是其位于洛杉矶的数据中心提供的裸机云服务器,凭借其卓越的性能和丰富的特性,受到了广大用户的青睐。本文将详细介绍RAKsmart洛杉矶裸机云服务器的特性和优势。
    的头像 发表于 11-22 09:17 121次阅读

    韩国裸机云服务器是什么?

    韩国裸机云服务器是一种结合了裸机服务器与云端技术,提供多IP地址分配和高性能网络服务的云计算解决方案。主机推荐小编为您整理发布韩国裸机云服务器的详细解释。
    的头像 发表于 11-06 10:11 120次阅读

    用GNU构建裸机系统

    基于AT91SAM7S平台,介绍裸机开发,以闪灯为蓝本,涉及汇编、链接、C/C++、中断等。   无处不在的ARM处理器家族得到了GNU C/C++工具链的良好支持。虽然许多在线和印刷资源关注
    发表于 10-16 17:34 0次下载

    韩国裸机云站群服务器的特点和使用步骤

    随着云计算技术的不断发展,裸机云(Bare Metal Cloud)作为一种结合了物理服务器强大性能与云服务灵活性的解决方案,正受到越来越多企业和开发者的青睐。韩国裸机云站群服务器因其独特的地理位置
    的头像 发表于 09-06 10:06 194次阅读

    freertos和裸机有什么区别

    FreeRTOS 和裸机编程是两种不同的嵌入式系统开发方法,它们在设计理念、资源使用、功能实现等方面有着显著的差异。 1. 基本概念 1.1 FreeRTOS FreeRTOS 是一个小型的、可裁剪
    的头像 发表于 09-02 14:13 1368次阅读

    韩国裸机云站群服务器是什么?

    韩国裸机云站群服务器是一种提供多IP地址分配和高性能网络服务的云计算解决方案,结合了裸机服务器与云端技术,具有高性能、高可靠性和灵活可扩展性的特点。韩国裸机云站群服务器广泛应用于需要多IP管理和高稳定性的网络应用,如大型企业、互
    的头像 发表于 08-19 10:48 232次阅读

    东京裸机云多IP服务器全面分析

    东京裸机云多IP服务器是一种提供多IP地址分配和高性能网络服务的云计算解决方案,广泛应用于需要多IP管理和高稳定性的网络应用。下面将从几个方面具体介绍东京裸机云多IP服务器,rak部落为您整理发布东京裸机云多IP服务器的全面分析
    的头像 发表于 07-22 09:49 327次阅读

    洛杉矶裸机云大宽带服务器的特性和优势

    洛杉矶裸机云大宽带服务器是结合了物理服务器性能和云服务灵活性的高性能计算服务,为用户提供高效、安全的计算和存储能力。在了解如何使用洛杉矶裸机云大宽带服务器之前,需要了解其基本特性和优势。以下是对洛杉矶裸机云大宽带服务器的具体分析
    的头像 发表于 07-08 10:11 245次阅读

    法兰克福裸机云服务器速度和性能评测

    在当今的云计算时代,裸机云服务器因其高性能、高可靠性和高灵活性而备受青睐。法兰克福作为欧洲的网络中心,其裸机云服务器更是备受关注。以下是对法兰克福裸机云服务器速度和性能的详细评测。
    的头像 发表于 06-04 11:12 244次阅读

    香港裸机云多IP服务器都有哪些配置?

    香港裸机云多IP服务器是一种高效、灵活的云计算服务,为用户提供了多IP地址的配置选项,以满足各种复杂的网络需求。这种服务器在配置上具有丰富的多样性和高度的可定制性,下面我们就来科普一下香港裸机云多IP服务器的主要配置。
    的头像 发表于 04-18 09:58 350次阅读

    STM32mp135裸机开发无法使用DDR吗?

    针对裸机开发,参考了此开发链接: https://wiki.stmicroelectronics.cn/stm32mpu/wiki
    发表于 03-11 07:01

    何时选择裸机?何时选择RTOS?何时选择GPOS?

    在每个开发项目的初期,你都必须选择软件开发的基础。虽然有很多选择,但它们通常分为三类:裸机、实时操作系统(RTOS)或通用操作系统(GPOS)。
    的头像 发表于 02-27 11:42 1161次阅读

    裸机云服务是什么?裸机云服务如何选择

     裸机云服务是一种基础设施即服务 (IaaS)的一个变体,它允许用户租用和配置单租户服务器,这通常意味着没有虚拟化层的存在。这种服务方式可以让用户享受到独立的硬件资源、带宽和防御,而且配置可以随时灵活升级。更重要的是,用户在需要时,最快在10分钟内就可以开通独立的服务器。
    的头像 发表于 01-08 09:22 474次阅读

    如何在裸机系统中集成SystemView

    SystemView是嵌入式系统可视化分析工具,提供了对应用程序的完整洞察,包括时间轴、CPU负载、运行时间信息、上下文运行时信息等可视化窗口,能够帮助开发者获得对应用运行时行为的深入理解。除μC
    的头像 发表于 12-29 11:07 2069次阅读
    如何在<b class='flag-5'>裸机</b>系统中集成SystemView