嵌入式裸机设计--MCU常用裸机架构有哪些?

为什么是裸机设计

792125321入群学习更高效!

在MCU(微控制器单元)裸机开发中,我们常见的架构设计主要围绕如何高效管理资源和任务调度。认识这些开发方式,对我们开发一个小型项目来说及有好处!

下面介绍一下几种常用的裸机架构及其特点:

1. ​超级循环(Super Loop)​

  • ​原理:程序通过一个无限循环(while(1))不断轮询任务。这也是我们最为熟悉的开发方式!

  • ​特点:

  • 简单易实现,适合小型项目。

  • 任务按顺序执行,实时性差,高优先级任务可能被阻塞。

  • 无抢占机制,依赖任务主动释放CPU。

  • ​适用场景:简单控制任务(如LED闪烁、按键检测)。

核心:中断快速响应,主循环处理非实时任务。

例子:

 

 

运行过程:像流水线工人,永远重复三个动作:看一眼按键 → 调一下LED亮度 → 发会儿呆 → 再从头开始。

 

缺点:发呆时会卡住,不能同时做其他事(比如发呆时按键可能漏检查)。

2. ​前后台系统(Foreground-Background)

  • ​原理:

  • ​前台:由中断服务程序(ISR)处理紧急任务(如外部事件)。

  • ​后台:主循环处理非实时任务(如数据处理、状态更新)。

  • ​特点:

  • 中断响应快,适合异步事件处理。

  • 后台任务仍可能被中断打断,需注意资源共享问题(如使用临界区)。

例子:

 

 

运行过程:

 

  • ​急诊:按键按下时,中断立刻标记“有人按了”(不处理,只记下来)。

  • ​门诊:主循环看到标记后,慢慢处理按键,然后继续做杂活。 优点:急诊响应快,杂活不耽误。

  • ​适用场景:需要快速响应外部中断的应用(如传感器触发、通信接收)。

核心:顺序执行,无优先级,阻塞式延时。

 

3. ​状态机(State Machine)​

  • ​原理:将任务分解为多个状态,通过状态转移逻辑控制流程。

  • ​实现方式:

  • switch-case 结构或函数指针跳转。

  • 可能结合查表法(Lookup Table)提高效率。

  • ​特点:

  • 逻辑清晰,适合复杂流程(如协议解析、多步骤控制)。

  • 需合理设计状态迁移条件,避免死锁。

  • ​适用场景:通信协议(UART、SPI)、多阶段控制(如电机启动流程)。

核心:状态迁移由事件或条件触发,逻辑清晰。

例子:

 

 

运行过程:像交通灯,按规则切状态:

 

  • 默认关 → 按下按键切到闪烁 → 闪够时间切到常亮 → 保持常亮。 优点:逻辑清晰,适合多步骤流程(比如洗衣机:加水→洗衣→脱水)。

 

4. ​时间片轮转调度(Time-Sliced Scheduling)​

  • ​原理:利用定时器中断划分时间片,依次执行多个任务。

  • ​特点:

  • 伪并行多任务,任务切换由定时器触发。

  • 任务执行时间需短于时间片,否则可能阻塞其他任务。

  • 需平衡时间片长度和任务实时性。

  • ​适用场景:周期性任务(数据采集、显示刷新)。

核心:定时器划分时间片,任务按片切换。

例子:

 

 

运行过程:像妈妈做饭,定时切换任务:

 

  • 前10秒炒菜 → 后10秒煮汤 → 再切回炒菜 → 循环… 优点:假装“同时”做多件事,适合周期性任务(如每隔1秒读传感器)。

 

5. ​事件驱动架构(Event-Driven)​

  • ​原理:任务由事件触发(如中断、消息队列),而非轮询。

  • ​实现方式:

  • 中断标记事件,主循环检查事件标志并执行回调函数。

  • 可能使用事件队列管理多个事件。

  • ​特点:

  • 低功耗设计(可进入休眠模式等待事件)。

  • 需处理事件优先级和冲突。

  • ​适用场景:低功耗设备(如电池供电的IoT设备)。

核心:事件触发任务,无事件时休眠省电。

例子:

 

 

运行过程:像保安值班,平时睡觉 → 有事(比如报警)就处理 → 处理完继续睡。 优点:省电!适合电池设备(如无线门磁传感器)。

 

 

6. ​协作式调度(Cooperative Scheduling)​

  • ​原理:任务主动释放CPU控制权(如调用yield()),让其他任务运行。

  • ​特点:

  • 无抢占,依赖任务协作,实时性一般。

  • 避免资源竞争,适合单线程环境。

  • ​适用场景:任务间依赖性较强的应用(如顺序执行的数据处理链)。

架构选择建议

  • ​简单任务:超级循环或状态机。

  • ​实时响应:前后台系统 + 中断。

  • ​多任务伪并行:时间片轮转或事件驱动。

  • ​低功耗需求:事件驱动 + 休眠模式。

  • ​复杂逻辑:状态机分层设计(如Harel状态机)。

核心:任务通过yield()主动让出CPU,实现协作切换。

例子:

 

 

运行过程:像两人合作搬砖:

 

  • A搬几块 → 喊“换人!” → B接着搬 → 再换A… 优点:任务自己控制节奏,适合配合型工作流(如先读数据再处理)。

这些架构可单独使用或组合(如“时间片轮转 + 状态机”),具体取决于项目需求和资源限制。裸机开发的核心是平衡实时性、复杂度和资源开销。

题外话:

裸机编程在嵌入式开发中始终是优先考虑的方案,其核心优势在于极致的精简与高效。它直接操作硬件,无需操作系统(OS)中间层,使得资源占用近乎为零——所有内存和算力都可投入业务逻辑,尤其适合资源有限的低端MCU(如STM32F0系列或51单片机)。

此外,裸机程序通过中断和轮询的组合,能够实现硬实时响应,例如电机控制或传感器数据采集的微秒级延迟,这对工业设备等高精度场景至关重要。开发层面,裸机代码结构简单,调试透明,无需学习复杂的OS API,开发周期短且维护成本低,尤其适合功能单一的小型项目。

然而,裸机的局限性在复杂系统中逐渐显现。当系统需并行处理多任务(如同时运行通信协议解析、用户界面刷新和实时控制)时,裸机需手动管理状态机和事件队列,代码复杂度陡增,可维护性下降。此外,协作式任务调度依赖开发者自行实现,若任务间存在强依赖或资源竞争,容易引发逻辑漏洞或优先级反转问题。例如,智能家居中控需要同时处理蓝牙连接、触摸屏交互和云端同步,仅靠裸机开发会显著增加协调成本。

此时,实时操作系统(RTOS)的价值得以体现。RTOS提供任务调度、同步机制(如信号量、消息队列)和内存管理,能优雅处理多任务并行与资源竞争。例如,在无人机飞控系统中,RTOS可确保姿态计算、传感器融合和电机驱动等任务按优先级精确调度,避免手动调度导致的时序错乱。同时,RTOS的模块化设计提升了代码可复用性,适合大型团队协作开发。

尽管如此,多数嵌入式场景仍推荐裸机优先。据统计,超过70%的嵌入式应用(如智能门锁、温控器、小型传感器)仅需实现有限功能,裸机开发完全可满足需求。RTOS的引入意味着至少4-8KB的RAM/ROM开销及额外的CPU负载,对成本敏感的量产项目而言,这些资源本可用于提升功能或降低硬件规格。嵌入式开发的黄金法则是“用最少资源解决问题”——在满足实时性和功能需求的前提下,裸机不仅能降低BOM成本,还能减少系统潜在风险(如RTOS内核漏洞)。因此,除非面临多任务强实时、高复杂度或长期迭代需求,否则裸机仍是更优解

 

总结

​“如无必要,勿增实体”​ —— 裸机是嵌入式开发的第一性原理,能用裸机实现的功能,绝不上RTOS。复杂度留给代码,简单留给系统。

 

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

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

相关文章

python内置函数sum的用法

知识点 - sum 函数 基本语法 sum(iterable[, start]) iterable 是一个可迭代对象,例如列表、元组、集合等,其中的元素通常是数字类型(整数或浮点数)。 start 是一个可选参数,表示累加的起始值,默认为 0。…

编程语言的几种常见的分类方法

一、 按照编程范式分类 命令式编程语言 强调通过语句来改变程序状态,如 C、Pascal、Fortran 等。 面向对象编程语言 基于对象和类的概念,支持封装、继承和多态,如 Java、C、Python、Ruby 等。 函数式编程语言 注重不可变性和纯函数&#xf…

基于DeepSeek×MWORKS 2025a的ROM Builder自动化降阶实战

一、引言 当前,工业仿真领域正经历着前所未有的「智能焦虑」——当自动驾驶算法已能理解城市路网,当大模型开始设计蛋白质结构,这个驱动大国重器研发的核心领域,却仍在与千万级方程组成的庞杂模型艰难博弈。传统仿真降阶如同在数…

配置单区域OSPF实验和报文抓包和分析

一、配置单区域OSPF概念: (1)配置单区域OSPF(Open Shortest Path First)是一种常见的动态路由协议配置方式,主要用于在同一区域内实现路由信息的交换和路由表的更新。 (2)OSPF是一…

巴耶赫利专业俄语外贸网站建设

巴耶赫利是专业俄语外贸网站建设与俄语搜索引擎Yandex SEO优化服务商。巴耶赫利致力于帮助中国品牌出海俄罗斯,打开俄罗斯市场,提升品牌在俄罗斯的知名度和美誉度。 以下是对巴耶赫利相关服务的详细介绍: 一、巴耶赫利专业俄语外贸网站建设…

Netty基础—6.Netty实现RPC服务三

大纲 1.RPC的相关概念 2.RPC服务调用端动态代理实现 3.Netty客户端之RPC远程调用过程分析 4.RPC网络通信中的编码解码器 5.Netty服务端之RPC服务提供端的处理 6.RPC服务调用端实现超时功能 5.Netty服务端之RPC服务提供端的处理 (1)RPC服务提供端NettyServer (2)基于反射…

路由器与防火墙配置命令

路由器与防火墙配置命令 小明啊,你不是学计算机的嘛,叔叔家的路由器坏了,可以过来帮叔叔看看吗 命令可以用缩写,造就一堆容易造成歧义的缩写,比如add是address的缩写,sh是shutdown的缩写。 默认为Cisco路…

Go语言进化之旅:从1.18到1.24的语法变革

文章目录 里程碑变革:泛型支持Go 1.18:泛型的引入Go 1.19-1.21:泛型的完善Go 1.24:泛型类型别名全面支持 循环与迭代的进化Go 1.22:循环变量作用域变化与整数遍历Go 1.23:迭代器函数的支持Go 1.24&#xff…

发现一个GoVCL的问题

之前用govcl写了一个服务端的界面程序,用来控制服务的开启和关闭。 由于这个服务程序运行的时间比较长,经常是挂着在服务器上24小时不间断运行。 后来经过调试发现,govcl的界面按钮控件,在程序长时间运行后,会出现无法…

34个适合机械工程及自动化专业【论文选题】

论文选题具有极其重要的意义,它直接关系到论文的质量、价值以及研究的可行性和顺利程度。选题明确了研究的具体领域和核心问题,就像给研究旅程设定了方向和目的地。例如,选择 “人工智能在医疗影像诊断中的应用” 这一选题,就确定…

电脑实用小工具--VMware常用功能简介

一、创建、编辑虚拟机 1.1 创建新的虚拟机 详见文章新创建虚拟机流程 1.2 编辑虚拟机 创建完成后,点击编辑虚拟机设置,可对虚拟机内存、处理器、硬盘等各再次进行编辑设置。 二、虚拟机开关机 2.1 打开虚拟机 虚拟机创建成功后,点击…

双指针算法专题之——有效三角形的个数

文章目录 题目介绍思路分析AC代码 题目介绍 链接: 611. 有效三角形的个数 思路分析 如果判断三个数能否构成一个三角形,相信大家都知道: 只要任意两边之和大于第三边即可。 比如三条边长度为a,b,c 那只要满足 ab>c ac>b b…

Linux内核实时机制27 - RT调度器10 - RT throttling 带宽控制下

文章目录 1、初始化带宽 init_rt_bandwidth1.1、init_rt_bandwidth2、定时器处理2.1、sched_rt_period_timer2.2、do_sched_rt_period_timer3、总结1、初始化带宽 init_rt_bandwidth rt_runtime : 一个时间周期内的运行时间,超过则限流,默认值为0.95ms 1、init_rt_bandwidth…

1.5[hardware][day5]

Link类跳转指令可以拆分为两个部分,一个是跳转,即下一个PC的生成,如果将分支条件的比较放到译码级来进行,则这部分只涉及取值级和译码级流水;另一个是Link操作,简单来说就是写寄存器,这部则主要…

Tomcat 与 Java 环境变量配置简明教程

Tomcat 与 Java 环境变量配置简明教程 一、Tomcat 环境变量配置 1. 确认安装路径 假设 Tomcat 安装在:D:\Tomcat\apache-tomcat-9.0.70 2. 设置 CATALINA_HOME 步骤: 右键点击「此电脑」→「属性」点击「高级系统设置」→「环境变量」在「系统变量…

3.16学习总结

学习了Java的知识点 基本数据类型 byte占1字节,储存范围-128~127 short占2字节,储存范围-32768~32767 int占4字节,储存范围-2147483648~2147483647 long占8字节,储存范围是-9223372036854775808~9223372036854775807 float占…

Android手机中各类安全相关知识总结

更多内容请见: 爬虫和逆向教程-专栏介绍和目录 文章目录 1. Android 安全威胁2. Android 安全防护措施3. Android 安全建议和最佳实践4. Android 安全工具推荐5. Android 安全常见问题5.1 如何检测设备是否感染恶意软件?5.2 如何防止应用滥用权限?5.3 如何保护设备免受网络攻…

【Ratis】项目总览

Apache Ratis 项目源码分析与运行原理 Apache Ratis 是一个高性能、可扩展的分布式一致性协议实现,是对Raft协议的Java版本的很好的工程实现。它提供了灵活的 API 和多种传输层支持(如 gRPC 和 Netty),适用于构建分布式系统中的核心组件,例如分布式存储、配置管理和服务发…

以太网 MAC 帧格式

文章目录 以太网 MAC 帧格式以太网帧间隔参考 本文为笔者学习以太网对网上资料归纳整理所做的笔记,文末均附有参考链接,如侵权,请联系删除。 以太网 MAC 帧格式 以太网技术的正式标准是 IEEE 802.3,它规定了以太网传输数据的帧结…

pycharm配置镜像源【pycharm最新版(23.2.5及以上)方法】

经常遇到pycharm中无法安装或者安装慢的问题,纠结了好久,终于找到这个解决办法了。 为什么要配置镜像源: 因为Python的包管理工具pip一般从PyPI(Python Package Index)下载安装包,但是PyPI位于国外&#x…