Micro Operations
Control Unit Functions
Control Unit Implementation
Hardwired Implementation
Microprogram Implementation
Micro-operations are the atomic operations performed by a processor while executing a program.
Each instruction cycle has several smaller cycles, including fetch, indirect, execute, and interrupt.
Fetch and execute cycles occur consistently across instruction cycles.
Smaller cycles comprise a series of steps involving processor registers, known as micro-operations.
Every step is simple and contributes minimally by itself to the overall processing task.
Instruction cycles consist of various phases, notably fetch, indirect, execute, and interrupt.
Each phase involves specific micro-operations (µOP).
Processor functions decompose into micro-operations.
Understanding micro-operations guides defining the control unit's functional requirements.
These requirements drive the design and implementation of the control unit.
Define the basic elements of the processor.
Describe the micro-operations performed by the processor.
Determine the necessary functions for the control unit to execute those micro-operations.
ALU: The functional essence of the computer.
Registers: Store data and status internal to the processor.
Internal Data Paths: Move data between registers and between registers and the ALU.
External Data Paths: Link registers to memory and I/O modules, typically using a system bus.
Control Unit: Manages and orchestrates operations within the processor.
All micro-operations performed by the processor can be categorized into:
Transfers between registers.
Transfers between a register and external interfaces (e.g., system bus).
Arithmetic or logic operations utilizing registers for input and output.
t1: MAR ← (PC)
t2: MBR ← M(MAR)
t3: IR ← (MBR)
MAR: Memory Address Register
MBR: Memory Buffer Register
PC: Program Counter
IR: Instruction Register
Initiates each instruction cycle to retrieve an instruction from memory.
Memory Address Register (MAR): Specifies read/write addresses.
Memory Buffer Register (MBR): Holds data for read/write operations.
Program Counter (PC): Points to the next instruction address.
Instruction Register (IR): Stores the most recently fetched instruction.
t1: MAR ← (IR(Address))
t2: MBR ← M(MAR)
t3: IR(Address) ← (MBR(Address))
Follows instruction fetching to retrieve source operands, especially when indirect addressing is specified.
Steps involved include:
Load instruction's address into the MAR.
Fetch operand address via MAR.
Update IR to contain a direct address.
t1: MBR ← (PC)
t2: MAR ← Address
t3: M(MAR) ← (MBR)
Occurs post-execution cycle upon detection of enabled interrupts.
Save content of the PC in MBR.
Load MAR with the address for saving PC's content.
Load PC with the address of the interrupt-processing routine.
Store MBR back to memory.
The execution phase varies greatly based on opcode with steps like instruction decoding.
ADD R1, X:
t1: MAR ← (IR(Address))
t2: MBR ← (memory)
t3: R1 ← R1 + (MBR)
ISZ X – Increment and skip if zero:
Executes several micro-operations, such as checking register values and conditionally modifying PC.
BSA X – Branch and save address
Stores the next instruction’s address in memory and continues execution from an altered location.
Steps include loading MAR with the instruction address and updating the PC.
Proper sequence handling:
MAR ← (PC) must precede MBR ← (memory).
Avoid conflicts:
Reading and writing to the same register simultaneously is not allowed.
Multiple actions involving ALU must be scheduled correctly to avoid hardware duplication.
Phases are decomposed into distinct sequences of micro-operations.
A register tracks the instruction cycle code, indicative of the processor’s state, with codes such as:
00 – Fetching
01 – Indirect addressing
10 – Execution
11 – Interrupt
Visual representation guiding instruction processing phases; demonstrates decision-making in handling interrupts and addressing modes.
Sequencing: Orchestrates processor micro-operations sequentially.
Execution: Triggers individual micro-operations through control signals.
Clock: Signals operations timing.
Instruction Register: Holds op-code dictating carried micro-instructions.
Flags: Indicate CPU state and previous operation results.
Commands for data movement between registers.
Activation of specific ALU functions.
Control signals to memory and I/O modules.
Breakdown of active control signals for various steps in instruction execution, detailing function and outcome.
Circuit Implementation: Fast but complex and costly.
Microprogram Implementation: Lower cost, more flexible, widely used in CISC machines.
Inputs include flags and opcode from instruction register; decoders are essential for generating control signals.
Detailed clock pulse sequences guide control signal generation corresponding to micro-operations.
Components include instruction registers, decoders, and timing generators reflecting connections and function.
Complexity in design and sequencing.
Inflexibility to adapt to new instructions.
Microprogram details dictate control unit operations; uses control memory to store micro-operations.
Structured to signal register transfers and ALU operations.
Control signals active based on present op-code and its conditions; specifies operations through a control word for every micro-operation.
Vertical Micro-Programming: Few operations specified.
Horizontal Micro-Programming: Multiple operations executed in parallel.
Various formats to represent necessary micro-operations clearly.
Micro-Operations
Control Unit Functions
Control Unit Implementation
Conveys the logical arrangement and relationships among control unit components.
Issues read commands.
Generates control signals post-read operation based on control buffer register contents.
Process involves decision-making for the next operation using control address register adjustments based on flag values and control buffer contents.
Details how microprogramming influences the control unit's behavior and efficiency.
Outlines the sequence and decision-making involved in operations.
Simpler design, cost-effective, reduced error rates.
Generally slower than hardwired designs.
Micro-operations definition and types.
Instruction cycle phases: fetch, indirect, interrupt, execute.
Control unit functionality and requirements.
Implementation methods and their implications.
Micro-Operations: Defined as the basic atomic operations that occur during program execution, encompassing key cycles such as fetch, indirect, execute, and interrupt, which together enable the processor to function effectively.
Control Unit Functions: This unit orchestrates the sequence of micro-operations executed by the processor, which is crucial for understanding both the functional requirements and the design of the control unit itself.
Define Processor Elements: Identifying and outlining the fundamental components that make up the processor, such as the ALU, registers, and buses.
Describe Performed Micro-Operations: Analyzing the specific micro-operations that are executed by these elements during instruction processing.
Identify Control Unit Functions: Determining the necessary functions that the control unit must perform to enable the execution of the aforementioned micro-operations effectively.
ALU (Arithmetic Logic Unit): The processing backbone of the computer that carries out arithmetic and logic operations.
Registers: Fast storage locations within the processor that hold data and status information temporarily during execution.
Data Paths: Internal pathways for moving data between registers and the ALU, while external paths connect these internal components to memory and input/output modules.
Control Unit: The mastermind that manages and coordinates all operations within the processor, ensuring that everything runs in sync.
Fetch Cycle: The first step where the processor loads an instruction from memory, storing it in the Instruction Register (IR).
Indirect Addressing Cycle: This occurs when the processor retrieves the operand addresses specified in the instruction, facilitating flexible data access.
Execute Cycle: The stage where the processor performs the necessary operations as dictated by the instruction's op-code, executing relevant micro-operations.
Interrupt Cycle: Conducted after the execution phase, this cycle addresses any interrupt signals, ensuring the processor can respond to critical events.
Types of Implementation: There are primarily two approaches to implementing control units - Hardwired implementation, known for its speed and complexity; and Microprogrammed implementation, characterized by its flexibility and lower cost.
Microprogramming: Involves the use of control memory to store the sequences of micro-operations, generating control signals based on the current operation’s op-code; it provides advantages such as a streamlined design but may exhibit slower performance relative to hardwired systems due to additional layers of abstraction.
Understanding micro-operations is fundamental for grasping the detailed processes involved in the instruction cycle.
The functions performed by the control unit are essential for governing the operational efficiency of the processor.