是CPU进入中断周期后自动关中断,为了让主程序和中断服务程序能够处理中断与中断嵌套都要安排开中断指令。
中断系统正在执行一个中断服务时,有另一个优先级更高的中断提出中断请求,这时会暂时终止当前正在执行的级别较低的中断源的服务程序,去处理级别更高的中断源,待处理完毕,再返回到被中断了的中断服务程序继续执行。
CPU进入中断周期后,由中断隐指令自动将使能全局中断标志位置零,即关中断,这就意味着CPU在执行中断服务程序中禁止响应新的中断请求。CPU若想再次响应中断请求,必须开中断,这一任务通常由中断服务程序中的开中断指令实现。
扩展资料:
中断源屏蔽处理的相关技术:
当中断源被屏蔽(屏蔽触发器mask=1),此时即使完成触发器D=1,中断查询信号到来时刻只能将中断请求触发器INTR置“0”,CPU接收不到该中断源的中断请求,即它被屏蔽。
若该中断源未被屏蔽(mask=0),当设备工作已完成时(D=1),中断查询信号则将INTR置“1”,表示该中断源向CPU发出中断请求,该信号送至排队器进行优先级判断。
为了保证级别低的中断源不干扰比其级别高的中断源的中断处理过程。可采用屏蔽技术。
参考资料来源:百度百科-可屏蔽中断标志
参考资料来源:百度百科-中断嵌套
放在while(1)中如果没有加延时会一直在获取AD值,而AD获取过程如果有中断打断的话,AD值会有非常大的差距,一般建议AD转换放中断。如果必须放主函数的话可以考虑在中断加一个标志位,每过1MS或者1S置1,主函数判断标志位,为1,则清0标志位并进行AD转换。只要AD转换的时间不超过中断一次的时间就不会出现数值不对的情况了欢迎分享,转载请注明来源:内存溢出
评论列表(0条)