介绍

SOME/IP是一种汽车中间件解决方案,可用于控制消息。它从一开始就被设计为完美地适应不同尺寸和不同操作系统的设备。这包括小型设备,如相机、AUTOSAR 设备,以及头戴设备或远程通信设备。它还确保SOME/IP支持信息娱乐域以及车辆中其他域的功能,从而允许SOME/IP用于大多数替换场景以及更传统的CAN场景。

SOME/IP-LMLPHP

SOME/IP工作在传输层之上,即硬件无关

SOME/IP-LMLPHP

功能

SOME/IP 支持广泛的中间件功能:

  • 序列化 – 线上输入输出转换。
  • 远程过程调用 (RPC) and Messaging – 实现函数和其他消息的远程调用。
  • 服务发现 (SD) – 动态查找、功能、配置。
  • 发布/订阅 (Pub/Sub) – 动态配置需要哪些数据并应发送到客户端。
  • UDP信息块 – 允许通过 UDP 传输大型 SOME/IP 消息,而无需分段。

序列化

SOME/IP序列化被设计成高效率的,它使用极少的RAM和CPU资源。 是通过二进制和不可读的格式实现的。基本上,各设备都有所有的参数。消息的格式与消息的内存中表示形式(打包结构)非常相似或在许多情况下完全相同。

SOME/IP能序列化如下基本的数据类型(数据类型被默认编码成网络字节序也就是大端序,当然也可以编码成小端序):

  • boolean: 一字节的布尔类型
  • uint8: 无符号的一字节整型
  • uint16: 无符号的两字节整型
  • uint32: 无符号的四字节整型
  • uint64: 无符号的八字节整型
  • sint8: 有符号的一字节整型
  • sint16: 有符号的两字节整型
  • sint32: 有符号的四字节整型
  • sint64: 有符号的八字节整型
  • float32: 无符号的一字节整型
  • float64: 无符号的一字节整型

SOME/IP能序列化如下的复杂的数据类型:

  • struct: 结构体
  • string: 字符串
  • array: 数组
  • enumeration: 枚举
  • bitfield: 位域
  • union: 共用体

远程过程调用 (RPC) 和消息体

SOME/IP服务支持以下几种消息:

  • 请求/响应方法: 从客户端发送到服务器的请求和从服务器发送到客户端的响应。此外,SOME/IP 允许错误响应从服务器发送回客户端,而不是常规响应。此功能可用于在错误情况下实现不同的数据包格式。
  • 即发即弃方法:从客户端发往服务端的请求。
  • 事件:从服务器发送到相关客户端的事件。哪个客户端需要此事件将通过 SOME/IP-SD 确定
  • 域: 字段可以具有选项通知程序(循环发送或更改时发送的事件)、可选资源库(用于更新字段的请求/响应方法)和可选 getter(用于读取字段当前值的请求/响应方法)。

SOME/IP报文格式

SOME/IP-LMLPHP

Message ID:

在SOME/IP里的Message ID被用来标识应用程序或事件的方法。MessageID跟CAN ID一样,它在整个车载网络总应该是唯一的。Message ID的规划由用户决定。

Message ID包含两个域,一个是service ID,另一个是Method ID。按如下方式构成:

Length:

长度域里的长度值为从Request ID/Client ID开始到SOME/IP消息尾的字节数。

Request ID:

请求 ID 用于区分同一方法、事件、getter 或 setter 的多个用例。应根据订阅者和提供者组合使用唯一的请求 ID。

提供者应当从请求中复制Request ID添加到响应中。这允许订阅者区分多个挂起的请求。

并且订阅者不应该使用相同的请求 ID,直到收到响应和/或不再期望收到响应。

Request ID 有两个子域 Client ID和Session ID,如下表所示。

Client ID:

客户端 ID 也是唯一标识符,用于区分使用相同Method而来自不同提供者的响应。

Session ID:

session ID也是唯一的标识,用来区分使用相同Method的多个调用,此处的提供者可以相同。

请求/响应方法应使用带会话 ID 的会话处理。会话 ID 应在每次调用后递增。当会话 ID 达到 0xFFFF 时,它将滚动并重新启动。如果响应的会话 ID 与请求的会话 ID 不匹配,订阅者必须忽略该响应。

Protocol Version:

协议版本应该是一个字节大小包含SOME/IP的协议版本。

Interface Version:

接口版本应该是一个字节大小,包含服务接口的主版本。

Message Type:

消息类型字段用于区分不同类型的消息,应包含下表中所示的以下值。

SOME/IP-LMLPHP

Return Code:

返回码用于指示请求是否已成功处理。 支持的返回码如下所示。

Payload:

在此字段中,实际数据将被传输,有效载荷字段没有固定大小,它是用户/应用程序定义的。但是,SOME/IP 中有效负载数据的最大限制取决于传输协议。使用 UDP 的 SOME/IP 有效负载大小为 0 到 1400 字节。

有效负载包含事件的数据元素和方法的参数。

在 SOME/IP 应用程序中,数据将使用“有效负载”字段上的序列化进行存储。在 SOME/IP 数据序列化中也依赖于配置参数,数据的序列化在最开头有讨论。

参考

Scalable service-Oriented MiddlewarE over IP (SOME/IP)

发送SOME/IP数据包的工具 https://gitee.com/wq897/FibexConverter.git 

SCALABLE SERVICE-ORIENTED MIDDLEWARE OVER IP (SOME/IP)

09-13 07:45