## CSEE W3827

# Fundamentals of Computer Systems <br> Homework Assignment 3 <br> Solutions 

Prof. Stephen A. Edwards<br>Columbia University<br>Due October 18th, 2011 at 10:35 AM

Show your work for each problem; we are more interested in how you get the answer than whether you get the right answer.

1. (10 pts.) The circuit below is called a linear-feedback shift register. Draw a bubble-and-arc diagram representing its behavior. Start from both the state $X=1, Y=0, Z=0$ and the all-zeros state.

2. (15 pts.) The 1965 Ford Thunderbird had sequential turn signals that would light sequentially. Design an FSM that implements such signals.


Your machine has three inputs: LEFT, RIGHT, and HAZARD, and six light outputs, LA, LB, LC, RA, RB, and RC.
When HAZARD is active, your machine should alternate between all lights on and all lights off.
Otherwise, when LEFT is active, LA, then LA and LB, then all the L's should light, then all turn off, then repeat. RIGHT should do the same thing for the R outputs. Assume LEFT and RIGHT are mutually exclusive.
(a) Draw a Moore-style bubble-and-arc diagram for your machine.
(b) Draw a transition table for your machine with symbolic state names.
(c) Draw an output table for your machine expressing the L's and the R's in terms of your states.

3. (20 pts.) Design a circuit for part of an HTML parser that signals when an ASCII character "H" (01001000 in binary) has arrived on a serial link. The rising edge of the clock indicates when the next bit is present on the input. Between bytes, the input stays high and the clock continues running. A byte starts with a single 0 start bit followed by the bits, LSB first, followed by a single 1 stop bit. The next byte could start immediately after the stop bit, or after an arbitrary number of 1 's.


One or more cycles
Assume the data stream starts in the idle state (i.e., not in the middle of a byte), then start looking for a start bit followed by the bit pattern, followed by a stop bit. Make sure your machine stays synchronized, i.e., so it will not erroneously report an H that crosses a stop/start bit boundary.
Consider modifying a shift register for part of your circuit.


Trick: use the start bit to indicate when a complete byte has passed

| State | Comment |
| :---: | :--- |
| 1111111111 | Reset state |
| 0111111111 | Start bit received |
| 00111111111 | 0 (LSB) |
| 0001111111 | 0 |
| 0000111111 | 0 |
| 1000011111 | 1 |
| 0100001111 | 0 |
| 0010000111 | 0 |
| 1001000011 | 1 |
| 0100100001 | 0 (MSB) |
| 1010010000 | Stop bit: check inner 8 and reset |
| 0111111111 | Start bit received |



Needs to reset in the all-1's state.

Moore Machine


| $\mathbf{S}$ | $\mathbf{X Y} \mathbf{~ c c c}$ |
| ---: | :--- |
| 0 | $00---$ |
| 1 | 01000 |
| 2 | 01001 |
| 3 | 01010 |
| $\vdots$ | $\vdots$ |
| 8 | 01111 |
| 9 | $10---$ |
| 10 | 11001 |
| 11 | 11010 |
| $\vdots$ | $\vdots$ |
| 16 | 11111 |
| 17 | 11000 |


| $\mathbf{S}$ | $\mathbf{D}$ | $\mathbf{S}^{\prime}$ |
| ---: | ---: | ---: |
| 0 | 0 | 1 |
| 0 | 1 | 0 |
| 1 | 0 | 2 |
| 1 | 1 | 10 |
| 2 | 0 | 3 |
| 2 | 1 | 11 |
| 3 | 0 | 4 |
| 3 | 1 | 12 |
| 4 | 0 | 13 |
| 4 | 1 | 5 |
| 5 | 0 | 6 |
| 5 | 1 | 14 |
| 6 | 0 | 7 |
| 6 | 1 | 15 |
| 7 | 0 | 16 |
| 7 | 1 | 8 |
| 8 | 0 | 9 |
| 8 | 1 | 17 |
| 9 | - | 0 |
| 10 | - | 11 |
| 11 | - | 12 |
| 12 | - | 13 |
| 13 | - | 14 |
| 14 | - | 15 |
| 15 | - | 16 |
| 16 | - | 17 |
| 17 | - | 0 |



Mealy Machine

$D / \bar{D}$


$$
\begin{aligned}
Y= & \bar{D} \overline{Q_{3}} Q_{2} Q_{1} Q_{0} \\
D_{3}= & Q_{3}\left(D+Q_{2}+\overline{Q_{1}}+\overline{Q_{1}}+\overline{Q_{0}}\right)+\overline{Q_{3} Q_{2} Q_{1} Q_{0}+} \\
& \bar{D}\left(\overline{Q_{3}} \overline{Q_{2}} \overline{Q_{1}} \overline{Q_{0}}+\overline{Q_{3}} \overline{Q_{2}} \overline{Q_{1}} Q_{0}+\overline{Q_{3}} \overline{Q_{2}} Q_{1} \overline{Q_{0}}+\overline{Q_{3}} Q_{2} \overline{Q_{1}} \overline{Q_{0}}+\overline{Q_{3}} Q_{2} \overline{Q_{1}} Q_{0}\right)+ \\
= & Q_{3}\left(D+Q_{2}+Q_{1}+\overline{Q_{3}} Q_{2} Q_{1} \overline{Q_{0}}\right) \\
& D\left(\overline{Q_{2}}+\overline{Q_{1}}+\overline{Q_{2}} Q_{1} \overline{Q_{0}}+Q_{2} \overline{Q_{2} Q_{1} Q_{0}+}+\overline{Q_{1}}\right)+\overline{Q_{1}}\left(\overline{Q_{2}} Q_{0}+Q_{2} \overline{Q_{0}}\right) \\
D_{2}= & Q_{2} \oplus\left(Q_{1} Q_{0}\right) \\
D_{1}= & Q_{1} \oplus Q_{0} \\
D_{0}= & Q_{0}\left(\overline{Q_{3}}+Q_{2}+Q_{1}\right)
\end{aligned}
$$

(30 pts.) Design a synchronous 7-bit counter that counts 0-59 in BCD, i.e., the seconds digits of a "binary clock." There are seven outputs, $Q_{1}, Q_{2}, Q_{4}, Q_{8}, Q_{10}, Q_{20}$, and $Q_{40}$, each driven by a $D$ flip-flop.
(a) Write Boolean expressions of the form $D_{i}=Q_{i} \oplus(\cdots)$ for each flip-flop's input. ( $\oplus$ is XOR)

$$
\begin{aligned}
D_{1} & =\overline{Q_{1}} \\
D_{2} & =Q_{2} \oplus\left(\overline{Q_{8}} Q_{1}\right) \\
D_{4} & =Q_{4} \oplus\left(Q_{2} Q_{1}\right) \\
D_{8} & =Q_{8} \oplus\left(Q_{4} Q_{2} Q_{1}+Q_{8} Q_{1}\right) \\
D_{10} & =Q_{10} \oplus\left(Q_{8} Q_{1}\right) \\
D_{20} & =Q_{20} \oplus\left(\overline{Q_{40}} Q_{10} Q_{8} Q_{1}\right) \\
D_{40} & =Q_{40} \oplus\left(\left(Q_{40}+Q_{20}\right) Q_{10} Q_{8} Q_{1}\right)
\end{aligned}
$$

(b) Write a small program to test your expressions and attach both it and its output. I wrote a C program like the one below, but you may use any language.
\#include <stdio.h>

```
int main()
{
    int i, q1, q2, q4, q8, q10, q20, q40,
                d1, d2, d4, d8, d10, d20, d40;
    q1 = q2 = q4 = q8 = q10 = q20 = q40 = 0;
    for (i = 0 ; i < 121 ; ++i) {
        printf("%2d %C%C%c %C%C%C%C\n", i, ... );
        d1 = ~q1;
        d2 = q2 ^ (q1 & ~q8);
        d4 = q4 ^ (q1 & q2);
        d8 = q8 ^ (q4 & q2 & q1 | q8 & q1);
        d10 = q10 ^ (q8 & q1);
        d20 = q20 ^ (q10 & ~q40 & q8 & q1);
        d40 = q40 ^ ((q20 | q40) & q10 & q8 & q1);
        q1 = d1; q2 = d2; q4 = d4;
        q8 = d8; q10 = d10; q20 = d20;
        q40 = d40;
    }
    return 0;
}
```

The output:
00000000
10000001
20000010
30000011
40000100
50000101
60000110
70000111
80001000
90001001
100010000
190011001
200100000
591011001
600000000
5. (10 pts.)
(a) Write a Boolean expression for the function of the following static CMOS gate.

(b) Draw the schematic for a static CMOS gate that implements $Y=\overline{(A B+C) D}$
6. (15 pts.) Show how to implement a full adder using the following PLA. The inputs should be $A, B$, and $C_{i}$ and the outputs $S$ and $C_{o}$ Hint: write the functions for the sum and carry in sum-of-products form then draw crosses to indicate connections on the AND plane.

$S=A \oplus B \oplus C_{i}=A \bar{B} \overline{C_{i}}+\bar{A} B \overline{C_{i}}+\bar{A} \bar{B} C_{i}+A B C_{i}$
$C_{o}=A B+A C_{i}+B C_{i}$

