处理器间中断处理(IPI)

处理器间中断处理(IPI)处理器间中断允许一个 CPU 向系统其他的 CPU 发送中断信号 处理器间中断 IPI 不是通过 IRQ 线传输的 而是作为信号直接放在连接所有 CPU 本地 APIC 的总线上

处理器间中断允许一个CPU向系统其他的CPU发送中断信号,处理器间中断(IPI)不是通过IRQ线传输的,而是作为信号直接放在连接所有CPU本地APIC的总线上。在多处理器系统上,Linux定义了下列三种处理器间中断:

CALL_FUNCTION_VECTOR (向量0xfb

发往所有的CPU,但不包括发送者,强制这些CPU运行发送者传递过来的函数,相应的中断处理程序叫做call_function_interrupt(),例如,地址存放在群居变量call_data中来传递的函数,可能强制其他所有的CPU都停止,也可能强制它们设置内存类型范围寄存器的内容。通常,这种中断发往所有的CPU,但通过smp_call_function()执行调用函数的CPU除外。

RESCHEDULE_VECTOR (向量0xfc

当一个CPU接收这种类型的中断时,相应的处理程序限定自己来应答中断,当从中断返回时,所有的重新调度都自动运行。

INVALIDATE_TLB_VECTOR (向量0xfd

发往所有的CPU,但不包括发送者,强制它们的转换后援缓冲器TLB变为无效。相应的处理程序刷新处理器的某些TLB表项。


处理器间中断处理程序的汇编语言代码是由BUILD_INTERRUPT宏产生的,它保存寄存器,从栈顶押入向量号减256的值,然后调用高级C函数,其名字就是第几处理程序的名字加前缀smp_,例如CALL_FUNCTION_VECTOR类型的处理器间中断的低级处理程序时call_function_interrupt(),它调用名为smp_call_function_interrupt()的高级处理程序,每个高级处理程序应答本地APIC上的处理器间中断,然后执行由中断触发的特定操作。

Linux有一组函数使得发生处理器间中断变为一件容易的事:

函数 说明
send_IPI_all() 发送一个IPI到所有CPU,包括发送者
send_IPI_allbutself() 发送一个IPI到所有CPU,不包括发送者
send_IPI_self() 发送一个IPI到发送者的CPU
send_IPI_mask() 发送一个IPI到位掩码指定的一组CPU
今天的文章 处理器间中断处理(IPI)分享到此就结束了,感谢您的阅读。
编程小号
上一篇 2024-12-25 08:33
下一篇 2024-12-25 08:30

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/bian-cheng-ji-chu/96350.html