# The University of Alabama in Huntsville Electrical & Computer Engineering Department CPE 426 01

#### **Final Exam Solution**

1. (12 points) Modify the following VHDL model to use process(es) instead of blocks.

```
use WORK.TSL.all, WORK.SYS.all;
entity I8212 is
 generic (GDEL,FFDEL,BUFDEL: TIME);
port (DI: in WORD;
       DO: out WORD;
       NDS1, DS2, MD, STB, NCLR: in BIT;
       NINT: out BIT := '1');
end I8212;
architecture BEHAVIOR of I8212 is
begin
I8212_BLK: block
  signal S0, S1, S2, S3, S4: BIT;
  signal SRQ: BIT;
  signal Q: WORD;
begin
INT BLK:
block (S1='1' and S4='1')
begin
Q <= guarded DI after FFDEL;
Q <="00000000" after FFDEL when (S1='0' and S4='0') else
 DO <= Q after BUFDEL when (S3 = '1') else
      "ZZZZZZZZ" after BUFDEL;
end block INT BLK;
S0 <= not NDS1 and DS2 after GDEL;
S1 \le (S0 \text{ and } MD) \text{ or } (STB \text{ and not } MD) \text{ after } (2*GDEL);
S2 <= (S0 nor (not S4)) after GDEL;
S3 <= (S0 or MD) after GDEL;
S4 <= (S1 OR NCLR) after GDEL;
SRQ <= '1' after FFDEL when (S2= '0') else
       ^{'0'} after FFDEL when (S2= ^{'1'}) and (not STB'STABLE) and (STB=^{'0'}) else
        SRQ;
NINT <= not SRQ nor S0 after GDEL;
end block I8212 BLK;
end BEHAVIOR;
Solution:
use WORK.TSL.all, WORK.SYS.all;
entity I8212 is
generic (GDEL,FFDEL,BUFDEL: TIME);
```

```
architecture BEHAVIOR of I8212 is
  signal S0,S1,S2,S3,S4: BIT;
  signal SRQ: BIT;
  signal Q: WORD;
begin
  process (S1, S4, DI, S3, Q)
  begin
    if (S1 = '1' \text{ and } S4 = '1') then
      Q <= DI after FFDEL;
    elsif (S1 = '0' and S4 = '0') then
     Q <="00000000" after FFDEL;
    end if;
    if (S3 = '1') then
      DO <= Q after BUFDEL;
      DO <= "ZZZZZZZZ" after BUFDEL;
    end if;
  end process;
  SO <= not NDS1 and DS2 after GDEL;
  S1 <= (S0 and MD) or (STB and not MD) after (2*GDEL);
  S2 <= (S0 nor (not S4)) after GDEL;
 S3 <= (S0 or MD) after GDEL;
 S4 <= (S1 OR NCLR) after GDEL;
  SRQ <= '1' after FFDEL when (S2= '0') else
       '0' after FFDEL when (S2= '1') and (not STB'STABLE) and (STB='0') else
 NINT <= not SRQ nor S0 after GDEL;
end BEHAVIOR;
```

2. (5 points) What kind of hardware element will be inferred by a synthesis tool from the following model?

**Solution:** A latch, since the behavior is level sensitive.

```
library ieee;
use ieee.std_logic_1164.all;
entity WIDGET is
  Port (A, B : in SIGNED (0 to 2);
        CLK, RESET : in std logic;
        Z : out SIGNED(0 to 2));
end WIDGET;
architecture EXAMPLE of WIDGET is
begin
 process (CLK, RESET)
 begin
    if (RESET = '1' then)
      Z <= '0';
    elsif (CLK = '1') then
      Z <= A nor B;
    end if;
  end process;
end EXAMPLE;
```

3. (5 points) Draw the transistor-level diagram of a CMOS inverter.

### Solution:



# Consider the following VHDL code:

```
entity SCHED2 is
port (A, B, C, D, E, F: in INTEGER;
CLK: in BIT;
W, X, Y: out INTEGER);
end SCHED2;

--- Architecture declaration

architecture HIGH_LEVEL of SCHED2 is
signal Z: INTEGER;
begin
X <= (A - B) * Z;
Y <= (A * B) + Z;
Z <= (C * D) + D * (E + F);
end HIGH_LEVEL;
```

4. (18 points) The following tasks refer to the VHDL code above. Assume that there are no hardware constraints.

a. (6 points) Draw a data flow graph.

Solution:



b. (6 points) Derive an ASAP schedule.

# Solution:



Ready Schedule {1, 2, 3, 4} {1, 2, 3, 4} {5} {5} {6} {6} {7, 8] {7, 8}

# Solution:

c. (6 points) Derive an ALAP schedule.

# Solution:



| Ready         | Schedule      |
|---------------|---------------|
| {7, 8]        | {7, 8}        |
| $\{1, 4, 6\}$ | $\{1, 4, 6\}$ |
| $\{2, 5\}$    | $\{2, 5\}$    |
| {3}           | {3}           |

5. (10 points) Derive a list schedule using the critical path priority metric for the VHDL code above, using the following hardware constraint; all operations are done in an ALU module and there are two ALU modules available.

# Solution:



6. (10 points) For the data lifetime chart shown, use the left edge algorithm to obtain an efficient register allocation.

|    | A | В | С | D | Е | F | G | Н | I | J | K | L |
|----|---|---|---|---|---|---|---|---|---|---|---|---|
| S1 |   |   | X | X |   |   | X |   |   |   |   |   |
| S2 |   | X | X |   | X |   | X |   |   | X |   |   |
| S3 |   | X |   |   |   | X | X | X |   | X |   |   |
| S4 | X | X |   |   |   | X |   |   | X |   |   | X |
| S5 | X |   |   |   |   | X |   |   | X |   | X | X |

## Solution:

|    | D | С | G | Ε | J | В | Η | F | Α | I | L | K |
|----|---|---|---|---|---|---|---|---|---|---|---|---|
| S1 | X | X | X |   |   |   |   |   |   |   |   |   |
| S2 |   | X | X | X | X | X |   |   |   |   |   |   |
| S3 |   |   | X |   | X | X | X | X |   |   |   |   |
| S4 |   |   |   |   |   | X |   | X | X | X | X |   |
| S5 |   |   |   |   |   |   |   | X | X | X | X | X |

|    | R1 | R2 | R3 | R4 | R5 |
|----|----|----|----|----|----|
| S1 | D  | C  | G  |    |    |
| S2 | Е  | C  | G  | J  | В  |
| S3 | Н  | F  | G  | J  | В  |
| S4 | A  | F  | I  | L  | В  |
| S5 | A  | F  | I  | L  | K  |

7. (1 point) \_\_\_\_Synthesis\_\_\_\_\_ is the process of transforming a behavioral description into a structural gate-level circuit.

8. (18. points) Design a Moore state machine in VHDL which converts NRZ (non-return-to-zero) coding to Manchester coding. In NRZ coding, each bit is transmitted for one bit time without any change. For the Manchester code, a 0 is transmitted as 0 for the first half of the bit time and 1 for the second half, but a 1 is transmitted as 1 for the first half and 0 for the second half. In order to do this conversion, use a clock(CLOCK2) that is twice the frequency of the basic clock. Note that if the NRZ bit is 0, it will be 0 for two CLOCK2 periods. Similarly, if the NRZ bit is 1, it will be 1 for two CLOCK2 periods. Your design should have an active low synchronous reset and work with CLOCK2.



### **Solution:**

```
entity NRZ2MAN is
  port (NRZ, CLOCK2, RESET : in BIT;
                        MAN : out BIT);
end NRZ2MAN;
architecture BEHAVE of NRZ2MAN is
  type STATE TYPE is (S0, S1, S2, S3);
  signal CURRENT_STATE, NEXT_STATE : STATE_TYPE;
  process (CURRENT STATE)
  begin
    case CURRENT_STATE is
      when S0 \Rightarrow if (NRZ = '0') then
                    NEXT STATE <= S1;
                    NEXT STATE <= S3;
                 end if;
      when S1 => NEXT STATE <= S2;
      when S2 \Rightarrow if NRZ = '0' then
                   NEXT STATE <= S1;
                 else
                   NEXT STATE <= S3;
                 end if;
      when S3 => NEXT STATE <= S0;
      when OTHERS => NEXT STATE <= S0;
    end case;
  end process;
  process (RESET, CLOCK2)
  begin
    if (CLOCK2'EVENT and CLOCK2 = '1') then
      if (RESET = '0') then
        CURRENT STATE <= S0;
      else
        CURRENT_STATE <= NEXT_STATE;
      end if;
```

```
end if;
end process;
process (CURRENT_STATE)
begin
   case CURRENT_STATE is
   when S0 | S1 => MAN <= '0';
   when S2 | S3 => MAN <= '1';
   when OTHERS => MAN <= '0';
   end case;
end process;
end BEHAVE;</pre>
```

9. (12 points) Write a VHDL entity and architecture of a two-input AND gate with the generics, TPLH an

### Solution:

```
entity AND2 is
 generic (TPLH, TPHL : time);
 port (I1, I2 : in BIT;
            O : out BIT);
end AND2;
architecture BEHAVE of AND2 is
  process (I1, I2)
    variable O_INT, LAST : BIT;
    O INT := I1 and I2;
    \overline{\text{if}} (LAST = '0' and O INT = '1') then
      O <= '1' after TPLH;
    elsif (LAST = '1'and O_INT = '0') then
      O <= '0' after TPHL;
    end if;
    LAST := O INT;
  end process;
end BEHAVE;
```

10. (5 points) If the NRE costs for FPGA and CBIC circuits are \$21,000 and \$187,000, respectively, and the cost of individual parts for FPGA and CBIC circuits are \$18 and \$5, respectively, what is the break-even manufacturing volume for these two types of circuits?

### Solution:

x — the number of units 18x + 21,000 = 5x + 187,000 13x = 166,000x = 12769

11. (1 point) A(n) \_\_\_\_ASIC\_\_\_\_\_\_ is an integrated circuit produced for a specific application and produced in relatively small volumes.

| 12. (1 point)                   | VHDL          | is an annoyingly strongly typed language.  |
|---------------------------------|---------------|--------------------------------------------|
| 13. (1 point) circuit has a sin |               | removes the hierarchy in a circuit, so the |
| 14. (1 point)                   | Communication | is the hardest problem.                    |