Download presentation
Presentation is loading. Please wait.
1
COMPUTER ARCHITECTURE (for Erasmus students)
Assoc.Prof. Stasys Maciulevičius Computer Dept.
2
Input/output We will define input/output as a subsystem of components that moves coded data between external devices and a host system, consisting of a CPU and main memory. I/O subsystems include, but are not limited to: Blocks of main memory that are devoted to I/O functions Buses that provide the means of moving data into and out of the system Control modules in the host and in peripheral devices Interfaces to external components such as keyboards and disks Cabling or communications links between the host system and its peripherals 2009 ©S.Maciulevičius
3
Computer and its I/O devices
CPU Cache Main memory I/O bus I/O controller HD Graphic unit LAN Interrupt requests 2009 ©S.Maciulevičius
4
Input/output problems
The possibility to connect various peripheral devices Performing of input/output operations parallel with operations in processor Maximally simplified programming of input and output processes The response to various emergency situations and problems in peripheral equipment 2009 ©S.Maciulevičius
5
Problem-solving ways Modularity of peripheral equipment (constructive completeness, a simple connection) Uniform data formats Unified interface Unified instruction formats and types 2009 ©S.Maciulevičius
6
Addressing of peripheral equipment and I/O instructions
a) separate address space (PDP) b) overlapping address spaces Instructions: a) move – universal (both for memory access and peripheral equipment) b) load/store - for memory access, in/out - for peripheral equipment access 2009 ©S.Maciulevičius
7
Transfer of information
The transfer of information between the processor and a peripheral consists of the following steps: 1. Selection of the device and checking the device for readiness 2. Transfer initiation, when the device is ready 3. Information transfer 4. Conclusion 2009 ©S.Maciulevičius
8
General I/O structure Memory CPU Device 1 Device 2 Device n Interface
Address bus Data bus Control and status Device 1 Interface Device 2 Device n Device selection lines 2009 ©S.Maciulevičius
9
Device interface A device interface is unique to a particular device since each device is unique with respect to its data representation and read-write operational characteristics The major functions of a device interface are Timing Control Data conversion Error detection and correction 2009 ©S.Maciulevičius
10
Device interface The timing and control aspects correspond to the manipulation of control and status signals to bring about the data transfer In addition, the operating speed difference between the CPU and the device must be compensated for by the interface In general, data conversion from one code to the other is needed, since each device (or the medium on which data are represented) may use a different code to represent data Errors occur during transmission and must be detected and if possible corrected by the interface 2009 ©S.Maciulevičius
11
Device interface Decoder (selector) Status Buffer Transducer Device
Data Binary data Commands Status Device selection Control (from CPU) (to CPU) lines controller 2009 ©S.Maciulevičius
12
Device interface Device selection is performed by address decoding
The transducer converts the data represented on the I/O medium (tape, disk, etc.) into the binary format and stores it in the data buffer, if the device is an input device In the case of an output device, the CPU sends data into the buffer and the transducer converts this binary data into a format suitable for output onto the external medium 2009 ©S.Maciulevičius
13
Programmed I/O a) unconditional I/O b) conditional I/O in/out port
Ready? No Yes in/out port Port – address of peripheral device 2009 ©S.Maciulevičius
14
Programmed I/O c) interrupt mode I/O ... Main program
Preparation of interrupt system Exchange subpro-gram INTR ... Preparation of information exchange 2009 ©S.Maciulevičius
15
Ports Input port – any data source that can be selected performing the input command Output port – any data receiver that can be selected performing the output command Port addresses are sent through the address bus (or part of it) 2009 ©S.Maciulevičius
16
I/O channels I/O channel is a generic term that refers to a high-performance input/output architecture that is implemented in various forms on a number of computer architectures, especially on mainframe computers In the past they were generally implemented with a custom processor, known alternately as I/O processor or peripheral processor 2009 ©S.Maciulevičius
17
Classic: IBM I/O channels
Processor I/O channel Main memory I/O controller 2009 ©S.Maciulevičius
18
I/O channel A channel is an independent hardware component that coordinates all I/O to a set of controllers or devices The CPU of a system that uses channel I/O typically has only one machine instruction for input and output; this instruction is used to pass input/output commands to the specialized I/O hardware in the form of channel programs I/O thereafter proceeds without intervention from the CPU until an event requiring notification of the operating system occurs, at which point the I/O hardware signals an interrupt to the CPU Each channel may support one or more controllers and/or devices 2009 ©S.Maciulevičius
19
I/O channel A channel program is a sequence of I/O instructions executed by the input/output channel processor in the IBM System/360 and subsequent architectures The channel program consists of one or more channel command words A channel command word (CCW) is an instruction for a specialized I/O channel processor 2009 ©S.Maciulevičius
20
Main functions of I/O channel
to address the data array in memory to set the length of data array to form memory addresses to calculate volume of data transmitted to determine the end of I/O operation to buffer data during tansfer to change data formats to minimize the processor participation in I/O to form interrupt requests to transfer information about the status of peripheral device 2009 ©S.Maciulevičius
21
Direct memory access (DMA)
The programmed and interrupt mode I/O structures transfer data from the device into or out of a CPU register Direct memory access (DMA) is a feature of modern computers and microprocessors that allows certain hardware subsystems within the computer to access system memory for reading and/or writing independently of the CPU Many hardware systems use DMA including disk drive controllers, graphics cards, network cards, and sound cards 2009 ©S.Maciulevičius
22
CPU inicializes DMA, setting DMA controller
Direct memory access CPU inicializes DMA, setting DMA controller CPU executes some process DMA controls data exchange Cyc- le ste- eling ... INTR 2009 ©S.Maciulevičius
23
Direct memory access The sequence of events during a DMA transfer:
CPU initializes DMA controller, setting AR (Address Register), WCR (Word Count Register) and sends to DMA controller command to start data transmission; continues processing If WCR0, DMA controller gathers data; when word is ready for transfer, holds CPU (i.e., “steals” a memory cycle); if WCR=0, sends transfer-complete interrupt to CPU 2009 ©S.Maciulevičius
24
Direct memory access CPU continues with any processing that does not need a memory access; if memory access is needed, tries to acquire a memory cycle if DMA controller is not accessing the memory DMA controller transfers data; releases the memory; decrements WCR; increments AR; goes to step 2 DMA controllers can be either dedicated to one device or shared among several input/output devices 2009 ©S.Maciulevičius
25
DMA controller Standard DMA transfers are managed by the DMA controller, built into the system chipset on modern PCs The original PC and XT had one of these controllers and supported 4 DMA channels, 0 to 3 Starting with the IBM AT, a second DMA controller was added 2009 ©S.Maciulevičius
26
DMA controller (8237A) D Data bus buffer Control unit 0 channel
Mode control block 3 channel TR(16) CR(8) SR(8) RR(4) MASK(4) CAR (16) BAR (16) CWR (16) MR (6) WCR (16) DREQ0 DACK0 D Control signals DREQ1 DACK1 DREQ2 DACK2 DREQ3 DACK3 2009 ©S.Maciulevičius
27
Registers and modes Registers: CR – Command Register
SR – Status Register CAR – Current Address Register BAR – Basic Address Register CWR – Current WordCount Reg. WCR – Basic WordCount Reg. SR – Request Register MASK – Mask Register 2009 ©S.Maciulevičius
28
DMA operation The multimode DMA controller issues a HRQ to the processor whenever there is at least one valid DMA request from a peripheral device. When the processor replies with a HLDA signal, the 8237A takes control of the address bus, the data bus and the control bus The address for the first transfer operation comes out in two bytes - the least significant 8 bits on the eight address outputs and the most significant 8 bits on the data bus The contents of the data bus are then latched into an 8-bit latch to complete the full 16 bits of the address bus 2009 ©S.Maciulevičius
29
DMA operation modes DMA service will take place in one of four modes:
Single Transfer Mode. In Single Transfer mode the device is programmed to make one transfer only. The word count will be decremented and the address decremented or incremented following each transfer. When the word count ``rolls over'' from zero to FFFFH, a Terminal Count (TC) will cause an Autoinitialize if the channel has been programmed to do so Block Transfer Mode. In Block Transfer mode the device is activated by DREQ to continue making transfers during the service until a TC, caused by word count going to FFFFH, or an external End of Process (EOP) is encountered 2009 ©S.Maciulevičius
30
DMA operation modes Demand Transfer Mode. In Demand Transfer mode the device is programmed to continue making transfers until a TC or external EOP is encountered or until DREQ goes inact. Thus transfers may continue until the I/O device has exhausted its data capacity Cascade Mode. This mode is used to cascade more than one 8237A together for simple system expansion. The HRQ and HLDA signals from the additional 8237A are connected to the DREQ and DACK signals of a channel of the initial 8237A. This allows the DMA requests of the additional device to propagate through the priority network circuitry of the preceding device 2009 ©S.Maciulevičius
31
Cascading 8237A CPU 8237A 8237A HRQ HRQ HLDA HLDA DREQ HRQ DACK HLDA
Slaves 8237A CPU Master 8237A DREQ DACK HRQ HLDA HRQ HLDA 8237A HRQ HLDA 2009 ©S.Maciulevičius
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.