面向服务架构SOA和以太网通信设计方法

汽车ECU开发 2021-11-28 10:25

来源:车载SOAk开发公众号

作者:窦明佳


推荐一个OTA的免费活动:直播预告:车云一体OTA自动化测试及应用


前言:

     SOA在IT行业已经存在很多年,随着近几年智能汽车的出现,用于对于自动驾驶、V2X、智能座舱等新功能的需求也逐渐强烈,汽车逐渐由一个机电耦合的系统转变为一个智能终端,类似智能手机,可升级可进化。面对这样的变革,汽车行业借鉴IT行业的经验引入了SOA及以太网,同时新的技术引入也需要和新的组织架构及开发方法适配,正如康威定律所说的:“Organizations which design systems[……] are constrained to producedesigns which are copies of the communication structures of the organizations.”在目前各OEM的组织架构中基本会划分为动力域、底盘域、车身域(电子电器)、智驾域等部门,因此我们的软件架构也会依据组织架构划分为不同的Domain,然而,引入SOA需要不同以往的跨域协调和通讯,部分职责需要跨域前期的部门和组织边界,协作和合作称为SOA开发成功的先决条件,同时也需要引入新的岗位和专家角色。

   在开发流程方面,为了更好的满足用户需求的快速迭代,一个新功能(Feature)通常通过Use Case(用例)来构建用户的需求,借助于UML(Unified Modelling Language)的建模工具创建Use CaseDiagram,然后进行逻辑功能架构设计、模块架构设计、服务设计等工作定义出服务,再借助于PREEvision工具进行服务实现软件架构的构建,以太网的设计,最终导出ARXML。


一、设计流程总述

本文以基于Classic AutoSAR 平台进行SOA和以太网的设计为例,介绍整个开发流程。

(1)  定义服务Service、服务角色(Service Provider/ServiceConsumer)、服务ID以及服务接口(Service Interface包含Methods,Properties、Events);

(2)  将服务接口及其子元素(Method/Properties/Events)部署到SOME/IP作为以太网的协议栈;

(3)  将服务进行软件实现,即将服务角色(Service Provider/Service Consumer)转换为对应的SoftwareType;

(4)  将服务接口(Service Interface)中的子元素由对应的CP SWC接口实现,例如R&R Method转换为C/S Interface,F&F Method转换为S/R Interface,Field(Getter/Setter)转换为C/S Interface,Event转换为S/R Interface;

(5)  软件组件作为软件类型的实例,其对应的Port端口被创建,同时将SWC Interface(C/Sor S/R)分配给对应的Port;

(6)  在硬件架构层创建以太网网络拓扑;

(7)  将实现服务的软件组件部署到网络拓扑中的对应的ECU上;

(8)  通过Switch Configuration将物理拓扑划分为逻辑网络VLAN;

(9)  信号路由,根据VLAN找到给定网络拓扑中的通信路径,并从服务设计和服务部署衍生出通信描述;

(10)        以太网通信定义,详细的SocketConnection定义;

(11)        数据序列化(Data Serialization),通过以太网传输的数据必须被序列化转换为比特流;

(12)        服务发现(Service Discovery)SOME/IP-SD通信框架定义;

(13)        导出符合AutoSAR规范的ARXML文件,用于Matlab/Simulink软件详细设计及CANoe仿真。


二、服务定义Service Definition

 (1)     服务定义

    定义整车的服务Service,并定义每个服务的服务提供者和服务消费者,以及Service ID和VLAN,同时定义服务的API-Service Interface.


(2)     服务接口定义

        服务的能力及特征由其服务接口定义,服务接口的定义决定了服务消费者如何使用服务,服务接口由如下子元素组成:

  • Properties(Field),描述一条数据,该数据可由服务消费者Client读取或写入,也可以生成一个NotifierEvent如果这个数据发生变化;

  • Event,当事件发生时,服务提供者Service通过Event向订阅的Client发送数据;

  • Method,描述可用的Operation,可以从其他服务进行调用,方法产生并返回一些数据(R&R),或者在服务中启动一些进程(F&F);

(3)     SOME/IP网络绑定

       在上述服务接口定义的基础上,通过CreateSOME/IP Interface Deployment自动将UML服务接口转换为SOME/IP接口,同时可定义传输协议(UDP/TCP),Method/Event ID以及Event Group,同时根据前期定义的Service ID以及Method/Event ID自动生层Message ID。

 (4)     数据类型定义

        创建Application Data Type 、ImplementationData Type 以及Base Data Type,并将BaseType和Implementation Type Mapping,同时将Application DataType和Implementation Data Type进行Mapping,最后将Application Data Type分配给服务接口的子元素。

 

二、服务实现Service Implementation

(1)     服务实现

      服务接口由Software Type来实现,通过Service to AutoSAR Classic Technology Mapping可自动创建Application SW Component Types以及C/S或S/R接口来实现服务和服务接口,每一个服务角色(Servcie Provider/ServiceConsumer)都生成对应的Application SW Component Type。

(2)     服务接口实现

通过上述Servcie to AutoSAR Classic Technology Mapping操作后,不仅为每个服务角色创建对应的Application SW Component Type和C/S以及S/R接口,同时创建对应的Operations 和Data Elements,对于同一个服务接口,R&R-method/Getter-Field/Setter-Field子元素转换为Operations被打包为一个Client/Server Interface,而对于Event/F&F-Method/Notifier-Field将会有单独的SenderReceiver Interface 实现。


三、网络拓扑设计Network Design

        在硬件拓扑层创建网络拓扑图,添加ECU、HPC、Ethernet Switch并创建Bus System Types,在Network Topology Editor表格中选择Bus System并点击Set Ethernet bus and connectorTypes,可为Bus Connectors分配EthernetConnenctor Type,同时为Bus System分配EthernetType,在Network Topology Editor Table选择网络拓扑中创建的Bus System选择Creating missing Cluster,基于Bus Type创建Ethernet Cluster,并自动将Bus System 移动到Ethernet Cluster。对于每一个Ethernet Cluster需要创建对应的Ethernet CommunicationCluster,在Network Topology Editor表格选择CL(Ethernet Cluster)点击Create missing EthernetCommunication Cluster,将在左侧结构树Communication Package创建Transport Layer Package以及Ethernet CommunicationCluster。



 四、以太网通信设计(Ethernet Communication)

(1)     ECU定义(ECUDefinition)

        定义网络拓扑中每一个ECU的ID,该ID用户后期MAC地址的自动计算,以太网物理层类型选择(例如100BASE T1),CNB主从时钟选择,MAC Address生成硬件MAC地址,VLAN 设置VLAN属性,IPV4配置。

 

(2)     以太网Cluster 配置(Ethernet Cluster Configuration)

定义ECU的Socket Addresses,指定传输协议TP,指定传输端口Port,NetworkEndpoint以及IPV4 Address。


五、服务部署/软件映射(Service Deployment/SoftwareMapping)

       在设计完Service以及ServiceInterface,并进行服务实现(Service Implementation)后,并设计完网络拓扑后,在面向服务的系统设计中下一步工作就是进行服务的部署,在将服务角色部署到ECU后,可自动创建实例化的Composition Type,用来实现服务角色,并同步在ECU内部创建Process Unit。


六、软件架构(Software Architecture)

  选择Service Interface,点击Connect ports compatible interface(Select a composition,SW-Componentor SW-port to Start),创建Port,并将Interface分配给Port。

     双击Root Compoistion Package 可自动创建Software Architecture Diagram,将ApplicationSW Component Type拖拽到图中,并选择所有Ports,右键选择Show Path,则自动创建Provider和Consumer SW Component Port口之间的连线。

 

七.信号路由(Signal Routing)

在进行了Servcie Definition、Service Implementation、Network Architecture、Software Mapping,下一步的以太网通信设计工作就是信号路由,信号路由能够从设置VLAN的网络拓扑中寻找通讯路径,并从中获取通信描述,信号路由需要满足的条件:

   定义了Service 和Service Interface;

   进行了服务实现,将ServiceProvider和ServiceConsumer转换为对应Software Type,并将Service Interface转换为C/S和S/R接口,并合成C/S接口的Operaton,以及S/R接口的Data Element;

   将硬件拓扑转换为网络拓扑;

   将服务角色部署到对应的ECU;

   更新Service Implementation,创建SWC Ports并为Ports分配对应的Interface。

在信号路由过程中,需要电定义几个通信Artifacts来完成以太网通信设计:

   Signa和PDU以及Signal和PDU Transmissions被自动创建;

   如果没有进行Switch Configuration,则初始VLAN结构的Switch Configuration被设置,

 

八、Socket Adaptor

        Socket Adaptor提供了基于Socket的以太网通信和Classic AutoSAR面向PDU的通信之间的转换,Socket Adaptor Connection Communication Viewer对于每一个VLAN提供了一个详细的视图,通过Take Over message ID ofService into IPDU header,可自动生成Socket Connection IPDUIdentifier的HeaderID。SocketAdaptor Bundle Communication Viewer提供了Server Sockets的详细视图。

 

九、数据序列化(Data Serialization)

   在以太网传输的数据必须被序列化成比特流,然后在接收端通过反序列化重构数据,选择Signal点击Update data Serialization setting atthe I-Signal,可生成Data Transformer,信号要经过Ldcom,对于每一个Signal-IPDU需要创建如下属性:Protocol:SOMEIP,Transformer Class:SERIALIZER,Version:1, Signal:设置信号长度,SignalIPDU:设置IPDU长度,Signal-IPDU-Assignment:设置Byte Order、Transfer Property,同时对每一个PDU增加Event controlled Timing.

十、服务发现(Service Discovery)

   通过服务发现可以在服务提供者和服务消费者之间建立通信,服务提供者可以通过Offer Service宣布服务可用性及服务位置,服务消费者通过订阅Event Groups来从服务提供者Get Notifications. 在PREEvisionSOA&Ethernet Explorer Service Discovery Category选择VLAN,点击Create Service Discovery,自动生成Socket Address/SocketConnection,通过Service Discovery Subscription创建服务订阅,自动创建Socket Adaptor Routing Group,并将ProvierInstance和ConsumerInstance进行绑定,对于每一个Provide ServiceInstance、Consumer Service Instance,Event Handler、Consumed Event Group,需要进行如下参数设置。

Minor Version:次要版本;

Major Version:主要版本;

Instance Identifier:1,视通信矩阵而定;

Service Identifier:10,视通信矩阵而定;

Offer Cyclic Delay:2,表示Offer方在进入主阶段后Offer报文的发送周期;

Initial Delay Min Value:初始化阶段延迟最小值;

Initial Delay Max Value:初始化阶段延迟最大值;

Initial Repetitions Base Delay:重复阶段报文发送基时;

Initial Repetitions Max:重复阶段报文发送最大次数;

TTL:生存周期,单位为秒;

Multicast Threshold:如果Server在响应订阅时不需要用到多播,该值就设置为0;

Event Group Identifier:事件组ID,视通信矩阵而定,当前为201。

最后可导出Software Component Descrption ARXML文件,导入MatlabSimulink进行进一步的算法开发。

 


总结:

         上述过程是基于PREEvision提供的SOA&Ethernet Exploer集成开发环境进行的,其提供了如下表格所示的10个Category,包含从服务定义到以太网设计的全过程,同时上述过程主要适用于Classic AutoSAR 平台SOA的开发,对于AP平台,PREEvision提供另外一个集成开发环境Adaptive AutoSAR Explorer,同时在服务定义阶段,目前Vector已经开发了接口可以导入由外部工具设计的服务矩阵(Excel文件)。

 

Category

Table Editor

Service Definition

Service Definition Editor

Service Interface Editor

SOME/IP Interface Deployment Editor

Service Interface Data Typr Editor

Service Implementation

Service Implementation Editor

Service Interface Implementation Editor

Network Design

Network Topology Editor

Service Deployment/Software Mapping

Service ECU Deployment Editor

Service Socket Deployment Editor

Software Architecture

Provider

Consumer

Switch Configuration

VLAN Switch Configuration Editor

Switch Load Editor

Multicast MAC Forawarding Editor

Ethernet Communication

ECU Definition

Ethernet Cluster Configuration

VLAN-ECU Allocation

Socket Adaptor

Socket Adaptor Connection Communication  Viewer

Socket Adaptor Bundle Communication  Viewer

Data Serialization

Data Transformation Viewer

Service Discovery

Service Discovery

Service Discovery Subscription

Service Discovery Editor

推荐阅读

关于DTC诊断故障码的获取与清除

沃尔沃:敏捷开发中满足ISO26262的软件安全分析

近万字的NvM学习笔记

特斯拉最新的12V蓄电池有什么不同?

特斯拉最新中央计算模块(CCM)解析

关于对自动驾驶传感器的理解

特斯拉的电池管理系统 (BMS) 相比其他电动车有哪些优势?

2021款特斯拉Model Y ECU接口梳理

详解CANoe之CAPL编程

关于CAN时间同步的理解

dbc文件的格式以及创建详解

大众ID.4 X网络架构详解

学习笔记——NVM数据处理机制

学习笔记——AUTOSAR NVM基础知识

基于UDS的Bootloder详解

关于整车上下电流程的理解

一文详解CAN总线错误帧|附下载

DoIP协议介绍,资料分享!

详解车载网络 OTA系统的开发|文末附下载

一文了解汽车嵌入式AUTOSAR架构|附下载

特斯拉Autopilot系统安全研究|附dbc下载

分享不易,恳请点个【在看】
汽车ECU开发 专注于汽车电子ECU软件开发,技术分享。
评论
  • 光伏逆变器是一种高效的能量转换设备,它能够将光伏太阳能板(PV)产生的不稳定的直流电压转换成与市电频率同步的交流电。这种转换后的电能不仅可以回馈至商用输电网络,还能供独立电网系统使用。光伏逆变器在商业光伏储能电站和家庭独立储能系统等应用领域中得到了广泛的应用。光耦合器,以其高速信号传输、出色的共模抑制比以及单向信号传输和光电隔离的特性,在光伏逆变器中扮演着至关重要的角色。它确保了系统的安全隔离、干扰的有效隔离以及通信信号的精准传输。光耦合器的使用不仅提高了系统的稳定性和安全性,而且由于其低功耗的
    晶台光耦 2024-12-02 10:40 105浏览
  • 艾迈斯欧司朗全新“样片申请”小程序,逾160种LED、传感器、多芯片组合等产品样片一触即达。轻松3步完成申请,境内免费包邮到家!本期热荐性能显著提升的OSLON® Optimal,GF CSSRML.24ams OSRAM 基于最新芯片技术推出全新LED产品OSLON® Optimal系列,实现了显著的性能升级。该系列提供五种不同颜色的光源选项,包括Hyper Red(660 nm,PDN)、Red(640 nm)、Deep Blue(450 nm,PDN)、Far Red(730 nm)及Ho
    艾迈斯欧司朗 2024-11-29 16:55 168浏览
  • 《高速PCB设计经验规则应用实践》+PCB绘制学习与验证读书首先看目录,我感兴趣的是这一节;作者在书中列举了一条经典规则,然后进行详细分析,通过公式推导图表列举说明了传统的这一规则是受到电容加工特点影响的,在使用了MLCC陶瓷电容后这一条规则已经不再实用了。图书还列举了高速PCB设计需要的专业工具和仿真软件,当然由于篇幅所限,只是介绍了一点点设计步骤;我最感兴趣的部分还是元件布局的经验规则,在这里列举如下:在这里,演示一下,我根据书本知识进行电机驱动的布局:这也算知行合一吧。对于布局书中有一句:
    wuyu2009 2024-11-30 20:30 106浏览
  • 概述 说明(三)探讨的是比较器一般带有滞回(Hysteresis)功能,为了解决输入信号转换速率不够的问题。前文还提到,即便使能滞回(Hysteresis)功能,还是无法解决SiPM读出测试系统需要解决的问题。本文在说明(三)的基础上,继续探讨为SiPM读出测试系统寻求合适的模拟脉冲检出方案。前四代SiPM使用的高速比较器指标缺陷 由于前端模拟信号属于典型的指数脉冲,所以下降沿转换速率(Slew Rate)过慢,导致比较器检出出现不必要的问题。尽管比较器可以使能滞回(Hysteresis)模块功
    coyoo 2024-12-03 12:20 71浏览
  • 在电子技术快速发展的今天,KLV15002光耦固态继电器以高性能和强可靠性完美解决行业需求。该光继电器旨在提供无与伦比的电气隔离和无缝切换,是现代系统的终极选择。无论是在电信、工业自动化还是测试环境中,KLV15002光耦合器固态继电器都完美融合了效率和耐用性,可满足当今苛刻的应用需求。为什么选择KLV15002光耦合器固态继电器?不妥协的电压隔离从本质上讲,KLV15002优先考虑安全性。输入到输出隔离达到3750Vrms(后缀为V的型号为5000Vrms),确保即使在高压情况下,敏感的低功耗
    克里雅半导体科技 2024-11-29 16:15 128浏览
  • 遇到部分串口工具不支持1500000波特率,这时候就需要进行修改,本文以触觉智能RK3562开发板修改系统波特率为115200为例,介绍瑞芯微方案主板Linux修改系统串口波特率教程。温馨提示:瑞芯微方案主板/开发板串口波特率只支持115200或1500000。修改Loader打印波特率查看对应芯片的MINIALL.ini确定要修改的bin文件#查看对应芯片的MINIALL.ini cat rkbin/RKBOOT/RK3562MINIALL.ini修改uart baudrate参数修改以下目
    Industio_触觉智能 2024-12-03 11:28 44浏览
  •         温度传感器的精度受哪些因素影响,要先看所用的温度传感器输出哪种信号,不同信号输出的温度传感器影响精度的因素也不同。        现在常用的温度传感器输出信号有以下几种:电阻信号、电流信号、电压信号、数字信号等。以输出电阻信号的温度传感器为例,还细分为正温度系数温度传感器和负温度系数温度传感器,常用的铂电阻PT100/1000温度传感器就是正温度系数,就是说随着温度的升高,输出的电阻值会增大。对于输出
    锦正茂科技 2024-12-03 11:50 70浏览
  • 学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习笔记&记录学习习笔记&记学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&
    youyeye 2024-11-30 14:30 73浏览
  • RDDI-DAP错误通常与调试接口相关,特别是在使用CMSIS-DAP协议进行嵌入式系统开发时。以下是一些可能的原因和解决方法: 1. 硬件连接问题:     检查调试器(如ST-Link)与目标板之间的连接是否牢固。     确保所有必要的引脚都已正确连接,没有松动或短路。 2. 电源问题:     确保目标板和调试器都有足够的电源供应。     检查电源电压是否符合目标板的规格要求。 3. 固件问题: &n
    丙丁先生 2024-12-01 17:37 86浏览
  • 戴上XR眼镜去“追龙”是种什么体验?2024年11月30日,由上海自然博物馆(上海科技馆分馆)与三湘印象联合出品、三湘印象旗下观印象艺术发展有限公司(下简称“观印象”)承制的《又见恐龙》XR嘉年华在上海自然博物馆重磅开幕。该体验项目将于12月1日正式对公众开放,持续至2025年3月30日。双向奔赴,恐龙IP撞上元宇宙不久前,上海市经济和信息化委员会等部门联合印发了《上海市超高清视听产业发展行动方案》,特别提到“支持博物馆、主题乐园等场所推动超高清视听技术应用,丰富线下文旅消费体验”。作为上海自然
    电子与消费 2024-11-30 22:03 86浏览
  • 最近几年,新能源汽车愈发受到消费者的青睐,其销量也是一路走高。据中汽协公布的数据显示,2024年10月,新能源汽车产销分别完成146.3万辆和143万辆,同比分别增长48%和49.6%。而结合各家新能源车企所公布的销量数据来看,比亚迪再度夺得了销冠宝座,其10月新能源汽车销量达到了502657辆,同比增长66.53%。众所周知,比亚迪是新能源汽车领域的重要参与者,其一举一动向来为外界所关注。日前,比亚迪汽车旗下品牌方程豹汽车推出了新车方程豹豹8,该款车型一上市就迅速吸引了消费者的目光,成为SUV
    刘旷 2024-12-02 09:32 101浏览
  • 国产光耦合器正以其创新性和多样性引领行业发展。凭借强大的研发能力,国内制造商推出了适应汽车、电信等领域独特需求的专业化光耦合器,为各行业的技术进步提供了重要支持。本文将重点探讨国产光耦合器的技术创新与产品多样性,以及它们在推动产业升级中的重要作用。国产光耦合器创新的作用满足现代需求的创新模式新设计正在满足不断变化的市场需求。例如,高速光耦合器满足了电信和数据处理系统中快速信号传输的需求。同时,栅极驱动光耦合器支持电动汽车(EV)和工业电机驱动器等大功率应用中的精确高效控制。先进材料和设计将碳化硅
    克里雅半导体科技 2024-11-29 16:18 170浏览
  • 11-29学习笔记11-29学习笔记习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习笔记&记录学习习笔记&记学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&学习学习笔记&记录学习学习笔记&记录学习学习笔记&记
    youyeye 2024-12-02 23:58 52浏览
  • 作为优秀工程师的你,已身经百战、阅板无数!请先醒醒,新的项目来了,这是一个既要、又要、还要的产品需求,ARM核心板中一个处理器怎么能实现这么丰富的外围接口?踌躇之际,你偶阅此文。于是,“潘多拉”的魔盒打开了!没错,USB资源就是你打开新世界得钥匙,它能做哪些扩展呢?1.1  USB扩网口通用ARM处理器大多带两路网口,如果项目中有多路网路接口的需求,一般会选择在主板外部加交换机/路由器。当然,出于成本考虑,也可以将Switch芯片集成到ARM核心板或底板上,如KSZ9897、
    万象奥科 2024-12-03 10:24 41浏览
  • 当前,智能汽车产业迎来重大变局,随着人工智能、5G、大数据等新一代信息技术的迅猛发展,智能网联汽车正呈现强劲发展势头。11月26日,在2024紫光展锐全球合作伙伴大会汽车电子生态论坛上,紫光展锐与上汽海外出行联合发布搭载紫光展锐A7870的上汽海外MG量产车型,并发布A7710系列UWB数字钥匙解决方案平台,可应用于数字钥匙、活体检测、脚踢雷达、自动泊车等多种智能汽车场景。 联合发布量产车型,推动汽车智能化出海紫光展锐与上汽海外出行达成战略合作,联合发布搭载紫光展锐A7870的量产车型
    紫光展锐 2024-12-03 11:38 68浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦