0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

基于AUTOSAR的应用层如何获取准确的时间戳呢

汽车ECU开发 ? 来源:ADAS与ECU之吾见 ? 作者:奋斗的农民工 ? 2022-09-21 14:42 ? 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

前言

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

基于AUTOSAR的应用层如何获取准确的时间戳吗?

时间同步的具体过程包含哪些细节呢?

如何正确地获取到全局时间戳呢?

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

eb2ee662-396f-11ed-9e49-dac502259ad0.png

正文

时间同步软件框架

正如前文《AUTOSAR基础篇之CanTsyn》所述,CanTsyn模块负责时间同步之间的协议处理,StbM模块则用来负责抽象底层不同的时间同步协议,为上层提供统一的时间戳接口以及当前的时间同步状态的接口。

通过如下图1所示的Tsync则用来代表基于不同总线通讯的时间同步协议,StbM则是时间同步协议层基础上的抽象,OS作为Triggered Customer,SW-C则作为Active Customer,后文将解释这两者之间的区别。

ebe2bf48-396f-11ed-9e49-dac502259ad0.png

图1 AUTOSAR时间同步协议软件框架

在上图中,我们可以看到存在5个不一样的数据流,下面将一一解释每个数据流的基本作用:

数据流1表示StbM主动调用TriggerCustomer提供的函数接口来完成时间同步,当前主要应用场景为OS Schedule Table的同步;

数据流2表示Active Customer(SW-C)主动调用StbM提供的标准接口来获取当前时间戳或者时间同步状态;

数据流3表示Active Customer(SW-C)主动调用StbM提供的标准接口来更新StbM维护的时间基准;

数据流4表示StbM模块通过Tsyn模块提供的标准函数接口来更新StbM的时间基准;

数据流5表示StbM模块主动通过Tsyn模块提供的标准函数接口来将当前的时间同步信息发送到相应的bus总线上。

在时间同步领域内涉及到诸多专有名词,因此为了便于大家理解后续的内容,有必要在此跟大家解释些重要的标准术语,具体细节如下图2所示:

ebffe0fa-396f-11ed-9e49-dac502259ad0.png

图2 时间同步标准术语解释

启动阶段

在该阶段StbM模块将会提供完成必要的初始化来提供针对上层应用的时间同步服务。

前置条件

StbM模块通过调用函数接口StbM_Init来完成初始化工作,但是在此之前需务必完成基础通讯模块的初始化,如Canif模块初始化,CanTsyn模块初始化等。

初始化

通过调用上述函数完成初始化之后,将会完成如下基本动作:

变量StbMSynchrinizedTimeBase将会被初始化为0;

timeBaseStatus将会将所有的bit初始化为0;

如果参数StbMStoreTimebaseNonVolatile等于STORAGE_AT_SHUTDOWN,那么就会从NVM中获取数据(一般包含s跟ns部分),如果NVM获取数据不成功,则都会赋值为0处理。

正常工作

Synchronized Time Base

每一次调用函数接口StbM_BusSetGlobalTime()时就会更新对应的同步time base以及对应的Time Base Status。

Time Master 同步状态监控

如下图3所示,一个全局时间网络至少一个Time Master跟一个Time Slave, Time Master将会将其时间信息传递至在同一Time Domain下的Time Slave。

ec2e2d34-396f-11ed-9e49-dac502259ad0.png

图3 Time Master 同步状态更新示意图

由上图可知,Time Master通过reference本地clock来更新本地全局时间,然后通过sync/FUP报文发送给到总线上。其中,如果Time Domain为0-15则为synchronized time base,而Time Domain 16-31则为Offset Time Base。

通过调用函数接口 StbM_GetCurrentTime() 来获取当前对应Time Domain下的Time Base,对应的timebasestatus以及user data;

通过调用函数接口StbM_GetCurrentTimeRaw() 来获取当前时间Time Base的ns部分;

通过调用函数接口StbM_GetCurrentTimeDiff() 来获取输入的时间戳与当前时间戳的时间间隔,单位为ns;

通过调用函数接口StbM_BusSetGlobalTime()来更新当前的Time Base以及设置对应的timebaseStatus;

通过调用函数接口 StbM_SetGlobalTime()并且会就将GLOBAL_TIME_BASE bit位置1,同时清除其他bit 位;

Time Slave 同步状态监控

如下图4所示体现了Time Slave的数据流交互关系,在下图中我们可以看到Time Slave会接收来自同一Time Domin下的sync/fup 报文,同时加上本地计算出来的接收sync/fup报文的时间差最终用于更新当前StbM的Time Base,该Time Base将最终被应用到应用层。

ec4ef06e-396f-11ed-9e49-dac502259ad0.png

图4 Time Slave同步状态更新图

Time Slave在完成上述时间同步的过程中,需要注意几点:

每次更新调用函数StbM_BusSetGlobalTime时,都会比较下当前更新的时间戳与当前内部正在使用的时间戳的差值是否超过StbMSyncLossThreshold参数设定的值,如果该值为0,则会取消该部分的检查,如果超过了设定的值, 那么将会将timeBaseStatus中的状态位TIMELEAP 置1;

如果下一次更新,差值保证在范围内,那么timeBaseStatus中的状态位TIMELEAP将会被清0;

TIme Slave会实时确认下当前的时间戳与最近一次调用该函数的时间差距是否在参数StbMSyncLossTimeout设定的范围内,如果Timeout发生,那么需置timeBaseStatus中的TIMEOUT bit位,一旦调用StbM_BusSetGlobalTime函数将会清除该TIMEOUT bit位。

如果从来没有发生过时间同步, 那么TIMEOUT位将不会置位,只要发生过一次成功的时间同步,后续同步没有按照预期发送,那么就会启动这个Timeout检查。

如果参数syncToTimeBase设定为sync to GTM,那么调用StbM_BusSetGlobalTime() 将会清除timeBaseStatus中的SYNC_TO_GATEWAY bit位;

如果参数syncToTimeBase设定为sync to subdomain,那么调用StbM_BusSetGlobalTime() 将会置位timeBaseStatus中的SYNC_TO_GATEWAY bit位;

一旦调用函数接口fStbM_BusSetGlobalTime(),那么就会设置timeBaseStatus中的GLOBAL_TIME_BASE Bit位,一旦置位,则不会清除。

Time Gateway同步状态监控

Time Gateway既作为属于某个Time Domain的Time slave,同时也会作为某个Time Domain下的Time Master而存在,如果存在Time Gateway的节点,那么必然存在Time SubDomain的概念。

如果Time Gateway作为某个Time Domain的Time Slave存在,同样存在着如下特性需要了解:

每次更新调用函数StbM_BusSetGlobalTime时,都会比较下当前更新的时间戳与当前内部正在使用的时间戳的差值是否超过StbMSyncLossThreshold参数设定的值,如果该值为0,则会取消该部分的检查,如果超过了设定的值, 那么将会将timeBaseStatus中的状态位TIMELEAP 置1;

如果下一次更新,差值保证在范围内,那么timeBaseStatus中的状态位TIMELEAP将会被清0;

TIme Slave会实时确认下当前的时间戳与最近一次调用该函数的时间差距是否在参数StbMSyncLossTimeout设定的范围内,如果Timeout发生,那么需置timeBaseStatus中的TIMEOUT bit位,一旦调用StbM_BusSetGlobalTime函数将会清除该TIMEOUT bit位。

如果从来没有发生过时间同步, 那么TIMEOUT位将不会置位,只要发生过一次成功的时间同步,后续同步没有按照预期发送,那么就会启动这个Timeout检查。

如果参数syncToTimeBase设定为sync to GTM,那么调用StbM_BusSetGlobalTime() 将会清除timeBaseStatus中的SYNC_TO_GATEWAY bit位;

如果参数syncToTimeBase设定为sync to subdomain,那么调用StbM_BusSetGlobalTime() 将会置位timeBaseStatus中的SYNC_TO_GATEWAY bit位;

一旦调用函数接口fStbM_BusSetGlobalTime(),那么就会设置timeBaseStatus中的GLOBAL_TIME_BASE Bit位,一旦置位,则不会清除。

Offset Time Base

对于Offset Time Base,相比Synchronized Time Base存在着如下一些特性:

每次调用StbM_SetOffset()就会用来更新相应的Time base的 Offset Time;

函数StbM_SetOffset() 与StbM_GetOffset() 只能接收16-31的TimeBaseId;

每一次调用函数StbM_GetOffset()将会返回对应的Offset Time Base的Offset Time;

在配置上也会存在限制,即只有StbMSynchronizedTimeBaseIdentifier为16至31,StbMOffsetTimeBase才会真实有效。

Customer

Customers作为理解为基于StbM模块基础之上的一种应用角色,按照其功能作用可划分为如下两种角色:

Active customers:顾名思义就是一种主动触发调用StbM相关函数接口的应用角色;

Triggered customers:就是一种被动被StbM模块调用其自身接口的应用角色;

Active customers

对于Active customers,为了便于理解,我们可以列出如下场景来体现其基本作用:

读取当前的time base value,同步状态以及user data;

设置对应time base的value以及相应的user data;

Triggered customers

对于Triggered customer,当前仅用于同步OS的schedule table,通过调用OS提供的API函数 SyncScheduleTable() 来实现Schedule Table之间的counter同步。

通过配置参数STBM_TRIGGERED_CUSTOMER_PERIOD来完成StbM定周期调用上述函数接口来完成各个sechdule table的os counter间的同步;

同时StbM仅在Schedule Table 处于WAITING,RUNNING,或者 RUNNING_SYNCHRONOUS状态时完成同步,因此也就意味着StbM在同步前先要确认下当前需同步的Schedule Table的状态,然后才能进行同步。

关闭阶段

针对Shutdown阶段,仅存在一个需要做的操作,如果参数StbMStoreTimebaseNonVolatile等于STORAGE_AT_SHUTDOWN,那么便会将当前实时时间戳(S跟ns部分)存储在NVM中。

常用函数接口说明

为了便于大家了解StbM模块所提供的基本功能,因此将常见的函数接口列举如下,以方便大家的查阅:

ec6cefa6-396f-11ed-9e49-dac502259ad0.png

图5 StbM模块常用函数接口




审核编辑:刘清

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • AUTOSAR
    +关注

    关注

    10

    文章

    382

    浏览量

    22842
  • NVM
    NVM
    +关注

    关注

    1

    文章

    44

    浏览量

    19472
  • Bus总线
    +关注

    关注

    1

    文章

    6

    浏览量

    8074
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    时间准确?就选网络时间服务器

    网络时间服务器是为网络设备提供准确、标准、、可靠和多功能的时间服务的解决方案,能提供准确的同步时钟信号,支持标准的NTP和SNTP网络时间
    的头像 发表于 08-13 15:39 ?54次阅读
    <b class='flag-5'>时间</b>不<b class='flag-5'>准确</b>?就选网络<b class='flag-5'>时间</b>服务器

    EPSON实时时钟模块RX8111CE为血压计提供灵活稳定低功耗时钟和时间功能

    记录是其非常重要的一项功能。电子血压计内的时间计时会被用在以下几个方面:1.准确记录测量时间,辅助医生对病人的病程变化的判断,以确定后续治疗安排,这就需求时间
    的头像 发表于 02-12 16:55 ?468次阅读
    EPSON实时时钟模块RX8111CE为血压计提供灵活稳定低功耗时钟和<b class='flag-5'>时间</b><b class='flag-5'>戳</b>功能

    AUTOSAR通信对自动驾驶的影响 AUTOSAR通信与嵌入式系统设计

    AUTOSAR通信与嵌入式系统设计紧密相连,共同推动着自动驾驶技术的发展。 AUTOSAR通信对自动驾驶的影响 提高通信效率和可靠性 AUTOSAR通信协议栈通过标准化的接口和协议,实现了汽车电子控制单元(ECU)之间的高效、
    的头像 发表于 12-17 15:09 ?828次阅读

    AUTOSAR通信与网络安全 AUTOSAR通信在车辆中的应用

    架构合作伙伴计划,旨在创建并建立一个开放的标准化软件架构,以简化汽车电子控制单元(ECU)的开发和生产。 1. AUTOSAR通信概述 AUTOSAR定义了一个分层的软件架构,其中包括了通信
    的头像 发表于 12-17 15:06 ?1068次阅读

    AUTOSAR中通信堆栈的配置 AUTOSAR通信模块测试方法

    )的开发和生产。通信堆栈是AUTOSAR架构中的关键组成部分,负责处理ECU之间的通信。 AUTOSAR中通信堆栈的配置 通信模型 : AUTOSAR定义了一种分层的通信模型,包括应用层
    的头像 发表于 12-17 15:01 ?1115次阅读

    AUTOSAR通信框架的优势 AUTOSAR通信实例与应用场景

    AUTOSAR通信框架的优势 AUTOSAR(AUTomotive Open System ARchitecture)是一个全球性的汽车软件架构合作伙伴计划,旨在创建并建立一个开放的标准化软件架构
    的头像 发表于 12-17 14:58 ?1171次阅读

    AUTOSAR通信与CAN协议的关系

    AUTOSAR通信模型: AUTOSAR定义了一个分层的软件架构,其中包括应用层、基础软件和微控制器抽象。在这些
    的头像 发表于 12-17 14:57 ?1110次阅读

    AUTOSAR通信组件介绍 AUTOSAR通信功能分析

    实现汽车电子控制单元(ECU)的软件设计和开发。这个架构包括多个,其中通信AUTOSAR架构中的关键组成部分之一。 1. 通信组件概述 AUTOSAR通信组件主要负责ECU之间的
    的头像 发表于 12-17 14:55 ?1622次阅读

    AUTOSAR通信协议解析 如何实现AUTOSAR通信

    AUTOSAR(Automotive Open System Architecture)即汽车开放系统架构,该架构支持汽车电子控制单元(ECU)之间的通信,实现了高度模块化和可重用性。AUTOSAR
    的头像 发表于 12-17 14:54 ?3158次阅读

    Java中时间的使用

    Java中时间的使用
    的头像 发表于 11-06 16:04 ?573次阅读
    Java中<b class='flag-5'>时间</b><b class='flag-5'>戳</b>的使用

    PCM2707C是否支持Android系统?PCM2707C Android应用层怎么写?

    有如下两个问题,帮忙看看,谢谢! 1,PCM2707C是否支持Android系统 2,PCM2707C Android应用层怎么写?如何获取USB上的音频数据。
    发表于 10-30 07:46

    同星多设备间的时间同步机制TSync功能与使用

    随着汽车网络测试的通道数量不断增加,时常需要多个同星设备同时连接在同一台电脑的同一个TSMaster应用程序,并进行多设备同时执行CAN报文收发和记录等功能,必然有多设备之间的时间同步以及设备
    的头像 发表于 10-12 08:05 ?3460次阅读
    同星多设备间的<b class='flag-5'>时间</b><b class='flag-5'>戳</b>同步机制TSync功能与使用

    Linux应用层控制外设的两种不同的方式

    众所周知,linux下一切皆文件,那么应用层如何控制硬件,同样是通过 文件I/O的方式来实现的,那么应用层控制硬件通常有两种方式。
    的头像 发表于 10-05 19:03 ?1445次阅读
    Linux<b class='flag-5'>应用层</b>控制外设的两种不同的方式

    物联网中的普通传感器如何通过DTU/RTU透传带有时间和IMEI的数据

    一 概述 时间是指格林威治时间1970年01月01日00时00分00秒(北京时间1970年01月01日08时00分00秒)起至现在的总秒数。时间
    的头像 发表于 09-25 16:35 ?1896次阅读
    物联网中的普通传感器如何通过DTU/RTU透传带有<b class='flag-5'>时间</b><b class='flag-5'>戳</b>和IMEI的数据

    合宙LuatOS应用,与时间相关那些事

    ()函数了。 接下来,我会讲一些与这个函数以及其他时间函数相关的知识。 一、时间相关 os.time()这个函数,只能获取当前时间
    的头像 发表于 09-25 07:25 ?673次阅读
    合宙LuatOS应用,与<b class='flag-5'>时间</b>相关那些事