190 likes | 206 Views
Lecture 2.5. Instructions: Branch and Jump Instructions. Learning Objectives. Understand that instruction label cannot be presented in binary representation directly Understand that the offset (in branch ) and the address (in jump ) have the unit of word
E N D
Lecture 2.5 Instructions: Branch and Jump Instructions
Learning Objectives • Understand that instruction label cannot be presented in binary representation directly • Understand that the offset (in branch) and the address (in jump) have the unit of word • Use the address of the next instruction as the base address • Covertbranch and jump instructions between assembly statements and binary representations • Useslt instruction with beq/bne to implement more complicated branch conditions Chapter 2 — Instructions: Language of the Computer — 2
Coverage • Textbook Chapter 2.7 Chapter 2 — Instructions: Language of the Computer — 3
op rs rt Offset 6 bits 5 bits 5 bits 16 bits Control Flow Instructions • Branch to a labeled instruction if a condition is true • Otherwise, continue sequentially • beq $rs, $rt, L1 • if (rs == rt) branch to instruction labeled L1; • bne $rs, $rt, L1 • if (rs != rt) branch to instruction labeled L1; • Instruction Format (I format) §2.7 Instructions for Making Decisions Chapter 2 — Instructions: Language of the Computer — 4
Compiling If Statements • C code: if (i==j) f = g+h;else f = g-h; • f,g,h,i,j in $s0,$s1,$s2,$s3,$s4 • Compiled MIPS code: bne $s3, $s4, Else add $s0, $s1, $s2 j ExitElse: sub $s0, $s1, $s2Exit: … Assembler calculates addresses Chapter 2 — Instructions: Language of the Computer — 5
Compiling If Statements • C code: if (i==j) f = g+h;else f = g-h; • f,g,h,i,j in $s0,$s1,$s2,$s3,$s4 • Compiled MIPS code: beq $s3, $s4, If sub $s0, $s1, $s2 j ExitIf: add $s0, $s1, $s2Exit: … Assembler calculates addresses Chapter 2 — Instructions: Language of the Computer — 6
op rs rt Offset 6 bits 5 bits 5 bits 16 bits Control Flow Instructions • Branch to a labeled instruction if a condition is true • Otherwise, continue sequentially • beq $rs, $rt, L1 • bne $rs, $rt, L1 • Instruction Format (I format) • How to specify the branch destination address? §2.7 Instructions for Making Decisions Chapter 2 — Instructions: Language of the Computer — 7
Specifying Branch Destinations • Use a base address (like in lw) added to the 16-bit offset • Which register? Instruction Address Register (Program Counter) • Its use is automatically implied by instructions • PC gets updated (PC+4) during the fetch stage so that it holds the address of the next instruction • Instruction address is always the multiple of 4. The unit of the offset is word • Limit the branch distance to -215to+215-1 (word) instructions from the instruction after the branch instruction Chapter 2 — Instructions: Language of the Computer — 8
Calculate Branch Destination Address • Target address = Base address + Offset × 4 • Offset = (Target address – Base address) / 4 = Address difference / 4 • Target address: the address of the labelled instruction • Base address: the address of the instruction following the branch instruction Chapter 2 — Instructions: Language of the Computer — 9
Compiling Loop Statements • C code: while (save[i] == k) i += 1; • i in $s3, k in $s5, address of save[] in $s6 • All items in save[] are 32-bit words • Compiled MIPS code: Loop: sll $t1, $s3, 2 add $t1, $t1, $s6 lw $t0, 0($t1) bne $t0, $s5, Exit addi $s3, $s3, 1 j LoopExit: … Chapter 2 — Instructions: Language of the Computer — 10
Branch Instruction Design • Why not blt, bge, etc? • Hardware for <, ≥, … slower than =, ≠ • Combining comparisons such as “<” with branch involves more work for a branch instruction, requiring a slower clock • All instructions are penalized! • beq and bne are the common and fast cases • This is a good design compromise Chapter 2 — Instructions: Language of the Computer — 11
In Support of Branch Instructions • We have beq, bne, but what about other kinds of branches (e.g., branch-if-less-than)? • Set on less than instruction: • slt $rd, $rs, $rt • if (rs < rt) rd = 1; else rd = 0; • Instruction format: R format • Alternate versions of slt • sltu $rd, $rs, $rt • slti $rt, $rs, Imm # SignExt • sltiu $rt, $rs, Imm # SignExt Chapter 2 — Instructions: Language of the Computer — 12
Signed vs. Unsigned • Signed comparison: slt, slti • Unsigned comparison: sltu, sltui • Example • $s0 = 1111 1111 1111 1111 1111 1111 1111 1111 • $s1 = 0000 0000 0000 0000 0000 0000 0000 0001 • slt $t0, $s0, $s1 # signed • –1 < +1 $t0 = 1 • sltu $t0, $s0, $s1 # unsigned • +4,294,967,295 > +1 $t0 = 0 Chapter 2 — Instructions: Language of the Computer — 13
Pseudo Branch Instructions • Can use slt, beq, bne, and the register $zero to create other conditions • less than blt $s1, $s2, Label • less than or equal to ble $s1, $s2, Label • greater than bgt $s1, $s2, Label • greater than or equal to bge $s1, $s2, Label • Such branches are included in the instruction set as pseudo instructions - recognized and expanded by the assembler • Assembler needs a reserved register ($at) slt $at, $s1, $s2 #$at set to 1 if bne $at, $zero, Label #$s1 < $s2 Chapter 2 — Instructions: Language of the Computer — 14
op address 26 bits 6 bits Unconditional Jump • Jump (j) targets could be anywhere in text segment within 256 (i.e., 228) MB • Encode full address in instruction • Instruction format: J format • (Pseudo)Direct jump addressing • Target address = (PC+4)31…28:(address×4) • address×4 = (Target address)27…0 • PC is the address of the jump instruction Chapter 2 — Instructions: Language of the Computer — 15
from the low order 26 bits of the jump instruction 26 00 32 4 PC+4 32 Form the target address • Where the 4 bits come from? • The upper 4 bits of the address of the instruction following the Jump instruction Chapter 2 — Instructions: Language of the Computer — 16
Target Addressing Example • Loop code from earlier example • Assume Loop at location 80000 Chapter 2 — Instructions: Language of the Computer — 17
Target Addressing Example • Loop code from earlier example • Assume Loop at location 80000 Chapter 2 — Instructions: Language of the Computer — 18
Branching Far Away • If branch target is too far to encode with 16-bit offset, assembler rewrites the code • Example beq $s0,$s1, L1 L2: … ↓ bne $s0,$s1, L2 j L1L2: … Chapter 2 — Instructions: Language of the Computer — 19