《MCSDK5.X中增加位置环》提及mc_position.c/mc_position.h
STM32G473 DRDY不置位?
stspin32G4这颗mcu里面集成的是哪一款G4?能不能用cubemx来进行配置
STM32G473是否支持硬件AES?
STM32G473VET6同时使用6个片上放大器(OPAMP)的PGA加外部偏置模式,引脚位置让差分信号走线分离,信号有无较大影响?
stm32G474的flash模式如何判定?single bank 和dual bank
STM32G474 ADC无法正常启动转换
STM32G474 HRTIM无法正常触发ADC
STM32G431RB,变量接受不到串口发下去的数据
foc电流环无法正确维持Iq在自己设定的数值。
给你说一个方法,你定义一个结构体,比如:
这个结构体每个故障定义一个。
每次故障被触发的时候就刷新当前发生故障的结构体,然后更新一下sys_fault_mgmt。比如当前的sys_fault_mgmt.next_trig_id不为零,就比较一下当前发生的故障要检查的时间点是否早于sys_fault_mgmt.next_check_point.如果更早就用这个故障的特征刷新。如果更晚就不用刷新。总之在故障产生、清除和确认的时候都刷新sys_fault_mgmt。而每次1ms中断的时候就只比较sys_fault_mgmt上面的事件。这个比较很简单不会耗费很多资源。
个人觉得当故障是这样的时候,裸机程序可以这样管理故障。当然如果你的系统有现成的链表。那么用链表的方法可能更好。就是说每次将最先需要检查的id放在链表的头部。依照事件顺序,插入新发生故障的链表可能会更好。
提供点参考思路。其实在早期MCU里TIMER也就1个或2个,
这么使用是常见的。
定时精度就设置为1ms. 如果说systick单独使用了,
单独拿个其它通用定时器无妨。设置多个不同的变量应对
不同的超时计时。
发生某事件需要设置超时值,开启超时计时,在定时中断里
检测超时值是否已到。
比方,为过流超时管理设置变量TIMEOUT_I,为过压设置超时管理变量
TIMEOUT_V等。使用共同中断对各个超时变量进行监测。
在中断里,如果超时变量本来就是0则不予理睬;如果是非0进行自减后若变0值
则视为超时值已到,得作相应处理。
G4有很多定时器和通道,根据超时范围可以通过设置比较值产生相对比较中断来确定ms级别的超时。
通过RTC的ALARM 来确定秒以上的超时。
另外选个通用定时器,仿造 systicK 再来一个1ms 计数也很方便。