SOME/IP学习笔记3

news/2025/3/22 18:34:44/

目录

1.SOMEIP Transformer

1.1 SOME/IP on-wire format

1.2 协议指定

2. SOMEIP TP

2.1 SOME/IP TP Header

3.小结


1.SOMEIP Transformer

       根据autosar CP 相关规范,SOME/IP Transformer主要用于将SOME/IP格式的数据序列化,相当于一个转换器。总体框架如下:

       如上图,SWC通过RTE处理数据,然后RTE执行相关的SOME/IP转换,将数据序列化转换为线性模式;接收端进行反序列化,最后传给另一个SWC。

1.1 SOME/IP on-wire format

        车载网路中PDU数据格式如下:

  • 报文长度限制

        当前用于CAN或FlexRay的数据长度限制为4095bytes;因此一个包含Header的SOME/IP报文不应该超过4095bytes。

  • 大小端

        Header均以大端表示,payload由SOMEIPTransformationDescription表示。

  • Header

        详见报文格式Some/IP学习笔记-CSDN博客

  • 参数和数据结构的序列化   

        支持序列化的基础数据类型如下:

        结构体的序列化:

        按照深度优先遍历的顺序进行序列化;如果需要对齐,在AUTOSAR数据类型中插入保留/填充元素,因为SOME/IP实现不会自动添加此类填充。

        例如,如果一个结构包含一个uint8和一个uint32,它们只是顺序写入缓冲区。这意味着uint8和uint32的第一个字节之间没有填充;因此,uint32可能没有对齐。因此,系统设计者必须考虑向数据类型添加填充元素,以实现所需的对齐或全局设置。

        如果SomeiptTransformationProps的属性sizeOfStructLengthField设置为大于0的值,则应在为其定义SomeiptTransformationProps的序列化结构之前插入长度字段。结构体的序列化有如下两种方式:

1.2 协议指定

        协议又分为Client/Server和Sender/Receiver

  • Client/Server通信

对于SOME/IP的请求message,Client端的SOME/IP transformer对payload和header做以下处理:

  1.  构建payload、设置独立的request ID、设置协议版本、设置接口版本、设置请求的message类型,returncode=0;
  2.  Server端的SOME/IP transformer应构建header,并处理payload、设置messageType为RESPONSE。
  • Sender/Receiver通信

        这里留个记录,暂时没有看到这里来

2. SOMEIP TP

        SOME/IP TP主要是将SOME/IP packet碎片化(UDP packet无法存放完整帧),接收端重新组装。

2.1 SOME/IP TP Header

        当MessageType中TP-Flag置1后,header变为如下结构:

        这里多出了4字节的内容,分别是28bit的offset、3bit的reserved bits和1bit 的More Segment Flag

  • TP-Flag处于第18位。
  • Offset Field:紧跟在return code,随着SOME/IP segment的发送或接收增加。每增加1相当于16个bytes已经接受或传输,例如offset值为92,表示已经传输了92*16=1472个字节的数据。
  • More Segment Flag置1,表示继续有SOME/IP PDU segment传输。

        现在假设要发送一个5571byte的SOME/IP报文、数据长度为8+5571;表示报文长度为8字节,总长为5571.

        现在将其分为5个连续的SOME/IP segments,每个最长payload为1392bytes。那么对应划分如下:

        8为报文长度、4为offset+res+m、1392为payload长度。

        结合上述,前4个segment总体结构如下:

        最后一个为:

3.小结

        总结一下,目前对于SOME\IP的认知还比较浅显,全是基础概念,所以接下来要进一步深入,搭建测试环境,入门车载以太网

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

相关文章

Live800:客服中心必备的7种客户服务原则

在现代商业社会中,客户服务已经成为企业竞争的重要因素之一。提供高质量的客户服务可以帮助企业赢得客户的忠诚度和信任,从而推动企业的发展。客服中心是企业与客户之间的桥梁,对于客户服务的质量要求更高。为了提高客服中心的服务质量&#…

单片机启动流程

存储器 ​ 一个单片机中存在rom和ram,Soc也有rom和ram(ddrx),部分Soc还包含MMU(Memory Manage Unit 内存管理单元)— (用于系统内存管理,比如说虚拟内存空间,内存区间的…

Python【奇偶数组】

要求: 给定一个非负整数数组A,将该数组中的所有偶数都放在奇数元素之前 代码如下: def sort_array_by_parity(arr):i 0for j in range(len(arr)):if arr[j] % 2 0: # 判断是否为偶数arr[i], arr[j] arr[j], arr[i] # 交换偶数和奇数的…

使用Badboy录制生成 JMeter 脚本

JMeter是一款在国外非常流行和受欢迎的开源性能测试工具,像LoadRunner 一样,它也提供了一个利用本地Proxy Server(代理服务器)来录制生成测试脚本的功能,但是这个功能并不好用。所以在本文中介绍一个更为常用的方法——…

并发线程的三大特性-原子性

1.1 什么是并发编程的原子性 JMM(Java Memory Model)。不同的硬件和不同的操作系统在内存上的操作有一定差异的。Java为了解决相同代码在不同操作 系统上出现的各种问题,用JMM屏蔽掉各种硬件和操作系统带来的差异。 让Java的并发编程可以做到…

首发!动手学大模型应用开发教程来了

大模型正逐步成为信息世界的新革命力量,其通过强大的自然语言理解、自然语言生成能力,为开发者提供了新的、更强大的应用开发选择。随着国内外井喷式的大模型 API 服务开放,如何基于大模型 API 快速、便捷地开发具备更强能力、集成大模型的应…

Linux:系统调用 和 Strace

1. 写在前面 本文主要介绍:Linux 下系统调用和 strace 工具概述; 公众号: 滑翔的纸飞机 2. 系统调用 和 Strace 当 Linux 上运行的应用程序/进程要使用 Linux 内核管理的资源时,如读取文件、创建进程等。应用程序进程向 Linux 内…

【NodeJS】Nodejs安装及环境配置

下载安装包 网址:https://nodejs.org/en 安装程序 1.下载完成后,双击安装包,进行安装,一路默认配置 nxet 即可,安装路劲给默认在C盘,或者选择其他位置,当前教程默认C盘 2.下图根据本身的…