CPE 232 MIPS Arithmetic1 CPE 232 Computer Organization MIPS Arithmetic – Part I Dr. Gheith Abandah [Adapted from the slides of Professor Mary Irwin ( which in turn Adapted from Computer Organization and Design, Patterson & Hennessy, © 2005, UCB]
CPE 232 MIPS Arithmetic2 32-bit signed numbers (2’s complement): two = 0 ten two = + 1 ten two = + 2,147,483,646 ten two = + 2,147,483,647 ten two = – 2,147,483,648 ten two = – 2,147,483,647 ten two = – 2 ten two = – 1 ten MIPS Number Representations maxint minint Converting <32-bit values into 32-bit values copy the most significant bit (the sign bit) into the “empty” bits > > sign extend versus zero extend ( lb vs. lbu ) MSB LSB
CPE 232 MIPS Arithmetic3 MIPS Arithmetic Logic Unit (ALU) Must support the Arithmetic/Logic operations of the ISA add, addi, addiu, addu sub, subu, neg mult, multu, div, divu sqrt and, andi, nor, or, ori, xor, xori beq, bne, slt, slti, sltiu, sltu 32 m (operation) result A B ALU 4 zeroovf 1 1 With special handling for sign extend – addi, addiu andi, ori, xori, slti, sltiu zero extend – lbu, addiu, sltiu no overflow detected – addu, addiu, subu, multu, divu, sltiu, sltu
CPE 232 MIPS Arithmetic4 Review: 2’s Complement Binary Representation 2’sc binarydecimal = -( ) = -2 3 = 1010 complement all the bits 1011 and add a 1 Note: negate and invert are different! Negate
CPE 232 MIPS Arithmetic5 Binary Addition
CPE 232 MIPS Arithmetic6 Review: A Full Adder 1-bit Full Adder A B S carry_in carry_out S = A B carry_in (odd parity function) carry_out = A&B | A&carry_in | B&carry_in (majority function) How can we use it to build a 32-bit adder? How can we modify it easily to build an adder/subtractor? ABcarry_incarry_outS
CPE 232 MIPS Arithmetic7 A 32-bit Ripple Carry Adder/Subtractor Remember 2’s complement is just complement all the bits add a 1 in the least significant bit A 0111 0111 B + 1-bit FA S0S0 c 0 =carry_in c1c1 1-bit FA S1S1 c2c2 S2S2 c3c3 c 32 =carry_out 1-bit FA S 31 c A0A0 A1A1 A2A2 A 31 B0B0 B1B1 B2B2 B 31 add/sub B0B0 control (0=add,1=sub) B 0 if control = 0, !B 0 if control =
CPE 232 MIPS Arithmetic8 Overflow Detection Overflow: the result is too large to represent in 32 bits Overflow occurs when l adding two positives yields a negative l or, adding two negatives gives a positive l or, subtract a negative from a positive gives a negative l or, subtract a positive from a negative gives a positive On your own: Prove you can detect overflow by: l Carry into MSB xor Carry out of MSB, ex for 4 bit signed numbers – –4 –
CPE 232 MIPS Arithmetic9 Need to support the logic operations ( and,nor,or,xor ) l Bit wise operations (no carry operation involved) l Need a logic gate for each function, mux to choose the output Need to support the set-on-less-than instruction ( slt ) l Use subtraction to determine if (a – b) < 0 (implies a < b) l Copy the sign bit into the low order bit of the result, set remaining result bits to 0 Need to support test for equality ( bne, beq ) l Again use subtraction: (a - b) = 0 implies a = b l Additional logic to “nor” all result bits together Immediates are sign extended outside the ALU with wiring (i.e., no logic needed) Tailoring the ALU to the MIPS ISA
CPE 232 MIPS Arithmetic10 MIPS ALU Least-significant bits FunctionBnegateOperation and000 or001 add010 sub110 slt111
CPE 232 MIPS Arithmetic11 MIPS ALU Most-significant bit FunctionBnegateOperation and000 or001 add010 sub110 slt111
CPE 232 MIPS Arithmetic12 MIPS ALU
CPE 232 MIPS Arithmetic13 Improving Addition Performance The ripple-carry adder is slow
CPE 232 MIPS Arithmetic14 Carry-Lookahead Adder Need fast way to find the carry
CPE 232 MIPS Arithmetic15 Carry-Lookahead Adder Carry generate and carry propagate g i = a i. b i p i = a i + b i aiai bibi gigi pipi
CPE 232 MIPS Arithmetic16 Carry-Lookahead Adder Carry Equations: c1 = g0 + p0c0 c2 = g1 + p1c1 = g1 + p1g0 + p1p0c0 c3 = g2 + p2c2 = g2 + p2g1 + p2p1g0 + p2p1p0c0 c4 = g3 + p3c3 = g3 + p3g2 + p3p2g1 + p3p2p1g0 + p3p2p1p0c0
CPE 232 MIPS Arithmetic17 4-bit Carry-Lookahead Adder
CPE 232 MIPS Arithmetic18 Larger Carry-Lookahead Adders P = p0p1p2p3 G = g3 + g2p3 + g1p2p3 + g0p1p2p3