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

汽车电子与软件 2021-11-28 17:20

前言:

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


阅读原文,关注作者知乎

END
汽车电子与软件 主要介绍汽车电子软件设计相关内容,每天分享一篇技术文章!
评论
  • 随着消费者对汽车驾乘体验的要求不断攀升,汽车照明系统作为确保道路安全、提升驾驶体验以及实现车辆与环境交互的重要组成,日益受到业界的高度重视。近日,2024 DVN(上海)国际汽车照明研讨会圆满落幕。作为照明与传感创新的全球领导者,艾迈斯欧司朗受邀参与主题演讲,并现场展示了其多项前沿技术。本届研讨会汇聚来自全球各地400余名汽车、照明、光源及Tier 2供应商的专业人士及专家共聚一堂。在研讨会第一环节中,艾迈斯欧司朗系统解决方案工程副总裁 Joachim Reill以深厚的专业素养,主持该环节多位
    艾迈斯欧司朗 2025-01-16 20:51 326浏览
  • 故障现象 一辆2007款日产天籁车,搭载VQ23发动机(气缸编号如图1所示,点火顺序为1-2-3-4-5-6),累计行驶里程约为21万km。车主反映,该车起步加速时偶尔抖动,且行驶中加速无力。 图1 VQ23发动机的气缸编号 故障诊断接车后试车,发动机怠速运转平稳,但只要换挡起步,稍微踩下一点加速踏板,就能感觉到车身明显抖动。用故障检测仪检测,发动机控制模块(ECM)无故障代码存储,且无失火数据流。用虹科Pico汽车示波器测量气缸1点火信号(COP点火信号)和曲轴位置传感器信
    虹科Pico汽车示波器 2025-01-23 10:46 74浏览
  •  光伏及击穿,都可视之为 复合的逆过程,但是,复合、光伏与击穿,不单是进程的方向相反,偏置状态也不一样,复合的工况,是正偏,光伏是零偏,击穿与漂移则是反偏,光伏的能源是外来的,而击穿消耗的是结区自身和电源的能量,漂移的载流子是 客席载流子,须借外延层才能引入,客席载流子 不受反偏PN结的空乏区阻碍,能漂不能漂,只取决于反偏PN结是否处于外延层的「射程」范围,而穿通的成因,则是因耗尽层的过度扩张,致使跟 端子、外延层或其他空乏区 碰触,当耗尽层融通,耐压 (反向阻断能力) 即告彻底丧失,
    MrCU204 2025-01-17 11:30 210浏览
  • 现在为止,我们已经完成了Purple Pi OH主板的串口调试和部分配件的连接,接下来,让我们趁热打铁,完成剩余配件的连接!注:配件连接前请断开主板所有供电,避免敏感电路损坏!1.1 耳机接口主板有一路OTMP 标准四节耳机座J6,具备进行音频输出及录音功能,接入耳机后声音将优先从耳机输出,如下图所示:1.21.2 相机接口MIPI CSI 接口如上图所示,支持OV5648 和OV8858 摄像头模组。接入摄像头模组后,使用系统相机软件打开相机拍照和录像,如下图所示:1.3 以太网接口主板有一路
    Industio_触觉智能 2025-01-20 11:04 194浏览
  • 本文介绍瑞芯微开发板/主板Android配置APK默认开启性能模式方法,开启性能模式后,APK的CPU使用优先级会有所提高。触觉智能RK3562开发板演示,搭载4核A53处理器,主频高达2.0GHz;内置独立1Tops算力NPU,可应用于物联网网关、平板电脑、智能家居、教育电子、工业显示与控制等行业。源码修改修改源码根目录下文件device/rockchip/rk3562/package_performance.xml并添加以下内容,注意"+"号为添加内容,"com.tencent.mm"为AP
    Industio_触觉智能 2025-01-17 14:09 203浏览
  •     IPC-2581是基于ODB++标准、结合PCB行业特点而指定的PCB加工文件规范。    IPC-2581旨在替代CAM350格式,成为PCB加工行业的新的工业规范。    有一些免费软件,可以查看(不可修改)IPC-2581数据文件。这些软件典型用途是工艺校核。    1. Vu2581        出品:Downstream     
    电子知识打边炉 2025-01-22 11:12 134浏览
  • 数字隔离芯片是一种实现电气隔离功能的集成电路,在工业自动化、汽车电子、光伏储能与电力通信等领域的电气系统中发挥着至关重要的作用。其不仅可令高、低压系统之间相互独立,提高低压系统的抗干扰能力,同时还可确保高、低压系统之间的安全交互,使系统稳定工作,并避免操作者遭受来自高压系统的电击伤害。典型数字隔离芯片的简化原理图值得一提的是,数字隔离芯片历经多年发展,其应用范围已十分广泛,凡涉及到在高、低压系统之间进行信号传输的场景中基本都需要应用到此种芯片。那么,电气工程师在进行电路设计时到底该如何评估选择一
    华普微HOPERF 2025-01-20 16:50 122浏览
  • 80,000人到访的国际大展上,艾迈斯欧司朗有哪些亮点?感未来,光无限。近日,在慕尼黑electronica 2024现场,ams OSRAM通过多款创新DEMO展示,以及数场前瞻洞察分享,全面展示自身融合传感器、发射器及集成电路技术,精准捕捉并呈现环境信息的卓越能力。同时,ams OSRAM通过展会期间与客户、用户等行业人士,以及媒体朋友的深度交流,向业界传达其以光电技术为笔、以创新为墨,书写智能未来的深度思考。electronica 2024electronica 2024构建了一个高度国际
    艾迈斯欧司朗 2025-01-16 20:45 973浏览
  • 嘿,咱来聊聊RISC-V MCU技术哈。 这RISC-V MCU技术呢,简单来说就是基于一个叫RISC-V的指令集架构做出的微控制器技术。RISC-V这个啊,2010年的时候,是加州大学伯克利分校的研究团队弄出来的,目的就是想搞个新的、开放的指令集架构,能跟上现代计算的需要。到了2015年,专门成立了个RISC-V基金会,让这个架构更标准,也更好地推广开了。这几年啊,这个RISC-V的生态系统发展得可快了,好多公司和机构都加入了RISC-V International,还推出了不少RISC-V
    丙丁先生 2025-01-21 12:10 595浏览
  • 2024年是很平淡的一年,能保住饭碗就是万幸了,公司业绩不好,跳槽又不敢跳,还有一个原因就是老板对我们这些员工还是很好的,碍于人情也不能在公司困难时去雪上加霜。在工作其间遇到的大问题没有,小问题还是有不少,这里就举一两个来说一下。第一个就是,先看下下面的这个封装,你能猜出它的引脚间距是多少吗?这种排线座比较常规的是0.6mm间距(即排线是0.3mm间距)的,而这个规格也是我们用得最多的,所以我们按惯性思维来看的话,就会认为这个座子就是0.6mm间距的,这样往往就不会去细看规格书了,所以这次的运气
    wuliangu 2025-01-21 00:15 321浏览
  • 日前,商务部等部门办公厅印发《手机、平板、智能手表(手环)购新补贴实施方案》明确,个人消费者购买手机、平板、智能手表(手环)3类数码产品(单件销售价格不超过6000元),可享受购新补贴。每人每类可补贴1件,每件补贴比例为减去生产、流通环节及移动运营商所有优惠后最终销售价格的15%,每件最高不超过500元。目前,京东已经做好了承接手机、平板等数码产品国补优惠的落地准备工作,未来随着各省市关于手机、平板等品类的国补开启,京东将第一时间率先上线,满足消费者的换新升级需求。为保障国补的真实有效发放,基于
    华尔街科技眼 2025-01-17 10:44 238浏览
  •  万万没想到!科幻电影中的人形机器人,正在一步步走进我们人类的日常生活中来了。1月17日,乐聚将第100台全尺寸人形机器人交付北汽越野车,再次吹响了人形机器人疯狂进厂打工的号角。无独有尔,银河通用机器人作为一家成立不到两年时间的创业公司,在短短一年多时间内推出革命性的第一代产品Galbot G1,这是一款轮式、双臂、身体可折叠的人形机器人,得到了美团战投、经纬创投、IDG资本等众多投资方的认可。作为一家成立仅仅只有两年多时间的企业,智元机器人也把机器人从梦想带进了现实。2024年8月1
    刘旷 2025-01-21 11:15 658浏览
  • Ubuntu20.04默认情况下为root账号自动登录,本文介绍如何取消root账号自动登录,改为通过输入账号密码登录,使用触觉智能EVB3568鸿蒙开发板演示,搭载瑞芯微RK3568,四核A55处理器,主频2.0Ghz,1T算力NPU;支持OpenHarmony5.0及Linux、Android等操作系统,接口丰富,开发评估快人一步!添加新账号1、使用adduser命令来添加新用户,用户名以industio为例,系统会提示设置密码以及其他信息,您可以根据需要填写或跳过,命令如下:root@id
    Industio_触觉智能 2025-01-17 14:14 145浏览
  • 高速先生成员--黄刚这不马上就要过年了嘛,高速先生就不打算给大家上难度了,整一篇简单但很实用的文章给大伙瞧瞧好了。相信这个标题一出来,尤其对于PCB设计工程师来说,心就立马凉了半截。他们辛辛苦苦进行PCB的过孔设计,高速先生居然说设计多大的过孔他们不关心!另外估计这时候就跳出很多“挑刺”的粉丝了哈,因为翻看很多以往的文章,高速先生都表达了过孔孔径对高速性能的影响是很大的哦!咋滴,今天居然说孔径不关心了?别,别急哈,听高速先生在这篇文章中娓娓道来。首先还是要对各位设计工程师的设计表示肯定,毕竟像我
    一博科技 2025-01-21 16:17 159浏览
  • 临近春节,各方社交及应酬也变得多起来了,甚至一月份就排满了各式约见。有的是关系好的专业朋友的周末“恳谈会”,基本是关于2025年经济预判的话题,以及如何稳定工作等话题;但更多的预约是来自几个客户老板及副总裁们的见面,他们为今年的经济预判与企业发展焦虑而来。在聊天过程中,我发现今年的聊天有个很有意思的“点”,挺多人尤其关心我到底是怎么成长成现在的多领域风格的,还能掌握一些经济趋势的分析能力,到底学过哪些专业、在企业管过哪些具体事情?单单就这个一个月内,我就重复了数次“为什么”,再辅以我上次写的:《
    牛言喵语 2025-01-22 17:10 175浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦