When you disable interrupts (with the cli
instruction in x86), what exactly happens?
Does the PIC wait for you to turn on interrupts, and fire the
The interrupts still fire, but the CPU isn't listening. When you start listening again (sti
), the signal is still there and will take effect at the first opportunity.
A PC PIC has several levels of interrupts, and I believe it can hold one active interrupt for each priority level. It will keep each one of them until the CPU tells it that the corresponding handling is completed. Having interrupts disabled for an extended period of time will probably break this, so just don't do that!
The device responsible for an interrupt will not get any response while waiting - which is kind of a response anyway. If it can't wait, it might enter some error state that the CPU will see when it eventually comes around.
You will only get the interrupts you have explicitly enabled, so there should be no surprises. The device driver turning on an interrupt has better know how to handle it.