介绍
SOME/IP是一种汽车中间件解决方案,可用于控制消息。它从一开始就被设服务器托管网计为完美地适应不同尺寸和不同操作系统的设备。这包括小型设备,如相机、AUTOSAR 设备,以及头戴设备或远程通信设备。它还确保SOME/IP支持信息娱乐域以及车辆中其他域的功能,从而允许SOME/IP用于大多数替换场景以及更传统的CAN场景。
SOME/IP工作在传输层之上,即硬件无关
功能
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报文格式
Message ID:
在SOME/IP里的Message ID被用来标识应用程序或事件的方法。MessageID跟CAN ID一样,它在整个车载网络总应该是唯一的。Message ID的规划由用户决定。
Message ID包含两个域,一个是service ID,另一个是Method ID。按如下方式构成:
Service ID [16 Bit] | 0 [1 Bit] | Method ID [last 15 Bit] |
Length:
长度域里的长度值为从Request ID/Client ID开始到SOME/IP消息尾的字节数。
Request ID:
请求 ID 用于区分同一方法、事件、getter 或 setter 的多个用例。应根据订阅者和提供者组合使用唯一的请求 ID。
提供者应当从请求中复制Request ID添加到响应中。这允许订阅者区分多个挂起的请求。
并且订阅者不应该使用相同的请求 ID,直到收到响应和/或不再期望收到响应。
Request ID 有两个子域 Client ID和Session ID,如下表所示。
Client ID [16 Bits] | Session ID [16 Bits] |
Client ID:
客户端 ID 也是唯一标识符,用于区分使用相同Method而来自不同提供者的响应。
Session ID:
session ID也是唯一的标识,用来区分使用相同Method的多个调用,此处的提供者可以相同。
请求/响应方法应使用带会话 ID 的会话处理。会话 ID 应在每次调用后递增。当会话 ID 达到 0xFFFF 时,它将滚动并重新启动。如果响应的会话 ID 与请求的会话 ID 不匹配,订阅者必须忽略该响应。
Protocol Version:
协议版本应该是一个字节大小包含SOME/IP的协议版本。
Interface Version:
接口版本应该是一个字节大小,包含服务接口的主版本。
Message Type:
消息类型字段用于区分不同类型的消息,应包含下表中所示的以下值。
Return Code:
返回码用于指示请求是否已成功处理。 支持的返回码如下所示。
Message Type | Allowed Return Codes |
---|---|
REQUEST | N/A set to 0x00 (E_OK) |
REQUEST_NO_RETURN | N/A set to 0x00 (E_OK) |
NOTIFICATION | N/A set to 0x00 (E_OK) |
RESPONSE | Many Sub Type are there |
ERROR | Many sub types are there , other then 0x00 (E_OK) |
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)
服务器托管,北京服务器托管,服务器租用 http://www.fwqtg.net
相关推荐: Python实战项目练习-Django商城项目之注册功能实现
设计到的前端知识 项目的前端页面使用vue来实现局部刷新,通过数据的双向绑定实现与用户的交互,下面来看一下需求,在用户输入内容后,前端需要做一些简单的规则校验,我们希望在在用户输入后能够实时检测,如果有错误能够在输入框的下方显示出来。 用户名: 请输入5-20…