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

关注公众号,点击公众号主页右上角“ ··· ”,设置星标,实时关注智能汽车电子与软件最新资讯


来源:车载SOAk开发
作者:窦明佳

前言:


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已经开发了接口可以导入由外部工具设计的服务矩阵。


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


关注公众号,点击公众号主页右上角“ ··· ”,设置星标,实时关注智能汽车电子与软件最新资讯

免责声明】文章为作者独立观点,不代表旺材汽车电子立场。如因作品内容、版权等存在问题,请于本文刊发30日内联系旺材汽车电子进行删除或洽谈版权使用事宜。

智能汽车电子与软件 专注于汽车电子领域的信息交融平台,涵盖汽车电子行业资讯、市场动态、技术干货、知识见解、行业趋势等资讯深度覆盖。
评论
  • 根据环洋市场咨询(Global Info Research)项目团队最新调研,预计2030年全球中空长航时无人机产值达到9009百万美元,2024-2030年期间年复合增长率CAGR为8.0%。 环洋市场咨询机构出版了的【全球中空长航时无人机行业总体规模、主要厂商及IPO上市调研报告,2025-2031】研究全球中空长航时无人机总体规模,包括产量、产值、消费量、主要生产地区、主要生产商及市场份额,同时分析中空长航时无人机市场主要驱动因素、阻碍因素、市场机遇、挑战、新产品发布等。报告从中空长航时
    GIRtina 2025-01-09 10:35 25浏览
  • 光伏逆变器是一种高效的能量转换设备,它能够将光伏太阳能板(PV)产生的不稳定的直流电压转换成与市电频率同步的交流电。这种转换后的电能不仅可以回馈至商用输电网络,还能供独立电网系统使用。光伏逆变器在商业光伏储能电站和家庭独立储能系统等应用领域中得到了广泛的应用。光耦合器,以其高速信号传输、出色的共模抑制比以及单向信号传输和光电隔离的特性,在光伏逆变器中扮演着至关重要的角色。它确保了系统的安全隔离、干扰的有效隔离以及通信信号的精准传输。光耦合器的使用不仅提高了系统的稳定性和安全性,而且由于其低功耗的
    晶台光耦 2025-01-09 09:58 28浏览
  • 「他明明跟我同梯进来,为什么就是升得比我快?」许多人都有这样的疑问:明明就战绩也不比隔壁同事差,升迁之路却比别人苦。其实,之间的差异就在于「领导力」。並非必须当管理者才需要「领导力」,而是散发领导力特质的人,才更容易被晓明。许多领导力和特质,都可以通过努力和学习获得,因此就算不是天生的领导者,也能成为一个具备领导魅力的人,进而被老板看见,向你伸出升迁的橘子枝。领导力是什么?领导力是一种能力或特质,甚至可以说是一种「影响力」。好的领导者通常具备影响和鼓励他人的能力,并导引他们朝着共同的目标和愿景前
    优思学院 2025-01-08 14:54 82浏览
  • 在过去十年中,自动驾驶和高级驾驶辅助系统(AD/ADAS)软件与硬件的快速发展对多传感器数据采集的设计需求提出了更高的要求。然而,目前仍缺乏能够高质量集成多传感器数据采集的解决方案。康谋ADTF正是应运而生,它提供了一个广受认可和广泛引用的软件框架,包含模块化的标准化应用程序和工具,旨在为ADAS功能的开发提供一站式体验。一、ADTF的关键之处!无论是奥迪、大众、宝马还是梅赛德斯-奔驰:他们都依赖我们不断发展的ADTF来开发智能驾驶辅助解决方案,直至实现自动驾驶的目标。从新功能的最初构思到批量生
    康谋 2025-01-09 10:04 26浏览
  • 故障现象一辆2017款东风风神AX7车,搭载DFMA14T发动机,累计行驶里程约为13.7万km。该车冷起动后怠速运转正常,热机后怠速运转不稳,组合仪表上的发动机转速表指针上下轻微抖动。 故障诊断 用故障检测仪检测,发动机控制单元中无故障代码存储;读取发动机数据流,发现进气歧管绝对压力波动明显,有时能达到69 kPa,明显偏高,推断可能的原因有:进气系统漏气;进气歧管绝对压力传感器信号失真;发动机机械故障。首先从节气门处打烟雾,没有发现进气管周围有漏气的地方;接着拔下进气管上的两个真空
    虹科Pico汽车示波器 2025-01-08 16:51 92浏览
  • 一个真正的质量工程师(QE)必须将一件产品设计的“意图”与系统的可制造性、可服务性以及资源在现实中实现设计和产品的能力结合起来。所以,可以说,这确实是一种工程学科。我们常开玩笑说,质量工程师是工程领域里的「侦探」、「警察」或「律师」,守护神是"墨菲”,信奉的哲学就是「墨菲定律」。(注:墨菲定律是一种启发性原则,常被表述为:任何可能出错的事情最终都会出错。)做质量工程师的,有时会不受欢迎,也会被忽视,甚至可能遭遇主动或被动的阻碍,而一旦出了问题,责任往往就落在质量工程师的头上。虽然质量工程师并不负
    优思学院 2025-01-09 11:48 31浏览
  • 本文介绍编译Android13 ROOT权限固件的方法,触觉智能RK3562开发板演示,搭载4核A53处理器,主频高达2.0GHz;内置独立1Tops算力NPU,可应用于物联网网关、平板电脑、智能家居、教育电子、工业显示与控制等行业。关闭selinux修改此文件("+"号为修改内容)device/rockchip/common/BoardConfig.mkBOARD_BOOT_HEADER_VERSION ?= 2BOARD_MKBOOTIMG_ARGS :=BOARD_PREBUILT_DTB
    Industio_触觉智能 2025-01-08 00:06 100浏览
  • 1月7日-10日,2025年国际消费电子产品展览会(CES 2025)盛大举行,广和通发布Fibocom AI Stack,赋智千行百业端侧应用。Fibocom AI Stack提供集高性能模组、AI工具链、高性能推理引擎、海量模型、支持与服务一体化的端侧AI解决方案,帮助智能设备快速实现AI能力商用。为适应不同端侧场景的应用,AI Stack具备海量端侧AI模型及行业端侧模型,基于不同等级算力的芯片平台或模组,Fibocom AI Stack可将TensorFlow、PyTorch、ONNX、
    物吾悟小通 2025-01-08 18:17 33浏览
  • 在智能网联汽车中,各种通信技术如2G/3G/4G/5G、GNSS(全球导航卫星系统)、V2X(车联网通信)等在行业内被广泛使用。这些技术让汽车能够实现紧急呼叫、在线娱乐、导航等多种功能。EMC测试就是为了确保在复杂电磁环境下,汽车的通信系统仍然可以正常工作,保护驾乘者的安全。参考《QCT-基于LTE-V2X直连通信的车载信息交互系统技术要求及试验方法-1》标准10.5电磁兼容试验方法,下面将会从整车功能层面为大家解读V2X整车电磁兼容试验的过程。测试过程揭秘1. 设备准备为了进行电磁兼容试验,技
    北汇信息 2025-01-09 11:24 26浏览
  •  在全球能源结构加速向清洁、可再生方向转型的今天,风力发电作为一种绿色能源,已成为各国新能源发展的重要组成部分。然而,风力发电系统在复杂的环境中长时间运行,对系统的安全性、稳定性和抗干扰能力提出了极高要求。光耦(光电耦合器)作为一种电气隔离与信号传输器件,凭借其优秀的隔离保护性能和信号传输能力,已成为风力发电系统中不可或缺的关键组件。 风力发电系统对隔离与控制的需求风力发电系统中,包括发电机、变流器、变压器和控制系统等多个部分,通常工作在高压、大功率的环境中。光耦在这里扮演了
    晶台光耦 2025-01-08 16:03 80浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦