程序流监控 —— AUTOSAR CP 功能安全在裸机 MCU 上的实现:实践篇

AUTOSAR源码如下:

AUTOSAR-CP的程序流监控(PFM)源码资源-CSDN下载

关于AUTOSAR CP功能安全的程序流监控的原理如下:

程序流监控:AUTOSAR CP 功能安全在裸机 MCU 上的实现(理论篇)-CSDN博客

1. 代码整体架构

1.1 模块分层

1.2 配置数据流(编译期 → 运行时)

1.3 核心数据结构关系

2. 监督机制的核心实现

2.1 三种监督的触发时机与判定函数

2.2 状态转换流程

(1)单个 SE 的局部状态机
(2)全局状态机(汇总所有激活 SE)

2.3 关键函数调用链

初始化链

检查点上报链

主周期处理链

3. 主要技术难点与解决方案

3.1 裸机环境下的时间基准与调度

难点:无 RTOS,需要精确的 1ms、10ms 周期性调度。

解决方案

  • 使用硬件定时器产生 1ms 中断,在 ISR 中递增全局变量 WDGM_udteOsTickCounter

  • 主循环中采用绝对时间点比较实现非阻塞调度:

3.2 Alive 监督的相位对齐问题

现象:监督窗口与任务周期相位错位,导致一个窗口内统计到的 Alive 次数不稳定(有时多一次,有时少一次)。

解决方案

  • SupervisionReferenceCycle 设置为任务周期的整数倍(例如 10ms 任务 → 100ms 窗口)。

  • 引入 MinMargin / MaxMargin 允许合理偏差。

  • 增加 FailedAliveSupervisionReferenceCycleTol 容限,避免瞬时抖动导致立即过期。

3.3 Deadline 监督的起点覆盖漏洞

漏洞描述 :若程序在未到达终点前再次上报起点,原实现会直接覆盖 LastTickValue,导致终点计算的时间差异常大(起点被后移)。

解决方案 :引入状态机,每个 Deadline 监督项维护隐含状态(通过 LastTickValue 是否为 0 判断):

  • IDLE (LastTickValue == 0):允许记录起点。

  • START_RECORDED (LastTickValue != 0):

    • 若再次收到起点 → 视为非法,设置 SubstateDeadline = INCORRECT

    • 若收到终点 → 正常计算,完成后将 LastTickValue 清零(回到 IDLE)。

代码体现 :在 WDGM_u8DeadlineMonitoring 中,仅当 LastTickValue == 0 时才记录起点;若已记录又收到起点,直接报错。

4. 项目结果

4.1 功能验证结果

4.2 可复用性

  • 新增 SE 只需在 WdgCfg.c 中添加配置数组,修改 Length_ 宏。

  • 支持多模式(通过增加 WdgM_Mode 数组项)。

  • 硬件驱动已抽象为函数指针,可替换为真实 FU7504 WDT 驱动。

5. 总结

本项目成功在裸机 MCU 上实现了 AUTOSAR CP 风格的轻量级程序流监控框架。通过合理裁剪和状态机设计,解决了裸机调度、相位对齐、时间戳管理等工程难题。最终交付了一套可配置、可调试、可扩展的 WdgM 模块,为功能安全软件监控提供了低成本、高可靠的基础组件。

相关推荐
元气少女小圆丶12 分钟前
SenseGlove Nova 2+Unity开发笔记1
笔记·学习·unity
QiLinkOS19 分钟前
【从实验室到商业战场:发明专利如何重塑科技与企业的共生生态】
大数据·c语言·数据结构·c++·人工智能·单片机·算法
周周记笔记23 分钟前
【元器件专题】三极管-如果B极给一个方波信号,那么V0输出也可以设计为一个方波信号
单片机·嵌入式硬件
潜创微科技25 分钟前
IT68353:DP 1.4 + HDMI 2.0 + USB-C 三合一转 HDMI 2.0 单芯片KVM切换方案
嵌入式硬件·音视频
nashane1 小时前
HarmonyOS 6学习:应用退出动画优化实战——从“闪退“到优雅退出的完美蜕变
学习·华为·harmonyos
HPT_Lt1 小时前
ZCC10012支持100V/1.2A 超低静态电流同步降压转换器 兼容LM5164
单片机·嵌入式硬件
Industio_触觉智能1 小时前
瑞芯微RK3576车载智能场景之ADAS+DMS+NVR
嵌入式硬件·dms·adas·nvr·rk3576·车载智能
-To be number.wan1 小时前
算法日记 | 暴力枚举
学习·算法
2zcode2 小时前
基于STM32的多功能万年历电子闹钟设计与实现
stm32·单片机·嵌入式硬件
一抹晴空2 小时前
Keil MDK AC6 compiler编译报错,与AC5区别
c语言·arm开发·单片机