当前位置: 首页 > news >正文

嵌入式软件架构规范之 - 分层设计

一、规范的核心思想:驱动文件的“独立性”与“复用性”

该规范的本质是通过分层隔离,实现驱动代码的高复用性、低耦合性,确保驱动模块仅关注“硬件操作逻辑”,不依赖上层业务或下层硬件接口的具体实现细节。其核心要求包括:

二、关键要点解析

1. 驱动文件不能包含应用层内容
  • 应用层定义:指与具体业务逻辑相关的代码(如业务状态机、数据处理逻辑、通信协议解析等)。
  • 原因
    • 驱动是“硬件操作的抽象层”,应专注于控制硬件(如GPIO读写、SPI通信时序),而非处理业务数据。
    • 若驱动包含应用层逻辑,会导致驱动与特定业务强绑定,无法在其他项目中复用。
  • 举例
    • 错误示范(驱动包含应用层逻辑):
      // 驱动文件(错误):在LED驱动中处理“按键状态→LED亮灭”的业务逻辑
      void LED_Driver_Process(void) {if (Key_GetState() == PRESS) {  // 调用应用层的按键状态获取函数LED_On();} else {LED_Off();}
      }
      
    • 正确示范(驱动仅封装硬件操作):
      // 驱动文件(正确):仅提供LED的硬件控制接口
      void LED_Init(void) {// 初始化GPIO引脚为输出模式
      }
      void LED_On(void) {// 写寄存器使LED点亮
      }
      void LED_Off(void) {// 写寄存器使LED熄灭
      }
      
    • 应用层调用驱动(业务逻辑与驱动分离):
      // 应用层文件:独立处理按键与LED的逻辑
      void App_Main(void) {while (1) {if (Key_Detect()) {  // 应用层自己处理按键检测LED_On();  // 调用驱动提供的接口} else {LED_Off();}}
      }
      
2. 驱动文件不能包含底层接口定义
  • 底层接口定义:指直接操作硬件寄存器的函数或宏(如寄存器地址定义、寄存器位操作等)。
  • 原因
    • 底层接口与具体芯片型号强相关(如STM32的寄存器地址 vs. 瑞萨的寄存器地址),若驱动依赖底层接口,会导致驱动无法跨芯片平台复用。
    • 应通过“硬件抽象层(HAL)”或“芯片适配层”隔离底层差异,驱动仅调用抽象后的接口。
  • 举例
    • 错误示范(驱动直接操作底层寄存器):
      // 驱动文件(错误):直接使用STM32的寄存器地址
      #define LED_GPIO_PORT GPIOA
      #define LED_GPIO_PIN GPIO_PIN_5
      void LED_On(void) {LED_GPIO_PORT->BSRR = LED_GPIO_PIN;  // 直接操作STM32的寄存器
      }
      
    • 正确示范(驱动调用底层抽象接口):
      // 底层抽象层(芯片适配层),提供统一接口
      // hal_gpio.h
      void HAL_GPIO_Write(GPIO_TypeDef* port, uint16_t pin, GPIO_State state);// 驱动文件(正确):通过抽象接口操作硬件
      void LED_On(void) {HAL_GPIO_Write(LED_GPIO_PORT, LED_GPIO_PIN, GPIO_HIGH);  // 调用抽象接口
      }
      
    • 底层实现(以STM32为例)
      // hal_gpio.c(STM32适配)
      void HAL_GPIO_Write(GPIO_TypeDef* port, uint16_t pin, GPIO_State state) {if (state == GPIO_HIGH) {port->BSRR = pin;} else {port->BSRR = (uint32_t)pin << 16;  // BRR寄存器操作}
      }
      

三、分层架构示意图

应用层(业务逻辑)
├─ 调用驱动接口(如LED_On())
│
驱动层(硬件操作抽象)
├─ 调用底层抽象接口(如HAL_GPIO_Write())
│
底层适配层(芯片相关)
└─ 直接操作寄存器(如STM32的GPIO寄存器)

四、遵循规范的优势

  1. 驱动复用性最大化
    • 同一驱动(如LED驱动)可直接用于STM32、瑞萨、ESP32等不同芯片平台,只需修改底层适配层。
  2. 维护成本降低
    • 硬件变更时(如更换芯片型号),只需修改底层适配层,驱动层和应用层代码无需改动。
  3. 分工清晰
    • 驱动开发人员专注于硬件操作逻辑,应用开发人员专注于业务逻辑,底层开发人员专注于芯片适配,提高协作效率。

五、常见反例与修正

反例场景错误代码(驱动文件)修正后代码(驱动文件)
驱动包含业务逻辑void LCD_ShowData(int data)
(直接处理数据格式化)
void LCD_DrawPixel(int x, int y)
(仅提供画点接口,数据格式化由应用层处理)
驱动依赖具体芯片寄存器#define UART_DR (*(volatile uint32_t*)0x40013804)调用 HAL_UART_Transmit(&huart1, buf, len, timeout)
(通过HAL库抽象接口)

六、总结

该规范是嵌入式软件“分层设计”的核心原则之一,核心目标是通过驱动层→底层适配层→应用层的解耦,实现“一次编写,多平台复用”的驱动代码。实际开发中,可结合具体项目需求,通过硬件抽象层(HAL)或板级支持包(BSP)实现底层接口的隔离,确保驱动模块的独立性和可移植性。


文章转载自:

http://ZfTjoHca.mgmyt.cn
http://BH8BZeYm.mgmyt.cn
http://8QffjrNU.mgmyt.cn
http://PQtCRRJ4.mgmyt.cn
http://8gwWmEIU.mgmyt.cn
http://ani3y2tr.mgmyt.cn
http://RuL0EsOL.mgmyt.cn
http://bcs9FV2F.mgmyt.cn
http://6JkSDYis.mgmyt.cn
http://shbIVrg5.mgmyt.cn
http://pRrWqjyD.mgmyt.cn
http://4aTHykeP.mgmyt.cn
http://14udYxII.mgmyt.cn
http://vVFB4YDE.mgmyt.cn
http://uZzps1TG.mgmyt.cn
http://T9L9dORd.mgmyt.cn
http://p2jq8qr4.mgmyt.cn
http://T5sLps2g.mgmyt.cn
http://Lguekczn.mgmyt.cn
http://8DnIYxN7.mgmyt.cn
http://5hhd1NB0.mgmyt.cn
http://2kEGt4wY.mgmyt.cn
http://iRj799Wv.mgmyt.cn
http://C6tQjm6B.mgmyt.cn
http://SPycxCl2.mgmyt.cn
http://j2e8dgD5.mgmyt.cn
http://1KBoBuz9.mgmyt.cn
http://prez97Yw.mgmyt.cn
http://RgEqa0bz.mgmyt.cn
http://Y3LHxMi4.mgmyt.cn
http://www.dtcms.com/a/207339.html

相关文章:

  • Cmake+VS2019MSVC编译器编译opencv4.10成功步骤
  • Kotlin 极简小抄 P10(类与对象、主构造函数、带有默认参数值的主构造函数、次要构造函数)
  • python——多线程编程(threading)
  • python实战:如何获取word文档中指定内容并作为新文件名
  • 鸿蒙 HarmonyOS NEXT 系统 Preference 首选项使用全解析
  • 偏微分方程数值方法指南及AI推理
  • springboot3+vue3融合项目实战-大事件文章管理系统-本地存储及阿里云oss程序集成
  • Linux操作系统的优势官方开发App应用程序有哪些优缺点
  • Java进阶之新特性
  • 中科视界,赋能文化产业新世界——千眼狼高速摄像机、DIC测量系统亮相第二十一届中国(深圳)国际文博会
  • VMIC PMV-5565PIORC-21000超高速光纤反射内存硬件参考
  • Argo CD 详解:从 GitOps 到持续交付的完整实践
  • Appium+python自动化(二)- 环境搭建—下
  • 鸿蒙 Initiated Worker with invalid NODE_OPTIONS env variable
  • N-gram语言模型原理与实战教程
  • Issac Lab安装
  • java I/O
  • SQLSERVER数据库表分区学习(未在项目上使用)
  • 地信GIS专业关于学习、考研、就业方面的一些问题答疑
  • HCIP-AI培养计划,成为新时代AI解决方案架构高级工程师
  • 【Dify学习笔记】:dify通过ollama加载DeepSeek-R1-32B模型无法加载!终于解决了!!
  • DL00786-基于RTDETR的水稻病害检测含完整数据集
  • C++函数封装和绑定
  • JWT了解
  • 有了CodeBuddy,10分钟上线MBTI测试网站
  • PiliPlus 非常好用的开源软件第三方B站哔哩哔哩 v1.1.3.35
  • upload-labs通关笔记-第18关文件上传之条件竞争
  • 文件操作和IO-3 文件内容的读写
  • QScrollArea内容增加后自动跳到底部
  • Python生成物理引擎的简单知识图谱