# Reduced Instruction Set Computer # Virendra Singh **Associate Professor** Computer Architecture and Dependable Systems Lab Department of Electrical Engineering Indian Institute of Technology Bombay http://www.ee.iitb.ac.in/~viren/ E-mail: viren@ee.iitb.ac.in # Computer Organization & Architecture Lecture 11 (09 April 2013) **CADSL** #### **Processor Architecture** # Where Does It All Begin? - In a register called program counter (PC). - PC contains the memory address of the next instruction to be executed. - In the beginning, PC contains the address of the memory location where the program begins. # Where is the Program? #### How Does It Run? # Datapath and Control - ➤ Datapath: Memory, registers, adders, ALU, and communication buses. Each step (fetch, decode, execute) requires communication (data transfer) paths between memory, registers and ALU. - Control: Datapath for each step is set up by control signals that set up dataflow directions on communication buses and select ALU and memory functions. Control signals are generated by a control unit consisting of one or more finite-state machines. # Datapath for Instruction Fetch # Register File: A Datapath Component # Multi-Operation ALU Operation select ALU function OOO AND **001** OR **010** Add 110 Subtract 111 Set on less than Operation select from control zero zero = 1, when all bits of result are 0 overflow # R-Type Instructions - Also known as arithmetic-logical instructions - add, sub, slt - Example: add \$t0, \$s1, \$s2 - Machine instruction word 000000 10001 10010 01000 00000 100000 opcode \$s1 \$s2 \$t0 function - Read two registers - Write one register - Opcode and function code go to control unit that generates RegWrite and ALU operation code. # Datapath for R-Type Instruction #### Load and Store Instructions I-type instructions ``` lw $t0, 1200 ($t1) # incr. in bytes 100011 01001 01000 0000 0100 1011 0000 opcode $t1 $t0 1200 ``` sw\$t0, 1200 (\$t1) # incr. in bytes 101011 01001 01000 0000 0100 1011 0000 opcode \$t1 \$t0 1200 # Datapath for lw Instruction ### Datapath for sw Instruction # Branch Instruction (I-Type) • beq \$s1, \$s2, 25 # if $$$s1 = $s2$$ , advance PC through instructions 25 16-bits 000100 10001 10010 0000 0000 0001 1001 Note: Can branch within ± 2<sup>15</sup> words from the current instruction address in PC. # Datapath for beg Instruction # J-Type Instruction • j 2500 # jump to instruction 2,500 000010 0000 0000 0000 0010 0111 0001 00 opcode 2,500 32-bit jump address 0000 0000 0000 0000 0010 0111 0001 0000 bits 28-31 from PC+4 # Datapath for Jump Instruction # **Control Logic** # Control Logic: Truth Table | | Inputs: instr. opcode bits | | | | | | Outputs: control signals | | | | | | | | | | |---------------|----------------------------|----|----|----|----|----|--------------------------|------|--------|----------|----------|---------|----------|--------|--------|--------| | Instr<br>type | 31 | 30 | 29 | 28 | 27 | 26 | RegDst | Jump | ALUSrc | MemtoReg | RegWrite | MemRead | MemWrite | Branch | ALOOp1 | ALUOp2 | | R | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | | lw | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | | SW | 1 | 0 | 1 | 0 | 1 | 1 | X | 0 | 1 | X | 0 | 0 | 1 | 0 | 0 | 0 | | beq | 0 | 0 | 0 | 1 | 0 | 0 | X | 0 | 0 | X | 0 | 0 | 0 | 1 | 0 | 1 | | j | 0 | 0 | 0 | 0 | 1 | 0 | X | 1 | X | X | X | X | X | X | X | X | # How Long Does It Take? - Assume control logic is fast and does not affect the critical timing. Major time delay components are ALU, memory read/write, and register read/write. - Arithmetic-type (R-type) | <ul><li>Fetch (memory read)</li></ul> | 2ns | |---------------------------------------|-----| |---------------------------------------|-----| Register read1ns ALU operation2ns Register write1ns Total6ns # Time for Iw and sw (I-Types) • ALU (R-type) 6ns Load word (I-type) Fetch (memory read)2ns Register read1ns ALU operation2ns Get data (mem. Read)2ns Register write1ns Total8ns Store word (no register write) 7ns # Time for beq (I-Type) ALU (R-type)6ns Load word (I-type)8ns Store word (I-type)7ns Branch on equal (I-type) Fetch (memory read)2ns Register read1ns ALU operation2ns Total5ns # Time for Jump (J-Type) ALU (R-type)6ns Load word (I-type)8ns Store word (I-type)7ns Branch on equal (I-type) Jump (J-type) Fetch (memory read)2ns Total #### How Fast Can the Clock Be? - If every instruction is executed in one clock cycle, then: - Clock period must be at least 8ns to perform the longest instruction, i.e., lw. - This is a single cycle machine. - It is slower because many instructions take less than 8ns but are still allowed that much time. - Method of speeding up: Use multicycle datapath. # Thank You