KEMBAR78
Input-Output Organization Guide | PDF | Input/Output | Central Processing Unit
0% found this document useful (0 votes)
21 views68 pages

Input-Output Organization Guide

Uploaded by

Aryan Rathore
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
21 views68 pages

Input-Output Organization Guide

Uploaded by

Aryan Rathore
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 68

Unit-4

Input-Output Organization:
Peripheral Devices, Input Output Interface, Data Transfer Schemes, Program Control and
Interrupts, Direct Memory Access Transfer and Input/Output Processor, Priority interrupt, Direct
memory access transfer, Input/Output processor, Modes of data transfer, Processor Status Word
Content
´ Peripheral Devices

´ Input Output Interface

´ Data Transfer Schemes

´ Program Control and Interrupts

´ Direct Memory Access Transfer and Input/Output Processor

´ Priority interrupt

´ Direct memory access transfer

´ Input/Output processor

´ Modes of data transfer

´ Processor Status Word


Input Output Organization

´ Input-Output Subsystem
´ Provides an efficient mode of communication between the central system and the outside
environment

´ Programs and data must be entered into computer memory for processing and
results obtained from computer must be recorded and displayed to user

´ When input transferred via slow keyboard, processor will be idle most of the time
waiting for information to arrive
´ Magnetic tapes, disks
Peripheral Devices
´ Input or output devices attached to the computer are also referred – Peripherals
´ Devices that are under direct control of computer are said to be connected on-line

´ There are three types of peripherals:


´ Input Peripherals
´ Output Peripherals
´ Input-Output peripherals

´ Peripheral (or I/O Device)


´ Monitor (Visual Output Device): CRT, LCD
´ Keyboard (Input Device): light pen, mouse, joy stick, digitizer
´ Printer (Hard Copy Output Device): Daisy wheel, dot matrix and laser printer
´ Storage Device: Magnetic tape, magnetic disk, optical disk
Which of the following is a Peripheral
devices

A. All input devices


B. All output devices
C. Both A and B
D. None of the above
Which of the following is a Peripheral
devices

A. All input devices


B. All output devices
C. Both A and B
D. None of the above
Which of the following is a Peripheral
device

A. Touch screen
B. CRT
C. LCD
D. All of the above
Which of the following is a Peripheral
device

A. Touch screen
B. CRT
C. LCD
D. All of the above
Peripheral Devices
Input Devices Output Devices

´ Keyboard ´ Puncher
´ Card Puncher
´ Optical Input devices
´ Paper Tape Puncher
´ Card Reader
´ Paper Tape Reader
´ Display (Screen)
´ Bar Code Reader
´ CRT, LCD, LED
´ Optical Mark Reader
´ Magnetic Input Devices
´ Printer
´ Magnetic Stripe Reader
´ Daisy Wheel
´ Screen Input Devices ´ Dot Matrix
´ Touch Screen ´ Laser
´ Light Pen
´ Mouse ´ Plotter
Card puncher is a

A. Input device
B. Output device
C. Both A and B
D. None of the above
Card puncher is a

A. Input device
B. Output device
C. Both A and B
D. None of the above
Input Output Organization

´ ASCII (American Standard Code for Information Interchange)


´ I/O communications usually involves transfer of alphanumeric information from
the device and the computer
´ Standard binary code for alphanumeric character is ASCII
´ ASCII Code:
´ It uses 7 bits to code 128 characters (94 printable and 34 non printing)
´ 7 bit 00 – 7F (0 – 127)
´ ASCII is 7 bits but most computers manipulate 8 bit quantity as a single unit
called byte
´ 80 – FF (128 – 255 ): Greek, Italic type font
´ Three types of control characters: Format effectors, Information separators and
communication control
ASCII – Code
Control Characters

´ Format Effectors – Control the layout of printing


´ They include familiar typewriter controls, such as backspace (BS), horizontal
tabulation(HT), carriage return(CR)

´ Information Separators – Used to separate data into divisions like


paragraphs and pages
´ They include characters such as record separator (RS) and file separator(FS).

´ Communication Control Characters – these are useful during the


transmission of text between remote terminals
´ These include STX(Start of text) and ETX(end of text)
ASCII Stands for

A. American Standard Communication for Information Interchange


B. American Stable Code for Information Interchange
C. American Standard Code for Information Interlink
D. American Standard Code for Information Interchange
ASCII Stands for

A. American Standard Communication for Information Interchange


B. American Stable Code for Information Interchange
C. American Standard Code for Information Interlink
D. American Standard Code for Information Interchange
Input–Output Bus and Interface
I/O bus
Data
Processor Address
Control

Interface Interface Interface Interface

Keyboard
and Printer Magnetic Magnetic
display disk tape
terminal

´ Interface:
´ Synchronizes the data flow and supervises
´ Transfer rate between peripheral and CPU or Memory (Data Formats)
´ Provides signals for the peripheral controller
´ Decodes the device address (device code)
´ Decodes the commands (operation)

Four types of command interface can receive: control, status, data output and data input
Input–Output Interface

´ Provides a method for transferring information between internal storage


´ such as memory and CPU registers and external I/O devices
´ Resolves the differences between the computer and peripheral devices
´ Conversion of Signals required
´ Peripherals – Electromechanical or Electromagnetic Devices
´ CPU or Memory - Electronic Device
´ Data Transfer Rate
´ Peripherals - Usually slower
´ CPU or Memory - Usually faster than peripherals
´ Some kinds of Synchronization mechanism may be needed

´ Data formats or Unit of Information


´ Peripherals – Byte, Block
´ CPU or Memory – Word
´ Operating modes of peripherals may differ
´ must be controlled so that not to disturbed other peripherals connected to CPU
Which of the following is Correct about
Input–Output (I/O) interface

´ Device address
´ Peripheral controller
´ Both A and B
´ None of the above
Which of the following is Correct about
Input–Output (I/O) interface

´ Device address
´ Peripheral controller
´ Both A and B
´ None of the above
I/O Bus and Interface

´ Control command
´ is issued to activate peripheral and to inform what to do

´ Status command
´ used to test various status condition in the interface and the peripherals

´ Data output command


´ causes the interface to respond by transferring data from the bus into one of its
registers

´ Data input command


´ interface receives an item of data from the peripheral and places it in its buffer
register.
Which of the following is a example of
I/O command

´ Control
´ Status
´ Data
´ All of the above
Which of the following is a example of
I/O command

´ Control
´ Status
´ Data
´ All of the above
I/O versus Memory Bus

´ Functions of Buses
´ MEMORY BUS is for information transfers between CPU and the Memory
´ I/O BUS is for information transfers between CPU and I/O devices through their I/O interface

´ Three ways to bus can communicate with memory and I/O:


´ Use two separate buses, one to communicate with memory and the other with I/O interfaces
´ Computer has independent set of data, address and control bus one for accessing memory and
another I/O
´ done in computers that have separate IOP other than CPU
´ Use one common bus for memory and I/O but separate control lines for each
´ Use one common bus for memory and I/O with common control lines for both
Isolated I/O
´ Common bus(data and address) for I/O and memory, Separate read and
write control lines for I/O and Memory
´ If data is for I/O then it places the address on the address line and set I/O
read or write control line
´ Address space of memory and I/O is isolated
´ Address for I/O here is called ports (Port Mapped I/O)
´ Different read-write instruction for both I/O and memory

´ Advantage
´ Full memory space is
available as I/O is Isolated

´ Disadvantage
´ Special instruction
´ Difficult for programming
Memory Mapped I/O
´ Common bus(data and address) and control lines are common for I/O and
memory
´ I/O devices and memory shares same address space, addressing
capability of memory become less
´ Single set of instructions for Read/Write for both I/O and Memory (eg. MOV)

´ Advantage
´ Single set of instructions
´ More user friendly

´ Disadvantage
´ Reduces memory address
range
Differences between memory mapped I/O and isolated I/O

Isolated I/O Memory Mapped I/O


Memory and I/O have separate
Both have same address space
address space
Due to addition of I/O addressable
All address can be used by the memory
memory become less for memory
Separate instruction control read and Same instructions can control both I/O
write operation in I/O and Memory and Memory
In this I/O address are called ports. Normal memory address are for both
More efficient due to seperate buses Lesser efficient
Larger in size due to more buses Smaller in size
It is complex due to separate separate Simpler logic is used as I/O is also
logic is used to control both treated as memory only.
Example of I/O Interface I/O data
Port A
register
Bidirectional
Bus
data bus buffers
I/O data
Port B
register

Internal bus
Chip select I/O
CPU CS
Register select Control Device
RS1 Control
Register select Timing register
RS0 and
I/O read Control
RD Status
I/O write Status
WR register

CS RS1 RS0 Register selected


0 x x None - data bus in high-impedence
1 0 0 Port A register
1 0 1 Port B register
1 1 0 Control register
Programmable Interface 1 1 1 Status register

´ Information in each port can be assigned a meaning depending on the mode of operation of the I/O
device
´ Port A = Data; Port B = Command
´ CPU initializes(loads) each port by transferring a byte to the Control Register
´ Allows CPU can define the mode of operation of each port
´ Programmable Port: By changing the bits in the control register, it is possible to change the interface
characteristics
Content
´ Peripheral Devices

´ Input Output Interface

´ Data Transfer Schemes

´ Modes of data transfer

´ Priority interrupt

´ Direct Memory Access Transfer

´ Input/Output processor

´ Program Control and Interrupts

´ Processor Status Word


Asynchronous Data Transfer

´ Synchronous Data Transfer: Clock pulses are applied to all registers within a
unit and all data transfer among internal registers occur simultaneously
during the occurrence of a clock pulse

´ Two units such as CPU and I/O Interface are designed independently of
each other

´ If the registers in the interface share a common clock with CPU registers, the
transfer between the two is said to be synchronous.
Asynchronous Data Transfer

´ Asynchronous Data Transfer: Internal timing in each unit (CPU and Interface) is
independent
´ Each unit uses its own private clock for internal registers.
´ Asynchronous data transfer between two independent units requires that
control signals be transmitted between the communicating units to indicate the
time at which data is being transmitted

´ One way of achieving this is by means of STROBE (Control signal to indicate the
time at which data is being transmitted) pulse

´ Other method is HANDSHAKING(Agreement between two independent units)


Source Initiated Strobe
Destination Initiated Strobe
Disadvantage of Strobe

´ No Acknowledgement

´ To overcome that we use Handshaking method

Strobe I/O
CPU
Interface
Source Initiated using Handshaking
Destination Initiated using Handshaking
Advantage of Handshaking

´ Valid Data confirmation


´ High degree of flexibility and reliability
´ Timeout – Error if any one unit is faulty and no data transfer takes place with
predetermined time
´ Used between I/O Interface and I/O Device

Strobe I/O Handshaking I/O


CPU
Interface Device
Asynchronous Serial Transfer

´ Synchronous transmission
´ The two unit share a common clock frequency
´ Bits are transmitted continuously at the rate dictated by the clock pulses

´ Asynchronous transmission
´ Binary information sent only when it is available and line remain idle otherwise
´ Special bits are inserted at both ends of the character code
´ Each character consists of three parts :
1. Start bit: always “0”, indicate the beginning of a character
2. Character bits: data
3. Stop bit: always “1” (One or two Stop bits).

1 1 0 0 0 1 0 1

Start Stop
Character bits
bit bit
Asynchronous Transmission Rules

´ When a character is not being sent, the line is kept in the 1-state
´ The initiation of a character transmission is detected from the start bit, which is
always “0”
´ The character bits always follow the start bit
´ After the last bit of the character is transmitted, a stop bit is detected when the
line returns to the 1-state for at least one bit time

Baud Rate : Data transfer rate in bits per second


´ 10 character per second with 11 bit format = 110 bit per second
´ Integrated Circuit designed to Interface between computer and similar
interactive terminals – Universal Asynchronous Receiver-Transmitter (UART)
Asynchronous Communication Interface
Transmit
Bidirectional Transmitter Shift data
data bus Bus register register
buffers
CS RS Oper. Register selected
Control Transmitter Transmitter
clock
0 x x None register control
and clock
1 0 WR Transmitter register Chip select

Internal Bus
CS
1 1 WR Control register Register select Status Receiver Receiver
RS Timing
register control clock
1 0 RD Receiver register and
I/O read and clock
RD
1 1 RD Status register Control
I/O write Receive
WR Receiver Shift data
register register
Transmitter Register
´ Accepts a data byte(from CPU) through the data bus
´ Transferred to a shift register for serial transmission
Receiver Register
´ Receives serial information into another shift register
´ Complete data byte is sent to the receiver register
Status Register Bits
´ Used for I/O flags and for recording errors (Parity Error, Framing Error and Overrun Error)
Control Register Bits
´ Define baud rate, no. of bits in each character, whether to generate and check parity, and no. of stop bits
Content
´ Peripheral Devices

´ Input Output Interface

´ Data Transfer Schemes

´ Modes of data transfer

´ Priority interrupt

´ Direct Memory Access Transfer

´ Input/Output processor

´ Program Control and Interrupts

´ Processor Status Word


Mode of Transfer
´ Binary information received from external device is usually stored in memory
´ Information transferred from central computer into an external device originates in
the memory unit
´ The CPU merely execute I/O instructions and may accept data temporarily but
ultimate source or destination is the Memory Unit
´ Data transfer between central computer and I/O devices may be handled in a
variety of modes. Some modes use CPU as intermediate path and others transfer
data directly to and from memory unit
´ Data Transfer to or from peripheral can be handled in one of three possible modes:
´ Programmed I/O
´ Interrupt–Initiated I/O
´ Direct Memory Access (DMA)
Programmed I/O

´ When byte of data is available – places it in the I/O


bus and enables data valid line
´ Interface accept bytes into its data register and
enables the data accept line (Flag-1)
´ Device can disable the data valid line, but next
byte will only be transferred – Data accept line is
disabled
´ If Flag=1 – CPU reads the data from the data register
and clear Flag=0
Programmed I/O
´ Programmed I/O operations are the result of I/O Instructions written in
computer program
´ Each data item transfer is initiated by an instruction in the program
´ Usually, transfer is to and from a CPU register to peripheral, other instructions
are needed to transfer data to and from CPU and Memory
´ Transferring data under program control requires constant monitoring of the
peripheral by CPU
´ In programmed I/O method, CPU stays in a program loop until the I/O unit
indicated that it is ready for data transfer
´ This is a time consuming process since it keeps the processor busy needlessly.
´ It can be avoided by using Interrupt facility and special commands to inform
the interface to issue an interrupt request signal when data are available for
the device.
Content
´ Peripheral Devices

´ Input Output Interface

´ Data Transfer Schemes

´ Modes of data transfer

´ Program Control and Interrupts

´ Processor Status Word

´ Priority interrupt

´ Direct Memory Access Transfer

´ Input/Output processor
Interrupts

´ If any device require immediate attention/service of CPU – High priority Instruction

´ Interrupt is a request from H/W device or S/W program for immediate service by processor

´ After Interrupt is generated, processor transfer the request to execute Interrupt Service
Routine (ISR) using Interrupt Handler
´ The status of the processor (Content of PC, Registers, PSW) is saved in the memory
´ ISR is completed, the saved states of processor is restored

Advantages Disadvantages
´ Efficiency of CPU is improved ´ Overhead required to service the interrupt (Interrupt Latency )
´ Save status of processor and restore it
Types of Interrupts
´ External interrupts – External Interrupts initiated from the outside of CPU and
Memory
´ I/O Device → Data transfer request or Data transfer complete
´ Timing Device → Timeout
´ Power Failure
´ Operator
´ Internal interrupts (traps) – Internal Interrupts are caused by the currently running
program
´ Register, Stack Overflow
´ Divide by zero
´ OP-code Violation
´ Protection Violation
´ Software Interrupts – Both External and Internal Interrupts are initiated by the
computer HW. Software Interrupts are initiated by the executing an instruction.
´ Supervisor Call
1. Switching from a user mode to the supervisor mode
2. Allows to execute a certain class of operations which are not allowed in the user mode
Vectored and Non-Vectored Interrupt
´ Ways the processor chooses the branch address of the service routine varies from one unit
to another. There are two methods
´ Non-Vectored Interrupt:
´ Branch address is assigned to a fixed location in memory
´ Device doesn’t provide the address of ISR
´ Vectored Interrupt:
´ Source (device) that interrupts, supplies the branch information to the computer – Interrupt Vector
´ Mostly used when CPU has multiple peripherals connected to system bus

In some computers the interrupt vector is the first address of I/O service routine
In other computers the interrupt vector is an address that points to the location in the memory
where the beginning address of I/O service routine is stored
Interrupt Initiated I/O

´ CPU constantly monitors the FLAG to let the interface inform the computer when it’s
ready to transfer
´ CPU proceeds to execute another programs and interface keeps monitoring the FLAG
´ When device is ready for transfer – generate interrupts
´ Detecting external interrupt signal – CPU stops the task momentarily and process I/O
data transfer and then resumes the original task it was performing

Advantage
´ Waiting period of CPU is ideally eliminated
Flag, Processor Status Word

´ In Basic Computer, the processor had several (status) flags – 1 bit value that
indicated various information about the processor’s state – E, FGI, FGO, I,
IEN, R
´ In some processors, flags like these are often combined into a register – the
Processor Status Register (PSR); sometimes called a Processor Status Word
(PSW)
´ Common flags in PSW are
Status Flag Circuit
´ C (Carry): Set to 1 if the carry out of the ALU is 1
A B
´ S (Sign): The MSB bit of the ALU’s output (F7) 8 8
c7
´ Z (Zero): Set to 1 if the ALU’s output is all 0’s
8-bit ALU
c8
´ V (Overflow): Set to 1 if there is an overflow F7 - F0
V Z S C
F7

Check for 8
zero output
F
Priority Interrupt
´ Data transfer between the CPU and an I/O device is initiated by CPU
´ Multiple I/O devices are connected to Computer
´ Priority Interrupt – System that establish priority, to determine which condition to be
serviced first when multiple Interrupt requests arrive simultaneously
´ Higher priority – High speed transfers (Magnetic Disks)
´ Lower priority – Lower speed (Keyboard)
´ Two method for priority interrupt
´ Software – Polling
´ Hardware
´ Serial Priority Interrupt – Serial connection
´ Parallel Priority Interrupt – Parallel connection
Interrupt–Initiated I/O VAD 1 VAD 2 VAD 3

Device 1 Device 2 Device 3


To next
PI PO PI PO PI PO
device

´ Serial connection of all device that request an


interrupt Interrupt request
INT
´ Device with highest priority placed in first position CPU
followed by devices with lower priority and so on Interrupt acknowledge
INTACK

´ Interrupt generated by any device – signals low state interrupt line (INTR )
´ CPU responds by enabling Interrupt Acknowledgement (INTACK) line
´ If device has requested the interrupt (PI=1)– Places the Vector Address (VAD) on the Bus
´ Blocks the further transfer of interrupt by PO=0 (PI=1 and PO=0) Highest Priority Device
´ If the device has not requested the interrupt
´ Passes the INTACK signal to the next device i.e. (PI=1 and PO=1)
´ This process continues unless appropriate device is found
´ If device get PI=0 generate PO=0 (INTACK has be blocked by the higher priority device)is
one with highest priority requesting interrupt
Working of Daisy Chain Priority Interrupt
One Stage of Daisy Chain Priority

0
If PI=1 and PO =0 , then

A. Interrupt is activated
B. No Interrupt
C. Interrupt ACK passed to next device
D. Invalid Interrupt
If PI=1 and PO =0 , then

A. Interrupt is activated
B. No Interrupt
C. Interrupt ACK passed to next device
D. Invalid Interrupt
Parallel Priority Interrupts
Interrupt register Bus
Buffer
Disk 0 I0 y
´ IEN: Set or Clear by instructions ION or IOF Printer 1 I1 x
Priority 0
´ IST: Represents an unmasked interrupt has Reader 2 encoder
I2
occurred. INTACK enables tristate Bus Buffer to 0 VAD
load VAD generated by the Priority Logic Keyboard 3 0 to CPU
I3
0
0
0 IEN IST
0
Mask
register 1 Enable

2
Interrupt
to CPU
3
INTACK
Interrupt Register: from CPU

´ Each bit is associated with an Interrupt Request from different Interrupt Source - different priority level
´ Each bit can be cleared by a program instruction
Mask Register:
´ Mask Register is associated with Interrupt Register
´ Each bit can be set or cleared by an Instruction
Priority Encoder

´ Determines the highest priority interrupt when more than one interrupts take
place

Inputs Outputs

I0 I1 I2 I3 x y IST Boolean functions


1 x x x 0 0 1
0 1 x x 0 1 1
0 0 1 x 1 0 1
0 0 0 1 1 1 1
0 0 0 0 x x 0 (IST) = I0 + I1 + I2 + I3
Interrupt Cycle
´ At the end of each Instruction cycle
´ CPU checks IEN and IST
´ If IEN and IST = 1, CPU -> Interrupt Cycle

´ 𝑆𝑃 ← 𝑆𝑃 − 1 Decrement stack pointer


´ 𝑀[𝑆𝑃] ← 𝑃𝐶 Push PC into stack
´ 𝐼𝑁𝑇𝐴𝐶𝐾 ← 1 Enable interrupt acknowledge
´ 𝑃𝐶 ← 𝑉𝐴𝐷 Transfer vector address to PC
´ 𝐼𝐸𝑁 ← 0 Disable further interrupts

Go To Fetch to execute the first instruction in the interrupt service routine


Software Routines
7
0 JMP DISK DISK Program to service
1 JMP PTR magnetic disk
VAD=00000011 3
2 JMP RDR PTR Program to service
3 JMP KBD line printer
8
1 Main program
KBD RDR Program to service
interrupt 749 current instr.
750 character reader
4
KBD Program to service
Stack
11 keyboard
5
2 255
256 Disk
interrupt 256
750

6 9 10

´ Each interrupt service routine must have an initial and final set of operations for
controlling the registers in the hardware interrupt system

Initial Sequence Final Sequence


[1] Clear lower level Mask reg. bits [1] IEN <- 0
[2] IST <- 0 [2] Restore CPU registers
[3] Save contents of CPU registers [3] Clear the bit in the Interrupt Reg
[4] IEN <- 1 [4] Set lower level Mask reg. bits
[5] Go to Interrupt Service Routine [5] Restore return address, IEN <- 1
Content
´ Peripheral Devices

´ Input Output Interface

´ Data Transfer Schemes

´ Modes of data transfer

´ Program Control and Interrupts

´ Processor Status Word

´ Priority interrupt

´ Direct Memory Access Transfer

´ Input/Output processor
Direct Memory Access (DMA)
´ Allows I/O devices to transfer data directly to/from Memory without CPU intervention
´ Block of data transfer between high speed devices like Disk and Memory
´ DMA controller – Interface which takes over the buses to manage the transfer
directly between Memory and I/O Device, freeing CPU for other tasks
´ CPU initializes DMA Controller by sending memory address and the block size
(number of words) Address bus

Data bus Address bus


Data bus
buffers buffers
Address bus
ABUS
Bus Request BR DBUS Data bus
CPU DMA select DS
Bus Granted BG RD Read Address register

Internal Bus
WR Write RS
Read RD Word count register
Address register: Write WR
Control
logic
Contains an address to specify Control register
Bus request BR
Desired location in memory
Word count register Bus grant BG
Holds no. of words to be transferred Interrupt Interrupt DMA request
Control register DMA acknowledge to I/O device
Specifies the mode of transfer
Direct Memory Access
RD and WR is bidirectional
´ When BG=0 CPU can communicate with DMA Register
´ When BG=1 CPU left the buses and DMA can communicate directly with memory

DMA Transfer can be made in several ways


´ Burst Transfer
´ Block sequence consisting of memory words is transferred in continuous burst while the DMA
controller is master of memory bus
´ This mode of transfer is needed for fast devices such as magnetic disk where data
transmission cannot be stopped or slowed down until an entire block is transferred
´ Cycle Stealing
´ Alternative technique called cycle stealing allows DMA controller to transfer one data word
at time after which it must return control of the buses to the CPU.
´ CPU merely delays its operation for one memory cycle to allow the direct memory I/O
transfer to “steal” one memory cycle
DMA Controller I/O Operation

DMA is first initialized by CPU. After that DMA starts and continues to transfer data
between memory and peripheral unit until an entire block is transferred.

CPU initializes the DMA by sending following information through data bus:

´ Starting address of the memory block (for read/write)

´ Word Count (no. of words in memory block)

´ Control to specify mode of transfer (E.g. read/write)

´ A control to start DMA Transfer


DMA Transfer
Interrupt
Random-access
BG
CPU memory unit (RAM)
BR

RD WR Addr Data RD WR Addr Data

Read control

Write control

Data bus

Address bus

Address
select

RD WR Addr Data

DS DMA ack.

RS I/O
DMA
Peripheral
BR Controller
device
BG DMA request

Interrupt
Content
´ Peripheral Devices

´ Input Output Interface

´ Data Transfer Schemes

´ Modes of data transfer

´ Program Control and Interrupts

´ Processor Status Word

´ Priority interrupt

´ Direct Memory Access Transfer

´ Input/Output processor
I/O Processor (IOP)
Channel
´ Processor with direct memory access capability that communicates with I/O devices
´ IOP is same as CPU – Designed to handle I/O processing
´ Unlike DMA Controller, IOP can fetch and execute its own instruction
´ IOP Instructions (Commands) specially designed to facilitate I/O transfer.(Additional function like
Arithmetic, Logic, Branching and code translation)
´ Data gathered in IOP at device rate and bit capacity while CPU executing own program
´ Transfer between IOP and Device similar to Programmed I/O and transfer between IOP and Memory
similar to DMA
´ CPU is master while IOP is slave processor
´ CPU initiates the channel by executing a channel I/O class instruction and once initiated, channel
operates independent of the CPU
Central
processing
unit (CPU)

Memory Bus
Peripheral devices
Memory
unit PD PD PD PD
Input-output
processor
(IOP) I/O bus
Channel CPU Communication
CPU operations IOP operations

Send instruction
to test IOP.path
Transfer status word
to memory
If status OK, then send
start I/O instruction
to IOP. Access memory
for IOP program

CPU continues with


another program Conduct I/O transfers
using DMA;
Prepare status report.

I/O transfer completed;


Interrupt CPU
Request IOP status

Transfer status word


Check status word to memory location
for correct transfer.

Continue

You might also like