Download presentation
Presentation is loading. Please wait.
Published byJesse Scott Modified over 9 years ago
1
Presented by: Sergio Ospina Qing Gao
2
Contents ♦ 12.1 Processor Organization ♦ 12.2 Register Organization ♦ 12.3 Instruction Cycle ♦ 12.4 Instruction Pipelining
3
12.1 Processor Organization ♦ Fetch Instruction ♦ Interpret Instruction ♦ Fetch Data ♦ Process Data ♦ Write Data
4
Remember…. ♦ The processor needs to store some data temporally. ♦ It must remember the location of the last instruction so that it can know where to get the next instruction. ♦ It needs to store instructions and data temporally while an instruction is being executed.
5
CPU with System Bus
6
CPU Internal Structure
7
12.2 Register Organization ♦ User-visible registers ♦ Control and status registers
8
User Visible Registers ♦ General Purpose ♦ Data ♦ Address ♦ Condition Codes
9
Control & Status Registers ♦ Program Counter Contains the address of an instruction to be fetched. ♦ Instruction Decoding Register Contains the instruction most recently fetched. ♦ Memory Address Register Contains the address of a location in memory. ♦ Memory Buffer Register Contains a word of data to be written to memory or the word most recently read.
10
Program Status Word ♦ Sign ♦ Zero ♦ Carry ♦ Equal ♦ Overflow ♦ Interrupt enable/disable ♦ Supervisor
11
Example Register Organization
12
12.3 Instruction Cycle ♦ It is the time in which a single instruction is fetched from memory, decoded, and executed. ♦ An Instruction Cycle requires the following sub cycle:
13
Instruction Cycle ♦ Fetch Reads the next instruction from memory into the processor. ♦ Indirect Cycle (Decode Cycle) May require memory access to fetch operands, therefore more memory accesses. ♦ Interrupt Save current instruction and service the interrupt. ♦ Execute Interpret the opcode and perform the indicated operation.
14
Instruction Cycle Fetch Interrupt IndirectExecute
15
Data Flow (Fetch Diagram) PC Control Unit PCMAR Memory Control Unit MBR Memory IRMBR
16
Data Flow (Indirect Diagram) MBR MAR Memory Control Unit Memory MBR Memory
17
Data Flow (Interrupt Diagram) Control Unit PC MBR PC Control Unit MAR Memory MBR Memory Control Unit Control Unit PC
18
Data Flow (Execute) ♦ May take many forms ♦ Depends on instruction being executed ♦ May include Memory read/write Input/Output Register transfers ALU operations
19
12.4 Instruction Pipelining ♦ Instruction processing is subdivided: Fetch/ Execute instruction ♦ Pipeline has two independent stages: 1 st Stage – Fetch an instruction and buffers it. 2 nd Stage – Temporarily free until first stage passes it the buffered instruction. While the second stage is executing the instruction, the first stage fetches and buffers the next instruction. ♦ Instruction prefetch or fetch overlap. - Purpose? To speed up instruction execution.
20
Two-Stage Instruction Pipeline
21
Instruction Processing ♦ Fetch instruction (FI) ♦ Decode instruction (DI) ♦ Calculate operands (CO) ♦ Fetch operands (FO) ♦ Execute instruction (EI) ♦ Write operand (WO) ♦ Successive instructions in a program sequence will overlap in execution.
22
Timing Diagram for Instruction Pipeline Operation
23
Six-Stage CPU Instruction Pipeline The logic needed for pipelining to account for branches, interrupts, and arising problems.
24
Alternative Pipeline Depiction
25
Branches ♦ Branch- group of instructions ♦ Branch Instructions – (Jump Instruction) One of it’s operands is the address of the next instruction to be executed.
26
Branches ♦ Two Types of Branch Instructions Unconditional – Branch always happens Conditional – Branch only happens if certain condition is met. -The PC is updated to the address specified in the operand of the conditional branch instruction. -A conditional branch instruction is similar to an if statement.
27
Conditional Branch Instructions ♦ Condition Codes BRP X ○ Branch to location X if result is positive BRZ X ○ Branch to location X if result is zero BRE R1,R2,X ○ Branch to location X if contents of R1 = R2
28
Conditional Branch Instructions
29
Dealing with Branches ♦ A major problem in designing an instruction pipeline is assuring a steady flow of instructions to the initial stages of the pipeline. ♦ Since conditional branches alter the steady flow of instructions, we must come up with ways to execute them efficiently.
30
Dealing with Branches ♦ 5 Approaches to Dealing with Conditional Branches Multiple Streams Delayed Branch Prefetch Branch target Loop Buffer Branch Prediction
31
Dealing with Branches ♦ Multiple Streams (IBM 370/168 and IBM 3033) ○ Pipeline fetches both instructions. Leads to contention delays, and branches can lead to too many streams. ♦ Delayed Branch o Branch Instruction occurs later than desired. ♦ Prefetch Branch Target (360/91 IBM) o The target of the branch is prefetched, along with the instruction following the branch, so if the branch is taken this will speed up performance.
32
Dealing with Branches ♦ Loop buffer ( Motorola 68010) Memory containing the n most recently fetched instructions. Useful with if-then and if-then-else statements, as well as loops ♦ Branch Prediction Different techniques are used to predict whether the branch will be taken or not If the prediction is correct this will speed up performance
33
Dealing with Branches
34
Review Questions 1. What are the major components of a processor? Arithmetic and Logic Unit (ALU) and the Control Unit (CU). 2. What is the function of the ALU? The ALU does the actual computation or processing of data. 3. What is the function of the control unit? The control unit controls the movement of data and instructions into and out of the processor and controls the operations of the ALU. 4. What are the two roles that registers in the processor perform? User-visible registers, and control and status registers. 5. What are bits set by the processor hardware as a result of operations? Condition codes.
35
Review Questions (Continued) 6. What is an instruction cycle? It is the time in which a single instruction is fetched from memory, decoded, and executed. 7. What are the four sub cycle of an instruction cycle? Fetch, Indirect (if any), execute, and interrupt (if any). 8. Is the fetch or execute cycle the same for all CPU? No, it depends on the CPU’s design. 9. What is the sequence of an interrupt cycle? PC MBR Address of Stack MAR MAR Memory PC Memory Control Unit request memory write via Control Bus PC is loaded with address of Interrupt handler.
36
Review Questions (Continued) 10. What is the main purpose for instruction pipelining? To speed up the instruction execution rate. 11. How can you make the pipelining more efficient? To gain further speedup, the pipeline must have more stages for decomposition. 12. What is a condition code? A statement that if true will allow the branch to be executed. 13. What is another name for a branch instruction? A jump instruction.
37
Research ♦ http://www.it.jcu.edu.au/Subjects/cp1300/resources/lect notes/system/fde.html http://www.it.jcu.edu.au/Subjects/cp1300/resources/lect notes/system/fde.html ♦ http://dr-pisit.com/csc331/Lec10-CPU&Pipeline.pdf http://dr-pisit.com/csc331/Lec10-CPU&Pipeline.pdf ♦ http://en.wikipedia.org/wiki/Instruction_pipelining http://en.wikipedia.org/wiki/Instruction_pipelining ♦ http://www.itreviews.co.uk/hardware/h738.htm http://www.itreviews.co.uk/hardware/h738.htm
Similar presentations
© 2024 SlidePlayer.com Inc.
All rights reserved.