当前位置: 首页 > news >正文

AutoSAR配置与实践(基础篇)2.5 RTE对数据一致性的管理

传送门 点击返回 ->AUTOSAR配置与实践总目录

AutoSAR配置与实践(基础篇)2.5 RTE对数据一致性的管理

  • 一、 数据一致性问题引入
  • 二、 数据一致性的管理
    • 2.1 RTE管理 (SWC间)
    • 2.2 中断保护 (SWC内)
    • 2.3 变量保护IRVS (SWC内)
    • 2.4 Task分配
    • 2.5 任务抢占控制

一、 数据一致性问题引入

数据一致性:当多个操作同时读写同一个数据,由于任务的抢占,出现了数据被篡改的情况,造成非预期的数据结果。

在抢占式调度RTOS系统中,可能会出现任务抢占导致的一致性问题:

例如:有两个Task,低优先级Task A和高优先级Task B, Task可抢占式调度系统。
Task A想要计算Var的值(预期结果应为Var = 1*5 = 5).
在这里插入图片描述

  1. Task A:先给GlobalVar赋初值1;
  2. Task B :因优先级高,Ready后打断A,给GlobalVar赋了新值( GlobalVar = 2);
  3. Task A : 在Task B执行结束后继续运算,运算GlobalVar 出错:
    预期值:1*5=5.
    实际值:2 *5 = 10

以上例子中,由于高优先级任务的抢占,导致了数据被篡改,从而引起非预期结果。

二、 数据一致性的管理

2.1 RTE管理 (SWC间)

适用场景: 不同SWC的Runnable访问数据,一般RTE机制自动实现,比如IRead和IWrite
方式:通过操作备份数据而不是原始数据,来防止数据被篡改。

示例代码:

Rte_IRead_<r>_<p>_<d>();//runnable运行前,读取到本地备份数据
User Code   //操作备份数据
Rte_IWrite_<r>_<p>_<d>();//runnable结束后,写入备份数据

针对第一章中的数据篡改示例,实施RTE管理的效果图:

在这里插入图片描述
RTE管理步骤:

  1. Task A :Runnable运行前Rte_Iread把全局变量读到局部变量, local Var = 1;
  2. Task B: 中断Task A重写值后,全局变量GlobalVar = 2;
  3. Task A 运算仍使用缓存数据local Var ,所以运算结果不受影响。

更详细机制介绍可以参考此前2.3章节对S/R类型接口的介绍。

2.2 中断保护 (SWC内)

适用场景:

  • SWC内部不同的Runnable访问共同全局变量,Runnable类似C文件中的函数,这些函数如果被放在不同Task上运行, 可能出现出现同一时刻多个函数共同运行的情况。

  • 如果要保护的代码段比较短,防止中断时间长对高优先级任务的影响。

方式: 通过禁用挂起所有中断、或仅操作系统中断或(如果硬件支持)仅某些中断级别来实现,因此不会出现高优先级打断的情况。

示例代码:

Rte_Enter_<ExclusiveArea>
//被保护的代码区
Rte_Exit_<ExclusiveArea>

针对第一章中的数据篡改示例,实施中断保护的效果图:
在这里插入图片描述
中断保护步骤:

  1. Task A:在操作GlobalVar 前,调用Rte_Enter_关闭中断;
  2. Task B :由于中断被关闭,因此即便高优先级Task B 就绪,也无法打断Task A;
  3. Task A:在操作GlobalVar 后,调用Rte_ Exit _开启中断。
  4. Task B:调度随即被Task B抢占,开始对GlobalVar新的操作。

2.3 变量保护IRVS (SWC内)

适用场景: SWC内部变量保护,限定局变量的作用域在变量的作用域在SWC的不同runnable间。

方式: 被限定的Runnable尝试变量时被限制。InterRunnableVariables在一个AUTOSAR软件组件内的runnable之间建立,所以只能被组件内部的访问。同时可以配置runnble访问范围,示例InterVarA变量只能被Runnable M访问。

示例代码:

Rte_IrvWrite_<r>_<v>
Rte_IrvRead_<r>_<v>

针对第一章中的数据篡改示例,实施变量保护的效果图:

在这里插入图片描述
变量保护步骤:

  1. Task A :赋值InterVarA =1
  2. Task B: 中断TaskA尝试重写值InterVarA,由于变量被保护,重写失败
  3. Task A :运算使用InterVarA 继续运算,运算结果不受影响

2.4 Task分配

将访问全局变量的runnable放在同一个Task中,这样runnable只能顺序执行,不会出现高优先级打断的情况,数据一致性就可以得到保证。

2.5 任务抢占控制

可以通过为受影响的任务分配相同的优先级,为受影响的任务分配相同的内部操作系统资源,或者将OS的任务配置为非抢占性来实现

传送门 点击返回 ->AUTOSAR配置与实践总目录

http://www.lryc.cn/news/131558.html

相关文章:

  • ASP.NET WEB API通过SugarSql连接MySQL数据库
  • 08-微信小程序视图层
  • [机器学习]特征工程:特征降维
  • 12. Docker可视化工具
  • css层叠关系
  • 【Unity实战篇 】| 如何在小游戏中快速接入一个新手引导教程
  • Lookup Singularity
  • idea 本地版本控制 local history
  • 【Freertos基础入门】深入浅出freertos互斥量
  • 皮爷咖啡基于亚马逊云科技的数据架构,加速数据治理进程
  • C++ string类详解
  • 深入浅出Pytorch函数——torch.nn.init.ones_
  • 一、docker及mysql基本语法
  • 【计算机网络】13、ARP 包:广播自己的 mac 地址和 ip
  • 通过微软Azure调用GPT的接口API-兼容平替OpenAI官方的注意事项
  • 回归预测 | MATLAB实现BO-SVM贝叶斯优化支持向量机多输入单输出回归预测(多指标,多图)
  • GAN!生成对抗网络GAN全维度介绍与实战
  • 自动驾驶仿真:基于Carsim开发的加速度请求模型
  • .netcore grpc客户端工厂及依赖注入使用
  • C语言入门_Day7 逻辑运算
  • 什么是Eureka?以及Eureka注册服务的搭建
  • Docker安装并配置镜像加速器,镜像、容器的基本操作
  • 前端 -- 基础 网页、HTML、 WEB标准 扫盲详解
  • 分布式锁实现方式
  • C语言小练习(一)
  • Flask-flask系统运行后台轮询线程
  • jsp本质-servlet
  • 回归预测 | MATLAB实现GWO-SVM灰狼优化算法优化支持向量机多输入单输出回归预测(多指标,多图)
  • 科技资讯|苹果Vision Pro新专利曝光:可调节液态透镜
  • 神经网络基础-神经网络补充概念-38-归一化输入