Presentation is loading. Please wait.

Presentation is loading. Please wait.

Computer Arthmetic Chapter Four P&H. Data Representation Why do we not encode numbers as strings of ASCII digits inside computers? What is overflow when.

Similar presentations


Presentation on theme: "Computer Arthmetic Chapter Four P&H. Data Representation Why do we not encode numbers as strings of ASCII digits inside computers? What is overflow when."— Presentation transcript:

1 Computer Arthmetic Chapter Four P&H

2 Data Representation Why do we not encode numbers as strings of ASCII digits inside computers? What is overflow when applied to binary operations on data Why do we not use signed magnitude to represent numbers inside computers? What is the two’s compliment number representation? How is a twos compliment number sign extended? Why does MIPs have: lb and lbi instructions slt and slti instructions

3 Addition and Subtraction No overflow possible when: Adding numbers with different signs Subtracting numbers with same sign one of numbers is zero Overflow occurs when: Adding two numbers with same sign and sign of result is different Subtracting numbers with different signs & result is the same sign as second number MIPs handles overflow with an exception

4 MIPs ALU Design MIPS ALU requirements Add, AddU, Sub, SubU, AddI, AddIU => 2’s complement adder/sub with overflow detection And, Or, AndI, OrI, Xor, Xori, Nor => Logical AND, logical OR, XOR, nor SLTI, SLTIU (set less than) => 2’s complement adder with inverter, check sign bit of result

5 Not easy to decide the “best” way to build something Don't want too many inputs to a single gate Don’t want to have to go through too many gates for our purposes, ease of comprehension is important Let's look at a 1-bit ALU for addition: How could we build a 1-bit ALU for add, and, and or? How could we build a 32-bit ALU? Different Implementations c out = a b + a c in + b c in sum = a xor b xor c in

6 Building a 32 bit ALU

7 Two's complement approach: just negate b and add. How do we negate? A very clever solution: What about subtraction (a – b) ?

8 Need to support the set-on-less-than instruction (slt) remember: slt is an arithmetic instruction produces a 1 if rs < rt and 0 otherwise use subtraction: (a-b) < 0 implies a < b Need to support test for equality (beq $t5, $t6, $t7) use subtraction: (a-b) = 0 implies a = b Tailoring the ALU to the MIPS

9 Supporting slt

10

11 Test for equality Notice control lines: 000 = and 001 = or 010 = add 110 = subtract 111 = slt Note: zero is a 1 when the result is zero!

12 Addition Ripple adders are slow What about sum-of products representation? c 1 = b 0 c 0 + a 0 c 0 + a 0 b 0 c 2 = b 1 c 1 + a 1 c 1 + a 1 b 1 c 2 = c 3 = b 2 c 2 + a 2 c 2 + a 2 b 2 c 3 = c 4 = b 3 c 3 + a 3 c 3 + a 3 b 3 c 4 =

13 Carry Lookahead Adder An approach in-between our two extremes Motivation: If we didn't know the value of carry-in, what could we do? When would we always generate a carry? g i = a i b i When would we propagate the carry? p i = a i + b i c 1 = g 0 + p 0 c 0 c 2 = g 1 + p 1 c 1 c 2 = c 3 = g 2 + p 2 c 2 c 3 = c 4 = g 3 + p 3 c 3 c 4 =

14 Carry Lookahead Adder

15 Conclusion We can build an ALU to support the MIPS instruction set key idea: use multiplexer to select the output we want we can efficiently perform subtraction using two’s complement we can replicate a 1-bit ALU to produce a 32-bit ALU Important points about hardware all of the gates are always working the speed of a gate is affected by the number of inputs to the gate the speed of a circuit is affected by the number of gates in series (on the “critical path” or the “deepest level of logic”) Our primary focus: comprehension, however, Clever changes to organization can improve performance (similar to using better algorithms in software) we’ll look at two examples for addition and multiplication

16


Download ppt "Computer Arthmetic Chapter Four P&H. Data Representation Why do we not encode numbers as strings of ASCII digits inside computers? What is overflow when."

Similar presentations


Ads by Google