CPU内状态寄存器SR中的SCG0、SCG1、OscOff和CPUOff位是重要的低功耗控制位。
本文引用地址:
https://www.eepw.com.cn/article/201611/320060.htm 只要任意中断被响应,PC和SR就被压入堆栈保存,在中断程序执行的过程中,SR被清除(因为SR被清除,其GIE也被清除,所以中断嵌套被禁止,如果手动将GIE置位,将不论优先级的将该中断服务程序中断),CPU进入AM模式,中断处理之后,又可以恢复先前的工作方式(在中断处理子程序执行期间,通过间接访问堆栈数据,可以操作这些位;这样允许程序在中断返回(RETI)后,以另一种功耗方式继续运行)。
各控制位作用如下:
SCG1:当SCG1复位时,使能SMCLK;SCG1置位则禁止SMCLK。
SCG0:当SCG0复位时,直流发生器被激活(相当于DCO被激活),只有SCG0被置位且DCOCLK信号没有用于MCLK或SMCLK,直流发生器才能被禁止。
OscOff:当OscOff复位时,LFXT晶体振荡器激活,只有当OscOff被置位且不用于MCLK或SMCLK时,LFXT晶体振荡器才能被禁止。
CPUOff:当CPUOff复位时,用于CPU的时钟信号MCLK被激活,当CPUOff置位时,MCLK停止。
控制位SCG1、SCG2、OscOff和CPUOff可由软件配置成6种不同的工作模式:1种活动模式和5种低功耗模式。如下表所示:
工作模式 | 控制位 | CPU状态、振荡器及时钟 |
活动模式 (AM) | SCG1=0 SCG0=0 OscOff=0 CPUOff=0 | CPU处于活动状态 MCLK活动 SMCLK活动 ACLK活动 |
低功耗模式0 (LPM0) | SCG1=0 SCG0=0 OscOff=0 CPUOff=1 | CPU处于禁止状态 MCLK被禁止 SMCLK活动 ACLK活动 |
低功耗模式1 (LPM1) | SCG1=0 SCG0=1 OscOff=0 CPUOff=1 | CPU处于禁止状态 如果DCO未用作MCLK或SMCKL,则直流发生器被禁止,否则仍保持活动 MCLK被禁止 SMCLK活动 ACLK活动 |
低功耗模式2 (LPM2) | SCG1=1 SCG0=0 OscOff=0 CPUOff=1 | CPU处于禁止状态 如果DCO未用作MCLK或SMCKL,自动被禁止 MCLK被禁止 SMCLK被禁止 ACLK活动 |
低功耗模式3 (LPM3) | SCG1=1 SCG0=1 OscOff=0 CPUOff=1 | CPU处于禁止状态 DCO被禁止,直流发生器被禁止 MCLK被禁止 SMCLK被禁止 ACLK活动 |
低功耗模式4 (LPM4) | SCG1=X SCG0=X OscOff=1 CPUOff=1 | CPU处于禁止状态 DCO被禁止,直流发生器被禁止 所有振荡器停止工作 MCLK被禁止 SMCLK被禁止 ACLK被禁止 |
评论