660 likes | 672 Views
Explore instruction set architecture, program execution, memory addressing, and hardware components in computer systems. Learn about compilers, assemblers, and linkers. Discover the language of the computer. Enhance your knowledge of digital design and circuitry.
E N D
CS-447– Computer Architecture M,W 10-11:20amLecture 4Instruction Set Architecture Sep 10th, 2007 Majd F. Sakr msakr@qatar.cmu.edu www.qatar.cmu.edu/~msakr/15447-f07/
Done by now • Read the first 3 chapters of the book • Review the slides • Come see us during office hours • Working on the project
Program Concept • Hardwired systems are inflexible • General purpose hardware can do different tasks, given correct control signals • Instead of re-wiring, supply a new set of control signals
What is a program? • A sequence of steps • For each step, an arithmetic or logical operation is done • For each operation, a different set of control signals are needed
Function of Control Unit • For each operation a unique code is provided • e.g. ADD, MOVE • A hardware segment accepts the code and issues the control signals • We have a computer!
Instruction Cycle • Two steps: • Fetch • Execute
Fetch Cycle • Program Counter (PC) holds address of next instruction to fetch • Processor fetches instruction from memory location pointed to by PC • Increment PC (PC = PC + 1) • Unless told otherwise • Instruction loaded into Instruction Register (IR) • Processor interprets instruction
Execute Cycle • Processor-memory • data transfer between CPU and main memory • Processor I/O • Data transfer between CPU and I/O module • Data processing • Some arithmetic or logical operation on data • Control • Alteration of sequence of operations • e.g. jump • Combination of above
Application (MediaPlayer) Operating Compiler System (Windows XP) Software Assembler Instruction Set Architecture Hardware Processor Memory I/O system Datapath & Control Layout & Technology Digital Design Circuit Design Transistors Instruction Set Architecture The Language of the Computer
Chapter objectives • The goal of this lecture is to discuss an instruction set (a simple one), showing both how instructions are represented in hardware & the relationship between high-level programming languages (for example C-language which you know) and this more primitive one. • Next time: the different addressing modes.
Chapter objectives (2) • By learning how to represent instructions, you will also discover the secret of computing: the stored-program concept.
Translating & Starting a Program C Program Compiler Assembly Language Program Assembler Object: Machine language module Linker Executable: Machine language program
Translating & Optimizing a Program: TheCompiler The Compiler transforms the C program into an assembly language program, a symbolic form of what the machine understands.
Translating a Program: TheAssembler The Assembler transforms the Assembly program into a machine language module.
Stitching a Program: TheLinker The linker or link editor takes all the independently assembled machine language programs and “stitches” them together. There are three steps for the linker: 1) Place code and data modules symbolically in memory2) Determine the addresses of data and instruction labels3) Patch both the internal and external references
What Happens in Hardware? Instructions CPU Memory Data
Address Bus & Data Bus Address Bus CPU Memory Data Bus
Address Bus CPU Memory Data Bus Address Bus & Data Bus • Address Bus: • Names • Locations • Where to go • Data Bus: • Content • Values • Variables
Memory Memory Decoder1 to 2 Decoder1 to 2 0 0 1 1 DataBus = 1 DataBus = 2 Example of Memory with AddrBus = 1 Address Bus = 1 Address Bus = 1
Example of Memory with AddrBus = 1 Memory Decoder1 to 2 0 1 Data Bus = 8 Address Bus = 1
Memory Decoder2 to 4 0 0 1 1 0 1 0 1 DataBus = 1 Example of Memory with AddrBus = 2 Address Bus = 2
Memory Decoder2 to 4 0 0 1 1 0 1 0 1 DataBus = 2 Example of Memory with AddrBus = 2 Address Bus = 2
Example of Memory with AddrBus = 2 Memory Decoder2 to 4 1 0 0 1 1 0 1 0 Address Bus = 2 DataBus = 8
Memory Addresses Vs Memory Content As shown in the memory table: # locations = 64 (ML0 to ML63) => memory require 6-bits to address if the memory word-size = 11-bits => largest content in memory is 2048
In General we Need 2#bits = # Memory Locations If we wish to have 120 locations (120 names), then7-bitsshould be dedicated to address them(27= 128) If we first decide to dedicate 6-bits to address the memory locations, then we will be limited to 64 in their number (26= 64)
Instruction Set Design CPU Memory Address Bus Instructions Register File Control Data IR Functional Units Data Bus PC
What is an instruction set? • The complete collection of instructions that are understood by a CPU • Machine Code • Binary • Usually represented by assembly codes
Elements of an Instruction • Operation code (Op code) • Do this operation • Source Operand reference • To this to this value • Result Operand reference • Put the answer here
Operation Code (page 342) • Operation code(Opcode) • Do this operation
Processor Operations: In total, the # of instructions desired is 8, and these require 3-bits for controlling.
Registers & How Big? • CPU must have some working space (temporary storage) • Number of Registers varies between processor designs • Large enough to hold full address • Large enough to hold full data word
Register Address Vs Register Content As shown in the register file: # registers = 8 (R0 to R7) => registers require 3-bits to address if the register size = 11-bits => largest content in registers is 2047
In General we Need 2#bits = # Registers If we wish to have 30 registers, then5-bitsshould be dedicated to address them(25= 32) If we first decide to dedicate 4-bits to address the registers, then we will be limited to 16 in their number (24= 16)
I want this operation to make the additionof two registers & place the result in a third one Example: Add R1, R2, R3 ; R1 = R2 + R3 Instruction Design
Instruction Design If in our register file we had 4 registers, requiring 2-bits for addressing each; thus the 3 operands desired (R1, R2, R3) in the Add operation require (2x3 =) 6-bits to be addressed.
Add R1, R2, R3 ;(= 001011011) What happens inside the CPU? 0 1 Register File I.R. 001011011 2 2 001011011 001011011 ... 3 P.C. 3 2 4 FunctionalUnits 5 6 7 Memory CPU
Add R1, R2, R3 ;(= 001011011) R1 R3 NextInstruction 011111111 001010101 I.R. 001011011 R2 010101010 ... 3 P.C. 4 010101010 001010101 + CPU
Hypothetical Machine Consider the following hypothetical machine: # registers = 16 {R0 to R15} require 4-bits to address them (24 = 16) # memory locations = 256 {M0 to M255} require 8-bits to address them (28 = 256)
Hypothetical Machine (cont’d) # instructions = 32 {Inst0 to Inst31} require 5-bits to be controlled (25 = 32) where Inst15 = Add (instruction # 15) & Inst9 = Load (instruction # 9)
The instruction In fact, each piece of an instruction can be considered as an individual number, & placing these numbers side by side forms the instruction.
The instruction In fact, the instruction format Example: OpCode, Operand, Operand, Operandis fixed only for a specific operation