# CS 61C <br> <br> Combinational Logic, SDS and <br> <br> Combinational Logic, SDS and FSMs 

 FSMs}

Fall 2023
Discussion 6

## 1 Boolean Logic

In digital electronics, it is often important to get certain outputs based on your inputs, as laid out by a truth table. Truth tables map directly to Boolean expressions, and Boolean expressions map directly to logic gates. However, in order to minimize the number of logic gates needed to implement a circuit, it is often useful to simplify long Boolean expressions.

We can simplify expressions using the nine key laws of Boolean algebra:

| Name | AND Form | OR form |
| :---: | :---: | :---: |
| Commutative | $\mathrm{AB}=\mathrm{BA}$ | $\mathrm{A}+\mathrm{B}=\mathrm{B}+\mathrm{A}$ |
| Associative | $\mathrm{AB}(\mathrm{C})=\mathrm{A}(\mathrm{BC})$ | $\mathrm{A}+(\mathrm{B}+\mathrm{C})=(\mathrm{A}+\mathrm{B})+\mathrm{C}$ |
| Identity | $1 \mathrm{~A}=\mathrm{A}$ | $0+\mathrm{A}=\mathrm{A}$ |
| Null | $0 \mathrm{~A}=0$ | $1+\mathrm{A}=1$ |
| Absorption | $\mathrm{A}(\mathrm{A}+\mathrm{B})=\mathrm{A}$ | $\mathrm{A}+\mathrm{AB}=\mathrm{A}$ |
| Distributive | $(\mathrm{A}+\mathrm{B})(\mathrm{A}+\mathrm{C})=\mathrm{A}+\mathrm{BC}$ | $\mathrm{A}(\mathrm{B}+\mathrm{C})=\mathrm{AB}+\mathrm{AC}$ |
| Idempotent | $\mathrm{A}(\mathrm{A})=\mathrm{A}$ | $\mathrm{A}+\mathrm{A}=\mathrm{A}$ |
| Inverse | $\mathrm{A}(\overline{\mathrm{A}})=0$ | $\mathrm{~A}+\overline{\mathrm{A}}=1$ |
| De Morgan's | $\overline{\mathrm{AB}}=\overline{\mathrm{A}}+\overline{\mathrm{B}}$ | $\overline{\mathrm{A}+\mathrm{B}}=\overline{\mathrm{A}}(\overline{\mathrm{B}})$ |

Simplify the following Boolean expressions:
(a) $(A+B)(A+\bar{B}) C$

$$
\begin{aligned}
(A+B)(A+\bar{B}) C & =(A A+A \bar{B}+B A+B \bar{B}) C \\
& =(A+A(\bar{B}+B)+0) C \\
& =(A+A) C \\
& =A C
\end{aligned}
$$

(b) $\bar{A} \bar{B} \bar{C}+\bar{A} B \bar{C}+A B \bar{C}+A \bar{B} \bar{C}+A B C+A \bar{B} C$

$$
\begin{aligned}
\bar{A} \bar{C}(\bar{B}+B)+A \bar{C}(B+\bar{B})+A C(B+\bar{B}) & =\bar{A} \bar{C}+A \bar{C}+A C \\
& =\bar{A} \bar{C}+A \bar{C}+A \bar{C}+A C \\
& =(\bar{A}+A) \bar{C}+A(\bar{C}+C) \\
& =\bar{C}+A
\end{aligned}
$$

Alternatively, you can prove to yourself that $\mathrm{X}+\bar{X} Y=X+Y . T h e n$,

$$
\begin{aligned}
& \bar{A} \bar{C}+A \bar{C}+A C \\
& =(\bar{A}+A) \bar{C}+A C \\
& =\bar{C}+A C \\
& =\bar{C}+A
\end{aligned}
$$

(c) $\overline{A(\overline{B C}+B C)}$

$$
\begin{aligned}
\overline{A(\bar{B} \bar{C}+B C)} & =\bar{A}+\overline{\bar{B} \bar{C}+B C} \\
& =\bar{A}+(\overline{\bar{B} \bar{C}}) \overline{B C} \\
& =\bar{A}+(B+C)(\bar{B}+\bar{C}) \\
& =\bar{A}+B \bar{C}+\bar{B} C
\end{aligned}
$$

## 2 Combinational Logic Design

Logic gates can be connected together to create a variety of useful functions. In this question, we will implement a simplified version of the memory write mask for the RISC-V CPU. The memory write mask looks at the store instruction given and decides which of the four bytes (in one word of memory) to write to. It is four bits long - each bit is one if we should write to the corresponding byte, but zero if we shouldn't. For simplicity, assume that all memory addresses used in store instruction are word-aligned. Here's a truth table for the simpified memory mask:

| Instruction | funct3 | Out |
| :---: | :---: | :---: |
| sb | 000 | 0001 |
| sh | 001 | 0011 |
| sw | 010 | 1111 |
| (undefined) | $011-111$ | xxxx |

The x's for the final entry of the table indicates that any output is fine in that case.
Write out and simplify boolean expressions for each of the output bits in terms of the funct3 (input) bits $f_{2}, f_{1}, f_{0}$.

We'll work on the bits from right to left. For Out[0], its value is one in all input cases that are defined, so we can just set $\operatorname{Out}[0]=1$.

For the other bits, we can write out the base canonical form first, but then we can bring in any amount of terms from the undefined cases (equivalent to setting this bit to one in that undefined case) to simplify the expression.
$\operatorname{Out}[1]=\overline{f_{2}} \overline{f_{1}} f_{0}+\overline{f_{2}} f_{1} \overline{f_{0}}$ from the cases given. Since all of the cases where $f_{2}=1$ are undefined, we can bring in some of those terms to cancel out the $f_{2}$ 's: Out[1] $=$ $\overline{f_{2}} \overline{f_{1}} f_{0}+f_{2} \overline{f_{1}} f_{0}+\overline{f_{2}} f_{1} \overline{f_{0}}+f_{2} f_{1} \overline{f_{0}}=\overline{f_{1}} f_{0}+f_{1} \overline{f_{0}}$. We can go one step further: the input 011 is also undefined, so if we bring in that term (and the corresponding $f_{2}=1$ term 111), we end up with Out[1] $=\overline{f_{1}} f_{0}+f_{1} \overline{f_{0}}+f_{1} f_{0}=f_{1}+f_{0}$.

Following a similar process, the final two bits simplify to Out[3] $=\operatorname{Out}[2]=f_{1}$.

Draw out the boolean circuit for this memory write mask based on your simplified expressions above. You may use constants 0 and 1, and the logic gates AND, OR, NOT.


## 3 State Intro

There are two basic types of circuits: combinational logic circuits and state elements. Combinational logic circuits simply change based on their inputs after whatever propagation delay is associated with them. For example, if an AND gate (pictured below) has an associated propagation delay of 2 ps , its output will change based on its input as follows:


You should notice that the output of this AND gate always changes 2ps after its inputs change.

State elements, on the other hand, can remember their inputs even after the inputs change. State elements change value based on a clock signal. A rising edge-triggered register, for example, samples its input at the rising edge of the clock (when the clock signal goes from 0 to 1 ).

Like logic gates, registers also have a delay associated with them before their output will reflect the input that was sampled. This is called the clk-to-q delay. ("Q" often indicates output). This is the time between the rising edge of the clock signal and the time the register's output reflects the input change.

The input to the register samples has to be stable for a
 certain amount of time around the rising edge of the clock for the input to be sampled accurately. The amount of time before the rising edge the input must be stable is called the setup time, and the time after the rising edge the input must be stable is called the hold time. Hold time is generally included in clk-to-q delay, so clk-to-q time will usually be greater than or equal to hold time. Logically, the fact that clk-to-q $\geq$ hold time makes sense since it only takes clk-to-q seconds to copy the value over, so there's no need to have the value
fed into the register for any longer.
For the following register circuit, assume setup of 2.5 ps , hold time of 1.5 ps , and a clk-to-q time of 1.5 ps . The clock signal has a period of 13 ps .


You'll notice that the value of the output in the diagram above doesn't change immediately after the rising edge of the clock. Until enough time has passed for the output to reflect the input, the value held by the output is garbage; this is represented by the shaded gray part of the output graph. Clock cycle time must be small enough that inputs to registers don't change within the hold time and large enough to account for clk-to-q times, setup times, and combinational logic delays.
3.1 For the following circuit, fill out the timing diagram. The clock period (rising edge to rising edge) is 8 ps . For every register, clk-to-q delay is 2 ps , setup time is 4 ps , and hold time is 2 ps .


At a rising clock edge, the value that the output of a register will update to is the value of the input of the register sampled at this rising clock edge. However, notice that the output will not update until clk to q after the rising clock edge.

Gray signals:

- the output of a register at the very beginning, before a rising clock edge.
- the input into a register did not satisfy setup or hold times, so the output of the register will be garbage. For example, at the 3rd rising clock edge, "in" changed 2 ps before, violating the setup time of 4 ps . Clk-to-q after this 3rd rising edge, the s 0 is garbage.
- the input into the register was garbage

In the circuit below, RegA and RegB have setup, hold, and clk-to-q times of 4ns,
all logic gates have a delay of 5 ns , and RegC has a setup time of 6 ns . What is the maximum allowable hold time for RegC? What is the minimum acceptable clock cycle time for this circuit, and clock frequency does it correspond to?


Hold time of RegC is the amount of time that the input into RegC must be stable for after a rising clock edge. We need to first consider the input to RegC and how it might change after a rising clock edge. Then, we need to consider the shortest amount of time that it could take for this input to change in order to determine max hold time. Think about why this is the case. What could happen if the hold time of RegC was greater? Again, the time we are considering is after a rising clock edge.

We look at the path of the input coming from a previous register. The input to RegC comes from the output of Reg A and B fed into some combinational logic (the AND and OR gates). How is the input related to a rising clock edge? Because this input signal path is the output of a register ( A and B ), it can be updated clk-to-q after the rising clock edge (taking on the values of the inputs to Reg A and B sampled at this rising clock edge). After this clk-to-q after the rising edge, the signal flows through the CL, and it takes CL delay time to reach RegC. To determine the minimum amount of time after the rising clock edge for the input to RegC to change, we consider the shortest CL path/delay.

Max hold time $\operatorname{Reg} \mathrm{C}=($ clk-to-q of A or B$)+$ shortest CL time $=4+(5+5)=14$ ns.

To determine minimum clock cycle time (time between two rising edges), consider every path between two registers. The clock cycle must be greater than the time for the output of the first register to update after the rising clock edge (clk-to-q delay) plus the longest CL delay of the CL path that this output feeds into. Recall, the output of a CL block updates delay time after its input changes. Then, the signal flowing out of the CL path and into the second register must be stable (or finalized with the correct value) setup time before the next rising clock edge. The minimum clock cycle ensures a register will sample the correct value at a rising clock edge.

Therefore, the minimum acceptable clock cycle time is clk-to-q + longest CL time + setup time. In the circuit above, there is a path between registers $\mathrm{A} / \mathrm{B}$ and C . Min clock cycle $=4+(5+5+5)+6=25 \mathrm{~ns}$.
25 ns corresponds to a clock frequency of $\left(1 /\left(25 * 10^{-9}\right)\right) \mathrm{s}^{-1}=40 \mathrm{MHz}$

Conceptual questions:
3.3 Simplifying boolean logic expressions will not affect the performance of the hardware implementation.
False. Different gate arrangements that implement the same logic can have different propagation delays, which can affect the allowable clock speed.
3.4 The fewer logic gates, the faster the circuit (assuming each gate has the same propagation delays).

False. Propagation delays add to the allowable clock speed with the depth of the circuit, so a wide circuit with more gates in parallel can have less delay than just a few gates arranged in sequence.

## 4 Finite State Machines

Automatons are machines that receive input and use various states to produce output. A finite state machine is a type of simple automaton where the next state and output depend only on the current state and input. Each state is represented by a circle, and every proper finite state machine has a starting state, signified either with the label "Start" or a single arrow leading into it. Each transition between states is labeled [input]/[output].
4.1 What pattern in a bitstring does the FSM below detect? What would it output for the input bitstring " 011001001110 "?


The FSM outputs a 1 if it detects the pattern " 11 ".
The FSM would output " 001000000110 "
Fill in the following FSM for outputting a 1 whenever we have two repeating bits as the most recent bits, and a 0 otherwise. You may not need all states.

4.3 Draw an FSM that will output a 1 if it recognizes the regex pattern $\{10+1\}$. (That is, if the input forms a pattern of a 1 , followed by one or more 0 s, followed by a 1.)


