车载以太网基础篇之Eth Driver

news2025/1/13 19:50:06

车载以太网基础篇之Ethernet Driver

前言

首先,请问大家几个小小问题,你清楚:

  • 你知道Eth Driver模块的主要作用是什么吗?
  • EthDriver与以太网控制器,以太网收发器,都有哪些关系呢?
  • Eth Driver的常见函数接口有哪些呢?
  • Eth Driver一般存在区别其他驱动特有的特性呢?

今天,我们就来一起探索并回答这些问题。为了便于大家理解,以下是本文的主题大纲:

在这里插入图片描述


正文

正如前文《车载以太网基础篇之EthIf》所述,Eth Driver将作为配置以太网的底层驱动,不仅能够被EthIf来进行调用,同时能够满足Eth收发器驱动的调用需求,因为有必要深入了解下车载以太网驱动(Eth Driver)在整个AUTOSAR层级中所扮演的重要作用。

如下图1所示,Ethernet If模块不仅会直接控制Ethernet Driver,如果存在Ethernet Switch驱动或者Ethernet Transiver驱动时,那么就会间接控制Ethernet Driver模块,总而言之,以太网驱动不仅能够完成以太网数据的正常收发,同时也能够实现针对以太网网关或者以太网收发器的直接配置。

在这里插入图片描述

图1 Ethernet Driver与其他以太网驱动关系

AUTOSAR层次关系

按照AUTOSAR标准文档规范,有关Eth Driver模块在整个AUTOSAR软件架构的具体位置描述如下图2所示:
在这里插入图片描述

图2 Eth Driver与以太网协议栈关系

如上图所示,可以得出如下几个基本结论:

  • 一个以太网协议栈中可以存在多家供应商的以太网控制器,同时针对每家供应商的控制器进行单独控制,互不影响;
  • 同一供应商的以太网控制器可以存在多个,但使用的以太网控制器驱动可以仅使用同一套;
  • 上述三家不同供应商的以太网驱动作为标准AUTOSAR MCAL的一部分,能够完全实现与底层硬件的解耦;

模块主体功能

Eth Driver作为车载以太网协议栈最为重要的底层构件,小T将带领大家从以下几个层面初步了解认识以太网驱动:

  • 以太网各个不同驱动内部的索引关系如何设定?
  • 以太网驱动如何进行数据发送;
  • 以太网驱动如何进行数据接收;
  • 以太网驱动特性如QoS,硬件时间戳,Offloading都具备什么功能?
  • 在以太网驱动常见的通信协议如MDIO,DMA如何在驱动中发挥作用?

驱动索引规则

如下图3所示,每个以太网驱动彼此都是独立的,同时其索引编号是从0开始,但是每个驱动内部的bufidx均可以从0开始,彼此之间互不干扰。
在这里插入图片描述

图3 Eth Driver索引关系

数据发送过程

上层应用如果需要通过Eth Driver将数据发送出去,那么就需要通过EthIf模块间接调用Eth Driver的发送函数Eth_Transmit来完成数据的发送。

其中EthIf模块的数据发送功能分为两者模式,一种是Polling模式,另外一种就是Interrupt模式,一般而言都优先采用中断模式来满足系统实时性要求。

如下图4为Polling模式,在Polling模式中可以看到在EthIf_MainfunctionTx函数中会去轮询是否发送成功的标志,这个也是Polling模式的典型特征。

Polling模式
在这里插入图片描述

图4 数据发送Polling模式

Interrupt模式

如下图5所示为以太网数据发送的中断模式,中断模式相比Polling模式可以看出并没有使用到EthIf_MainfunctionTx函数,而是使用Eth模块的中断函数来确认发送是否成功。

在这里插入图片描述

图5 数据发送中断模式

数据接收功能

同理相比数据发送功能,EthIf模块的数据接收功能也可以分为Polling模式与中断模式两种,如下图9所示为EthIf模块的数据接收Polling模式。

如下图6所示,如果EthIf模块数据接收采用Polling模式,那么就需要使用到EthIf_MainfunctionRx函数,在该函数中去调用EthIf_RxIndication来告知上层数据已成功被接收,使用该模式会大大降低数据接收效率,一般接收优先采用中断模式

Polling模式

在这里插入图片描述

图6 数据接收Polling模式

Interrupt模式

如下图7所示为EthIf模块的数据接收中断功能,在该模式中可以看到通过Eth模块通过中断函数来进而告知上层数据已被接收。

在这里插入图片描述

图7 数据接收中断模式

驱动特性简介

以太网驱动相比其他驱动而言,存在很多诸多独有的特性,小T将会带领大家来了解这些特性,争取对这些特性有个基本的认识,以便我们对以太网驱动有个较为全面的了解,应用它时也会更加得心应手。

以下列举了以太网驱动(网卡)常见的三种特性:Offloading 特性,硬件TimeStamp特性,QoS特性

Offloading特性

“Offload"顾名思义表示卸载的意思,那么给谁卸载以及卸载什么呢?其实该特性存在的目的就是为了给CPU卸载,卸载的方式如将CRC计算交给硬件来做,或者分包组包的动作也放在硬件中来处理,从而减小这部分在以太网协议栈中的占用时间,降低软件运行延迟造成的性能不足以及CPU loading过高等问题。

在AUTOSAR规范中针对以太网驱动(Eth Driver)发送或者接收报文的CRC进行了Offloading的特别说明如下:

  • 对于IPV4帧,如果EthCtrlEnableOffloadChecksumIPv4设置成TRUE,那么就可以Offloading CRC;
  • 对于ICMP帧,如果 EthCtrlEnableOffloadChecksumICMP设置成TRUE,那么就可以Offloading CRC;
  • 对于TCP帧,如果 EthCtrlEnableOffloadChecksumTCP 设置成TRUE,那么就可以Offloading CRC;
  • 对于UDP帧,如果 EthCtrlEnableOffloadChecksumUDP设置成TRUE,那么就可以Offloading CRC;

值得注意的是这些CRC计算都仅会在硬件中完成,对于接收方而言,CRC校验检测会通过硬件来完成,如果CRC校验不通过,那么就会丢弃该接收到的帧。

硬件TimeStamp特性

如之前文章《cantsyncc》与《StbM》所述,大家相比CAN时间同步有了一个基本的认识与了解,与CAN时间同步对比,以太网时间同步协议采用的IEEE1588或者IEEE802.1AS的PTP(Precise Time Protocal)协议,该协议需要确认使用的网卡(MAC)是否本身支持。

该协议使用到通过底层硬件MAC来打上对应的以太网报文收发的时间戳,能够最大限度的降低软件时间戳所带来的不确定性,将时间同步精度能够做到微秒甚至是纳微秒级别。

AUTOSAR规范中定义的EthTsync模块使用的是双步端延时PTP时间同步协议,如下为基于该协议的Time Master与Time Slave两者之间的交互关系,后期也会针对EthTsync模块进行单一讲解,敬请关注。

在这里插入图片描述

图8 双步以太网端延时机制PTP时间同步协议

如上图8所示,如果是基于单步模式下的以太网端延时机制的PTP时间同步,那么虚线标注的部分则不会有,如果是基于双步模式下的以太网端延时机制的PTP时间同步,那么虚线标注的部分必须要有。

值得注意的是在IEEE802.1AS存在一个GrandMaster概念,需要通过BMCA(Best Master Clock Algorithm)来实现,不过由于汽车内部属于静态网络,因此只会存在唯一的GrandMaster,无需使用到BMCA动态分配确认算法。

以太网硬件实现PTP协议有如下两种方式:

  • 以太网MAC控制器支持PTP协议,常见双步模式;
  • 有些TI的PHY层也可以支持PTP,不过一般是单步模式,如果使用AUTOSAR标准的EthTsync模块,要提前确认是否支持双步模式;

QoS特性

Qos是IEEE 802.1P协议,该协议运行在以太网第二层,用来保证在以太网数据转发拥堵时通过优先级方式来保证重要的数据包能够及时发送出去。

普通的以太网二层报文是不包含优先级字段的,IEEE802.1P是IEEE802.1Q(VLAN标签技术)标准的扩充技术,彼此之间协同工作,802.1Q虽然定义了标签字段,但是并没有定义与使用优先级,而使用802.1P协议补充之后便可以正常使用优先级,正如IEEE 802.1P与IEEE802.1Q两者协同定义的标签字段如下图9所示:

在这里插入图片描述

图9 IEEE802.1Q标签头信息

以太网帧通过QoS特性来通过802.1Q标签中的802.1P用户优先级(COS)来进行标记,其优先级具备8级,从优先级0至优先级7,如下图10所示:

在这里插入图片描述

图10 COS优先级说明

通讯协议介绍

在使用车载以太网驱动的过程中,我们经常性会碰到如下三种常见的通讯协议,这三种通讯协议对于车载以太网正常工作,非常重要:

  • MII接口通讯协议,用于以太网MAC层与物理层收发器PHY之间的数据传输协议;
  • MDIO通讯协议,用于以太网MAC层控制PHY的状态设置与获取协议;
  • DMA通讯协议,用于以太网MAC层与CPU之间的数据搬运通讯协议,提高数据搬运效率,降低CPU负载;

MII接口通讯协议基础介绍

MII接口时IEEE802.3定义的以太网行业标准,该标准就是为了解决,以太网MAC层与PHY之间的兼容性,保证即使更换了不同类型的MAC,PHY始终能够正常工作。

MII接口随着技术的发展与进步,目前已经衍生出了多种增强型MII接口,常用的就有MII,RMII,SMII,SSMII,SSSMII,GMII,RGMII,SGMII ,其中对于车载以太网最为常用的还是RGMII接口

具体的通讯协议介绍不在本文中进行展开,该接口的选择只要软件上MCAL配置使用对应的MII接口类型,其余都是硬件行为,硬件上保证接口正常连接即可,如下图11所示,介绍了MII接口在以太网硬件连接上的所处关系:

在这里插入图片描述

图11 以太网MAC与PHY之间的MII物理连接示意图

MDIO协议基础介绍

首先,MDIO是Management Data Input/Output的缩写,且该接口协议在IEEE802.3中也有所体现,是一种专门用于管理MAC与PHY之间的串口数据接口,基本功能如下:

  • 读取PHY相关寄存器的值;
  • 获取PHY的Link及其他工作状态等;
  • 设置对应PHY的工作模式等;

除此之外,MDIO协议接口是一种实时,半双工,串行的数据接口,由两个线组成,一个叫做MDIO线,另外一根则是MDC线。

MDIO线负责数据的传输,MAC与PHY之间可以双向传输,写寄存器时由MAC驱动,读寄存器由PHY驱动,先传高位(MSB),再传低位(LSB),且该Pin脚需要上拉1.5kΩ-10kΩ范围内的电阻

MDC线负责传递时钟同步信号,只能单向通过MAC驱动,且只能在MDC上升沿对MDIO线上的数据进行采样,该MDC允许最大的时间频率一般都通过PHY决定

一个MDIO接口可支持32个PHY地址,该接口有32个寄存器地址,其中前16个寄存器已经在标准中定义,其余16个则有各个器件厂商自行定义。

根据IEEE802.3协议中将MDIO协议分为两种帧格式,分别为Clause 22与Clause 45,其中Clause 22主要用于千兆以下的以太网PHY,而Clause 45则用于千兆以上的以太网PHY。

接下来就针对Clause 22与Clause 45两者协议的基本使用与区别做个简要说明:

Clause 22读数据帧格式如下:
在这里插入图片描述

图12 Clause 22 读数据帧格式

Clause 22写数据帧格式如下:

在这里插入图片描述

图13 Clause 22 写数据帧格式

Clause 45 地址帧格式如下:

在这里插入图片描述

图14 Clause 45 地址帧格式

Clause 45 读数据帧格式如下:

在这里插入图片描述

图15 Clause 45 读数据帧格式

Clause 45 写数据帧格式如下:

在这里插入图片描述

图16 Clause 45 写数据帧格式

如下图17,小T根据上述Clause 22与Clause 45的帧格式定义,列举了两者之间的帧格式的定义说明以及区别联系,这样便于大家对两者格式的使用有个基本认识。

在这里插入图片描述

图17 Clause 22与Clause 45帧格式区别与联系

DMA协议基础介绍

DMA协议对于使用过它的朋友而言,特别是做底层驱动开发的朋友应该不会陌生,DMA就是为了在不需要CPU干预的前提下来实现外设与内存之间的搬运或者内存与内存之间的搬运,那么以太网DMA也是如此,就是为了实现以太网外设与内存之间的数据交换。

本文不会对DMA协议本身做过多的解释说明,旨在说明DMA在以太网数据收发过程中如何起作用,通过如下的两张图来了解认识DMA在以太网数据收发过程中的用途。

以太网DMA发送

如下图18所示,Tx ringbuffer作为DMA描述符,DMA在以太网发送过程中的作用表现:

在这里插入图片描述

图18 以太网DMA发送过程

以太网DMA接收

如下图19所示,Tx Ringbuffer作为DMA描述符,DMA在以太网接收过程中的作用表现:

在这里插入图片描述

图18 以太网DMA接收过程

常用函数总结

为了便于大家更好的使用Eth Driver这个模块,小T整理了关于车载以太网驱动这部分常用的函数接口与功能说明,如下图19所示:

在这里插入图片描述

图19 以太网驱动常用函数接口

更多精彩内容,敬请关注公号“ADAS与ECU之吾见”!!!

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

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

相关文章

java虚拟机反射机制

(1)Java虚拟机反射机制的定义? Java反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意方法和属性;这种动态获取信息以及动态调用对象方法的功…

苍穹最终一致性使用

适用场景 最终一致模式可以保证跨数据库或跨节点更新时的数据一致。它会以1个更新操作为基准,注册多个其它更新操作,最终保证所有更新都成功,实现分布式事务的弱一致性。可以适用一个更新适用多个场景(跨云、跨库、跨系统) 工作原理 1、在第…

4月17日第壹简报,星期一,农历闰二月廿七

4月17日第壹简报,星期一,农历闰二月廿七坚持阅读,静待花开1. 风云三号G星顺利入轨!我国成功发射首颗主动降水测量卫星(能探测到毛毛雨般的降水)。2. 四次出舱!神舟十五号乘组刷新单个乘组出舱活…

Opencv c++ 图片截取不规则ROI区域

做目标检测的很多时候,需要我们选择一个相对固定的区域来识别目标。 思路很简单,适合相机固定,ROI变化不大的场景。 1、原图备份后先截取不规则的ROI区域,其他区域置为黑背景,检测识别效果 2、在原图上,将…

全新适配鸿蒙生态,Cocos引擎助力3D应用开发

一、适配HarmonyOS背景 HarmonyOS 3.1版本自发布以来,备受广大开发者的好评,同时也吸引了鸿蒙生态众多伙伴的青睐。 鸿蒙生态所强调的智慧全场景、多端联动与跨设备流转等能力,与Cocos所具有的跨平台、低功耗、高性能三大核心特点不谋而合。C…

银河麒麟服务器ky10 sp3 x86编译安装postgresql(包含uuid)

目录 下载 编译安装 目录说明 脚本文件说明 压缩包说明 脚本代码 下载 官网 PostgreSQL: The worlds most advanced open source database 源码下载地址 PostgreSQL: File Browser 有多个版本可以选择,我选择的是10.23 点击下载即可 我下载好之后把他上传到…

Qt网络编程 (udp广播和接收例)

大纲概述senderreceiver演示概述 使用两个项目 1 sender 用来广播"hello world";2 receiver 用来接收广播信息 sender 1 创建Qdialog类2 在sender.pro 中添加 QT network 一行代码3 在sender.h 中声明类 class QUdpSocket;在声明一个私有对象QUdpSocket *sender;…

ASEMI代理AD8226ARZ-R7亚德诺(ADI)车规级AD8226ARZ-R7

编辑:ll ASEMI代理AD8226ARZ-R7亚德诺(ADI)车规级AD8226ARZ-R7 型号:AD8226ARZ-R7 品牌:ADI /亚德诺 封装:SOIC-8 批号:2023 安装类型:表面贴装型 引脚数量:8 类…

VS 创建ATL组件(C++)

目录1、新建ATL项目2、添加接口类、实现接口方法3、创建自己的方法。在头文件Add.h中添加声明4、在源文件Add.cpp中添加函数实现5、在MyComTest.idl中添加方法接口设置,如interface IAdd:IDispatch中所示。6、解决方案配置选择release, 平台选择x64,生成。MyComTest…

【数据结构与算法】判定给定的字符向量是否为回文算法

题目: Qestion: 试写一个算法判定给定的字符向量是否为回文。   回文解释: 回文是指正读反读均相同的字符序列,如“abba”和“abdba”均是回文,但“good”不是回文。 主要思路: 因为数据要求不是很严格并且是一个比较简单的…

软件测试—基础篇

软件测试—基础篇🔎软件测试的生命周期🔎如何描述一个BUG🔎如何定义BUG 的级别🔎BUG 的生命周期🔎测试的执行与管理测试的执行与管理如何发现更多的BUG🔎产生争执怎么办🔎结尾🔎软件…

基于PaddlePaddle的词向量实战 | 深度学习基础任务教程系列

词向量是自然语言处理中常见的一个操作,是搜索引擎、广告系统、推荐系统等互联网服务背后常见的基础技术。 在这些互联网服务里,我们经常要比较两个词或者两段文本之间的相关性。为了做这样的比较,我们往往把词表示成计算机适合处理的方式。最…

CRM管理系统有哪些优势?在企业中有什么作用?

CRM管理系统有哪些优势?在企业中有什么作用? 其实,公司上crm管理系统不仅不会增加员工负担,还能提升员工满意度、赋能员工。当然,前提是一款优质的CRM管理系统。 那么,一款优质的CRM管理系统一般具备哪些…

45.Promise,async,await

目录 1 Promise 1.1 状态 1.2 then 1.3 任务的优先级 1.4 连续then 1.4.1 then()的返回值也是一个Promise对象 1.4.2 默认情况下,在第一个then之后,会执行第二个then的成功函数 1.4.3 then的value可以用返回值传递 1.4.4 通过then的返…

为什么老年人会经常性出现吃饭呛咳的情况 什么因素导致的

其实很多老年人在吃饭或是喝水的时候,都存在吞咽困难的问题,呛咳或者是忘了如何下咽。其实在老年人群体当中,这也是一种较为常见的现象,但是很多人都把这种现象当回事。 对于呛咳的现象是很好判断的,在家里老人喝水或是…

专注区块链底层技术突破,“复杂美”用技术开源推动产业未来

杭州复杂美科技有限公司(以下简称:复杂美)成立于2008年,是一家致力于高性能撮合技术研发的区块链底层技术提供商,专注于区块链撮合系统、区块链清算系统的应用与推广。 公司于2013年启动区块链、智能合约的研发应用&am…

PyTorch 深度学习实战 | 基于 ResNet 的花卉图片分类

“工欲善其事,必先利其器”。如果直接使用 Python 完成模型的构建、导出等工作,势必会耗费相当多的时间,而且大部分工作都是深度学习中共同拥有的部分,即重复工作。所以本案例为了快速实现效果,就直接使用将这些共有部…

36岁大龄程序员被裁,找了2个月工作,年包从100万降到50万,要不要接?

为了找到工作,你愿意接受降薪多少?一位36岁的杭州程序员问:36岁被裁,找了2个月工作,年包从100万降到50万,真心纠结,要不要接?网友们分成了旗帜鲜明的两派,一派人认为不要…

【数学模型】欧拉公式和证明

一、说明 在图型学中,欧拉公式很有用处,比如皮克定律也可以用欧拉公式证明。本篇介绍欧拉公式的定义和三个证明过程。 二、欧拉公式 在任何一个规则球面地图上,用 R记区域个 数 ,V记顶点个数 ,E记边界个数 &#xff0c…

BGP基础知识

今天海翎光电的小编主要介绍一下BGP的相关基础知识,文章浅显易懂,适合对BGP完全没有了解的同学。 BGP介绍 边界网关协议BGP(Border Gateway Protocol)是一种实现自治系统AS(Autonomous System)之间的路由可…