SOME/IP

2023-09-12 14:53:29

介绍

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:

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

Message type in SOME/IP

Return Code:

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

Message TypeAllowed Return Codes
REQUESTN/A set to 0x00 (E_OK)
REQUEST_NO_RETURNN/A set to 0x00 (E_OK)
NOTIFICATIONN/A set to 0x00 (E_OK)
RESPONSEMany Sub Type are there
ERRORMany 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)

更多推荐

Java手写启发式搜索算法和启发式搜索算法应用拓展案例

Java手写启发式搜索算法和启发式搜索算法应用拓展案例1.算法思维导图以下是使用Mermanid代码表示的启发式搜索算法的实现原理:#mermaid-svg-3nox60fbtHCDRqqD{font-family:"trebuchetms",verdana,arial,sans-serif;font-size:16p

免费好用bpm平台,实现生产管理系统

1.什么是生产管理系统生产制造管理系统主要是以生产制造管理为核心,其管理功能包括产品结构设置(BOM)生产计划、加工、领料、质检、库存、成本核算等。通过信息化解决行业管理问题,满足各企业科学管理的需求,并为制造管理提供较完善的解决方案。2.为什么选择天翎市面上不乏各种成品软件可供企业选择,但成品软件多数为通用固定的功能

Shell 正则表达式及综合案例及文本处理工具

目录一、常规匹配二、常用特殊字符三、匹配手机号四、案例之归档文件五、案例之定时归档文件六、Shell文本处理工具1.cut工具2.awk工具一、常规匹配一串不包含特殊字符的正则表达式匹配它自己例子,比如说想要查看密码包含root字符串的,可以这样写cat/etc/passwd|greproot二、常用特殊字符特殊字符作

【跟小嘉学 Rust 编程】三十二、Rust的设计模式(Design Patterns)

系列文章目录【跟小嘉学Rust编程】一、Rust编程基础【跟小嘉学Rust编程】二、Rust包管理工具使用【跟小嘉学Rust编程】三、Rust的基本程序概念【跟小嘉学Rust编程】四、理解Rust的所有权概念【跟小嘉学Rust编程】五、使用结构体关联结构化数据【跟小嘉学Rust编程】六、枚举和模式匹配【跟小嘉学Rust

K8S:pod集群调度及相关操作

文章目录一.pod集群调度概念1.调度约束(List-Watch组件)2.List-Watch的工作机制(1)List-Watch的工作机制流程(2)List-Watch的工作机制图示3.调度的过程(1)调度的任务(2)调度选择pod节点(3)调度的过程(4)调度的算法(5)调度的优先级二.pod集群调度示例1.指定调

嵌入式-数据进制之间的转换

目录一.简介1.1十进制1.2二进制1.3八进制1.4十六进制二.进制转换2.1二进制-十进制转换2.2八进制-十进制转换2.3十六进制-十进制转换2.4十进制-二进制转换2.5十进制-八进制转换2.6十进制-十六进制转换2.7小数部分转换一.简介被传入到计算机的数据要转换成0,1的二进制数据才能被计算机识别。为了方便

【MySQL】MySQL 数据库锁知识 讲解

MySQL数据库锁知识讲解1.为什么需要加锁在日常生活中,如果你心情不好想静静,不想被比别人打扰,你就可以把自己关进房间里,并且反锁。这就是生活中的加锁。同理,对于MySQL数据库来说的话,一般的对象都是一个事务一个事务来说的。所以,如果一个事务内,一个SQL正在更新某条记录,我们肯定不想它被别的事务影响到嘛?因此,数

PG大小版本升级步骤

版本介绍当前PostgreSQL版本号由主要版本号和小版本号组成。例如,在版本号10.1中,10是主要版本号,1是小要版本号,这意味着这将是主要版本10的第一个小版本。对于PostgreSQL版本10.0之前的版本,版本号由三个数字组成,例如9.5.3。在这些情况下,主要版本由版本号的前两位数组组成,例如9.5,而小版

分享一个基于uniapp+springboot技术开发的校园失物招领小程序(源码、lw、调试)

💕💕作者:计算机源码社💕💕个人简介:本人七年开发经验,擅长Java、Python、PHP、.NET、微信小程序、爬虫、大数据等,大家有这一块的问题可以一起交流!💕💕学习资料、程序开发、技术解答、文档报告💕💕如需要源码,可以扫取文章下方二维码联系咨询💕💕JavaWeb项目💕💕微信小程序项目💕💕

数据结构与算法(五)--链表概念以及向链表添加元素

一、前言今天我们学习另一种非常重要的线性数据结构–链表,之前我们已经学习了三种线性数据结构,分别是动态数组,栈和队列。其中队列我们额外学习了队列的另一种实现方式–循环队列。其实我们自己实现过前三个数据结构就知道,它们底层均依托静态数组,靠resize解决固定容量问题。而链表和前三种均不同,它是真正的动态数据结构。学好链

SpingBoot:整合Mybatis-plus+Druid+mysql

SpingBoot:整合Mybatis-plus+Druid一、特别说明二、创建springboot新工程三、配置3.1配置pom.xml文件3.2配置数据源和durid连接池3.3编写拦截器配置类四、自动生成代码五、测试六、附件-mysql数据库表本文参考链接:[Java]SpringBoot集成MyBatisPlu

热文推荐