CPU响应中断需要哪些条件?

CPU响应中断需要哪些条件?,第1张

需要的条件有:

1.中断源如何向CPU表达中断请求

一般是设置中断请求触发器,在需要CPU服务时,将中断请求触发器置位,其拆或手1端或0端输出的跳变作为中断请求信号。显然中断源可以随时提出中断请求。

2.中断请求何种情况下才可能得到CPU响应

一个中断请求在同时具备下列两个条件时,才有可能得到CPU响应:

①该中断源未被屏蔽;

②该中断请求在当前所有中断请求中级别最高。

3.CPU何时响应中断

CPU在同时满足下列两个条件时,响应中断:

①IF=1(对非屏蔽中断,没有此项要求);

②现行指令执行完。

CPU在每一个指令周期的最后一个总线周期的最后一个时钟周期的开始采样中断请求输入线,若有中断请求,则下一步不进入取指令周期,而进入中断响应周期,如图5.1所示。对于8086系列CPU,中断响应周期为两个。

之所以把一条指令执行完作为响应中旅嫌断的条件,是因为中断响应周期以及中断服务程序要占用CPU资源。如果在执行一条指令的中间响应中断,则指令的当前状态既不能保存也无法加以恢复。与此相对比,DMA *** 作是在DMA控制器的作用团汪下进行的,不占用CPU资源,所以在一条指令执行中间、当前总线周期结束即可进入DMA周期。

1.中断源如何向CPU表达中断请求\x0d\x0a一般是设置中断请求触发器,在需要CPU服务时,将中断请求触发器置位,其1端或0端输出的跳变作为中断请求信号。显然中断源可以随时提出中断请求。\x0d\x0a2.中断请求何种情况下才可能得到CPU响应\x0d\x0a一个中断请求在同时具备下列两个条件时,才有可能得到CPU响应:\x0d\x0a①该中断源未被屏蔽;\x0d\x0a②该中断请求在当前所有中断请求中级别最高。\x0d\x0a3.CPU何时响应中断\x0d\x0aCPU在同时满足下列两个条件时,响应中断:\x0d\x0a①IF=1(对非屏蔽中断,没有此项要求);\x0d\x0a②现行指令执行完。\x0d\x0aCPU在每一个指令周期的最后一个总线周期的最后一个时钟周期的开始采样中断请求输入线,若有中断请求,则下一步不进入取指令周期,而进入中断响应周期,如图5.1所示。对于8086系列CPU,中断响应周期为两个。\x0d\x0a之所以把一条指令执行完作为响应中断的高模条件,是因为中断响应周期以及中断服务程序要占用CPU资源。如果在执行一条指令的中间响应中断,则指令的当前状态既模差不能保存也无法加以恢复。与此相对比,DMA *** 作是在戚码缓DMA控制器的作用下进行的,不占用CPU资源,所以在一条指令执行中间、当前总线周期结束即可进入DMA周期。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/yw/12401235.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-25
下一篇 2023-05-25

发表评论

登录后才能评论

评论列表(0条)

保存