Prerequisite – I/O Interface (Interrupt and DMA Mode)
Data transfer between the CPU and I/O devices can be done in variety of modes. These are three possible modes:
- Programmed I/O
- Interrupt initiated I/O
- Direct Memory Access (DMA)
In this article we shall discuss the first two modes only.
1. Programmed I/O :
In this mode the data transfer is initiated by the instructions written in a computer program. An input instruction is required to store the data from the device to the CPU and a store instruction is required to transfer the data from the CPU to the device. Data transfer through this mode requires constant monitoring of the peripheral device by the CPU and also monitor the possibility of new transfer once the transfer has been initiated. Thus CPU stays in a loop until the I/O device indicates that it is ready for data transfer. Thus programmed I/O is a time consuming process that keeps the processor busy needlessly and leads to wastage of the CPU cycles.
This can be overcome by the use of an interrupt facility. This forms the basis for the Interrupt Initiated I/O.
2. Interrupt Initiated I/O :
This mode uses an interrupt facility and special commands to inform the interface to issue the interrupt command when data becomes available and interface is ready for the data transfer. In the meantime CPU keeps on executing other tasks and need not check for the flag. When the flag is set, the interface is informed and an interrupt is initiated. This interrupt causes the CPU to deviate from what it is doing to respond to the I/O transfer. The CPU responds to the signal by storing the return address from the program counter (PC) into the memory stack and then branches to service that processes the I/O request. After the transfer is complete, CPU returns to the previous task it was executing. The branch address of the service can be chosen in two ways known as vectored and non-vectored interrupt. In vectored interrupt, the source that interrupts, supplies the branch information to the CPU while in case of non-vectored interrupt the branch address is assigned to a fixed location in memory.
Difference between Programmed and Interrupt Initiated I/O :
|Programmed I/O||Interrupt Initiated I/O|
|Data transfer is initiated by the means of instructions stored in the computer program. Whenever there is a request for I/O transfer the instructions are executed from the program.||The I/O transfer is initiated by the interrupt command issued to the CPU.|
|The CPU stays in the loop to know if the device is ready for transfer and has to continuously monitor the peripheral device.||There is no need for the CPU to stay in the loop as the interrupt command interrupts the CPU when the device is ready for data transfer.|
|This leads to the wastage of CPU cycles as CPU remains busy needlessly and thus the efficiency of system gets reduced.||The CPU cycles are not wasted as CPU and hence this method is more efficient.|
|CPU cannot do any work until the transfer is complete as it has to stay in the loop to continuously monitor the peripheral device.||CPU can do any other work until it is interrupted by the command indicating the readiness of device for data transfer|
|Its module is treated as a slow module.||Its module is faster than programmed I/O module.|
|It is quite easy to program and understand.||It can be tricky and complicated to understand if one uses low level language.|
|The performance of the system is severely degraded.||The performance of the system is enhanced to some extent.|
Attention reader! Don’t stop learning now. Get hold of all the important CS Theory concepts for SDE interviews with the CS Theory Course at a student-friendly price and become industry ready.