默认情况下,ISR 不能被任何其他中断中断。 红外线等到在处理任何待处理的中断之前,该函数已完成。› 为了允许通过更高优先级的服务请求中断 ISR 的执行,必须在 ISR 的开头添加以下 iLD 函数:ifxCPU_enableInterrupts ();如果我让更高优先级的 ISR 中断优先级较低的 ISR,那么 ISR 的上下文保存和恢复是如何完成的?
共2条
1/1 1 跳转至页
2楼
当更高优先级的ISR中断了较低优先级的ISR时,上下文保存和恢复是通过中断处理器的硬件机制完成的。
首先,当更高优先级的ISR中断较低优先级的ISR时,中断处理器会自动保存较低优先级的ISR的当前状态。这包括将寄存器的值保存到堆栈上,以及保存堆栈指针的值。
然后,中断处理器会加载更高优先级的ISR的上下文,并开始执行该ISR。这包括将堆栈指针切换到更高优先级ISR的堆栈,以及将堆栈上保存的寄存器值加载到相应的寄存器中。
一旦更高优先级的ISR完成执行,中断处理器会恢复较低优先级的ISR的上下文。这将包括将堆栈指针切换回较低优先级的ISR的堆栈,并将堆栈上保存的寄存器值恢复到相应的寄存器中。
通过这种方式,中断处理器可以在更高优先级的ISR执行期间保存和恢复较低优先级的ISR的上下文,以确保程序的正确执行。
共2条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
与电子爱好者谈读图二被打赏50分 | |
【FRDM-MCXN947评测】Core1适配运行FreeRtos被打赏50分 | |
【FRDM-MCXN947评测】双核调试被打赏50分 | |
【CPKCORRA8D1B评测】---移植CoreMark被打赏50分 | |
【CPKCORRA8D1B评测】---打开硬件定时器被打赏50分 | |
【FRDM-MCXA156评测】4、CAN loopback模式测试被打赏50分 | |
【CPKcorRA8D1评测】--搭建初始环境被打赏50分 | |
【FRDM-MCXA156评测】3、使用FlexIO模拟UART被打赏50分 | |
【FRDM-MCXA156评测】2、rt-thread MCXA156 BSP制作被打赏50分 | |
【FRDM-MCXN947评测】核间通信MUTEX被打赏50分 |