汽车 Automotive > SOME/IP应用学习

news2024/11/30 2:48:27

目录

SOME/IP介绍

SOME/IP主要功能

SOME/IP协议

SOME/IP服务类型

SOME/IP-举例

SOME/IP各模块协议

SOME/IP-基础元件

SOME/IP-SoAD

SOME/IP-SD协议

SOME/IP-SD举例

SOME/IP-TP协议

SOME/IP-TP举例


SOME/IP介绍

        SOME/IP ( Scalable service-Oriented Middleware over IP),即“运行于IP之上的可伸缩(可扩展)的面向服务的中间件”。是一个汽车中间件解决方案,可以用于控制消息。从一开始,它的设计就是为了完美地适应不同尺寸和不同操作系统的设备。这包括小型设备,如相机、AUTOSAR设备,以及头部单元或远程信息处理设备。同时还确保了SOME/IP支持Infotainment域以及车内其他域的功能,从而使SOME/IP可以用于多数替换场景以及更传统的CAN场景。所谓“Middleware中间件”是一种独立的系统软件或服务程序,分布式应用软件可借助Middleware在不同的技术之间共享资源。所谓的分布式应用软件,在这里指的就是“服务”;不同的技术之间,在这里指的就是“不同的平台或操作系统,比如Adaptive AUTOSAR系统等。

        SOME/IP服务是SOME/IP的最核心概念。在一个服务中,定义了ServerClient两个角色:Server提供服务,Client调用服务。对于同一个服务,只能存在一个Server,但可以同时存在多个Client调用服务。一个Service0~多个Event/Method/Field组成。与CAN相比,面向服务的通讯方式能够大大降低总线的负载率。

        SOME/IP不等同于SOA,SOME/IP只是实现了SOA(面向服务的架构)和符合其协议规范。

  •         SOME/IP允许应用程序进行通信。
  •         数据包格式由服务规范自动确定。
  •         服务器提供了一个实现服务接口的服务实例。
  •         客户端使用SOME/IP来使用服务实例。
  •         一个Service0~多个Event/Method/Field组成

SOME/IP主要功能

1) SOME/IP中间件在运行时(而不是在系统设计时)动态地创建服务提供者和服务使用者之间的连接
2) 通过网络提供面向服务的通信
3) SOME/IP 支持广泛的中间件功能
        -序列化转换为二级制序列转换,包含基本数据类型(e.g. Boolean、uint8和sint32等)和复杂数据类型(e.g. struct string和array等)
        -远程过程调用 (RPC) 实现函数的远程调用。
        -服务发现 (SD) 动态查找功能并配置其访问权限。
        -发布/订阅 (Pub/Sub) 动态配置需要哪些数据并将其发送到客户端。
        -UDP 消息的分段允许通过 UDP 传输大型 SOME/IP 消息而无需分段。
4) SOME/IP 可以在不同的操作系统上实现(即 AUTOSAR、GENIVI Linux和 OSEK),甚至没有操作系统的嵌入式设备
5) SOME/IP 用于 ECU 间客户端/服务器序列化

英文原始内如如下:

  • SOME/IP provides service oriented communication over a network
  • SOME/IP supports a wide range of middleware features
  • Serialization–transforming into and from on-wire representation.
  • Remote Procedure Call (RPC) –implementing remote invocation of functions.
  • Service Discovery (SD) –dynamically finding functionality and configuring its access.
  • Publish/Subscribe (Pub/Sub) –dynamically configuring which data is needed and shall be sent to the client.
  • Segmentation of UDP messages –allowing the transport of large SOME/IP messages over UDP without the need of fragmentation.
  • SOME/IP can be implemented on different operating systems (i.e. AUTOSAR, GENIVI Linux and OSEK) and even embedded devices without operating system
  • SOME/IP is used for inter-ECU Client/Server Serialization
  • https://www.mathworks.com/help/autosar/ug/autosar-platform-comparison.html

SOME/IP协议

Message ID,用于唯一标识消息,当消息为Method类型时,由Service IDMethod ID组成,当消息为Event类型时,由Service IDEvent ID组成,如下图所示:

Length,消息长度(Request ID开始到Payload结束)

Request ID,服务提供者和调用者可用于区分相同消息的不同调用,由Client IDSession ID组成。通常我们称服务提供者为Service,服务调用者为ClientService IDClient ID用于区分,一般会在一个SOA架构中统一地配置这些ID的数值。

Protocol Version,协议头版本号,目前该值必须为1

Interface Version,接口版本号,一般由服务提供者定义;

Message TypeReturn Code,用于标识消息的类型,报文类型,目前共5/返回码

Payload,数据段,需要传输的相关数据

SOME/IP服务类型

  • 服务说明
  • 服务是SOME/IP的最核心概念。在一个服务中,定义了ServerClient两个角色:Server提供服务,Client调用服务。
  • 对于同一个服务,只能存在一个Server,但可以同时存在多个Client调用服务。一个Service0~多个Event/Method/Field组成。
  • CAN相比,面向服务的通讯方式能够大大降低总线的负载率。
  • Method
  • 调用或引用一个进程/函数/子程序,通常由Client发起,并由Server答复。
  • Request是最常见的一种Method,由ClientServer请求数据;ResponseRequest的结果,由Server答复ClientRequest
  • Method Fire & Forget方式,只ClientServer发起,但Server对该请求不回复。
  • Event
  • 一个单向的数据传输,只能是on change类型,用于Server主动向订阅(Subscribe)了相关服务的Client发布(Publish)信息。
  • Field
  • 由以下三项内容构成:
  • Notifier:通知,ServerClient订阅了服务后第一时间主动向其发送数据。
  • Getter:获取,由ClientServer读取数据。
  • Setter:设置,由Client修改Server的数据。

SOME/IP-举例

SOME/IP各模块协议

  • SOME/IP被定义到AUTOSAR CPBSW模块的一部分。
  • SOME/IP被统一到AUTOSAR AP的通信管理中。
  • VSOME/IP开源,可以移植到Linux平台,有公司基于VSOME/IP进行自己产品开发

SOME/IP-基础元件

SOME/IP-SoAD

  • SoAD层通过TCP/IP网络实现基于PDU的通信
  • AUTOSAR I-PDU映射到SoAD配置和维护的Socket连接。
  • 要对多个I-PDU使用Socket连接,可在每个I-PDU前面添加一个SoAD PDU头
  • PDU路由组管理-启用/禁用从/到Socket的PDU路由
  • SOME/IP-Socket适配器[SoAD]-AUTOSAR型号通用上层支撑的构建块
    •         要了解Autosar中的通讯栈,就必须了解PDUProtocol Data Unit)。 PDUAutosar通讯中重要的概念,每个PDU包含着SDUPCI,每个PDU拥有独自的ID用于互相区分。 非TP层的I-PDU数据不应超过8字节的长度。 这确保了可以在单个CAN消息中发送I-PDU
  • SOME/IP-SD协议

  •         由于服务需要由ServerClient共同完成,因此在进行正常的数据传输之前,需要一系列的准备工作确认ServerClient之间是否已有网络连接。之后,Client还要询问Server能否提供所需的服务,并对服务的Event进行订阅。这些工作都是通过SOME/IP服务发现(Service Discovery)实现的。SOME/IP服务发现用于定位服务实例、检查服务是否可用以及部署发布和订阅句柄。服务发现只能通过UDP实现。服务发现的报文格式与一般的SOME/IP报文相同,但是其Message ID固定为0xFFFF8100
    •         主要功能
  • 定位服务实例
  • 检测服务实例是否在运行(即服务实例的状态)
  • 发布/订阅行为的管理
    •         SD报文解析
      •         SOME/IP SD报文也是一种SOME/IP报文,是在SOME/IP报文的基础上进行了扩展增加了EntryOption等字段;
  • Entries用于同步服务实例的状态和发布/订阅的管理。
  • Options用于传输Entries的附加信息。
    •         SOME/IP SD报文的ServiceID0xFFFF)、MethodID0x8100)、Request ID0x0000)、ProtocolVersion0x01)、Interface Version0x01)、MessageType0x02)、ReturnCode0x00)等属性都是固定值。
      •         Entry
  • Entry字段可以理解为服务实例的“入口”,该入口包含服务实例以及需要订阅的事件组的信息。主要通过Entry实现提供服务、发现服务,以及订阅事件组的功能。

SOME/IP-SD举例

Term

Description

描述

Service

A functional entity that offers an interface. A logical combination of zero or more methods, zero or more events, and zero or more fields.

提供接口的功能实体。零个或多个Methods、零个或多个events以及零个或多个Field的逻辑组合。

Service Instance

A single instance of the Service. Implementation of a service, which can exist more than once in the vehicle and more than once on an ECU

服务的单个实例。实施一项服务,该服务可以在车辆中存在多次,也可以在ECU中存在多次

Offer Service

A message entry that declares offer of a Service Instance

声明服务实例提供的消息条目

Stop Offer

A message entry that declares stopping of a Service Instance

声明停止服务实例的消息项

Find Service

A message entry used to find a Service Instance.

用于查找服务实例的消息条目

Event

A message send by an ECU implementing a Service Instance to an ECU using this Service Instance.

由执行服务实例的ECU向使用该服务实例的ECU发送的消息

EventGroup

A logical grouping of 1 or more events. An EventGroup is part of a Service.

一个或多个事件的逻辑分组。事件组是服务的一部分

Field

A field does represent a status and thus has an valid value at all times on which getter, setter and notifieract upon.

一个字段确实代表一个状态,因此在gettersetternotified所依赖的任何时候都有一个有效值。

Getter/Setter

A Request/Response call that allows Read/Write access to a field.

允许对字段进行读/写访问的请求/响应调用。

Method

A method, procedure, function, or subroutine that is called/invoked.

被调用的方法、过程、函数或子例程。

Notification Event

An event message of the notifierof a field.

通知字段的事件消息。

Notifier

Sends out event message with a new value on change of the value of the field.

在字段值发生变化时,发送带有新值的事件消息。

Remote Procedure Call (RPC)

A method call from one ECU to another that is transmitted using messages

从一个ECU到另一个ECU的方法调用,使用消息进行传输

  • SD - 服务器角色
  • 回复“查找”
  • 提供服务
  • 收回提供
  • SD - 客户角色
  • 发送“查找”
  • 倾听提供
  • 倾听停止的提供

 

SOME/IP-TP协议

        我们知道CAN-TP是用来对当总线CAN数据过大时,就需要对CAN整包数据进行分割拆包进行发送,这个时候发送方的TP层就起作用,同理对于接收方而言,也需要将分割的数据包进行组包完成整包数据的重组还原。

        因此,举一反三,我们便可以知道SOME/IP-TP模块的主体功能就是为了实现对应用层发送数据过大时进行的必要拆包与组包的工作,进而完成大量数据包的发送与接收。

        SOME/IP作为一种应用层协议,既可以运行在TCP之上,也可以运行在UDP之上,由于TCP协议本身支持发送大量数据同时还支持流控等特点因此无需用到SOME/IP-TP,该协议仅针对运行在UDP协议基础上的SOME/IP协议

        如下图7.1所示,则较为清晰的表明了SOME/IP-TPCP AUTOSAR的具体位置以及与其他模块的交互关系。

 

 

SOME/IP-TP举例

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/41323.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于Android的JavaEE课设

目录 1 技术栈 2 android前端 2.1 概述 2.1.1 目录结构 2.1.2 代码分层 2.2 技术点 2.2.1 数据绑定 2.2.2 前后端数据交互 2.2.3 九宫格图片 2.2.4 未处理消息提醒 2.2.5 动画效果 2.2.6 实时聊天 2.2.7 文件上传 2.2.8 底部弹窗 2.2.9 其他 3 后端 3.1 概述 …

BUUCTF Misc 假如给我三天光明 数据包中的线索 后门查杀 webshell后门

假如给我三天光明 下载文件,一个压缩包(需要密码)和图片 百度得知下面一行是盲文,根据盲文对照表 和上述图片对照,得到字符串:kmdonowg 。使用它解压压缩包 使用Audacity打开 转换成摩斯密码,…

C语言程序设计 复习总结[持续更新ing]

目录 一 初识C语言 1 main 主函数 2 注释 3 C 程序执行的过程: 4 C 程序的结构 5 进制的转换 1.内存容量 2.二进制与十进制的转换 1>将二进制数转换成十进制 2>将十进制转换成二进制数 3.二进制与八进制的转换 1>将八进制数转换成二进制: 2>将二进…

Java项目:JSP酒店客房管理系统

作者主页:源码空间站2022 简介:Java领域优质创作者、Java项目、学习资料、技术互助 文末获取源码 项目介绍 酒店管理系统共分为三个角色,客房经理、前台管理员、客户,各个角色的权限各不相同; 客房经理功能包括&#…

leetcode《图解数据结构》刷题日志【第五周】(2022/11/21-2022/11/28)

leetcode《图解数据结构》刷题日志【第五周】1. 剑指 Offer 60. n 个骰子的点数1.1 题目1.2 解题思路1.3 数据类型功能函数总结1.4 java代码1.5 踩坑小记1.6 进阶做法2. 剑指 Offer 63. 股票的最大利润2.1 题目2.2 解题思路2.3 数据类型功能函数总结2.4 java代码3. 剑指 Offer …

SpringBoot SpringBoot 原理篇 1 自动配置 1.16 自动配置原理【2】

SpringBoot 【黑马程序员SpringBoot2全套视频教程,springboot零基础到项目实战(spring boot2完整版)】 SpringBoot 原理篇 文章目录SpringBootSpringBoot 原理篇1 自动配置1.16 自动配置原理【2】1.16.1 看源码了1.16.2 Import({AutoConfig…

archlinux 安装matlab

最近在学matlab使用的是windows版本的,比起windows我更喜欢在linux中写代码。于是乎就想在Linux中安装一下。 主要过程参考此篇文章: 《【首发】 ubuntu20.04安装matlab2021b/matlab2020b》 https://blog.csdn.net/hanjuefu5827/article/details/1151677…

【Hack The Box】Linux练习-- Forge

HTB 学习笔记 【Hack The Box】Linux练习-- Forge 🔥系列专栏:Hack The Box 🎉欢迎关注🔎点赞👍收藏⭐️留言📝 📆首发时间:🌴2022年11月27日🌴 &#x1f36…

队列(C语言实现)

文章目录:1.队列的概念2.队列的结构3.接口实现3.1初始化队列3.2判断队列是否为空3.3入队3.4出队3.5查看队头元素3.6查看队尾元素3.7统计队列数据个数3.8销毁队列1.队列的概念 队列:只允许在一端进行插入数据操作,在另一端进行删除数据操作的特…

jQuery插件【validate】国际化校验插件

jQuery插件系列 相信大家在网站上都遇到过这种注册的情况吧,有的时候我们什么也不输入点登录或者注册或者鼠标失去焦点的时候,就会自动提示xxx为空,密码不正确,请输入xxx等一系列的提示信息。 那么这是怎么实现的呢,其…

【LeetCode】No.101. Symmetric Tree -- Java Version

题目链接:https://leetcode.com/problems/symmetric-tree/ 1. 题目介绍(Symmetric Tree) Given the root of a binary tree, check whether it is a mirror of itself (i.e., symmetric around its center). 【Translate】: 给定…

QT实战项目1——无边框窗口拖拽和阴影

课时2 开发环境,无边框窗口拖拽和阴影_哔哩哔哩_bilibilihttps://www.bilibili.com/video/BV14t411b7EL?p2&vd_source0471cde1c644648fafd07b54e303c905 目录 一、设置无边框 和 鼠标可以拖动窗口 1.1 设置无边框 1.2 鼠标拖动 1.3 展示阴影 一、设置无边框 和 鼠标可…

设计模式-组合模式

组合模式一、学校院系展示需求二、传统方案解决学校院系展示三、组合模式基本介绍四、组合模式原理类图五、组合模式解决的问题六、使用组合模式解决院校展示问题6.1、类图6.2、代码一、学校院系展示需求 编写程序展示一个学校院系结构:需求是这样,要在…

SQL练习题

新建数据表 首先建立测试数据库的表,新建数据库的sql语句如下,大家可以粘贴成一个sql文件,然后新建所有的表并插入所有的数据: 新建数据库sql文件: DROP TABLE IF EXISTS EMP; DROP TABLE IF EXISTS DEPT; DROP TAB…

Unity UI锚点和位置关系

一、Anchors锚点 Anchors的设置会直接改变RectTransform中它的位置信息;Anchors设置中的X 改变会影响(PosX和Width)或(left和right) 1、Anchors改变位置信息 下图中X锚点的Min和Max值相同时,上面的一栏中…

Java调用命令行并返回打印的内容

博主在最近的工作中,收到了这样一个需求。 调用别人以前完成开发的 jar 包或 python 程序,并将原程序在命令行中输出的内容封装为 JSON 对象后通过 RESTFul 接口返回。 面对以上的需求,博主给出了以下解决方案。话不多说,上代码。…

Mathematica for Linux v13.1.0 科学计算软件多语言版

Wolfram Mathematica for Linux 中文正式版是一款强大的数学计算科学计算软件,MathWorks MATLAB 和 Wolfram Mathematica 、Maplesoft Maple 并称为三大数学软件,Wolfram Mathematica 中文正式版主要用于符号计算软件,也称为计算机代数系统&a…

MySQL如何恢复不小心误删的数据记录(binlog)

前言 题主于今天(2022年11月27日) 在线上环境误操作删除了记录,且没有备份数据,通宵排查事故原因,终于没有酿成生产事故。谨以此文记录。 参考资料 https://blog.csdn.net/qq_23543983/article/details/127298578 …

单源最短路径问题(Java)

单源最短路径问题(Java) 文章目录单源最短路径问题(Java)1、问题描述2、算法思路3、代码实现4、算法正确性和计算复杂性4.1 贪心选择性质4.2 最优子结构性质4.3 计算复杂性5、参考资料1、问题描述 给定带权有向图G(V,E),其中每条…

分布式电源接入对配电网的影响matlab程序(IEEE9节点系统算例)

分布式电源接入对配电网的影响matlab程序(IEEE9节点系统算例) 摘 要:分布式电源的接入使得配电系统从放射状无源网络变为分布有中小型电源的有源网络。带来了使单向流动的电流方向具有了不确定性等等问题,使得配电系统的控制和管…