嵌入式软件组件经典架构与存储器分类

简介: 嵌入式软件组件经典架构与存储器分类

☞嵌入式软件组件

· 系统软件鼻祖——ROM Monitor监控程序(固件)

  • 存储在非易失性存储设备中的组件称之为固件。
  • ROM Monitor 是运行在嵌入式系统中的一段代码,具有管理系统资源与用户进行交互的功能,具有操作系统内核的一小部分功能。
  • 嵌入式系统正式运行时,通常不需要监控程序的干预,发生故障时,可以作为恢复系统的接口和手段。
  • 只负责监控硬件。

· Boot Loader

  • Boot Loader 与硬件密切相关,但是不完全通用;
  • Boot Loader 是驻留在嵌入式处理器的片上ROM或板上Flash存储区保留分区中的与具体处理器和硬件特性密切相关的一段可启动代码;
  • 应具有最小功能要求,即至少驱动一个外部的数据通信接口,且应该提供至少一种读、写、擦除Flash的方法;
  • 不含应用功能,但具备与外界通信的能力,支持UART、I2C、SPI、Ethernet、CAN等通信接口和协议;(非应用软件)
  • 应该非常清楚系统内存的映射模型;
  • 由特定的IO驱动、通信协议或协议栈、文件系统、用户交互接口、内存映射配置表以及操作系统引导组件等构成;

启动过程:

  • 预启动,通常是指ROM的执行阶段,为 Boot Loader运行做准备;
  • 第一启动阶段(Stage1):Boot Loader 执行基本的初始化代码,初始化堆栈,准备RAM空间,并将下一阶段代码拷贝到RAM特定位置后,跳转至下一阶段的代码入口点执行;
  • 第二启动阶段(Stage2):Stage2的代码在内存中运行,无内存容量限制,可设计复杂功能;

· BSP——板级支持包

  • 与硬件密切相关的功能软件包;
  • 系统上电时,对硬件初始化功能;
  • 为操作系统提供访问硬件所需要的驱动程序以及中断服务程序;
  • 集成的硬件相关/无关的操作系统所需要的引导模块;

· 嵌入式虚拟化技术

虚拟机:零型虚拟机、轻量级虚拟机。

☞嵌入式系统经典架构

软件移植时,只需要改动操作系统适配层即可,比如说微信APP既可以运行于安卓又可以运行于苹果系统等。

☞存储器分类

· 易失性存储器

  • RAM:Random Access Memory,随机存储器,随机存储是指当存储器中的数据被读取或者写入时,所需要的时间与这段数据所在的位置无关(区别于顺序存储)。
  • DRAM:动态随机存储器,存储单元以电容的电荷表示数据,有电荷为1,无电荷为0。但是这种状态不能长久保持,因为电量为1时会释放电荷,为0时会吸收电荷,所以需要定时来刷新。速度慢、集成度高、成本低、用于CPU外部扩展内存。
  • SDRAM:可同步通讯(需要时钟),上升沿有效。
  • DDR SDRAM:Double Data Rate SDRAM,边沿有效(上升沿和下降沿都有效),一个周期内可以表示两个数据,时钟频率高,速度快。
  • SRAM:静态随机存储器,存储单元使用锁存器存储数据。速度快、集成度低、成本高、用于CPU内部高速缓存Cache。
  • SSRAM:同步通讯静态随机存储器。

· 非易失性存储器

  • ROM:非易失性半导体存储器,现在也有可以写入的ROM,所以ROM并非是只读存储器。
  • MASK ROM:只读存储器,成本低。
  • OTPROM:One Time Programmable ROM,一次可编程存储器,只能写入一次,可以用来存储密钥,使用专用编程器写入。
  • EPROM:Erasable Programmable ROM,可重复擦写存储器,可以重复擦除写入,需要专用设备写入和擦除。
  • EEPROM:Electrically Erasable Programmable ROM,电可擦除,使用电路控制写入擦除,并且按照字节来修改数据,无需擦除整个芯片。(主流)
  • FLASH:闪存,可以重复擦写,按照扇区进行擦除。
  • NOR FLASH:价格贵、集成度低、随机存取,地址线与数据线独立分开,以扇区或块进行擦除,可基于字节读写,读取速度快,但是写入速度慢,支持XIP,坏块较少。在写入数据前需要先擦除,一般用于存储代码,比如嵌入式控制器内部程序存储空间。

NAND FLASH:价格便宜、集成度高、连续存储,地址线和数据线共用,以扇区或块进行擦除,以块为单位进行读写,读取速度慢,写入速度快,不支持XIP,坏块较多。写入前需要先擦除,一般用于存储大量数据,比如SD卡、U盘、固态硬盘等。

相关文章
|
3月前
|
消息中间件 存储 Java
RocketMQ(一):消息中间件缘起,一览整体架构及核心组件
【10月更文挑战第15天】本文介绍了消息中间件的基本概念和特点,重点解析了RocketMQ的整体架构和核心组件。消息中间件如RocketMQ、RabbitMQ、Kafka等,具备异步通信、持久化、削峰填谷、系统解耦等特点,适用于分布式系统。RocketMQ的架构包括NameServer、Broker、Producer、Consumer等组件,通过这些组件实现消息的生产、存储和消费。文章还提供了Spring Boot快速上手RocketMQ的示例代码,帮助读者快速入门。
|
2月前
|
运维 负载均衡 Shell
控制员工上网软件:高可用架构的构建方法
本文介绍了构建控制员工上网软件的高可用架构的方法,包括负载均衡、数据备份与恢复、故障检测与自动切换等关键机制,以确保企业网络管理系统的稳定运行。通过具体代码示例,展示了如何实现这些机制。
133 63
|
2月前
|
监控 前端开发 数据可视化
3D架构图软件 iCraft Editor 正式发布 @icraft/player-react 前端组件, 轻松嵌入3D架构图到您的项目,实现数字孪生
@icraft/player-react 是 iCraft Editor 推出的 React 组件库,旨在简化3D数字孪生场景的前端集成。它支持零配置快速接入、自定义插件、丰富的事件和方法、动画控制及实时数据接入,帮助开发者轻松实现3D场景与React项目的无缝融合。
226 8
3D架构图软件 iCraft Editor 正式发布 @icraft/player-react 前端组件, 轻松嵌入3D架构图到您的项目,实现数字孪生
|
2月前
|
SQL 数据采集 分布式计算
【赵渝强老师】基于大数据组件的平台架构
本文介绍了大数据平台的总体架构及各层的功能。大数据平台架构分为五层:数据源层、数据采集层、大数据平台层、数据仓库层和应用层。其中,大数据平台层为核心,负责数据的存储和计算,支持离线和实时数据处理。数据仓库层则基于大数据平台构建数据模型,应用层则利用这些模型实现具体的应用场景。文中还提供了Lambda和Kappa架构的视频讲解。
293 3
【赵渝强老师】基于大数据组件的平台架构
|
2月前
|
Kubernetes 前端开发 分布式数据库
工作中常见的软件系统部署架构
在实际应用中,会根据项目的具体需求、规模、性能要求等因素选择合适的部署架构,或者综合使用多种架构模式来构建稳定、高效、可扩展的系统。
295 2
|
3月前
|
SQL 存储 分布式计算
大数据-157 Apache Kylin 背景 历程 特点 场景 架构 组件 详解
大数据-157 Apache Kylin 背景 历程 特点 场景 架构 组件 详解
54 9
|
3月前
|
消息中间件 运维 NoSQL
基础架构组件选型及服务化
【10月更文挑战第15天】本文概述了分布式系统中常见的基础架构组件及其选型与服务化的重要性。
|
1月前
|
弹性计算 API 持续交付
后端服务架构的微服务化转型
本文旨在探讨后端服务从单体架构向微服务架构转型的过程,分析微服务架构的优势和面临的挑战。文章首先介绍单体架构的局限性,然后详细阐述微服务架构的核心概念及其在现代软件开发中的应用。通过对比两种架构,指出微服务化转型的必要性和实施策略。最后,讨论了微服务架构实施过程中可能遇到的问题及解决方案。
|
2月前
|
Cloud Native Devops 云计算
云计算的未来:云原生架构与微服务的革命####
【10月更文挑战第21天】 随着企业数字化转型的加速,云原生技术正迅速成为IT行业的新宠。本文深入探讨了云原生架构的核心理念、关键技术如容器化和微服务的优势,以及如何通过这些技术实现高效、灵活且可扩展的现代应用开发。我们将揭示云原生如何重塑软件开发流程,提升业务敏捷性,并探索其对企业IT架构的深远影响。 ####
62 3
|
2月前
|
Cloud Native 安全 数据安全/隐私保护
云原生架构下的微服务治理与挑战####
随着云计算技术的飞速发展,云原生架构以其高效、灵活、可扩展的特性成为现代企业IT架构的首选。本文聚焦于云原生环境下的微服务治理问题,探讨其在促进业务敏捷性的同时所面临的挑战及应对策略。通过分析微服务拆分、服务间通信、故障隔离与恢复等关键环节,本文旨在为读者提供一个关于如何在云原生环境中有效实施微服务治理的全面视角,助力企业在数字化转型的道路上稳健前行。 ####

热门文章

最新文章