在不同的处理器上运行代码(x86程序集)

时间:2009-10-25 23:01:14

标签: assembly x86 multiprocessing smp real-mode

在x86的实模式下,需要使用哪些指令在多处理器系统中的不同处理器上运行代码?

(我正在汇编程序中编写一些需要设置某些CPU寄存器的预启动代码,并在实际操作系统启动之前在系统中的每个CPU上执行此操作。)

1 个答案:

答案 0 :(得分:9)

所以你有一个独立的(你说的“预启动”)程序,就像一个以实模式运行的引导加载程序?这是在PeeCee上用普通的BIOS吗?

在这种情况下,您只有一个CPU正在运行。为了启动其他CPU单元,操作系统通常会执行所谓的通用启动算法,如下所示:

BSP sends AP an INIT IPI
BSP DELAYs (10mSec)
If (APIC_VERSION is not an 82489DX) {
  BSP sends AP a STARTUP IPI
  BSP DELAYs (200μSEC)
  BSP sends AP a STARTUP IPI
  BSP DELAYs (200μSEC)
}
BSP verifies synchronization with executing AP

BSP是引导处理器。 AP是应用程序处理器。 IPI是处理器间中断。为了进行IPI,您需要启用APIC,这是PC架构的中断控制器扩展,在启动时未启用。这就是代码担心它运行的ICU版本的原因。所有这些都是相当深刻的内核魔力。您可以尝试查看Linux,NetBSD或其他* BSD源代码,但这样做并不容易。如果你真的赢了,你可能会在那里找到一个小内核或独立的SMP测试程序。

有关详细信息,请参阅Intel Multiprocessor Specification