OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 3641|回复: 1

嵌入式程序架构--你了解多少?

[复制链接]

1156

主题

1168

帖子

2

精华

超级版主

Rank: 8Rank: 8

积分
4985
金钱
4985
注册时间
2019-5-8
在线时间
1260 小时
发表于 2021-12-20 14:52:12 | 显示全部楼层 |阅读模式
以下文章来源于:公众号开源电子网读取更多技术文章,请扫码关注




前言

单片机开发中,我们往往首先接触裸机系统,然后到RTOS,那么它们的软件架构是什么?这是我们开发人员必须认真考虑的问题。在实际项目中,首先选择软件架构是非常重要的,接下来我们浅谈一下我们单片机开发中,有哪些程序架构。

一.裸机系统

1.轮询系统


    轮询系统是 MCU中最简单的入门系统,它的程序结构是通常只需要一个While(1)或for(;;)死循环来实现:

  1. int main(void)

  2. {

  3.     while(1)

  4.     {

  5.         //事务1

  6.         //......

  7.         //事务n

  8.     }

  9.     return0;

  10. }

复制代码

    这种程序架构就是不断循环,那么这种程序架构的缺点是非常的明显的—实时性差,因为我们的编写的代码都是顺序的执行,如果事务1和事务2之间有一个延时函数,那么处理事务2必须等待延时时间到来才可以执行相应的代码。

例如下面的动画显示:

1.gif


    所有的事务都是顺序的执行的。

2.前后台系统

    这种系统可称为前后台系统或超循环系统(Super-Loops)。应用程序是一个无限的循环,循环中调用相应的函数完成相应的操作,这部分可以看成后台行为(background)。中断服务程序处理异步事件,这部分可以看成前台行为(foreground)。后台也可以叫做任务级。前台也叫中断级。

    前后台系统在轮询系统中,增加了中断 机制。中断机制可以打断 MCU目前正在执行的程序,而执行另外一段程序,这段程序称为中断程序,当中断程序执行完成,再回到原先位置,如以下源码所示:

  1. int main(void)

  2. {

  3.     while(1)

  4.     {

  5.         事务1;

  6.         事务2;

  7.         事务3;

  8.         ......

  9.     }

  10.     return0;

  11. }

  12. //中断服务函数

  13. void interrupt_event(void)

  14. {

  15.     事务4;         //语句4

  16.     return0;

  17. }
复制代码

    前后台系统与轮询系统相比,其中一个明显优点是可以实时响应外部输入、中断是可以嵌套的,即是当发生一个中断时,MCU开始执行中断相关代码,此时一个优先级更高的中断发生,MCU将转向执行另一个更高优先级的中断。

    例如下面的动画显示:

2.gif

二.RTOS操作系统

1.时间片轮转调度

    时间片轮询法实际上通常出现在操作系统中,也就是说它属于操作系统,每个进程被分配一个时间段,称作它的时间片,即该进程允许运行的时间。如果在时间片结束时进程还在运行,则CPU将被剥夺并分配给另一个进程。如以下源码所示:

    注意:任务是有优先级的,同等优先级下的任务才可以使用时间片轮转调度。

  1. void task1(void)

  2. {

  3.     while(1)

  4.     {

  5.         事务1;

  6.     }

  7. }



  8. void task2(void)

  9. {

  10.     while(1)

  11.     {

  12.         事务2;

  13.     }

  14. }
复制代码

例如下面的动画显示:

3.gif



2.抢占式系统


    RTOS的内核负责管理所有的任务,内核决定了运行哪个任务,何时停止当前任务切换到其他任务,这个是内核的多任务管理能力。多任务管理给人的感觉就好像芯片有多个CPU,多任务管理实现了CPU资源的最大化利用,多任务管理有助于实现程序的模块化开发,能够实现复杂的实时应用。中断能打断所有任务。

4.gif

三.如何选择合适的程序架构

    对于上述讲解的程序架构,我们该如何选择呢,首先根据自己的项目以及MCU两个方面考虑。


    项目选择分析:我们的产品是否要求实时性非常好的产品,如果实时性非常好的产品,小编建议使用RTOS作为实时系统例如UCOSIII、FreeRTOS等操作系统,如果我们单单制作功能特别少的,例如汽车的智能钥匙,就是负责汽车的开锁,关闭等特别少的功能,比较适合选择前后台系统,

    如果我们的项目是关于物联网领域的,小编建议使用RT-Thread以及OneOS等相关物联网操作系统,因为该操作系统不需要我们编写相关的设备驱动以及移植网络协议,直接调用相关API函数即可。

    MCU选择分析:首先我们选择的主控芯片有关,如果我们选择一款flash以及SRAM非常小型的MCU,那么移植RTOS可能比较吃力了,目前FreeRTOS操作系统最低需要3k到5k内存。

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

2

主题

36

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3840
金钱
3840
注册时间
2020-8-7
在线时间
267 小时
发表于 2021-12-21 07:36:52 | 显示全部楼层
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-17 21:10

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表