KEMBAR78
CSA Unit2 | PDF | Input/Output | Central Processing Unit
0% found this document useful (0 votes)
23 views9 pages

CSA Unit2

This document is a study material for the Computer System Architecture course at Government Arts College, Chidambaram, designed for BSc-Computer Science students. It covers various topics including digital logic circuits, register transfer and microoperations, central processing unit organization, computer arithmetic, memory organization, and input/output operations. The material provides detailed explanations of concepts such as instruction cycles, micro-operations, and the role of interrupts in computer systems.
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)
23 views9 pages

CSA Unit2

This document is a study material for the Computer System Architecture course at Government Arts College, Chidambaram, designed for BSc-Computer Science students. It covers various topics including digital logic circuits, register transfer and microoperations, central processing unit organization, computer arithmetic, memory organization, and input/output operations. The material provides detailed explanations of concepts such as instruction cycles, micro-operations, and the role of interrupts in computer systems.
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/ 9

GOVERNEMENT ARTS COLLEGE,

CHIDAMBARAM
(Affiliated to Annamalai University)

COMPUTER SYSTEM ARCHITECTURE

Study Material

For

III-CS
BSc-Computer Science

Prepared By

Prof.P.Sankar.,M.C.A.,M.Phil.,(P.hD).,
Faculty of Computer Science & Application

PG DEPARTMENT OF COMPUTER SCIENCE

2024
COMPUTER SYSTEM ARCHITECTURE

Unit – I: (12Hours)
Digital Logic Circuits: Combinational Circuits – Flip-Flops. Data Representation: Data Types
– Complements – Fixed and Floating Point Representation – Other Binary Codes – Error
Detection Codes.
Unit – II: (12Hours)
Register Transfer and Microoperations: Register Transfer Language – Register Transfer –
Arithmetic Microoperations – Logic Microoperations – Shift Microoperations – Arithmetic
Logic Shift Unit. Basic Computer Organization and Design: Instruction Codes – Computer
Registers – Computer Instructions – Timing and Control – Instruction Cycle – Memory
Reference Instructions – Input/Output and Interrupt.
Unit – III: (12Hours)
Central Processing Unit : General Register Organization – Stack Organization – Instruction
Formats – Addressing Modes – Data Transfer and Manipulation – Program Control –
Reduced Instruction Set Computer.
Unit – IV: (12Hours)
Computer Arithmetic: Addition and Subtraction - Multiplication Algorithms – Division
Algorithms. Pipeline and Vector Processing: Parallel processing – Pipelining – Arithmetic
pipeline – Instruction pipeline – Vector Processing – Array Processor.
Unit – V: (12Hours)
Memory Organization: Memory Hierarchy – Main Memory – Auxiliary Memory –
Associative Memory – Cache Memory – Virtual Memory – Memory Management Hardware.
Multiprocessors: Characteristics of Multiprocessors – Interconnection Structures –
Interprocessor Arbitration
UNIT-II

Register Transfer and Micro operations:

 A digital computer system connects digital components such as registers, decoders,


arithmetic components, and control logic. To make a comprehensive digital system,
these digital modules are equipped with some common data and control channels.

Furthermore, the registers and the actions performed on the data stored in them best describe
digital modules. Micro-operations are operations that are done on data contained in registers.

Understanding Register Transfer Language


Register transfer language is a symbolic notation for describing micro-operation transfers
between registers.

The availability of hardware logic circuits that can perform a specified micro-operation and
transfer the outcome of the operation to the same or another register is referred to as register
transfer. The term “language” was coined by programmers to describe programming
languages. This programming language is a method of expressing a computer process
through symbols.

Following are some commonly used register transfer example with an example:

1. Accumulator: This is the most commonly used register for storing data read from
memory.

2. General-Purpose Registers: These are used to store data on intermediate outcomes during
the execution of a programme. Assembly programming is required to access it.

3. Special Purpose Registers: Users do not have access to the Special Purpose Registers.
These are computer system registers.

 MAR: Memory Address Registers are the registers that store the memory unit’s address
 MBR: This register stores instructions and data received from and sent from the
memory
 PC: Program Counter indicates the next command to be executed
 IR: Instruction Register stores the to-be-executed instruction

Register Transfer
The replacement operator designates the information moved from one register to another in
symbolic form.

R2 ← R1

It denotes the data transfer from register R1 to register R2.


In most cases, we want the transfer to happen only under specific control conditions. The
following if-then sentence demonstrates this: If (P=1), (R2 R1)

The control signal P is generated in the control portion.

Micro-Operations
Micro-operations are operations performed on data stored in registers. A micro-operation is a
simple operation that is carried out on data contained in one or more registers.

Example: Load, Shift, count, and clear.

Types of Micro-Operations
The following are the different types of micro-operations:

1. Micro-operations that move binary data from one register to another are known as register
transfers.

2. In registers, arithmetic micro-operations operate on numeric data stored.

3. Bit manipulation operations on non-numeric data are performed by logic micro-


operations.

4. Shift micro-operations are data-based shift micro-operations.

1. Arithmetic Micro-Operations

· Add Micro-Operation

The following statement defines it:

R1 + R2 = R3

The foregoing line tells the computer to add the data or contents of register R1 to the data or
contents of register R2, then transfer the sum to register R3.

· Subtract Micro-Operation

Consider the following scenario:

R1 + R2′ + 1 R3

Instead of using the minus operator, we use the complement of 1 and add one to the register
being subtracted.

· Increment/Decrement Micro-Operation
In general, increment and decrement micro-operations are accomplished by adding and
removing 1 from the register.

R1 → R1 + 1

R1 → R1 – 1

2. Logic Micro-Operations

These are binary micro-operations carried out on the register bits. These procedures treat each
bit as a binary variable and consider it separately.

Consider the X-OR micro-operation with the contents of R1 and R2 registers.

P: R1 ← R1 X-OR R2

A Control Function is also provided in the above statement.

3. Shift micro-operations

These are the important different types of micro-operations. That means we can move the
register’s contents to the left or right. The serial input shifts a bit to the rightmost position in
the shift left operation, and a bit to the leftmost position in the shift right action.

There are three different sorts of shifts:

a) Logical Shift

The serial input is used to send 0 to the device. The symbols “shl” and “shr” are used to
represent logical shifts left and right, respectively.

R1 ← she R1

R1 ← she R1

b) Circular Shift

This moves the bits of the register around the two ends without losing any data or contents.
The shift register’s serial output is connected to its serial input in this configuration. The
terms “cir” and “cil” stand for left and right circular shifts, respectively.

d) Shift in Arithmetic

A signed binary number is shifted to the left or right using this method. Arithmetic shift left
multiplies and divides a signed binary number by two. Because the signed number remains
the same when multiplied or divided by two, the sign bit is left unaltered by the arithmetic
shift micro-operation.

D = (1001)XS-3
Instruction code :
Instruction code, also known as machine code, is the binary code that a computer's processor
understands and executes directly. It is the lowest-level representation of a program or
instruction that a computer can understand.

Instruction code consists of a series of binary digits (0s and 1s) that represent instructions,
such as:

- Arithmetic operations (e.g., add, subtract, multiply, divide)

- Logical operations (e.g., AND, OR, NOT)

- Control flow instructions (e.g., jump, branch, loop)

- Load/store instructions (e.g., move data between registers and memory)

Instruction code is specific to a particular computer architecture and is typically generated by


a compiler or assembler.

Some common instruction codes include:

- x86 (Intel/AMD)

- ARM (Advanced RISC Machines)

- MIPS (MIPS Instruction Set)

- PowerPC (IBM)

Instruction code is used to:

- Perform calculations and data processing

- Control the flow of a program

- Interact with input/output devices

- Manage memory and resources

INSTRUCTION CYCLE:

The instruction cycle is a basic computer system that deals with the central processor unit's
core operations. It is also known as the fetch-decode-execute cycle, is a fundamental concept
in computer architecture and microprocessor operation. It represents the series of steps that a
computer's central processing unit (CPU) goes through to execute a single machine
instruction.
Instruction Cycle:

The instruction cycle is defined as the basic cycle in which a computer system fetches an
instruction from memory, decodes it, and then executes it. Fetch-Execute-Cycle is another
name for it. All instructions in a computer system are executed in the RAM of the computer
system. The CPU is in charge of carrying out the instruction.

Each instruction cycle in a basic computer includes the following procedures:

 It has the ability to retrieve instructions from memory.


 It's used to decode the command.
 If the instruction has an indirect address, it can read the effective address from
memory.
 It is capable of carrying out the command.

Initiating Cycle

During this phase, the computer system boots up and the Operating System loads into the
central processing unit's main memory. It begins when the computer system starts.
Fetching of Instruction

The first phase is instruction retrieval. Each instruction executed in a central processing unit
uses the fetch instruction. During this phase, the central processing unit sends the PC to MAR
and then the READ instruction to a control bus. After sending a read instruction on the data
bus, the memory returns the instruction that was stored at that exact address in the memory.
The CPU then copies data from the data bus into MBR, which it then copies to registers. The
pointer is incremented to the next memory location, allowing the next instruction to be
fetched from memory.

Decoding of Instruction

The second phase is instruction decoding. During this step, the CPU determines which
instruction should be fetched from the instruction and what action should be taken on the
instruction. The instruction's opcode is also retrieved from memory, and it decodes the related
operation that must be performed for the instruction.

Read of an Effective Address

The third phase is the reading of an effective address. The operation's decision is made during
this phase. Any memory type operation or non-memory type operation can be used. Direct
memory instruction and indirect memory instruction are the two types of memory instruction
available.

Execution of Instruction

The last step is to carry out the instructions. The instruction is finally carried out at this stage.
The instruction is carried out, and the result is saved in the register. The CPU gets prepared
for the execution of the next instruction after the completion of each instruction. The
execution time of each instruction is calculated, and this information is used to determine the
processor's processing speed.
Input/output (I/O) and Interrupts

Input/output (I/O):

- I/O devices allow communication between the computer and the outside world.
- Examples: keyboards, displays, storage devices, network interfaces.
- I/O operations involve data transfer between devices and memory.

Types of I/O:

- Synchronous I/O: CPU waits for I/O operation to complete.


- Asynchronous I/O: CPU continues executing while I/O operation is in progress.

I/O Interfaces:

- Programmed I/O: CPU executes I/O instructions.


- Interrupt-driven I/O: CPU receives interrupt requests from devices.
- Direct Memory Access (DMA): Devices access memory directly.

Interrupts:

- An interrupt is a signal to the CPU that an event requires attention.


- Interrupts allow the CPU to respond to events asynchronously.
- Examples: keyboard press, disk completion, network packet arrival.

Interrupt Handling:

- CPU receives interrupt request.


- CPU saves current state and executes interrupt handler.
- Interrupt handler processes event and returns control to CPU.

Types of Interrupts:

- Maskable interrupts: Can be disabled by the CPU.


- Non-maskable interrupts: Cannot be disabled.

Interrupts are used to:

- Handle I/O operations


- Manage system resources
- Respond to exceptions and errors

You might also like