### Combinational logic design case studies

- General design procedure
- Case studies
  - BCD to 7-segment display controller
  - logical function unit
  - process line controller
  - calendar subsystem
- Arithmetic circuits
  - integer representations
  - addition/subtraction
  - arithmetic/logic units

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

.

# General design procedure for combinational logic

- 1. Understand the problem
  - what is the circuit supposed to do?
  - write down inputs (data, control) and outputs
  - draw block diagram or other picture
- 2. Formulate the problem using a suitable design representation
  - truth table or waveform diagram are typical
  - may require encoding of symbolic inputs and outputs
- 3. Choose implementation target
  - ROM, PAL, PLA
  - mux, decoder and OR-gate
  - discrete gates
- 4. Follow implementation procedure
  - K-maps for two-level, multi-level
  - design tools and hardware description language (e.g., Verilog)

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

# BCD to 7-segment display controller

- Understanding the problem
  - □ input is a 4 bit bcd digit (A, B, C, D)
  - output is the control signals for the display (7 outputs C0 – C6)
- Block diagram



Autumn 2003

CSE370 - V - Combinational Logic Case Studies

#### Formalize the problem

- Truth table
  - show don't cares
- Choose implementation target
  - if ROM, we are done
  - don't cares imply PAL/PLA may be attractive
- Follow implementation procedure
  - minimization using K-maps

| Α | В | С | D | C0 | C1 | C2 | C3 | C4 | C5 | C6 |
|---|---|---|---|----|----|----|----|----|----|----|
| 0 | 0 | 0 | 0 | 1  | 1  | 1  | 1  | 1  | 1  | 0  |
| 0 | 0 | 0 | 1 | 0  | 1  | 1  | 0  | 0  | 0  | 0  |
| 0 | 0 | 1 | 0 | 1  | 1  | 0  | 1  | 1  | 0  | 1  |
| 0 | 0 | 1 | 1 | 1  | 1  | 1  | 1  | 0  | 0  | 1  |
| 0 | 1 | 0 | 0 | 0  | 1  | 1  | 0  | 0  | 1  | 1  |
| 0 | 1 | 0 | 1 | 1  | 0  | 1  | 1  | 0  | 1  | 1  |
| 0 | 1 | 1 | 0 | 1  | 0  | 1  | 1  | 1  | 1  | 1  |
| 0 | 1 | 1 | 1 | 1  | 1  | 1  | 0  | 0  | 0  | 0  |
| 1 | 0 | 0 | 0 | 1  | 1  | 1  | 1  | 1  | 1  | 1  |
| 1 | 0 | 0 | 1 | 1  | 1  | 1  | 0  | 0  | 1  | 1  |
| 1 | 0 | 1 | - | -  | -  | -  | -  | -  | -  | -  |
| 1 | 1 | _ | - | -  | -  | -  | -  | -  | -  | -  |
|   |   |   |   |    |    |    |    |    |    |    |

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

#### Implementation as minimized sum-of-products

15 unique product terms when minimized individually



Autumn 2003

CSE370 - V - Combinational Logic Case Studies

Implementation as minimized S-o-P (cont'd)

- Can do better
  - 9 unique product terms (instead of 15)
  - share terms among outputs
  - each output not necessarily in minimized form





Autumn 2003

CSE370 - V - Combinational Logic Case Studies

#### PLA implementation



Autumn 2003

CSE370 - V - Combinational Logic Case Studies

# PAL implementation vs.

## Discrete gate implementation

- Limit of 4 product terms per output
  - decomposition of functions with larger number of terms
  - do not share terms in PAL anyway
     (although there are some with some shared terms)
     C2 = B + C' + D

```
C2 = B' D + B C' D + C' D' + C D + B C D'
```

C2 = B' D + B C' D + C' D' + W need another input and another output W = C D + B C D'

- decompose into multi-level logic (hopefully with CAD support)
  - find common sub-expressions among functions

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

## Logical function unit

- Multi-purpose function block
  - 3 control inputs to specify operation to perform on operands
  - 2 data inputs for operands
  - 1 output of the same bit-width as operands

| C0 C1 C2 Function Comments     |                       |
|--------------------------------|-----------------------|
| 0 0 0 1 always 1               |                       |
| 0 0 1 A + B   logical OR       | alimmutar CO C1 C2    |
| U I U I (A • B) I logical NAND | ol inputs: C0, C1, C2 |
| U I I A XOFB   IOQICAI XOF     | inputs: A, B          |
| 1 0 0 A xnor B logical xnor    | IT: F                 |
| 1 0 1 A • B logical AND        |                       |
| 1 1 0 (A + B)' logical NOR     |                       |
| 1 1 1 0 always 0               |                       |

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

9

# 

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

10

C1

#### Production line control

- Rods of varying length (+/-10%) travel on conveyor belt
  - mechanical arm pushes rods within spec (+/-5%) to one side
  - second arm pushes rods too long to other side
  - rods that are too short stay on belt
  - 3 light barriers (light source + photocell) as sensors
  - design combinational logic to activate the arms
- Understanding the problem
  - inputs are three sensors
  - outputs are two arm control signals
  - assume sensor reads "1" when tripped, "0" otherwise
  - call sensors A, B, C

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

11

#### Sketch of problem

- Position of sensors
  - □ A to B distance = specification 5%
  - □ A to C distance = specification + 5%



Autumn 2003

CSE370 - V - Combinational Logic Case Studies

#### Formalize the problem

- Truth table
  - show don't cares

| Α | В | С | Function   |
|---|---|---|------------|
| 0 | 0 | 0 | do nothing |
| 0 | 0 | 1 | do nothing |
| 0 | 1 | 0 | do nothing |
| 0 | 1 | 1 | do nothing |
| 1 | 0 | 0 | too short  |
| 1 | 0 | 1 | don't care |
| 1 | 1 | 0 | in spec    |
| 1 | 1 | 1 | too long   |
|   |   |   |            |

logic implementation now straightforward just use three 3-input AND gates

```
"too short" = AB'C'
(only first sensor tripped)
```

"in spec" = A B C' (first two sensors tripped)

"too long" = A B C
(all three sensors tripped)

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

13

#### Calendar subsystem

- Determine number of days in a month (to control watch display)
  - used in controlling the display of a wrist-watch LCD screen
  - inputs: month, leap year flag
  - outputs: number of days
- Use software implementation to help understand the problem

```
integer number_of_days ( month, leap_year_flag) {
    switch (month) {
        case 1: return (31);
         case 2: if (leap_year_flag == 1)
                    then return (29)
                    else return (28);
         case 3: return (31);
         case 4: return (30);
         case 5: return (31);
         case 6: return (30);
         case 7: return (31);
         case 8: return (31);
         case 9: return (30);
         case 10: return (31);
         case 11: return (30);
         case 12: return (31);
         default: return (0);
```

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

### Formalize the problem

- Encoding:
  - binary number for month: 4 bits
  - 4 wires for 28, 29, 30, and 31
     one-hot only one true at any time
- Block diagram:



| month | leap | 28 | 29 | 30 | 31 |
|-------|------|----|----|----|----|
| 0000  | - 1  | _  | _  | _  | _  |
| 0001  | -    | 0  | 0  | 0  | 1  |
| 0010  | 0    | 1  | 0  | 0  | 0  |
| 0010  | 1    | 0  | 1  | 0  | 0  |
| 0011  | -    | 0  | 0  | 0  | 1  |
| 0100  | -    | 0  | 0  | 1  | 0  |
| 0101  | -    | 0  | 0  | 0  | 1  |
| 0110  | -    | 0  | 0  | 1  | 0  |
| 0111  | -    | 0  | 0  | 0  | 1  |
| 1000  | -    | 0  | 0  | 0  | 1  |
| 1001  | -    | 0  | 0  | 1  | 0  |
| 1010  | -    | 0  | 0  | 0  | 1  |
| 1011  | -    | 0  | 0  | 1  | 0  |
| 1100  | -    | 0  | 0  | 0  | 1  |
| 1101  | -    | _  | -  | -  | _  |
| 111-  | -    | _  | _  | _  | -  |
|       |      |    |    |    |    |

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

15

16

# Choose implementation target and perform mapping

- Discrete gates
  - 28 = m8' m4' m2 m1' leap'
  - □ 29 = m8′ m4′ m2 m1′ leap
  - □ 30 = m8′ m4 m1′ + m8 m1
  - □ 31 = m8′ m1 + m8 m1′
- Can translate to S-o-P or P-o-S

| month | leap | 28 | 29 | 30 | 31 |
|-------|------|----|----|----|----|
| 0000  | _ `  | _  | _  | _  | _  |
| 0001  | - 1  | 0  | 0  | 0  | 1  |
| 0010  | 0    | 1  | 0  | 0  | 0  |
| 0010  | 1    | 0  | 1  | 0  | 0  |
| 0011  | -    | 0  | 0  | 0  | 1  |
| 0100  | -    | 0  | 0  | 1  | 0  |
| 0101  | -    | 0  | 0  | 0  | 1  |
| 0110  | -    | 0  | 0  | 1  | 0  |
| 0111  | -    | 0  | 0  | 0  | 1  |
| 1000  | -    | 0  | 0  | 0  | 1  |
| 1001  | -    | 0  | 0  | 1  | 0  |
| 1010  | -    | 0  | 0  | 0  | 1  |
| 1011  | -    | 0  | 0  | 1  | 0  |
| 1100  | -    | 0  | 0  | 0  | 1  |
| 1101  | -    | _  | _  | _  | -  |
| 111-  | -    | _  | -  | _  | -  |

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

#### Leap year flag

- Determine value of leap year flag given the year
  - For years after 1582 (Gregorian calendar reformation),
  - leap years are all the years divisible by 4,
  - except that years divisible by 100 are not leap years,
  - but years divisible by 400 are leap years.
- Encoding the year:
  - binary easy for divisible by 4,
     but difficult for 100 and 400 (not powers of 2)
  - BCD easy for 100, but more difficult for 4, what about 400?
- Parts:
  - construct a circuit that determines if the year is divisible by 4
  - construct a circuit that determines if the year is divisible by 100
  - construct a circuit that determines if the year is divisible by 400
  - combine the results of the previous three steps to yield the leap year flag

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

17

## Activity: divisible-by-4 circuit

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

### Divisible-by-100 and divisible-by-400 circuits

Divisible-by-100 just requires checking that all bits of two low-order digits are all 0:

```
YT8' YT4' YT2' YT1' • YO8' YO4' YO2' YO1'
```

 Divisible-by-400 combines the divisible-by-4 (applied to the thousands and hundreds digits) and divisible-by-100 circuits

```
(YM1' YH2' YH1' + YM1 YH2 YH1')
• (YT8' YT4' YT2' YT1' • YO8' YO4' YO2' YO1' )
```

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

19

# Combining to determine leap year flag

Label results of previous three circuits: D4, D100, and D400

```
leap_year_flag = D4 (D100 • D400') '
= D4 • D100' + D4 • D400
= D4 • D100' + D400
```

Autumn 2003

CSE370 - V - Combinational Logic Case Studies



### Arithmetic circuits

- Excellent examples of combinational logic design
- Time vs. space trade-offs
  - doing things fast may require more logic and thus more space
  - example: carry lookahead logic
- Arithmetic and logic units
  - general-purpose building blocks
  - critical components of processor datapaths
  - used within most computer instructions

#### Number systems

- Representation of positive numbers is the same in most systems
- Major differences are in how negative numbers are represented
- Representation of negative numbers come in three major schemes
  - sign and magnitude
  - 1s complement
  - 2s complement
- Assumptions
  - we'll assume a 4 bit machine word
  - 16 different values can be represented
  - roughly half are positive, half are negative

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

23

#### Sign and magnitude

- One bit dedicate to sign (positive or negative)
   0 100 = + 4
  - □ sign: 0 = positive (or zero), 1 = negative

 $1\ 100 = -4$ 

- Rest represent the absolute value or magnitude
  - three low order bits: 0 (000) thru 7 (111)
- Range for n bits
  - $\neg$  +/- 2n-1 -1 (two representations for 0)
- Cumbersome addition/subtraction
  - must compare magnitudes to determine sign of result



Autumn 2003

CSE370 - V - Combinational Logic Case Studies

### 1s complement

- If N is a positive number, then the negative of N (its 1s complement or N') is N' = (2n-1) - N
  - example: 1s complement of 7

$$2^{4}$$
 = 10000  
 $1 = 00001$   
 $2^{4}-1 = 1111$   
 $1000 = -7 \text{ in 1s complement form}$ 

shortcut: simply compute bit-wise complement (0111 -> 1000)

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

25

### 1s complement (cont'd)

- Subtraction implemented by 1s complement and then addition
- Two representations of 0
  - causes some complexities in addition
- High-order bit can act as sign bit



+0

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

#### 2s complement

- 1s complement with negative numbers shifted one position clockwise
  - only one representation for 0
  - one more negative number than positive numbers
  - high-order bit can act as sign bit



Autumn 2003

CSE370 - V - Combinational Logic Case Studies

27

#### 2s complement (cont'd)

- If N is a positive number, then the negative of N (its 2s complement or N\*) is N\* = 2n – N
  - example: 2s complement of 7

$$2^4 = 10000$$

subtract 7 = 0111

1001 = repr. of -7

□ example: 2s complement of -7

subtract -7 = 1001

0111 = repr. of 7

- □ shortcut: 2s complement = bit-wise complement + 1
  - 0111 -> 1000 + 1 -> 1001 (representation of -7)
  - 1001 -> 0110 + 1 -> 0111 (representation of 7)

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

#### 2s complement addition and subtraction

- Simple addition and subtraction
  - simple scheme makes 2s complement the virtually unanimous choice for integer number systems in computers

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

20

#### Why can the carry-out be ignored?

- Can't ignore it completely
  - needed to check for overflow (see next two slides)
- When there is no overflow, carry-out may be true but can be ignored

-M + N when N > M:

$$M^* + N = (2n - M) + N = 2n + (N - M)$$

ignoring carry-out is just like subtracting 2n

$$-M + -N$$
 where  $N + M \le 2n-1$ 

$$(-M) + (-N) = M^* + N^* = (2n-M) + (2n-N) = 2n - (M+N) + 2n$$

ignoring the carry, it is just the 2s complement representation for -(M + N)

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

# Overflow in 2s complement addition/subtraction

- Overflow conditions
  - add two positive numbers to get a negative number
  - add two negative numbers to get a positive number





5 + 3 = -8

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

31

-7 - 2 = +7

#### Overflow conditions

Overflow when carry into sign bit position is not equal to carry-out

$$\begin{array}{r}
1 & 0 & 0 & 0 \\
1 & 0 & 0 & 1 \\
1 & 0 & 0 & 1 \\
-7 & & 1 & 1 & 1 & 0 \\
\hline
-7 & & & & & & & & \\
-7 & & & & & & & & \\
\hline
-7 & & & & & & & & \\
-7 & & & & & & & & \\
\hline
-1 & 1 & 1 & 0 & 1 & 1 & 1
\end{array}$$

overflow overflow

no overflow

no overflow

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

### Circuits for binary addition

- Half adder (add 2 1-bit numbers)
  - □ Sum = Ai' Bi + Ai Bi' = Ai xor Bi
  - Cout = Ai Bi
- Full adder (carry-in to cascade for multi-bit adders)
  - □ Sum = Ci xor A xor B
  - □ Cout = B Ci + A Ci + A B = Ci (A + B) + A B

| Ai | Bi | Sum | Cout |
|----|----|-----|------|
| 0  | 0  | 0   | 0    |
| 0  | 1  | 1   | 0    |
| 1  | 0  | 1   | 0    |
| 1  | 1  | 1   | 1    |

| Αi | Bi | Cin | Sum | Cout |
|----|----|-----|-----|------|
| 0  | 0  | 0   | 0   | 0    |
| 0  | 0  | 1   | 1   | 0    |
| 0  | 1  | 0   | 1   | 0    |
| 0  | 1  | 1   | 0   | 1    |
| 1  | 0  | 0   | 1   | 0    |
| 1  | 0  | 1   | 0   | 1    |
| 1  | 1  | 0   | 0   | 1    |
| 1  | 1  | 1   | 1   | 1    |

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

33

### Full adder implementations



- Alternative implementation
- Cout = A B + Cin (A xor B) = A B + B Cin + A Cin

- 5 gates
- half adder is an XOR gate and AND gate
- □ 2 XORs, 2 ANDs, 1 OR



Autumn 2003

CSE370 - V - Combinational Logic Case Studies

### Adder/subtractor

- Use an adder to do subtraction thanks to 2s complement representation
  - $\Box$  A B = A + (-B) = A + B' + 1
  - control signal selects B or 2s complement of B



Ripple-carry adders



the propagation of carry from low to high order stages





0

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

### Ripple-carry adders (cont'd)

- Critical delay
  - the propagation of carry from low to high order stages
  - □ 1111 + 0001 is the worst case addition
  - carry must propagate through all bits



Autumn 2003

CSE370 - V - Combinational Logic Case Studies

37

### Carry-lookahead logic

- Carry generate: Gi = Ai Bi
  - □ must generate carry when A = B = 1
- Carry propagate: Pi = Ai xor Bi
  - carry-in will equal carry-out here
- Sum and Cout can be re-expressed in terms of generate/propagate:
  - □ Si = Ai xor Bi xor Ci
    - = Pi xor Ci
  - □ Ci+1 = Ai Bi + Ai Ci + Bi Ci
    - = Ai Bi + Ci (Ai + Bi)
    - = Ai Bi + Ci (Ai xor Bi)
    - = Gi + Ci Pi

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

### Carry-lookahead logic (cont'd)

- Re-express the carry logic as follows:
  - □ C1 = G0 + P0 C0
  - □ C2 = G1 + P1 C1 = G1 + P1 G0 + P1 P0 C0
  - □ C3 = G2 + P2 C2 = G2 + P2 G1 + P2 P1 G0 + P2 P1 P0 C0
  - □ C4 = G3 + P3 C3 = G3 + P3 G2 + P3 P2 G1 + P3 P2 P1 G0 + P3 P2 P1 P0 C0
- Each of the carry equations can be implemented with two-level logic
  - all inputs are now directly derived from data inputs and not from intermediate carries
  - this allows computation of all sum outputs to proceed in parallel

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

Pi @ 1 gate delay

Si @ 2 gate delays

39

### Carry-lookahead implementation

Adder with propagate and generate outputs



increasingly complex logic for carries

C0
P0
P1
P2
P3
G0
P1
P2
P3
G1
P2
P3
G2
P3
G3
G3
G3

Autumn 2003

Ci

CSE370 - V - Combinational Logic Case Studies

#### Carry-lookahead implementation (cont'd) Carry-lookahead logic generates individual carries sums computed much more quickly in parallel however, cost of carry logic increases with more stages S0 @2 B0 C1 @3 S0 @2 C1 @2 S1 @4 B1 C2 @3 S1 @3 C2 @4 В1 A2 S2 @4 B2 C3 @3 S2 @5 B2-C3 @6 А3 > S3 @4 В3 C4 @3 А3. S3 @7 ➤ C4 @3 Cout @8 CSE370 - V - Combinational Logic Case Studies Autumn 2003 41



### Carry-select adder

- Redundant hardware to make carry calculation go faster
  - compute two high-order sums in parallel while waiting for carry-in
  - one assuming carry-in is 0 and another assuming carry-in is 1
  - select correct result once carry-in is finally computed



Autumn 2003

CSE370 - V - Combinational Logic Case Studies

### Arithmetic logic unit design specification

#### M = 0, logical bitwise operations

| S1 | S0 | Function        | Comment                                |
|----|----|-----------------|----------------------------------------|
| 0  | 0  | Fi = Ai         | input Ai transferred to output         |
| 0  | 1  | Fi = not Ai     | complement of Ai transferred to output |
| 1  | 0  | Fi = Ai xor Bi  | compute XOR of Ai, Bi                  |
| 1  | 1  | Fi = Ai xnor Bi | compute XNOR of Ai, Bi                 |

#### M = 1, C0 = 0, arithmetic operations

| 0 | 0 | F = A              | input A passed to output         |
|---|---|--------------------|----------------------------------|
| 0 | 1 | F = not A          | complement of A passed to output |
| 1 | 0 | F = A plus B       | sum of A and B                   |
| 1 | 1 | F = (not A) plus B | sum of B and complement of A     |

#### M = 1, C0 = 1, arithmetic operations

| 0 | 0 | F = A plus 1              | increment A              |
|---|---|---------------------------|--------------------------|
| 0 | 1 | F = (not A) plus 1        | twos complement of A     |
| 1 | 0 | F = A plus B plus 1       | increment sum of A and B |
| 1 | 1 | F = (not A) plus B plus 1 | B minus A                |

logical and arithmetic operations not all operations appear useful, but "fall out" of internal logic

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

44

## Arithmetic logic unit design (cont'd)

Sample ALU – truth table

| M | S1             | S0 | L Ci                                    | Ai | Bi                                      | L Fi                                    | Ci+1                                                                       |
|---|----------------|----|-----------------------------------------|----|-----------------------------------------|-----------------------------------------|----------------------------------------------------------------------------|
| 0 | <u>S1</u><br>0 | 0  | Ŷ                                       | 0  | X                                       | 0                                       | X                                                                          |
|   | 0              | 1  | l ŝ                                     | ģ  | ŝ                                       | 1                                       | ŝ                                                                          |
|   | 1              | 0  | X                                       | 0  | X<br>0                                  | 0                                       | X                                                                          |
|   |                |    | X                                       | 0  | 1                                       | 1                                       | X                                                                          |
|   |                |    | l ŝ                                     | 1  | ĭ                                       | Ō                                       | ŝ                                                                          |
|   | 1              | 1  | X                                       | 0  | 1                                       | 0                                       | X                                                                          |
|   |                |    | X                                       | 1  | 0                                       | 0                                       | X                                                                          |
| 1 | 0              | 0  | Ô                                       | 0  | Ž,                                      | 0                                       | <del>-</del> X                                                             |
|   | 0              | 1  | Ŏ                                       | ģ  | â                                       | 1                                       | Ŷ                                                                          |
|   | 1              | 0  | 0                                       |    | X<br>0                                  | 0                                       | X<br>0                                                                     |
|   |                |    | 0                                       | 0  | 1                                       | 1                                       | 0                                                                          |
|   |                |    | ŏ                                       | į  | 1                                       | ģ                                       | 1                                                                          |
|   | 1              | 1  | 0                                       | 0  | 1                                       | 0                                       | 1                                                                          |
|   |                |    | 0                                       | 1  | 0                                       | 0                                       | 0                                                                          |
| 1 | 0              | 0  | į                                       | 9  | Ŷ.                                      | 1                                       | 0                                                                          |
|   | 0              | 1  | 1                                       | ō  | â                                       | ő                                       | i                                                                          |
|   | 1              | 0  | 1                                       |    | X<br>0                                  | 1                                       | 0                                                                          |
|   |                | -  | 1                                       | 0  | 1                                       | 0                                       | 1                                                                          |
|   |                |    | 1                                       | 1  | 1                                       | 1                                       | į                                                                          |
|   | 1              | 1  | $\begin{array}{c c} 1 \\ 1 \end{array}$ |    | 1                                       | 1                                       | 1                                                                          |
|   |                |    | XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX  | Ai | XXXX01010101010101010101010101010101010 | E10110001101001001100110011001100110011 | XX<br>XX<br>XX<br>XX<br>XX<br>XX<br>XX<br>XX<br>XX<br>XX<br>XX<br>XX<br>XX |
|   |                |    |                                         |    |                                         |                                         |                                                                            |

Autumn 2003

CSE370 - V - Combinational Logic Case Studies

45

## Arithmetic logic unit design (cont'd)

Sample ALU – multi-level discrete gate logic implementation



Autumn 2003

CSE370 - V - Combinational Logic Case Studies

#### Arithmetic logic unit design (cont'd)

#### Sample ALU – clever multi-level implementation



```
first-level gates
 use S0 to complement Ai
S0 = 0 causes ga
                       causes gate X1 to pass Ai
       S0 = 1
                       causes gate X1 to pass Ai'
  use S1 to block Bi
       S1 = 0
                       causes gate A1 to make Bi go forward as 0
                       (don't want Bi for operations with just A)
       S1 = 1
                       causes gate A1 to pass Bi
  use M to block Ci
                       causes gate A2 to make Ci go forward as 0
       M = 0
                       (don't want Ci for logical operations)
       M = 1
                       causes gate A2 to pass Ci
other gates
 for M=0 (logical operations, Ci is ignored)
 Fi = S1 Bi xor (S0 xor Ai)
= S1'S0' (Ai) + S1'S0 (Ai') +
S1 S0' (Ai Bi' + Ai' Bi) + S1 S0 (Ai' Bi' + Ai Bi)
for M=1 (arithmetic operations)
Fi = S1 Bi xor ((S0 xor Ai) xor Ci) =
Ci+1 = Ci (S0 xor Ai) + S1 Bi ((S0 xor Ai) xor Ci) =
   just a full adder with inputs S0 xor Ai, S1 Bi, and Ci
```

#### Summary for examples of combinational logic

CSE370 - V - Combinational Logic Case Studies

- Combinational logic design process
  - formalize problem: encodings, truth-table, equations
  - choose implementation technology (ROM, PAL, PLA, discrete gates)
  - implement by following the design procedure for that technology
- Binary number representation
  - positive numbers the same
  - difference is in how negative numbers are represented
  - 2s complement easiest to handle: one representation for zero, slightly complicated complementation, simple addition
- Circuits for binary addition
  - basic half-adder and full-adder
  - carry lookahead logic
  - carry-select
- ALU Design
  - specification, implementation

Autumn 2003

CSE370 - V - Combinational Logic Case Studies