记录WFI相关细节,以及如何让中断唤醒后先执行wfi后指令,再执行中断异常;或者优先执行中断异常,再执行wfi后指令。
1. ARM(A7)关于WFI的描述
处理器可以通过执行WFI指令进入WFI低功耗状态。
当硬件检测到WFI唤醒事件,WFI指令结束。
WFI唤醒事件无法被CPSR屏蔽位屏蔽。
执行wfi后processor clock状态
进入wfi后,processor clock是什么状态?
WFI执行的结果:
关闭核内大部分时钟保持核供电。
保留小部分时钟确保核能从WFI低功耗状态唤醒。
执行wfi指令后,进入WFI低功耗模式之前,硬件做了如下的工作
某些情况下,打开processor clock但是processor并没有退出wfi状态
导致处理器退出WFI低功耗的几种事件
WFI和STANDBYWFI信号的关系
2. 通过配置CPSR控制wfi后中断行为
2.1 CPSR寄存器以及配置
通过配置AIF位,来决定CPU是否处理相关异常:
2.1.1 读写CPSR
对CPSR寄存器读写可以通过如下进行:
__STATIC_INILINE uint32_t __get_CPSR(void)
register uint32_t __regCPSR __ASM("cpsr");
return(__regCPSR);
__STATIC_INILINE uint32_t __set_CPSR(uint32_t cpsr)
register uint32_t __regCPSR __ASM("cpsr");
__regCPSR = cpsr;
2.1.2 cps指令
cps指令用于配置CPSR的A、I、F位,以及进入特定处理器模式。仅在特权模式下可使用。
CPSeffect iflags{, #mode}
CPS #mode
where:
effect is one of:
IE Interrupt or abort enable.
ID Interrupt or abort disable.
iflags is a sequence of one or more of:
a Enables or disables imprecise aborts.
i Enables or disables IRQ interrupts.
f Enables or disables FIQ interrupts.
specifies the number of the mode to change to.
cpsie if - 表示使能处理器对IRQ和FIQ的响应。
cpsid ai, #17 - 表示关闭aborts和irq响应,并进入FIQ模式。
cps #16 - 表示进入User模式。
2.2 配置流程
中断满足GIC的需求,通过Distributor送到CPU Interface,再送到Processor。
此时必然会将Processor从WFI状态唤醒,但是中断异常是否执行取决于CPSR.IF位设置。对于Async Abort执行取决于CPSR.A位设置。
所以根据需要,在执行WFI之前设置CPSR.IF标志位即可:
联系方式:arnoldlu@qq.com