How are interrupts handled on SMP?

后端 未结 5 878
无人共我
无人共我 2021-02-12 03:51

How are interrupts handled on SMP (Symmeteric multiprocessor/multicore) machines? Is there only one memory management unit or more?

Say two threads, A and B running on d

5条回答
  •  闹比i
    闹比i (楼主)
    2021-02-12 04:12

    Well, it depends on the specific architecture, but from what I can remember from the Intel docs...

    There are two main sources of interrupts:

    • Internal: These are generated by the CPU itself. Includes faults, traps, software interrupts, etc.
    • External: These are hardware interrupts generated by peripherals.

    The internal interrupts are always delivered to the CPU that generated it. The external ones are sent to an arbirary core.

    In modern models, interrupts can also be delivered using a bus-like system instead the old interrupt driven one, but I ignore if this model is being used in any current OS.

    About the MMU, each core has its own, of course, but they are usually forced the same segments by the OS, so they can be used symmetrically. Note that most of the mapping between physical and virtual memory are actually in memory, and that is always shared.

    About the sequence in your example:

    • The page fault is forwarded to the core that generated it.
    • The kernel updates its MMU tables, that are protected by a shared lock or similar.
    • No, there is only one kernel, usually, unless you apply a model of virtualization.
    • They synchronize using a shared lock or similar structure. If both cores happen to fault at the same page at the same time... well it's not a big deal, actually.

提交回复
热议问题