【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


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

汽车电子嵌入式

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

评论
  • 嘿,咱来聊聊RISC-V MCU技术哈。 这RISC-V MCU技术呢,简单来说就是基于一个叫RISC-V的指令集架构做出的微控制器技术。RISC-V这个啊,2010年的时候,是加州大学伯克利分校的研究团队弄出来的,目的就是想搞个新的、开放的指令集架构,能跟上现代计算的需要。到了2015年,专门成立了个RISC-V基金会,让这个架构更标准,也更好地推广开了。这几年啊,这个RISC-V的生态系统发展得可快了,好多公司和机构都加入了RISC-V International,还推出了不少RISC-V
    丙丁先生 2025-01-21 12:10 464浏览
  • 现在为止,我们已经完成了Purple Pi OH主板的串口调试和部分配件的连接,接下来,让我们趁热打铁,完成剩余配件的连接!注:配件连接前请断开主板所有供电,避免敏感电路损坏!1.1 耳机接口主板有一路OTMP 标准四节耳机座J6,具备进行音频输出及录音功能,接入耳机后声音将优先从耳机输出,如下图所示:1.21.2 相机接口MIPI CSI 接口如上图所示,支持OV5648 和OV8858 摄像头模组。接入摄像头模组后,使用系统相机软件打开相机拍照和录像,如下图所示:1.3 以太网接口主板有一路
    Industio_触觉智能 2025-01-20 11:04 189浏览
  • 数字隔离芯片是一种实现电气隔离功能的集成电路,在工业自动化、汽车电子、光伏储能与电力通信等领域的电气系统中发挥着至关重要的作用。其不仅可令高、低压系统之间相互独立,提高低压系统的抗干扰能力,同时还可确保高、低压系统之间的安全交互,使系统稳定工作,并避免操作者遭受来自高压系统的电击伤害。典型数字隔离芯片的简化原理图值得一提的是,数字隔离芯片历经多年发展,其应用范围已十分广泛,凡涉及到在高、低压系统之间进行信号传输的场景中基本都需要应用到此种芯片。那么,电气工程师在进行电路设计时到底该如何评估选择一
    华普微HOPERF 2025-01-20 16:50 119浏览
  • 故障现象 一辆2007款日产天籁车,搭载VQ23发动机(气缸编号如图1所示,点火顺序为1-2-3-4-5-6),累计行驶里程约为21万km。车主反映,该车起步加速时偶尔抖动,且行驶中加速无力。 图1 VQ23发动机的气缸编号 故障诊断接车后试车,发动机怠速运转平稳,但只要换挡起步,稍微踩下一点加速踏板,就能感觉到车身明显抖动。用故障检测仪检测,发动机控制模块(ECM)无故障代码存储,且无失火数据流。用虹科Pico汽车示波器测量气缸1点火信号(COP点火信号)和曲轴位置传感器信
    虹科Pico汽车示波器 2025-01-23 10:46 60浏览
  •     IPC-2581是基于ODB++标准、结合PCB行业特点而指定的PCB加工文件规范。    IPC-2581旨在替代CAM350格式,成为PCB加工行业的新的工业规范。    有一些免费软件,可以查看(不可修改)IPC-2581数据文件。这些软件典型用途是工艺校核。    1. Vu2581        出品:Downstream     
    电子知识打边炉 2025-01-22 11:12 117浏览
  • 2024年是很平淡的一年,能保住饭碗就是万幸了,公司业绩不好,跳槽又不敢跳,还有一个原因就是老板对我们这些员工还是很好的,碍于人情也不能在公司困难时去雪上加霜。在工作其间遇到的大问题没有,小问题还是有不少,这里就举一两个来说一下。第一个就是,先看下下面的这个封装,你能猜出它的引脚间距是多少吗?这种排线座比较常规的是0.6mm间距(即排线是0.3mm间距)的,而这个规格也是我们用得最多的,所以我们按惯性思维来看的话,就会认为这个座子就是0.6mm间距的,这样往往就不会去细看规格书了,所以这次的运气
    wuliangu 2025-01-21 00:15 299浏览
  •  万万没想到!科幻电影中的人形机器人,正在一步步走进我们人类的日常生活中来了。1月17日,乐聚将第100台全尺寸人形机器人交付北汽越野车,再次吹响了人形机器人疯狂进厂打工的号角。无独有尔,银河通用机器人作为一家成立不到两年时间的创业公司,在短短一年多时间内推出革命性的第一代产品Galbot G1,这是一款轮式、双臂、身体可折叠的人形机器人,得到了美团战投、经纬创投、IDG资本等众多投资方的认可。作为一家成立仅仅只有两年多时间的企业,智元机器人也把机器人从梦想带进了现实。2024年8月1
    刘旷 2025-01-21 11:15 619浏览
  • 高速先生成员--黄刚这不马上就要过年了嘛,高速先生就不打算给大家上难度了,整一篇简单但很实用的文章给大伙瞧瞧好了。相信这个标题一出来,尤其对于PCB设计工程师来说,心就立马凉了半截。他们辛辛苦苦进行PCB的过孔设计,高速先生居然说设计多大的过孔他们不关心!另外估计这时候就跳出很多“挑刺”的粉丝了哈,因为翻看很多以往的文章,高速先生都表达了过孔孔径对高速性能的影响是很大的哦!咋滴,今天居然说孔径不关心了?别,别急哈,听高速先生在这篇文章中娓娓道来。首先还是要对各位设计工程师的设计表示肯定,毕竟像我
    一博科技 2025-01-21 16:17 149浏览
  • 临近春节,各方社交及应酬也变得多起来了,甚至一月份就排满了各式约见。有的是关系好的专业朋友的周末“恳谈会”,基本是关于2025年经济预判的话题,以及如何稳定工作等话题;但更多的预约是来自几个客户老板及副总裁们的见面,他们为今年的经济预判与企业发展焦虑而来。在聊天过程中,我发现今年的聊天有个很有意思的“点”,挺多人尤其关心我到底是怎么成长成现在的多领域风格的,还能掌握一些经济趋势的分析能力,到底学过哪些专业、在企业管过哪些具体事情?单单就这个一个月内,我就重复了数次“为什么”,再辅以我上次写的:《
    牛言喵语 2025-01-22 17:10 162浏览
  • Ubuntu20.04默认情况下为root账号自动登录,本文介绍如何取消root账号自动登录,改为通过输入账号密码登录,使用触觉智能EVB3568鸿蒙开发板演示,搭载瑞芯微RK3568,四核A55处理器,主频2.0Ghz,1T算力NPU;支持OpenHarmony5.0及Linux、Android等操作系统,接口丰富,开发评估快人一步!添加新账号1、使用adduser命令来添加新用户,用户名以industio为例,系统会提示设置密码以及其他信息,您可以根据需要填写或跳过,命令如下:root@id
    Industio_触觉智能 2025-01-17 14:14 140浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦