POINTER
TO
INTERRUPT
HANDLER
FOR:
INTERRUPT
255
INTERRUPT
254
INTERRUPT
253
INTERRUPT
1
INTERRUPT
0
POINTER
POINTER
POINTER
~
POINTER
POINTER
REAL ADDRESS MODE
..
~~
PHYSICAL
ADDRESS
1020
1016
1012
4
0
1
0
•
19
I
. . . .
. .
01
VECTOR
101
oj
10
9 2 1 0
G3010a
Figure 5-3.
Interrupt
Vector
Table
for
Real Address Mode
Table 5-1.
Interrupt
Processing Order
Order
Interrupt
1.
Instruction exception
2.
Single step
3.
NMI
4.
Processor extension segment overrun
5.
INTR
The Interrupt Vector Table consists of as many as 256 consecutive entries, each four bytes long. Each
entry defines the address of a service routine to
be associated \vith the correspondingly numbered
interrupt vector code. Within each entry, an address
is
specified by a full 32-bit pointer that consists
of a 16-bit offset and a 16-bit segment selector. Interrupts
0-31
are reserved by Intel.
In Real Address Mode, the interrupt table can be accessed directly
at
physical memory location
o through 1023. In the protected virtual address mode, however, the interrupt vector table has
no
fixed
physical address and cannot be directly accessed. Therefore,
Real Address mode programs that directly
manipulate the interrupt vector table will not work
in
the protected virtual address mode.
5.2.1.1 INTERRUPT PRIORITIES
When simultaneous interrupt requests occur, they are processed
in
a fixed order
as
shown
in
table
5-1.
Interrupt processing involves saving the flags, the return address, and setting CS:IP to point at the first
instruction of the interrupt handler.
If
other interrupts remain enabled, they are processed before the
first instruction of the current interrupt handler
is
executed. The last interrupt processed
is
therefore
the first one serviced.
5-4