zoukankan      html  css  js  c++  java
  • Adaptive AUTOSAR 学习笔记 5 架构 物理视图

    本系列学习笔记基于 AUTOSAR Adaptive Platform 官方文档 R20-11 版本 AUTOSAR_EXP_PlatformDesign.pdf

    缩写

    AP:AUTOSAR Adaptive Platform
    AA:Adaptive Application
    ARA:AUTOSAR Runtime for Adaptive Applications
    FC:Functional Cluster
    CM:Communication Management
    RS:Requirement Specification
    SWS:Software Specification

    3.2 物理视图

    本节内容仅为解释说明,不能替代正式需求规范,AP 内部仍由实现决定。更多关于 AP 内部架构细节,请参考 EXP_SWArchiteture。

    3.2.1 系统、进程和线程

    AP 操作系统必须提供 POSIX 多进程支持:

    • 每个 AA 都是一个独立的进程,有独立的逻辑内存地址空间和命名空间
    • 注意:一个 AA 可以有多个进程,可以部署在一个 AP 实例或分布在多个 AP 实例上
    • 从模块组织的角度来看,每个进程都是 OS 从可执行文件实例化出来的
    • 多个进程可以由一个可执行文件实例化
    • AA 也可以由多个可执行文件组成

    FC 一般实现为进程:

    • 一个 FC 可以实现为单进程或多进程
    • AP 平台 Service 或 非平台 Service(由 AA 提供的服务)都实现为进程

    以上进程都可以是单线程/多线程。他们能够使用的 OS API 根据他们所在的逻辑层而有所不同:

    • ARA 之上的 AA 只能用 PSE51 规定的接口
    • FC 能使用所有的 OS 接口

    总结:在 OS 看来,AP 和 AA 都是一系列的进程,每个进程包括一个或多个线程。尽管 AP 实现可以对进程进行划分,这些进程之间没有本质区别。进程之间通过 IPC 或其他系统功能(ara::com)交互。注意:AA 进程之间不能直接 IPC 进程间通信,只能借助 ARA 通信。

    3.2.2 基于库或服务的 FC 实现

    如图 3-1 AP 架构逻辑视图所示,一个 FC 可以是 Foundation 也可以是 Service,两者通常都是进程。他们如果想要和 AA(AA 也是进程)通信,需要通过进程间通信。除此之外,还有两种替代设计:

    • 基于库的设计:FC 提供接口库,链接到 AA,直接调用 IPC;
    • 基于服务的设计:进程通过 CM 通信,AA 链接服务代理库。代理库调用 CM 的接口,处理 AA 和 Server 进程的通信。注意:AA 是否只和 CM 直接进程间通信还是混合代理库和 Server 通信是由实现决定的。

    一般来说,如果 FC 只是用于本地 AP 实例,基于库的设计更合适,简单、高效。如果是分布式的场景,用于其他 AP 实例,建议使用基于服务的设计。因为 CM 可以封装差异,忽略 AA 和 Service 的实际部署位置,提供统一的通信方式。AP Foundation 的 FC 都是基于库的,AP Service 的 FC 都是基于服务的,正如他们的名字所指示的那样。

    最后还要注意,只要满足 FC 的 RS 和 SWS,FC 的实现可以只有库,没有进程,即运行在 AA 的上下文。这种情况下,AA 和 FC 的交互就是普通的函数调用,而不是上面所说的 IPC。

    3.2.3 FC 之间的交互

    FC 之间可以按照实现特有的方式交互,因为他们不受限于 ARA 接口。比如 ARA 的 PSE51 接口限制,限制了 IPC。他们可以使用其他 FC 的 ARA public 接口。FC 之间典型的交互模型是使用 FC 的 protected 接口,提供一些特权,以实现特定的 FC 功能。

    此外,从 AP R18-03 开始,引入了新的概念 IFC(Inter-Functional-Cluster)接口,描述了 FC 向其他 FC 提供的接口。注意,这不是 ARA 的一部分,也不是 AP 实现的正式规范。只是通过澄清 FC 之间的交互来帮助开发 AP 规范,并且向 AP 规范的用户提供了更好的架构视角。这些接口在各个 FC 的 SWS 附录中有介绍。

    3.2.4 机器/硬件

    AP 把运行它的硬件叫做机器(Machine),背后的原因是想有个统一的平台,不论底层使用了什么虚拟化技术。机器可以是真实的物理机器、完全虚拟化的机器、准虚拟化的系统、系统级虚拟化的容器或其他任意虚拟环境。

    硬件(一般假定只有单一芯片)之上可以有一个或多个机器,一个机器上只能有一个 AP 实例。只要 AP 的实现支持,也可以多个芯片共同组成一个机器

    更多关于 Adaptive AUTOSAR 文章

    https://www.cnblogs.com/tengzijian/category/1995263.html

  • 相关阅读:
    常用功能测试点的测试用例
    如何设计功能测试测试用例
    管理小原则
    政党提供的公共产品是其存在的依据
    为什么人是根本?
    学问总分类
    和孩子沟通的开头常用语
    教育的核心对象是心中的那枚种子
    用目标激发动力,用计划控制落实,用梳理总结进行提高
    要想影响孩子第一位的是保证沟通畅通
  • 原文地址:https://www.cnblogs.com/tengzijian/p/15022020.html
Copyright © 2011-2022 走看看