

Figure 14-9. PC/XT Sources of Hardware Interrupts (Reprinted by permission from "IBM BIOS Technical Reference" c. 1984 by International Business Machines Corporation)



Figure 14-10. Sources of NMI in the PC/XT (Reprinted by permission from "IBM BIOS Technical Reference" c. 1984 by International Business Machines Corporation)

**CHAPTER 14: INTERRUPTS AND THE 8259 CHIP** 

If the NMI is so important to the system, which devices can activate it, and can they be masked at all? First, as can be seen from Figure 14-10, there are three sources of activation of the NMI:

- 1. NPIRQ (numerical processor interrupt request)
- 2. Read/write PCK (parity check)
- 3. IOCHK (input/output channel check)

Since three different sources can activate NMI, how does the system know which one is requesting interrupt service at any given time? The IBM PC system recognizes which of these interrupt requests has been activated by checking input port C of the 8255. It looks at PC6 of the 8255 to see if it is IOCHK and at PC7 to see if it is PCK. The NMI service routine software must check PC6 and PC7 and determine which one has requested service. If neither of these two is requesting service, the request must have come from the 8087 coprocessor on the motherboard (in IBM terminology, planer). IBM BIOS checks the source of each and as it finds them, displays an appropriate messages on the video screen. The BIOS code is shown next.

| E2C3<br>E2C3<br>E2C3 50<br>E2C4 E462<br>E2C6 A8C0<br>E2C8 7415 | 746<br>747 NMI_INT<br>748<br>749<br>750<br>751 | ORG<br>PROC<br>PUSH<br>IN<br>TEST<br>JZ | 0E2C3H<br>NEAR<br>AX<br>AL,PORT<br>AL,0C0H<br>D14 | ;SAVE ORIG CONTENTS OF AX<br>_C<br>;PARITY CHECK?<br>;NO, EXIT FROM ROUTINE                                                             |
|----------------------------------------------------------------|------------------------------------------------|-----------------------------------------|---------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| E2CE A840<br>E2D0 7504<br><br>E2D6<br>                         | 752<br>753<br>754<br>755<br>756 D13:<br>757    | TEST<br>JNZ<br>                         | AL,40H<br>D13<br>                                 | ;ADDR OF ERROR MSG<br>;I/O PARITY CHECK<br>;DISPLAY ERROR MEG<br>;MUST BE PLANER<br>sends the message to<br>video and halts the system. |
| E2DF 58<br>E2E0 CF                                             | 762 D14:<br>763<br>764<br>765 NMI INTENDP      | POP<br>IRET                             | AX                                                | ;RESTORE ORIGINAL AX                                                                                                                    |

(Reprinted by permission from "IBM BIOS Technical Reference" c. 1984 by International Business Machines Corporation)

Is there any way that NMI can be masked? The answer is yes. As can be seen from Figure 14-10, NMI is masked by a RESET signal from the CPU with CLR of the D flip-flop when the computer is first turned on. It can also be unmasked or masked through port A0H by setting D7 of the data bus to 1 (unmask) or 0 (mask). Again from the IBM PC/XT BIOS we see the following:

|                        | 1261<br>1262        | ;          | ENABLE NMI INTERRUPTS |                       |                                                 |  |
|------------------------|---------------------|------------|-----------------------|-----------------------|-------------------------------------------------|--|
| E5BC B080<br>E5BE E6A0 | 1263<br>1264        | 1263       | MOV<br>OUT            | AL,80H<br>0A0H,AL     | ;ENABLE NMI INTERRUPTS                          |  |
| (Reprinted by pe       | <br>rmission from ' | IBM BIOS T | <br>echnical R        | <br>eference" c. 1984 | by International Business Machines Corporation) |  |

## **Review Questions**

- 1. True or false. The IBM PC/XT uses only one 8259.
- 2. What ports are assigned to ICWs in the PC/XT?
- 3. In the PC/XT, the IRQ are (edge-, level-triggered).
- 4. Of the 256 possible interrupts of the 8088, which ones are assigned to IRQ0 IRQ7 of the 8259?
- 5. True or false. IRQ0 and IRQ1 can be used by the system but not by the user.
- 6. Which IRQ of the 8259 is available on the expansion slot?
- 7. True or false. The 80x86 can mask and unmask the NMI by using the STI and CLI instructions.
- 8. True or false. If there is a problem with the memory of the PC, NMI is activated.