【OS】AUTOSAROSCounter实现原理(上篇)

原创 汽车电子嵌入式 2024-07-01 07:54

前言

<>一文中我们介绍了STM用于Os  Counter的硬件Counter实现;在<<符合AUTOSAR标准的RTAOS--Counters详解>>一文中我们介绍了AUTOSAR Counter的概念及其配置,但是站在开发者的角度来讲,Os Counter这个概念还是很抽象,Counter在代码中到底具体是个什么了?本文就来就详细介绍Os Counter的具体实现原理,希望能理解以下问题:

问题1Os Resource在代码中的具体实现是什么?

问题2:如何区分软件Counter和硬件Counter, 硬件Counter是否还可以再细分?

问题3AlarmCounter的具体交互过过程?

值得关注的features: Os利用数组下标实现类似二叉树的逻辑结构,达到使用同一个Counter的任务(Job, 来自Alarm或者ScheduleTable的请求)的优先级排序,本文也会详细介绍。

目录

环境

AUTOSAR工具链:Davinci

Hardware Platform: Infineon Tricore

Build Tools: GHS


注:本文章引用了一些第三方工具和文档,若有侵权,请联系作者删除!

正文

1.STM比较器的中断控制

Os Hardware Counter引用STM Channel后,Os Tick的实现就是依赖STMcompare中断事件:

 

Compare中断事件产生举例:


1:配置STMx_CMCON. MSTARTx位域,设置比较寄存器在STM中的起始位置

2:配置STMx_CMCON.MSIZEx使用STM_CMPx的宽度(多少bit

3:配置STM_CMPx. CMPVAL[31:0]定时器值

4:配置STM_ICR.CMPxOS到时触发STMIR0还是STMIR1中断

5:配置STM_ICR.CMPxEN使能中断,等待定时中断触发


中断触发后:在中断服务例程(ISR,中断服务函数)里设置STM_ISCR.CMPxIRR=1清除中断,并重复上述第5步操作重新使能中断,等待中断触发。参考:《TC3xx芯片STM介绍》


2.OsCounter类别及其适用场景

Counter类别

区别

适用场景

Software Counter

计数器是由OS内部维护,也就是一个RAM全局变量。

时间精度要求较低的场景

Hardware Counter

计数器是由外部硬件维护,比如STM_TIM0.

时间精度要求较高的场景

1:软件Counter和硬件Counter区别


硬件Counter类别

对应的配置宏

区别

Periodic tick timer

OS_CFG_COUNTER_PIT_USED

1. OsCounter配置容器下的Counter Type配置为HARDWARE.

 

2. OsDriver配置容器下Driver High Resolution配置为False.

 

3. OsDriver配置容器下Driver Hardware Timer Channel Ref引用了GPT Channel.

 

High resolution timer

OS_CFG_COUNTER_HRT_USED

1. OsCounter配置容器下的Counter Type配置为HARDWARE.

2. OsDriver配置容器下Driver High Resolution配置为True.

 

Periodic free running timer

OS_CFG_COUNTER_PFRT_USED

1. OsCounter配置容器下的Counter Type配置为HARDWARE.

 

2. OsDriver配置容器下Driver High Resolution配置为False.

 

3. OsDriver配置容器下Driver Hardware Timer Channel Ref引用了STM Channel.

 

2:硬件Counter的具体细分


1容易理解,表2AUTOSAR OS文档中是找不到的,来自TC3xx硬件平台上Os Counters的具体实现总结,详细可以看第3章节的Os Counter配置。


3.OsCounter配置

3.1 OsCounter配置容器


Short Name: 配置Counter的名字,用来标识一个Counter, 生成的配置代码中会使用这个名字。


Counter Max Allowed Value: 一个Counter的最大值,其配置范围为 [1, 2147483647] (0x7FFF FFFF == 2147483647), 这个值在计算使用同一个CounterJobJob来自于Alarm或者ScheduleTable的请求)的优先级的时候会使用到。至于为什么可配置最大值是2147483647,还不清楚。可能是这个最大值已经能满足所有工况了?


Counter Min: 一个Counter的最小值,其配置范围为 [1, Counter Max Allowed Value - 1].


Counter Ticks Per Base:

官方解释TICKSPERBASE属性指定达到计数器特定单位所需的tick数。解释是针对具体实施的。


该值是通过将所需计数器周期(OsSecondsPerTick)除以单个硬件刻度的周期来计算的,该周期是通过频率的倒数(1/fosc)来计算的。如果Counter配置为Software Counter, 则这个值恒为1.


个人理解:比如如果我们配置的Seconds Per Tick0.001s, 也就是1ms, 使用的是STM硬件时钟,那么(1/fstm) * Counter Ticks Per Base == Seconds Per Tick == 0.001s.

Counter Type: 配置为软件counter还是硬件counter.


Seconds Per Tick:

官方解释:一个计数器tick的时间(秒)。该值以秒为单位指定计数器所需的tick周期。


个人理解:配置Os Tick时基,也就是一个Os Tick是多少秒。


注意Os Tick和使用的硬件时钟的Tick不是一个意思。Os Tick == Seconds Per Tick == (1/fstm) * Counter Ticks Per Base


3.2 OsDriver配置容器

只有配置为Hardware Counter的才需要配置OsDriver.


Driver High Resolution: 配置改Hardware counter是否是一个高精度的定时器。对于高精度Counter的解释见下文。


3.3 PITHRT

3.3.1 Periodical Interrupt Timer (PIT)

定时器硬件设置为以严格的周期性间隔(例如1ms)生成定时器中断请求。在操作系统运行期间,间隔不会更改。


在每个定时器产生的ISR中,OS会检查AlarmSchedule-table的到期情况,并执行配置的操作(e.g. SetEvent…)。


配置PIT的步骤:

-Counter Type配置为HARDWARE, 同时在OsDriver配置容器中引用对应的硬件通道。

-OsDriverHighResolution配置为FALSE.

-属性OsSecondsPerTick”指定中断生成的周期时间。

-属性OsCounterTicksPerBase”指定达到“OsSecondsPerTick”所需的计时器计数器周期数。


注意OS将自动向配置中添加适当的ISR.


3.3.2 High Resolution Timer (HRT)

定时器硬件设置为在执行AlarmSchedule-table动作时生成一个定时器中断请求。

在每个定时器产生的ISR中,OS会执行该操作,计算下一个操作的定时器间隔,并用新的到期时间重新编程定时器硬件。

配置HRT的步骤:

-Counter Type配置为HARDWARE, 同时在OsDriver配置容器中引用对应的硬件通道。

-OsDriverHighResolution配置为TRUE.

-属性OsSecondsPerTick”指定中断生成的周期时间。

-属性OsCounterTicksPerBase”必须设置为10.

-属性OsCounterMaxAllowedValue”必须设置为0x3FFFFFFF.


注意

1. OS将自动向配置中添加适当的ISR.


2. 为避免操作系统时基损坏,HRT ISR的延迟时间不得超过硬件计数器周期的一半。例如,对于16位硬件计时器,半个硬件计数器周期是从0计数到0x7FFF所需的时间。


3.4 Counters类别汇总

从第2章节,我们得知,分类各种各样,这里又多了PITHRT的分配,是不是都晕了。通过下表可以清楚的理解他们的包含关系。



3: Counter的分类及其包含关系


3.5 PITPFRT对比

通过表3我们知道,PITPFRT除了Driver Hardware Timer Channel Ref配置不一样外,其他的配置都可以一样,Driver Hardware Timer Channel Ref引用GPT channelPIT,引用STM Channel则为PFRT.


其生成的配置代码差异如下:


我们举例几个由代表性的配置文件看看差异:

Os_Counter_Cfg.h

左边配置为PFRT,就会配置OS_CFG_COUNTER_PFRT_USEDSTD_ON;右边配置为PIT,就会配置OS_CFG_COUNTER_PIT_USEDSTD_ON.


Os_Counter_Lcfg.c

PFRTPIT的配置结构体也是有差异的,后文我们具体分析PFRT的配置代码。


4.OsCounter具体实现

我们这里以PFRT为例具体讲解Counter的实现。


感兴趣的可以阅读下篇



End

「汽车电子嵌入式在CSDN上同步推出AUTOSAR精进之路专栏,本专栏每个模块完全按实际项目中开发及维护过程来详细介绍。模块核心概念介绍、实际需求描述、实际工程配置、特殊需求介绍及背后原理、实际工程使用经验总结。目的是让读者看完每一个章节后能理解原理后根据需求完成一个模块的配置或者解决一个问题。」


点击文章最后左下角的阅读原文可以获取更多信息


或者复制如下链接到浏览器获取更多信息

https://blog.csdn.net/qq_36056498/article/details/132125693


文末福利




1
.如需汽车电子嵌入式收集的学习文档,
后台回复“

资料

即可免费下载;

2.为便于技术交流,创建了汽车电子嵌入式技术交流群,可尽情探讨AP,CP,DDS,SOME/IP等前沿热点话题,后台回复“加群”即可加入;


注:本文引用了一些第三方工具和文档,若有侵权,请联系作者删除!


推荐阅读

汽车电子嵌入式精彩文章汇总第一期:20210530-20230703

汽车电子嵌入式精彩文章汇总第2期

TC3xx芯片GTM模块-CMU,CCM,TBU详解

TC3xx芯片GTM模块-TOM详解

AUTOSAR架构下PWM模块配置实践

TC3xx芯片GTM模块-TIM详解

AUTOSAR架构下ICU模块配置实践

TC3xx芯片电源管理系统PMS详解

TC3xx DMA模块详解

TC3xx芯片SMU模块详解

如何监控TC3xx芯片PFlash的ECC错误

TC3xx芯片RAM的错误检测

TC3xx芯片的总线内存保护

AUTOSAR架构下MCAL Modules软件分区问题分析

AUTOSAR架构下内部看门狗复位检测

TC3xx芯片时钟监控

TC3xx芯片电压监控和温度监控

嵌入式基础:环形缓冲区ring buffer

AUTOSAR架构下ECU休眠唤醒Wakeup Time详解

【OS】AUTOSAR架构下的中断和异常向量表

【OS】AUTOSAR Os是如何启动第一个Task的

【OS】AUTOSAR OS如何实现Task抢占

【OS】AUTOSAR OS系统调用产生Trap的过程详解

【OS】AUTOSAR OS调度器实现原理

【OS】AUTOSAR OS Resource实现原理

编译链接专题第1篇-make和makefile介绍

编译链接专题第2篇-初识makefile结构

编译链接专题第3篇-初识makefile中的伪目标

编译链接专题第4篇-变量和变量的不同赋值方式

编译链接专题第5篇-预定义变量的使用

编译链接专题第6篇-变量的高级主题(上)

编译链接专题第7篇-变量的高级主题(下)

编译链接专题第8篇-条件判断语句




End


欢迎点赞,关注,转发,在看,您的每一次鼓励,都是我最大的动力!

汽车电子嵌入式

微信扫描二维码,关注我的公众号

评论
  • RDDI-DAP错误通常与调试接口相关,特别是在使用CMSIS-DAP协议进行嵌入式系统开发时。以下是一些可能的原因和解决方法: 1. 硬件连接问题:     检查调试器(如ST-Link)与目标板之间的连接是否牢固。     确保所有必要的引脚都已正确连接,没有松动或短路。 2. 电源问题:     确保目标板和调试器都有足够的电源供应。     检查电源电压是否符合目标板的规格要求。 3. 固件问题: &n
    丙丁先生 2024-12-01 17:37 83浏览
  • 当前,智能汽车产业迎来重大变局,随着人工智能、5G、大数据等新一代信息技术的迅猛发展,智能网联汽车正呈现强劲发展势头。11月26日,在2024紫光展锐全球合作伙伴大会汽车电子生态论坛上,紫光展锐与上汽海外出行联合发布搭载紫光展锐A7870的上汽海外MG量产车型,并发布A7710系列UWB数字钥匙解决方案平台,可应用于数字钥匙、活体检测、脚踢雷达、自动泊车等多种智能汽车场景。 联合发布量产车型,推动汽车智能化出海紫光展锐与上汽海外出行达成战略合作,联合发布搭载紫光展锐A7870的量产车型
    紫光展锐 2024-12-03 11:38 65浏览
  • 学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习笔记&记录学习习笔记&记学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&
    youyeye 2024-11-30 14:30 73浏览
  • 概述 说明(三)探讨的是比较器一般带有滞回(Hysteresis)功能,为了解决输入信号转换速率不够的问题。前文还提到,即便使能滞回(Hysteresis)功能,还是无法解决SiPM读出测试系统需要解决的问题。本文在说明(三)的基础上,继续探讨为SiPM读出测试系统寻求合适的模拟脉冲检出方案。前四代SiPM使用的高速比较器指标缺陷 由于前端模拟信号属于典型的指数脉冲,所以下降沿转换速率(Slew Rate)过慢,导致比较器检出出现不必要的问题。尽管比较器可以使能滞回(Hysteresis)模块功
    coyoo 2024-12-03 12:20 70浏览
  • 11-29学习笔记11-29学习笔记习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习笔记&记录学习习笔记&记学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&学习学习笔记&记录学习学习笔记&记录学习学习笔记&记
    youyeye 2024-12-02 23:58 51浏览
  • 作为优秀工程师的你,已身经百战、阅板无数!请先醒醒,新的项目来了,这是一个既要、又要、还要的产品需求,ARM核心板中一个处理器怎么能实现这么丰富的外围接口?踌躇之际,你偶阅此文。于是,“潘多拉”的魔盒打开了!没错,USB资源就是你打开新世界得钥匙,它能做哪些扩展呢?1.1  USB扩网口通用ARM处理器大多带两路网口,如果项目中有多路网路接口的需求,一般会选择在主板外部加交换机/路由器。当然,出于成本考虑,也可以将Switch芯片集成到ARM核心板或底板上,如KSZ9897、
    万象奥科 2024-12-03 10:24 38浏览
  •         温度传感器的精度受哪些因素影响,要先看所用的温度传感器输出哪种信号,不同信号输出的温度传感器影响精度的因素也不同。        现在常用的温度传感器输出信号有以下几种:电阻信号、电流信号、电压信号、数字信号等。以输出电阻信号的温度传感器为例,还细分为正温度系数温度传感器和负温度系数温度传感器,常用的铂电阻PT100/1000温度传感器就是正温度系数,就是说随着温度的升高,输出的电阻值会增大。对于输出
    锦正茂科技 2024-12-03 11:50 66浏览
  • 遇到部分串口工具不支持1500000波特率,这时候就需要进行修改,本文以触觉智能RK3562开发板修改系统波特率为115200为例,介绍瑞芯微方案主板Linux修改系统串口波特率教程。温馨提示:瑞芯微方案主板/开发板串口波特率只支持115200或1500000。修改Loader打印波特率查看对应芯片的MINIALL.ini确定要修改的bin文件#查看对应芯片的MINIALL.ini cat rkbin/RKBOOT/RK3562MINIALL.ini修改uart baudrate参数修改以下目
    Industio_触觉智能 2024-12-03 11:28 41浏览
  • 艾迈斯欧司朗全新“样片申请”小程序,逾160种LED、传感器、多芯片组合等产品样片一触即达。轻松3步完成申请,境内免费包邮到家!本期热荐性能显著提升的OSLON® Optimal,GF CSSRML.24ams OSRAM 基于最新芯片技术推出全新LED产品OSLON® Optimal系列,实现了显著的性能升级。该系列提供五种不同颜色的光源选项,包括Hyper Red(660 nm,PDN)、Red(640 nm)、Deep Blue(450 nm,PDN)、Far Red(730 nm)及Ho
    艾迈斯欧司朗 2024-11-29 16:55 168浏览
  • 光伏逆变器是一种高效的能量转换设备,它能够将光伏太阳能板(PV)产生的不稳定的直流电压转换成与市电频率同步的交流电。这种转换后的电能不仅可以回馈至商用输电网络,还能供独立电网系统使用。光伏逆变器在商业光伏储能电站和家庭独立储能系统等应用领域中得到了广泛的应用。光耦合器,以其高速信号传输、出色的共模抑制比以及单向信号传输和光电隔离的特性,在光伏逆变器中扮演着至关重要的角色。它确保了系统的安全隔离、干扰的有效隔离以及通信信号的精准传输。光耦合器的使用不仅提高了系统的稳定性和安全性,而且由于其低功耗的
    晶台光耦 2024-12-02 10:40 105浏览
  • 最近几年,新能源汽车愈发受到消费者的青睐,其销量也是一路走高。据中汽协公布的数据显示,2024年10月,新能源汽车产销分别完成146.3万辆和143万辆,同比分别增长48%和49.6%。而结合各家新能源车企所公布的销量数据来看,比亚迪再度夺得了销冠宝座,其10月新能源汽车销量达到了502657辆,同比增长66.53%。众所周知,比亚迪是新能源汽车领域的重要参与者,其一举一动向来为外界所关注。日前,比亚迪汽车旗下品牌方程豹汽车推出了新车方程豹豹8,该款车型一上市就迅速吸引了消费者的目光,成为SUV
    刘旷 2024-12-02 09:32 101浏览
  • 戴上XR眼镜去“追龙”是种什么体验?2024年11月30日,由上海自然博物馆(上海科技馆分馆)与三湘印象联合出品、三湘印象旗下观印象艺术发展有限公司(下简称“观印象”)承制的《又见恐龙》XR嘉年华在上海自然博物馆重磅开幕。该体验项目将于12月1日正式对公众开放,持续至2025年3月30日。双向奔赴,恐龙IP撞上元宇宙不久前,上海市经济和信息化委员会等部门联合印发了《上海市超高清视听产业发展行动方案》,特别提到“支持博物馆、主题乐园等场所推动超高清视听技术应用,丰富线下文旅消费体验”。作为上海自然
    电子与消费 2024-11-30 22:03 86浏览
  • 《高速PCB设计经验规则应用实践》+PCB绘制学习与验证读书首先看目录,我感兴趣的是这一节;作者在书中列举了一条经典规则,然后进行详细分析,通过公式推导图表列举说明了传统的这一规则是受到电容加工特点影响的,在使用了MLCC陶瓷电容后这一条规则已经不再实用了。图书还列举了高速PCB设计需要的专业工具和仿真软件,当然由于篇幅所限,只是介绍了一点点设计步骤;我最感兴趣的部分还是元件布局的经验规则,在这里列举如下:在这里,演示一下,我根据书本知识进行电机驱动的布局:这也算知行合一吧。对于布局书中有一句:
    wuyu2009 2024-11-30 20:30 106浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦