嵌入式系统硬件抽象层(HAL & BSP)的设计思想--第一部分

嵌入式系统硬件抽象层(HAL & BSP)的设计思想--第一部分

  • 1 前言
    • 特点
    • 1.1 层次化思想
    • 1.2 模块化思想
    • 1.3 对象化思想
  • 2 板级支持包(BSP)
  • 3 嵌入式系统硬件抽象层的原理
    • 3.1 硬件抽象层的引入
    • 3.2 BSP的特点与功能
    • 3.3 BSP的设计与实现
      • 嵌入式系统初始化以及BSP的功能
      • 硬件相关的设备驱动程序
    • 3.4 设计实现BSP的方法
      • 设计实现BSP的一般方法
      • 方法一:以经典BSP为参考
      • 方法二:使用操作系统提供的BSP模板
    • 3.5 BSP设计方法的不足与改进

此设计思想针对嵌入式系统RTOS级别(BSP),而非Linux级别(POSIX标准接口)。

文章来源:
https://blog.csdn.net/devillyd2018/article/details/91375124

https://blog.csdn.net/deniro_li/article/details/108919150

https://baike.baidu.com/item/%E7%A1%AC%E4%BB%B6%E6%8A%BD%E8%B1%A1%E5%B1%82/9084603?fr=aladdin

1 前言

硬件抽象层是位于操作系统内核与硬件电路之间的接口层,其目的在于将硬件抽象化。它隐藏了特定平台的硬件接口细节,为操作系统提供虚拟硬件平台,使其具有硬件无关性,可在多种平台上进行移植。 从软硬件测试的角度来看,软硬件的测试工作都可分别基于硬件抽象层来完成,使得软硬件测试工作的并行进行成为可能。

硬件抽象层是一个编程层,允许计算机操作系统在逻辑层而不是硬件层与硬件设备交互。

嵌入式操作系统的设计是一个涉及嵌入式软件、硬件的方方面面的非常复杂的问题,解决这个问题可基于这样一个基本原理:问题分解,各个击破。设计易于移植的嵌入式平台,应遵循层次化、模块化和对象化的设计方法 [1] 。

特点

硬件抽象层与硬件密切相关性;
硬件抽象层与操作系统无关性;
硬件抽象层接口定义的功能应包含硬件或系统所需硬件支持的所有功能;
硬件抽象层接口定义应该简单明了,如果定义太多接口,会增加软件模拟的复杂性;
具有可测性的接口设计有利于系统的软硬件测试和集成。

嵌入式系统硬件抽象层(HAL & BSP)的设计思想--第一部分_第1张图片

嵌入式系统硬件抽象层(HAL & BSP)的设计思想--第一部分_第2张图片

1.1 层次化思想

层次化设计对于嵌入式操作系统而言,体现在嵌入式操作系统的纵向结构上。为了适应多种硬件平台,将操作系统划分出来一个可以直接和硬件通讯的层次,然后为其上层提供抽象支持,下层通过API的形式向上层提供服务。这样上层在进行硬件操作时,不需要了解设备的具体细节,从而大大减少系统理解和开发的复杂度。所以,层次化的方法主要有以下优点:节省成本、易于理解、易于扩展、易于排错。

1.2 模块化思想

模块化最大特点就是将接口和实现分离开来,将具体的功能块隐藏在抽象的接口背后,以保证每个模块可以在不影响其他模块的情况下进行改变。这样,可将模块之间的依赖关系仅仅限定于接口。模块化方法与层次化方法不同,软件模块之间是相互独立的关系,而不是层次之间相互依赖的关系。

1.3 对象化思想

就当前的目的来说,对象是结构化使用模块的方法。面向对象设计方法将数据与数据上的操作封装在对象这个模块实体中,外界不能直接对对象内部进行访问和操作,只能通过消息的方式间接访问。因此,面向对象设计方法能够使软件开发人员更加容易理解,并且也提高了软件的扩展性、维护性和重用性。
下面具体讲述了这些功能实现的原理。
首先,为了更好地实现嵌入式系统中硬件相关和硬件无关两部分程序代码的隔离,使得硬件抽象层为上层软件提供一个已屏蔽硬件差异的接口,可将HAL进一步细化为几个子层次,即采用层次结构设计的思想。那么,在层次结构设计中,各子层之间定义了统一的接口调用。这些接口采用C/C++语言进行编码,即下层的功能实现需要按照与上层确定的接口规范来进行。而这些上下层之间的接口是使用宏定义的方式进行的。宏定义在预编译时进行替换,没有执行时的性能损失。在系统初始化阶段,片级初始化、板级初始化和系统级初始化基本上就是使用了宏定义这一特点。
其次,为保证开发语言的移植性,引入面向对象的思想。C语言虽不能直接支持面向对象的数据结构,如数据类型的动态绑定、多态函数或类继承。但在设计时可以借鉴面向对象语言的特点实现基于C语言的对象,却又不依赖于它。这样,就使系统开发难度大为降低。

2 板级支持包(BSP)

是嵌入式系统中常用的硬件抽象形式,是介于操作系统和硬件之间的软件层次。介绍BSP的功能和特点,并结合工作实践提出了设计BSP的一般方法;最后针对当前嵌入式系统中BSP的设计方法所面临的问题提出了可行的解决办法。

随着计算机硬件技术的快速发展,出现了越来越多的便携设备和智能设备。这些设备中通常包含控制用的CPU和相应的操作系统;这类特殊的计算机系统叫做嵌入式实时系统。嵌入式实时系统以其简洁高效等特点在计算机、通信等领域中广泛使用。

由于嵌入式实时系统应用环境的特殊性,因此在设计实现过程中存在着许多特殊问题。其中,操作系统及其他系统软件模块与硬件之间的接口形式是嵌入式实时系统的主要特征和系统设计过程中的必需环节,也是影响嵌入式系统应用前景的关键问题。经过近些年的发展,随着通用嵌入式操作系统技术的日趋成熟和应用的不断扩大,一种统一的接口形式得到广泛的认可和应用,这就是通常所说的板级支持包,即BSP。

3 嵌入式系统硬件抽象层的原理

3.1 硬件抽象层的引入

嵌入式实时系统作为一类特殊的计算机系统自底向上包含三个部分,如图1所示。

(1)硬件环境:是整个嵌入式实时操作系统实时应用程序运行的硬件平台;不同的应用通常有不同的硬件环境;硬件平台的多样性是嵌入式系统的一个主要特点。

(2)嵌入式实时操作系统——RTOS:完成嵌入式实时应用的任务调度和控制等核心功能,具有内核较精简、可配置、与高层应用紧密关联等特点。嵌入式操作系统具有相对不变性。

(3)嵌入式实时应用程序:运行于操作系统之上,利用操作系统提供的实时机制完成特定功能的嵌入式应用。不同的系统需要设计不同的嵌入式实时应用程序。

由于嵌入式系统应用的硬件环境差异较大,因此,如何简洁有效地使嵌入式系统能够应用于各种不同的应用环境是嵌入式系统发展中所必须解决的关键问题。

经过不断的发展,原先嵌入式系统的三层结构逐步演化成为一种四层结构。这个新增加的中间层次位于操作系统和硬件之间,包含了系统中与硬件相关的大部分功能。通过特定的上层接口与操作系统进行交互,向操作系统提供底层的硬件信息;并根据操作系统的要求完成对硬件的直接操作。由于引入了一个中间层次,展蔽了底层硬件的多样性,操作系统不再直接面对具体的硬件环境。而是面向由这个中间层次所代表的、逻辑上的硬件环境。因此,把这个中间层次叫做硬件抽象层HAL(Hardware Abstraction Layer)。在目前的嵌入式领域中通常也把HAL叫做板级支持包BSP(Board Support Package)。图2显示了引入HAL以后的嵌入式系统结构。BSP的引入大大推动了嵌入式实时操作系统的通用化,从而为嵌入式系统的广泛应用提供了可能。

3.2 BSP的特点与功能

HAL/BSP的提出使通用的嵌入式操作系统及高层的嵌入式应用能够有效地运行于特定的、应用相关的硬件环境之上,使担任系统和应用程序能够控制和操作具体的硬件设备,完成特定的功能。因此,在绝大多数的嵌入式系统中,BSP是一个必不可少的层次。

由于在系统中的特殊位置,因此BSP具有以下主要特点:

(1)硬件相关性

因为嵌入式实时系统的硬件环境具有应用相关性,所以,作为高层软件与硬件之间的接口,BSP必须为操作系统提供操作和控制具体硬件的方法。

(2)操作系统相关性

不同的操作系统具有各自的软件层次结构, 因此,不同的操作系统具有特定的硬件接口形式。

在实现上,BSP是一个介于操作系统和底层硬件之间的软件层次,包括了系统中大部分与硬件相关的软件模块。在功能上包含两部分:系统初始化及与硬件相关的设备驱动。

3.3 BSP的设计与实现

为实现上述两部分功能,设计一个完整的BSP需要完成两部分工作:

(1)设计初始化过程,完成嵌入式系统的初始化;

(2)设计硬件相关的设备驱动,完成操作系统及应用程序对具体硬件的操作。

嵌入式系统初始化以及BSP的功能

嵌入式系统的初始化过程是一个同时包括硬件初始化和软件(主要是操作系统及系统软件模块)初始化的过程;而操作系统启动以前的初始化操作是BSP的主要功能之一。由于嵌入式系统不仅具有硬件环境的多样性,同时具有软件的可配置性,因此,不同的嵌入式系统初始化所涉及的内容各不相同,复杂程度也不尽相同。但是初始化过程总是可以抽象为三个主要环境,按照自底向上、从硬件到软件的次序依次为:片级初始化、板级初始化和系统级初始化。

(1)片级初始化: 主要完成CPU的初始化,包括设置CPU的核心寄存器和控制寄存器,CPU核心工作模式以及CPU的局部总线模式等。片级初始化把CPU从上电时的缺省状态逐步设置成为系统所要求的工作状态。这是一个纯硬件的初始化过程。

(2)板级初始化: 完成CPU以外的其他硬件设备的初始化。除此之外,还要设置某些软件的数据结构和参数,为随后的系统级初始化和应用程序的运行建立硬件和软件环境。这是一个同时饮食软硬件两部分在内的初始化过程。

(3)系统级初始化: 这是一个以软件初始化为主的过程,主要进行操作系统初始化。BSP将控制转交给操作系统,由操作系统进行余下的初始化操作。包括加载和初始化与硬件无关的设备驱动程序,建立系统内存区,加载并初始化其他系统软件模块,比如网络系统、文件系统等;最后,操作系统创建应用程序环境并将控制转交给应用程序的入口。

经过以上三个层次的操作,嵌入式系统运行所需要的硬件和软件环境已经进行了正确设置,从这里开始,高层的实时应用程序可以运行了。

需要指出:系统级初始化不是BSP的工作。但是,系统级初始化成功与否的关键在于BSP的前两个初始化过程中所进行的软件和硬件的正确设置,而且系统级初始化也是由BSP发起的。因此,设计BSP中初始化功能的重点主要集中在前两个环节。图3显示了嵌入式系统的初始化过程。

硬件相关的设备驱动程序

BSP另一个主要功能是硬件相关的设备驱动。与初始化过程相反,硬件相关的设备驱动程序的初始化和使用通常是一个从高层到底层的过程。

尽管BSP中包含硬件相关的设备驱动程序,但是这些设备驱动程序通常不直接由BSP使用,而是在系统初始化过程中由BSP把它们与操作系统中通用的设备驱动程序关联起来,并在随后的应用中由通用的设备驱动程序调用,实现对硬件设备的操作。设计与硬件相关的驱动程序是BSP设计中另一个关键环节。图4显示了调用设备驱动程序时系统各个层次之间的关系。

3.4 设计实现BSP的方法

设计实现BSP的一般方法

因为BSP同时具硬件相关性和操作系统相关性,是一个介于硬件与软件之间的中间层次。因此BSP的开发不仅需要具备一定的硬件知识,例如CPU的控制、中断控制器的设置、内存控制器的设置及有关的总线规范等;同时还要求掌握操作系统所定义的BSP接口。另外,在BSP的初始化部分通常会包含一些汇编代码,因此还要求对所使用的CPU汇编指令有所了解,例如X86的汇编和PowerPC的汇编指令等;对于某些复杂的BSP还要了解所使用的开发工具,例如GNU、Diab Data等。

总之,开发BSP要求具备比较全面的软、硬件知识和必要的编程经验。由于设计实现的复杂性,在设计特定BSP时很少从零开始,而是采用以下两种快捷方法。

方法一:以经典BSP为参考

在设计BSP时,首先选择与应用硬件环境最为相似的参考设计,例如Motorola的ADS系列评估板等。针对这些评估板,不同的操作系数都会提供完整的BSP,这些BSP是学习和开发自己BSP的最佳参考。针对具体应用的特定环境对参考设计的BSP进行必要的修改和增加,就可以完成简单的BSP设计。

下面以设计pSOS操作系统的BSP初始化过程为例。PSOS系统初始化的层次非常清晰,与初始化过程相对应的是以下三个文件:

1)init.s:对应于片级初始化;完成CPU的初始化操作,设置CPU的工作状态;

2)board.c:对庆于板级初始化;继续CPU初始化,并设置CPU以外的硬件设备;

3)sysinit.c:对应于系统级初始化;完成操作系统的初始化,并启动应用程序。

以参考BSP为切入点,针对初始化过程的具体环节,在对应的文件中进行某些参数的修改及功能的增加就可以实现BSP的系统初始化功能。

因为BSP具有操作系统相关性,因此,不同的操作系统会使用不同的文件完成类似的初初化操作。

BSP中硬件相关的设备驱动程序随操作系统的不同而具有比较大的差异,设计过程中应参照操作系统相应的接口规范。

方法二:使用操作系统提供的BSP模板

除了提供某些评估板的BPS以外,很多操作系统还提供相应的BSP模板(一组需要编写的文件),根据模板的提示也可以逐步完成特定BSP的设计。

相比较而言,第一种方法最为简单快捷。因此,在实际的设计过程中,通常以第一种方法为主,同时结合使用第二种方法。

在设计实现BSP两部分功能时应采用以下两种不同方法:

(1)“自底向上”地实现BSP中的初始化操作:从片级初始化开始到系统初始化;

(2)“自顶向下”地设计硬件相关的驱动程序:从API开始,到操作系统内部的通用设备驱动程序,再到BSP内部的硬件相关的设备驱动程序,最后到底层具体的硬件设备。

3.5 BSP设计方法的不足与改进

从以上介绍的两种设计方法可以看出:目前BSP的设计与实现主要是针对某些特定的文件进行修改。这种方法比较原始,它不仅要求设计人员了解BSP的各个组成部分及所对应的文件和相关参数的具体含义,还要求具备比较全面的软硬件知识。直接修改相关文件容易造成代码的不一致性,增加软件设计上的隐形错误,从而增加系统调试和代码维护的难度。随着底层硬件功能的日益复杂,开发BSP所涉及的内容也越来越多。这种原始方法的足之处也越来越突出。进行BSP设计方法和工具的创新成为一个日益突出的问题。

解决这个问题的一个可行办法是:设计实现一种具有图形界面的BSP开发设计向导,由该向导指导设计者逐步完成BSP的设计和开发,并最终由向导生成相应的BSP文件,而不再由设计人员直接对源文件进行修改。这样不仅可以大大缩短BSP的开发周期,减少代码不一致性,而且系统排错、调试以及维护都很简单。因此,这种方法是目前嵌入式领域中BSP设计的一个趋势和研究方向。但是,由于嵌入式系统硬件环境的多样性,设计向导的实现仍需解决若干关键问题。为此,作者仍将在这一方面作进一步研究。

你可能感兴趣的:(嵌入式MCU,c语言,c++,mcu,物联网,嵌入式硬件)