车载以太网基础篇之EthernetDriver

谈思汽车 2023-04-11 10:49

点击上方蓝字谈思汽车

获取更多汽车网络安全资讯


前言

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

  • 你知道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特性

如之前文章所述,大家相比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 以太网驱动常用函数接口



码上报名

2023第六届无人驾驶及智能驾舱中国峰会

5月11-12日,上海



码上报名

AutoSec 7周年年会暨中国汽车网络安全与数据安全合规峰会,5月11-12日,上海


码上报名

第四届中国国际汽车以太网峰会,6月8-9日,上海



谈思汽车社群目前已覆盖


自动驾驶、信息安全、网络安全、车联网……

谈思汽车 智能汽车安全新媒体
评论
  • 每日可见的315MHz和433MHz遥控模块,你能分清楚吗?众所周知,一套遥控设备主要由发射部分和接收部分组成,发射器可以将控制者的控制按键经过编码,调制到射频信号上面,然后经天线发射出无线信号。而接收器是将天线接收到的无线信号进行解码,从而得到与控制按键相对应的信号,然后再去控制相应的设备工作。当前,常见的遥控设备主要分为红外遥控与无线电遥控两大类,其主要区别为所采用的载波频率及其应用场景不一致。红外遥控设备所采用的射频信号频率一般为38kHz,通常应用在电视、投影仪等设备中;而无线电遥控设备
    华普微HOPERF 2025-01-06 15:29 153浏览
  • 村田是目前全球量产硅电容的领先企业,其在2016年收购了法国IPDiA头部硅电容器公司,并于2023年6月宣布投资约100亿日元将硅电容产能提升两倍。以下内容主要来自村田官网信息整理,村田高密度硅电容器采用半导体MOS工艺开发,并使用3D结构来大幅增加电极表面,因此在给定的占位面积内增加了静电容量。村田的硅技术以嵌入非结晶基板的单片结构为基础(单层MIM和多层MIM—MIM是指金属 / 绝缘体/ 金属) 村田硅电容采用先进3D拓扑结构在100um内,使开发的有效静电容量面积相当于80个
    知白 2025-01-07 15:02 128浏览
  • 大模型的赋能是指利用大型机器学习模型(如深度学习模型)来增强或改进各种应用和服务。这种技术在许多领域都显示出了巨大的潜力,包括但不限于以下几个方面: 1. 企业服务:大模型可以用于构建智能客服系统、知识库问答系统等,提升企业的服务质量和运营效率。 2. 教育服务:在教育领域,大模型被应用于个性化学习、智能辅导、作业批改等,帮助教师减轻工作负担,提高教学质量。 3. 工业智能化:大模型有助于解决工业领域的复杂性和不确定性问题,尽管在认知能力方面尚未完全具备专家级的复杂决策能力。 4. 消费
    丙丁先生 2025-01-07 09:25 105浏览
  • 本文介绍Linux系统更换开机logo方法教程,通用RK3566、RK3568、RK3588、RK3576等开发板,触觉智能RK3562开发板演示,搭载4核A53处理器,主频高达2.0GHz;内置独立1Tops算力NPU,可应用于物联网网关、平板电脑、智能家居、教育电子、工业显示与控制等行业。制作图片开机logo图片制作注意事项(1)图片必须为bmp格式;(2)图片大小不能大于4MB;(3)BMP位深最大是32,建议设置为8;(4)图片名称为logo.bmp和logo_kernel.bmp;开机
    Industio_触觉智能 2025-01-06 10:43 90浏览
  • 本文介绍编译Android13 ROOT权限固件的方法,触觉智能RK3562开发板演示,搭载4核A53处理器,主频高达2.0GHz;内置独立1Tops算力NPU,可应用于物联网网关、平板电脑、智能家居、教育电子、工业显示与控制等行业。关闭selinux修改此文件("+"号为修改内容)device/rockchip/common/BoardConfig.mkBOARD_BOOT_HEADER_VERSION ?= 2BOARD_MKBOOTIMG_ARGS :=BOARD_PREBUILT_DTB
    Industio_触觉智能 2025-01-08 00:06 77浏览
  • 在智能家居领域中,Wi-Fi、蓝牙、Zigbee、Thread与Z-Wave等无线通信协议是构建短距物联局域网的关键手段,它们常在实际应用中交叉运用,以满足智能家居生态系统多样化的功能需求。然而,这些协议之间并未遵循统一的互通标准,缺乏直接的互操作性,在进行组网时需要引入额外的网关作为“翻译桥梁”,极大地增加了系统的复杂性。 同时,Apple HomeKit、SamSung SmartThings、Amazon Alexa、Google Home等主流智能家居平台为了提升市占率与消费者
    华普微HOPERF 2025-01-06 17:23 185浏览
  • By Toradex 秦海1). 简介嵌入式平台设备基于Yocto Linux 在开发后期量产前期,为了安全以及提高启动速度等考虑,希望将 ARM 处理器平台的 Debug Console 输出关闭,本文就基于 NXP i.MX8MP ARM 处理器平台来演示相关流程。 本文所示例的平台来自于 Toradex Verdin i.MX8MP 嵌入式平台。  2. 准备a). Verdin i.MX8MP ARM核心版配合Dahlia载板并
    hai.qin_651820742 2025-01-07 14:52 93浏览
  • PLC组态方式主要有三种,每种都有其独特的特点和适用场景。下面来简单说说: 1. 硬件组态   定义:硬件组态指的是选择适合的PLC型号、I/O模块、通信模块等硬件组件,并按照实际需求进行连接和配置。    灵活性:这种方式允许用户根据项目需求自由搭配硬件组件,具有较高的灵活性。    成本:可能需要额外的硬件购买成本,适用于对系统性能和扩展性有较高要求的场合。 2. 软件组态   定义:软件组态主要是通过PLC
    丙丁先生 2025-01-06 09:23 92浏览
  • 这篇内容主要讨论三个基本问题,硅电容是什么,为什么要使用硅电容,如何正确使用硅电容?1.  硅电容是什么首先我们需要了解电容是什么?物理学上电容的概念指的是给定电位差下自由电荷的储藏量,记为C,单位是F,指的是容纳电荷的能力,C=εS/d=ε0εrS/4πkd(真空)=Q/U。百度百科上电容器的概念指的是两个相互靠近的导体,中间夹一层不导电的绝缘介质。通过观察电容本身的定义公式中可以看到,在各个变量中比较能够改变的就是εr,S和d,也就是介质的介电常数,金属板有效相对面积以及距离。当前
    知白 2025-01-06 12:04 205浏览
  • 根据Global Info Research项目团队最新调研,预计2030年全球封闭式电机产值达到1425百万美元,2024-2030年期间年复合增长率CAGR为3.4%。 封闭式电机是一种电动机,其外壳设计为密闭结构,通常用于要求较高的防护等级的应用场合。封闭式电机可以有效防止外部灰尘、水分和其他污染物进入内部,从而保护电机的内部组件,延长其使用寿命。 环洋市场咨询机构出版的调研分析报告【全球封闭式电机行业总体规模、主要厂商及IPO上市调研报告,2025-2031】研究全球封闭式电机总体规
    GIRtina 2025-01-06 11:10 117浏览
  • 随着市场需求不断的变化,各行各业对CPU的要求越来越高,特别是近几年流行的 AIOT,为了有更好的用户体验,CPU的算力就要求更高了。今天为大家推荐由米尔基于瑞芯微RK3576处理器推出的MYC-LR3576核心板及开发板。关于RK3576处理器国产CPU,是这些年的骄傲,华为手机全国产化,国人一片呼声,再也不用卡脖子了。RK3576处理器,就是一款由国产是厂商瑞芯微,今年第二季推出的全新通用型的高性能SOC芯片,这款CPU到底有多么的高性能,下面看看它的几个特性:8核心6 TOPS超强算力双千
    米尔电子嵌入式 2025-01-03 17:04 57浏览
  •     为控制片内设备并且查询其工作状态,MCU内部总是有一组特殊功能寄存器(SFR,Special Function Register)。    使用Eclipse环境调试MCU程序时,可以利用 Peripheral Registers Viewer来查看SFR。这个小工具是怎样知道某个型号的MCU有怎样的寄存器定义呢?它使用一种描述性的文本文件——SVD文件。这个文件存储在下面红色字体的路径下。    例:南京沁恒  &n
    电子知识打边炉 2025-01-04 20:04 113浏览
  • 根据环洋市场咨询(Global Info Research)项目团队最新调研,预计2030年全球无人机锂电池产值达到2457百万美元,2024-2030年期间年复合增长率CAGR为9.6%。 无人机锂电池是无人机动力系统中存储并释放能量的部分。无人机使用的动力电池,大多数是锂聚合物电池,相较其他电池,锂聚合物电池具有较高的能量密度,较长寿命,同时也具有良好的放电特性和安全性。 全球无人机锂电池核心厂商有宁德新能源科技、欣旺达、鹏辉能源、深圳格瑞普和EaglePicher等,前五大厂商占有全球
    GIRtina 2025-01-07 11:02 103浏览
  • 彼得·德鲁克被誉为“现代管理学之父”,他的管理思想影响了无数企业和管理者。然而,关于他的书籍分类,一种流行的说法令人感到困惑:德鲁克一生写了39本书,其中15本是关于管理的,而其中“专门写工商企业或为企业管理者写的”只有两本——《为成果而管理》和《创新与企业家精神》。这样的表述广为流传,但深入探讨后却发现并不完全准确。让我们一起重新审视这一说法,解析其中的矛盾与根源,进而重新认识德鲁克的管理思想及其著作的真正价值。从《创新与企业家精神》看德鲁克的视角《创新与企业家精神》通常被认为是一本专为企业管
    优思学院 2025-01-06 12:03 150浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦