IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 嵌入式 -> 小猫爪:S32K3学习笔记11-S32K3之FCCU -> 正文阅读

[嵌入式]小猫爪:S32K3学习笔记11-S32K3之FCCU

1 前言

??这一节来学习一下safety中的一个核心模块,它就是FCCU(Fault Collection and Control Unit),看名字就知道这是一个错误收集模块,其他模块发生错误了,就会讲错误信号传递到FCCU中进行统一管理。

2 FCCU的功能框图

??这FCCU的功能框图如下:
在这里插入图片描述

2.1 错误输入

??这DCM可以理解成是K3里面的一个错误集合器,主要体现在6个寄存器中,分别是标志寄存器DCMROD3,DCMROD4和DCMROD5;以及相对应的使能寄存器DCMRWD3,DCMRWD4和DCMRWD5。每一个bit代表着一个DCM错误通道,所以理论上总共有3*32=96个DCM通道(实际上并没有96个,因为有几个通道是reserve状态),只有当标志寄存器位和其对应的使能寄存器位都等于1时,这个错误才能传送到FCCU中去被处理。

??这里可以提一下的就是ERM 20个通道所能报告的错误是DCM的一个子集,但是ERM通道和DCM通道并不是一一对应,这里很好理解,因为两者对错误的分类方式不同。ERM针对的是Memory ECC的错误,而DCM则涵盖了K3整个所有的错误。

??DCM的96个通道传送到FCCU后,FCCU又把DCM的错误按照错误类型又将其划分成8种通道组,分别对应NCF[7:0]这8个通道组,如下表所示:
在这里插入图片描述
??除了8个NCF通道组外,FCCU还能通过EIN[1:0]接收来自芯片外部的错误信号,并做一些处理。

2.2 时钟输入

??FCCU的时钟源有三个,分别是Primary Clock,Safety Clock0和Safety Clock1,其中Primary Clock为FCCU的主时钟,其来源为AIPS_PLAT_CLK,而Safety Clock是给FCCU中的一些特殊模块使用的,至于到底给了谁,我也不知道,其来源为FIRC_CLK。

2.3 FSM

??FSM是FCCU的主体,它负责整个FCCU状态机的切换,其实就是接收错误信号,然后根据相关配置来决定触发几个特殊的信号给外部。首先它能触发两个中断,分别是Alarm Interrupt和NMI interrupt,还可以触发一个function reset信号给MC_RGM来让K3执行功能性复位(这里需要注意一点,Function Reset并不能复位FCCU模块),还可以触发两个外部信号EOUT[1:0]给外部SBC,EOUT[1:0]是互补相反的。

2.4 FOSU

??这个模块是用来监控FCCU的,是为了防止FCCU失效的。如果一个错误信号传送到了FCCU,而FCCU在短时间内并没有做出相应的反应,那么FOSU就认为FCCU挂了,那么它会触发一个Destructive Reset给MC_RGM来让K3执行破坏性复位(这里需要注意一点,Destructive Reset会复位FCCU模块)。

3 FCCU的状态机

??当一个错误传到了FCCU中,FCCU的处理分为几个阶段,即其状态机,每个阶段干不同的事情,FCCU的状态机切换如下图所示:
在这里插入图片描述
??从图中可以看出,FCCU包含四种状态,分别是CONFIG, NORMAL, ALARM,FAULT,这几种状态的切换也是非常的简单。

  1. CONFIG: K3启动后,默认是CONFIG,在这个状态中,你可以对FCCU的寄存器进行操作配置,等配置完后,再手动切换至NORMAL。在FCCU中有个config timer, 如果在一定时间没有切换至NORMAL而导致config timer超时(该超时时间可配置),那么FCCU会自动切换至NARMAL,而FCCU的配置则为默认配置,同时config timer超时也可触发一个超时中断信号。
  2. NORMAL: FCCU检测到NCF的8个通道任何一个及以上有错误时,这个时候FCCU就会从NORMAL切换到ALARM或者FAULT,至于切换到哪种状态取决于是否使能了NCF通道的ALARM中断。
  3. ALARM:如果当前NCF通道使能了ALARM中断,并且伴随着错误,那么FCCU就会从NORMAL切换到ALRAM,并且触发ALARM中断,用户可以在ALARM中断中对错误进行处理,如果经过处理后,让错误消失,那么FCCU就会重新切换至NORMAL状态。在FCCU中还有个alarm timer, 如果在一定时间内没有让错误消失而导致alarm timer超时(该超时时间可配置),那么FCCU就会进入FAULT状态。
  4. FAULT:如果当前NCF通道没有使能ALARM中断,并且伴随着错误,那么FCCU就会从NORMAL直接切换到FAULT,或者FCCU在ALARM状态中超时那么FCCU就会从ALARM切换到FAULT。一旦FCCU进入到FAULT,那么可以选择触发function reset或者触发NMI中断。如果通过function reset或者NMI中断处理程序消除了所有错误,那么FCCU就会从FAULT切换回NORMAL;如果没有清除掉的话,问题会很严重。如果是NORMAL-ALARM-FAULT的情况,则FCCU会回到Alarm状态,随即超时又会进入Fault状态,触发Functional Reset,连续6次后,会直接触发Dectructive Reset信号;如果MCU会在故障状态下持续运行。GPIO会进入安全模式(每个pin有 safe state output),但是CPU能执行指令,可以通过插入软件触发Dectructive Reset信号。

??另外进入FAULT也可以选择是否输出EOUT信号给SBC,SBC接收到信号可以进行一些操作。

4 MCAL配置

??我们可以在MCAL中的eMcem中配置FCCU模块,如下可配置一些基本参数:
在这里插入图片描述
??在下面这个界面中可对8个NCF通道作配置,主要有是否产生ALARM中断,是否产生NMI中断,是否产生Function Reset等等,大家自行体会,不再多言。
在这里插入图片描述
??然后在每个NCF通道里面,可以看到每个NCF对应得DCM通道,比如NCF0:
在这里插入图片描述
??然后就可以对每个通道进行配置,如是否失/使能这个DCM错误,还有配置这个错误的alarm中断服务回调函数。这里为了方便,我把所有的错误的alarm中断服务回调函数都配置成为eMcemUserAlarmHandler,到时候再在函数里面细分。

5 SPD应用代码示例

??又到了紧张刺激的示例代码环节,在上节EIM和ERM中,就已经稍微提过了,具体流程就是使用EIM注入错误,然后FCCU收集错误并处理,然后ERM作为错误信息收集模块。

??首先使用EIM在在通道0,也就是SRAM1中注入ECC错误,如下:

void SRAM_EIM_FaultInjection(void)
{
		printf("Inject fault %d.\r\n", (unsigned int)(nInjectFault));
		printf("Inject RAM0 ECC error.\r\n");
		eMcem_SetupInjectionChannel(EMCEM_EIM_CH_0, 0, 1);
		eMcem_InjectFault( EMCEM_EIM_CH_0 );
		Cache_Ip_InvalidateByAddr(CACHE_IP_DATA, 0x20420000, 32);
		ErrorTriggle = *(uint32_t *)(0x20420000);
}

??注入后,CPU再次访问SRAM1时候,就会触发ECC错误,这个时候就会报告到FCCU中去从而触发FCCU的alarm中断,这里需要注意的是这个ECC错误同时也会触发ARM核的BusFaultHandle,所以需要在BusFaultHandle里面需要加点小的处理:

void BusFault_Handler(void)
{
    //..........
    //..........
	/* if FCCU Alarm interrupt is active, leave bus fault handler
	 and let FCCU Alarm ISR to handle the fault */
	if(IP_FCCU->IRQ_STAT & FCCU_IRQ_STAT_ALRM_STAT_MASK)
	{
		return;
	}
	//..........
}

??判断一下是否有FCCU的alarm中断产生,如果有的话,那就直接return,让FCCU的alarm中断服务函数去处理,如下:

eMcem_ErrRecoveryType eMcemUserAlarmHandler( eMcem_FaultType nFaultId )
{
	uint32_t u32FccuFaults = 0;
	uint32_t u32FaultAddr = 0;

	/* read fault information */
	eMcem_GetErrors( &faultContainer );
	eMcem_Fccu_GetErrors( &u32FccuFaults, &u32FccuFaults );

	/* Must clear faults in time (within 10ms after fault detected), 
	otherwise FCCU enters fault state and reset occurred. */
	eMcem_ClearFaults( nFaultId );
	/* print message showing execution of FCCU Alarm Handler. */
	printf("FCCU alarm handler. FCCU_NCF=0x%X, Fault_ID=%d.\r\n", (unsigned int)u32FccuFaults, (unsigned int)nFaultId);
	printf("faultContainer = 0x%08X, 0x%08X, 0x%08X. \r\n", (unsigned int)faultContainer.au32Faults[0], (unsigned int)faultContainer.au32Faults[1], (unsigned int)faultContainer.au32Faults[2]);

    //...........
    //...........
   
	/* if it's NCF2 fault - RAM ECC error */
	if(u32FccuFaults & FCCU_NCF_S_NCFS2_MASK)
	{
		eMcem_GetMemErrInfo( EMCEM_ERM_SRAM0, &memErrInfo );
		eMcem_ClearFaults( nFaultId );
		u32FaultAddr = memErrInfo.Err_AddrRaw;
		u32FccuFaults &= (~FCCU_NCF_S_NCFS2_MASK);
		/* A reserved area without RAM ECC init can be placed at the following address for test purpose */
		if((u32FaultAddr>=0x20427FF0) && (u32FaultAddr<0x20428000))
		{
			u32FaultAddr &= 0xFFFFFFF8;
			*((uint64_t *)u32FaultAddr) = 0;
		}
		else
		{
			if(u32FccuFaults == 0)
			{
				while(1);
				Mcu_PerformReset();
			}
		}
	}
	
	//...........
    //...........
}

??好了,我只能稍微写一点来示范一下EIM,ERM,FCCU三者的联动,重点在于帮助大家理解K3的错误处理机制(嘿嘿嘿,我是不会说,这个例子是我抄袭的)。

??在这里还需要注意一下,在调试状态下,可能会出现eMcem_Init初始化失败,查看DCM状态寄存器后发现了分别在RCCU1,RCCU2和ITCM处发生了错误,至于原因吗,可能是因为在调试状态下,有些访问顺序不符合K3功能安全检测条件的要求,具体我也不清楚,所以一开始需要修改两个地方:

  1. 第一点就是在startup.s的启动代码处加上三句话,如下图:
    在这里插入图片描述
  2. 第二点就是在MCAL配置中,将整个NCF0通道错误关闭,如下:
    在这里插入图片描述

??FCCU是整个K3功能安全的核心,后面有很多的错误处理机制都是由FCCU来完成的,所以FCCU至关重要。

END

  嵌入式 最新文章
基于高精度单片机开发红外测温仪方案
89C51单片机与DAC0832
基于51单片机宠物自动投料喂食器控制系统仿
《痞子衡嵌入式半月刊》 第 68 期
多思计组实验实验七 简单模型机实验
CSC7720
启明智显分享| ESP32学习笔记参考--PWM(脉冲
STM32初探
STM32 总结
【STM32】CubeMX例程四---定时器中断(附工
上一篇文章      下一篇文章      查看所有文章
加:2022-03-15 22:44:59  更:2022-03-15 22:47:14 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/4 16:40:18-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码