

Université d'Ottawa  
Faculté de Génie

École de Science Informatique  
et de Génie Électrique



University of Ottawa  
Faculty of Engineering

School of Electrical Engineering  
and Computer Science

uOttawa

L'Université canadienne  
Canada's university

## CEG3155/CEG3555 Digital Systems II

Name (surname, first name): \_\_\_\_\_

Student Number: \_\_\_\_\_

**Examiners:** Professor Miodrag Bolic  
Professor Rami Abielmona

Final Examination: December 10, 2015 (14:00-17:00)      Time allowed: 3 hours

Note:

- This is a closed-book examination and you are required to abide by the University's regulations regarding the conduct of exams
- Answer ALL questions.
- Use the provided space to answer the following questions. If more space is needed, use the back of the page.
- Read all the questions carefully before you start.

**Good luck**

| Question     | Max. Points | Points     |
|--------------|-------------|------------|
| 1            | 20          |            |
| 2            | 20          |            |
| 3A or 3B     | 20          |            |
| 4A or 4B     | 20          |            |
| 5A or 5B     | 20          |            |
| <b>Total</b> | <b>100</b>  | <b>100</b> |

**Question 1 (20 marks)****Part A (5 marks):**

Short questions.

- a) Is this code correct? If not, why.

```

library ieee;
use ieee.std_logic_1164.all;
entity mode_demo is
    port(
        a, b: in std_logic;
        x, y: out std_logic);
end mode_demo;
architecture wrong_arch of mode_demo is
begin
    x <= a and b;
    y <= not x;
end wrong_arch;

```

In architecture, it is trying to execute  $y \leftarrow \text{not } x$ ; But,  $x$  is defined as an **out** in the entity, so there will be an error. To execute this correctly, need a **tmp** to store  $x$ .

- b) Explain the difference in the output of these two pieces of code. Assume that  $a, b, c$  and  $y$  are signals. Note that  $tmp$  is a signal in the code on the left and a variable in the code on the right.

|                                                                                                                                                       |                                                                                                                                                                                             |
|-------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>process(a,b,c,tmp)</b><br><b>begin</b><br>$tmp \leq '0';$<br>$tmp \leq tmp \text{ or } a;$<br>$tmp \leq tmp \text{ or } b;$<br><b>end process;</b> | <b>process(a,b,c)</b><br>variable $tmp$ : std_logic;<br><b>begin</b><br>$tmp := '0';$<br>$tmp := tmp \text{ or } a;$<br>$tmp := tmp \text{ or } b;$<br>$y \leq tmp;$<br><b>end process;</b> |
|-------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

Left side, using signals (parallel logic)  
only execute  $\text{tmp} = \text{tmp} \text{ or } b$  } Variables use sequential logic  
so all statements will execute.

- ∵ On left hand side, tmp signal will only get result of last statement which is  $\text{tmp} \leftarrow \text{tmp} \text{ or } b$ ;

On right side all statements execute so y will get value  
of ('0' or a) or b.

- Let us consider a 4-bit binary counter that counts from 0 to 15 and then resets to 0 and starts up again. Do you need additional logic to go from 15 to 0 such as checking if the output of the counter is 15? Why?

No, we can use ~~or~~. unsigned (3 downto 0)  
as type of the counter.

$$\text{"1111"} + \text{"0001"} = \text{"0000"} \checkmark$$

- Let us consider a 4-bit shift register that only supports shift right operations. How many D flip-flops do we need to implement this shift register? If this register was modified to become a bi-directional shift register, how many D flip-flops would it take then to implement the new shift register?

4 DFFs ; for bi-directional , till 4 Dffs should be enough . ✓

- e) Combinational logic functions are sometimes implemented using look-up tables (like in Altera FPGAs). The look-up table contains results for all possible combinations of the input. If the maximum number of inputs per look-up table was 5, how many look-up tables would it take to implement a 7-variable function?

It requires 4 look-up tables to store outputs for all  $2^7$  combination of inputs as well as a 2-to-4 decoder to select one of these 4 look-up tables. The decoder can be implemented in the 5-th look-up table or as a separate logic.

### Part B (5 marks):

This question deals with bus-based systems.

- Draw a block diagram of a circuit that connects outputs of 4 blocks to a shared bus. All the lines are 16 bits wide. The output of the logic blocks are connected to the bus using tri-state buffers. Two bit select input are used to select/open one of the 4 tri-state buffers.
- Derive VHDL code for your block diagram.



```

library ieee;
use ieee.std_logic_1164.all;

entity tri-state-buffer is
port(
    a,b,c,d : in std_logic_vector(15 downto 0);
    y0,y1,y2,y3 : out std_logic_vector(15 downto 0);
    sel : in std_logic_vector(1 downto 0)
);
end tri-state-buffer;

```

Architecture arch of tri-state-buffer is

```
begin
    signal oe : std-logic-vector (3 downto 0);
    signal y0,y1,y2,y3 : std-logic-vector (15 downto 0);
    begin
        with sel select
            oe <= "0001" when "00",
            "0010" when "10",
            "0100" when "01",
            "1000" when others;
            y0 <= a when oe(0)='1' else 'Z';
            y1 <= b when oe(1)='1' else 'Z';
            y2 <= c when oe(2)='1' else 'Z';
            y3 <= d when oe(3)='1' else 'Z';
            data-bus <= y0;
            data-bus <= y1;
            data-bus <= y2;
            data-bus <= y3;
        end arch;
```

**Part C (5 marks):**

7

A synchronizer is presented in the figure below along with an illustrative timing diagram.

- a) What do the gray areas in the figure on the right represent?

*rising edge of the clock signal.*

- (b) Why must d remain stable during that time interval? What is metastability?  
*since Dff will sample d signal at 1/2 ~ SETUP AND HOLD TIME*

- c) Given the asynchronous input d shown in the figure, draw the waveforms for q<sub>0</sub> and d<sub>sync</sub>. (The initial part of q<sub>0</sub> was already drawn).

*see right figure*

- d) Two short pulses (lasting less than one clock period) are included in the d waveform. Are they always detected? Justify your answer.

*No, due to T<sub>cq</sub> clock to output delay it's not always detected at d<sub>sync</sub>.*



*WHENEVER THERE ARE SETUP AND HOLD TIME VIOLATIONS, THE F.F. ENTERS A STATE WHERE THE OUTPUT IS UNPREDICTABLE: THIS STATE IS KNOWN AS METASTABLE STATE.*

- a) Gray area also present setup and hold time around each rising edge of the clock.



**Part D (5 marks):**

Using a conditional signal assignment, write VHDL code for an 8-to-3 priority encoder.

| <i>v</i>          | <i>y</i> |
|-------------------|----------|
| 1 X X X X X X X X | 111      |
| 1 X X X X X X X   | 110      |
| 1 X X X X X X     | 101      |
| 1 X X X X X       | 100      |
| 1 X X X X         | 011      |
| 1 X X X           | 010      |
| 1 X X             | 001      |
| 1 X               | 000      |

no status required!  
ie.  $v = '0000\ 0000'$   
encoder is OFF.

```

library IEEE;
use IEEE.STD-LOGIC_1164.all;

entity p-enc is
  port (
    v : in STD-LOGIC-VECTOR(7 downto 0);
    y : out STD-LOGIC-VECTOR(2 downto 0)
  );
end p-enc;

architecture arch of p-enc is
begin
  y <= "111" when v(7) = '1' else
    "110" when v(6) = '1' else
    "101" when v(5) = '1' else
    "100" when v(4) = '1' else
    "011" when v(3) = '1' else
    "010" when v(2) = '1' else
    "001" when v(1) = '1' else
    "000" when others;
end arch;

```

**Question 2 (20 marks)****Part A (10 marks)**

A stack is a buffer in which the data is stored and retrieved in first-in-last-out fashion. A synchronous stack should consist of the following I/O signals:

- *data\_in* and *data\_out*: data to be written (also known as pushed) into and read (also known as popped) from the stack.
- *push* and *pop*: control signals to enable the push or pop operation.
- *full* and *empty*: status signals.
- *clk* and *reset*: the clock and reset signals.

We can use a register file, as in the figure below, to construct this circuit.

- (a) Consider a stack of four 16-bit words. Draw the FSM that includes control logic for implementing the stack controller.





**Question 2 Part B (10 marks)**

Derive the VHDL code for generating the *full* and *empty* status signals.

```

library ieee;
use ieee.std_logic_1164.all;

entity s_controller is
port(
    clk, reset : in std_logic;
    push, pop : in std_logic;
    full, empty : out std_logic
);
end s_controller;

architecture fsm of s_controller is
type state_type is (idle, ONE, Two, Three, Four);
signal state_rg, state_next : state_type;
begin
process (clk, reset)
begin
    if (reset = '1') then
        state_rg <= IDLE;
    elsif (clk'event and clk = '1') then
        state_rg <= state_next;
    end if;
end process;
process (state_rg, push, pop)
begin
    case state_rg is
        when IDLE =>
            if (push = '1') then
                state_next <= ONE;
            else
                state_next <= IDLE;
            end if;
        when ONE =>
            if (push = '1') then
                state_next <= Two;
            elsif (pop = '1') then
                state_next <= IDLE;
            else
                state_rg <= ONE;
            end if;
        when Two =>
            if (push = '1') then
                state_next <= Three;
            elsif (pop = '1') then
                state_next <= IDLE;
            else
                state_rg <= Two;
            end if;
        when Three =>
            if (push = '1') then
                state_next <= Four;
            elsif (pop = '1') then
                state_next <= IDLE;
            else
                state_rg <= Three;
            end if;
        when Four =>
            if (push = '1') then
                state_next <= One;
            elsif (pop = '1') then
                state_next <= IDLE;
            else
                state_rg <= Four;
            end if;
    end case;
end process;
end fsm;

```

when TWO  $\Rightarrow$

if (push = '1') then  
state-next  $\leftarrow$  Three;  
else (pull = '1') then  
state-next  $\leftarrow$  ONE;  
else  
state-next  $\leftarrow$  TWO;  
end if;

when THREE  $\Rightarrow$

if (push = '1') then  
state-next  $\leftarrow$  Four;  
else (pull = '1') then  
state-next  $\leftarrow$  TWO;  
else  
state-next  $\leftarrow$  Three;

when FOUR  $\Rightarrow$

if (pull = '1') then  
state-next  $\leftarrow$  Three;  
else  
state-next  $\leftarrow$  Four;  
end if;

end case;

end process;

empty  $\leftarrow$  '1' when state-my  $\leftarrow$  IDLE else  
'0';

Pull  $\leftarrow$  '1' when state-my  $\leftarrow$  FOUR else  
'0';

end FSM;



Please choose only one of Question 3A and Question 3B.

**Question 3A Part A (10 marks):**

This question deals with the synthesis of synchronous sequential circuits.

Use the method of partitioning minimization procedure to minimize the state table below, and show the sets P1 to P5 and your reduced table (hint: the reduced table contains 5 states).

| Present State<br>$y_2y_1y_0$ | Next states |             | Output Z |       |
|------------------------------|-------------|-------------|----------|-------|
|                              | X = 0       | X = 1       | X = 0    | X = 1 |
|                              | $Y_2Y_1Y_0$ | $Y_2Y_1Y_0$ |          |       |
| A                            | B           | C           | 0        | 0     |
| B                            | C           | D           | 1        | 0     |
| C                            | B           | E           | 0        | 0     |
| D                            | F           | E           | 0        | 0     |
| E                            | G           | A           | 0        | 0     |
| F                            | F           | H           | 1        | 0     |
| G                            | A           | D           | 1        | 0     |
| H                            | D           | F           | 1        | 1     |

$$P1 = (ABCDEFGH)$$

$$P2 =$$

$$P3 =$$

$$P4 =$$

$$P5 =$$

| Present State<br>$y_2y_1y_0$ | Next states |             | Output Z |       |
|------------------------------|-------------|-------------|----------|-------|
|                              | X = 0       | X = 1       | X = 0    | X = 1 |
|                              | $Y_2Y_1Y_0$ | $Y_2Y_1Y_0$ |          |       |
|                              |             |             |          |       |
|                              |             |             |          |       |
|                              |             |             |          |       |
|                              |             |             |          |       |
|                              |             |             |          |       |



**Question 3A Part B (10 marks):**

For the reduced table in Part A, determine the implementation equations for the next state and output variables by using a sequential state assignment.

Compare the output equation with that of an output generated by using a Gray state assignment (avoiding two variable changes). Use the circuit cost measure for your comparison.

**Question 3B (20 marks)**

Design an ASM capable of sequentially comparing two arbitrarily long serial bit streams. The machine must determine whether the last  $N$  bits are pairwise equal (this means that the effect of the oldest pair of bits must be discarded when a new pair is received).

The circuit ports are depicted in the figure below. The inputs (serial bit streams) are  $a$  and  $b$ , while the output is  $y$  ( $= '1'$  if all last  $N$  pairs of bits are equal). The comparator, in this case, is just a two-input XNOR gate, also depicted in the figure, which produces  $x = '1'$  when the inputs are equal. This signal ( $x$ ) will be the actual input to the FSM.

- Design an ASM that would work for any value of  $N$  (unsigned 8 bit number).
- Draw timing diagram for  $N=3$ . Please note that timing diagram also needs to show present state. If your ASM has a counter then present the value at the output of the counter (symbol  $i$  represents the counter). Please note that  $i=0$  is shown in the timing diagram (but you do not need to start from 0).





Please choose only one of Question 4A and Question 4B.

**Question 4A (20 marks):**

For the following flow table:

| Present State | Next State                        |     |     |     | Output z |
|---------------|-----------------------------------|-----|-----|-----|----------|
|               | w <sub>2</sub> w <sub>1</sub> =00 | 01  | 10  | 11  |          |
| A             | (A)                               | G   | E   | —   | 0        |
| B             | K                                 | —   | (B) | D   | 0        |
| C             | F                                 | (C) | —   | H   | 1        |
| D             | —                                 | C   | —   | (D) | 0        |
| E             | A                                 | —   | (E) | D   | 1        |
| F             | (F)                               | C   | J   | —   | 0        |
| G             | K                                 | (G) | —   | D   | 1        |
| H             | —                                 | —   | E   | (H) | 1        |
| J             | F                                 | —   | (J) | D   | 0        |
| K             | (K)                               | C   | B   | —   | 0        |

**Question 4A Part A (5 marks):**

- Show the reduced table using the partitioning procedure
- Show the merger diagram for the table

**Question 4A part B (5 marks)**

- For the reduced table in part A, , convert the table into the form of Mealy model and merge the compatible states
- Show the reduced flow table
- Show the relabeled flow table

**Question 4A part C (10 marks)**

- For the flow table in part B, show the initial transition diagram
- Modify the transition diagram to avoid any diagonals
- Show the final flow table, from the modified transition diagram
- Show the final excitation table, using a suitable state assignment.

**Question 4B (20 marks)**

An example of a 4-bit multiplication procedure is shown below.

| × | $a_3$     | $a_2$     | $a_1$     | $a_0$     | multiplicand |         |         |         |                |
|---|-----------|-----------|-----------|-----------|--------------|---------|---------|---------|----------------|
|   | $b_3$     | $b_2$     | $b_1$     | $b_0$     | multiplier   |         |         |         |                |
|   |           | $a_3 b_0$ | $a_2 b_0$ | $a_1 b_0$ | $a_0 b_0$    |         |         |         |                |
|   |           | $pp0_4$   | $pp0_3$   | $pp0_2$   | $pp0_1$      |         |         |         |                |
| + | $a_3 b_1$ | $a_2 b_1$ | $a_1 b_1$ | $a_0 b_1$ | $pp0_0$      |         |         |         |                |
|   | $pp1_4$   | $pp1_3$   | $pp1_2$   | $pp1_1$   | $pp1_0$      |         |         |         |                |
| + | $a_3 b_2$ | $a_2 b_2$ | $a_1 b_2$ | $a_0 b_2$ | $pp1$        |         |         |         |                |
|   | $pp2_4$   | $pp2_3$   | $pp2_2$   | $pp2_1$   | $pp2_0$      |         |         |         |                |
| + | $a_3 b_3$ | $a_2 b_3$ | $a_1 b_3$ | $a_0 b_3$ | $pp2$        |         |         |         |                |
|   | $pp3_4$   | $pp3_3$   | $pp3_2$   | $pp3_1$   | $pp3_0$      |         |         |         |                |
|   |           |           |           |           | $pp3$        |         |         |         |                |
|   | $pp3_4$   | $pp3_3$   | $pp3_2$   | $pp3_1$   | $pp3_0$      | $pp2_0$ | $pp1_0$ | $pp0_0$ | product $prod$ |

As can be seen, multiplication can be implemented by performing additions of shifted partial-products (pp). Now, let us consider an 8-bit multiplier. Let  $pp_7, pp_6, \dots, pp_1, pp_0$  be the shifted partial products of an 8-bit multiplier. The final product can be expressed as

$$y = pp_7 + pp_6 + \dots + pp_1 + pp_0$$

- (a) Arrange the additions as a tree to exploit parallelism and show the block diagram of your implementation. Make sure that you take care about the number of bits in each adder.
- (b) Assume that only one adder is provided. Derive the ASMD chart to perform multiplication based on just simple sequential additions.
- (c) Show block diagram of the datapath (including status signals).
- (d) Show the block diagram of the FSM.
- (e) What is the minimum and maximum number of clock cycles required to perform multiplication? What is the total number of bits in each register?

- (a)
- $PP_0 \Leftarrow "00000000" \& a_7 b_0 a_6 b_0 a_5 b_0 \dots a_0 b_0;$
  - $PP_1 \Leftarrow "0000000" \& a_7 b_1 a_6 b_1 a_5 b_1 \dots a_0 b_1 \& "0";$
  - $PP_2 \Leftarrow "000000" \& a_7 b_2 a_6 b_2 a_5 b_2 \dots a_0 b_2 \& "00";$
  - $PP_3 \Leftarrow "00000" \& a_7 b_3 a_6 b_3 \dots a_0 b_3 \& "000";$
  - $PP_7 \Leftarrow "0" \& a_7 b_7 a_6 b_7 \dots a_0 b_7 \& "0000000";$



- e) Minimum and maximum number of clock cycles required to perform multiplication = 1 when one operand is 0 and  $8+1=9$  otherwise.

What is the total number of bits in each register?  $n = 8$  bits,  $p = 16$  bits





c) Please choose one of Question 5A and Question 5B.

**Question 5A (20 marks):**

**Question 5A Part A (10 marks):**

All transitions between stable states in the following flow table have a Hamming distance of 2, since we are utilizing a one-hot state assignment for the table rows. We can add unstable states to try and reduce the Hamming distance by 1 for each transition from a stable state to another, passing through an unstable state. Your task is to determine the encodings of the unstable states, and the new values for the next state and output variables to reflect the addition of the unstable states. Complete the table below with your answers.

| Present State | Next State                        |     |     |     | Output z |
|---------------|-----------------------------------|-----|-----|-----|----------|
|               | w <sub>2</sub> w <sub>1</sub> =00 | 01  | 10  | 11  |          |
| A → 0001      | (A)                               | B   | D   | (A) | 1        |
| B → 0010      | C                                 | (B) | (B) | D   | 0        |
| C → 0100      | (C)                               | (C) | B   | A   | 0        |
| D → 1000      | A                                 | C   | (D) | (D) | 1        |

| Present State | Next State                        |     |     |     | Output z |
|---------------|-----------------------------------|-----|-----|-----|----------|
|               | w <sub>2</sub> w <sub>1</sub> =00 | 01  | 10  | 11  |          |
| A → 0001      | (A)                               |     |     | (A) | 1        |
| B → 0010      |                                   | (B) | (B) |     | 0        |
| C → 0100      | (C)                               | (C) |     |     | 0        |
| D → 1000      |                                   |     | (D) | (D) | 1        |
| E → _____     |                                   |     |     |     |          |
| F → _____     |                                   |     |     |     |          |
| G → _____     |                                   |     |     |     |          |
| H → _____     |                                   |     |     |     |          |
| J → _____     |                                   |     |     |     |          |
| K → _____     |                                   |     |     |     |          |



**Question 5A part B (10 marks)**

For the following logic circuit  $f(a, b, c, d)$ , determine the static hazards. Redesign the circuit to be hazard-free and having the same output (i.e.  $f$ ). Show the final circuit. Note that the apostrophe in the figure indicates the complemented form of the variable.



**Question 5B (20 marks)**

- Show a block diagram of a counter that counts from 30 until 1 and then again from 30 using methods that we studied in the section on sequential design (without using FSM, ASM or ASMD). The counter should generate 1 for one clock cycle (or less) every time the value at its output is 1.
- Show the ASM for this counter.
- Derive the VHDL code for part b).



```

entity mod_30 is
port(C pulse : out std-logic);
end;

end entity;

architecture beh of mod_30 is
type state is (INIT,COUNT);
c-reg, c-reg-next : std-logic-vector(c downto 0);
signed state;
cpt, cnt-next : unsigned(c downto 0);

begin
process(clk, reset)
begin
if (reset) then
  CNT <= 30;
  C-reg <= INIT;
elsif (clk='1' and clk'event) then
  C-reg <= c-reg-next;
  CNT <= CNT-next;
endif;
end process;
process (c-reg)
begin
  C-reg;
  case CNT is
    when INIT =>
      Cnt-next <= 30;
      C-reg-next <= COUNT;
    when COUNT =>
      Cnt-next <= CNT - 1;
      if (CnT-next = 1) then
        pulse = '1';
        C-reg-next <= INIT;
      else
        C-reg-next <= COUNT;
      end if;
    end case;
  end process;
end;

```