关于ARM Kinetis MCU唤醒源NVIC和AWIC的工作过程解惑

2024-02-28 13:38

本文主要是介绍关于ARM Kinetis MCU唤醒源NVIC和AWIC的工作过程解惑,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

之前对Kinetis的低功耗系统进行学习的过程中,大体上了解NVIC是主管同步唤醒事件,而AWIC是主管异步唤醒事件,同步和异步主要指的是是否与CPU的时钟保持同步。NVIC是在CPU醒着的时候(有时钟供应)的情况下接受中断请求,处于ARM核心内部,需要CPU的时钟供应以维持工作。AWIC可以在CPU休眠时(在Deep Stop模式中)通过异步机制继续响应来自存活外设的中断请求以唤醒CPU。但是在之前的理解中,AWIC和NVIC是相互独立工作,分别接入CPU中的。这也导致了我在理解例如LLWU等从特殊低功耗模式下唤醒的执行序列时仍存在诸多疑惑(唤醒后到底是先复位还是先执行中断服务程序?)。

今天详读一份Kinetis的datasheet时,注意到如下一段关于AWIC说明:

此处的意思是“AWIC在异步模式下(包括CPU的系统时钟停止供应)捕获到事件,AWIC恢复系统时钟(包括CPU时钟)。系统时钟恢复后,NVIC恢复工作,监测到中断事件发生,然后执行常规的基于NVIC的中断服务处理程序”。这就说明AWIC和NVIC有交接工作的关系:AWIC从一些Deep Sleep模式中恢复系统时钟,它的工作内容就结束了。系统时钟恢复后,NVIC自动接替事件的响应过程,启动中断服务程序处理相应的中断事件。

再拿文中提到的一个案例进行分析:

由此可以解释,当使用LLWU(隶属于AWIC的范畴)这类超低功耗掉电模式的唤醒事件监控模块时,会先唤醒系统,然后通过NVIC的引导开始执行中断服务程序,当系统从中断服务程序的高优先级的特权状态中回归到常规优先级的普通状态时,开始启动复位操作序列(此时的复位操作序列感觉像是一个最低优先级的中断服务程序,同LLWU的中断服务组成“咬尾中断”,也就是说指令序列从来都没有回到过main函数)(当然也有另一种可能的解释,就是LLWU的中断服务最后面由硬件自动添加了一段复位操作序列,用户看不到,也不可编程,此时指令序列也没有回到main函数)。总之,结论是“先执行中断服务程序再复位”,那么在这种情况下,LLWU的中断服务程序一般可以用来在时钟完备的情况下保存一下复位前的现场信息。这样在复位之后,在新一轮的生命周期中,使用上一个生存周期末尾保存的现场信息执行一些对应的处理工作。

 

 

这篇关于关于ARM Kinetis MCU唤醒源NVIC和AWIC的工作过程解惑的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/755662

相关文章

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

LiteFlow轻量级工作流引擎使用示例详解

《LiteFlow轻量级工作流引擎使用示例详解》:本文主要介绍LiteFlow是一个灵活、简洁且轻量的工作流引擎,适合用于中小型项目和微服务架构中的流程编排,本文给大家介绍LiteFlow轻量级工... 目录1. LiteFlow 主要特点2. 工作流定义方式3. LiteFlow 流程示例4. LiteF

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

MySQL存储过程之循环遍历查询的结果集详解

《MySQL存储过程之循环遍历查询的结果集详解》:本文主要介绍MySQL存储过程之循环遍历查询的结果集,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言1. 表结构2. 存储过程3. 关于存储过程的SQL补充总结前言近来碰到这样一个问题:在生产上导入的数据发现

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte

Spring Boot 整合 Apache Flink 的详细过程

《SpringBoot整合ApacheFlink的详细过程》ApacheFlink是一个高性能的分布式流处理框架,而SpringBoot提供了快速构建企业级应用的能力,下面给大家介绍Spri... 目录Spring Boot 整合 Apache Flink 教程一、背景与目标二、环境准备三、创建项目 & 添

详解如何使用Python构建从数据到文档的自动化工作流

《详解如何使用Python构建从数据到文档的自动化工作流》这篇文章将通过真实工作场景拆解,为大家展示如何用Python构建自动化工作流,让工具代替人力完成这些数字苦力活,感兴趣的小伙伴可以跟随小编一起... 目录一、Excel处理:从数据搬运工到智能分析师二、PDF处理:文档工厂的智能生产线三、邮件自动化:

基于Python开发一个有趣的工作时长计算器

《基于Python开发一个有趣的工作时长计算器》随着远程办公和弹性工作制的兴起,个人及团队对于工作时长的准确统计需求日益增长,本文将使用Python和PyQt5打造一个工作时长计算器,感兴趣的小伙伴可... 目录概述功能介绍界面展示php软件使用步骤说明代码详解1.窗口初始化与布局2.工作时长计算核心逻辑3

pytest+allure环境搭建+自动化实践过程

《pytest+allure环境搭建+自动化实践过程》:本文主要介绍pytest+allure环境搭建+自动化实践过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、pytest下载安装1.1、安装pytest1.2、检测是否安装成功二、allure下载安装2.

Pytorch介绍与安装过程

《Pytorch介绍与安装过程》PyTorch因其直观的设计、卓越的灵活性以及强大的动态计算图功能,迅速在学术界和工业界获得了广泛认可,成为当前深度学习研究和开发的主流工具之一,本文给大家介绍Pyto... 目录1、Pytorch介绍1.1、核心理念1.2、核心组件与功能1.3、适用场景与优势总结1.4、优